Compare commits

..

1 Commits

Author SHA1 Message Date
ef78704b98 Use Docker bake to build targets 2025-11-20 01:09:07 +01:00

View File

@@ -14,9 +14,8 @@ on:
description: Webhook to call after build is completed description: Webhook to call after build is completed
type: string type: string
outputs: outputs:
metadata: images:
description: Digest of the build docker container value: ${{ jobs.build.outputs.images }}
value: ${{ jobs.build.outputs.metadata }}
env: env:
OCI_REPO: git.huizinga.dev/dreaded_x/${{ gitea.event.repository.name}} OCI_REPO: git.huizinga.dev/dreaded_x/${{ gitea.event.repository.name}}
@@ -26,7 +25,7 @@ jobs:
name: Build container and manifests name: Build container and manifests
runs-on: ubuntu-latest runs-on: ubuntu-latest
outputs: outputs:
metadata: ${{ steps.build.outputs.metadata }} images: ${{ steps.images.outputs.images }}
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v4
@@ -71,15 +70,12 @@ jobs:
type=semver,pattern=v{{major}} type=semver,pattern=v{{major}}
- name: Bake containers - name: Bake containers
id: build id: bake
uses: docker/bake-action@v6 uses: docker/bake-action@v6
with: with:
files: | files: |
./docker-bake.hcl ./docker-bake.hcl
cwd://${{ steps.meta.outputs.bake-file }} cwd://${{ steps.meta.outputs.bake-file }}
set: |
*.cache-from=type=gha
*.cache-to=type=gha,mode=max
push: true push: true
sbom: true sbom: true
provenance: mode=max provenance: mode=max
@@ -88,6 +84,14 @@ jobs:
RELEASE_VERSION: ${{ env.RELEASE_VERSION }} RELEASE_VERSION: ${{ env.RELEASE_VERSION }}
SOURCE_DATE_EPOCH: ${{ env.TIMESTAMP }} SOURCE_DATE_EPOCH: ${{ env.TIMESTAMP }}
- name: Output images
id: images
run: |
METADATA='${{ steps.bake.outputs.metadata }}'
IMAGES=$(echo ${METADATA} | jq 'map_values((."image.name" | split(",|:";""))[0] + "@" + ."containerimage.digest")')
echo images=${IMAGES} >> $GITHUB_OUTPUT
# TODO: Move this into docker-bake.hcl
- name: Generate CRDs - name: Generate CRDs
if: inputs.generate_crds == true if: inputs.generate_crds == true
run: | run: |
@@ -96,6 +100,7 @@ jobs:
- name: Kustomize manifests - name: Kustomize manifests
if: inputs.push_manifests == true if: inputs.push_manifests == true
run: | run: |
# TODO: Fix this
./kustomize build ./manifests | sed "s/\${DIGEST}/${{ steps.build.outputs.digest }}/" > ./manifests.yaml ./kustomize build ./manifests | sed "s/\${DIGEST}/${{ steps.build.outputs.digest }}/" > ./manifests.yaml
- name: Push manifests - name: Push manifests