Signed provenance for agent-assisted Git commits with offline verification; emulated Ed25519 ships today and the SE050 hardware path remains an optional preview.
Project description
Matrix Scroll
Signed provenance for agent-assisted Git commits with offline verification.
Matrix Scroll is a cryptographic evidence layer for Git. When an agent, CI workflow, or human operator produces a commit, a signed commit envelope can record the actor, tool, and optional bounded scope. Anyone can verify that envelope locally, in CI, or in the browser without trusting the editor session that produced it.
The reference SDK ships pure Ed25519 over canonical manifest bytes today. The SSX360 / NXP SE050 path is the compatible next trust layer and remains a preview path until device acceptance is complete.
Honest limits
- Shipping now: PyPI
matrixscroll==0.2.6, Git post-commit hooks,matrixscroll envelope-verify, Scroll Gate PR verification, browser verifier, the GitHub Action, and a USB CDC host transport preview for the SE050 rollout path. - In progress: RP2350 + SE050 firmware validation, external Ed25519-capable hardware key backends, and transparency-log integrations.
- Not: IAM, sandboxing, prompt filtering, or an agent runtime.
Quickstart
pip install "matrixscroll==0.2.6"
matrixscroll hook-install
export MATRIXSCROLL_ACTOR_TYPE=agent
export MATRIXSCROLL_TOOL=agent-runner
git commit -m "feat: agent-assisted change"
matrixscroll envelope-verify "$(git rev-parse HEAD)"
See docs/quickstart-git.md and run
examples/demo/agent-commit-demo.sh.
CI verify
Scroll Gate for a PR commit range
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: SSX360/matrixscroll-verify-action@v1
with:
head-ref: ${{ github.event.pull_request.head.sha }}
base-ref: ${{ github.event.pull_request.base.sha }}
source: notes
matrixscroll-version: "0.2.6"
require-mode: emulated
Publish envelopes to git notes before review:
matrixscroll envelope-publish-notes --base origin/main --head HEAD
git push origin refs/notes/matrixscroll
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: SSX360/matrixscroll-verify-action@v1
with:
head-ref: ${{ github.event.pull_request.head.sha }}
base-ref: ${{ github.event.pull_request.base.sha }}
source: notes
matrixscroll-version: "0.2.6"
summary-output: provenance-summary.json
See docs/quickstart-git.md and
examples/ci/protected-branch.yml.
The --require-mode, --trusted-keys, and actor or delegation policy checks
are available in the 0.2.x line; the examples in this README pin 0.2.6.
Why it is different from Sigstore
Sigstore, GitHub artifact attestations, and SLSA answer "what was built in CI?" Matrix Scroll answers "who signed this commit before push?" The systems are complementary: Matrix Scroll signs commit envelopes at commit time, while artifact-attestation systems sign build outputs later in the delivery chain.
Matrix Scroll does not compete with general authentication keys on their home field. Existing hardware roots can become Matrix Scroll signing backends only when they preserve the same pure Ed25519 byte contract.
Public proof links
- Browser verifier: https://matrixscroll.com/verify/
- Compare page: https://matrixscroll.com/compare/
- Specification:
SPEC.md - Commit envelope schema:
schemas/commit-envelope.v1.json - Whitepaper:
docs/WHITEPAPER.md - Conformance vectors:
vectors/ - GitHub Action: https://github.com/SSX360/matrixscroll-verify-action
- Agentic AI controls:
docs/AGENTIC_AI_SECURITY.md - Site: https://matrixscroll.com
- Reference device path: https://matrixscroll.com/device/
Python API
pip install "matrixscroll==0.2.6"
import matrixscroll
print(matrixscroll.status())
# {'schema': 'matrixscroll.identity.v1', 'available': True,
# 'mode': 'emulated', 'device_id': 'MS-A3F2-9C81', ...}
signed = matrixscroll.sign_manifest({"release": "v1.0.0", "artifacts": [...]})
assert matrixscroll.verify_manifest(signed)
CLI
$ matrixscroll status
{
"available": true,
"device_id": "MS-A3F2-9C81",
"mode": "emulated",
"public_key": "...",
"schema": "matrixscroll.identity.v1"
}
$ matrixscroll sign release.json > release.signed.json
$ matrixscroll verify release.signed.json
{"device_id": "MS-A3F2-9C81", "mode": "emulated", "ok": true, "signed_at": "..."}
matrixscroll verify exits 0 on a valid signature and 2 on failure
(tampered manifest, missing signature block, wrong schema or algorithm,
mismatched device ID, malformed public key, unreadable file).
How it works
your IDE / agent / CI
|
| commit envelope, release manifest, evidence pack, SBOM
v
matrixscroll.sign_manifest(...) / post-commit hook
|
| canonical JSON (sorted keys, ASCII-escaped, no NaN,
| signature block excluded from input)
v
IdentityProvider --> Ed25519 signature
(L1 emulated today,
SSX360 / SE050 roadmap)
|
v
signed document --> matrixscroll.verify_manifest(...)
(anyone, anywhere, offline)
Switch providers with MATRIXSCROLL_MODE. Hardware mode includes a USB CDC
host transport preview and a mock path for CI; real SE050 signing still
depends on device firmware validation. External-key backends stay out of the
mainline until they can sign the same canonical bytes with Ed25519.
Compliance levels
| Level | Provider | Backed by | Status |
|---|---|---|---|
| L1 Emulated | EmulatedProvider |
Software key, file-backed (0600) | Shipping |
| L2 Hardware | HardwareProvider |
NXP SE050 secure element (SSX360) | In progress |
| L3 Attested | future | L2 + remote attestation | Roadmap |
status() exposes the active level via the mode and available fields.
Storage and trust boundaries
- Emulated key store:
~/.matrixscroll/device.json(override withMATRIXSCROLL_HOME). - The directory is created
0700; the seed file is opened0600withO_CREAT|O_EXCLso the private seed is never momentarily world-readable. - A corrupt or truncated store fails loud (
IdentityError) rather than silently minting a fresh identity. - The planned hardware path holds nothing private on disk; the seed is sealed in the secure element.
Reference implementation, not the only one
Matrix Scroll is a protocol. This Python package is the reference. We welcome
implementations in Rust, Go, TypeScript, and embedded C. Run them against
vectors/ to self-certify. See CONTRIBUTING.md.
Agentic AI guidance proof
The repo includes a machine-readable control matrix at
controls/agentic_ai_controls.json, an
example bounded-agent evidence manifest at
examples/agentic_ai_evidence_manifest.json,
and executable checks in tests/test_agentic_guidance.py.
License
- Code: Apache-2.0 (
LICENSE). - Specification text (
SPEC.md,vectors/): CC0 1.0 - public domain.
Security
See SECURITY.md. Report vulnerabilities privately to
security@matrixscroll.com or via a GitHub Security Advisory.
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
Built Distribution
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 matrixscroll-0.2.6.tar.gz.
File metadata
- Download URL: matrixscroll-0.2.6.tar.gz
- Upload date:
- Size: 81.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1aa271d9b582e506ed0e49974bb964e75b591e76b2fc0aa067d8767d37d8e573
|
|
| MD5 |
aac81361d08b13d362590bf0302ae2c2
|
|
| BLAKE2b-256 |
2fd80c07c4eadfed0bd728ce6a5969f335c37a1a152841b2886daf781c998111
|
Provenance
The following attestation bundles were made for matrixscroll-0.2.6.tar.gz:
Publisher:
publish.yml on SSX360/matrixscroll
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
matrixscroll-0.2.6.tar.gz -
Subject digest:
1aa271d9b582e506ed0e49974bb964e75b591e76b2fc0aa067d8767d37d8e573 - Sigstore transparency entry: 1895168370
- Sigstore integration time:
-
Permalink:
SSX360/matrixscroll@654df36acc462a4c9431b8d57ffce54d46e0c0a3 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/SSX360
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@654df36acc462a4c9431b8d57ffce54d46e0c0a3 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file matrixscroll-0.2.6-py3-none-any.whl.
File metadata
- Download URL: matrixscroll-0.2.6-py3-none-any.whl
- Upload date:
- Size: 41.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d5ae1a399bca4bdac36c2d10980b4adb19df423d60fc11e1baedc4507bda785d
|
|
| MD5 |
fc9d2ae27802284d4f5b417faee1ba8b
|
|
| BLAKE2b-256 |
f131dbce9ed7283d6544ae953afaf5d838363558cf842db9907d3ff207ed0022
|
Provenance
The following attestation bundles were made for matrixscroll-0.2.6-py3-none-any.whl:
Publisher:
publish.yml on SSX360/matrixscroll
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
matrixscroll-0.2.6-py3-none-any.whl -
Subject digest:
d5ae1a399bca4bdac36c2d10980b4adb19df423d60fc11e1baedc4507bda785d - Sigstore transparency entry: 1895168474
- Sigstore integration time:
-
Permalink:
SSX360/matrixscroll@654df36acc462a4c9431b8d57ffce54d46e0c0a3 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/SSX360
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@654df36acc462a4c9431b8d57ffce54d46e0c0a3 -
Trigger Event:
workflow_dispatch
-
Statement type: