SLSA Assessment

Flux assessment of SLSA Level 3 requirements.

Introduction

Supply Chain Levels for Software Artifacts, or SLSA (pronounced “salsa”), is a security framework which aims to prevent tampering and secure artifacts in a project. SLSA is designed to support automation that tracks code handling from source to binary protecting against tampering regardless of the complexity of the software supply chain.

Starting with Flux version 2.0.0, the build, release and provenance portions of the Flux project supply chain provisionally meet SLSA Build Level 3.

SLSA Requirements and Flux Compliance State

What follows is an assessment made by members of the Flux core maintainers team on how Flux v2.0 complies with the Build Level 3 requirements as specified by SLSA v1.0.

Producer Requirements

RequirementRequired at SLSA L3Met by Flux
Choose an appropriate build platformYesYes
Follow a consistent build processYesYes
Distribute provenanceYesYes

Choose an appropriate build platform

The producer MUST choose a builder capable of producing Build Level 3 provenance.

  • The Flux project uses Git for source code management and the Flux project’s repositories are hosted on GitHub under the FluxCD organization.
  • All the Flux maintainers are required to have two-factor authentication enabled and to sign-off all their contributions.
  • The Flux project uses GitHub Actions and GitHub Runners for building all its release artifacts.
  • The build and release process runs in isolation on an ephemeral environment provided by GitHub-hosted runners.

Follow a consistent build process

The producer MUST build their artifact in a consistent manner such that verifiers can form expectations about the build process.

  • The build and release process is defined in code (GitHub Workflows and Makefiles) and is kept under version control.
  • The GitHub Workflows make use of GitHub Actions pinned to their Git commit SHA and are kept up-to-date using GitHub Dependabot.
  • All changes to build and release process are done via Pull Requests that must be approved by at least one Flux maintainer.
  • The release process can only be kicked off by a Flux maintainer by pushing a Git tag in the semver format.

Distribute provenance

The producer MUST distribute provenance to artifact consumers.

  • The Flux project uses the official SLSA GitHub Generator project for provenance generation and distribution.
  • The provenance for the release artifacts published to GitHub releases (binaries, SBOMs, deploy manifests, source code) is generated using the generator_generic_slsa3 GitHub Workflow provided by the SLSA GitHub Generator project.
  • The provenance for the release artifacts published to GitHub Container Registry and to DockerHub (Flux controllers multi-arch container images) is generated using the generator_container_slsa3 GitHub Workflow provided by the SLSA GitHub Generator project.

Build Platform Requirements

Provenance generation

RequirementRequired at SLSA L3Met by Flux
Provenance ExistsYesYes
Provenance is AuthenticYesYes
Provenance is UnforgeableYesYes

The build process MUST generate provenance that unambiguously identifies the output package by cryptographic digest and describes how that package was produced.

  • The Flux project release workflows make use of the official SLSA GitHub Generator project for provenance generation.
  • The provenance file stores the SHA-256 hashes of the release artifacts (binaries, SBOMs, deploy manifests, source code).
  • The provenance identifies the Flux container images using their digest in SHA-256 format.

Consumers MUST be able to validate the authenticity of the provenance attestation in order to ensure integrity and define trust.

  • The provenance is signed by Sigstore Cosign using the GitHub OIDC identity and the public key to verify the provenance is stored in the public Rekor transparency log.
  • The release process and the provenance generation are run in isolation on an ephemeral environment provided by GitHub-hosted runners.
  • The provenance of the Flux release artifacts (binaries, container images, SBOMs, deploy manifests) can be verified using the official SLSA verifier tool.

Provenance MUST be strongly resistant to forgery by tenants.

  • The provenance generation workflows run on ephemeral and isolated virtual machines which are fully managed by GitHub.
  • The provenance signing secrets are ephemeral and are generated through Sigstore’s keyless signing procedure.
  • The SLSA GitHub generator runs on separate virtual machines than the build and release process, so that the Flux build scripts don’t have access to the signing secrets.

Isolation strength

RequirementRequired at SLSA L3Met by Flux
HostedYesYes
IsolatedYesYes

All build steps ran using a hosted build platform on shared or dedicated infrastructure.

  • The release process and the provenance generation are run in isolation on an ephemeral environment provided by GitHub-hosted runners.
  • The provenance generation is decoupled from the build process, the SLSA GitHub generator runs on separate virtual machines fully managed by GitHub.

The build platform ensured that the build steps ran in an isolated environment, free of unintended external influence.

  • The release process can only be kicked off by a Flux maintainer by pushing a Git tag in the semver format.
  • The release process runs on ephemeral and isolated virtual machines which are fully managed by GitHub.
  • The release process can’t access the provenance signing key, because the provenance generator runs in isolation on separate GitHub-hosted runners.

Provenance verification

The provenance of the Flux release artifacts (binaries, container images, SBOMs, deploy manifests) can be verified using the official SLSA verifier tool.

Container images

The provenance of the Flux multi-arch container images hosted on GitHub Container Registry and DockerHub can be verified using the official SLSA verifier tool and Sigstore Cosign.

What follows is the list of Flux components along with their minimum required version for provenance verification.

Git RepositoryImagesMin versionProvenance (SLSA L3)
flux2docker.io/fluxcd/flux-cli
ghcr.io/fluxcd/flux-cli
v2.0.1Yes
source-controllerdocker.io/fluxcd/source-contoller
ghcr.io/fluxcd/source-contoller
v1.0.0Yes
kustomize-controllerdocker.io/fluxcd/kustomize-contoller
ghcr.io/fluxcd/kustomize-contoller
v1.0.0Yes
notification-controllerdocker.io/fluxcd/notification-contoller
ghcr.io/fluxcd/notification-contoller
v1.0.0Yes
helm-controllerdocker.io/fluxcd/helm-contoller
ghcr.io/fluxcd/helm-contoller
v0.35.0Yes
image-reflector-controllerdocker.io/fluxcd/image-reflector-contoller
ghcr.io/fluxcd/image-reflector-contoller
v0.29.0Yes
image-automation-controllerdocker.io/fluxcd/image-automation-contoller
ghcr.io/fluxcd/image-automation-contoller
v0.35.0Yes

Example

We will be using the source-controller container image hosted on GHCR for this example, but these instructions can be used for all Flux container images.

First, collect the digest of the image to verify:

$ crane digest ghcr.io/fluxcd/source-controller:v1.0.0
sha256:8dfd386a338eab2fde70cd7609e3b35a6e2f30283ecf2366da53013295fa65f3

Using the digest, verify the provenance of the Flux controller by specifying the repository and version:

$ slsa-verifier verify-image ghcr.io/fluxcd/source-controller:v1.0.0@sha256:8dfd386a338eab2fde70cd7609e3b35a6e2f30283ecf2366da53013295fa65f3 --source-uri github.com/fluxcd/source-controller --source-tag v1.0.0
Verified build using builder https://github.comslsa-framework/slsa-github-generator/.github/workflows/generator_container_slsa3.yml@refs/tags/v1.7.0 at commit a40e0da705f26710077a7591f9dad05b7cd55acd
PASSED: Verified SLSA provenance

Using Cosign, verify the SLSA provenance attestation by specifying the workflow and GitHub OIDC issuer:

$ cosign verify-attestation --type slsaprovenance --certificate-identity-regexp https://github.com/slsa-framework/slsa-github-generator/.github/workflows/generator_container_slsa3.yml@refs/tags/v --certificate-oidc-issuer https://token.actions.githubusercontent.com ghcr.io/fluxcd/source-controller:v1.0.0
Verification for ghcr.io/fluxcd/source-controller:v1.0.0 --
The following checks were performed on each of these signatures:
  - The cosign claims were validated
  - Existence of the claims in the transparency log was verified offline
  - The code-signing certificate was verified using trusted certificate authority certificates
Certificate subject: https://github.com/slsa-framework/slsa-github-generator/.github/workflows/generator_container_slsa3.yml@refs/tags/v1.7.0
Certificate issuer URL: https://token.actions.githubusercontent.com
GitHub Workflow Trigger: push
GitHub Workflow SHA: a40e0da705f26710077a7591f9dad05b7cd55acd
GitHub Workflow Name: release
GitHub Workflow Repository: fluxcd/source-controller
GitHub Workflow Ref: refs/tags/v1.0.0

Flux artifacts

The provenance of the Flux release artifacts (binaries, container images, SBOMs, deploy manifests) published on GitHub can be verified using the official SLSA verifier tool.

Example

In this example we use the Flux SBOM file, but the instructions can be used for all artifacts included with the Flux release.

First, download the release artifacts from GitHub:

FLUX_VER=2.0.1 && \
gh release download v${FLUX_VER} -R=fluxcd/flux2 -p="*"

Using the provenance.intoto.jsonl file, verify the provenance attestation of the Flux SBOM (flux_<version>_sbom.spdx.json):

$ slsa-verifier verify-artifact --provenance-path provenance.intoto.jsonl --source-uri github.com/fluxcd/flux2 --source-tag v${FLUX_VER} flux_${FLUX_VER}_sbom.spdx.json
Verified signature against tlog entry index 27066821 at URL: https://rekor.sigstore.dev/api/v1/log/entries/24296fb24b8ad77ac2d2dc6381ec7f1f04d991344771214c5fb5861621dbd9da6f0551f806cbf609
Verified build using builder https://github.comslsa-framework/slsa-github-generator/.github/workflows/generator_generic_slsa3.yml@refs/tags/v1.7.0 at commit 9b3162495ce1b99b1fcdf137c553f543eafe3ec7
Verifying artifact flux_2.0.1_sbom.spdx.json: PASSED
PASSED: Verified SLSA provenance