Toolset that helps with creating and interacting with SBOMs, enriching with licensing and copyright information, and checking for Open Source license compliance
Project description
Compliance Assistant
Compliance Assistant is a comprehensive toolset designed to assist with creating and managing Software Bill of Materials (SBOMs). It helps in enriching SBOMs with licensing and copyright information and checks for Open Source license compliance using data from ClearlyDefined.
Features
- SBOM Generation: Automatically generate a CycloneDX SBOM from a specified code repository.
- SBOM Enrichment: Enhance an existing SBOM with detailed licensing and copyright information using ClearlyDefined data.
- SBOM Parsing: Extract specific information from a CycloneDX SBOM.
- License and Copyright Information Retrieval: Fetch licensing and copyright details for a single package from ClearlyDefined.
Requirements
- Python 3.10+
- Internet connection for accessing ClearlyDefined services
- Docker for generating SBOMs
Installation
Install and run via pipx (Recommended)
pipx makes installing and running Python programs easier and avoid conflicts with other packages. Install it with
pip3 install pipx
The following one-liner both installs and runs this program from PyPI:
pipx run compliance-assistant
If you want to be able to use compliance-assistant without prepending it with pipx run
every time, install it globally like so:
pipx install compliance-assistant
compliance-assistant will then be available in ~/.local/bin
, which must be added to your $PATH
.
After this, make sure that ~/.local/bin
is in your $PATH
. On Windows, the required path for your environment may look like %USERPROFILE%\AppData\Roaming\Python\Python310\Scripts
, depending on the Python version you have installed.
To upgrade compliance-assistant to the newest available version, run this command:
pipx upgrade compliance-assistant
Other installation methods
You may also use pure pip
or poetry
to install this package.
Usage
The Compliance Assistant provides multiple commands to facilitate different tasks. Each command is invoked through the compliance-assistant
command-line interface with specific options.
Depending on your exact installation method, this may be one of
# Run via pipx
pipx run compliance-assistant
# Installation via pipx or pip
compliance-assistant
# Run via poetry
poetry run compliance-assistant
In the following, we will just use compliance-assistant
Command Structure
compliance-assistant [global-options] <command> [command-options]
Commands
Please run compliance-assistant --help
to get an overview of the commands and global options.
For each command, you can get detailed options, e.g. compliance-assistant sbom-enrich --help
.
Examples
- Create an SBOM for the current directory:
compliance-assistant sbom-generate -d .
- Enrich an SBOM with ClearlyDefined data:
compliance-assistant sbom-enrich -f /tmp/my-sbom.json -o /tmp/my-enriched-sbom.json
- Extract certain data from an SBOM:
compliance-assistant sbom-parse -f /tmp/my-enriched-sbom.json -e purl,copyright,name
- Gather ClearlyDefined licensing/copyright information for one package:
compliance-assistant clearlydefined -p pkg:pypi/inwx-dns-recordmaster@0.3.1
Run as GitHub workflow
You may also use GitHub workflows to generate an SBOM regularly, e.g. on each published release:
name: Generate and enrich SBOM
on:
release:
types: [published]
jobs:
# Generate raw SBOM using cdxgen, but with NPMJS package, not Docker container
sbom-gen:
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
- name: Install cdxgen
run: npm install -g @cyclonedx/cdxgen
- name: Generate CycloneDX SBOM with cdxgen
run: cdxgen -r . -o ${{ runner.temp }}/sbom-raw.json
- name: Store raw SBOM as artifact
uses: actions/upload-artifact@v4
with:
name: sbom-raw
path: ${{ runner.temp }}/sbom-raw.json
# Enrich the generated SBOM
sbom-enrich:
runs-on: ubuntu-22.04
needs: sbom-gen
steps:
# Install compliance-assistant
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.12"
- name: Install compliance-assistant
run: pip install compliance-assistant
# Download raw SBOM
- uses: actions/download-artifact@v4
with:
name: sbom-raw
path: ${{ runner.temp }}
# Run compliance-assistant sbom-enrich
- name: Enrich SBOM
run: compliance-assistant sbom-enrich -f ${{ runner.temp }}/sbom-raw.json -o ${{ runner.temp }}/sbom-enriched.json
# Upload enriched SBOM as artifact
- name: Store enriched SBOM as artifact
uses: actions/upload-artifact@v4
with:
name: sbom-enriched
path: ${{ runner.temp }}/sbom-enriched.json
Development and Contribution
We welcome contributions to improve Compliance Assistant. Please read CONTRIBUTING.md for all information.
License
The content of this repository is licensed under the Apache 2.0 license.
There may be components under different, but compatible licenses or from different copyright holders. The project is REUSE compliant which makes these portions transparent. You will find all used licenses in the LICENSES directory.
The project is has been started by the OpenRail Association. You are welcome to contribute!
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file compliance_assistant-0.2.0.tar.gz
.
File metadata
- Download URL: compliance_assistant-0.2.0.tar.gz
- Upload date:
- Size: 24.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.1 Linux/6.5.0-1023-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8e8982a743dba868356fc226365b96f753c02aac2b702f36bf41d9a999b53104 |
|
MD5 | a86ecac144d30693c23f162e7938f748 |
|
BLAKE2b-256 | 6cdc47f9314df69d0f034924da2b2ea777e1c5bb47684577976abc8c4b7c64b0 |
File details
Details for the file compliance_assistant-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: compliance_assistant-0.2.0-py3-none-any.whl
- Upload date:
- Size: 31.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.1 Linux/6.5.0-1023-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6cc9e247d586879cb14f226ce71fd19ac5fcb9672ff007a91a8461b0aa7d5cdf |
|
MD5 | bb73d30b4951dfd80350302f1a3319f8 |
|
BLAKE2b-256 | d3f6e0f4497de92a81e65ac012baee0006a308b5686224c4b26af38336a7de0f |