Model Context Protocol server for AI agent access to CPZAI
A production-grade Model Context Protocol (MCP) server that exposes CPZAI capabilities — strategy management, backtesting, multi-broker order routing (Alpaca / Interactive Brokers / FIX), portfolios, risk analytics, market data — as tools for any MCP-compatible AI agent (Claude, Cursor, GPT, etc.).
The hosted endpoint at https://mcp.cpz-lab.com/mcp is the only supported way to connect. This repo exists for transparency: anyone wiring their broker API keys through an AI agent should be able to read the exact code that handles those keys.
You'll need a CPZ API key + secret. Create one at ai.cpz-lab.com/settings/api-keys.
Add to .cursor/mcp.json:
{
"mcpServers": {
"cpzai": {
"url": "https://mcp.cpz-lab.com/mcp",
"headers": {
"X-CPZ-Key": "your_cpz_key",
"X-CPZ-Secret": "your_cpz_secret"
}
}
}
}Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"cpzai": {
"url": "https://mcp.cpz-lab.com/mcp",
"headers": {
"X-CPZ-Key": "your_cpz_key",
"X-CPZ-Secret": "your_cpz_secret"
}
}
}
}The server speaks OAuth 2.1 + PKCE at https://mcp.cpz-lab.com/.well-known/oauth-authorization-server. Use Claude's "Connect a server" flow and point it at https://mcp.cpz-lab.com/mcp.
Agent (Cursor / Claude / GPT / custom)
│
│ Streamable HTTP + X-CPZ-Key / X-CPZ-Secret
▼
mcp.cpz-lab.com
│
▼
Node.js MCP server (stateless) ← this repo
│
│ per-request API key validation
▼
CPZ Platform REST API
Design decisions:
- Stateless transport. Each
POST /mcpcreates a fresh server instance — no session tracking, scales horizontally without coordination. - Thin protocol adapter. Validates the API key, then proxies tool calls to the CPZ REST API. Zero business logic in the MCP layer; what you see in
src/is what runs in production. - Key auth. Agents authenticate with CPZ platform API keys (
X-CPZ-Key/X-CPZ-Secret) — the same keys used by the REST API and thecpzPython SDK. - Paper-only by default. Live trading on a strategy requires explicit per-strategy promotion in the platform.
18 tools exposed today, organized by domain.
| Tool | Description | Read-only |
|---|---|---|
| Strategies | ||
list_strategies |
List trading strategies with filtering | ✓ |
get_strategy |
Get a specific strategy by ID | ✓ |
create_strategy |
Create a new trading strategy | |
update_strategy |
Update an existing strategy | |
| Backtests | ||
get_backtest_results |
List backtest run results | ✓ |
| Orders & trading | ||
list_orders |
List trading orders with filtering | ✓ |
place_order |
Place a new trading order | |
list_positions |
List current portfolio positions | ✓ |
sync_portfolio |
Trigger portfolio sync across brokers | |
list_accounts |
List connected trading accounts | ✓ |
| Market data | ||
get_market_data |
Real-time quotes (price, bid/ask, volume) | ✓ |
| Risk | ||
compute_risk |
Compute fresh risk snapshot (VaR, Sharpe, drawdown) | |
list_risk_snapshots |
List historical risk snapshots | ✓ |
| Execution | ||
execute_strategy |
Execute a strategy on the Python backend | |
| Webhooks | ||
list_webhooks |
List webhook subscriptions | ✓ |
create_webhook |
Subscribe to platform events | |
delete_webhook |
Remove a webhook subscription | |
| User | ||
get_profile |
Get authenticated user profile | ✓ |
npm install
export CPZ_API_BASE_URL=https://api.cpz-lab.com
export CPZ_SERVICE_KEY=your_service_key
npm run dev
# server starts on http://localhost:3001npm test # single run
npm run test:watch # watch mode
npx tsc --noEmit # type checknpm run build # compiles TS → dist/
npm start # runs the compiled serverdocker build -t cpzai-mcp-server .
docker run --rm -p 3001:3001 \
-e CPZ_API_BASE_URL=https://api.cpz-lab.com \
-e CPZ_SERVICE_KEY=your_service_key \
cpzai-mcp-server- All connections HTTPS with TLS 1.3 at the edge.
- API credentials are forwarded in HTTP headers and never logged.
- Per-request API key validation against the platform's
api_keystable. - All data access is user-scoped via the
user_idderived from the validated key. - OAuth tokens (when used) are held in server memory only — never persisted.
See the privacy policy for the full data-handling story.
We don't currently support self-hosting. Use the hosted endpoint at https://mcp.cpz-lab.com/mcp with your CPZ API key. The hosted server is the same code in this repo plus AWS infrastructure (ALB, ECS Fargate, WAF, secrets) that's not part of this repo.
If you have a strong reason to self-host (e.g. air-gapped trading desk), open an issue and we'll talk.
Issues and PRs welcome. Before submitting:
npx tsc --noEmitmust passnpm testmust pass- Keep changes minimal and aligned with existing patterns
MIT © CPZ Capital Ltd.