Skip to main content

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

OpenRail Administrative Project Test suites REUSE status The latest version of Compliance Assistant can be found on PyPI. Information on what versions of Python Compliance Assistant supports can be found on PyPI.

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.
  • License compliance support: Extract and unify licenses from SBOM, suggest possible license outbound candidates

Some of these features are made possible by excellent programs such as flict, cdxgen and syft.

Requirements

  • Python 3.10+
  • Internet connection for accessing ClearlyDefined services
  • At least one SBOM generator:

Installation

Install and run via pipx (Recommended)

pipx makes installing and running Python programs easier and avoids 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 uv 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 uv
uv run compliance-assistant

In the following, we will just use compliance-assistant.

Command Structure

compliance-assistant <command> [<subcommand>] [subcommand-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 using syft: compliance-assistant sbom generate -g syft -d . -o /tmp/my-sbom.json
  • 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 fetch -p pkg:pypi/inwx-dns-recordmaster@0.3.1
  • Get all licenses found in the enriched SBOM: compliance-assistant licensing list -f /tmp/my-enriched-sbom.json -o plain
  • Get license outbound candidate based on licenses from SBOM: compliance-assistant licensing outbound -f /tmp/my-enriched-sbom.json

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 the SBOM with syft and enrich the generated SBOM
  sbom-generate-and-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"
          cache: "pip"
      - name: Install compliance-assistant
        run: pip install compliance-assistant
      # Install syft
      - run: mkdir -p ~/.local/bin
      - name: Install syft
        run: curl -sSfL https://raw.githubusercontent.com/anchore/syft/main/install.sh | sh -s -- -b ~/.local/bin
      # Generate SBOM with syft via compliance-assistant
      - name: Generate SBOM with syft
        run: compliance-assistant sbom generate -g syft -d . -o ${{ runner.temp }}/sbom-raw.json
      # Enrich SBOM with compliance-assistant
      - 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 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

compliance_assistant-1.1.6.tar.gz (19.0 kB view details)

Uploaded Source

Built Distribution

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

compliance_assistant-1.1.6-py3-none-any.whl (23.6 kB view details)

Uploaded Python 3

File details

Details for the file compliance_assistant-1.1.6.tar.gz.

File metadata

  • Download URL: compliance_assistant-1.1.6.tar.gz
  • Upload date:
  • Size: 19.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for compliance_assistant-1.1.6.tar.gz
Algorithm Hash digest
SHA256 60888ea5b9c062130b6734f1ba5b7bdc02d090d1708cbb2448369b537fb87e0c
MD5 83a64e3403bd39e3c901686905d8d063
BLAKE2b-256 6cbb07a03b3c0877afc4a7039389ea7ad8b817d3421f584bbb4d4aca10e7ec54

See more details on using hashes here.

Provenance

The following attestation bundles were made for compliance_assistant-1.1.6.tar.gz:

Publisher: publish.yaml on OpenRailAssociation/compliance-assistant

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file compliance_assistant-1.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for compliance_assistant-1.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 8f39a3a8cb1dc0efe2c4005fab8c21b71cc7dfb7bee6ff8c4a155ad39870651d
MD5 d85573ba96ebb199da85b0fc3a90e858
BLAKE2b-256 15e2698836377909499269e9c0a5c4ede47ad7a1926f6d93a9990a653d4e00a3

See more details on using hashes here.

Provenance

The following attestation bundles were made for compliance_assistant-1.1.6-py3-none-any.whl:

Publisher: publish.yaml on OpenRailAssociation/compliance-assistant

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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