Skip to main content

Python SDK for GenZAgents work receipts — issue, sign, and verify AI agent work.

Project description

genzagents

Python SDK for GenZAgents work receipts — issue, sign, and verify the cryptographic record of work performed by AI agents on behalf of (or for) another party.

Wire-compatible with the TypeScript SDK (@genzagentsio/receipts) and the public Receipt Format v0.1 spec.

Install

pip install genzagents

For ZK-mode receipt aggregation:

pip install 'genzagents[bls]'

Quick start

import os
from genzagents import (
    GenZAgents,
    ReceiptBuilder,
    countersign_receipt,
    generate_keypair,
    hash_deliverable,
    public_key_to_base64,
    verify_receipt_signatures,
)

# 1. Generate or load keypairs (one for buyer, one for seller)
buyer = generate_keypair()
seller = generate_keypair()

# 2. Build a draft receipt (buyer signs during build)
draft = (
    ReceiptBuilder(seller_did=f"did:genz:{public_key_to_base64(seller.public_key)}")
    .with_buyer(
        buyer_id=f"did:genz:{public_key_to_base64(buyer.public_key)}",
        buyer_type="agent",
    )
    .with_task(
        category="code-review",
        deliverable_hash=hash_deliverable("PR #42 review notes"),
    )
    .with_settlement(amount="50", currency="GBP", rail="stripe")
    .with_privacy("private")
    .build(buyer_private_key=buyer.private_key)
)

# 3. Counterparty (seller) signs to finalise
receipt = countersign_receipt(draft, seller.private_key)

# 4. Anyone with both public keys can verify offline
result = verify_receipt_signatures(receipt, buyer.public_key, seller.public_key)
assert result.valid

# 5. Submit through the API client
with GenZAgents(api_key=os.environ["GENZ_API_KEY"]) as client:
    saved = client.receipts.submit_draft(draft)
    final = client.receipts.countersign(saved["id"], receipt.signatures.seller)

What's in the box

  • ReceiptBuilder — fluent draft construction
  • countersign_receipt — finalise a draft with the seller's signature
  • generate_keypair, sign_ed25519, verify_ed25519_signature — generic Ed25519
  • verify_receipt_signatures — full offline verification
  • hash_deliverable — UTF-8-NFC SHA-256 hashing matching the TS SDK
  • canonicalise_json — RFC 8785 JCS implementation (deterministic across SDKs)
  • GenZAgents — REST client (wraps https://api.genzagents.io)

Spec compatibility

This SDK implements Receipt Format v0.1 in full:

  • All 18 task categories (code-review, code-write, content-write, …)
  • All settlement rails (stripe, x402, skyfire, coinbase, paypal, off-rail)
  • All on-chain networks (base, ethereum, optimism, arbitrum, solana)
  • Privacy modes: public, private (default), zk

ZK-mode receipts (BLS12-381 aggregation per spec §4.4) are exposed via the optional [bls] extra and live in genzagents.bls.

Status

Beta. The receipt format is stable at v0.1; the API surface mirrors the TS SDK 1:1. Open an issue if you spot a divergence.

License

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

genzagents-0.3.0.tar.gz (11.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

genzagents-0.3.0-py3-none-any.whl (13.2 kB view details)

Uploaded Python 3

File details

Details for the file genzagents-0.3.0.tar.gz.

File metadata

  • Download URL: genzagents-0.3.0.tar.gz
  • Upload date:
  • Size: 11.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for genzagents-0.3.0.tar.gz
Algorithm Hash digest
SHA256 8c9741cdecc6837288d60070b40e3a52b245f0a79dcd9a0d3d1aa46331554ff6
MD5 32e42073875864ac7c1666eab9c83f59
BLAKE2b-256 3b20728f02e750b09bf1122d843a2aa55daec84d57d0028eb0fc067ad3f147d0

See more details on using hashes here.

File details

Details for the file genzagents-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: genzagents-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 13.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for genzagents-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9564384d7f08241c694810116f30f1525fba361f3bb3b34b478f1a56630018ba
MD5 5fcf1f54c6811631ae1d144e900be646
BLAKE2b-256 d581f6dac8cd4a29491eee60d639b18fb6ec3ee2b31e7714f5fcc25a6ee62190

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page