mono-mcp

sin4ch/mono-mcp

3.5

If you are the rightful owner of mono-mcp 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 Mono Banking MCP Server is a comprehensive Model Context Protocol server designed for Nigerian banking operations, utilizing the Mono Open Banking API.

Tools
9
Resources
0
Prompts
0

Mono Banking MCP Server

Try on FastMCP Cloud

A comprehensive Model Context Protocol (MCP) server for Nigerian banking operations using the Mono Open Banking API. Features integrated webhook support for real-time banking events and seamless deployment on FastMCP Cloud.

Table of Contents

Key Features

  • Complete Banking Operations - Account management, payments, BVN verification
  • Real-time Webhooks - Integrated webhook endpoints for live banking events
  • AI Assistant Ready - Seamless integration with Claude, ChatGPT, and other AI assistants
  • Cloud Deployment - Ready for FastMCP Cloud with automatic scaling
  • Enterprise Security - HMAC signature verification and secure API handling
  • Event Monitoring - Built-in webhook event storage and debugging tools

Architecture

sequenceDiagram
    participant User as šŸ‘¤ User
    participant AI as šŸ¤– AI Assistant<br/>(Claude/ChatGPT)
    participant MCP as ⚔ MCP Server<br/>(FastMCP + Webhooks)
    participant Client as šŸ”— Mono Client<br/>(httpx)
    participant API as šŸ¦ Mono API<br/>(Nigerian Banks)
    participant Webhook as šŸ“” Webhook Events

    User->>AI: "Check my account balance"
    AI->>MCP: list_tools()
    MCP-->>AI: 12 banking tools + webhook monitoring

    AI->>MCP: get_account_balance(account_id)
    MCP->>Client: get_account_balance(account_id)
    Client->>API: GET /accounts/{id}/balance
    API-->>Client: {"balance": 50000, "currency": "NGN"}
    Client-->>MCP: Account balance data
    MCP-->>AI: {"success": true, "balance": "₦500.00"}
    AI-->>User: "Your account balance is ₦500.00"

    Note over Webhook,MCP: Real-time Events
    API->>MCP: POST /mono/webhook (account.updated)
    MCP->>MCP: Verify HMAC signature
    MCP->>MCP: Store event in database

Technologies Used

  • Python 3.12+ - Modern Python with async/await support
  • FastMCP 2.12+ - Simplified MCP server with custom route support
  • Starlette - ASGI framework for webhook endpoints
  • httpx - Modern async HTTP client for API communication
  • SQLAlchemy - Database ORM for webhook event storage
  • Mono Open Banking API v2 - Nigerian banking infrastructure
  • python-dotenv - Environment variable management
  • uv - Fast Python package manager (recommended)

Project Structure

mono-banking-mcp/
ā”œā”€ā”€ mono_banking_mcp/           # Main package
│   ā”œā”€ā”€ server.py                 # FastMCP server with 12 tools + webhook endpoints
│   ā”œā”€ā”€ mono_client.py            # Mono API client with async httpx
│   └── database.py               # SQLAlchemy database for webhook events storage
ā”œā”€ā”€ tests/                     # Comprehensive test suite with webhook integration tests
│   ā”œā”€ā”€ conftest.py               # Test configuration and fixtures
│   └── test_mono_banking.py      # Unit and integration tests
ā”œā”€ā”€ pyproject.toml            # Modern Python project configuration (uv-based)
ā”œā”€ā”€ uv.lock                   # Dependency lock file with FastMCP 2.12+
ā”œā”€ā”€ pytest.ini               # Test configuration and markers
ā”œā”€ā”€ Makefile                  # Development workflow automation with webhook commands
ā”œā”€ā”€ README.md                 # This comprehensive documentation
└── .env.example              # Environment variables template

Webhook Integration

Real-time Event Processing

The server includes integrated webhook support for real-time banking events:

graph LR
    A[Mono API] -->|POST /mono/webhook| B[FastMCP Server]
    B -->|HMAC Verify| C[Signature Check]
    C -->|āœ… Valid| D[Store Event]
    C -->|āŒ Invalid| E[Reject]
    D --> F[SQLite Database]
    F --> G[get_webhook_events Tool]
    G --> H[AI Assistant]

Key Integration Points

  • /mono/webhook - Webhook endpoint for real-time Mono events
  • /health - Health check endpoint for monitoring

Supported Webhook Events

  • account.connected - New account linked
  • account.updated - Account information changed
  • account.unlinked - Account disconnected
  • job.completed - Data sync completed
  • job.failed - Data sync failed

Security Features

  • HMAC-SHA256 Signature Verification - Ensures webhook authenticity
  • Environment-based Secrets - Secure credential management
  • Request Validation - Malformed request rejection
  • Event Storage - Audit trail for all webhook events

Quick Start

Ready to use immediately! Connect your AI assistant to:

Try on FastMCP Cloud

https://mono-banking-mcp.fastmcp.app/mcp

Available Endpoints

  • MCP Server: https://mono-banking-mcp.fastmcp.app/mcp
  • Webhook Endpoint: https://mono-banking-mcp.fastmcp.app/mono/webhook
  • Health Check: https://mono-banking-mcp.fastmcp.app/health

Usage

Claude Desktop Integration

Add to your Claude Desktop configuration (~/.config/claude-desktop/config.json):

{
  "mcpServers": {
    "mono-banking": {
      "command": "npx",
      "args": ["-y", "@modelcontextprotocol/server-fetch", "https://mono-banking-mcp.fastmcp.app/mcp"]
    }
  }
}

Usage Examples

Once connected to an AI assistant (Claude, Gemini, etc.), you can use natural language commands:

Account Management
  • "List all my linked bank accounts"
  • "Show me the balance for account abc123"
  • "Get detailed information for my GTBank account"
  • "Show me the last 20 transactions for account xyz789"
Payment Operations
  • "Verify the account name for 0123456789 at GTBank (code 058)"
  • "Initiate a payment of ₦5000 to account 1234567890 at Access Bank for John Doe"
  • "Check the status of payment reference PAY_ABC123"
Banking Information
  • "Show me all supported Nigerian banks and their codes"
  • "Look up BVN 12345678901 for identity verification"
  • "Help a new customer link their bank account"
Complete Workflow Example
  1. "Show me all Nigerian banks" - Get bank codes
  2. "Verify account 1234567890 at Access Bank" - Confirm recipient
  3. "Initiate payment of ₦10000 to verified account for rent payment" - Start payment
  4. "Check payment status for the reference you just gave me" - Verify completion

Available Banking Tools

The server provides these comprehensive banking tools (12 total):

Core Banking Operations

ToolDescriptionParameters
list_linked_accountsList all linked bank accountsNone
get_account_balanceGet current account balanceaccount_id
get_account_infoGet basic account informationaccount_id
get_account_detailsGet comprehensive account details including BVNaccount_id
get_transaction_historyRetrieve transaction records with paginationaccount_id, limit, page
verify_account_nameVerify recipient account details before paymentsaccount_number, bank_code
initiate_paymentStart a payment via Mono DirectPayamount, recipient_account_number, recipient_bank_code, customer info
verify_paymentCheck payment status using referencereference
get_nigerian_banksList all supported Nigerian banks with codesNone
lookup_bvnPerform BVN identity verificationbvn, scope
initiate_account_linkingStart account linking process for new customerscustomer_name, customer_email

Contributing

Contributions to the Mono Banking MCP Server are welcome! For questions or help getting started, please open an issue.

Development Workflow

Quick Start for Contributors:

# Fork and clone the repository
git clone https://github.com/YOUR_USERNAME/mono-banking-mcp.git
cd mono-banking-mcp

# Set up development environment
uv sync
uv pip install -e .

# Verify installation with webhook support
python -c "from mono_banking_mcp.server import mcp; print('āœ… Package installed successfully')"

# Run comprehensive tests
make test-all

# Create feature branch and start developing
git checkout -b feature/your-feature-name

# Test your changes
make test-webhook  # Test webhook functionality
make tools         # Verify all 12 tools are working