Table: aws_ecr_repository - Query AWS ECR Repositories using SQL
The AWS ECR Repository is a managed docker container registry service provided by Amazon Web Services. It makes it easy for developers to store, manage, and deploy Docker container images. Amazon ECR eliminates the need to operate your own container repositories or worry about scaling the underlying infrastructure.
Table Usage Guide
The aws_ecr_repository
table in Steampipe provides you with information about repositories within AWS Elastic Container Registry (ECR). This table allows you, as a DevOps engineer, to query repository-specific details, including repository ARN, repository URI, and creation date. You can utilize this table to gather insights on repositories, such as repository policies, image scanning configurations, image tag mutability, and more. The schema outlines the various attributes of the ECR repository for you, including the repository name, creation date, and associated tags.
Examples
Basic info
Explore which Elastic Container Registry (ECR) repositories are available in your AWS account and determine their associated details such as creation date and region. This can be beneficial in managing your repositories and understanding their distribution across different regions.
select repository_name, registry_id, arn, repository_uri, created_at, region, account_idfrom aws_ecr_repository;
select repository_name, registry_id, arn, repository_uri, created_at, region, account_idfrom aws_ecr_repository;
List repositories which are not using Customer Managed Keys (CMK) for encryption
Determine the areas in which repositories are not utilizing Customer Managed Keys for encryption. This is useful for enhancing security measures by identifying potential vulnerabilities in your encryption methods.
select repository_name, encryption_configuration ->> 'EncryptionType' as encryption_type, encryption_configuration ->> 'KmsKey' as kms_keyfrom aws_ecr_repositorywhere encryption_configuration ->> 'EncryptionType' = 'AES256';
select repository_name, json_extract(encryption_configuration, '$.EncryptionType') as encryption_type, json_extract(encryption_configuration, '$.KmsKey') as kms_keyfrom aws_ecr_repositorywhere json_extract(encryption_configuration, '$.EncryptionType') = 'AES256';
List repositories with automatic image scanning disabled
Identify instances where automatic image scanning is disabled in repositories. This is useful to ensure security measures are consistently applied across all repositories.
select repository_name, image_scanning_configuration ->> 'ScanOnPush' as scan_on_pushfrom aws_ecr_repositorywhere image_scanning_configuration ->> 'ScanOnPush' = 'false';
select repository_name, json_extract(image_scanning_configuration, '$.ScanOnPush') as scan_on_pushfrom aws_ecr_repositorywhere json_extract(image_scanning_configuration, '$.ScanOnPush') = 'false';
List images for each repository
Determine the images associated with each repository to understand their size, push time, last pull time, and scan status. This can help in managing repository resources, tracking image usage, and ensuring security compliance.
select r.repository_name as repository_name, i.image_digest as image_digest, i.image_tags as image_tags, i.image_pushed_at as image_pushed_at, i.image_size_in_bytes as image_size_in_bytes, i.last_recorded_pull_time as last_recorded_pull_time, i.registry_id as registry_id, i.image_scan_status as image_scan_statusfrom aws_ecr_repository as r, aws_ecr_image as iwhere r.repository_name = i.repository_name;
select r.repository_name as repository_name, i.image_digest as image_digest, i.image_tags as image_tags, i.image_pushed_at as image_pushed_at, i.image_size_in_bytes as image_size_in_bytes, i.last_recorded_pull_time as last_recorded_pull_time, i.registry_id as registry_id, i.image_scan_status as image_scan_statusfrom aws_ecr_repository as r join aws_ecr_image as i on r.repository_name = i.repository_name;
List images with failed scans
Identify instances where image scans have failed in your AWS ECR repositories. This can help in diagnosing and rectifying issues related to image scanning, thereby improving the security and reliability of your container images.
select r.repository_name as repository_name, i.image_digest as image_digest, i.image_scan_status as image_scan_statusfrom aws_ecr_repository as r, aws_ecr_image as iwhere r.repository_name = i.repository_name and i.image_scan_status ->> 'Status' = 'FAILED';
select r.repository_name as repository_name, i.image_digest as image_digest, json_extract(i.image_scan_status, '$.Status') as image_scan_statusfrom aws_ecr_repository as r join aws_ecr_image as i on r.repository_name = i.repository_namewhere json_extract(i.image_scan_status, '$.Status') = 'FAILED';
List repositories whose tag immutability is disabled
Determine the areas in which image tag immutability is disabled within your repositories. This allows you to identify and manage potential vulnerabilities in your AWS Elastic Container Registry.
select repository_name, image_tag_mutabilityfrom aws_ecr_repositorywhere image_tag_mutability = 'IMMUTABLE';
select repository_name, image_tag_mutabilityfrom aws_ecr_repositorywhere image_tag_mutability = 'IMMUTABLE';
List repositories whose lifecycle policy rule is not configured to remove untagged and old images
Determine the areas in which repositories are not configured to automatically clean up untagged and old images. This can help in managing storage and avoiding unnecessary costs associated with unused or outdated images.
select repository_name, r -> 'selection' ->> 'tagStatus' as tag_status, r -> 'selection' ->> 'countType' as count_typefrom aws_ecr_repository, jsonb_array_elements(lifecycle_policy -> 'rules') as rwhere ( (r -> 'selection' ->> 'tagStatus' <> 'untagged') and (r -> 'selection' ->> 'countType' <> 'sinceImagePushed') );
select repository_name, json_extract(r.value, '$.selection.tagStatus') as tag_status, json_extract(r.value, '$.selection.countType') as count_typefrom aws_ecr_repository, json_each(lifecycle_policy, 'rules') as rwhere ( ( json_extract(r.value, '$.selection.tagStatus') <> 'untagged' ) and ( json_extract(r.value, '$.selection.countType') <> 'sinceImagePushed' ) );
List repository policy statements that grant full access for each repository
Identify instances where full access has been granted to each repository. This is useful to review and manage access permissions, ensuring optimal security and control over your data repositories.
select title, p as principal, a as action, s ->> 'Effect' as effect, s -> 'Condition' as conditionsfrom aws_ecr_repository, jsonb_array_elements(policy -> 'Statement') as s, jsonb_array_elements_text(s -> 'Principal' -> 'AWS') as p, jsonb_array_elements_text(s -> 'Action') as awhere s ->> 'Effect' = 'Allow' and a in ('*', 'ecr:*');
select title, json_extract(p.value, '$') as principal, json_extract(a.value, '$') as action, json_extract(s.value, '$.Effect') as effect, json_extract(s.value, '$.Condition') as conditionsfrom aws_ecr_repository, json_each(policy, '$.Statement') as s, json_each(json_extract(s.value, '$.Principal.AWS')) as p, json_each(json_extract(s.value, '$.Action')) as awhere json_extract(s.value, '$.Effect') = 'Allow' and ( json_extract(a.value, '$') = '*' or json_extract(a.value, '$') = 'ecr:*' );
List repository scanning configuration settings
Determine the frequency and triggers for scanning within your repositories to optimize security checks and resource management. This enables you to understand the efficiency and effectiveness of your scanning configurations.
select repository_name, r ->> 'AppliedScanFilters' as applied_scan_filters, r ->> 'RepositoryArn' as repository_arn, r ->> 'ScanFrequency' as scan_frequency, r ->> 'ScanOnPush' as scan_on_pushfrom aws_ecr_repository, jsonb_array_elements( repository_scanning_configuration -> 'ScanningConfigurations' ) as r;
select repository_name, json_extract(r.value, '$.AppliedScanFilters') as applied_scan_filters, json_extract(r.value, '$.RepositoryArn') as repository_arn, json_extract(r.value, '$.ScanFrequency') as scan_frequency, json_extract(r.value, '$.ScanOnPush') as scan_on_pushfrom aws_ecr_repository, json_each( repository_scanning_configuration, '$.ScanningConfigurations' ) as r;
List repositories where the scanning frequency is set to manual
Determine the areas in your AWS ECR repositories where the scanning frequency is manually set. This allows you to identify instances where automated scanning is not enabled, potentially leaving your repositories vulnerable to undetected issues.
select repository_name, r ->> 'RepositoryArn' as repository_arn, r ->> 'ScanFrequency' as scan_frequencyfrom aws_ecr_repository, jsonb_array_elements( repository_scanning_configuration -> 'ScanningConfigurations' ) as rwhere r ->> 'ScanFrequency' = 'MANUAL';
select repository_name, json_extract(r.value, '$.RepositoryArn') as repository_arn, json_extract(r.value, '$.ScanFrequency') as scan_frequencyfrom aws_ecr_repository, json_each( repository_scanning_configuration, '$.ScanningConfigurations' ) as rwhere json_extract(r.value, '$.ScanFrequency') = 'MANUAL';
List repositories with scan-on-push is disabled
Identify instances where the scan-on-push feature is disabled in your repositories. This can help improve your security measures by ensuring all repositories are scanned for vulnerabilities upon each push.
select repository_name, r ->> 'RepositoryArn' as repository_arn, r ->> 'ScanOnPush' as scan_on_pushfrom aws_ecr_repository, jsonb_array_elements( repository_scanning_configuration -> 'ScanningConfigurations' ) as rwhere r ->> 'ScanOnPush' = 'false';
select repository_name, json_extract(r.value, '$.RepositoryArn') as repository_arn, json_extract(r.value, '$.ScanOnPush') as scan_on_pushfrom aws_ecr_repository, json_each( repository_scanning_configuration, 'ScanningConfigurations' ) as rwhere json_extract(r.value, '$.ScanOnPush') = 'false';
Query examples
- ecr_policy_std_for_ecr_repository
- ecr_repositories_for_codebuild_project
- ecr_repositories_for_codepipeline_pipeline
- ecr_repositories_for_ecs_task_definition
- ecr_repository_1_year_count
- ecr_repository_24_hours_count
- ecr_repository_30_90_days_count
- ecr_repository_30_days_count
- ecr_repository_90_365_days_count
- ecr_repository_age_table
- ecr_repository_by_account
- ecr_repository_by_creation_month
- ecr_repository_by_region
- ecr_repository_count
- ecr_repository_encrypted
- ecr_repository_encryption_disabled_count
- ecr_repository_input
- ecr_repository_overview
- ecr_repository_public_access
- ecr_repository_scan_on_push
- ecr_repository_scan_on_push_disabled_count
- ecr_repository_tag_immutability
- ecr_repository_tag_mutability_count
- ecr_repository_tagging
- ecr_repository_tagging_disabled_count
- ecr_repository_tags
- ecs_task_definitions_for_ecr_repository
- kms_keys_for_ecr_repository
Control examples
- All Controls > ECR > ECR repositories should prohibit public access
- AWS Foundational Security Best Practices > Elastic Container Registry > 1 ECR private repositories should have image scanning configured
- AWS Foundational Security Best Practices > Elastic Container Registry > 2 ECR private repositories should have tag immutability configured
- AWS Foundational Security Best Practices > Elastic Container Registry > 3 ECR repositories should have at least one lifecycle policy configured
- ECR private repositories should have tag immutability configured
- ECR repositories should have image scan on push enabled
- ECR repositories should have lifecycle policies configured
Schema for aws_ecr_repository
Name | Type | Operators | Description |
---|---|---|---|
_ctx | jsonb | Steampipe context in JSON form. | |
account_id | text | =, !=, ~~, ~~*, !~~, !~~* | The AWS Account ID in which the resource is located. |
akas | jsonb | Array of globally unique identifier strings (also known as) for the resource. | |
arn | text | The Amazon Resource Name (ARN) that identifies the repository. | |
created_at | timestamp with time zone | The date and time, in JavaScript date format, when the repository was created. | |
encryption_configuration | jsonb | The encryption configuration for the repository. | |
image_scanning_configuration | jsonb | The image scanning configuration for a repository. | |
image_tag_mutability | text | The tag mutability setting for the repository. | |
last_evaluated_at | timestamp with time zone | The time stamp of the last time that the lifecycle policy was run. | |
lifecycle_policy | jsonb | The JSON lifecycle policy text. | |
partition | text | The AWS partition in which the resource is located (aws, aws-cn, or aws-us-gov). | |
policy | jsonb | The JSON repository policy text associated with the repository. | |
policy_std | jsonb | Contains the policy in a canonical form for easier searching. | |
region | text | The AWS Region in which the resource is located. | |
registry_id | text | = | The AWS account ID associated with the registry that contains the repositories to be described. |
repository_name | text | = | The name of the repository. |
repository_scanning_configuration | jsonb | Gets the scanning configuration for one or more repositories. | |
repository_uri | text | The URI for the repository. | |
sp_connection_name | text | =, !=, ~~, ~~*, !~~, !~~* | Steampipe connection name. |
sp_ctx | jsonb | Steampipe context in JSON form. | |
tags | jsonb | A map of tags for the resource. | |
tags_src | jsonb | A list of tags assigned to the Repository. | |
title | text | Title of the resource. |
Export
This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.
You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh
script:
/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- aws
You can pass the configuration to the command with the --config
argument:
steampipe_export_aws --config '<your_config>' aws_ecr_repository