getAlby/paidmcp-boilerplate
If you are the rightful owner of paidmcp-boilerplate and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The Boilerplate Paid MCP Server is an example server that facilitates paid interactions using the Model Context Protocol (MCP) and integrates with Bitcoin Lightning payments.
ask_riddle
A free tool that returns a riddle.
check_riddle
A paid tool that requires 21 sats to check your answer to a riddle.
Boilerplate Paid MCP Server
An example paid MCP server using PaidMCP and the official MCP TypeScript SDK
This MCP server is designed to be used in combination with Alby Bitcoin Payments MCP Server or another MCP Server that can make lightning payments.
Tools
This boilerplate MCP server has 3 tools:
get_weather
is a paid tool to fetch the weather in a given cityget_food_delivery_menu
is a free tool that returns food items that can be purchasedorder_food_delivery
order one or more items from the menu
Examples
1. Weather
What's the weather in Wellington?
I'll get the current weather information for Wellington for you.
āāā get_weather | weather āāāāāāāāāāāāāāāāāāāāāāāāāā
city: Wellington
It looks like this weather service requires a small Lightning payment to access the data. I can help you pay this invoice using your connected Lightning wallet if you'd like to proceed.
The invoice is for 21 sats to get weather data for Wellington. Let me pay this invoice and then get your weather information.
āāā pay_invoice | alby-http āāāāāāāāāāāāāāāāāāāāāāāāāā
invoice: ...
ā Goose would like to call the above tool, do you allow?
ā Allow
ā
Great! Payment successful. Now let me get the weather information for Wellington using the payment hash.
āāā get_weather | weather āāāāāāāāāāāāāāāāāāāāāāāāāā
city: Wellington
payment_hash: ...
## Weather in Wellington
The current temperature in Wellington is **14.2°C** (about 57.6°F).
*This weather data was obtained via a Lightning micropayment of 21 sats.*
2. Food Delivery
Order me 2 pizzas
The user wants to order 2 pizzas. Looking at the environment details, I can see this is a boilerplate MCP project with food delivery functionality. I can see there are food delivery tools available:
food_delivery_menu.ts
food_delivery_order.ts
I also notice there's a boilerplate_paid_mcp MCP server connected that has food delivery tools available:
food_delivery_menu: Shows the food delivery menu items available for purchase
food_delivery_order: Order food delivery of one or more items
To order pizzas, I should:
First check the menu to see what pizza options are available
Then place an order for 2 pizzas
Let me start by checking the menu to see what's available.
I'll help you order 2 pizzas. Let me first check the food delivery menu to see what pizza options are available.
āāā boilerplate_paid_mcp | get_food_delivery_menu āāāāāāāāāāāāāāāāāāāāāāāāāā
{}
Perfect! I can see there's Pizza available on the menu for 21 sats each. Now I'll place an order for 2 pizzas.
āāā boilerplate_paid_mcp | order_food_delivery āāāāāāāāāāāāāāāāāāāāāāāāāā
Order food delivery of one or more items
{
"menu_items": [
{
"title": "Pizza"
},
{
"title": "Pizza"
}
]
}
The food delivery service requires payment before completing the order. I need to pay the lightning invoice first. Let me pay the invoice for 42 sats (21 sats Ć 2 pizzas) using the Alby MCP server.
āāā alby_mcp | pay_invoice āāāāāāāāāāāāāāāāāāāāāāāāāā
{
"invoice": "lnbc420n1p58vggudpyfaexgetjypnx7u3q2p5h57np9ss9q6t60fssnp4q228a2ztxkwzaypvzrsh823qngmv97f2v9puwvtsadetypmutyscwpp53jg4mzq70r7gj75wu0scphy3h46df8t9ehjfs5ae4w4wfm93fwgssp5a4pus38dey8e5mqw0y6cyn6gce9w3yq2gpn52cha636fzll29xrq9qyysgqcqpcxqyz5vqlg4ess44vklv7a3tsl59tuh29jz6g55dp5hg0dwnsfhg47p4g02nyzmlaawul8mscspgqkz00radh94kk7m0nn3a84x22yhree8s42qqe95prr"
}
Great! The payment was successful with no fees. Now I'll complete the pizza order by providing the payment hash.
āāā boilerplate_paid_mcp | order_food_delivery āāāāāāāāāāāāāāāāāāāāāāāāāā
{
"menu_items": [
{
"title": "Pizza"
},
{
"title": "Pizza"
}
],
"payment_hash": "8c915d881e78fc897a8ee3e180dc91bd74d49d65cde49853b9abaae4ecb14b91"
}
Task Completed
Your order for 2 pizzas has been successfully placed!
Order details:
Order ID: 21
Items: 2 Ć Pizza
Total cost: 42 sats (21 sats per pizza)
Payment: Completed successfully with 0 fees
Your pizzas are now being prepared for delivery.
Get started
- Follow the local development instructions below to build and inspect the MCP server
- Replace the with your own
- Deploy your MCP server with
fly launch
Local Development
Prerequisites
- Node.js 20+
- Yarn
- A connection string from a lightning wallet that supports NWC
Installation
yarn install
Add your NWC connection
Copy .env.example
to .env
and update your NWC connection secret.
Don't have one yet? check out Alby Hub
Configure in Roo code
Add to your MCP server list and update the args
and env
:
{
"mcpServers": {
"boilerplate_paid_mcp": {
"command": "node",
"args": ["/YOUR_PATH_TO_REPOSITORY/boilerplate-paid-mcp/build/index.js"],
"env": {
"NWC_CONNECTION_STRING": "nostr+walletconnect://..."
},
"disabled": false,
"autoApprove": [],
"alwaysAllow": [],
"disabledTools": []
}
}
}
Also it's recommended to install Alby MCP to test making payments.
Building
yarn build
Inspect the tools (use/test without an LLM)
yarn inspect
Troubleshooting
Model Usage
Make sure you use a decent model (e.g. Claude Sonnet 3.7) otherwise the MCP server will not work.
Contact Alby Support
Visit support.getalby.com and we're happy to help you get the MCP server working.