Brings OpenTimestamps directly into Claude and other MCP clients so you can prove a document existed at a specific time by anchoring its SHA-256 hash into the Bitcoin blockchain. The server exposes tools to stamp hashes against public OTS calendars, upgrade pending proofs once Bitcoin confirms them (typically 60 minutes but sometimes longer), and verify timestamps against actual blocks. Everything runs locally with no API keys, storing proofs in a SQLite database at ~/.ots-mcp/. Includes a watcher that monitors pending stamps and a scheduler you can install to auto-upgrade them. Useful when you need cryptographic proof of existence for contracts, code releases, or any file where timestamp integrity matters and you want Bitcoin's immutability backing it up.
OpenTimestamps MCP server - stamp, upgrade, and verify Bitcoin timestamps via AI agents.
Exposes a set of tools to any MCP-compatible agent so it can timestamp documents, monitor confirmation status, and verify proofs against the Bitcoin blockchain - all from a conversation.
Note on confirmation times: After stamping, a proof is
pendinguntil Bitcoin confirms it. This typically takes ~60 minutes but can take several hours during network congestion. Useots-mcp watchorupgrade_timestampto monitor. A pending status is not an error.
npm install -g @otskit/mcp
ots-mcp setup claude # Claude Desktop
ots-mcp setup claude-code # Claude Code CLI
ots-mcp setup codex # Codex CLI
Each command writes the MCP entry into the agent's config file, makes a .bak backup if the file already exists, and skips if ots-mcp is already configured. Restart the agent afterwards to apply the changes.
| Command | Description |
|---|---|
ots-mcp serve | Start the MCP server (stdio transport) |
ots-mcp stamp <sha256> | Stamp a SHA-256 hash against Bitcoin calendars |
ots-mcp upgrade <id> | Check if a pending stamp has been confirmed |
ots-mcp verify <id> | Verify a stamp against Bitcoin |
ots-mcp list [status] | List stamps (pending / confirmed / failed) |
ots-mcp watch [minutes] | Monitor pending stamps and attempt due upgrades (default: 30 min, minimum: 15 min) |
ots-mcp check-pending | Run one upgrade pass over all pending stamps |
ots-mcp scheduler install|remove|status | Manage OS-level scheduler for auto-upgrades |
ots-mcp backup [dest] | Backup the SQLite database |
ots-mcp setup <claude|claude-code|codex> | Configure MCP for an agent |
| Tool | Description |
|---|---|
create_timestamp | Stamp a SHA-256 hash against 4 public OTS calendars |
upgrade_timestamp | Check if a pending stamp has been confirmed in Bitcoin |
verify_timestamp | Verify a stamp - proves hash existed before a given Bitcoin block |
inspect_timestamp | Inspect a stored proof file without network calls |
list_pending | List stamps with status, retry count, and filters |
watch | Open a terminal window monitoring pending stamps and attempting due upgrades |
hash_file | Compute the SHA-256 of a local file and return it as a 64-char hex string (no network calls) |
stamp_file | Compute SHA-256 of a local file and stamp it on Bitcoin in one step |
All data is stored in ~/.ots-mcp/:
~/.ots-mcp/
ots-mcp.db # SQLite database (stamps, proof files)
config.json # Optional config overrides
ots-mcp.log # Log file
Create ~/.ots-mcp/config.json to override defaults:
{
"stamp_enabled": true,
"scheduler_interval_minutes": 30,
"retry_max_attempts": 20,
"calendar_timeout_ms": 10000,
"calendars": [
"https://alice.btc.calendar.opentimestamps.org",
"https://bob.btc.calendar.opentimestamps.org",
"https://finney.calendar.eternitywall.com",
"https://btc.calendar.catallaxy.com"
]
}
npm run build # production build
npm run dev # watch mode
npm test # run tests
@otskit/core - OpenTimestamps core logic@otskit/client - OTS calendar client@modelcontextprotocol/sdk - MCP SDKnode-sqlite3-wasm - local database (pure WASM, no native compilation)io.github.shelvick/shopify-subscription-reconciliation
csoai-org/meok-stripe-acp-checkout-mcp
csoai-org/stripe-billing-mcp
ai.adramp/google-ads
co.pipeboard/google-ads-mcp
co.curie/commerce