quanta-x402-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@quanta-x402-mcplist available assets"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Quanta
Pay-per-call structured data for autonomous AI agents. x402-metered, MCP-native.
A small, real reference service: a FastAPI API serves a structured dataset, every data call is metered by the x402 protocol (a USDC micropayment on Base or Solana), and the same data is exposed as MCP tools so an agent can discover and call it natively. Backed by Postgres/Supabase (SQLite locally).
This is a working slice of the agent-commerce stack: agent -> MCP tool -> x402 paywall -> data.
Why it exists
It's the exact shape of the systems I build for: a live API that sells structured data to autonomous agents, monetized per call, with an MCP front door. It runs the real protocols (official x402 SDK + official MCP SDK), not a mock.
Related MCP server: aipaygen-mcp
Architecture
┌──────────────────────────────────────────┐
AI agent ───────▶ │ MCP tools (FastMCP) /mcp │
(Claude, etc.) │ list_assets · get_asset · get_signal │
└───────────────┬──────────────────────────┘
│ same data layer
HTTP client ─────▶ ┌──────────────▼──────────────────────────┐
(curl, SDK) │ FastAPI /v1/* ── x402 middleware ────┤
│ 402 challenge ▶ verify ▶ settle ▶ data │
└───────────────┬──────────────────────────┘
│
┌───────────────▼──────────────┐ ┌──────────────────┐
│ data.py (single source) │ │ x402 facilitator │
│ assets + usage_log │ │ verify + settle │
└───────────────┬──────────────┘ │ Base / Solana │
│ └──────────────────┘
┌───────────────▼──────────────┐
│ Postgres / Supabase (SQLite) │
└───────────────────────────────┘The x402 request loop
Agent calls a
/v1/*route with no payment.Server replies
402 Payment Required+ the accepted rails (USDC on Base Sepolia and Solana devnet), price, and pay-to address.Agent signs a payment and retries with an
X-PAYMENTproof.The facilitator verifies + settles on-chain; the server returns the data and writes a row to
usage_log(who paid, which chain, which record).
Metering is a feature flag. If the x402 wheel isn't present (local dev on an unsupported Python), the app logs a warning and serves unmetered so you can still work on everything else. It never fails to boot.
Layout
app/
main.py FastAPI app, /v1/* data routes, x402 wired in
x402_setup.py multi-chain (EVM + Solana) metering, import-safe
data.py seed data + shared queries + usage log (one source of truth)
models.py Asset + UsageLog (SQLAlchemy 2.0 async)
db.py async engine; DATABASE_URL swaps SQLite <-> Supabase
config.py typed settings
mcp_server/
server.py FastMCP tools (x402-gated per tool), stdio or HTTP
client/
pay_and_fetch.py agent demo: unpaid -> 402, then paid -> data
scripts/seed.py create tables + load sample data
tests/test_api.py
Dockerfile · railway.jsonRun it locally
python3.12 -m venv .venv && source .venv/bin/activate
pip install -r requirements.txt
cp .env.example .env # defaults to SQLite + testnet
python -m scripts.seed
uvicorn app.main:app --port 4021Prove the metering is live:
curl -i http://localhost:4021/v1/assets/BTC # -> 402 Payment Required + rails
curl http://localhost:4021/internal/usage # -> audit trail (free)
python -m client.pay_and_fetch # unpaid 402, then paid loopMCP (stdio, for Claude Desktop / MCP Inspector):
python -m mcp_server.serverDeploy
Railway / Cloud Run / Render: Docker build (Python 3.12).
railway.jsonis included; health check is/health.Database: set
DATABASE_URLto your Supabase Postgres string (postgresql+asyncpg://...).Payments: testnet works with the public
x402.orgfacilitator and no keys. For mainnet settlement, setCDP_API_KEY_ID/CDP_API_KEY_SECRET(Coinbase CDP) and switch the network.
Honest scope
The dataset is a clearly-labelled sample snapshot, not a live market feed - enough to prove the pay-per-call mechanics end to end.
Settlement runs on testnet (Base Sepolia / Solana devnet). Flipping to mainnet is config, not code.
The full paid loop in
client/pay_and_fetch.pyneeds a funded test wallet; the unpaid402proves the contract without one.
Stack
FastAPI · SQLAlchemy 2.0 (async) · Postgres/Supabase · official x402 SDK (EVM + SVM) · official MCP SDK (FastMCP) · Docker.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/themeknock/quanta-x402-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server