Paidmcp
Charge agents to access your MCP Server tools
Installation
npx paidmcpAsk AI about Paidmcp
Powered by Claude · Grounded in docs
I know everything about Paidmcp. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
PaidMCP - Charge Bitcoin For MCP Server Tools
Receive lightning payments for each tool request, powered by NWC.
In a few lines of code, turn your modelcontextprotocol/sdk MCP Server tool into a paid tool:
- const server = new McpServer({name: "your-mcp-server"});
+ const server = new PaidMcpServer({name: "your mcp server"}, {nwcUrl, storage});
- server.registerTool(name, config, callback);
+ server.registerPaidTool(name, config, charge, callback);
Why use PaidMCP
Instead of using the Cloudflare Stripe MCP Boilerplate which is difficult to setup, high fees and chargeback risks, you can accept payments easily and instantly from anyone in the world, without fees. This is made possible by the bitcoin lightning network.
Get started
Try an example Paid MCP
If your agent supports remote MCP servers - HTTP Streamable transports or SSE (e.g. N8N), you can connect to Alby's MCP server:
- HTTP Streamable:
https://weather-mcp.fly.dev/mcp - SSE (Deprecated):
https://weather-mcp.fly.dev/sse
Then ask: "What's the weather in Berlin?"
Make sure to also install Alby MCP to allow your agent to make the payment.
Install
npm install @getalby/paidmcp
or
yarn add @getalby/paidmcp
Import and use PaidMcpServer
PaidMcpServer is a thin wrapper around the standard McpServer class that adds ability to create paid tools.
This MCP requires an NWC-enabled lightning wallet to be able to charge payments. NWC is an open protocol for connecting apps to lightning wallets. If you don't have a NWC-enabled lightning wallet yet, try Alby Hub.
import { PaidMcpServer, MemoryStorage } from "@getalby/paidmcp";
// Configure your NWC URL - should be "nostr+walletconnect://..."
const nwcUrl = process.env.NWC_URL;
// Configure storage of unused paid tool requests
const storage = new MemoryStorage();
// use PaidMcpServer instead of McpServer
const server = new PaidMcpServer(
{ name: "your-mcp-server" },
{ nwcUrl, storage }
);
// for paid tools, use registerPaidTool
// it requires an additional argument before the callback
// to configure charging information based on the request
server.registerPaidTool(
name,
config,
(args) => ({ satoshi: 1, description: "Paid tool usage: " + args.city }),
callback
);
Powered by PaidMCP
- f418.me Paid MCP Server - Send SMS message from your agent, paid with sats
Examples
- Weather example - simple example of a paid
get_weathertool - PaidMCP Boilerplate - full boilerplate repository to get you started straight away with free and paid tools
How it works
For a simple example we have a paid weather MCP - that you can fetch the weather for a city by paying a small fee.
{
"city": "Berlin"
}
Some additional parameters are injected into the tool request and response. If a paid tool is requested without a payment hash, the following response will be returned:
the required payment amount and description can be configured per-request.
{
"payment_instructions": "Payment required. Pay the payment_request and try the same request again with the payment_hash set to continue.",
"payment_request": "lnbc...",
"payment_hash": "2b3e38cff2ab0172d28e004931938c09a19b3e81a2054c3b46ac087ec3bc30b3"
}
Once the payment is made by the human or their agent (this can be done with Alby MCP), the agent will request the same tool again, this time providing the payment_hash along with the request:
{
"city": "Berlin",
"payment_hash": "2b3e38cff2ab0172d28e004931938c09a19b3e81a2054c3b46ac087ec3bc30b3"
}
The MCP server will then execute the actual tool callback as normal.
{
"temperature_celcius": "27.4"
}
