Bitnovo Pay
MCP server for Bitnovo Pay integration with AI agents. Provides cryptocurrency payment capabilities through Bitnovo Pay API. Features include payment creation, status checking, QR code generation, and webhook management with support for multiple tunnel providers (ngrok, zrok, manual).
MCP Bitnovo Pay
MCP server for Bitnovo Pay integration with AI agents
A Model Context Protocol (MCP) server that provides AI agents with cryptocurrency payment capabilities through Bitnovo Pay API integration. This server enables AI models to create payments, check payment status, manage QR codes, and access cryptocurrency catalogs.
๐ Features
-
8 MCP Tools for comprehensive payment management:
create_payment_onchain
- Generate cryptocurrency addresses for direct paymentscreate_payment_link
- Create web payment URLs with redirect handlingget_payment_status
- Query payment status with detailed informationlist_currencies_catalog
- Get supported cryptocurrencies with filteringgenerate_payment_qr
- Generate custom QR codes from existing paymentsget_webhook_events
- Query webhook events received in real-timeget_webhook_url
- Get public webhook URL with configuration instructionsget_tunnel_status
- Diagnose tunnel connection status
-
Automatic Webhook System with 3 tunnel providers:
- ๐ ngrok: Free persistent URL (1 static domain per account)
- ๐ zrok: 100% free open-source with persistent URLs
- ๐ข manual: For servers with public IP (N8N, Opal, VPS)
-
Multi-LLM Support - Compatible with:
- ๐ค OpenAI ChatGPT (GPT-5, GPT-4o, Responses API, Agents SDK)
- ๐ง Google Gemini (Gemini 2.5 Flash/Pro Sept 2025, CLI, FastMCP)
- ๐ฎ Claude (Claude Desktop, Claude Code)
-
High-Quality QR Codes (v1.1.0+):
- ๐ฑ 512px default resolution (up from 300px) for modern displays
- ๐จ๏ธ Support up to 2000px for professional printing
- โจ Sharp edges with optimized interpolation algorithms
- ๐จ Custom Bitnovo Pay branding with smooth logo scaling
-
Privacy by Default - Sensitive data masked in logs, minimal data exposure
-
Secure - HTTPS enforcement, HMAC signature validation, secure secret handling
-
Reliable - Built-in retry logic, timeout handling, stateless operation
๐ Prerequisites
- Node.js 18+
- Bitnovo Pay Account with Device ID and optional Device Secret
- Environment Configuration (see setup guides below)
โก Quick Start
1. Get Your Bitnovo Credentials
- Sign up at Bitnovo Pay
- Obtain your Device ID from the Bitnovo dashboard
- (Optional) Generate a Device Secret for webhook signature validation
2. Configure Your MCP Client
Add this configuration to your MCP client config file:
For Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json
):
{
"mcpServers": {
"bitnovo-pay": {
"command": "npx",
"args": ["-y", "@bitnovopay/mcp-bitnovo-pay"],
"env": {
"BITNOVO_DEVICE_ID": "your_device_id_here",
"BITNOVO_BASE_URL": "https://pos.bitnovo.com"
}
}
}
}
For OpenAI ChatGPT (see OpenAI Setup Guide):
{
"mcpServers": {
"bitnovo-pay": {
"command": "npx",
"args": ["-y", "@bitnovopay/mcp-bitnovo-pay"],
"env": {
"BITNOVO_DEVICE_ID": "your_device_id_here",
"BITNOVO_BASE_URL": "https://pos.bitnovo.com"
}
}
}
}
3. Restart Your MCP Client
Restart Claude Desktop, ChatGPT, or your MCP client to load the server.
4. Test the Integration
Ask your AI assistant: "Create a payment for 10 euros"
๐ฆ Installation Options
Option A: Using npx (Recommended)
No installation required! The npx
command automatically downloads and runs the latest version.
npx -y @bitnovopay/mcp-bitnovo-pay
Advantages:
- โ Always get the latest version
- โ No manual updates needed
- โ No local installation required
- โ Works immediately
Option B: Clone Repository (For Development)
For contributors or advanced users who need to modify the code:
# Clone the repository
git clone https://github.com/bitnovo/mcp-bitnovo-pay.git
cd mcp-bitnovo-pay
# Or install from npm
npm install -g @bitnovopay/mcp-bitnovo-pay
# Install dependencies
npm install
# Build the project
npm run build
# Run locally
npm start
Advantages:
- โ Full control of source code
- โ Ability to modify and test changes
- โ Ideal for contributing to the project
๐ง Configuration by LLM Platform
Choose your AI platform and follow the specific setup guide:
Claude Desktop (Anthropic)
Config File Location: ~/Library/Application Support/Claude/claude_desktop_config.json
(macOS)
Guide: Claude Setup Guide
Basic Configuration:
{
"mcpServers": {
"bitnovo-pay": {
"command": "npx",
"args": ["-y", "@bitnovopay/mcp-bitnovo-pay"],
"env": {
"BITNOVO_DEVICE_ID": "your_device_id_here",
"BITNOVO_BASE_URL": "https://pos.bitnovo.com"
}
}
}
}
With Webhooks (for real-time payment notifications):
{
"mcpServers": {
"bitnovo-pay": {
"command": "npx",
"args": ["-y", "@bitnovopay/mcp-bitnovo-pay"],
"env": {
"BITNOVO_DEVICE_ID": "your_device_id_here",
"BITNOVO_BASE_URL": "https://pos.bitnovo.com",
"BITNOVO_DEVICE_SECRET": "your_device_secret_hex",
"WEBHOOK_ENABLED": "true",
"TUNNEL_ENABLED": "true",
"TUNNEL_PROVIDER": "ngrok",
"NGROK_AUTHTOKEN": "your_ngrok_token",
"NGROK_DOMAIN": "your-domain.ngrok-free.app"
}
}
}
}
OpenAI ChatGPT
Guide: OpenAI Setup Guide Supported: GPT-5, GPT-4o, Responses API, Agents SDK
Basic Configuration:
{
"mcpServers": {
"bitnovo-pay": {
"command": "npx",
"args": ["-y", "@bitnovopay/mcp-bitnovo-pay"],
"env": {
"BITNOVO_DEVICE_ID": "your_device_id_here",
"BITNOVO_BASE_URL": "https://pos.bitnovo.com"
}
}
}
}
Google Gemini
Guide: Gemini Setup Guide Supported: Gemini 2.5 Flash/Pro (Sept 2025), CLI, FastMCP
Basic Configuration:
{
"mcpServers": {
"bitnovo-pay": {
"command": "npx",
"args": ["-y", "@bitnovopay/mcp-bitnovo-pay"],
"env": {
"BITNOVO_DEVICE_ID": "your_device_id_here",
"BITNOVO_BASE_URL": "https://pos.bitnovo.com"
}
}
}
}
Environment Variables
Variable | Required | Description | Example |
---|---|---|---|
BITNOVO_DEVICE_ID | โ Yes | Your Bitnovo Pay device identifier | 12345678-abcd-1234-abcd-1234567890ab |
BITNOVO_BASE_URL | โ Yes | Bitnovo API endpoint | https://pos.bitnovo.com (production)https://payments.pre-bnvo.com (development) |
BITNOVO_DEVICE_SECRET | โ ๏ธ Optional | HMAC secret for webhook validation | your_hex_secret |
WEBHOOK_ENABLED | โ ๏ธ Optional | Enable webhook server | true or false |
TUNNEL_ENABLED | โ ๏ธ Optional | Auto-start tunnel for webhooks | true or false |
TUNNEL_PROVIDER | โ ๏ธ Optional | Tunnel provider | ngrok , zrok , or manual |
Security Note: Never commit credentials to version control. Use environment variables or secure secret management.
๐ ๏ธ MCP Tools Reference
Payment Creation
create_payment_onchain
Creates a cryptocurrency payment with a specific address for direct transactions.
Use when: User specifies a cryptocurrency (Bitcoin, ETH, USDC, etc.)
{
"amount_eur": 50.0,
"input_currency": "BTC",
"notes": "Coffee payment"
}
create_payment_link
Creates a web-based payment URL where customers can choose their cryptocurrency.
Use when: Generic payment request without specific crypto mentioned (DEFAULT OPTION)
{
"amount_eur": 50.0,
"url_ok": "https://mystore.com/success",
"url_ko": "https://mystore.com/cancel",
"notes": "Order #1234"
}
Payment Management
get_payment_status
Retrieves current payment status with detailed information.
{
"identifier": "payment_id_here"
}
Status Codes:
NR
(Not Ready): Pre-payment created, no crypto assignedPE
(Pending): Waiting for customer paymentAC
(Awaiting Completion): Crypto detected in mempoolCO
(Completed): Payment confirmed on blockchainEX
(Expired): Payment time limit exceededCA
(Cancelled): Payment cancelledFA
(Failed): Transaction failed to confirm
list_currencies_catalog
Gets available cryptocurrencies with optional amount-based filtering.
{
"filter_by_amount": 25.0
}
generate_payment_qr
Creates custom QR codes for existing payments with high-quality output.
{
"identifier": "payment_id_here",
"qr_type": "both",
"size": 512,
"style": "branded"
}
QR Types:
address
: Crypto address only (customer enters amount manually)payment_uri
: Address + amount included (recommended)both
: Generate both types (recommended)gateway_url
: QR of payment gateway URL
QR Size Options (v1.1.0+):
- Default: 512px (optimized for modern displays)
- Range: 100px - 2000px
- Recommended sizes:
512px
: Mobile and web displays800-1200px
: Standard printing1600-2000px
: High-quality printing (posters, stands)
Quality Improvements (v1.1.0):
- โจ Sharp edges with
nearest
kernel interpolation for QR patterns - ๐ฏ High-quality logo scaling with
lanczos3
kernel - ๐ฆ PNG compression level 6 with adaptive filtering
- ๐ผ๏ธ Default size increased from 300px to 512px for better clarity
Webhook Tools
get_webhook_events
Query webhook events received in real-time from Bitnovo Pay API.
Available when: WEBHOOK_ENABLED=true
{
"identifier": "payment_id_here",
"limit": 50,
"validated_only": true
}
get_webhook_url
Get public webhook URL with configuration instructions for Bitnovo panel.
Available when: WEBHOOK_ENABLED=true
{
"validate": true
}
get_tunnel_status
Diagnose tunnel connection status (ngrok, zrok, or manual).
Available when: WEBHOOK_ENABLED=true
{}
๐ Documentation
- API Tools Reference - Detailed documentation for all MCP tools
- Usage Examples - Real-world usage examples
- Error Handling - Error codes and troubleshooting
- Webhook System - Webhook configuration and tunnel management
๐๏ธ Development
Available Scripts
npm run build # Compile TypeScript to JavaScript
npm run dev # Run development server with hot reload
npm start # Start production server
npm test # Run test suite
npm run test:watch # Run tests in watch mode
npm run lint # Run ESLint
npm run format # Format code with Prettier
Architecture
โโโโโโโโโโโโโโโโโโโ
โ MCP Tools โ โ 8 tools: 5 payment + 3 webhook
โ (src/tools/) โ
โโโโโโโโโโโโโโโโโโโค
โ Services โ โ Business logic: PaymentService, CurrencyService
โ (src/services/) โ
โโโโโโโโโโโโโโโโโโโค
โ API Client โ โ Bitnovo API integration with retry logic
โ (src/api/) โ
โโโโโโโโโโโโโโโโโโโค
โ Webhook Server โ โ HTTP Express + Event Store + Tunnel Manager
โ (src/webhook-*) โ
โโโโโโโโโโโโโโโโโโโค
โ Utilities โ โ Logging, validation, error handling, crypto
โ (src/utils/) โ
โโโโโโโโโโโโโโโโโโโ
Dual-Server Architecture
The MCP server can run two servers simultaneously:
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ MCP Bitnovo Pay Server โ
โ โ
โ โโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโ
โ โ MCP Server โ โ Webhook Server โ โ Tunnel โโ
โ โ (stdio) โ โ (HTTP :3000) โ โ Manager โโ
โ โโโโโโโโฌโโโโโโโโ โโโโโโโโโโฌโโโโโโโโโโ โโโโโโโโฌโโโโโโโ
โ โ โ โ โ
โ โ Event Store โ Public URL โ โ
โ โ (in-memory) โ (ngrok/zrok) โ โ
โ โโโโโโโโโโโโฌโโโโโโโโโดโโโโโโโโโโโฌโโโโโโโโโ โ
โโโโโโโโโโโโโโโโโโโโโโผโโโโโโโโโโโโโโโโโโโโผโโโโโโโโโโโโโโโโ
โ โ
โโโโโโโโโโดโโโโโโโโโ โโโโโโโโโดโโโโโโโโโ
โ โ โ โ
Claude Desktop Bitnovo API Tunnel Provider
(MCP Tools) (Webhooks) (ngrok/zrok/manual)
๐ Security
- HTTPS Only - All API calls use HTTPS
- HMAC Validation - Webhook signature verification with SHA-256
- Replay Attack Prevention - Nonce caching with 5-minute TTL
- Data Privacy - Sensitive information is masked in logs
- No Rate Data - Exchange rates not exposed to prevent inaccuracies
- Stateless Design - No local persistence, real-time API queries
- Auto-reconnection - Exponential backoff up to 10 retries for tunnels
- Health Monitoring - Connection verification every 60 seconds
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ค Contributing
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
๐ Support
- Issues: GitHub Issues
- Bitnovo Support: https://www.bitnovo.com/
- MCP Protocol: https://modelcontextprotocol.io/
๐ Related
- Model Context Protocol - Official MCP specification
- Bitnovo Pay - Cryptocurrency payment platform
- Bitnovo Pay - Documentation - Bitnovo Pay Official Documentation
- Bitnovo Pay - Documenciรณn en Espaรฑol - Bitnovo Pay Documentaciรณn Oficial
- MCP SDK - Official MCP SDK for TypeScript
Related Servers
Asset Price MCP Server
Provides real-time prices for assets like precious metals and cryptocurrencies.
Euroleague Live
Provides club information and advanced player statistics for Euroleague and Eurocup basketball from the Euroleague API.
Healthcare RAG
A healthcare-focused RAG server using Groq API and Chroma for information retrieval from patient records.
Weather MCP
An API for AI models to fetch weather data.
Swift Tarot
Provides tarot card readings, including single card draws, multi-card spreads, and full deck access.
Fewsats
Enable AI Agents to purchase anything in a secure way using Fewsats
Sherlock Domains
A server to buy and manage domains with Sherlock.
UU่ท่ ฟ MCP Server
Create orders on the uupt.com open platform using the MCP protocol.
Kite Trading
A server for performing trading operations using the Kite Connect API.
MCP Claude Spotify
An integration for Claude Desktop to interact with Spotify using the Model Context Protocol (MCP).