Skip to main content

Package trust and provenance verification for PyPI consumers.

Project description

trustcheck

CI Source Build CodeQL PyPI Python 3.10 | 3.11 | 3.12 | 3.13 | 3.14 PyPI Downloads Marketplace

trustcheck is a Python package and CLI for evaluating the trust posture of PyPI releases before they are installed, promoted, or approved.

It combines PyPI metadata, vulnerability records, provenance availability, cryptographic attestation verification, Trusted Publisher identity hints, and repository matching into a single operator-friendly report.

Packages that publish no provenance are treated as needing review rather than as automatic high-risk findings, while invalid provenance, partial coverage, repository mismatches, and known vulnerabilities remain stronger negative signals.

What it checks

For a selected package version, trustcheck can:

  • fetch project and release metadata from PyPI
  • verify published provenance against artifact digests
  • surface Trusted Publisher repository and workflow identity hints
  • compare expected repository input against declared and attested signals
  • flag publisher drift, missing verification, and known vulnerabilities
  • emit concise text output or structured JSON for automation

Installation

pip install trustcheck

Requirements:

  • Python >=3.10
  • Network access to PyPI

Quick start

Inspect the latest release:

trustcheck inspect requests

Inspect a specific version:

trustcheck inspect sampleproject --version 4.0.0

Show only known vulnerabilities for a release:

trustcheck inspect sampleproject --version 4.0.0 --cve

Inspect a package and its direct dependencies:

trustcheck inspect sampleproject --version 4.0.0 --with-deps

Inspect the full transitive dependency tree:

trustcheck inspect sampleproject --version 4.0.0 --with-transitive-deps

Require a release to match an expected repository:

trustcheck inspect sampleproject \
  --version 4.0.0 \
  --expected-repo https://github.com/pypa/sampleproject

Emit JSON for another tool:

trustcheck inspect sampleproject --version 4.0.0 --format json

Emit only vulnerability records as JSON:

trustcheck inspect sampleproject --version 4.0.0 --cve --format json

Fail CI when full verification is missing:

trustcheck inspect sampleproject --version 4.0.0 --strict

Use it from Python:

from trustcheck import inspect_package

report = inspect_package("sampleproject", version="4.0.0", include_dependencies=True)
print(report.recommendation)

Documentation

Full documentation: https://halfblood-prince.github.io/trustcheck/

License

Trustcheck Personal Use License

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

trustcheck-1.7.0.tar.gz (632.2 kB view details)

Uploaded Source

Built Distribution

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

trustcheck-1.7.0-py3-none-any.whl (33.0 kB view details)

Uploaded Python 3

File details

Details for the file trustcheck-1.7.0.tar.gz.

File metadata

  • Download URL: trustcheck-1.7.0.tar.gz
  • Upload date:
  • Size: 632.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for trustcheck-1.7.0.tar.gz
Algorithm Hash digest
SHA256 a2ba429aff4a80512486c4d862de3fafd216989c587803ec113634fe667250e8
MD5 d061af2124bdccd5b98453caa8f28443
BLAKE2b-256 7be66c9210cc14618f583329e1ad91a7d082e502274bc0e5463221b8ddbbfff7

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustcheck-1.7.0.tar.gz:

Publisher: publish.yml on Halfblood-Prince/trustcheck

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

File details

Details for the file trustcheck-1.7.0-py3-none-any.whl.

File metadata

  • Download URL: trustcheck-1.7.0-py3-none-any.whl
  • Upload date:
  • Size: 33.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for trustcheck-1.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 25607606986a793cd6515e5557c8bedcc5bb885ac45a0eb863c144460cdd21ac
MD5 85c4df1cc966fbd6c03e7b23173763db
BLAKE2b-256 84ca70ac4679db0cfac043c3c7cdccfbbc77c9a6ffb9c44c31a0bd86fa0b57cd

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustcheck-1.7.0-py3-none-any.whl:

Publisher: publish.yml on Halfblood-Prince/trustcheck

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