Provides comprehensive payment processing integration with payware APIs, enabling creation and management of EUR transactions, QR/barcode payment generation, transaction status monitoring, and callback handling for European payment systems
payware MCP Server
Minimal MCP server for payware API integration. Enables quick merchant integration with payware APIs in sandbox environment.
Features
🔐 Authentication Tools
RSA Key Generation: Generate secure 2048-bit RSA key pairs
JWT Token Creation: Create properly formatted JWT tokens
Sandbox Setup: Configure sandbox authentication
💳 Transaction Tools
Create Transaction: Support PLAIN, QR, and BARCODE transactions
Transaction Status: Check transaction status by ID
Callback Simulation: Test callback scenarios
🛠️ Utility Tools
Advanced Code Generation: Generate complete integration code across 8 languages (Python, Node.js, PHP, Java, C#, Go, Ruby, cURL) with 16+ framework support
Framework Integration: Framework-specific examples for Django, FastAPI, Express, NestJS, Laravel, Spring Boot, ASP.NET, and more
Real-world Scenarios: Generate complete integration scenarios (e-commerce, ISV multi-merchant, P2P payments)
Comprehensive Documentation: Auto-generate complete API documentation with code examples
Request Formatting: Format and validate API requests
Quick Start
1. Installation
2. Environment Configuration
Copy the example environment file and configure your credentials:
Edit .env file:
⚠️ Security Note: Never commit the .env file to version control. It contains sensitive credentials.
3. Start the MCP Server
4. Basic Integration Flow
Generate RSA Keys
Tool: payware_authentication_generate_rsa_keysCreate JWT Token
Tool: payware_authentication_create_jwt_token Parameters: - partnerId: (from PAYWARE_PARTNER_ID) - privateKey: (from environment-specific key path)Setup Sandbox
Tool: payware_authentication_setup_sandbox_auth Parameters: - partnerId: (from PAYWARE_PARTNER_ID)Create Transaction
Tool: payware_operations_create_transaction Parameters: - partnerId: (from PAYWARE_PARTNER_ID) - privateKey: (from environment-specific key path) - amount: 10.00 - currency: EUR - reasonL1: "Payment description" - type: PLAINCheck Status
Tool: payware_operations_get_transaction_status Parameters: - partnerId: (from PAYWARE_PARTNER_ID) - privateKey: (from environment-specific key path) - transactionId: TRANSACTION_ID
API Request Structure
The payware MCP server transforms flat parameter inputs into the proper nested JSON structure required by the payware API:
Create Transaction Request Structure
Parameter Mapping
When using MCP tools, parameters are automatically mapped to the correct API structure:
MCP Tool Parameter | API Location | Description |
,
| Authentication | Used for JWT signing, not sent in request |
,
,
,
,
| Root Level | Transaction metadata |
,
,
,
|
object | Core transaction data |
,
|
object | Transaction behavior |
,
, etc. |
object | QR code settings (when type=QR) |
,
, etc. |
object | Barcode settings (when type=BARCODE) |
Available Tools
Code Generation & Documentation
payware_generate_code_example
Advanced multi-language code generation with framework support
Supports 60+ operations across all partner types:
Transactions: create_transaction, get_transaction_status, cancel_transaction, process_transaction, get_transaction_history, simulate_callback
Products: create_product, get_product, update_product, delete_product, list_products, get_product_image, create_schedule, update_schedule, delete_schedule, list_schedules
OAuth2 (ISV only): obtain_token, get_token_info, create_token_simple, refresh_token, revoke_token, list_active_tokens
Data: generate_report, get_report_status, export_report, download_export, cancel_report, list_reports, get_analytics_summary, create_custom_report
Deep Links: get_transaction_link, get_product_link, create_custom_link, delete_transaction_link, delete_product_link, list_active_links, get_link_analytics, create_batch_links
P2P (Payment Institution): initiate_p2p_transfer, accept_p2p_transfer, reject_p2p_transfer, get_p2p_transfer_status, list_p2p_transfers, cancel_p2p_transfer, create_p2p_link, get_p2p_analytics
Soundbites (Payment Institution): register_audio, get_audio, update_audio, delete_audio, list_audios, create_soundbite_transaction, stream_audio, download_audio, get_soundbite_analytics, create_audio_playlist, get_audio_preview
payware_generate_documentation
Comprehensive documentation generator
Generates complete API documentation with working code examples for any partner type and programming language combination.
Authentication
payware_authentication_generate_rsa_keys
Generate RSA key pair for API authentication.
Parameters:
keySize(optional): RSA key size in bits (default: 2048)
payware_authentication_create_jwt_token
Create JWT token for API authentication.
Parameters:
partnerId(required): Partner ID from paywareprivateKey(required): RSA private key in PEM format
payware_authentication_validate_jwt
Validate JWT token format and signature.
Parameters:
token(required): JWT token to validatepartnerId(required): Partner ID for validation
payware_authentication_test_jwt
Test JWT token with payware API.
Parameters:
token(required): JWT token to testpartnerId(required): Partner ID
payware_authentication_setup_sandbox_auth
Setup sandbox authentication configuration.
Parameters:
partnerId(required): Partner ID from paywareprivateKey(optional): Private key for validation
Transactions
Transaction Status Overview
payware transactions can have the following statuses:
ACTIVE Status:
⏳ ACTIVE: Active transaction pending processing or finalizing
This is the only status returned by
payware_transactions_get_transaction_statusUse GET
/transactions/{id}endpoint
Final Statuses:
✅ CONFIRMED: Successfully finalized
❌ DECLINED: Declined by the user, processing or finalizing payment institutions
💥 FAILED: Failed due to technical reasons or other
⏰ EXPIRED: Time to live of the transaction has passed
🚫 CANCELLED: Transaction canceled by the originator
These final statuses are only available through payware_operations_get_transaction_history using GET /transactions-history/{id} endpoint.
payware_operations_create_transaction
Create a new transaction with full API structure support.
Key Parameters:
currency(required): ISO 3-character code (EUR, USD, GBP, etc.)reasonL1(required): Transaction description (max 100 chars)partnerId(required): Partner ID from payware dashboardprivateKey(required): RSA private key for JWT signingamount(optional): Currency value (default: "0.00" for flexible amounts)type(optional): PLAIN, QR, or BARCODE (default: PLAIN)timeToLive(optional): Payment timeout in seconds, 60-600 (default: 120)
QR Options (when type=QR):
qrFormat: PNG, SVG, JPG, GIF, BMP (default: SVG)qrErrorCorrection: LOW, MEDIUM, QUARTILE, HIGH (default: QUARTILE)qrScale,qrBorder,qrVersion: Size and appearance settings
Barcode Options (when type=BARCODE):
barFormat: PNG, SVG, JPG (default: SVG)barModuleWidth,barBarHeight,barFontSize: Size settings
payware_operations_get_transaction_status
Get status of ACTIVE transactions only. For completed/finalized transactions use history tool.
Parameters:
transactionId(required): Transaction ID (starts with 'pw')partnerId(required): Partner IDprivateKey(required): Private key for JWT signing
payware_operations_simulate_callback
Simulate callback scenarios for testing.
Parameters:
transactionId(required): Transaction IDstatus(optional): CONFIRMED, DECLINED, FAILED, EXPIRED, or CANCELLED (default: CONFIRMED)callbackUrl(optional): URL where callback would be sentamount(optional): Transaction amount (default: 10.00)currency(optional): Currency (default: EUR)type(optional): Transaction type (default: PLAIN)
Utilities
payware_generate_code_example
Generate production-ready code examples for any payware operation.
Parameters:
operation(required): Operation to generate - see complete list belowlanguage(optional): python, nodejs, php, java, csharp, curl (default: python)partner_type(optional): merchant, isv, payment_institution (default: merchant)include_comments(optional): Include detailed code comments (default: true)include_error_handling(optional): Include comprehensive error handling (default: true)
Available Operations by Category:
Authentication:
authentication- JWT authentication setup
Transaction Operations (all partner types):
create_transaction- Create a new payment transactionget_transaction_status- Get transaction status and detailsprocess_transaction- Process a pending transactioncancel_transaction- Cancel a pending transaction
Product Operations (merchant, isv):
create_product- Create a new productget_product- Get product detailslist_products- List all products
OAuth2 Operations (isv only):
obtain_token- Obtain OAuth2 access tokenget_token_info- Get OAuth2 token information
Data Operations (all partner types):
generate_report- Generate analytics reportget_report_status- Get report generation status
P2P Operations (payment_institution only):
initiate_p2p_transfer- Initiate peer-to-peer transferaccept_p2p_transfer- Accept P2P transfer
Deep Links (all partner types):
get_transaction_link- Get deep link for transaction
Soundbites (payment_institution only):
register_audio- Register audio content for soundbite transactions
payware_generate_documentation
Generate comprehensive API documentation with code examples.
Parameters:
language(optional): Target programming language (default: python)partnerType(optional): merchant, isv, payment_institution (default: merchant)includeScenarios(optional): Include real-world integration scenarios (default: true)outputFormat(optional): markdown, html, json (default: markdown)
payware_utils_format_request
Format and validate API requests with deterministic JSON serialization for MD5 consistency.
Parameters:
type(required): transaction, headers, or curldata(optional): Data to formatjwtToken(optional): JWT token for headerssignature(optional): Request signatureendpoint(optional): API endpoint for curlmethod(optional): HTTP method (default: POST)
payware_utils_format_json_deterministic
Format JSON with deterministic property ordering for consistent MD5 calculation.
Parameters:
data(required): Object to serializeminimize(optional): Remove whitespace (default: true)
payware_utils_server_info
Get MCP server information and configuration.
Note: All transaction data is serialized using consistent property ordering to prevent MD5 mismatch errors.
Dependencies
@modelcontextprotocol/sdk: MCP server frameworkaxios: HTTP client for API callsjsonwebtoken: JWT token creationnode-forge: RSA key generation
Environment
Sandbox Only: All API calls are restricted to sandbox environment
Base URL:
https://sandbox.payware.eu/api/v1Supported Currencies: EUR, USD, GBP
Supported Transaction Types: PLAIN, QR, BARCODE
Security
⚠️ Important Security Notes:
Environment Variables
REQUIRED: Use environment variables for all credentials
Never commit
.envfiles to version controlUse different credentials for development and production
Store private key files outside web-accessible directories
Private Key Security
Generate separate key pairs for sandbox and production
Store private keys with restricted file permissions (600)
Never embed private keys in source code
Rotate keys regularly according to security policies
API Security
This server is designed for sandbox testing only
Never use sandbox keys in production environment
Implement proper error handling in production
Use HTTPS for all API communications
Validate all input parameters
Implement rate limiting and monitoring
JSON Serialization & MD5 Consistency
⚠️ CRITICAL: payware API requires deterministic JSON serialization for MD5 calculation
Property Order: JSON objects must have consistent property ordering
Minimized Format: No whitespace or formatting in request bodies
MD5 Calculation: Must be calculated from the exact same JSON string sent to API
Implementation: This server uses deterministic JSON serialization to ensure consistency
Example of correct JSON format:
Why this matters:
Different property orders produce different MD5 hashes
MD5 mismatch results in
ContentMd5 mismatcherrorsServer validates that JWT contentMd5 matches request body MD5
Troubleshooting
Common Issues
Authentication Failed (ERR_INVALID_SIGNATURE)
Root Cause: Public key registered with payware doesn't match your private key
Solution: Ensure the public key registered on payware site corresponds to your private key
Verification: Use
openssl rsa -in privateKey.pem -puboutto extract public key from private keyStatus: ✅ Resolved - Keys must be properly registered on payware partner portal
ContentMd5 Mismatch Error
Root Cause: Inconsistent JSON property ordering
Solution: Use deterministic JSON serialization (implemented in this server)
Symptoms: Server logs show different expected vs actual MD5 hashes
Prevention: Always use
createMinimizedJSON()from/src/utils/json-serializer.jsStatus: ✅ Fixed - Deterministic JSON serialization implemented
Transaction Creation Failed
Ensure all required parameters are provided
Check amount is non-negative
Verify transaction type is supported
Status: ✅ Working - Create and cancel operations confirmed functional
MCP Connection Issues
Ensure server is started with
npm startCheck that MCP client is properly configured
Verify no firewall blocking stdio communication
Note: Use MCP Inspector (
npm run inspector) for debugging
Proxy and Bridge Tools
HTTP Proxy Server (npm run proxy):
Bridges MCP tools to HTTP REST API
Useful for testing tools via HTTP requests
Documentation:
README-proxy.md
MCP Bridge (npm run bridge):
Connects MCP server to MCP Inspector
Essential for debugging and development
Use with:
npm run inspector
Testing Status
✅ Confirmed Working Operations:
JWT token creation with RS256 algorithm
Transaction creation (POST /api/transactions)
Transaction cancellation (PATCH /api/transactions/{id})
Deterministic JSON serialization for MD5 consistency
Public/private key pair validation
🧪 Test Results:
All MCP tools tested successfully with real payware sandbox API
Both create and cancel transaction flows working end-to-end
Signature validation resolved with proper key registration
Support
For issues related to:
MCP Server: Check server logs and MCP client configuration
payware API: Refer to payware documentation and sandbox status
Integration: Use code examples and formatting tools provided
Key Issues: Ensure public key is registered on payware partner portal
License
MIT License
This server cannot be installed
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Enables merchant integration with payware payment APIs for creating transactions, managing authentication, and generating code examples across multiple programming languages. Provides comprehensive tools for payment processing, JWT authentication, and sandbox testing.