Skip to main content
Glama
motok2031
by motok2031

x402-mcp-payment

This is an example project combining MCP (Model Context Protocol) and the x402 payment protocol. It demonstrates how to enable LLMs (such as ChatGPT, Claude) to access paid resources via the MCP protocol. After a user completes payment in the chat using a universal crypto wallet (supporting x402), the LLM can automatically retrieve and process the paid content.

Core Functionality: Empowering AI Agents with the ability to "pay for information".

User Interaction Flow

  1. Service Request: The user requests a paid service in ChatGPT (e.g., "Give me a riddle").

  2. Order Generation: The MCP Server generates a dynamic x402 payment link containing a unique payid and returns it to the user.

  3. User Payment: The user clicks the link and pays the specified amount using a universal crypto wallet.

  4. Status Recording: The x402 Server confirms the payment success and records the payid as "paid".

  5. Service Delivery: The user continues the conversation in ChatGPT (e.g., "I have paid"), and the AI automatically verifies the payment status and retrieves the service content.

Interaction Diagram

sequenceDiagram
    participant User as User
    participant AI as ChatGPT (LLM)
    participant MCP as MCP Server
    participant x402 as x402 Payment Server
    participant Wallet as Crypto Wallet

    User->>AI: Request paid service
    AI->>MCP: Call get_riddle
    MCP->>MCP: Generate payid
    MCP-->>AI: Return payment link (with payid)
    AI-->>User: Show payment link
    User->>x402: Click link to payment page
    x402->>Wallet: Initiate payment request
    Wallet->>x402: Confirm payment
    x402->>x402: Record payid as [Paid]
    x402-->>User: Show payment success
    User->>AI: I have finished payment
    AI->>MCP: Call get_answer (payid)
    MCP->>x402: Verify payid status
    x402-->>MCP: Verification passed (and clear status)
    MCP-->>AI: Return paid content (answer)
    AI-->>User: Provide service/answer

Prerequisites

  • Node.js (v18+)

  • Coinbase Developer Platform (CDP) API Key (for x402 payment verification)

Quick Start

1. Install Dependencies

npm install

2. Configure Environment Variables

Create a .env file in the project root directory and fill in your Coinbase API keys:

CDP_API_KEY_ID="your_cdp_key_id"
CDP_API_KEY_SECRET="your_cdp_key_secret"

3. Configuration File (Optional)

Modify config.yaml to customize server ports, payment address, price, and riddle content.

# x402 Payment Address (Your EVM wallet address)
payToAddress: "0x..."

# Payment Configuration
payment:
  price: "$0.01" # Price
  network: "base" # Network (base, polygon, ethereum, etc.)

4. Start Service

This project requires running two separate processes:

  1. MCP Server - Deployed at mcp.mydomain.com (port 3000)

  2. x402 Payment Server - Deployed at x402.mydomain.com (port 3001)

Development Mode (Supports hot reload):

# Terminal 1: Start MCP Server
npm run dev:mcp

# Terminal 2: Start x402 Payment Server
npm run dev:x402

Production Mode:

npm run build
npm run start:mcp
npm run start:x402

5. Configure ChatGPT

To use this service in ChatGPT:

  1. Open ChatGPT (web or app)

  2. Go to SettingsApp & Connectors (or similar MCP configuration section)

  3. Add a new MCP server: https://mcp.mydomain.com

  4. Now you can interact with paid riddles directly in ChatGPT!

Note: Currently requires a ChatGPT Pro, Plus, Team, or Education account to access MCP integration features.

-
security - not tested
F
license - not found
-
quality - not tested

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/motok2031/mcpx402chatgpt'

If you have feedback or need assistance with the MCP directory API, please join our Discord server