Skip to main content

Interactive terminal frontend for viewing Software Bill of Materials (SBOM) files

Project description

Sbommage

SBOM + Rummage = Sbommage.

Pronounced (in my British English) as "ess-bomb-idge", or "SBOM Mage 🧙" if you prefer.

Sbommage is an interactive terminal frontend for viewing Software Bill of Materials (SBOM) files in various formats.

A short video showing Sbommage

Introduction

Software Bill of Materials (SBOM) files are increasingly important in software supply chain security. However, they come in multiple formats (SPDX, CycloneDX, Syft's native format), each with their own structure and complexity. Sbommage aims to provide a consistent, user-friendly way to view and explore SBOM data, regardless of the underlying format.

Installation

Sbommage is written in Python and requires Python 3.8 or later.

From PyPI (Recommended)

The easiest way to install sbommage is from PyPI:

pip install sbommage

Or use the install script:

curl -sSL https://raw.githubusercontent.com/popey/sbommage/main/install.sh | bash

From GitHub Releases

Download the latest release from the GitHub releases page.

Using Homebrew (macOS/Linux)

brew tap popey/sbommage
brew install sbommage

Using Docker

Note: -it is required for interaction with the application. Setting the TERM variable allows for better colour support.

docker run --rm -it -e TERM=xterm-256color -v $(pwd):/data ghcr.io/popey/sbommage:latest /data/your-sbom.json

From Source

For development or if you prefer to install from source:

git clone https://github.com/popey/sbommage
cd sbommage
pip install -e .

Using uv (Alternative)

If you use uv for Python environment management:

git clone https://github.com/popey/sbommage
cd sbommage
uv venv
source .venv/bin/activate  # On Windows: .venv\Scripts\activate
uv pip install -e .

Usage

Point sbommage at an SBOM file:

./sbommage example_sboms/nextcloud-latest-syft-sbom.json

Sbommage will detect the SBOM format (SPDX, CycloneDX, GitHub, or Syft), and present the data in an interactive interface. Use the cursor keys or mouse to navigate the tree on the left pane. Click or press Enter on an item to see detailed information in the right pane.

Keys:

Change view:

  • n - View by package Name
  • t - View by package Type
  • c - View by License (Copyright/Code)
  • s - View by Supplier

Navigation:

  • h - Move left
  • j - Move down
  • k - Move up
  • l - Move right

Misc:

  • / - Search
  • q - Quit

Supported SBOM Formats

The goal is to support as many SBOM formats as possible. Patches welcome!

  • SPDX
  • CycloneDX (JSON)
  • GitHub
  • Syft

Generating SBOMs

There are various tools available to generate SBOMs:

For example, to generate an SBOM with Syft:

syft alpine:latest -o json > alpine-syft.json

Caveats

I am an open-source enthusiast and self-taught coder creating projects driven by curiosity and a love for problem-solving. The code may have bugs or sharp edges. Kindly let me know if you find one, via an issue. Thanks.

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

sbommage-1.0.2.tar.gz (17.5 MB view details)

Uploaded Source

Built Distribution

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

sbommage-1.0.2-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

Details for the file sbommage-1.0.2.tar.gz.

File metadata

  • Download URL: sbommage-1.0.2.tar.gz
  • Upload date:
  • Size: 17.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sbommage-1.0.2.tar.gz
Algorithm Hash digest
SHA256 383ea408f380811c930f8d0ed470bcbb8c1b33fa1d39e653f0e6c623db38e6af
MD5 61002657083ac3132db8d59858387f9e
BLAKE2b-256 918b51e42640f857aa5a356827305dde378664cc50796bf0739db460c5afc719

See more details on using hashes here.

Provenance

The following attestation bundles were made for sbommage-1.0.2.tar.gz:

Publisher: release.yml on popey/sbommage

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

File details

Details for the file sbommage-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: sbommage-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 20.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sbommage-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 80a84ecf475037a23a6bcf44aa5b07091284429d45c930ae04afd6cd47c68cc2
MD5 72fe183eb8b0d22dd0f2c543e2bc5885
BLAKE2b-256 5f6959713cf27e64b661af02bc72fb645c80c52169a97efb2e256767c878c1bf

See more details on using hashes here.

Provenance

The following attestation bundles were made for sbommage-1.0.2-py3-none-any.whl:

Publisher: release.yml on popey/sbommage

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