Native Groth16 BN254 verification primitives for the Xian stack
Project description
xian-tech-zk
Small native zero-knowledge verification and proving primitives for the Xian workspace.
Purpose
- This package exposes the narrow verifier surface used by the Xian runtime.
- It also now exposes the first external proving toolkit for the shielded-note-token development flow.
- It is still intentionally small. It is not a general-purpose zk framework.
Current Scope
- Groth16 verification
- BN254
- Python bindings for runtime integration
- A pure Rust verifier core for cargo-level testing and fixtures
- Shielded-note proving circuits and proof generation helpers
- Deterministic dev bundle generation for local shielded-note workflows
- Note math helpers for commitments, nullifiers, asset ids, and Merkle roots
- Trusted local prover-service support for note, command, and relay proof generation
flowchart LR
Wallet["Shielded wallet"] --> Request["Proof request"]
Request --> Prover["xian-zk prover toolkit"]
Prover --> Proof["Groth16 proof and public inputs"]
Proof --> Contract["Shielded contract"]
Contract --> Registry["zk_registry verifying key"]
Contract --> Bridge["contract-side zk bridge"]
Bridge --> Verifier["xian-zk verifier"]
API
Python module xian_zk exposes:
- raw and prepared Groth16 BN254 verification
- native public-input, payload-hash, tree, and command digest helpers
- shielded note request/result/prover/wallet types
- shielded command request/result/prover/wallet types
- shielded relay transfer request/result/prover/wallet types
- registry manifest helpers for note, command, and relay verifying keys
- note encryption/decryption, discovery-tag, sync-hint, and wallet sync helpers
- local prover service clients and
ShieldedZkProverService
CLI entrypoints:
uv run xian-zk-shielded-bundle generate-note --output-dir ...uv run xian-zk-shielded-bundle generate-command --output-dir ...uv run xian-zk-shielded-bundle import-note --bundle ... --output-dir ...uv run xian-zk-shielded-bundle import-command --bundle ... --output-dir ...uv run xian-zk-shielded-bundle validate-note --bundle ...uv run xian-zk-shielded-bundle validate-command --bundle ...uv run xian-zk-shielded-bundle promote --network ... --contract-name ...--note-bundle ... --relay-command-bundle ... --output-dir ...uv run xian-zk-prover-service --host 127.0.0.1 --port 8787 ...
The Rust crate exposes the verifier core, shielded fixture builders, and proof generation helpers used by the Python bindings and tests.
Encoding
- Verifying keys: compressed canonical bytes as
0x-prefixed hex - Proofs: compressed canonical bytes as
0x-prefixed hex - Public inputs: 32-byte big-endian field elements as
0x-prefixed hex
Validation
cargo test --manifest-path packages/xian-zk/Cargo.toml --no-default-featurescargo run --manifest-path packages/xian-zk/Cargo.toml --no-default-features --example generate_test_vectorcargo run --manifest-path packages/xian-zk/Cargo.toml --no-default-features --example generate_shielded_note_fixturecd packages/xian-zk && uv sync --group dev && uv run maturin develop && uv run pytest -qcd packages/xian-zk && uv run pytest -q -m slow
Build performance: the [profile.dev] block in Cargo.toml sets opt-level = 3,
so even a plain maturin develop produces optimized proving/setup. Without it an
unoptimized build is ~25x slower (Groth16 setup ~100s vs ~4s) — do not lower it.
Published/CI wheels build --release regardless.
Notes
- The runtime-facing verifier surface is still intentionally narrow.
- The shielded-note proving helpers are the first external proving toolkit slice, not a broad proving framework.
- The shielded-note circuits now use Merkle auth paths instead of witnessing
the whole leaf set, and the shipped dev bundle / fixture ids are
v4for the note family andv5for the command family. The circuits hash with Poseidon-BN254 (seesrc/poseidon.rs). - Shielded outputs are now addressed to
owner_public, not to the recipient's spending secret. That lets senders create recipient outputs without learning the recipient's private shielded spend key. - The Python toolkit now separates spending and viewing authority. A wallet can disclose note contents by sharing only a viewing key or by adding explicit extra viewers to an encrypted note payload without exposing the spend key.
- The Python toolkit now also ships a first-class
ShieldedWalletabstraction for seed backup, state snapshots, record sync, note selection, and request planning for deposit / transfer / withdraw flows. - The package now also ships deployment CLI helpers that generate or import
proving bundles, emit public registry manifests, write
register_and_bind.pyoperator helpers, and create catalog snippets for promoted ceremony artifacts. Keep private bundles offline; only registry manifests should be used forzk_registryregistration. - The encrypted payload format now supports owner delivery plus optional disclosed viewers inside a single on-chain payload blob.
- The encrypted payload format uses anonymous per-viewer discovery tags and ephemeral keys for new payloads, so recipient viewing keys are no longer embedded in cleartext.
ShieldedWallet.sync_records(...)now prefilters candidate payloads before full decryption, and note records now exposepayload_tagsso indexers can persist discovery metadata for later selective queries.xian-zk-prover-serviceis a trusted local proving companion, not a true split-prover protocol. It improves deployability and wallet ergonomics, but the service still sees witness material.- Exact withdraws no longer need a forced change note. A withdraw can spend a note set down to zero shielded outputs when value conservation closes exactly.
- The proving requests separate
old_rootfromappend_state, which lets a client prove against a recent accepted root while still projecting the canonical post-state from the current append frontier. - Python
pytestnow excludes the slow proof-generation tests by default. Runpytest -m slowexplicitly when you want the proving-toolkit path. - The contract runtime prefers registry-backed verification by
vk_id; this package exposes the lower-level raw and prepared-key verifier primitives that runtime builds on. ShieldedNoteProver.build_insecure_dev_bundle()is for local development and tests only. Its deterministic setup seed exposes toxic waste and must never be used for a real network.ShieldedNoteProver.build_random_bundle(...)andxian-zk-shielded-bundle generate-notegenerate a single-party random trusted setup. That is appropriate for deployment tooling, but it is still not an MPC ceremony.- Proof generation uses real randomness even when the proving bundle is a deterministic dev bundle.
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 xian_tech_zk-0.1.7b1.tar.gz.
File metadata
- Download URL: xian_tech_zk-0.1.7b1.tar.gz
- Upload date:
- Size: 76.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
be6cee2eaa384e399b212412a6e7eb0726973d7d37f18024a8728b4e5e4cbcdc
|
|
| MD5 |
9cd1afc34b7928359565d05fc95540b4
|
|
| BLAKE2b-256 |
1227699e67571a4e3ed8c71a7ea57fd3c10989b9fa36db2af84133757b4add78
|
Provenance
The following attestation bundles were made for xian_tech_zk-0.1.7b1.tar.gz:
Publisher:
release.yml on xian-technology/xian-contracting
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xian_tech_zk-0.1.7b1.tar.gz -
Subject digest:
be6cee2eaa384e399b212412a6e7eb0726973d7d37f18024a8728b4e5e4cbcdc - Sigstore transparency entry: 1794880124
- Sigstore integration time:
-
Permalink:
xian-technology/xian-contracting@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Branch / Tag:
refs/tags/zk-v0.1.7-beta.1 - Owner: https://github.com/xian-technology
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file xian_tech_zk-0.1.7b1-cp314-abi3-win_amd64.whl.
File metadata
- Download URL: xian_tech_zk-0.1.7b1-cp314-abi3-win_amd64.whl
- Upload date:
- Size: 883.8 kB
- Tags: CPython 3.14+, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5494464427e282f332a199e313832d096ceb5be40051cf4c4a009597c099ec04
|
|
| MD5 |
ae4499feac322457971566b40115cca1
|
|
| BLAKE2b-256 |
c9bb7851a76287d3ad55539eeaf4ae736964c7233664466ca5a3acc1844954c2
|
Provenance
The following attestation bundles were made for xian_tech_zk-0.1.7b1-cp314-abi3-win_amd64.whl:
Publisher:
release.yml on xian-technology/xian-contracting
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xian_tech_zk-0.1.7b1-cp314-abi3-win_amd64.whl -
Subject digest:
5494464427e282f332a199e313832d096ceb5be40051cf4c4a009597c099ec04 - Sigstore transparency entry: 1794880593
- Sigstore integration time:
-
Permalink:
xian-technology/xian-contracting@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Branch / Tag:
refs/tags/zk-v0.1.7-beta.1 - Owner: https://github.com/xian-technology
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file xian_tech_zk-0.1.7b1-cp314-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: xian_tech_zk-0.1.7b1-cp314-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.1 MB
- Tags: CPython 3.14+, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c570e8de29826227025a549da4cc3ce9c4cfd3a9e565b68ca78ae0687fb65eda
|
|
| MD5 |
e0375e8943c0918cc2a2092287fb886f
|
|
| BLAKE2b-256 |
92861154aeaee44724ecb0cec3bc251e11e7ab5fb4810d1ac8c48bb1fffd8293
|
Provenance
The following attestation bundles were made for xian_tech_zk-0.1.7b1-cp314-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
release.yml on xian-technology/xian-contracting
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xian_tech_zk-0.1.7b1-cp314-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl -
Subject digest:
c570e8de29826227025a549da4cc3ce9c4cfd3a9e565b68ca78ae0687fb65eda - Sigstore transparency entry: 1794882723
- Sigstore integration time:
-
Permalink:
xian-technology/xian-contracting@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Branch / Tag:
refs/tags/zk-v0.1.7-beta.1 - Owner: https://github.com/xian-technology
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file xian_tech_zk-0.1.7b1-cp314-abi3-macosx_11_0_arm64.whl.
File metadata
- Download URL: xian_tech_zk-0.1.7b1-cp314-abi3-macosx_11_0_arm64.whl
- Upload date:
- Size: 989.7 kB
- Tags: CPython 3.14+, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f7ae09e56a2bcfb66bd398f5f9f6f797664968b1e1f046ae7564e01a73a2d7c3
|
|
| MD5 |
6695360a0f3c478bbb5f6ee438fd099c
|
|
| BLAKE2b-256 |
e879c80e106b441ba9b4d2ab4e53a54b3bb6591e8d64e49f17633639da0d84e3
|
Provenance
The following attestation bundles were made for xian_tech_zk-0.1.7b1-cp314-abi3-macosx_11_0_arm64.whl:
Publisher:
release.yml on xian-technology/xian-contracting
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xian_tech_zk-0.1.7b1-cp314-abi3-macosx_11_0_arm64.whl -
Subject digest:
f7ae09e56a2bcfb66bd398f5f9f6f797664968b1e1f046ae7564e01a73a2d7c3 - Sigstore transparency entry: 1794881145
- Sigstore integration time:
-
Permalink:
xian-technology/xian-contracting@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Branch / Tag:
refs/tags/zk-v0.1.7-beta.1 - Owner: https://github.com/xian-technology
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file xian_tech_zk-0.1.7b1-cp314-abi3-macosx_10_12_x86_64.whl.
File metadata
- Download URL: xian_tech_zk-0.1.7b1-cp314-abi3-macosx_10_12_x86_64.whl
- Upload date:
- Size: 1.0 MB
- Tags: CPython 3.14+, macOS 10.12+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
651b368505e88e6450a82c31242cdecdfecb690c71893348aa919f64167cf7b4
|
|
| MD5 |
019a9724fe4a0bd98484d07751470055
|
|
| BLAKE2b-256 |
9f2d344955edd26b91157eb69ac45e073737eac731f01f11745504e79ecdc639
|
Provenance
The following attestation bundles were made for xian_tech_zk-0.1.7b1-cp314-abi3-macosx_10_12_x86_64.whl:
Publisher:
release.yml on xian-technology/xian-contracting
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
xian_tech_zk-0.1.7b1-cp314-abi3-macosx_10_12_x86_64.whl -
Subject digest:
651b368505e88e6450a82c31242cdecdfecb690c71893348aa919f64167cf7b4 - Sigstore transparency entry: 1794881810
- Sigstore integration time:
-
Permalink:
xian-technology/xian-contracting@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Branch / Tag:
refs/tags/zk-v0.1.7-beta.1 - Owner: https://github.com/xian-technology
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e5a993ad50a87d90ceaa93b2859533d177e547f0 -
Trigger Event:
push
-
Statement type: