Skip to main content

Convert SBOM between formats

Project description

SBOMConvert

The SBOMConvert is a free, open source tool to transform a SBOM (Software Bill of Materials) into another format. The format supported are various versions of SBOMs in either SPDX and CycloneDX formats.

SBOMs are supported in the following formats and versions:

SBOM Type Version Format
SPDX 2.2 TagValue
SPDX 2.2 JSON
SPDX 2.2 YAML
SPDX 2.2 RDF
SPDX 2.2 XML
SPDX 2.3 TagValue
SPDX 2.3 JSON
SPDX 2.3 YAML
SPDX 2.3 RDF
SPDX 2.3 XML
CycloneDX 1.4 JSON
CycloneDX 1.4 XML
CycloneDX 1.5 JSON
CycloneDX 1.5 XML
CycloneDX 1.6 JSON
CycloneDX 1.6 XML

Note that support for SPDX RDF and XML formats is limited to a few package attributes.

Installation

To install use the following command:

pip install sbomconvert

Alternatively, just clone the repo and install dependencies using the following command:

pip install -U -r requirements.txt

The tool requires Python 3 (3.9+). It is recommended to use a virtual python environment especially if you are using different versions of python. virtualenv is a tool for setting up virtual python environments which allows you to have all the dependencies for the tool set up in a single environment, or have different environments set up for testing using different versions of Python.

Usage

usage: sbomconvert [-h] [-i INPUT_FILE] [-d] [--sbom {spdx,cyclonedx}] [--format {tag,json,yaml}] [-o OUTPUT_FILE] [-V]

SBOMconvert transforms a Software Bill of Materials from one format to another, or between output formats.

options:
  -h, --help            show this help message and exit
  -V, --version         show program's version number and exit

Input:
  -i INPUT_FILE, --input-file INPUT_FILE
                        identity of SBOM

Output:
  -d, --debug           add debug information
  --sbom {spdx,cyclonedx}
                        specify type of sbom to generate (default: spdx)
  --format {tag,json,yaml}
                        specify format of software bill of materials (sbom) (default: tag)
  -o OUTPUT_FILE, --output-file OUTPUT_FILE
                        output filename (default: output to stdout)

Operation

The --input-file option is used to identify of the SBOM. The tool will automatically detect the type and version of SBOM.

The --sbom option is used to specify the format of the generated SBOM (the default is SPDX). The --format option can be used to specify the formatting of the SBOM (the default is Tag Value format for a SPDX SBOM). JSON format is supported for both SPDX and CycloneDX SBOMs).

The --output-file option is used to control the destination of the output generated by the tool. The default is to report to the console but can be stored in a file (specified using --output-file option).

Licence

Licenced under the Apache 2.0 Licence.

The tool uses a local copy of the SPDX Licenses List which is released under Creative Commons Attribution 3.0 (CC-BY-3.0).

Limitations

The usefulness of the tool is dependent on the SBOM data which is provided to the tool. Unfortunately, the tool is unable to determine the validity or completeness of such a SBOM file; users of the tool are therefore reminded that they should assert the quality of any data which is provided to the tool.

Invalid SBOMs will lead to unpredictable results.

When processing and validating licenses, the application will use a set of synonyms to attempt to map some license identifiers to the correct SPDX License Identifiers. However, the user of the tool is reminded that they should assert the quality of any data which is provided by the tool particularly where the license identifier has been modified.

Feedback and Contributions

Bugs and feature requests can be made via GitHub Issues.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sbomconvert-0.1.0-py2.py3-none-any.whl (9.2 kB view details)

Uploaded Python 2Python 3

File details

Details for the file sbomconvert-0.1.0-py2.py3-none-any.whl.

File metadata

  • Download URL: sbomconvert-0.1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.8

File hashes

Hashes for sbomconvert-0.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 cd4200d764ade935e430ed7a4e6808d37fd7d71d242f84e17c2c2508e05ebb77
MD5 f5dbdc9b8cfaea9d02b23a08245fbe74
BLAKE2b-256 eb4e4fcf75d4be956aec70d911c720a5e3f3c1ebf4cb102ded64a2ee21ff77e9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page