A cli tool to enforce documentation for code suppressions
Project description
Turn silent tech debt into reviewable and documented decisions.
shamefile won't let anyone silence a linter warning in your code without writing down why.
People are lazy. Both committer and code reviewer.
- The committer slaps a
// NOLINTcomment when there's no easy fix. They don't justify it — in most languages there's no good place for that. - The code reviewer focuses on more important things: security, bugs, design. There's no dedicated time for checking new suppression arrivals.
Shamefile adds shamefile.yaml for the code reviewer and the shame CLI for the committer to give them tools to react before tech debt gets out of control.
Why it's important
A mysterious # noqa with no explanation, left by a developer who moved on years ago. Nobody remembers why. Nobody wants to touch it. This is how legacy code accumulates — silently, one linter suppression at a time.
shamefile interrupts that pattern. Every suppression is tracked in a single shamefile.yaml — one file, one purpose. When it changes in a pull request, a reviewer sees the full cost of a shortcut in a single diff. And as AI coding agents become routine PR authors, the registry acts as a consistent gate: whether a suppression was introduced by a human or a model, it ships with a written justification or it doesn't ship at all.
How it works
shamefile exposes two stages, one command each.
Scan — shame me . walks your project, finds every suppression token, and syncs the central shamefile.yaml. New suppressions are registered with auto-filled metadata (owner from git blame, timestamp, source line). Stale entries are removed. The command fails if any entry lacks a why.
Document — shame next shows the first undocumented suppression, with the exact source line highlighted. Provide the reason inline (shame next "<reason>"), or target a specific entry with shame fix <location> <token> --why "<reason>".
The same interface works for a developer opening a PR and for an AI agent iterating through gaps one at a time — without having to read the full registry into context.
Workflow
1. Developer writes code with a suppression:
result = parse_legacy_api(raw) # type: ignore
2. Pre-commit (or manual) run surfaces the gap:
$ shame me .
Creating new registry at /home/user/myproject/shamefile.yaml
Scanning . for suppressions...
Added 1 new entries to /home/user/myproject/shamefile.yaml
1 suppressions need documentation (why).
Run `shame next` to see the first one, or `shame next "<reason>"` to fill its why.
...
3. Developer documents it:
$ shame next
./src/api.py:42
|
42| result = parse_legacy_api(raw) # type: ignore
| ^^^^^^^^^^^^^^
Fix with:
shame next "<reason>"
shame fix "./src/api.py:42" "# type: ignore" --why "<reason>"
$ shame next "legacy API returns untyped dict; types module in progress"
Documented: # type: ignore at ./src/api.py:42
All entries documented. No shame today!
4. Developer commits both api.py and shamefile.yaml. The shortcut and its justification land in the same PR, reviewable in a single diff.
CI/CD integration
On the CI side, shame me . --dry-run is read-only and deterministic. It validates three contracts:
| Check | Meaning |
|---|---|
| Coverage | Every suppression in code is registered in shamefile.yaml |
| Staleness | Every registered entry still points at a live suppression in code |
| Justification | Every entry has a non-empty why |
A failure on any of the three exits non-zero.
# .github/workflows/ci.yml
- name: Check suppressions
run: shame me . --dry-run
| Flag | Description |
|---|---|
--dry-run (-n) |
Read-only validation for CI/CD — never writes to disk |
--hidden |
Also scan hidden files and directories (dotfiles) |
Registry format
shamefile.yaml lives at the project root (git root if available, otherwise the working directory). Every entry is human-readable and stable under git diff:
---
config: {}
entries:
- location: ./src/api.py:42
token: '# type: ignore'
content: 'result = parse_legacy_api(raw) # type: ignore'
created_at: 2026-04-17
owner: Anna Nowak <anna@example.com>
why: 'legacy API returns untyped dict; types module in progress'
locationandtokenform the entry's identity.contentis the verbatim source line — used for reconciliation when code moves.ownerandcreated_atare populated automatically on first run viagit blame.whyis the only field that requires a written justification — from a developer or an AI agent. The PR reviewer decides whether the reason is good enough.
Cascade matching
A registry that breaks every time you refactor is worse than no registry. shamefile reconciles entries against source code in two passes:
- Location match — exact
file:line+ token. - Content match — same source line + token (handles line shifts, with rename detection limited to the most recent commit via
git diff HEAD~1..HEAD -M).
Reformatting a function or inserting imports above a suppression preserves the entry — owner, created_at, and why stay intact. Entries are only removed when the token itself is gone from the code.
Supported tokens
| Token | Tool | Language |
|---|---|---|
# noqa |
Flake8 / Ruff | Python |
# pylint: disable |
Pylint | Python |
# type: ignore |
Mypy | Python |
# pyright: ignore |
Pyright | Python |
# pytype: disable |
Pytype | Python |
# pyre-ignore / # pyre-fixme |
Pyre | Python |
nosec |
Bandit | Python |
# pragma: no cover |
Coverage.py | Python |
# fmt: off / # fmt: skip |
Black / Ruff | Python |
# isort: skip |
isort | Python |
# lint-fixme / # lint-ignore |
Fixit | Python |
# autopep8: off |
autopep8 | Python |
// eslint-disable, /* eslint-disable |
ESLint | JS / TS / TSX |
// tslint:disable, /* tslint:disable |
TSLint | TS / TSX |
// @ts-ignore, /* @ts-ignore |
TypeScript | JS / TS / TSX |
// @ts-expect-error, /* @ts-expect-error |
TypeScript | JS / TS / TSX |
Experimental tokens
New languages added via the Add a language template land here first. They have passed the existing test suite and a sanity run on a real codebase, but no real-world showcase has been contributed yet. Promotion to Supported tokens happens through the Verify and release a language flow.
| Language |
|---|
Supported file extensions: .py, .js, .jsx, .mjs, .cjs, .ts, .tsx.
Installation
| Source | Command |
|---|---|
| npm | npm install -g shamefile |
| PyPI | pip install shamefile |
| crates.io | cargo install shamefile |
| From source | cargo install --git https://github.com/BKDDFS/shamefile |
| Homebrew | coming soon |
All channels install the shame CLI. Run shame --help to verify.
Or as a pre-commit hook:
# .pre-commit-config.yaml
- repo: https://github.com/BKDDFS/shamefile
rev: main
hooks:
- id: shamefile
Roadmap
- MCP server — native integration for LLM-based PR authors (avoids loading the full registry into agent context)
- Custom git merge driver — auto-resolve
shamefile.yamlconflicts on parallel PRs - Additional language grammars — Rust, Go, Java, Kotlin, C# via tree-sitter
- Custom entry fields — attach
ticket,reviewer, ordeadlinemetadata to suppressions - Native exclusion config — first-class
exclude:patterns inshamefile.yamlfor checked-in vendored or generated code that bypasses the default.gitignorediscovery
FAQ
Why not just write the reason inline, like # noqa: F401 # legacy import?
- Reviewers don't see it. A
# noqaburied in one of seven changed files rarely gets pushback.shamefile.yamlputs every suppression in the PR into one diff — the reviewer sees the full cost as a single list, with author andwhyper entry. - Nothing forces a reason. Linters accept any string after the token, or none.
shame me . --dry-runfails the build until every entry has a non-emptywhy. This matters most for AI coding agents, which lose the suppression's context the moment the session ends — the registry forces them to write the reason to disk while it still exists. - Inline is a bad trade-off. A short reason carries no information; a useful one drowns the line of code it is attached to. The registry keeps source readable and justifications detailed.
What stops developers from writing why: 'TODO' and moving on?
The tool guarantees a string is written; the reviewer judges whether it is a real reason. If why: 'TODO' passes review, that is an organisational gap, not a tool gap — but the registry makes the gap visible: every lazy entry is one grep away, by author and date. Before shamefile, the same shortcut was hidden inside whichever file it lived in.
Won't shamefile.yaml become a merge conflict magnet on parallel PRs?
The registry is sorted by (location, token), so suppressions added in unrelated parts of the codebase land in different regions of the file — most parallel PRs do not collide. When they do, shame me is idempotent: after a merge, running it on the resolved tree deterministically reconciles entries from source, so git checkout --theirs shamefile.yaml && shame me . is the escape hatch. A custom git merge driver that resolves automatically is on the Roadmap. This is the same trade-off every shared-file tool (lockfiles, changelogs, schema migrations) has accepted in exchange for single-source-of-truth visibility.
What about generated, vendored, or third-party code?
A repo's typical generated/vendored content is excluded for free:
.gitignoreand.ignorefiles are respected (handled by the same engineripgrepuses), sonode_modules/,target/,dist/,__pycache__/etc. are skipped without configuration.- Only
.py / .js / .jsx / .mjs / .cjs / .ts / .tsxare scanned, so vendored content in any other language is silently ignored.
A first-class exclude: config in shamefile.yaml is on the Roadmap.
Contributing
Contributions are welcome. Where you start depends on what you have:
- Found a bug? Open an issue with a minimal repro.
- Idea or design question? Open a Discussion under Ideas so direction can be agreed before any code is written.
- Usage question or trouble setting things up? Ask in Q&A.
- Want to send a PR? Read CONTRIBUTING.md first — dev setup, build/test/lint commands, commit format.
- Security vulnerability? Use the private advisory form — see SECURITY.md. Do not open a public issue.
By participating you agree to the Code of Conduct.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file shamefile-0.1.3.tar.gz.
File metadata
- Download URL: shamefile-0.1.3.tar.gz
- Upload date:
- Size: 139.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fb74b170f96c479ddec90c167c814745cd3888cece273d7d51d06fbd9c2efb7b
|
|
| MD5 |
42f3401b334f1f53560d883e741423f4
|
|
| BLAKE2b-256 |
0e515b5bcc09635c8931fc3c0f96256f342783bfdf2aefda2bc7376af4344198
|
Provenance
The following attestation bundles were made for shamefile-0.1.3.tar.gz:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3.tar.gz -
Subject digest:
fb74b170f96c479ddec90c167c814745cd3888cece273d7d51d06fbd9c2efb7b - Sigstore transparency entry: 1442291517
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-win_arm64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-win_arm64.whl
- Upload date:
- Size: 1.7 MB
- Tags: Python 3, Windows ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
48867d02593ca8b5610c50e47f6be28b585fd48362d67ca38e52460b7bd39a31
|
|
| MD5 |
a341de654d91f4ecfb968088ab65e59b
|
|
| BLAKE2b-256 |
001ffa4c3071f11a849a88cc902f996e6d7bb74ff468a0d764a04d6ca5a7a8c5
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-win_arm64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-win_arm64.whl -
Subject digest:
48867d02593ca8b5610c50e47f6be28b585fd48362d67ca38e52460b7bd39a31 - Sigstore transparency entry: 1442292182
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-win_amd64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-win_amd64.whl
- Upload date:
- Size: 1.8 MB
- Tags: Python 3, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2adbdc5c4219d0aee42df2422f33c074c2213f9945354fd2b39a711613674039
|
|
| MD5 |
cecde103600149f17807a8b0fdbf7f9e
|
|
| BLAKE2b-256 |
1ad309a5cffacebbb80203016aee0e46c057370fc5cfad693ffad39097fd95fc
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-win_amd64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-win_amd64.whl -
Subject digest:
2adbdc5c4219d0aee42df2422f33c074c2213f9945354fd2b39a711613674039 - Sigstore transparency entry: 1442291764
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-musllinux_1_2_x86_64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-musllinux_1_2_x86_64.whl
- Upload date:
- Size: 2.0 MB
- Tags: Python 3, musllinux: musl 1.2+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b7aa5e47a7f6eb22cd1c2745ccde05a8bdc13c6e2fc92315726834f81bca1076
|
|
| MD5 |
6af674584c0249a2e8cf16772262fbac
|
|
| BLAKE2b-256 |
fcb6534fe1245b5c27b60242c0d8e34637908631d82dd7aea459e9eedbf7eefa
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-musllinux_1_2_x86_64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-musllinux_1_2_x86_64.whl -
Subject digest:
b7aa5e47a7f6eb22cd1c2745ccde05a8bdc13c6e2fc92315726834f81bca1076 - Sigstore transparency entry: 1442291913
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-musllinux_1_2_aarch64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-musllinux_1_2_aarch64.whl
- Upload date:
- Size: 1.8 MB
- Tags: Python 3, musllinux: musl 1.2+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d31e78cf2fb10c8bd2f836a60e7dc1b6a6bc513eb4f41550cdc59bb438f46579
|
|
| MD5 |
327c88d47fd24db851c6fa82a954b63f
|
|
| BLAKE2b-256 |
bff7db1f4e3e204623004efd115ca7605d95ad4079f0d2053e66ff1b8d6e9ada
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-musllinux_1_2_aarch64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-musllinux_1_2_aarch64.whl -
Subject digest:
d31e78cf2fb10c8bd2f836a60e7dc1b6a6bc513eb4f41550cdc59bb438f46579 - Sigstore transparency entry: 1442291598
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.9 MB
- Tags: Python 3, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cf47cb6e798dd98edb9abb4f687e1f6d7859fe45e543f04184ae031f6aa469e3
|
|
| MD5 |
8b89733e10f8d26d6d754cc62920b7a7
|
|
| BLAKE2b-256 |
5f456e5d6381f25e040540bf7e8ba8e02383f1eea094c0a30ed9210405723f90
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl -
Subject digest:
cf47cb6e798dd98edb9abb4f687e1f6d7859fe45e543f04184ae031f6aa469e3 - Sigstore transparency entry: 1442291990
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
- Upload date:
- Size: 1.8 MB
- Tags: Python 3, manylinux: glibc 2.17+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d6392e2fa739f074c8c24dbda137e1bee6b431a213c1269b34ec68934225be66
|
|
| MD5 |
006e8ec2a1ec20b7531ce08aa6039375
|
|
| BLAKE2b-256 |
4d6317f64da4df86eb74249d9cf1be36316d69db493bc1b18318cbbd2405ebf4
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl -
Subject digest:
d6392e2fa739f074c8c24dbda137e1bee6b431a213c1269b34ec68934225be66 - Sigstore transparency entry: 1442291697
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-macosx_11_0_arm64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-macosx_11_0_arm64.whl
- Upload date:
- Size: 1.8 MB
- Tags: Python 3, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5ae2aebffedcde4cd7c33f15b2a794811973c4ce2b626f68d98c3f0c97648ce5
|
|
| MD5 |
a1c543b8dfaa5218720c31d7d9f6716c
|
|
| BLAKE2b-256 |
791e49f729bb597d91dfa900c33ed0a138f586c657b963ffa100e0188d065726
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-macosx_11_0_arm64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-macosx_11_0_arm64.whl -
Subject digest:
5ae2aebffedcde4cd7c33f15b2a794811973c4ce2b626f68d98c3f0c97648ce5 - Sigstore transparency entry: 1442291845
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type:
File details
Details for the file shamefile-0.1.3-py3-none-macosx_10_12_x86_64.whl.
File metadata
- Download URL: shamefile-0.1.3-py3-none-macosx_10_12_x86_64.whl
- Upload date:
- Size: 1.8 MB
- Tags: Python 3, macOS 10.12+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d01e06e49a92a5c35591132abec5d4db5d39eabe5b24080552157763079e7c15
|
|
| MD5 |
550009814b7da147e79eb2122bc4c948
|
|
| BLAKE2b-256 |
17effae1bd44e6fd17ba7917130170ed72c47aaa3d3ae8492038031ba8ba3bd7
|
Provenance
The following attestation bundles were made for shamefile-0.1.3-py3-none-macosx_10_12_x86_64.whl:
Publisher:
publish-pypi.yml on BKDDFS/shamefile
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
shamefile-0.1.3-py3-none-macosx_10_12_x86_64.whl -
Subject digest:
d01e06e49a92a5c35591132abec5d4db5d39eabe5b24080552157763079e7c15 - Sigstore transparency entry: 1442292086
- Sigstore integration time:
-
Permalink:
BKDDFS/shamefile@29a6ae78180595da89e30abdd59ec0e409f84028 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/BKDDFS
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@29a6ae78180595da89e30abdd59ec0e409f84028 -
Trigger Event:
release
-
Statement type: