mirror of
https://github.com/docker/build-push-action.git
synced 2026-05-30 22:40:00 +03:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| df9c7450bf |
@@ -22,6 +22,10 @@ on:
|
|||||||
slug:
|
slug:
|
||||||
required: false
|
required: false
|
||||||
type: string
|
type: string
|
||||||
|
aws-role-to-assume:
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
description: "IAM role ARN to assume via OIDC for ECR authentication. When set, configure-aws-credentials runs before registry login."
|
||||||
secrets:
|
secrets:
|
||||||
registry_username:
|
registry_username:
|
||||||
required: false
|
required: false
|
||||||
@@ -36,6 +40,9 @@ env:
|
|||||||
jobs:
|
jobs:
|
||||||
run:
|
run:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
id-token: write
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
@@ -111,6 +118,14 @@ jobs:
|
|||||||
driver-opts: |
|
driver-opts: |
|
||||||
image=${{ matrix.buildkit_image }}
|
image=${{ matrix.buildkit_image }}
|
||||||
network=host
|
network=host
|
||||||
|
-
|
||||||
|
name: Configure AWS credentials
|
||||||
|
if: inputs.aws-role-to-assume != '' && (contains(inputs.registry, '.ecr.') || inputs.registry == 'public.ecr.aws')
|
||||||
|
uses: aws-actions/configure-aws-credentials@7474bc4690e29a8392af63c5b98e7449536d5c3a # v4.3.1
|
||||||
|
with:
|
||||||
|
role-to-assume: ${{ inputs.aws-role-to-assume }}
|
||||||
|
aws-region: us-east-1
|
||||||
|
role-session-name: gha-build-push-action-e2e-${{ github.run_id }}-${{ github.run_attempt }}
|
||||||
-
|
-
|
||||||
name: Login to Registry
|
name: Login to Registry
|
||||||
if: github.event_name != 'pull_request' && (inputs.type == 'remote' || env.REGISTRY_USER != '')
|
if: github.event_name != 'pull_request' && (inputs.type == 'remote' || env.REGISTRY_USER != '')
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ name: e2e
|
|||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
contents: read
|
contents: read
|
||||||
|
id-token: write
|
||||||
|
|
||||||
concurrency:
|
concurrency:
|
||||||
group: ${{ github.workflow }}-${{ github.ref }}
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
@@ -99,14 +100,15 @@ jobs:
|
|||||||
name: ${{ matrix.name }}
|
name: ${{ matrix.name }}
|
||||||
registry: ${{ matrix.registry }}
|
registry: ${{ matrix.registry }}
|
||||||
slug: ${{ matrix.slug }}
|
slug: ${{ matrix.slug }}
|
||||||
|
aws-role-to-assume: arn:aws:iam::175142243308:role/official_gha_cicd
|
||||||
secrets:
|
secrets:
|
||||||
# Pass only the two secrets needed by each matrix entry.
|
# Pass only the two secrets needed by each matrix entry.
|
||||||
|
# AWS ECR entries use OIDC via aws-role-to-assume instead of static keys.
|
||||||
registry_username: >-
|
registry_username: >-
|
||||||
${{
|
${{
|
||||||
matrix.auth == 'dockerhub' && secrets.DOCKERHUB_USERNAME ||
|
matrix.auth == 'dockerhub' && secrets.DOCKERHUB_USERNAME ||
|
||||||
matrix.auth == 'ghcr' && secrets.GHCR_USERNAME ||
|
matrix.auth == 'ghcr' && secrets.GHCR_USERNAME ||
|
||||||
matrix.auth == 'gitlab' && secrets.GITLAB_USERNAME ||
|
matrix.auth == 'gitlab' && secrets.GITLAB_USERNAME ||
|
||||||
matrix.auth == 'aws' && secrets.AWS_ACCESS_KEY_ID ||
|
|
||||||
matrix.auth == 'gar' && secrets.GAR_USERNAME ||
|
matrix.auth == 'gar' && secrets.GAR_USERNAME ||
|
||||||
matrix.auth == 'acr' && secrets.AZURE_CLIENT_ID ||
|
matrix.auth == 'acr' && secrets.AZURE_CLIENT_ID ||
|
||||||
matrix.auth == 'quay' && secrets.QUAY_USERNAME ||
|
matrix.auth == 'quay' && secrets.QUAY_USERNAME ||
|
||||||
@@ -118,7 +120,6 @@ jobs:
|
|||||||
matrix.auth == 'dockerhub' && secrets.DOCKERHUB_TOKEN ||
|
matrix.auth == 'dockerhub' && secrets.DOCKERHUB_TOKEN ||
|
||||||
matrix.auth == 'ghcr' && secrets.GHCR_PAT ||
|
matrix.auth == 'ghcr' && secrets.GHCR_PAT ||
|
||||||
matrix.auth == 'gitlab' && secrets.GITLAB_TOKEN ||
|
matrix.auth == 'gitlab' && secrets.GITLAB_TOKEN ||
|
||||||
matrix.auth == 'aws' && secrets.AWS_SECRET_ACCESS_KEY ||
|
|
||||||
matrix.auth == 'gar' && secrets.GAR_JSON_KEY ||
|
matrix.auth == 'gar' && secrets.GAR_JSON_KEY ||
|
||||||
matrix.auth == 'acr' && secrets.AZURE_CLIENT_SECRET ||
|
matrix.auth == 'acr' && secrets.AZURE_CLIENT_SECRET ||
|
||||||
matrix.auth == 'quay' && secrets.QUAY_TOKEN ||
|
matrix.auth == 'quay' && secrets.QUAY_TOKEN ||
|
||||||
|
|||||||
Reference in New Issue
Block a user