loading…
Search for a command to run...
loading…
Cryptographic accountability for AI agents. Ed25519-signed receipts for every MCP tool call. Constraints, chains, AI judgment, invoicing, and local dashboard in
Cryptographic accountability for AI agents. Ed25519-signed receipts for every MCP tool call. Constraints, chains, AI judgment, invoicing, and local dashboard included.
Your AI agent remembers everything — and you can prove it.
Persistent memory for AI agents, backed by cryptographic receipts. Every fact your agent learns is signed, traceable, and independently verifiable. No cloud required.
Live Demo Interactive Walkthrough npm version License: MIT
Try the Interactive Demo · Install in 30 Seconds · How It's Different
You're building with AI agents. Claude Code refactors your auth module and says "done, all tests pass." Your agent generates a customer quote and says it applied the right pricing. Your assistant remembers your preferences from last week — but you can't see why it thinks that, or whether it's right.
Three things are broken:
Agents forget everything between sessions. Every conversation starts from zero. Context is lost. You re-explain the same things.
When agents do remember, you can't see inside. Platform memory is a black box. You can't see what it stored, when, or why. You can't correct it, export it, or verify it.
There's no proof of what agents actually did. Logs are mutable. Agents write their own logs. "I updated 3 files and all tests pass" — did it? You're trusting the agent's word about its own work.
Your agent gets structured, persistent memory across sessions — people, projects, tools, preferences, facts. Not a flat key-value store. An entity-observation graph where every fact links to the conversation that created it.
# Your agent learns something
memory_observe → "User prefers TypeScript, uses Neovim, building a SaaS called ModQuote"
# Next session, it already knows
memory_context → loads everything: entities, observations, relationships, preferences
# You can search it
memory_recall → "what tech stack does the user prefer?" → structured results
# You can forget (and the forget itself is tracked)
memory_forget → soft delete with audit trail
The agent handles this automatically when you add the system prompt. You don't manage memory manually.
Every memory observation and every agent action produces a receipt — a signed JSON document with:
This isn't logging. Logs are mutable text files the agent writes about itself. Receipts are cryptographic proof that a third party can verify without trusting you, your server, or the agent.
npx @agent-receipts/mcp-server
That's it. No API key. No account. No cloud. No monthly fee. No data leaving your machine. SQLite database in ~/.agent-receipts/. Works offline.
I was building ModQuote — a multi-tenant SaaS where AI agents generate quotes for automotive protection shops. Real money, real customers, real liability.
When Claude generated a $2,400 PPF quote, I needed answers: What vehicle data did it receive? What pricing rules did it apply? If a customer disputes the price, can I prove what happened — not with a log entry the agent wrote about itself, but with cryptographic proof?
I looked at the existing tools:
None of them could answer: "Prove to someone outside your system that this specific agent took this specific action with this specific input at this specific time."
So I built Agent Receipts. Now every quote generation is a signed receipt. Every memory has a provenance chain. And when someone asks "how did the agent come up with that number?" — I hand them a receipt they can verify themselves.
| Agent Receipts | Mem0 | Langfuse | Zep | |
|---|---|---|---|---|
| Memory | Signed entity-observation graph | Smart extraction + consolidation | No memory | Temporal knowledge graph |
| Proof | Ed25519 signed receipts | None | Mutable traces | None |
| Verification | Offline, by anyone, no server | No | No | No |
| Infrastructure | npx and done. Zero config. |
Requires LLM for extraction | Cloud or self-host | Cloud API |
| Cost | Free forever (local) | Free tier, then paid | Free tier, then paid | Paid |
| Export | Portable bundles with crypto verification | Export available | API export | No |
| Audit trail | Immutable receipt chain | Mutable | Mutable logs | Mutable |
Agent Receipts isn't a better version of these tools. It's a different thing.
Mem0 answers: "What does my agent remember?" Langfuse answers: "What happened in my LLM pipeline?" Agent Receipts answers: "Can you prove it?"
Claude Code:
claude mcp add agent-receipts -- npx @agent-receipts/mcp-server
Claude Desktop (claude_desktop_config.json) / Cursor (.cursor/mcp.json):
{
"mcpServers": {
"agent-receipts": {
"command": "npx",
"args": ["@agent-receipts/mcp-server"]
}
}
}
This tells your agent when to observe memories, recall context, and track actions — so it works automatically:
npx @agent-receipts/cli prompts claude-code
Copy the output into your project instructions or system prompt.
Your agent will now:
memory_context at the start of sessions to load what it knows about youmemory_observe when it learns something worth rememberingtrack_action when it performs significant actionsnpx @agent-receipts/dashboard # Web UI at localhost:3274
npx @agent-receipts/cli stats # Terminal overview
npx @agent-receipts/cli memory entities # See what your agent remembers
Run the interactive demo → — experience memory, verification, and bundle export in 60 seconds. No install required.
any, zero ESLint warnings@noble/ed25519 (audited, pure JS)Export your agent's entire memory as a single verifiable file:
npx @agent-receipts/cli memory export > my-project.bundle.json
The bundle includes every entity, observation, relationship, the receipts that created them, and the public key needed to verify everything. Hand it to another agent, another team, or another Agent Receipts instance — they can verify every fact without trusting you.
| Interactive Demo | Try it in your browser — 60 seconds |
| Live Dashboard | See the full dashboard with sample data |
| How It Works | Receipt anatomy, memory model, ModQuote story |
| npm | All 6 packages |
ar.track(params) — Track a completed action with automatic hashingar.start(params) — Create a pending receiptar.complete(receiptId, params) — Complete a pending receiptar.verify(receiptId) — Verify a receipt's Ed25519 signaturear.get(receiptId) — Get a receipt by IDar.list(filter?) — List receipts with filtering and paginationar.getPublicKey() — Get the signing public keyar.getJudgments(receiptId) — Get judgments for a receiptar.cleanup() — Delete expired receiptsar.generateInvoice(options) — Generate invoice from receiptsar.context(params?) — Get full memory context dump for session initar.observe(params) — Store a memory observation (always receipted)ar.recall(params?) — Search memories (quiet by default, audited: true for receipt)ar.forget(params) — Soft-delete observation or entity (always receipted)ar.entities(filters?) — List entitiesar.relate(params) — Create entity relationshipar.provenance(observationId) — Get provenance chainar.memoryAudit(params?) — Memory audit reportar.exportBundle(params?) — Export portable, verifiable memory bundlear.importBundle(bundle, params?) — Import and verify a memory bundlear.emit(params) — Alias for track()| Tool | Description | Key Parameters |
|---|---|---|
track_action |
Track an agent action with automatic hashing | action, input, output, constraints |
create_receipt |
Create a receipt with pre-computed hashes | action, input_hash, output_hash |
complete_receipt |
Complete a pending receipt with results | receipt_id, output, status |
verify_receipt |
Verify the cryptographic signature | receipt_id |
get_receipt |
Retrieve a receipt by ID | receipt_id |
list_receipts |
List receipts with filtering | agent_id, status, chain_id |
get_chain |
Get all receipts in a chain | chain_id |
get_public_key |
Export the Ed25519 public key | — |
judge_receipt |
Start AI Judge evaluation | receipt_id, rubric |
complete_judgment |
Complete a pending judgment | receipt_id, verdict, score |
get_judgments |
Get all judgments for a receipt | receipt_id |
cleanup |
Delete expired receipts | dry_run, cleanup_memory |
generate_invoice |
Generate invoice from receipts | from, to, format |
get_started |
Getting-started guide | — |
memory_context |
Full context dump for session init | scope, max_entities |
memory_observe |
Store a memory observation | entity_name, entity_type, content |
memory_recall |
Search stored memories | query, entity_type, scope |
memory_forget |
Soft-delete observation or entity | entity_id or observation_id |
memory_entities |
List known entities | entity_type, scope, query |
memory_relate |
Create entity relationship | from_entity_id, to_entity_id, type |
memory_provenance |
Provenance chain for observation | observation_id |
memory_audit |
Memory operations audit report | agent_id, from, to |
memory_export_bundle |
Export portable memory bundle | entity_ids, include_receipts |
memory_import_bundle |
Import and verify memory bundle | bundle, skip_existing |
| Command | Description |
|---|---|
init |
Create data directory and generate signing keys |
keys [--export] [--import] |
Display, export, or import signing keys |
inspect <id|file> |
Pretty-print a receipt |
verify <id|file> [--key] |
Verify a receipt signature |
list [--agent] [--status] [--json] |
List receipts with filters |
chain <chain_id> [--tree] |
Show receipt chain |
judgments <id> [--json] |
List judgments for a receipt |
cleanup [--dry-run] |
Delete expired receipts |
stats |
Aggregate receipt statistics |
export <id|--all> [--pretty] |
Export receipts as JSON |
invoice --from --to [--format] |
Generate invoice |
seed [--demo] [--count] [--clean] |
Seed demo data |
watch [--agent] [--action] |
Watch for new receipts |
prompts <client> |
Setup guide (claude-code, cursor, system) |
memory context |
Memory context summary |
memory observe <name> <type> <content> |
Store observation |
memory recall [query] |
Search memories |
memory entities [--type] |
List entities |
memory forget <id> |
Forget observation or entity |
memory audit |
Memory audit report |
memory provenance <obs_id> |
Provenance chain |
memory export |
Export memories as JSON |
memory import <file> |
Import memories |
| Environment Variable | Description | Default |
|---|---|---|
AGENT_RECEIPTS_DATA_DIR |
Data directory path | ~/.agent-receipts |
AGENT_RECEIPTS_AGENT_ID |
Default agent ID | local-agent |
AGENT_RECEIPTS_ORG_ID |
Organization ID | local-org |
AGENT_RECEIPTS_ENVIRONMENT |
Environment label | production |
RECEIPT_SIGNING_PRIVATE_KEY |
Ed25519 private key (hex) | Auto-generated |
Storage:
~/.agent-receipts/
├── keys/
│ ├── private.key # Ed25519 private key (mode 0600)
│ └── public.key # Ed25519 public key
├── receipts.db # SQLite database (receipts + memory)
└── config.json # Agent and org configuration
| Package | Description |
|---|---|
| @agent-receipts/schema | Zod schemas and TypeScript types |
| @agent-receipts/crypto | Ed25519 signing, verification, key management |
| @agent-receipts/mcp-server | MCP server with 24 tools |
| @agent-receipts/sdk | TypeScript SDK (21 methods) |
| @agent-receipts/cli | Command-line interface |
| @agent-receipts/dashboard | Mission Control web UI |
MIT
Built by Amin Suleiman — building ModQuote and Agent Receipts.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"agent-receipts": {
"command": "npx",
"args": []
}
}
}