TBZ (TIBET-zip) — Block-level authenticated compression for the Zero-Trust era
Project description
tbz — TIBET-zip for Python
Block-level authenticated compression for the Zero-Trust era.
Every block carries its own TIBET provenance envelope and Ed25519 signature. Tampered blocks are rejected before decompression touches memory. Built as a response to CVE-2026-0866 (Zombie ZIP) — where a single header flip fools 50 out of 51 antivirus engines.
Install
pip install tbz
What you get
| Feature | Pure Python | With Rust CLI |
|---|---|---|
| Read block headers | yes | yes |
| Inspect archive structure | yes | yes |
| SHA-256 hash verification | yes | yes |
| Ed25519 signature verification | — | yes |
| Pack files into .tza | — | yes |
| Unpack via TIBET Airlock | — | yes |
| Transparency Mirror client | yes | yes |
Pure Python works standalone — no binary needed. Add the Rust CLI for full cryptographic verification and pack/unpack.
Quick Start
Inspect and verify
from tbz import TBZArchive
archive = TBZArchive("release.tza")
# Inspect: read block headers (pure Python)
info = archive.inspect()
print(f"Blocks: {info['block_count']}")
print(f"Hash: {info['content_hash']}")
for block in info["blocks"]:
sig = "signed" if block["signed"] else "unsigned"
print(f" [{block['index']}] {block['type']} — {block['compressed_size']} bytes, {sig}")
# Verify: SHA-256 + Ed25519 (uses Rust CLI if available)
result = archive.verify()
print(result) # TBZ VERIFIED: 3 blocks (hash + Ed25519), 0 errors
Transparency Mirror — supply chain lookup
from tbz import Mirror
mirror = Mirror() # connects to bootstrap node
# Look up any TBZ archive by its hash (public, no auth)
entry = mirror.lookup("sha256:abc123...")
if entry:
print(f"Source: {entry['source_repo']}")
print(f"Attestations: {len(entry['attestations'])}")
# Search by publisher
results = mirror.search(jis_id="jis:ed25519:77214ce9c262843e")
# Search by verdict
safe_packages = mirror.search(verdict="safe")
# Mirror node stats
stats = mirror.stats()
print(f"Node: {stats['node']}, entries: {stats['total_entries']}")
Pack and unpack (requires Rust CLI)
# Pack
archive = TBZArchive.pack("./src", output="release.tza")
# Unpack through TIBET Airlock (quarantine buffer, 0x00 wipe on failure)
archive.unpack("./extracted")
Rust CLI
For full features, install the Rust CLI:
cargo install tbz-cli
Then you get short aliases and smart mode:
tbz p ./src -o release.tza # pack
tbz x release.tza # extract
tbz v release.tza # verify
tbz i release.tza # inspect
tbz release.tza # smart: verify + unpack
tbz ./src # smart: pack
Transparency Mirror
The Mirror is a distributed trust database for verifying TBZ package provenance. The bootstrap node runs at brein.jaspervandemeent.nl.
from tbz import Mirror
# Default: bootstrap node
mirror = Mirror()
# Custom node
mirror = Mirror(node_url="https://your-mirror.example.com")
# Public endpoints (no auth required)
mirror.lookup("sha256:...") # look up by content hash
mirror.search(verdict="safe") # search attestations
mirror.search(signing_key="77") # search by key prefix
mirror.stats() # node statistics
Why TBZ?
ZIP, tar.gz, and 7z have no cryptographic binding between headers and data. CVE-2026-0866 proves this: flip one byte in a ZIP header, and 50 out of 51 antivirus engines see noise instead of malware.
TBZ fixes this by design:
- Ed25519 signature covers header + envelope + payload together
- SHA-256 hash in TIBET envelope is the source of truth
- Quarantine buffer wipes to 0x00 on verification failure
No header trust. Verify first, decompress second.
Links
License
MIT / Apache-2.0
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 tbz-0.1.3.tar.gz.
File metadata
- Download URL: tbz-0.1.3.tar.gz
- Upload date:
- Size: 9.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4173fa67f00366f2e413db97e64c1313b162ca18c263d8bfa3e78caf0bc88e79
|
|
| MD5 |
9c24cd5ab46981051399e7b085666d39
|
|
| BLAKE2b-256 |
c789f3f426c7dc85b508bcf10b0a9fed23a3dd7a2050c03ce497557688471739
|
File details
Details for the file tbz-0.1.3-py3-none-any.whl.
File metadata
- Download URL: tbz-0.1.3-py3-none-any.whl
- Upload date:
- Size: 8.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bc1c39df204e9da133db951eb79a950f19417b8fc04f219625ed2f93719444d5
|
|
| MD5 |
0dcc1605e562cf51e76f6ee1f46056fb
|
|
| BLAKE2b-256 |
270e7c0e4110a767d99b2be916439411b2b72776ad6cac137be54035d944a0af
|