-
-
Notifications
You must be signed in to change notification settings - Fork 255
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
Provide validation of the SBOM content #3484
Comments
ty for the link. I have checked the CycloneDX cli tool and tested it on one of the sbom files. It validates with success while its not clear what happens under the hood. |
btw. for the notarization service I have worked on generating slsa provenance files and a script to download and verify releases: https://github.com/eclipse-cbi/macos-notarization-service/blob/main/.github/workflows/release.yml Test artifacts are available here: https://github.com/OtterdogTest/macos-notarization-service/releases/tag/v1.2.0 Maybe a good reference for comparison. |
The IVT job is currently working reasonably well, although without a GA build after the GCC/GLIB fix went in we cannot run this against a GA build. I have put in some fixes to allow it to work with a non-GA build including skipping the verification of the temurin-build SHA since that cannot be easily verified with the current approach unless it was a tagged commit. This testing has also highlighted the absence of the FreeType version information in the case where the FreeType code is not downloaded - #3493 has been raised to address this. At the moment the code is in an
When I saw this I managed to make sure that was integrated into my checks to and it works well as you say - thanks. I'll aim to see what I can do with the other links you've given :-) |
Going to skip the explicit freetype check for now in the basis of the large number of inconsistent versions discovered in #3504 (comment) - will reinstate when that is resolved. |
I've got the verification now running successfully for all tested fields. It currently runs on a Linux machine and does a series of checks. It does not verify signatures on Windows or Mac builds, but I feel that after some issues we have experienced in the October 2023 release cycle (adoptium/ci-jenkins-pipelines#831, adoptium/ci-jenkins-pipelines#832, adoptium/temurin#4 (comment)) that will be a requirement going forward, potentially building on the work from @netomi above and/or as part of #3494. I think I'm probably right in saying that it won't be possible to do that well enough within the job that is running on Linux so we'll need something alongside my existing processes. |
List of related tickets:
I would consider #3528 to be mandatory for claiming any SLSA level, the remaining are optional to further improve our attestation imho. Something that we do not capture yet (and its not mentioned in the general SLSA requirements) is that we identify in our attestation by which builder this attestation has been produced. The intoto format declares that the builder is mandatory, but that lies in the nature of the format as it is intended to be used by tools for automatic validation purposes. In the case of Eclipse Temurin we use a highly customized format where the builder is implicitly assumed from the format, so I would expect that it would be ok to omit an identification of the builder itself in our specific case. |
Bumping back to earlier plan as this was completed in the middle of December. |
We have lots of information in our SBOM. As part of SLSA verification requirements we should ensure that as much as possible of the data is validated including checking that the fields with information we populate about the build look "reasonable" and include checking versions of some of the prerequisites and validate that the github SHAs listed are valid.
FYI @andrew-m-leonard @netomi as this came out of the conversation we had a few weeks ago. My first pass of a validation script that does some validation on our nightly JDK17 versions is
validateSBOMcontent.sh.txt - this is very much an initial prototype (and is not currently in git until we decide on a suitable location for it) and will need to be enhanced to ensure that it can handle the correct checks for all of our openjdk versions and probably other checks.
At the moment it checks the GLIBC/GCC and ALSA versions against "expected" versions as well as validating that the GIT shas for the openjdk codebase and temurin-build are present in the corresponding repositories. All suggestions for further checks welcome. Note that this will not currently validate the last GA versions as they have a number of omissions (e.g. no GLIBC etc.) so this can only be reasonably used against the nightly builds at present.
I have been prototyping this by running it as part of a longer build download verification process that validates all the GPG signatures etc. and does other integrity checks on the downloads, so this issue purely covers validation of the SBOM content.
We can also look at CycloneDX's format validator to check that the overall format of the file is as per the CycloneDX specification.
The text was updated successfully, but these errors were encountered: