Compare commits
	
		
			89 Commits 
		
	
	
	| Author | SHA1 | Date | 
|---|---|---|
|  | 28fdb31ff3 | |
|  | 2064b45545 | |
|  | 5e57cd1181 | |
|  | 97e31439e8 | |
|  | 3a0796b57f | |
|  | 5b7b28b1cc | |
|  | abc9fb3154 | |
|  | d468688814 | |
|  | a99b2f88fc | |
|  | 0d7fae8057 | |
|  | 9832253cb7 | |
|  | 09e05bbdf6 | |
|  | 4384bb23be | |
|  | 722c6681a5 | |
|  | 0bd2ba43c1 | |
|  | 18836d8e24 | |
|  | 997e14a133 | |
|  | 67d87fe2c8 | |
|  | 1287044d73 | |
|  | 9fa22322ec | |
|  | 738e2ed2fd | |
|  | 5497b8b59c | |
|  | 2d98472de9 | |
|  | 3c28a369b4 | |
|  | 072e0d514c | |
|  | 65c0768122 | |
|  | 3d793fe111 | |
|  | 9fc23e88e3 | |
|  | bdf14dc173 | |
|  | 21ddfdf39a | |
|  | d5f9e03fca | |
|  | 9b3389107c | |
|  | 184bdaa072 | |
|  | 5c6bc94683 | |
|  | caf4058643 | |
|  | ef38ec311a | |
|  | d52e8ef81c | |
|  | 9644ab7025 | |
|  | 7abd1d5126 | |
|  | 1a81202c4f | |
|  | d1ab30dc54 | |
|  | f25ff28d1c | |
|  | e0c62a93a1 | |
|  | 34f6d346b5 | |
|  | a547b56e5b | |
|  | b7f56fce8a | |
|  | 3d100841f6 | |
|  | 5713f8474e | |
|  | 0a8c41d6e2 | |
|  | 6d4b68b490 | |
|  | b7f1bbcce7 | |
|  | abd3abc99c | |
|  | ac38c32963 | |
|  | 74a5d14239 | |
|  | 2f4f00e4c6 | |
|  | 67c184546c | |
|  | 3d4cc89e85 | |
|  | 6cc823a6c4 | |
|  | d94e792124 | |
|  | 033db0da30 | |
|  | 09c2ae9716 | |
|  | ba56f006fc | |
|  | 75bf9a79af | |
|  | ed2698b25f | |
|  | 52ad1d2e01 | |
|  | f18ea97ee4 | |
|  | 07d7ee0dc6 | |
|  | 327cd5a69d | |
|  | e217ef3a2d | |
|  | 407f438d11 | |
|  | 28e19ee314 | |
|  | 7ca345011a | |
|  | 02b671aa02 | |
|  | 06895751d1 | |
|  | 02c9ff3be2 | |
|  | 5d8785b43a | |
|  | 7a65d3de5d | |
|  | bd2f40996a | |
|  | 9fd0581bf0 | |
|  | eefb7e8744 | |
|  | cb13d66af0 | |
|  | 1f36f5b7a2 | |
|  | bcb47c2c49 | |
|  | 8165a5b270 | |
|  | 29df2a9f8c | |
|  | 2b0e0e02ba | |
|  | fe7fd06c5d | |
|  | 3b8fed7e4b | |
|  | 90de1764cc | 
|  | @ -19,7 +19,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Stop docker |         name: Stop docker | ||||||
|         run: | |         run: | | ||||||
|  | @ -43,7 +43,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to GitHub Container Registry |         name: Login to GitHub Container Registry | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -60,7 +60,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to GitHub Container Registry |         name: Login to GitHub Container Registry | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -85,7 +85,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to ACR |         name: Login to ACR | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -105,7 +105,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to Docker Hub |         name: Login to Docker Hub | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -124,7 +124,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to ECR |         name: Login to ECR | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -144,10 +144,10 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Configure AWS Credentials |         name: Configure AWS Credentials | ||||||
|         uses: aws-actions/configure-aws-credentials@v4 |         uses: aws-actions/configure-aws-credentials@v5 | ||||||
|         with: |         with: | ||||||
|           aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} |           aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  | @ -169,7 +169,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to Public ECR |         name: Login to Public ECR | ||||||
|         continue-on-error: ${{ matrix.os == 'windows-latest' }} |         continue-on-error: ${{ matrix.os == 'windows-latest' }} | ||||||
|  | @ -192,10 +192,10 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Configure AWS Credentials |         name: Configure AWS Credentials | ||||||
|         uses: aws-actions/configure-aws-credentials@v4 |         uses: aws-actions/configure-aws-credentials@v5 | ||||||
|         with: |         with: | ||||||
|           aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} |           aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  | @ -218,7 +218,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to GitHub Container Registry |         name: Login to GitHub Container Registry | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -238,7 +238,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to GitLab |         name: Login to GitLab | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -258,7 +258,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to Google Artifact Registry |         name: Login to Google Artifact Registry | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -278,7 +278,7 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Login to Google Container Registry |         name: Login to Google Container Registry | ||||||
|         uses: ./ |         uses: ./ | ||||||
|  | @ -286,3 +286,73 @@ jobs: | ||||||
|           registry: gcr.io |           registry: gcr.io | ||||||
|           username: _json_key |           username: _json_key | ||||||
|           password: ${{ secrets.GCR_JSON_KEY }} |           password: ${{ secrets.GCR_JSON_KEY }} | ||||||
|  | 
 | ||||||
|  |   registry-auth: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Login to registries | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           registry-auth: | | ||||||
|  |             - username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|  |               password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|  |             - registry: ghcr.io | ||||||
|  |               username: ${{ github.actor }} | ||||||
|  |               password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |             - registry: public.ecr.aws | ||||||
|  |               username: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|  |               password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |             - registry: registry.gitlab.com | ||||||
|  |               username: ${{ secrets.GITLAB_USERNAME }} | ||||||
|  |               password: ${{ secrets.GITLAB_TOKEN }} | ||||||
|  | 
 | ||||||
|  |   registry-auth-dup: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Login to registries | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           registry-auth: | | ||||||
|  |             - registry: ghcr.io | ||||||
|  |               username: ${{ github.actor }} | ||||||
|  |               password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |             - registry: public.ecr.aws | ||||||
|  |               username: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||||||
|  |               password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|  |             - registry: ghcr.io | ||||||
|  |               username: ${{ github.actor }} | ||||||
|  |               password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  | 
 | ||||||
|  |   registry-auth-exclusive: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Login to registries | ||||||
|  |         id: login | ||||||
|  |         continue-on-error: true | ||||||
|  |         uses: ./ | ||||||
|  |         with: | ||||||
|  |           registry: ghcr.io | ||||||
|  |           username: ${{ github.actor }} | ||||||
|  |           password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |           registry-auth: | | ||||||
|  |             - username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|  |               password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|  |       - | ||||||
|  |         name: Check | ||||||
|  |         run: | | ||||||
|  |           if [ "${{ steps.login.outcome }}" != "failure" ] || [ "${{ steps.login.conclusion }}" != "success" ]; then | ||||||
|  |             echo "::error::Should have failed" | ||||||
|  |             exit 1 | ||||||
|  |           fi | ||||||
|  |  | ||||||
|  | @ -31,10 +31,10 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Initialize CodeQL |         name: Initialize CodeQL | ||||||
|         uses: github/codeql-action/init@v3 |         uses: github/codeql-action/init@v4 | ||||||
|         with: |         with: | ||||||
|           languages: ${{ matrix.language }} |           languages: ${{ matrix.language }} | ||||||
|           config: | |           config: | | ||||||
|  | @ -42,9 +42,9 @@ jobs: | ||||||
|               - src |               - src | ||||||
|       - |       - | ||||||
|         name: Autobuild |         name: Autobuild | ||||||
|         uses: github/codeql-action/autobuild@v3 |         uses: github/codeql-action/autobuild@v4 | ||||||
|       - |       - | ||||||
|         name: Perform CodeQL Analysis |         name: Perform CodeQL Analysis | ||||||
|         uses: github/codeql-action/analyze@v3 |         uses: github/codeql-action/analyze@v4 | ||||||
|         with: |         with: | ||||||
|           category: "/language:${{matrix.language}}" |           category: "/language:${{matrix.language}}" | ||||||
|  |  | ||||||
|  | @ -0,0 +1,17 @@ | ||||||
|  | name: pr-assign-author | ||||||
|  | 
 | ||||||
|  | permissions: | ||||||
|  |   contents: read | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   pull_request_target: | ||||||
|  |     types: | ||||||
|  |       - opened | ||||||
|  |       - reopened | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   run: | ||||||
|  |     uses: crazy-max/.github/.github/workflows/pr-assign-author.yml@1b673f36fad86812f538c1df9794904038a23cbf | ||||||
|  |     permissions: | ||||||
|  |       contents: read | ||||||
|  |       pull-requests: write | ||||||
|  | @ -0,0 +1,21 @@ | ||||||
|  | name: publish | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: | ||||||
|  |       - published | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   publish: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       contents: read | ||||||
|  |       id-token: write | ||||||
|  |       packages: write | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Checkout | ||||||
|  |         uses: actions/checkout@v5 | ||||||
|  |       - | ||||||
|  |         name: Publish | ||||||
|  |         uses: actions/publish-immutable-action@v0.0.4 | ||||||
|  | @ -17,15 +17,16 @@ jobs: | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Test |         name: Test | ||||||
|         uses: docker/bake-action@v5 |         uses: docker/bake-action@v6 | ||||||
|         with: |         with: | ||||||
|  |           source: . | ||||||
|           targets: test |           targets: test | ||||||
|       - |       - | ||||||
|         name: Upload coverage |         name: Upload coverage | ||||||
|         uses: codecov/codecov-action@v4 |         uses: codecov/codecov-action@v5 | ||||||
|         with: |         with: | ||||||
|           file: ./coverage/clover.xml |           files: ./coverage/clover.xml | ||||||
|           token: ${{ secrets.CODECOV_TOKEN }} |           token: ${{ secrets.CODECOV_TOKEN }} | ||||||
|  |  | ||||||
|  | @ -15,16 +15,17 @@ jobs: | ||||||
|   prepare: |   prepare: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     outputs: |     outputs: | ||||||
|       targets: ${{ steps.targets.outputs.matrix }} |       targets: ${{ steps.generate.outputs.targets }} | ||||||
|     steps: |     steps: | ||||||
|       - |       - | ||||||
|         name: Checkout |         name: Checkout | ||||||
|         uses: actions/checkout@v4 |         uses: actions/checkout@v5 | ||||||
|       - |       - | ||||||
|         name: Targets matrix |         name: List targets | ||||||
|         id: targets |         id: generate | ||||||
|         run: | |         uses: docker/bake-action/subaction/list-targets@v6 | ||||||
|           echo "matrix=$(docker buildx bake validate --print | jq -cr '.group.validate.targets')" >> $GITHUB_OUTPUT |         with: | ||||||
|  |           target: validate | ||||||
| 
 | 
 | ||||||
|   validate: |   validate: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  | @ -35,11 +36,8 @@ jobs: | ||||||
|       matrix: |       matrix: | ||||||
|         target: ${{ fromJson(needs.prepare.outputs.targets) }} |         target: ${{ fromJson(needs.prepare.outputs.targets) }} | ||||||
|     steps: |     steps: | ||||||
|       - |  | ||||||
|         name: Checkout |  | ||||||
|         uses: actions/checkout@v4 |  | ||||||
|       - |       - | ||||||
|         name: Validate |         name: Validate | ||||||
|         uses: docker/bake-action@v5 |         uses: docker/bake-action@v6 | ||||||
|         with: |         with: | ||||||
|           targets: ${{ matrix.target }} |           targets: ${{ matrix.target }} | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										12
									
								
								.yarnrc.yml
								
								
								
								
							
							
						
						
									
										12
									
								
								.yarnrc.yml
								
								
								
								
							|  | @ -1,3 +1,9 @@ | ||||||
|  | # https://yarnpkg.com/configuration/yarnrc | ||||||
|  | 
 | ||||||
|  | compressionLevel: mixed | ||||||
|  | enableGlobalCache: false | ||||||
|  | enableHardenedMode: true | ||||||
|  | 
 | ||||||
| logFilters: | logFilters: | ||||||
|   - code: YN0013 |   - code: YN0013 | ||||||
|     level: discard |     level: discard | ||||||
|  | @ -5,9 +11,7 @@ logFilters: | ||||||
|     level: discard |     level: discard | ||||||
|   - code: YN0076 |   - code: YN0076 | ||||||
|     level: discard |     level: discard | ||||||
|  |   - code: YN0086 | ||||||
|  |     level: discard | ||||||
| 
 | 
 | ||||||
| nodeLinker: node-modules | nodeLinker: node-modules | ||||||
| 
 |  | ||||||
| plugins: |  | ||||||
|   - path: .yarn/plugins/@yarnpkg/plugin-interactive-tools.cjs |  | ||||||
|     spec: "@yarnpkg/plugin-interactive-tools" |  | ||||||
|  |  | ||||||
							
								
								
									
										107
									
								
								README.md
								
								
								
								
							
							
						
						
									
										107
									
								
								README.md
								
								
								
								
							|  | @ -24,6 +24,7 @@ ___ | ||||||
|   * [OCI Oracle Cloud Infrastructure Registry (OCIR)](#oci-oracle-cloud-infrastructure-registry-ocir) |   * [OCI Oracle Cloud Infrastructure Registry (OCIR)](#oci-oracle-cloud-infrastructure-registry-ocir) | ||||||
|   * [Quay.io](#quayio) |   * [Quay.io](#quayio) | ||||||
|   * [DigitalOcean](#digitalocean-container-registry) |   * [DigitalOcean](#digitalocean-container-registry) | ||||||
|  |   * [Authenticate to multiple registries](#authenticate-to-multiple-registries) | ||||||
| * [Customizing](#customizing) | * [Customizing](#customizing) | ||||||
|   * [inputs](#inputs) |   * [inputs](#inputs) | ||||||
| * [Contributing](#contributing) | * [Contributing](#contributing) | ||||||
|  | @ -51,7 +52,7 @@ jobs: | ||||||
|         name: Login to Docker Hub |         name: Login to Docker Hub | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           username: ${{ secrets.DOCKERHUB_USERNAME }} |           username: ${{ vars.DOCKERHUB_USERNAME }} | ||||||
|           password: ${{ secrets.DOCKERHUB_TOKEN }} |           password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -105,7 +106,7 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: registry.gitlab.com |           registry: registry.gitlab.com | ||||||
|           username: ${{ secrets.GITLAB_USERNAME }} |           username: ${{ vars.GITLAB_USERNAME }} | ||||||
|           password: ${{ secrets.GITLAB_PASSWORD }} |           password: ${{ secrets.GITLAB_PASSWORD }} | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -136,7 +137,7 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: <registry-name>.azurecr.io |           registry: <registry-name>.azurecr.io | ||||||
|           username: ${{ secrets.AZURE_CLIENT_ID }} |           username: ${{ vars.AZURE_CLIENT_ID }} | ||||||
|           password: ${{ secrets.AZURE_CLIENT_SECRET }} |           password: ${{ secrets.AZURE_CLIENT_SECRET }} | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -199,8 +200,7 @@ jobs: | ||||||
| Use a service account with permission to push to GCR and [configure access control](https://cloud.google.com/container-registry/docs/access-control). | Use a service account with permission to push to GCR and [configure access control](https://cloud.google.com/container-registry/docs/access-control). | ||||||
| Download the key for the service account as a JSON file. Save the contents of | Download the key for the service account as a JSON file. Save the contents of | ||||||
| the file [as a secret](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository) | the file [as a secret](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository) | ||||||
| named `GCR_JSON_KEY` in your GitHub repository. Set the username to `_json_key`, | named `GCR_JSON_KEY` in your GitHub repository. Set the username to `_json_key`. | ||||||
| or `_json_key_base64` if you use a base64-encoded key. |  | ||||||
| 
 | 
 | ||||||
| ```yaml | ```yaml | ||||||
| name: ci | name: ci | ||||||
|  | @ -302,7 +302,7 @@ jobs: | ||||||
| 
 | 
 | ||||||
| ### AWS Elastic Container Registry (ECR) | ### AWS Elastic Container Registry (ECR) | ||||||
| 
 | 
 | ||||||
| Use an IAM user with the ability to [push to ECR with `AmazonEC2ContainerRegistryPowerUser` managed policy for example](https://docs.aws.amazon.com/AmazonECR/latest/userguide/ecr_managed_policies.html#AmazonEC2ContainerRegistryPowerUser). | Use an IAM user with the ability to [push to ECR with `AmazonEC2ContainerRegistryPowerUser` managed policy for example](https://docs.aws.amazon.com/AmazonECR/latest/userguide/security-iam-awsmanpol.html#security-iam-awsmanpol-AmazonEC2ContainerRegistryPowerUser). | ||||||
| Download the access keys and save them as `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY` [as secrets](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository) | Download the access keys and save them as `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY` [as secrets](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository) | ||||||
| in your GitHub repo. | in your GitHub repo. | ||||||
| 
 | 
 | ||||||
|  | @ -322,7 +322,7 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: <aws-account-number>.dkr.ecr.<region>.amazonaws.com |           registry: <aws-account-number>.dkr.ecr.<region>.amazonaws.com | ||||||
|           username: ${{ secrets.AWS_ACCESS_KEY_ID }} |           username: ${{ vars.AWS_ACCESS_KEY_ID }} | ||||||
|           password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |           password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -345,7 +345,7 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: <aws-account-number>.dkr.ecr.<region>.amazonaws.com |           registry: <aws-account-number>.dkr.ecr.<region>.amazonaws.com | ||||||
|           username: ${{ secrets.AWS_ACCESS_KEY_ID }} |           username: ${{ vars.AWS_ACCESS_KEY_ID }} | ||||||
|           password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |           password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|         env: |         env: | ||||||
|           AWS_ACCOUNT_IDS: 012345678910,023456789012 |           AWS_ACCOUNT_IDS: 012345678910,023456789012 | ||||||
|  | @ -371,7 +371,7 @@ jobs: | ||||||
|         name: Configure AWS Credentials |         name: Configure AWS Credentials | ||||||
|         uses: aws-actions/configure-aws-credentials@v4 |         uses: aws-actions/configure-aws-credentials@v4 | ||||||
|         with: |         with: | ||||||
|           aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} |           aws-access-key-id: ${{ vars.AWS_ACCESS_KEY_ID }} | ||||||
|           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |           aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|           aws-region: <region> |           aws-region: <region> | ||||||
|       - |       - | ||||||
|  | @ -406,7 +406,7 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: public.ecr.aws |           registry: public.ecr.aws | ||||||
|           username: ${{ secrets.AWS_ACCESS_KEY_ID }} |           username: ${{ vars.AWS_ACCESS_KEY_ID }} | ||||||
|           password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |           password: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||||||
|         env: |         env: | ||||||
|           AWS_REGION: <region> |           AWS_REGION: <region> | ||||||
|  | @ -440,7 +440,7 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: <region>.ocir.io |           registry: <region>.ocir.io | ||||||
|           username: ${{ secrets.OCI_USERNAME }} |           username: ${{ vars.OCI_USERNAME }} | ||||||
|           password: ${{ secrets.OCI_TOKEN }} |           password: ${{ secrets.OCI_TOKEN }} | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -467,7 +467,7 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: quay.io |           registry: quay.io | ||||||
|           username: ${{ secrets.QUAY_USERNAME }} |           username: ${{ vars.QUAY_USERNAME }} | ||||||
|           password: ${{ secrets.QUAY_ROBOT_TOKEN }} |           password: ${{ secrets.QUAY_ROBOT_TOKEN }} | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | @ -491,23 +491,90 @@ jobs: | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@v3 | ||||||
|         with: |         with: | ||||||
|           registry: registry.digitalocean.com |           registry: registry.digitalocean.com | ||||||
|           username: ${{ secrets.DIGITALOCEAN_USERNAME }} |           username: ${{ vars.DIGITALOCEAN_USERNAME }} | ||||||
|           password: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }} |           password: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }} | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | ### Authenticate to multiple registries | ||||||
|  | 
 | ||||||
|  | To authenticate against multiple registries, you can specify the login-action | ||||||
|  | step multiple times in your workflow: | ||||||
|  | 
 | ||||||
|  | ```yaml | ||||||
|  | name: ci | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: main | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   login: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Login to Docker Hub | ||||||
|  |         uses: docker/login-action@v3 | ||||||
|  |         with: | ||||||
|  |           username: ${{ vars.DOCKERHUB_USERNAME }} | ||||||
|  |           password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|  |       - | ||||||
|  |         name: Login to GitHub Container Registry | ||||||
|  |         uses: docker/login-action@v3 | ||||||
|  |         with: | ||||||
|  |           registry: ghcr.io | ||||||
|  |           username: ${{ github.actor }} | ||||||
|  |           password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | You can also use the `registry-auth` input for raw authentication to | ||||||
|  | registries, defined as YAML objects. Each object can contain `registry`, | ||||||
|  | `username`, `password` and `ecr` keys similar to current inputs: | ||||||
|  | 
 | ||||||
|  | > [!WARNING] | ||||||
|  | > We don't recommend using this method, it's better to use the action multiple | ||||||
|  | > times as shown above. | ||||||
|  | 
 | ||||||
|  | ```yaml | ||||||
|  | name: ci | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: main | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   login: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - | ||||||
|  |         name: Login to registries | ||||||
|  |         uses: docker/login-action@v3 | ||||||
|  |         with: | ||||||
|  |           registry-auth: | | ||||||
|  |             - username: ${{ vars.DOCKERHUB_USERNAME }} | ||||||
|  |               password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|  |             - registry: ghcr.io | ||||||
|  |               username: ${{ github.actor }} | ||||||
|  |               password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
| ## Customizing | ## Customizing | ||||||
| 
 | 
 | ||||||
| ### inputs | ### inputs | ||||||
| 
 | 
 | ||||||
| The following inputs can be used as `step.with` keys: | The following inputs can be used as `step.with` keys: | ||||||
| 
 | 
 | ||||||
| | Name       | Type   | Default | Description                                                                   | | | Name            | Type   | Default     | Description                                                                   | | ||||||
| |------------|--------|---------|-------------------------------------------------------------------------------| | |-----------------|--------|-------------|-------------------------------------------------------------------------------| | ||||||
| | `registry` | String |         | Server address of Docker registry. If not set then will default to Docker Hub | | | `registry`      | String | `docker.io` | Server address of Docker registry. If not set then will default to Docker Hub | | ||||||
| | `username` | String |         | Username for authenticating to the Docker registry                            | | | `username`      | String |             | Username for authenticating to the Docker registry                            | | ||||||
| | `password` | String |         | Password or personal access token for authenticating the Docker registry      | | | `password`      | String |             | Password or personal access token for authenticating the Docker registry      | | ||||||
| | `ecr`      | String | `auto`  | Specifies whether the given registry is ECR (`auto`, `true` or `false`)       | | | `ecr`           | String | `auto`      | Specifies whether the given registry is ECR (`auto`, `true` or `false`)       | | ||||||
| | `logout`   | Bool   | `true`  | Log out from the Docker registry at the end of a job                          | | | `logout`        | Bool   | `true`      | Log out from the Docker registry at the end of a job                          | | ||||||
|  | | `registry-auth` | YAML   |             | Raw authentication to registries, defined as YAML objects                     | | ||||||
|  | 
 | ||||||
|  | > [!NOTE] | ||||||
|  | > The `registry-auth` input is mutually exclusive with `registry`, `username`, | ||||||
|  | > `password` and `ecr` inputs. | ||||||
| 
 | 
 | ||||||
| ## Contributing | ## Contributing | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -10,7 +10,9 @@ describe('isECR', () => { | ||||||
|     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', true], |     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', true], | ||||||
|     ['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', true], |     ['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', true], | ||||||
|     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', true], |     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', true], | ||||||
|     ['public.ecr.aws', true] |     ['012345678901.dkr-ecr.eu-north-1.on.aws', true], | ||||||
|  |     ['public.ecr.aws', true], | ||||||
|  |     ['ecr-public.aws.com', true] | ||||||
|   ])('given registry %p', async (registry, expected) => { |   ])('given registry %p', async (registry, expected) => { | ||||||
|     expect(aws.isECR(registry)).toEqual(expected); |     expect(aws.isECR(registry)).toEqual(expected); | ||||||
|   }); |   }); | ||||||
|  | @ -23,7 +25,9 @@ describe('isPubECR', () => { | ||||||
|     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', false], |     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', false], | ||||||
|     ['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', false], |     ['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', false], | ||||||
|     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', false], |     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', false], | ||||||
|     ['public.ecr.aws', true] |     ['012345678901.dkr-ecr.eu-north-1.on.aws', false], | ||||||
|  |     ['public.ecr.aws', true], | ||||||
|  |     ['ecr-public.aws.com', true] | ||||||
|   ])('given registry %p', async (registry, expected) => { |   ])('given registry %p', async (registry, expected) => { | ||||||
|     expect(aws.isPubECR(registry)).toEqual(expected); |     expect(aws.isPubECR(registry)).toEqual(expected); | ||||||
|   }); |   }); | ||||||
|  | @ -34,6 +38,7 @@ describe('getRegion', () => { | ||||||
|     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', 'eu-west-3'], |     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', 'eu-west-3'], | ||||||
|     ['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', 'cn-north-1'], |     ['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', 'cn-north-1'], | ||||||
|     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', 'cn-northwest-1'], |     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', 'cn-northwest-1'], | ||||||
|  |     ['012345678901.dkr-ecr.eu-north-1.on.aws', 'eu-north-1'], | ||||||
|     ['public.ecr.aws', 'us-east-1'] |     ['public.ecr.aws', 'us-east-1'] | ||||||
|   ])('given registry %p', async (registry, expected) => { |   ])('given registry %p', async (registry, expected) => { | ||||||
|     expect(aws.getRegion(registry)).toEqual(expected); |     expect(aws.getRegion(registry)).toEqual(expected); | ||||||
|  | @ -46,6 +51,7 @@ describe('getAccountIDs', () => { | ||||||
|     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', '012345678910,023456789012', ['012345678901', '012345678910', '023456789012']], |     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', '012345678910,023456789012', ['012345678901', '012345678910', '023456789012']], | ||||||
|     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', '012345678901,012345678910,023456789012', ['012345678901', '012345678910', '023456789012']], |     ['012345678901.dkr.ecr.eu-west-3.amazonaws.com', '012345678901,012345678910,023456789012', ['012345678901', '012345678910', '023456789012']], | ||||||
|     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', '012345678910,023456789012', ['390948362332', '012345678910', '023456789012']], |     ['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', '012345678910,023456789012', ['390948362332', '012345678910', '023456789012']], | ||||||
|  |     ['876820548815.dkr-ecr.eu-north-1.on.aws', '012345678910,023456789012', ['876820548815', '012345678910', '023456789012']], | ||||||
|     ['public.ecr.aws', undefined, []] |     ['public.ecr.aws', undefined, []] | ||||||
|   ])('given registry %p', async (registry, accountIDsEnv, expected) => { |   ])('given registry %p', async (registry, accountIDsEnv, expected) => { | ||||||
|     if (accountIDsEnv) { |     if (accountIDsEnv) { | ||||||
|  |  | ||||||
|  | @ -18,12 +18,14 @@ inputs: | ||||||
|     required: false |     required: false | ||||||
|   ecr: |   ecr: | ||||||
|     description: 'Specifies whether the given registry is ECR (auto, true or false)' |     description: 'Specifies whether the given registry is ECR (auto, true or false)' | ||||||
|     default: 'auto' |  | ||||||
|     required: false |     required: false | ||||||
|   logout: |   logout: | ||||||
|     description: 'Log out from the Docker registry at the end of a job' |     description: 'Log out from the Docker registry at the end of a job' | ||||||
|     default: 'true' |     default: 'true' | ||||||
|     required: false |     required: false | ||||||
|  |   registry-auth: | ||||||
|  |     description: 'Raw authentication to registries, defined as YAML objects' | ||||||
|  |     required: false | ||||||
| 
 | 
 | ||||||
| runs: | runs: | ||||||
|   using: 'node20' |   using: 'node20' | ||||||
|  |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							|  | @ -1,3 +1,9 @@ | ||||||
|  | target "_common" { | ||||||
|  |   args = { | ||||||
|  |     BUILDKIT_CONTEXT_KEEP_GIT_DIR = 1 | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| group "default" { | group "default" { | ||||||
|   targets = ["build"] |   targets = ["build"] | ||||||
| } | } | ||||||
|  | @ -11,42 +17,49 @@ group "validate" { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "build" { | target "build" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "build-update" |   target = "build-update" | ||||||
|   output = ["."] |   output = ["."] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "build-validate" { | target "build-validate" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "build-validate" |   target = "build-validate" | ||||||
|   output = ["type=cacheonly"] |   output = ["type=cacheonly"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "format" { | target "format" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "format-update" |   target = "format-update" | ||||||
|   output = ["."] |   output = ["."] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "lint" { | target "lint" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "lint" |   target = "lint" | ||||||
|   output = ["type=cacheonly"] |   output = ["type=cacheonly"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "vendor" { | target "vendor" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "vendor-update" |   target = "vendor-update" | ||||||
|   output = ["."] |   output = ["."] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "vendor-validate" { | target "vendor-validate" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "vendor-validate" |   target = "vendor-validate" | ||||||
|   output = ["type=cacheonly"] |   output = ["type=cacheonly"] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| target "test" { | target "test" { | ||||||
|  |   inherits = ["_common"] | ||||||
|   dockerfile = "dev.Dockerfile" |   dockerfile = "dev.Dockerfile" | ||||||
|   target = "test-coverage" |   target = "test-coverage" | ||||||
|   output = ["./coverage"] |   output = ["./coverage"] | ||||||
|  |  | ||||||
							
								
								
									
										36
									
								
								package.json
								
								
								
								
							
							
						
						
									
										36
									
								
								package.json
								
								
								
								
							|  | @ -23,28 +23,30 @@ | ||||||
|   ], |   ], | ||||||
|   "author": "Docker Inc.", |   "author": "Docker Inc.", | ||||||
|   "license": "Apache-2.0", |   "license": "Apache-2.0", | ||||||
|   "packageManager": "yarn@3.6.3", |   "packageManager": "yarn@4.9.2", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@actions/core": "^1.10.1", |     "@actions/core": "^1.11.1", | ||||||
|     "@aws-sdk/client-ecr": "^3.583.0", |     "@aws-sdk/client-ecr": "^3.890.0", | ||||||
|     "@aws-sdk/client-ecr-public": "^3.583.0", |     "@aws-sdk/client-ecr-public": "^3.890.0", | ||||||
|     "@docker/actions-toolkit": "^0.35.0", |     "@docker/actions-toolkit": "^0.63.0", | ||||||
|     "http-proxy-agent": "^7.0.2", |     "http-proxy-agent": "^7.0.2", | ||||||
|     "https-proxy-agent": "^7.0.5" |     "https-proxy-agent": "^7.0.6", | ||||||
|  |     "js-yaml": "^4.1.0" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/node": "^20.12.12", |     "@types/js-yaml": "^4.0.9", | ||||||
|     "@typescript-eslint/eslint-plugin": "^7.9.0", |     "@types/node": "^20.19.9", | ||||||
|     "@typescript-eslint/parser": "^7.9.0", |     "@typescript-eslint/eslint-plugin": "^7.18.0", | ||||||
|     "@vercel/ncc": "^0.38.1", |     "@typescript-eslint/parser": "^7.18.0", | ||||||
|     "eslint": "^8.57.0", |     "@vercel/ncc": "^0.38.3", | ||||||
|     "eslint-config-prettier": "^9.1.0", |     "eslint": "^8.57.1", | ||||||
|     "eslint-plugin-jest": "^28.5.0", |     "eslint-config-prettier": "^9.1.2", | ||||||
|     "eslint-plugin-prettier": "^5.1.3", |     "eslint-plugin-jest": "^28.14.0", | ||||||
|  |     "eslint-plugin-prettier": "^5.5.4", | ||||||
|     "jest": "^29.7.0", |     "jest": "^29.7.0", | ||||||
|     "prettier": "^3.2.5", |     "prettier": "^3.6.2", | ||||||
|     "ts-jest": "^29.1.2", |     "ts-jest": "^29.4.1", | ||||||
|     "ts-node": "^10.9.2", |     "ts-node": "^10.9.2", | ||||||
|     "typescript": "^5.4.5" |     "typescript": "^5.9.2" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -5,14 +5,15 @@ import {NodeHttpHandler} from '@smithy/node-http-handler'; | ||||||
| import {HttpProxyAgent} from 'http-proxy-agent'; | import {HttpProxyAgent} from 'http-proxy-agent'; | ||||||
| import {HttpsProxyAgent} from 'https-proxy-agent'; | import {HttpsProxyAgent} from 'https-proxy-agent'; | ||||||
| 
 | 
 | ||||||
| const ecrRegistryRegex = /^(([0-9]{12})\.dkr\.ecr\.(.+)\.amazonaws\.com(.cn)?)(\/([^:]+)(:.+)?)?$/; | const ecrRegistryRegex = /^(([0-9]{12})\.(dkr\.ecr|dkr-ecr)\.(.+)\.(on\.aws|amazonaws\.com(.cn)?))(\/([^:]+)(:.+)?)?$/; | ||||||
|  | const ecrPublicRegistryRegex = /public\.ecr\.aws|ecr-public\.aws\.com/; | ||||||
| 
 | 
 | ||||||
| export const isECR = (registry: string): boolean => { | export const isECR = (registry: string): boolean => { | ||||||
|   return ecrRegistryRegex.test(registry) || isPubECR(registry); |   return ecrRegistryRegex.test(registry) || isPubECR(registry); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export const isPubECR = (registry: string): boolean => { | export const isPubECR = (registry: string): boolean => { | ||||||
|   return registry === 'public.ecr.aws'; |   return ecrPublicRegistryRegex.test(registry); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export const getRegion = (registry: string): string => { | export const getRegion = (registry: string): string => { | ||||||
|  | @ -23,7 +24,7 @@ export const getRegion = (registry: string): string => { | ||||||
|   if (!matches) { |   if (!matches) { | ||||||
|     return ''; |     return ''; | ||||||
|   } |   } | ||||||
|   return matches[3]; |   return matches[4]; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export const getAccountIDs = (registry: string): string[] => { | export const getAccountIDs = (registry: string): string[] => { | ||||||
|  |  | ||||||
|  | @ -6,6 +6,7 @@ export interface Inputs { | ||||||
|   password: string; |   password: string; | ||||||
|   ecr: string; |   ecr: string; | ||||||
|   logout: boolean; |   logout: boolean; | ||||||
|  |   registryAuth: string; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export function getInputs(): Inputs { | export function getInputs(): Inputs { | ||||||
|  | @ -14,6 +15,7 @@ export function getInputs(): Inputs { | ||||||
|     username: core.getInput('username'), |     username: core.getInput('username'), | ||||||
|     password: core.getInput('password'), |     password: core.getInput('password'), | ||||||
|     ecr: core.getInput('ecr'), |     ecr: core.getInput('ecr'), | ||||||
|     logout: core.getBooleanInput('logout') |     logout: core.getBooleanInput('logout'), | ||||||
|  |     registryAuth: core.getInput('registry-auth') | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -36,11 +36,7 @@ export async function loginStandard(registry: string, username: string, password | ||||||
|   loginArgs.push('--username', username); |   loginArgs.push('--username', username); | ||||||
|   loginArgs.push(registry); |   loginArgs.push(registry); | ||||||
| 
 | 
 | ||||||
|   if (registry) { |   core.info(`Logging into ${registry}...`); | ||||||
|     core.info(`Logging into ${registry}...`); |  | ||||||
|   } else { |  | ||||||
|     core.info(`Logging into Docker Hub...`); |  | ||||||
|   } |  | ||||||
|   await Docker.getExecOutput(loginArgs, { |   await Docker.getExecOutput(loginArgs, { | ||||||
|     ignoreReturnCode: true, |     ignoreReturnCode: true, | ||||||
|     silent: true, |     silent: true, | ||||||
|  |  | ||||||
							
								
								
									
										50
									
								
								src/main.ts
								
								
								
								
							
							
						
						
									
										50
									
								
								src/main.ts
								
								
								
								
							|  | @ -1,21 +1,61 @@ | ||||||
|  | import * as yaml from 'js-yaml'; | ||||||
|  | import * as core from '@actions/core'; | ||||||
| import * as actionsToolkit from '@docker/actions-toolkit'; | import * as actionsToolkit from '@docker/actions-toolkit'; | ||||||
| 
 | 
 | ||||||
| import * as context from './context'; | import * as context from './context'; | ||||||
| import * as docker from './docker'; | import * as docker from './docker'; | ||||||
| import * as stateHelper from './state-helper'; | import * as stateHelper from './state-helper'; | ||||||
| 
 | 
 | ||||||
|  | interface Auth { | ||||||
|  |   registry: string; | ||||||
|  |   username: string; | ||||||
|  |   password: string; | ||||||
|  |   ecr: string; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| export async function main(): Promise<void> { | export async function main(): Promise<void> { | ||||||
|   const input: context.Inputs = context.getInputs(); |   const inputs: context.Inputs = context.getInputs(); | ||||||
|   stateHelper.setRegistry(input.registry); |   stateHelper.setLogout(inputs.logout); | ||||||
|   stateHelper.setLogout(input.logout); | 
 | ||||||
|   await docker.login(input.registry, input.username, input.password, input.ecr); |   if (inputs.registryAuth && (inputs.registry || inputs.username || inputs.password || inputs.ecr)) { | ||||||
|  |     throw new Error('Cannot use registry-auth with other inputs'); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   if (!inputs.registryAuth) { | ||||||
|  |     stateHelper.setRegistries([inputs.registry || 'docker.io']); | ||||||
|  |     await docker.login(inputs.registry || 'docker.io', inputs.username, inputs.password, inputs.ecr || 'auto'); | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const auths = yaml.load(inputs.registryAuth) as Auth[]; | ||||||
|  |   if (auths.length == 0) { | ||||||
|  |     throw new Error('No registry to login'); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const registries: string[] = []; | ||||||
|  |   for (const auth of auths) { | ||||||
|  |     if (!auth.registry) { | ||||||
|  |       registries.push('docker.io'); | ||||||
|  |     } else { | ||||||
|  |       registries.push(auth.registry); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   stateHelper.setRegistries(registries.filter((value, index, self) => self.indexOf(value) === index)); | ||||||
|  | 
 | ||||||
|  |   for (const auth of auths) { | ||||||
|  |     await core.group(`Login to ${auth.registry || 'docker.io'}`, async () => { | ||||||
|  |       await docker.login(auth.registry || 'docker.io', auth.username, auth.password, auth.ecr || 'auto'); | ||||||
|  |     }); | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| async function post(): Promise<void> { | async function post(): Promise<void> { | ||||||
|   if (!stateHelper.logout) { |   if (!stateHelper.logout) { | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   await docker.logout(stateHelper.registry); |   for (const registry of stateHelper.registries.split(',')) { | ||||||
|  |     await docker.logout(registry); | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| actionsToolkit.run(main, post); | actionsToolkit.run(main, post); | ||||||
|  |  | ||||||
|  | @ -1,10 +1,10 @@ | ||||||
| import * as core from '@actions/core'; | import * as core from '@actions/core'; | ||||||
| 
 | 
 | ||||||
| export const registry = process.env['STATE_registry'] || ''; | export const registries = process.env['STATE_registries'] || ''; | ||||||
| export const logout = /true/i.test(process.env['STATE_logout'] || ''); | export const logout = /true/i.test(process.env['STATE_logout'] || ''); | ||||||
| 
 | 
 | ||||||
| export function setRegistry(registry: string) { | export function setRegistries(registries: string[]) { | ||||||
|   core.saveState('registry', registry); |   core.saveState('registries', registries.join(',')); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export function setLogout(logout: boolean) { | export function setLogout(logout: boolean) { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue