Skip to main content

Emerald Exchange — Unified Finance MCP Server with fully abstracted exchange backends for equities, crypto, and derivatives trading. CONCEPT:EE-001

Project description

Emerald Exchange - API | MCP | A2A

PyPI - Version MCP Server

Version: 0.10.0

Overview

Emerald Exchange is a unified Finance MCP Server providing fully abstracted exchange backends for equities, crypto, and derivatives trading. All trading functionality is tool-driven via MCP, with built-in financial hardening controls (OS-5.1).

Key Features:

  • 5 Exchange Backends: Paper (default), Alpaca (FREE), CCXT (100+ exchanges), Freqtrade
  • 6 MCP Tool Domains: market-data, orders, portfolio, risk, signals, strategy
  • Financial Hardening: Paper-first default, Kelly criterion position sizing, circuit breakers, kill switch
  • Config-Driven: All settings via ~/.config/agent-utilities/config.json

Architecture

flowchart TB
    A["Agent / IDE"] --> B["emerald-exchange MCP"]
    B --> C["Risk Guard (OS-5.1)"]
    C --> D{"Exchange Router"}
    D --> E["Paper Backend (Default)"]
    D --> F["Alpaca Backend (FREE)"]
    D --> G["CCXT Backend (Binance/Coinbase/Kraken)"]
    D --> H["Freqtrade Backend"]

    style B fill:#10B981,stroke:#065F46,color:#fff
    style C fill:#EF4444,stroke:#991B1B,color:#fff
    style E fill:#6366F1,stroke:#4338CA,color:#fff

MCP Tools

Domain Tool Name Actions Tag
Market Data emerald_market_data quote, historical, exchanges market-data
Orders emerald_orders submit, cancel, status, halt, resume orders
Portfolio emerald_portfolio positions, account portfolio
Prediction Markets emerald_prediction_markets kalshi_events, polymarket_events, open_meteo_ensemble prediction-markets
Risk emerald_risk status, drawdown_check, daily_loss_check, kelly, limits risk
Signals emerald_signals regime, alpha, fuse signals
Strategy emerald_strategy list, promote, export strategy

Exchange Backends

Backend Assets Paper Live Free
Paper All
Alpaca Equities, Crypto
CCXT (Binance) Crypto
CCXT (Coinbase) Crypto
CCXT (Kraken) Crypto
Freqtrade Crypto
Prediction Markets (Kalshi/Polymarket) Events/Weather

Financial Hardening (OS-5.1)

Control Default
Trading Mode Paper (must explicitly opt into live)
Max Position Size 2% of portfolio (Kelly criterion)
Max Portfolio Drawdown 10% auto-halt
Max Daily Loss 3% auto-halt
Regime Shift Detection KS-test auto-halt
Human Approval for Live Required
Kill Switch emerald_orders(action="halt")

Usage

MCP Configuration

stdio Mode

{
  "mcpServers": {
    "emerald-exchange": {
      "command": "uv",
      "args": ["run", "--with", "emerald-exchange", "emerald-exchange"],
      "env": {}
    }
  }
}

Streamable HTTP Mode

emerald-exchange --transport streamable-http --port 8100

Configuration

All trading settings are configured via ~/.config/agent-utilities/config.json:

{
  "trading": {
    "default_mode": "paper",
    "default_exchange": "alpaca",
    "exchanges": {
      "alpaca": {
        "enabled": true,
        "api_key_env": "ALPACA_API_KEY",
        "api_secret_env": "ALPACA_SECRET_KEY",
        "base_url": "https://paper-api.alpaca.markets"
      }
    },
    "risk_limits": {
      "max_position_pct": 0.02,
      "max_portfolio_drawdown_pct": 0.10,
      "max_daily_loss_pct": 0.03,
      "require_human_approval_live": true
    }
  }
}

⚙️ Dynamic Tool Selection & Visibility

This MCP server supports dynamic toolset selection and visibility filtering at runtime. This allows you to restrict the set of exposed tools in order to prevent blowing up the LLM's context window.

You can configure tool filtering via multiple input channels:

  • CLI Arguments: Pass --tools or --toolsets (or their disabled counterparts --disabled-tools and --disabled-toolsets) during startup.
  • Environment Variables: Define standard environment variables:
    • MCP_ENABLED_TOOLS / MCP_DISABLED_TOOLS
    • MCP_ENABLED_TAGS / MCP_DISABLED_TAGS
  • HTTP SSE Request Headers: Pass custom headers during transport initialization:
    • x-mcp-enabled-tools / x-mcp-disabled-tools
    • x-mcp-enabled-tags / x-mcp-disabled-tags
  • HTTP SSE Request Query Parameters: Append query parameters directly to your transport connection URL:
    • ?tools=tool1,tool2
    • ?tags=tag1

When query strings or parameters are supplied, an LLM-free Knowledge Graph resolution layer (using DynamicToolOrchestrator) matches query intents against known tool tags, names, or descriptions, with safe fallback and automated 24-hour background cache refreshing.


Installation

pip install emerald-exchange           # Core + paper backend
pip install emerald-exchange[alpaca]   # + Alpaca equities
pip install emerald-exchange[crypto]   # + CCXT crypto
pip install emerald-exchange[prediction_markets] # + Kalshi & Polymarket
pip install emerald-exchange[all]      # Everything

Docker

docker compose -f docker/compose.yml up -d

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

emerald_exchange-0.10.0.tar.gz (24.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

emerald_exchange-0.10.0-py3-none-any.whl (29.3 kB view details)

Uploaded Python 3

File details

Details for the file emerald_exchange-0.10.0.tar.gz.

File metadata

  • Download URL: emerald_exchange-0.10.0.tar.gz
  • Upload date:
  • Size: 24.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for emerald_exchange-0.10.0.tar.gz
Algorithm Hash digest
SHA256 f2caf8ccf1bd2effb7377946a0a37a9189360a4558218defb569c6b3d1d76880
MD5 95562de5d927e1fa8de6ba2e186e266b
BLAKE2b-256 a7b3c6d4757da3d9f136d0e84641c87be4eee8d3275c71760895ba6fc790ec12

See more details on using hashes here.

File details

Details for the file emerald_exchange-0.10.0-py3-none-any.whl.

File metadata

File hashes

Hashes for emerald_exchange-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 358e3315b6012be1e5ed4416db7c28872623424138e73e0f569ddd84ad2615e4
MD5 e4e4553c1fd02c361544c6882aa1a928
BLAKE2b-256 10ba13d5f2163a1e59bcf83eb19fc0146c7b7605602122d5c0ba75329b29365c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page