Server data from the Official MCP Registry
Pay for AI inference with USDC micropayments on Polygon. No API keys needed.
Pay for AI inference with USDC micropayments on Polygon. No API keys needed.
Valid MCP server (2 strong, 4 medium validity signals). 4 known CVEs in dependencies (0 critical, 3 high severity) Package registry verified. Imported from the Official MCP Registry.
11 files analyzed · 5 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: DRAIN_PRIVATE_KEY
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-kimbo128-drain-mcp": {
"env": {
"DRAIN_PRIVATE_KEY": "your-drain-private-key-here"
},
"args": [
"-y",
"drain-mcp"
],
"command": "npx"
}
}
}From the project's GitHub README.
Decentralized Runtime for AI Networks
An open protocol for trustless, streaming micropayments between AI consumers and providers.
ERC-8190: This protocol is being formalized as an Ethereum standard — Payment Channels with Signed Vouchers. The ERC defines the minimal interface for unidirectional payment channels using EIP-712 signed vouchers, complementary to ERC-8183 (Agentic Commerce).
╔══════════════════════════════════════════════════════════════════════════════╗
║ 1000 AI REQUESTS ║
╠══════════════════════════════════════════════════════════════════════════════╣
║ ║
║ DRAIN │ Per-Request Payments (x402, etc.) ║
║ ───── │ ──────────────────────────────── ║
║ 2 transactions │ 1000 transactions ║
║ ~$0.04 gas │ ~$20+ gas ║
║ 0ms latency │ 2-5 sec per request ║
║ 1 wallet popup │ 1000 wallet popups (or API key) ║
║ ║
╚══════════════════════════════════════════════════════════════════════════════╝
| 🏦 2 On-Chain TXs | ⚡ Zero Latency | 💸 ~$0.04 Total Gas | 🔐 No API Keys |
|---|---|---|---|
| Open + Close only | Off-chain vouchers | 500x cheaper at scale | Cryptographic auth |
Existing decentralized AI protocols require holding volatile tokens, creating speculation dynamics that overwhelm utility. Meanwhile, 78% of the world lacks credit cards, and AI agents can't have bank accounts.
DRAIN fills this gap: stablecoin micropayments without tokens, complexity, or intermediaries.
| Problem | DRAIN Solution |
|---|---|
| Token volatility | USDC-only, predictable pricing |
| High fees | ~$0.02 per tx on Polygon (varies: $0.015-0.025) |
| AI agents can't pay | First-class programmatic support |
| Credit card barriers | Permissionless crypto access |
DRAIN enables permissionless, pay-per-token AI inference without intermediaries. Users open payment channels with USDC, stream requests to any compatible provider, and settle on-chain only when needed.
Core Principles:
DRAIN is like a prepaid card for AI: deposit USDC, use it across requests, withdraw the remainder.
┌──────────────────────────────────────────────────────────────────┐
│ Off-Chain (Fast & Free) │
│ │
│ Consumer Provider │
│ │ │ │
│ │───────── Request + Voucher ────────────────►│ │
│ │◄──────── AI Response ───────────────────────│ │
│ │───────── Request + Voucher ────────────────►│ │
│ │◄──────── AI Response ───────────────────────│ │
│ │ ... │ │
│ │
└────────┼─────────────────────────────────────────────┼───────────┘
│ │
│ On-Chain (Rare) │
▼ ▼
┌──────────────────────────────────────────────────────────────────┐
│ DRAIN Contract │
│ │
│ open(provider, amount, duration) → Lock USDC │
│ claim(channelId, amount, signature) → Pay provider │
│ close(channelId) → Refund remainder │
└──────────────────────────────────────────────────────────────────┘
| Role | What They Do | On-Chain Actions |
|---|---|---|
| Consumer | Pays for AI services | open (deposit), close (refund) |
| Provider | Delivers AI responses | claim (withdraw earnings) |
The consumer sets the channel duration when opening (e.g., 24h). But providers control their requirements:
| Provider Can... | How |
|---|---|
| Require minimum duration | Reject vouchers from channels < X hours |
| Recommend duration | Document in API: "We recommend 24h channels" |
| Claim anytime | No deadline until consumer calls close() |
Key insight: Even after channel expiry, the provider can claim as long as the consumer hasn't closed. The consumer must actively call close() – it's not automatic.
Each voucher contains the total amount spent, not the increment:
Request 1: voucher.amount = $0.10 (total spent so far)
Request 2: voucher.amount = $0.25 (total, not $0.15 increment)
Request 3: voucher.amount = $0.40 (total, not $0.15 increment)
Provider only needs to claim the last voucher to receive full payment.
| Asset | Network | Why |
|---|---|---|
| USDC | Polygon | Stable ($1), liquid ($500M+), low fees (~$0.02/tx, varies: $0.015-0.025) |
USDC on Polygon can be bridged from Ethereum, Base, Arbitrum via Circle CCTP.
The official DRAIN marketplace is Handshake58 - a provider directory where AI agents can discover and pay for AI inference.
| Link | Description |
|---|---|
| https://www.handshake58.com | Main marketplace |
| https://www.handshake58.com/for-agents | Quick start for AI agents |
| https://www.handshake58.com/api/mcp/providers | Provider discovery API |
Install the MCP Server and start using AI with crypto payments:
npm install -g drain-mcp
Configure in Claude Desktop or Cursor:
{
"mcpServers": {
"drain": {
"command": "drain-mcp",
"env": {
"DRAIN_PRIVATE_KEY": "your-polygon-wallet-key"
}
}
}
}
That's it! The MCP server auto-discovers providers from Handshake58.
| URL | Purpose |
|---|---|
/for-agents | Static, crawlable agent page |
/api/agent | Quick discovery JSON |
/llms.txt | 25-line agent instruction |
/skill.md | Full documentation (MCP first) |
DRAIN implements ERC-8190: Payment Channels with Signed Vouchers — an Ethereum standard for streaming micropayments via EIP-712 signed vouchers.
| Component | Description | Standard |
|---|---|---|
| Smart Contract | Escrow and settlement logic (IPaymentChannel) | ERC-8190 (normative) |
| Voucher Format | EIP-712 typed signatures for off-chain payments | ERC-8190 (normative) |
| Service Interaction | HTTP 402 discovery, cost reporting, error codes | ERC-8190 (RECOMMENDED) |
| API Standard | OpenAI-compatible interface with payment headers | Application layer |
The protocol intentionally excludes provider discovery, reputation systems, dispute resolution, and governance. See ERC-8183 (Agentic Commerce) and ERC-8004 (Trustless Agents) for complementary standards.
Full specification: See contracts/ for the Solidity implementation and the ERC-8190 draft for the formal standard.
| Party | Protected Against | How |
|---|---|---|
| Consumer | Overcharging | Only signs amounts they agree to |
| Consumer | Non-delivery | Stops signing, refunds after expiry |
| Provider | Overspending | amount ≤ deposit enforced on-chain |
| Provider | Double-spend | USDC locked in contract, not wallet |
EIP-712 signatures with chainId and verifyingContract prevent replay attacks. OpenZeppelin ECDSA provides malleability protection.
// EIP-712 typed data
struct Voucher {
bytes32 channelId;
uint256 amount; // Cumulative total spent
uint256 nonce; // Incrementing per voucher
}
Consumer signs vouchers off-chain. Provider submits latest voucher to claim payment.
| Role | Cost |
|---|---|
| Consumer | ~$0.02 open + provider rate + ~$0.02 close |
| Provider | ~$0.02 claim gas, keeps 100% of fees |
| Protocol | Zero fees |
Total overhead: <$0.05 per session regardless of usage.
Minimum Deposit Recommendations:
See Test Results for verified cost data.
| ❌ | Why |
|---|---|
| Token | No speculation, no governance drama |
| Marketplace | Discovery is separate, built on top |
| Reputation system | Out of scope, can be layered |
| Upgradeable | Immutable contracts, no admin keys |
drain/
├── contracts/ # Solidity smart contracts
│ ├── src/DrainChannel.sol # Core payment channel contract
│ ├── test/ # 47 Foundry tests
│ └── script/ # Deploy scripts
├── sdk/ # TypeScript SDK
│ ├── src/consumer.ts # Consumer: open, sign, close
│ └── src/provider.ts # Provider: verify, claim
├── provider/ # Reference AI Provider
│ ├── src/index.ts # Express server (OpenAI-compatible)
│ └── src/drain.ts # Voucher validation
├── mcp/ # MCP Server for AI Agents
│ ├── src/index.ts # MCP server entry point
│ └── src/tools/ # drain_chat, drain_balance, etc.
└── demo/ # AI-optimized examples
├── README.md # Quick start for AI agents
└── simple-demo.ts # Minimal code example
DRAIN includes an MCP (Model Context Protocol) server that enables AI agents to autonomously pay for AI services.
✅ Successfully tested with Claude Desktop - An AI agent autonomously opened a $0.10 channel and made AI inference requests, proving the agent-to-agent payment economy works without human intervention.
Test Results: $0.000005 per request, 20,000 requests possible with $0.10 channel. See Test Results and Comparison with Credit Cards for detailed metrics.
npm install -g drain-mcp
Configure in Cursor or Claude:
{
"mcpServers": {
"drain": {
"command": "npx",
"args": ["-y", "drain-mcp"],
"env": {
"DRAIN_PRIVATE_KEY": "0x..."
}
}
}
}
Available Tools:
| Tool | Description |
|---|---|
drain_providers | Discover AI providers |
drain_balance | Check wallet balance |
drain_open_channel | Open payment channel |
drain_chat | AI chat with payment |
drain_close_channel | Close channel, get refund |
See mcp/README.md for full documentation.
npm install @drain-protocol/sdk viem
import { createDrainConsumer, CHAIN_IDS } from '@drain-protocol/sdk';
// Open channel, sign vouchers, close when done
const consumer = createDrainConsumer(walletClient, account, {
chainId: CHAIN_IDS.POLYGON_MAINNET,
});
await consumer.approveUsdc('10');
const { channelId } = await consumer.openChannel({
provider: '0x...',
amount: '10',
duration: '24h',
});
const voucher = await consumer.signVoucher(channelId, '0.50');
// Send voucher to provider...
See sdk/README.md for full documentation.
OpenAI-compatible API server that accepts DRAIN payments.
🟢 Live Provider: https://drain-production-a9d4.up.railway.app/v1/pricing
| Model | Input/1K Tokens | Output/1K Tokens | ~Cost/Message |
|---|---|---|---|
| gpt-4o-mini | $0.000225 | $0.0009 | ~$0.001 ✨ |
| gpt-4o | $0.00375 | $0.015 | ~$0.01 |
| gpt-4-turbo | $0.015 | $0.045 | ~$0.03 |
| gpt-3.5-turbo | $0.00075 | $0.00225 | ~$0.002 |
Prices include 50% margin over OpenAI base rates
Run your own:
cd provider
cp env.example .env # Configure OPENAI_API_KEY, PROVIDER_PRIVATE_KEY
npm install
npm run dev
Endpoints:
GET /v1/pricing → View pricing per model
GET /v1/models → List available models
POST /v1/chat/completions → Chat (with X-DRAIN-Voucher header)
DRAIN Headers:
# Request
X-DRAIN-Voucher: {"channelId":"0x...","amount":"1000000","nonce":"1","signature":"0x..."}
# Response
X-DRAIN-Cost: 8250
X-DRAIN-Total: 158250
X-DRAIN-Remaining: 9841750
See provider/README.md for full documentation.
DRAIN is a permissionless protocol - anyone can be a provider. Multiple discovery options:
| Method | Best For | Link |
|---|---|---|
| Handshake58 | Humans browsing providers | Launch App |
| MCP Server | AI agents (auto-discovery) | npm package |
| Direct Address | Known provider integration | Use provider wallet address |
The marketplace is optional - DRAIN protocol works standalone with any provider address.
Quick Start for AI Agents: See demo/README.md for machine-readable examples.
Live Demo: https://www.handshake58.com
Try DRAIN without writing code:
| Component | Status | Link |
|---|---|---|
| Smart Contract | ✅ Complete | polygonscan |
| Test Suite (47 tests) | ✅ Complete | contracts/test/ |
| TypeScript SDK | ✅ Available | sdk/ |
| Reference Provider | ✅ Online | Railway |
| MCP Server | ✅ Published | npm |
| Handshake58 | ✅ LIVE | Launch App |
| Network | Contract | Address |
|---|---|---|
| Polygon Mainnet | DrainChannelV2 (ERC-8190) | 0x0C2B3aA1e80629D572b1f200e6DF3586B3946A8A |
| Polygon Mainnet | DrainChannel (V1, immutable) | 0x1C1918C99b6DcE977392E4131C91654d8aB71e64 |
| Polygon Amoy (Testnet) | DrainChannel | 0x61f1C1E04d6Da1C92D0aF1a3d7Dc0fEFc8794d7C |
DrainChannelV2 is the production contract used by Handshake58 and the ERC-8190 reference implementation. It adds cooperative close and optional platform fees over V1.
git clone https://github.com/kimbo128/DRAIN.git
cd DRAIN/contracts
# Install Foundry if needed: https://book.getfoundry.sh
forge build
forge test -vvv
forge test --gas-report # Gas optimization
forge coverage # Line coverage
| Chain | Tx Cost | Finality | USDC Liquidity |
|---|---|---|---|
| Polygon | ~$0.02 (varies: $0.015-0.025) | 5 sec | $500M+ native |
Why Polygon?
Future chains via CREATE2 for identical addresses.
Stop signing vouchers. Your USDC stays locked until expiry, then you can close the channel and get a full refund. The provider can only claim what you've signed.
Provider stops delivering service and claims the last valid voucher. The consumer's deposit covers all signed vouchers.
No. DRAIN v1 supports only USDC on Polygon. This keeps the protocol simple and prices predictable.
No. Channels have a fixed duration (e.g., 24h) to protect providers. After expiry, unused funds are refundable.
Recommended: when accumulated earnings exceed ~$10 (to amortize ~$0.02 gas). Providers can claim at any time – before, during, or after channel expiry.
Providers are protected by the channel duration. Here's the timeline:
Channel Open → Provider can claim (anytime) → Channel Expiry → Consumer can close
│ │ │ │
└────────────────────┴────────────────────────┴──────────────────┘
Provider can claim throughout this entire period
close()Example with 24h channel:
Best practice: Set up monitoring to claim before expiry, but know you have a buffer.
No. Open a new channel instead. This keeps the protocol simple and avoids edge cases.
| Project | Description | Link |
|---|---|---|
| Handshake58 Marketplace | Official provider directory | https://www.handshake58.com |
| For AI Agents | Agent quick start | https://www.handshake58.com/for-agents |
| Provider API | Discovery endpoint | https://www.handshake58.com/api/mcp/providers |
| MCP Server | AI agent integration (Claude, Cursor) | npm |
| Reference Provider | Live DRAIN-compatible AI provider | API |
See CONTRIBUTING.md for guidelines.
MIT License – Attribution required.
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.