npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@paystack/mcp-server

v0.0.3

Published

Model Context Protocol (MCP) server for Paystack API integration

Downloads

239

Readme

Paystack MCP Server

A Model Context Protocol (MCP) server that enables AI assistants to interact with the full range of Paystack APIs.

[!WARNING] Public Preview: This MCP server is currently in public preview. We're seeking early feedback to improve the next iteration, so use cautiously and report any issues you encounter.

Quick Start

Install and run via npm (recommended):

npx @paystack/mcp-server --api-key sk_test_your_key_here

Or for local development, clone and build:

git clone https://github.com/PaystackOSS/paystack-mcp-server.git
cd paystack-mcp-server
npm install
npm run build

Then configure your MCP client to use the server (see Client Integration).

Requirements

  • Node.js v18+
  • npm or yarn
  • A Paystack test secret key (starts with sk_test_)

Configuration Options

| Environment Variable | Purpose | | -------------------------- | ------------------------------------------------------ | | PAYSTACK_TEST_SECRET_KEY | Your Paystack test secret key (fallback if no CLI arg) |

You can provide your API key in two ways:

  1. CLI argument (recommended): --api-key sk_test_...
  2. Environment variable: Set PAYSTACK_TEST_SECRET_KEY

Security note: Only test keys (sk_test_*) are allowed. The server validates this at startup and will reject live keys.

Client Integration

The Paystack MCP Server works with any MCP-compatible client. Below is the standard configuration schema used by most clients (Claude Desktop, ChatGPT Desktop, Cursor, Windsurf, etc.).

Using npm (recommended)

For npm-installed server:

{
  "mcpServers": {
    "paystack": {
      "command": "npx",
      "args": ["@paystack/mcp-server", "--api-key", "sk_test_..."]
    }
  }
}

Using a local build

If you've cloned and built the server locally:

{
  "mcpServers": {
    "paystack": {
      "command": "node",
      "args": ["/path/to/paystack-mcp-server/build/index.js"],
      "env": {
        "PAYSTACK_TEST_SECRET_KEY": "sk_test_..."
      }
    }
  }
}

[!IMPORTANT] When setting command: "node", you should ensure you're using Node v18+. If you are using a package manager, you might need to get the path of your Node binary by running this command in your CLI:

Linux and MacOS

which node

Windows

where node

Once you have the path, use it as the value of the MCP Server command in the JSON configuration. e.g., command: "path/to/installation/bin/node"

Where to add this configuration

| Client | Config file location | | --------------- | ------------------------------------------------- | | VS Code | .vscode/mcp.json | | Claude Desktop | claude_desktop_config.json | | ChatGPT Desktop | MCP settings in app preferences | | Cursor | .cursor/mcp.json or global MCP settings | | Windsurf | MCP configuration in settings | | Claude Code | ~/.claude/mcp.json or project-level .mcp.json |

How It Works

The Paystack MCP Server exposes the entire Paystack API to AI assistants by parsing Paystack's OpenAPI specification at runtime. Instead of hardcoding individual endpoints, the server dynamically discovers all available operations and makes them accessible through a small set of tools.

Available Tools

| Tool | Description | | ------------------------ | ------------------------------------------------------------------ | | get_paystack_operation | Fetch operation details (method, path, parameters) by operation ID | | make_paystack_request | Execute a Paystack API request |

Available Resources

| Resource | URI | Description | | ------------------------- | ---------------------------- | -------------------------------------------------------- | | paystack_operation_list | paystack://operations/list | List all available Paystack operations and their details |

Example

When you ask your AI assistant something like "Get me the last 5 transactions on my Paystack integration", here's what happens behind the scenes:

  1. The assistant calls get_paystack_operation("transaction_list") to look up the endpoint details
  2. It gets back the method (GET), path (/transaction), and available query parameters
  3. It then calls make_paystack_request with { method: "GET", path: "/transaction", data: { perPage: 5 } }
  4. You get your transactions

Prompt recommendation

To get the best results when using this MCP server, be specific in your prompts and always include "Paystack" in your requests. This helps the LLM quickly identify and use the appropriate Paystack tools.

Good prompts:

  • "Initialize a Paystack transaction for 50000 NGN"
  • "Create a customer with email [email protected] on my Paystack account"
  • "How can I send money with the Paystack API?"

Less effective prompts:

  • "List my transactions" (unclear which service to use)
  • "Charge a customer" (missing context about Paystack)

Being explicit ensures the LLM narrows down to the right tool quickly and reduces ambiguity.

Development

Run locally (without building)

For local development and testing, you can run the TypeScript source directly:

PAYSTACK_TEST_SECRET_KEY=sk_test_... npm run dev

Run with MCP Inspector

npm run inspect

Build

npm run build

Run tests

npm test

Troubleshooting

| Issue | Solution | | -------------------------------- | ------------------------------------------------------------------ | | Server exits silently at startup | Check that PAYSTACK_TEST_SECRET_KEY is set | | "Invalid key" error | Key must start with sk_test_ — live keys are not allowed | | Tools not appearing in client | Ensure the server is running and the client config path is correct | | Request timeouts | Check network connectivity to api.paystack.co |

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

See CONTRIBUTING.md for more details.

License

MIT