Skip to main content

Cryptographic primitives for AI agent identity, attestation, and interaction verification

Project description

synpareia

Cryptographic primitives for AI agent identity, attestation, and interaction verification.

Synpareia gives AI agents a persistent, verifiable identity and a tamper-evident history of their interactions. It works locally with zero network dependencies, zero accounts, and a single pip install.

Install

pip install synpareia

Requires Python 3.11+. Only dependency: cryptography.

Quick Start

Create an identity

Every agent gets an Ed25519 keypair. The identity is derived deterministically from the public key — no server, no registration.

import synpareia

# Generate a new agent identity
profile = synpareia.generate()
print(profile.id)  # did:synpareia:a1b2c3...

Sign a block

A block is the atomic unit: a typed, hashed, signed record of something that happened.

block = synpareia.create_block(
    profile,
    type="message",
    content="Hello from Agent A",
)

# Anyone with the public key can verify authorship
assert synpareia.verify_block(block, profile.public_key)

Build a chain

A chain is an ordered, hash-linked sequence of blocks — a tamper-evident history.

# Create a Chain of Presence (personal history)
chain = synpareia.create_chain(profile)

# Append blocks
pos1 = synpareia.append_block(chain, block)
pos2 = synpareia.append_block(chain, another_block)

# Verify the chain is intact
valid, errors = synpareia.verify_chain(chain)
assert valid

Export and verify independently

Chains are portable. Export them as JSON, send them to anyone, and they can verify independently.

from synpareia import export_chain, verify_export

# Export
data = export_chain(chain)

# Anyone can verify — no network, no trust, just math
valid, errors = verify_export(data)
assert valid

Link chains with anchors

When an agent participates in a shared conversation, anchors link their personal chain to the shared record.

# Agent A's personal chain references a position in the shared chain
anchor_block, anchor_pos = synpareia.create_anchor_block(
    profile,
    agent_chain,
    target_chain_id=shared_chain.id,
    target_sequence=3,
    target_block_hash=shared_block.content_hash,
    anchor_type="correspondence",
)

Commit-reveal for independent evaluation

Two agents can independently commit to assessments before revealing them — proving neither was influenced by the other.

# Agent commits (keeps nonce secret)
commitment_block, nonce = synpareia.create_commitment_block(
    profile,
    content=b"My honest assessment: excellent interaction",
)

# Later, reveal and verify (the commitment hash is the block's content)
assert synpareia.verify_commitment(
    commitment_block.content,
    b"My honest assessment: excellent interaction",
    nonce,
)

Core Concepts

Four Primitives

Primitive Purpose Example
Block Atomic signed record A message, thought, reaction, or system event
Chain Ordered, hash-linked sequence of blocks An agent's personal history, a conversation log
Anchor Cross-chain reference "This block in my chain corresponds to that block in theirs"
Seal Third-party attestation (Tier 4, coming soon) A witness timestamps or checkpoints a chain

Chain of Presence (CoP)

An agent's personal, append-only, hash-linked history across interactions and platforms. Like a cryptographic resume — verifiable by anyone, controlled by the agent.

Spheres

When two or more agents interact, the shared observable history is a sphere chain. Each agent's CoP links to the sphere via anchors, creating a verifiable record of who said what, and when.

What You Can Verify

Claim How
"Agent X authored this content" Ed25519 signature on the block
"This content existed at time T" Block timestamp + chain position
"This history hasn't been tampered with" Hash-linked chain verification
"Agent X participated in conversation Y" Anchor from CoP to sphere chain
"Both assessments were independent" Commit-reveal: both commitments precede both reveals
"This chain export is authentic" verify_export() — standalone, offline verification

API Reference

Identity

Function Description
generate() Create a new Ed25519 keypair and Profile
from_private_key(bytes) Reconstruct Profile from private key
from_public_key(bytes) Create a verify-only Profile
load(pub_b64, priv_b64?) Load Profile from base64-encoded keys

Blocks

Function Description
create_block(profile, type, content) Create a signed block
verify_block(block, public_key?) Verify content hash and signature
reveal_block(block, content) Reveal content of a hash-only block

Chains

Function Description
create_chain(profile, chain_type?) Create a new chain
append_block(chain, block) Append a block, returns ChainPosition
verify_chain(chain) Walk and verify all hash links
export_chain(chain) Export as portable, verifiable JSON
verify_export(data) Verify an export without the original chain

Anchors

Function Description
create_anchor_block(profile, chain, ...) Create a cross-chain reference
verify_anchor(anchor, source, target) Verify anchor references are valid

Commitments

Function Description
create_commitment(content, nonce?) Create a commitment hash
verify_commitment(hash, content, nonce) Verify a commitment reveal
create_commitment_block(profile, content) Create a commitment as a block

Types

BlockType, ChainType, AnchorType, ContentMode — extensible enums for all standard types.

Storage

MemoryStore (default), ChainStore protocol for custom backends.

Design Choices

  • Ed25519 for signatures — fast, small, deterministic, safe-by-default
  • SHA-256 for hashing — universal, well-audited, interoperable
  • JCS (RFC 8785) for canonicalization — deterministic JSON serialization for reproducible hashes
  • Frozen dataclasses — immutable primitives, zero framework dependency
  • Length-prefixed commitments — prevents separator collision in commit-reveal payloads
  • Constant-time comparison — timing-safe commitment verification via hmac.compare_digest

Tiers

The SDK is structured in tiers of increasing dependency:

Tier What Dependencies
1-3 (this release) Blocks, Chains, Anchors cryptography only
4 (coming) Witness seals, liveness + network client
5 (coming) Reputation, discovery + synpareia network

Tiers 1-3 work entirely offline. No server, no account, no network.

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

synpareia-0.1.0.tar.gz (67.2 kB view details)

Uploaded Source

Built Distribution

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

synpareia-0.1.0-py3-none-any.whl (24.9 kB view details)

Uploaded Python 3

File details

Details for the file synpareia-0.1.0.tar.gz.

File metadata

  • Download URL: synpareia-0.1.0.tar.gz
  • Upload date:
  • Size: 67.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for synpareia-0.1.0.tar.gz
Algorithm Hash digest
SHA256 ac5563548a914d078c8fbc5a84c58a2c269528caa496377e511193ffd33e4968
MD5 d82ac8604b58e8490e1689711d9f63de
BLAKE2b-256 5b12769d9c4dd5589cabc161563ec2aaae11e301631f71db1c1c4d7727536590

See more details on using hashes here.

File details

Details for the file synpareia-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: synpareia-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 24.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for synpareia-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c8c6655843afd48a68a32328948617fcf8df1fd154faf53c50d0f4f41a25287c
MD5 332d7b51df482e6af28ebbd10b10c866
BLAKE2b-256 a4b2f2e11db1094096ff22a9d768d6ec16ad77bfe4aa14d1af8727b377a72fa8

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