|
12 | 12 | DOCKER_TAGS: |
13 | 13 | required: true |
14 | 14 | type: string |
15 | | - DOCKER_LOAD_BOOL: |
16 | | - required: false |
17 | | - type: boolean |
18 | | - default: false |
19 | | - DOCKER_PUSH_BOOL: |
20 | | - required: false |
21 | | - type: boolean |
22 | | - default: false |
23 | 15 | DOCKER_USERNAME: |
24 | 16 | required: true |
25 | 17 | type: string |
26 | 18 |
|
27 | 19 | jobs: |
28 | 20 | build-and-scan: |
| 21 | + runs-on: ubuntu-latest |
29 | 22 | env: |
30 | 23 | DOCKER_PATH_CONTEXT: ${{ inputs.DOCKER_PATH_CONTEXT }} |
31 | 24 | DOCKER_BUILD_DOCKERFILE: ${{ inputs.DOCKER_BUILD_DOCKERFILE }} |
32 | 25 | DOCKER_TAGS: ${{ inputs.DOCKER_TAGS }} |
33 | | - DOCKER_LOAD_BOOL: ${{ inputs.DOCKER_LOAD_BOOL }} |
34 | | - DOCKER_PUSH_BOOL: ${{ inputs.DOCKER_PUSH_BOOL }} |
35 | 26 | DOCKER_USERNAME: ${{ inputs.DOCKER_USERNAME }} |
36 | | - runs-on: ubuntu-latest |
37 | 27 | 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 |
| 28 | + - uses: actions/checkout@v6 |
| 29 | + - uses: docker/setup-qemu-action@v4 |
| 30 | + - uses: docker/setup-buildx-action@v4 |
| 31 | + - uses: docker/login-action@v4 |
46 | 32 | with: |
47 | 33 | username: ${{ env.DOCKER_USERNAME }} |
48 | 34 | password: ${{ secrets.DOCKERHUB_TOKEN }} |
49 | | - - name: Build (and maybe push) Docker image |
| 35 | + - name: Build & push multi-arch image |
50 | 36 | uses: docker/build-push-action@v7 |
51 | 37 | 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') }} |
| 38 | + context: ${{ env.DOCKER_PATH_CONTEXT }} |
| 39 | + file: ${{ env.DOCKER_BUILD_DOCKERFILE }} |
| 40 | + platforms: linux/amd64,linux/arm64 |
| 41 | + push: true |
| 42 | + tags: docker.io/${{ env.DOCKER_TAGS }} |
| 43 | + - name: Run Trivy vulnerability scanner (multi-arch manifest) |
59 | 44 | uses: aquasecurity/trivy-action@0.35.0 |
60 | 45 | with: |
61 | 46 | image-ref: docker.io/${{ env.DOCKER_TAGS }} |
|
0 commit comments