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

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

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.6.1.tar.gz (630.6 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.6.1-py3-none-any.whl (32.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for trustcheck-1.6.1.tar.gz
Algorithm Hash digest
SHA256 e5dc09f62a60d498c8237e66088c94d0ed9a41b02b04ccc76319d076f05db5c6
MD5 0df7f773f021c9afea508d266dfc64a9
BLAKE2b-256 dff29a8197301d0552edce3d895dfa729f91ca601c5d916c34bb24a4a21ea0f7

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustcheck-1.6.1.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.6.1-py3-none-any.whl.

File metadata

  • Download URL: trustcheck-1.6.1-py3-none-any.whl
  • Upload date:
  • Size: 32.4 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.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2ebe96d4ca02db87af0eac9d708198ac268aa2b60a9621b2bcf2fbf414b22602
MD5 2a78d727295cf0e487f2392fb904a9f8
BLAKE2b-256 9a32d513c554999d872fdd94072268fd6d66ee0f8f614d602986b4688f220058

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustcheck-1.6.1-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