This workflow illustrates creation of SPDX and CycloneDX SBOMs for a java application. Keycloak is used as an example due to its wide use and complexity. The workflow is well commented and can be used as a reference implementation for your own projects.
- Create both SPDX and CycloneDX SBOMs using open source tools
- Showcase the additional SBOM lifecycle steps
- Provide sample tools and implementation for others to use
Generate SBOM with Trivy
JobAugment Keycloak SPDX
andAugment Keycloak CycloneDX
Jobs- Tool
- Notes
- There is metadata that typically cannot be determined through analysis. This is metadata that needs to be determined by the author of the primary component and author of the SBOM document. Examples of this information are project description, SBOM author, and supplier.
- There are multiple ways to augment this metadata, you can use jq, write a custom application, or merge a static SBOM into a generated one.
Enrich Keycloak SPDX
andEnrich Keycloak CycloneDX
Jobs- Tool
- Notes
- SBOM generation tools usually find components and their dependencies by analyzing package manager configuration files. This usually does not provide enough information to meet NTIA minimum elements, and tools like parlay can enrich components in an SBOM by looking up additional component metadata from external databases.
Display SBOM quality score through sbomqs
Job- Tool