mirror of
https://github.com/fluxcd/flux2.git
synced 2026-02-08 00:37:27 +00:00
Bumps the ci group with 14 updates in the / directory: | Package | From | To | | --- | --- | --- | | [actions/checkout](https://github.com/actions/checkout) | `5.0.0` | `6.0.1` | | [fluxcd/gha-workflows/.github/workflows/backport.yaml](https://github.com/fluxcd/gha-workflows) | `0.4.0` | `0.5.0` | | [actions/setup-go](https://github.com/actions/setup-go) | `6.0.0` | `6.1.0` | | [helm/kind-action](https://github.com/helm/kind-action) | `1.12.0` | `1.13.0` | | [fluxcd/pkg](https://github.com/fluxcd/pkg) | `1.22.0` | `1.24.0` | | [docker/setup-qemu-action](https://github.com/docker/setup-qemu-action) | `3.6.0` | `3.7.0` | | [docker/setup-buildx-action](https://github.com/docker/setup-buildx-action) | `3.11.1` | `3.12.0` | | [actions/upload-artifact](https://github.com/actions/upload-artifact) | `4.6.2` | `6.0.0` | | [github/codeql-action](https://github.com/github/codeql-action) | `3.30.5` | `4.31.9` | | [anchore/sbom-action](https://github.com/anchore/sbom-action) | `0.20.6` | `0.21.0` | | [sigstore/cosign-installer](https://github.com/sigstore/cosign-installer) | `3.10.0` | `4.0.0` | | [fluxcd/gha-workflows/.github/workflows/code-scan.yaml](https://github.com/fluxcd/gha-workflows) | `0.4.0` | `0.5.0` | | [fluxcd/gha-workflows/.github/workflows/labels-sync.yaml](https://github.com/fluxcd/gha-workflows) | `0.4.0` | `0.5.0` | | [peter-evans/create-pull-request](https://github.com/peter-evans/create-pull-request) | `7.0.8` | `8.0.0` | Updates `actions/checkout` from 5.0.0 to 6.0.1 - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](08c6903cd8...8e8c483db8) Updates `fluxcd/gha-workflows/.github/workflows/backport.yaml` from 0.4.0 to 0.5.0 - [Release notes](https://github.com/fluxcd/gha-workflows/releases) - [Commits](https://github.com/fluxcd/gha-workflows/compare/v0.4.0...v0.5.0) Updates `actions/setup-go` from 6.0.0 to 6.1.0 - [Release notes](https://github.com/actions/setup-go/releases) - [Commits](4469467582...4dc6199c7b) Updates `helm/kind-action` from 1.12.0 to 1.13.0 - [Release notes](https://github.com/helm/kind-action/releases) - [Commits](a1b0e39133...92086f6be0) Updates `fluxcd/pkg` from 1.22.0 to 1.24.0 - [Commits](bf02f0a2d6...62ddfc16c2) Updates `docker/setup-qemu-action` from 3.6.0 to 3.7.0 - [Release notes](https://github.com/docker/setup-qemu-action/releases) - [Commits](29109295f8...c7c5346462) Updates `docker/setup-buildx-action` from 3.11.1 to 3.12.0 - [Release notes](https://github.com/docker/setup-buildx-action/releases) - [Commits](e468171a9d...8d2750c68a) Updates `actions/upload-artifact` from 4.6.2 to 6.0.0 - [Release notes](https://github.com/actions/upload-artifact/releases) - [Commits](ea165f8d65...b7c566a772) Updates `github/codeql-action` from 3.30.5 to 4.31.9 - [Release notes](https://github.com/github/codeql-action/releases) - [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md) - [Commits](3599b3baa1...5d4e8d1aca) Updates `anchore/sbom-action` from 0.20.6 to 0.21.0 - [Release notes](https://github.com/anchore/sbom-action/releases) - [Changelog](https://github.com/anchore/sbom-action/blob/main/RELEASE.md) - [Commits](f8bdd1d8ac...a930d0ac43) Updates `sigstore/cosign-installer` from 3.10.0 to 4.0.0 - [Release notes](https://github.com/sigstore/cosign-installer/releases) - [Commits](d7543c93d8...faadad0cce) Updates `fluxcd/gha-workflows/.github/workflows/code-scan.yaml` from 0.4.0 to 0.5.0 - [Release notes](https://github.com/fluxcd/gha-workflows/releases) - [Commits](https://github.com/fluxcd/gha-workflows/compare/v0.4.0...v0.5.0) Updates `fluxcd/gha-workflows/.github/workflows/labels-sync.yaml` from 0.4.0 to 0.5.0 - [Release notes](https://github.com/fluxcd/gha-workflows/releases) - [Commits](https://github.com/fluxcd/gha-workflows/compare/v0.4.0...v0.5.0) Updates `peter-evans/create-pull-request` from 7.0.8 to 8.0.0 - [Release notes](https://github.com/peter-evans/create-pull-request/releases) - [Commits](271a8d0340...98357b18bf) --- updated-dependencies: - dependency-name: actions/checkout dependency-version: 6.0.1 dependency-type: direct:production update-type: version-update:semver-major dependency-group: ci - dependency-name: fluxcd/gha-workflows/.github/workflows/backport.yaml dependency-version: 0.5.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: actions/setup-go dependency-version: 6.1.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: helm/kind-action dependency-version: 1.13.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: fluxcd/pkg dependency-version: 1.24.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: docker/setup-qemu-action dependency-version: 3.7.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: docker/setup-buildx-action dependency-version: 3.12.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: actions/upload-artifact dependency-version: 6.0.0 dependency-type: direct:production update-type: version-update:semver-major dependency-group: ci - dependency-name: github/codeql-action dependency-version: 4.31.9 dependency-type: direct:production update-type: version-update:semver-major dependency-group: ci - dependency-name: anchore/sbom-action dependency-version: 0.21.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: sigstore/cosign-installer dependency-version: 4.0.0 dependency-type: direct:production update-type: version-update:semver-major dependency-group: ci - dependency-name: fluxcd/gha-workflows/.github/workflows/code-scan.yaml dependency-version: 0.5.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: fluxcd/gha-workflows/.github/workflows/labels-sync.yaml dependency-version: 0.5.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: peter-evans/create-pull-request dependency-version: 8.0.0 dependency-type: direct:production update-type: version-update:semver-major dependency-group: ci ... Signed-off-by: dependabot[bot] <support@github.com>
208 lines
8.4 KiB
YAML
208 lines
8.4 KiB
YAML
name: release
|
|
|
|
on:
|
|
push:
|
|
tags: ["v*"]
|
|
|
|
permissions:
|
|
contents: read
|
|
|
|
jobs:
|
|
release-flux-cli:
|
|
outputs:
|
|
hashes: ${{ steps.slsa.outputs.hashes }}
|
|
image_url: ${{ steps.slsa.outputs.image_url }}
|
|
image_digest: ${{ steps.slsa.outputs.image_digest }}
|
|
runs-on:
|
|
group: "Default Larger Runners"
|
|
labels: ubuntu-latest-16-cores
|
|
permissions:
|
|
contents: write # needed to write releases
|
|
id-token: write # needed for keyless signing
|
|
packages: write # needed for ghcr access
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
- name: Unshallow
|
|
run: git fetch --prune --unshallow
|
|
- name: Setup Go
|
|
uses: actions/setup-go@4dc6199c7b1a012772edbd06daecab0f50c9053c # v6.1.0
|
|
with:
|
|
go-version: 1.25.x
|
|
cache: false
|
|
- name: Setup QEMU
|
|
uses: docker/setup-qemu-action@c7c53464625b32c7a7e944ae62b3e17d2b600130 # v3.7.0
|
|
- name: Setup Docker Buildx
|
|
id: buildx
|
|
uses: docker/setup-buildx-action@8d2750c68a42422c14e847fe6c8ac0403b4cbd6f # v3.12.0
|
|
- name: Setup Syft
|
|
uses: anchore/sbom-action/download-syft@a930d0ac434e3182448fe678398ba5713717112a # v0.21.0
|
|
- name: Setup Cosign
|
|
uses: sigstore/cosign-installer@faadad0cce49287aee09b3a48701e75088a2c6ad # v4.0.0
|
|
with:
|
|
cosign-release: v2.6.1 # TODO: remove after Flux 2.8 with support for cosign v3
|
|
- name: Setup Kustomize
|
|
uses: fluxcd/pkg/actions/kustomize@62ddfc16c29b86028b855f5b999329c6abca4207 # main
|
|
- name: Login to GitHub Container Registry
|
|
uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0
|
|
with:
|
|
registry: ghcr.io
|
|
username: fluxcdbot
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
- name: Login to Docker Hub
|
|
uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0
|
|
with:
|
|
username: fluxcdbot
|
|
password: ${{ secrets.DOCKER_FLUXCD_PASSWORD }}
|
|
- name: Generate manifests
|
|
run: |
|
|
make cmd/flux/.manifests.done
|
|
./manifests/scripts/bundle.sh "" ./output manifests.tar.gz
|
|
kustomize build ./manifests/install > ./output/install.yaml
|
|
- name: Build CRDs
|
|
run: |
|
|
kustomize build manifests/crds > all-crds.yaml
|
|
- name: Generate OpenAPI JSON schemas from CRDs
|
|
uses: fluxcd/pkg/actions/crdjsonschema@62ddfc16c29b86028b855f5b999329c6abca4207 # main
|
|
with:
|
|
crd: all-crds.yaml
|
|
output: schemas
|
|
- name: Archive the OpenAPI JSON schemas
|
|
run: |
|
|
tar -czvf ./output/crd-schemas.tar.gz -C schemas .
|
|
- name: Run GoReleaser
|
|
id: run-goreleaser
|
|
uses: goreleaser/goreleaser-action@e435ccd777264be153ace6237001ef4d979d3a7a # v6.4.0
|
|
with:
|
|
version: latest
|
|
args: release --skip=validate
|
|
env:
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
HOMEBREW_TAP_GITHUB_TOKEN: ${{ secrets.BOT_GITHUB_TOKEN }}
|
|
AUR_BOT_SSH_PRIVATE_KEY: ${{ secrets.AUR_BOT_SSH_PRIVATE_KEY }}
|
|
- name: Generate SLSA metadata
|
|
id: slsa
|
|
env:
|
|
ARTIFACTS: "${{ steps.run-goreleaser.outputs.artifacts }}"
|
|
run: |
|
|
set -euo pipefail
|
|
|
|
hashes=$(echo -E $ARTIFACTS | jq --raw-output '.[] | {name, "digest": (.extra.Digest // .extra.Checksum)} | select(.digest) | {digest} + {name} | join(" ") | sub("^sha256:";"")' | base64 -w0)
|
|
echo "hashes=$hashes" >> $GITHUB_OUTPUT
|
|
|
|
image_url=fluxcd/flux-cli:$GITHUB_REF_NAME
|
|
echo "image_url=$image_url" >> $GITHUB_OUTPUT
|
|
|
|
image_digest=$(docker buildx imagetools inspect ${image_url} --format '{{json .}}' | jq -r .manifest.digest)
|
|
echo "image_digest=$image_digest" >> $GITHUB_OUTPUT
|
|
|
|
release-flux-manifests:
|
|
runs-on: ubuntu-latest
|
|
needs: release-flux-cli
|
|
permissions:
|
|
id-token: write
|
|
packages: write
|
|
steps:
|
|
- uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1
|
|
- name: Setup Kustomize
|
|
uses: fluxcd/pkg/actions/kustomize@62ddfc16c29b86028b855f5b999329c6abca4207 # main
|
|
- name: Setup Flux CLI
|
|
uses: ./action/
|
|
with:
|
|
token: ${{ secrets.GITHUB_TOKEN }}
|
|
- name: Prepare
|
|
id: prep
|
|
run: |
|
|
VERSION=$(flux version --client | awk '{ print $NF }')
|
|
echo "version=${VERSION}" >> $GITHUB_OUTPUT
|
|
- name: Login to GHCR
|
|
uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0
|
|
with:
|
|
registry: ghcr.io
|
|
username: fluxcdbot
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
- name: Login to DockerHub
|
|
uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0
|
|
with:
|
|
username: fluxcdbot
|
|
password: ${{ secrets.DOCKER_FLUXCD_PASSWORD }}
|
|
- name: Push manifests to GHCR
|
|
run: |
|
|
mkdir -p ./ghcr.io/flux-system
|
|
flux install --registry=ghcr.io/fluxcd \
|
|
--components-extra=image-reflector-controller,image-automation-controller \
|
|
--export > ./ghcr.io/flux-system/gotk-components.yaml
|
|
|
|
cd ./ghcr.io && flux push artifact \
|
|
oci://ghcr.io/fluxcd/flux-manifests:${{ steps.prep.outputs.version }} \
|
|
--path="./flux-system" \
|
|
--source=${{ github.repositoryUrl }} \
|
|
--revision="${{ github.ref_name }}@sha1:${{ github.sha }}"
|
|
- name: Push manifests to DockerHub
|
|
run: |
|
|
mkdir -p ./docker.io/flux-system
|
|
flux install --registry=docker.io/fluxcd \
|
|
--components-extra=image-reflector-controller,image-automation-controller \
|
|
--export > ./docker.io/flux-system/gotk-components.yaml
|
|
|
|
cd ./docker.io && flux push artifact \
|
|
oci://docker.io/fluxcd/flux-manifests:${{ steps.prep.outputs.version }} \
|
|
--path="./flux-system" \
|
|
--source=${{ github.repositoryUrl }} \
|
|
--revision="${{ github.ref_name }}@sha1:${{ github.sha }}"
|
|
- uses: sigstore/cosign-installer@faadad0cce49287aee09b3a48701e75088a2c6ad # v4.0.0
|
|
with:
|
|
cosign-release: v2.6.1 # TODO: remove after Flux 2.8 with support for cosign v3
|
|
- name: Sign manifests
|
|
env:
|
|
COSIGN_EXPERIMENTAL: 1
|
|
run: |
|
|
cosign sign --yes ghcr.io/fluxcd/flux-manifests:${{ steps.prep.outputs.version }}
|
|
cosign sign --yes docker.io/fluxcd/flux-manifests:${{ steps.prep.outputs.version }}
|
|
- name: Tag manifests
|
|
run: |
|
|
flux tag artifact oci://ghcr.io/fluxcd/flux-manifests:${{ steps.prep.outputs.version }} \
|
|
--tag latest
|
|
|
|
flux tag artifact oci://docker.io/fluxcd/flux-manifests:${{ steps.prep.outputs.version }} \
|
|
--tag latest
|
|
|
|
release-provenance:
|
|
needs: [release-flux-cli]
|
|
permissions:
|
|
actions: read # for detecting the Github Actions environment.
|
|
id-token: write # for creating OIDC tokens for signing.
|
|
contents: write # for uploading attestations to GitHub releases.
|
|
uses: slsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@v2.1.0
|
|
with:
|
|
provenance-name: "provenance.intoto.jsonl"
|
|
base64-subjects: "${{ needs.release-flux-cli.outputs.hashes }}"
|
|
upload-assets: true
|
|
|
|
dockerhub-provenance:
|
|
needs: [release-flux-cli]
|
|
permissions:
|
|
actions: read # for detecting the Github Actions environment.
|
|
id-token: write # for creating OIDC tokens for signing.
|
|
packages: write # for uploading attestations.
|
|
uses: slsa-framework/slsa-github-generator/.github/workflows/generator_container_slsa3.yml@v2.1.0
|
|
with:
|
|
image: ${{ needs.release-flux-cli.outputs.image_url }}
|
|
digest: ${{ needs.release-flux-cli.outputs.image_digest }}
|
|
registry-username: fluxcdbot
|
|
secrets:
|
|
registry-password: ${{ secrets.DOCKER_FLUXCD_PASSWORD }}
|
|
|
|
ghcr-provenance:
|
|
needs: [release-flux-cli]
|
|
permissions:
|
|
actions: read # for detecting the Github Actions environment.
|
|
id-token: write # for creating OIDC tokens for signing.
|
|
packages: write # for uploading attestations.
|
|
uses: slsa-framework/slsa-github-generator/.github/workflows/generator_container_slsa3.yml@v2.1.0
|
|
with:
|
|
image: ghcr.io/${{ needs.release-flux-cli.outputs.image_url }}
|
|
digest: ${{ needs.release-flux-cli.outputs.image_digest }}
|
|
registry-username: fluxcdbot
|
|
secrets:
|
|
registry-password: ${{ secrets.GITHUB_TOKEN }}
|