WariMCP

WariMCP

A unified MCP server for West African payment providers, enabling AI agents and REST clients to initiate payments, payouts, refunds, and manage webhooks across 10 providers with a single API.

Category
Visit Server

README

WariMCP

WariMCP is an MCP (Model Context Protocol) server that gives AI agents and REST clients a unified interface to West African payment providers. It exposes 10 providers through a single API — payments, payouts, refunds, webhooks — with FedaPay as the recommended primary and Hub2 as the recommended secondary. Runs as an MCP stdio server (for Claude/Cursor/Windsurf), an Express HTTP API, or both simultaneously.

Quick Start

git clone https://github.com/Bigabou007-dev/warimcp.git
cd warimcp
npm install
cp .env.example .env   # edit with your credentials
npm run db:migrate      # set up PostgreSQL schema
npm run db:seed-api-key # generate your first API key
npm run dev             # starts MCP + HTTP on port 3000

Requires Node >= 22 and PostgreSQL 16+.

Providers

10 providers are available in the codebase. The recommended production setup is FedaPay + Hub2.

Provider Key Region Methods Currencies Status
FedaPay fedapay CI, SN, BJ, TG, BF, ML, NE, GW MTN, Orange, Moov, Wave, Card XOF, XAF, GNF Recommended Primary — live keys, true aggregator
Hub2 hub2 CI, SN, ML, BF, TG, BJ, NE, CM Mobile Money XOF, XAF Recommended Secondary — pending sandbox access
CinetPay cinetpay CI, SN, ML, BF, TG, BJ + 6 more Mobile Money, Card, Wallet XOF, XAF, CDF, GNF Requires RCCM
Wave wave CI, SN, ML, BF, UG, TZ Wave wallet XOF Requires RCCM
Flutterwave flutterwave CI, SN, NG, GH, KE + 4 more Mobile Money, Card, Bank XOF, XAF, NGN, GHS, KES, USD, EUR Available
KKiaPay kkiapay CI, SN, BJ, BF, ML, TG, NE, GW MTN, Orange, Wave, Card XOF, XAF Available
Moneroo moneroo CI, SN, BJ, BF + 10 more MTN, Orange, Wave, Moov, Card, Bank XOF, XAF, GNF, CDF, NGN, GHS, KES, USD, EUR Available
MTN MoMo mtn CI, GH, UG, RW, BJ, CM, CG MTN Mobile Money EUR Available
PAPSS papss CI, KE, NG, GH Bank Transfer XOF, KES, NGN, GHS Future
Mock mock All All All Testing only

Set WARIMCP_MODE=mock to route all providers through the mock provider (no API keys needed).

API Endpoints

All payment/payout endpoints require an X-Api-Key header. Generate keys with npm run db:seed-api-key.

Method Path Auth Description
GET /health No Health check
GET /api/v1/providers No List all providers and their config status
POST /api/v1/payments/initiate Yes Initiate a payment (returns checkout URL)
GET /api/v1/payments/:id Yes Verify payment status
POST /api/v1/payments/:id/refund Yes Full or partial refund
GET /api/v1/payments Yes List transactions (filterable by provider, status)
POST /api/v1/payment-links Yes Generate a shareable payment link
POST /api/v1/payouts/initiate Yes Disburse to mobile money or bank
GET /api/v1/payouts/:id Yes Verify payout status
POST /api/v1/webhooks/:provider No Inbound webhook receiver (signature-verified)

MCP Tools

When registered as an MCP server, WariMCP exposes these tools to AI agents:

Tool Description
list_providers List all providers, their config status, and supported rails
initiate_payment Start a payment via any provider — returns a checkout URL
verify_payment Check the status of a payment by transaction ID
refund_payment Issue a full or partial refund
list_transactions List recent transactions with provider/status filters
generate_payment_link Create a shareable payment link
initiate_payout Disburse funds to a mobile money wallet or bank account
verify_payout Check the status of a payout

MCP Registration

{
  "mcpServers": {
    "warimcp": {
      "command": "node",
      "args": ["/path/to/warimcp/dist/index.js"],
      "env": {
        "WARIMCP_TRANSPORT": "stdio",
        "DATABASE_URL": "postgresql://warimcp:yourpass@localhost:5432/warimcp",
        "FEDAPAY_SECRET_KEY": "sk_live_..."
      }
    }
  }
}

Security

  • Helmet with Content-Security-Policy (default-src 'self', no inline scripts)
  • Timing-safe HMAC verification for CinetPay and Wave webhooks (crypto.timingSafeEqual)
  • HMAC-SHA256 signed webhook relay — outbound relays include X-WariMCP-Signature header
  • API key auth with SHA-256 hashed storage, per-key permissions, and per-key rate limits
  • Token bucket rate limiting — 60 req/min default per API key
  • Error sanitization — provider errors are caught and rewritten; internal details never leak to clients
  • Non-root Docker user — container runs as dedicated warimcp user (UID 1001)
  • Zod validation on all inputs with strict schemas (amount bounds, phone format, UUID checks)

No Custody (Bring Your Own Keys)

WariMCP holds no funds and ships no credentials. It only instructs licensed payment service providers; money settles directly into the account that the keys belong to — never an intermediary account. Each operator runs their own instance with their own PSP credentials and is the merchant of record, responsible for their own licensing and regulatory compliance.

An earlier "manual payment collection" feature (which routed funds into a personal mobile-money account with SMS reconciliation) was removed in 2026-06 as incompatible with this no-custody posture. Do not reintroduce custody of third-party funds.

Configuration

All configuration is via environment variables (see .env.example):

# Mode: mock | sandbox | live
WARIMCP_MODE=mock

# Transport: stdio | http | both
WARIMCP_TRANSPORT=both
WARIMCP_PORT=3000

# Database
DATABASE_URL=postgresql://warimcp:changeme@localhost:5432/warimcp

# Primary — FedaPay
FEDAPAY_SECRET_KEY=
FEDAPAY_PUBLIC_KEY=

# Secondary — Hub2
HUB2_API_KEY=

# Other providers (configure as needed)
CINETPAY_API_KEY=
CINETPAY_SITE_ID=
WAVE_API_KEY=
WAVE_WEBHOOK_SECRET=
FLUTTERWAVE_SECRET_KEY=
FLUTTERWAVE_PUBLIC_KEY=
KKIAPAY_PUBLIC_KEY=
KKIAPAY_PRIVATE_KEY=
KKIAPAY_SECRET=
MONEROO_SECRET_KEY=
MTN_MOMO_COLLECTION_SUBSCRIPTION_KEY=
MTN_MOMO_API_USER=
MTN_MOMO_API_KEY=
MTN_MOMO_ENVIRONMENT=sandbox
MTN_MOMO_CALLBACK_URL=
PAPSS_API_KEY=

# Webhooks
WARIMCP_WEBHOOK_BASE_URL=
WARIMCP_RELAY_SECRET=

Docker Deployment

# Set DB_PASSWORD in .env, then:
docker compose up -d

Runs two containers on the npm_proxy network:

  • warimcp — Node 22 Alpine, non-root, 512 MB limit, health-checked at /health
  • warimcp_db — PostgreSQL 16 Alpine, 256 MB limit, persistent volume

The HTTP transport is used in Docker (WARIMCP_TRANSPORT=http). For MCP stdio access, run the server directly with node dist/index.js.

Roadmap

Phase 1 (current): FedaPay as primary aggregator + Hub2 as secondary. All 10 provider adapters implemented. No-custody, bring-your-own-keys posture.

Phase 2: CinetPay + Wave activation once RCCM is filed. Full webhook verification for all active providers. Automatic provider fallback (FedaPay -> Hub2 -> CinetPay).

Phase 3: PAPSS pan-African corridor (CI to KE/NG/GH). Multi-currency settlement. Bulk payouts.

License

MIT

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured