|
23 | 23 | DOCKER_USERNAME: |
24 | 24 | required: true |
25 | 25 | type: string |
| 26 | + DOCKER_PLATFORMS: |
| 27 | + required: false |
| 28 | + type: string |
| 29 | + default: 'linux/amd64,linux/arm64' |
26 | 30 |
|
27 | 31 | jobs: |
28 | | - build-and-scan: |
| 32 | + build: |
| 33 | + runs-on: ubuntu-latest |
| 34 | + strategy: |
| 35 | + matrix: |
| 36 | + platform: ${{ fromJson(inputs.DOCKER_PLATFORMS) }} |
29 | 37 | env: |
30 | 38 | DOCKER_PATH_CONTEXT: ${{ inputs.DOCKER_PATH_CONTEXT }} |
31 | 39 | DOCKER_BUILD_DOCKERFILE: ${{ inputs.DOCKER_BUILD_DOCKERFILE }} |
32 | 40 | DOCKER_TAGS: ${{ inputs.DOCKER_TAGS }} |
33 | | - DOCKER_LOAD_BOOL: ${{ inputs.DOCKER_LOAD_BOOL }} |
34 | | - DOCKER_PUSH_BOOL: ${{ inputs.DOCKER_PUSH_BOOL }} |
35 | 41 | DOCKER_USERNAME: ${{ inputs.DOCKER_USERNAME }} |
36 | | - runs-on: ubuntu-latest |
37 | 42 | steps: |
38 | | - - name: Checkout repository |
39 | | - uses: actions/checkout@v6 |
40 | | - - name: Set up QEMU |
41 | | - uses: docker/setup-qemu-action@v4 |
42 | | - - name: Set up Docker Buildx |
43 | | - uses: docker/setup-buildx-action@v4 |
44 | | - - name: Login to DockerHub |
45 | | - uses: docker/login-action@v4 |
| 43 | + - uses: actions/checkout@v6 |
| 44 | + - uses: docker/setup-qemu-action@v4 |
| 45 | + - uses: docker/setup-buildx-action@v4 |
| 46 | + - uses: docker/login-action@v4 |
46 | 47 | with: |
47 | 48 | username: ${{ env.DOCKER_USERNAME }} |
48 | 49 | password: ${{ secrets.DOCKERHUB_TOKEN }} |
49 | | - - name: Build (and maybe push) Docker image |
| 50 | + - name: Build & push per-arch image |
50 | 51 | uses: docker/build-push-action@v7 |
51 | 52 | with: |
52 | | - context: ${{ env.DOCKER_PATH_CONTEXT }} |
53 | | - file: ${{ env.DOCKER_BUILD_DOCKERFILE}} |
54 | | - load: ${{ env.DOCKER_LOAD_BOOL }} |
55 | | - push: ${{ env.DOCKER_PUSH_BOOL }} |
56 | | - tags: ${{ env.DOCKER_TAGS }} |
57 | | - - name: Run Trivy vulnerability scanner (remote) |
58 | | - if: ${{ github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v') }} |
| 53 | + context: ${{ env.DOCKER_PATH_CONTEXT }} |
| 54 | + file: ${{ env.DOCKER_BUILD_DOCKERFILE }} |
| 55 | + platforms: ${{ matrix.platform }} |
| 56 | + push: true |
| 57 | + tags: docker.io/${{ env.DOCKER_TAGS }}-${{ matrix.platform }} |
| 58 | + - name: Run Trivy vulnerability scanner (per-arch) |
59 | 59 | uses: aquasecurity/trivy-action@0.35.0 |
60 | 60 | with: |
61 | | - image-ref: docker.io/${{ env.DOCKER_TAGS }} |
| 61 | + image-ref: docker.io/${{ env.DOCKER_TAGS }}-${{ matrix.platform }} |
62 | 62 | format: 'table' |
63 | 63 | exit-code: '1' |
64 | 64 | ignore-unfixed: true |
65 | 65 | vuln-type: 'os,library' |
66 | 66 | severity: 'CRITICAL,HIGH' |
| 67 | + |
| 68 | + manifest: |
| 69 | + runs-on: ubuntu-latest |
| 70 | + needs: build |
| 71 | + env: |
| 72 | + DOCKER_TAGS: ${{ inputs.DOCKER_TAGS }} |
| 73 | + DOCKER_USERNAME: ${{ inputs.DOCKER_USERNAME }} |
| 74 | + steps: |
| 75 | + - uses: docker/login-action@v4 |
| 76 | + with: |
| 77 | + username: ${{ env.DOCKER_USERNAME }} |
| 78 | + password: ${{ secrets.DOCKERHUB_TOKEN }} |
| 79 | + - name: Create and push multi-arch manifest |
| 80 | + run: | |
| 81 | + docker buildx imagetools create \ |
| 82 | + -t docker.io/${{ env.DOCKER_TAGS }} \ |
| 83 | + docker.io/${{ env.DOCKER_TAGS }}-linux_amd64 \ |
| 84 | + docker.io/${{ env.DOCKER_TAGS }}-linux_arm64 |
0 commit comments