k2gl/composer-attest
Composer 安装命令:
composer require k2gl/composer-attest
包简介
Composer plugin that verifies GitHub build-provenance attestations for the packages you install.
关键字:
README 文档
README
A Composer plugin that verifies GitHub build-provenance attestations for the packages you install. As Composer downloads each package, the plugin hashes the artifact, asks GitHub for any attestation bound to that digest, and verifies the Sigstore bundle — requiring the signing identity to be a GitHub Actions workflow of the package's own repository.
It builds on k2gl/sigstore-verify for
the cryptographic verification (certificate chain, transparency-log inclusion,
DSSE envelope, identity), so a passing check means the artifact really was built
by the repository's own CI and recorded in the public transparency log.
Status: proof of concept. The verification path is real and tested end to end (see Caveat for what this does and does not cover today).
Install
composer require k2gl/composer-attest
Composer will ask to trust the plugin the first time (it runs during install).
Configure
All configuration lives under extra.k2gl-attest in your root composer.json:
{
"extra": {
"k2gl-attest": {
"mode": "warn",
"require-attestation": false,
"issuer": "https://token.actions.githubusercontent.com"
}
}
}
modewarn(default) — verify and print the result; a bad attestation is a warning, not a stop.enforce— fail the install if an attestation is present but does not verify (and, withrequire-attestation, if one is missing).off— do nothing.
require-attestation— treat a package that publishes no attestation as a failure (respectingmode). Off by default, since most packages don't publish one yet.issuer— the OIDC issuer the signing certificate must carry. Defaults to GitHub Actions.
What you'll see
✓ attestation verified for k2gl/sigstore-verify (k2gl/sigstore-verify)
· no attestation for some/other-package
Under enforce, a package whose attestation fails verification aborts the install
with a non-zero exit code.
How it works
The plugin subscribes to Composer's POST_FILE_DOWNLOAD event. For each package
dist it:
- computes the artifact's SHA-256 digest;
- requests
GET /repos/{owner}/{repo}/attestations/sha256:{digest}(through Composer's authenticated HTTP client); - parses each returned Sigstore bundle and verifies it with
sigstore-verify, requiring a GitHub Actions identity of{owner}/{repo}; - confirms the artifact's digest is one of the in-toto statement's subjects.
Caveat: what gets attested
Composer installs a package's dist as a GitHub zipball
(api.github.com/repos/{owner}/{repo}/zipball/{ref}). For the plugin to verify a
package at install time, the repository must publish a build-provenance
attestation for that zipball's digest.
Most repositories today attest their release tarball (a git archive output) or
other build outputs — a different artifact than the zipball Composer fetches — so
the plugin will report "no attestation" for them. This is a property of the
current ecosystem, not the plugin: it is exactly why the zipball digest is
reproducible yet unattested. As registries and publishers begin attesting the
artifacts Composer actually installs, the plugin verifies them with no changes.
The verification logic itself is proven: it verifies a real published attestation end to end (the k2gl release tarballs, whose digests are attested, verify against the live GitHub attestations API).
Requirements
- PHP 8.1+
- Composer 2 (
composer-plugin-api ^2.0)
License
MIT
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 2
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-07-04