PaidMCP - Charge Bitcoin For MCP Server Tools

Receive lightning payments for each tool request, powered by NWCarrow-up-right.

In a few lines of code, turn your modelcontextprotocol/sdkarrow-up-right 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 Boilerplatearrow-up-right 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 MCParrow-up-right to allow your agent to make the payment.

Install

or

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. NWCarrow-up-right is an open protocol for connecting apps to lightning wallets. If you don't have a NWC-enabled lightning wallet yet, try Alby Hubarrow-up-right.

Powered by PaidMCP

Examples

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.

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.

Once the payment is made by the human or their agent (this can be done with Alby MCParrow-up-right), the agent will request the same tool again, this time providing the payment_hash along with the request:

The MCP server will then execute the actual tool callback as normal.

Last updated

Was this helpful?