Give AI agents the ability to interact with Counterparty — the token protocol built on Bitcoin. Query balances, assets, orders, and dispensers. Compose, sign, and broadcast transactions. Works with any MCP-compatible client.
No download needed — just add the config below to your AI client. npx fetches and runs the server automatically.
Add to claude_desktop_config.json (how to find it):
{
"mcpServers": {
"counterparty": {
"command": "npx",
"args": ["-y", "@21e14/mcp-server"]
}
}
}claude mcp add counterparty -- npx -y @21e14/mcp-serverWith signing (see Signing & Broadcasting):
claude mcp add counterparty \
-e SIGNER_PRIVATE_KEY=L1aW4aubDFB7yfras2S1mN... \
-e SIGNER_ADDRESS=bc1q... \
-- npx -y @21e14/mcp-serverManage servers with claude mcp list, claude mcp get counterparty, or claude mcp remove counterparty.
Use Ctrl+Shift+P → MCP: Add Server → Stdio, then enter:
npx -y @21e14/mcp-server
Or add to .vscode/mcp.json:
{
"servers": {
"counterparty": {
"type": "stdio",
"command": "npx",
"args": ["-y", "@21e14/mcp-server"]
}
}
}Add to .cursor/mcp.json:
{
"mcpServers": {
"counterparty": {
"command": "npx",
"args": ["-y", "@21e14/mcp-server"]
}
}
}Add to ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"counterparty": {
"command": "npx",
"args": ["-y", "@21e14/mcp-server"]
}
}
}In ChatGPT desktop, go to Settings → Beta Features → MCP Servers, then add:
npx -y @21e14/mcp-server
The server speaks stdio. Point any MCP-compatible client at:
npx -y @21e14/mcp-serverThat's it. The agent can now query the Counterparty network and compose unsigned transactions.
To let the agent sign and broadcast transactions, add a signing key:
{
"mcpServers": {
"counterparty": {
"command": "npx",
"args": ["-y", "@21e14/mcp-server"],
"env": {
"SIGNER_PRIVATE_KEY": "L1aW4aubDFB7yfras2S1mN...",
"SIGNER_ADDRESS": "bc1q..."
}
}
}
}This enables the sign_and_broadcast tool. Signing gives the AI agent the ability to spend funds — read the security guidance below.
- Generate a fresh keypair offline. Don't reuse an existing wallet or generate keys through the AI.
- Fund it with only what you're willing to risk. This is your blast radius.
- Use a segwit address. P2WPKH (
bc1q...), P2SH-P2WPKH (3...), or P2TR (bc1p...). Legacy P2PKH is not supported. - One key, one address. No HD derivation. Counterparty reuses addresses by design.
- Keep main holdings elsewhere. The bot wallet is disposable.
Without signing keys, the server returns unsigned transaction hex from all compose tools. You can review and sign offline with your own tooling. This is the safest mode.
sign_and_broadcast extracts and returns the embedded OP_RETURN data from the transaction before signing — done locally without trusting the API, so the agent can verify the transaction matches what was requested.
| Variable | Required | Description |
|---|---|---|
COUNTERPARTY_NODE |
No | Counterparty node URL (default: https://api.counterparty.io:4000) |
SIGNER_PRIVATE_KEY |
No | WIF-encoded private key for signing |
SIGNER_ADDRESS |
No | Bitcoin address for the signing key |
| Tool | Description |
|---|---|
get_balances |
All token balances for an address |
get_balance |
Single asset balance for an address |
get_asset_info |
Asset metadata (supply, divisibility, issuer) |
get_asset_balances |
All holders of an asset |
get_assets |
Search/list assets |
get_issuances |
Issuance history for an asset |
get_owned_assets |
Assets issued by an address |
get_orders |
DEX orders |
get_order |
Single order by hash |
get_order_matches |
Matches for an order |
get_orders_by_pair |
Order book for a trading pair |
get_asset_orders |
Orders involving an asset |
get_address_orders |
Orders by address |
get_dispensers |
Dispensers |
get_dispenser |
Single dispenser by hash |
get_dispensers_by_asset |
Dispensers for an asset |
get_address_dispensers |
Dispensers by address |
get_dispenses |
Purchases from a dispenser |
get_dividends |
Dividend distributions for an asset |
get_address_transactions |
Transaction history for an address |
get_sends |
Token transfers from an address |
get_transaction |
Single transaction by hash |
get_utxo_balances |
Tokens attached to a UTXO |
get_latest_block |
Latest block info |
| Tool | Description |
|---|---|
compose_send |
Send tokens to an address |
compose_mpma |
Multi-party multi-asset send |
compose_order |
Place a DEX order |
compose_cancel |
Cancel an open order |
compose_btcpay |
Pay for a matched BTC order |
compose_issuance |
Create or update an asset (supports inscriptions) |
compose_dispenser |
Create, open, or close a dispenser |
compose_dispense |
Buy from a dispenser |
compose_dividend |
Distribute dividends to holders |
compose_broadcast |
Broadcast a message (supports inscriptions) |
compose_sweep |
Sweep all assets to a destination |
compose_destroy |
Permanently burn tokens |
compose_fairminter |
Create a fair launch (supports inscriptions) |
compose_xcp420_fairminter |
XCP-420 compliant fair launch |
compose_fairmint |
Mint from an active fair launch |
compose_attach |
Attach tokens to a UTXO |
compose_detach |
Detach tokens from a UTXO |
compose_movetoutxo |
Move a UTXO to a new output |
| Tool | Description |
|---|---|
sign_and_broadcast |
Sign and broadcast (requires signing keys) |
broadcast_transaction |
Broadcast an already-signed transaction |
get_fee_estimate |
Current fee rate estimate |
decode_transaction |
Decode raw transaction hex |
| Tool | Description |
|---|---|
unpack_transaction |
Decode a Counterparty message from a transaction |
get_server_info |
Node status and version |
api_request |
Raw API request to any endpoint (full API reference) |
The server includes protocol documentation that agents can read for context:
counterparty://protocol-overview— Assets, quantities, DEX, dispensers, fair minting, fees, and operational tipscounterparty://xcp420-standard— XCP-420 fair launch standardcounterparty://quick-start— Step-by-step workflows for common operations
git clone https://github.com/XCP/mcp-server.git
cd mcp-server
npm install
npm testTest locally:
{
"mcpServers": {
"counterparty": {
"command": "node",
"args": ["/path/to/mcp-server/dist/index.js"]
}
}
}MIT