polymarket-trader-mcp
Polymarket Agent MCP Server
Trade, analyze, and automate Polymarket prediction markets through AI.
The most comprehensive MCP server for Polymarket — 48 tools spanning direct trading, market discovery, smart money tracking, copy trading, backtesting, risk management, and portfolio optimization. Works with Claude Code, Cursor, or any MCP-compatible client.
Tool Overview
Category | Count | Highlights |
Discovery | 9 | Search, trending, featured, events, related markets, smart money flow |
Analysis | 8 | AI opportunity scoring, conviction rating, price history, market quality, top holders, comparison |
Trading | 8 | Buy, sell, batch orders, limit orders, order management, safety limits |
Copy Trading | 5 | Watch traders, auto-monitor, auto-rebalance, backtest |
Portfolio | 10 | Positions, P&L, balance, risk assessment, SL/TP, optimization, market alerts |
Utilities | 8 | Dashboard, config, trade history, watchlists, agent logging |
Quick Start
npm Install
npm install -g polymarket-agent-mcpDocker
docker compose upClaude Code Config
Add to ~/.claude/settings.json:
{
"mcpServers": {
"polymarket": {
"command": "npx",
"args": ["polymarket-agent-mcp"]
}
}
}Usage Examples
Just talk naturally to your AI assistant:
"What are the trending markets today?"
"Search for bitcoin prediction markets"
"Buy $5 on this market"
"Score this trader — should I copy them?"
"Backtest this trader with $10 per trade"
"Show smart money flow — what are the top traders buying?"
"Set stop-loss at 0.30 on my BTC position"
"Optimize my portfolio with a balanced strategy"
"Scan for arbitrage opportunities"
"Compare these two markets side by side"
All 48 Tools
Discovery
Tool | Description |
| Search markets by keyword (bitcoin, election, UFC...) |
| Find top traders by PnL and volume |
| Find markets by end date and category |
| Top markets by 24h/7d/30d volume |
| Most liquid markets by category (politics, sports, crypto...) |
| WTA tennis markets with stink bid prices |
| Smart money signals — multiple top traders buying same market |
| Find markets related to a topic or market |
| Browse all markets under an event |
Analysis
Tool | Description |
| AI-powered BUY/SELL/HOLD recommendation |
| Detailed trader profile, win rate, P&L |
| Conviction score (0-100) across 5 dimensions |
| Market quality — spread, depth, price range |
| Live bid/ask/spread prices |
| Historical prices with sparkline (1h to 1m) |
| Biggest position holders in a market |
| Side-by-side comparison of 2-5 markets |
Trading
Tool | Description |
| Buy shares on any market |
| Sell an open position |
| Execute up to 10 orders at once |
| Place limit orders at discount |
| Cancel all open orders |
| View pending limit orders |
| Check status of a specific order |
| Switch from preview to live mode |
Copy Trading
Tool | Description |
| Add/remove traders from watchlist |
| Start automatic copy trading loop |
| Stop monitoring |
| Remove underperforming traders |
| Simulate copying a trader's past trades |
Portfolio & Risk
Tool | Description |
| Account balance, budget, and P&L |
| Multi-wallet overview with P&L per trader |
| Open/closed positions |
| Manually close a position |
| Set stop-loss and take-profit levels |
| Check positions for resolution |
| Portfolio risk scoring and warnings |
| AI-powered optimization (conservative/balanced/aggressive) |
| Market watchlist with price alerts |
| Find YES+NO price discrepancies |
Configuration
Tool | Description |
| Update bot settings |
| Max order size, exposure cap, spread tolerance |
| Terminal-formatted dashboard |
| Trade history with filters |
| Show watched wallets |
| Log agent cycle for dashboard |
| View a trader's open positions |
| WTA tennis market discovery |
Architecture
Claude Code / Cursor / AI Client
|
| MCP Protocol (stdio)
v
+------------------+
| MCP Server | 48 tools registered
| (index.ts) |
+--------+---------+
|
+----+----+
| |
Tools Services
| |
v v
+-------+ +------------+
| Zod | | Backtester |
| Input | | Scorer |
| Valid. | | SmartFlow |
+-------+ | Filter |
| Tracker |
| Executor |
+-----+------+
|
+-------+-------+
| | |
Data Gamma CLOB
API API APIHTTP Transport & Deployment
The server supports two transport modes:
Mode | Activation | Use case |
stdio (default) |
| Claude Code, Cursor, local MCP clients |
HTTP |
| Self-hosted Docker, private VPS, single-user remote |
Deployment model — read this first
This server is designed for single-tenant use. Each client runs its own instance with its own SQLite database (copytrader.db), watchlist, daily budget, trade history, and monitor loop. The stdio mode is the recommended path for most users — npx polymarket-agent-mcp or the Claude Code config above gives you a fully isolated, local-only instance.
⚠️ Do not expose an HTTP instance publicly. The server has no per-user isolation: watchlist, positions, budget, and the background monitor loop are shared across every client that connects. A public HTTP deployment is effectively a shared workspace, not a multi-tenant SaaS. If you enable live trading, a public endpoint can drain your Polymarket wallet from any caller. Always configure the HTTP bearer-token env var (see PERMISSIONS.md) and keep the endpoint behind a firewall, VPN, or auth proxy.
Starting in HTTP mode
# Flag
node dist/index.js --http
# Or set PORT (defaults to 3000)
PORT=8080 node dist/index.jsEndpoints
Path | Method | Description |
| POST | MCP protocol endpoint (Streamable HTTP transport) |
| GET | Health check — returns |
| GET | Server discovery card for Smithery |
| GET | Server info with version and endpoint list |
Authentication
The HTTP transport accepts an optional bearer token gated by an environment variable — the exact name is documented in PERMISSIONS.md. When set, clients must send Authorization: Bearer <token> on requests to /mcp; when unset the endpoint is open (suitable only for local or private networks).
Docker deployment
The included Dockerfile builds a multi-stage production image that runs in HTTP mode:
docker build -t polymarket-mcp .
docker run -p 3000:3000 -v mcp-data:/app/data \
-e DAILY_BUDGET=50 \
polymarket-mcp
# To require bearer-token auth on /mcp, also pass the HTTP bearer env var
# listed in PERMISSIONS.md (e.g. `-e <VAR>=my-secret-key`).DB_PATH (default /app/data/copytrader.db) controls where SQLite data is persisted — mount a volume to keep it across restarts.
Configuration
All secrets stay in memory for the lifetime of the process — they are never written to the database, logs, or disk, and are only transmitted to their designated Polymarket API endpoint over HTTPS. The complete authoritative env var list, with per-variable sensitivity and scope, lives in PERMISSIONS.md and SECURITY.md.
Variable | Required | Default | Description |
| No |
|
|
| No |
| Max daily spend in USDC |
| No |
| Min trade size to copy ($) |
Wallet signing key | Live only | - | Locally signs CLOB order payloads, never persisted (see PERMISSIONS.md for exact env var name) |
CLOB API credentials | Live only | - | API key / secret / passphrase — sent only to |
Safety Features
Configurable order size limits
Total exposure caps
Per-market position limits
Minimum liquidity requirements
Maximum spread tolerance
Stop-loss / take-profit automation
Preview mode (default) — no real money
Permissions & Capabilities
This package has a transparent, minimal footprint. Full disclosure: PERMISSIONS.md — machine-readable version in .well-known/mcp/server-card.json.
Category | Scope |
Network (outbound) | 3 Polymarket HTTPS APIs + 1 inbound-only WSS public price stream ( |
Filesystem | Single SQLite database file + |
Environment | API credentials (live mode only, in memory only), budget config, mode selection |
Processes | None — no child processes, no shell commands, no |
Telemetry | None — no analytics, no crash reports, no update checks, no third-party data flow |
WebSocket scope: The WSS connection to Polymarket is inbound-only for public price updates. No wallet, credential, or user identity is transmitted — it carries the same public feed available to any browser client.
Secrets scope: Every secret environment variable is held in memory only, never logged, never persisted, and sent to exactly one host (see SECURITY.md).
Development
git clone https://github.com/demwick/polymarket-agent-mcp.git
cd polymarket-agent-mcp
npm install
npm run build
npm test # 200+ testsLicense
MIT - see LICENSE
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/demwick/polymarket-trader-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server