Skip to main content

Interactive terminal frontend for Grype to view vulnerabilities.

Project description

Grummage

Grype + Rummage = Grummage.

Grummage is an interactive terminal frontend to Grype.

A short video showing Grummage

Introduction

Grype is an awesome vulnerability scanner. It produces minimal textual output, or verbose JSON files. I wanted something to rummage around in the json, without having to learn arcane jq syntax ;).

So Grummage was born.

Installation

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

Pre-requisites

Grummage requires the Grype binary in your path to function.

You may want to confirm the Grype command line works, and has updated the vulnerability database first.

grype --version
grype 0.84.0
grype db update
  ✔ Vulnerability DB                [no update available]
 No vulnerability database update available

From PyPI (Recommended)

The easiest way to install grummage is from PyPI:

pip install grummage

From GitHub Releases

Download the latest release from the GitHub releases page.

Using Homebrew (macOS/Linux)

brew tap popey/grummage
brew install grummage

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/grummage:latest /data/your-sbom.json

Using Snap

sudo snap install grummage

From Source

For development or if you prefer to install from source:

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

Using uv (Alternative)

If you use uv for Python environment management:

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

Usage

Point grummage at an SBOM (Software Bill of Materials):

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

Grummage will check the grype vulnerability database, update it if needed, then load the SBOM and analyze it with Grype. A loading screen shows progress during these operations.

Once loaded, use the cursor keys or mouse to navigate the tree on the left pane. Press Enter or mouse click on a vulnerability to obtain limited details.

Keys:

Navigation:

  • Arrow keys or h/j/k/l - Navigate the tree
  • Enter - Select item

Views:

  • p - View by package name
  • v - View by vulnerability ID
  • t - View by package type
  • s - View by severity

Search:

  • / - Search within current view
  • n - Find next result
  • N - Find previous result

Actions:

  • e - Request further details via grype explain
  • q - Quit

Making SBOMs

I use Syft to generate SBOMs, but other tools are available. For example:

syft nextcloud:latest -o syft-json=nextcloud-latest-syft-sbom.json
 ✔ Loaded image       nextcloud:latest
 ✔ Parsed image       sha256:44c884988b43e01e1434a66f58943dc809a193abf1a6df0f2cebad450e587ad7
 ✔ Cataloged contents bdca3ed5b303726bba5579564ab8fe5df700d637ae04f00689443260b26cc832
   ├── ✔ Packages                        [418 packages]
   ├── ✔ File digests                    [10,605 files]
   ├── ✔ File metadata                   [10,605 locations]
   └── ✔ Executables                     [1,317 executables]

Distribution

Grummage is available through multiple distribution channels:

  • PyPI: pip install grummage
  • Homebrew: brew tap popey/grummage && brew install grummage
  • Docker: ghcr.io/popey/grummage:latest
  • Snap: sudo snap install grummage
  • GitHub Releases: Pre-built packages available

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

grummage-2.0.0.tar.gz (10.0 MB view details)

Uploaded Source

Built Distribution

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

grummage-2.0.0-py3-none-any.whl (650.3 kB view details)

Uploaded Python 3

File details

Details for the file grummage-2.0.0.tar.gz.

File metadata

  • Download URL: grummage-2.0.0.tar.gz
  • Upload date:
  • Size: 10.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for grummage-2.0.0.tar.gz
Algorithm Hash digest
SHA256 765619ef34fdfb0c17ea9d630209e52b1d3af03443306f63403e6f662b66ff49
MD5 17a11ab3a42b79c169b4b6e5e1d9aaa2
BLAKE2b-256 7df4af14bc87e85a59a20cc4797c611e3a894e12e102ed3c3304af26705d7df9

See more details on using hashes here.

Provenance

The following attestation bundles were made for grummage-2.0.0.tar.gz:

Publisher: release.yml on popey/grummage

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

File details

Details for the file grummage-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: grummage-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 650.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for grummage-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5a44fc4546d444db6c8b5a767cb51cdede39c5dee61a0bfd51ee1c9cf66d5989
MD5 b642d1ab538420a10b57813367c0089f
BLAKE2b-256 cb59571dc606c00705d8b58b10e641bc01acec1af532bd4530062eaebbe72f9d

See more details on using hashes here.

Provenance

The following attestation bundles were made for grummage-2.0.0-py3-none-any.whl:

Publisher: release.yml on popey/grummage

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