|
10 | 10 | permissions: {} |
11 | 11 |
|
12 | 12 | env: |
13 | | - # Image repository configuration - can be overridden in forks |
14 | | - IMAGE_REGISTRY: ${{ vars.IMAGE_REGISTRY || 'quay.io' }} |
15 | | - IMAGE_NAMESPACE: ${{ vars.IMAGE_NAMESPACE || 'argoproj' }} |
16 | | - IMAGE_REPOSITORY: ${{ vars.IMAGE_REPOSITORY || 'argocd' }} |
17 | | - # Fork release control - set to 'true' in fork to enable release workflows |
18 | | - ENABLE_FORK_RELEASES: ${{ vars.ENABLE_FORK_RELEASES || 'false' }} |
19 | 13 | # renovate: datasource=golang-version packageName=golang |
20 | 14 | GOLANG_VERSION: '1.25.3' # Note: go-version must also be set in job argocd-image.with.go-version |
21 | 15 |
|
22 | 16 | jobs: |
23 | 17 | argocd-image: |
| 18 | + needs: [setup-variables] |
24 | 19 | permissions: |
25 | 20 | contents: read |
26 | 21 | id-token: write # for creating OIDC tokens for signing. |
27 | 22 | packages: write # used to push images to `ghcr.io` if used. |
28 | 23 | if: github.repository == 'argoproj/argo-cd' || (github.repository_owner != 'argoproj' && vars.ENABLE_FORK_RELEASES == 'true' && startsWith(github.ref, 'refs/tags/') && vars.IMAGE_NAMESPACE && vars.IMAGE_NAMESPACE != 'argoproj') |
29 | 24 | uses: ./.github/workflows/image-reuse.yaml |
30 | 25 | with: |
31 | | - quay_image_name: ${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_REPOSITORY }}:${{ github.ref_name }} |
| 26 | + quay_image_name: ${{ needs.setup-variables.outputs.quay_image_name }} |
32 | 27 | # Note: cannot use env variables to set go-version (https://docs.github.com/en/actions/using-workflows/reusing-workflows#limitations) |
33 | 28 | # renovate: datasource=golang-version packageName=golang |
34 | 29 | go-version: 1.25.3 |
|
45 | 40 | outputs: |
46 | 41 | is_pre_release: ${{ steps.var.outputs.is_pre_release }} |
47 | 42 | is_latest_release: ${{ steps.var.outputs.is_latest_release }} |
| 43 | + image_registry: ${{ steps.var.outputs.image_registry }} |
| 44 | + image_namespace: ${{ steps.var.outputs.image_namespace }} |
| 45 | + image_repository: ${{ steps.var.outputs.image_repository }} |
| 46 | + quay_image_name: ${{ steps.var.outputs.quay_image_name }} |
| 47 | + provenance_image: ${{ steps.var.outputs.provenance_image }} |
| 48 | + sbom_image: ${{ steps.var.outputs.sbom_image }} |
48 | 49 | steps: |
49 | 50 | - name: Checkout code |
50 | 51 | uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 |
|
73 | 74 | fi |
74 | 75 | echo "is_pre_release=$PRE_RELEASE" >> $GITHUB_OUTPUT |
75 | 76 | echo "is_latest_release=$IS_LATEST" >> $GITHUB_OUTPUT |
| 77 | + |
| 78 | + # Calculate image names with defaults (single source of truth) |
| 79 | + IMAGE_REGISTRY="${{ vars.IMAGE_REGISTRY || 'quay.io' }}" |
| 80 | + IMAGE_NAMESPACE="${{ vars.IMAGE_NAMESPACE || 'argoproj' }}" |
| 81 | + IMAGE_REPOSITORY="${{ vars.IMAGE_REPOSITORY || 'argocd' }}" |
| 82 | + |
| 83 | + echo "image_registry=$IMAGE_REGISTRY" >> $GITHUB_OUTPUT |
| 84 | + echo "image_namespace=$IMAGE_NAMESPACE" >> $GITHUB_OUTPUT |
| 85 | + echo "image_repository=$IMAGE_REPOSITORY" >> $GITHUB_OUTPUT |
| 86 | + echo "quay_image_name=$IMAGE_REGISTRY/$IMAGE_NAMESPACE/$IMAGE_REPOSITORY:${{ github.ref_name }}" >> $GITHUB_OUTPUT |
| 87 | + echo "provenance_image=$IMAGE_REGISTRY/$IMAGE_NAMESPACE/$IMAGE_REPOSITORY" >> $GITHUB_OUTPUT |
| 88 | + echo "sbom_image=$IMAGE_REGISTRY/$IMAGE_NAMESPACE/$IMAGE_REPOSITORY:${{ github.ref_name }}" >> $GITHUB_OUTPUT |
76 | 89 |
|
77 | 90 | argocd-image-provenance: |
78 | | - needs: [argocd-image] |
| 91 | + needs: [setup-variables, argocd-image] |
79 | 92 | permissions: |
80 | 93 | actions: read # for detecting the Github Actions environment. |
81 | 94 | id-token: write # for creating OIDC tokens for signing. |
|
84 | 97 | if: github.repository == 'argoproj/argo-cd' || (github.repository_owner != 'argoproj' && vars.ENABLE_FORK_RELEASES == 'true' && startsWith(github.ref, 'refs/tags/') && vars.IMAGE_NAMESPACE && vars.IMAGE_NAMESPACE != 'argoproj') |
85 | 98 | uses: slsa-framework/slsa-github-generator/.github/workflows/generator_container_slsa3.yml@v2.1.0 |
86 | 99 | with: |
87 | | - image: ${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_REPOSITORY }} |
| 100 | + image: ${{ needs.setup-variables.outputs.provenance_image }} |
88 | 101 | digest: ${{ needs.argocd-image.outputs.image-digest }} |
89 | 102 | secrets: |
90 | 103 | registry-username: ${{ secrets.RELEASE_QUAY_USERNAME }} |
@@ -213,7 +226,7 @@ jobs: |
213 | 226 | # managers (gomod, yarn, npm). |
214 | 227 | PROJECT_FOLDERS: '.,./ui' |
215 | 228 | # full qualified name of the docker image to be inspected |
216 | | - DOCKER_IMAGE: ${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_REPOSITORY }}:${{ github.ref_name }} |
| 229 | + DOCKER_IMAGE: ${{ needs.setup-variables.outputs.sbom_image }} |
217 | 230 | run: | |
218 | 231 | yarn install --cwd ./ui |
219 | 232 | go install github.com/spdx/spdx-sbom-generator/cmd/generator@$SPDX_GEN_VERSION |
|
0 commit comments