-
Notifications
You must be signed in to change notification settings - Fork 119
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Enhancement: Add signed SLSA attestations to nightly docker builds #125
Comments
Is this only related to the docker nightly images or also to the Tensorflow nightly wheels built with these images? Cause we still don't publicly know on which specific nightly commits the nightly wheels are built. See #72 |
They're not really related. The wheels need a lot more work to get attestations added. |
This would just be the docker nightly images. Right now we can create attestations on a general hashable artifacts (which could apply to the wheels), golang binaries, and OCI artifacts. We are working to create better SLSA attestations for the python ecosystem separately, so that attestations can directly be retrieved through Re the issue: the aim is that slsa attestations will provide information on the config source where it was built, including the commit SHA. |
Should close tensorflow/build#125 TODO: the same for all other containers we maintain, maybe? Signed-off-by: Mihai Maruseac <mihaimaruseac@google.com>
Should close tensorflow/build#125 TODO: the same for all other containers we maintain, maybe? Signed-off-by: Mihai Maruseac <mihaimaruseac@google.com>
(closed by mistake on my fork) |
Hi! I'm reaching out on behalf of the Open Source Security Foundation (openssf.org). We work on improving supply-chain security of critical open source projects. We believe we can help improve the tamper resistance of TF's nightly docker builds, with just a few lines of code. Starting with nightly docker builds is relatively low-risk, and allows some testing of the verification flow before moving to the more stable images.
These docker builds are built in this repository via GitHub Actions. Adding a provenance attestation during the build process allows a cryptographically verifiable guarantee that the image was built in this repository. This provenance is a file with metadata that lets users know that the container images were built from your repository’s workflow and not altered by anyone.
The container provenance generator workflow uploads the attestation in the registry using Sigstore's attestation specification. This is projected to go GA in the next few weeks (the API may be change in future releases of the generator), and we would love to use TF's nightly builds as an early adoption.
Generating these attestations is also a step toward adopting Supply-chain Levels for Software Artifacts (SLSA). SLSA is a security framework to improve transparency and authenticity of the build / release process. It’s designed and used by a consortium of companies including Google, Intel, Chainguard, Citi, and Datadog, under the umbrella of the Open Source Security Foundation. By generating these attestations in the future for stable docker builds, your project will reach SLSA Level 3 for provenance. You can even add a SLSA badge to your repository so users know that you take security seriously.
If you're interested in reading more, check out this recent blog post, which describes how some of the recent supply-chain attacks would have been prevented using SLSA provenance.
Happy to answer any question you might have.
I'll follow up with a PR and link here to show the changes needed to add provenance to the docker workflow.
cc @ianlewis @mihaimaruseac @laurentsimon
The text was updated successfully, but these errors were encountered: