-
-
Notifications
You must be signed in to change notification settings - Fork 251
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
Implement a new Sign-JSON type job for secure signing of SBOM json using an EF PEM/signService #3946
Comments
Work that needs to be done: https://ci.adoptium.net/job/build-scripts/job/release/job/sign_temurin_jsf/ has been created to replicate https://ci.adoptium.net/job/build-scripts/job/release/job/sign_temurin_gpg/ but to use the PEM format. The sign_temurin_jsf job needs to be updated to use https://github.com/adoptium/temurin-build/blob/master/cyclonedx-lib/sign_src/TemurinSignSBOM.java to sign the SBOM file Because we dont want the jenkins worker node to build any of the cyclone dx jars, this needs to run in the build scripts during the jdk build, temurin-build/cyclonedx-lib/build.xml Line 68 in 62ecfba
|
#4017 ensures the SBOM signing jars get built. adoptium/ci-jenkins-pipelines#1131 kicks off the sign_temurin_jsf job. Work in progress |
@sxa It looks like the SBOM signing jars can only be built with JDK17+ This would make it difficult to build the jars on a build node for platforms like Solaris for example. It should be discussed the feasibility of building the jars on the eclipse signing node |
Andrew's idea of cacheing the cyclone dx dependency jars can be done on the eclipse signing node. Instead of them being downloaded during the ant build step |
From chatting with Stewart and Thomas, ideally we don't want to build on the signing node if we can help it. We could add in a "build-sbom-jars-and-sign" job, which builds on any suitable node, and is then used as upstream to the "sign_temurin_jsf" job. |
https://ci.adoptium.net/job/build_sign_sbom_libraries/ is a new jenkins job which will build the signing libraries on a x64 linux node and then archives the jar files. This job will need to be integrated with https://ci.adoptium.net/job/build-scripts/job/release/job/sign_temurin_jsf/ |
https://github.com/adoptium/ci-jenkins-pipelines/pull/1131/files is at a state where it kicks off the sign_temurin_jsf job together with the build job. But the signing mechanism is hitting an error
See https://ci.adoptium.net/job/build-scripts/job/release/job/sign_temurin_jsf/19/console |
Update, @sxa has fixed the above error. The key was being stored in an encrypted state, making it difficult for TemurinSignSBOM to read |
While I have prototyped with an unencrypted key in jenkins, the solution we want is to have it encrypted but to decrypt on the fly. For this to work we need:
|
adoptium/ci-jenkins-pipelines#1131 and #4094 are ready to be merged |
The above prs were merged |
EPIC adoptium/ci-jenkins-pipelines#610 documents the parts required to implement SBOM json signing.
This issue is to implement the necessary temurin-build/ci-jenkins-pipelines parts to interface with an EF provided signing PEM or "json signing service".
The text was updated successfully, but these errors were encountered: