claude-tws-connect

claude-tws-connect

An MCP server that enables interaction with Interactive Brokers TWS/Gateway via natural language for portfolio management and market data retrieval. It provides tools for account summaries, historical data, and a secure two-step confirmation process for placing and canceling orders.

Category
Visit Server

README

claude-tws-connect

License: MIT Python 3.10+ Sponsor

MCP (Model Context Protocol) server that connects Claude to Interactive Brokers TWS via ib_insync. Use natural language to check your portfolio, pull market data, and place orders — all from Claude Desktop, Claude Code, or any MCP-compatible client.

Quick Start

macOS:

git clone https://github.com/danielkristofik/mcp_claude_ibkr.git
cd mcp_claude_ibkr
./install.sh

Linux (Ubuntu/Debian):

git clone https://github.com/danielkristofik/mcp_claude_ibkr.git
cd mcp_claude_ibkr
./install-linux.sh

The installer will:

  1. Find or install Python 3.10+
  2. Create a virtual environment and install dependencies
  3. Let you choose Paper or Live trading port
  4. Configure Claude Desktop automatically
  5. Configure Claude Code (CLI) if installed

Features

Tool Description Read-only
ib_account_summary Account overview — liquidation value, cash, margin, buying power Yes
ib_positions Portfolio positions with market value and P&L Yes
ib_pnl Daily P&L — realized and unrealized Yes
ib_fundamental_data Fundamentals — P/E, EPS, market cap, dividends, 52-week range Yes
ib_margin_impact Margin impact estimate for a hypothetical order (what-if) Yes
ib_market_data Real-time snapshot (bid/ask/last/volume) + Greeks for options Yes
ib_historical_data Historical OHLCV bars Yes
ib_scanner Market scanner (top gainers, losers, most active, etc.) Yes
ib_contract_details Contract details Yes
ib_option_chains Option expirations and strikes Yes
ib_open_orders Active orders Yes
ib_executions Today's executions / fills Yes
ib_prepare_order Prepare an order for review (step 1/2) Yes
ib_submit_order Submit a confirmed order (step 2/2) No
ib_cancel_order Cancel an active order No

Order Safety

Orders use a two-step confirmation flow:

  1. ib_prepare_order — validates the contract, builds the order, and returns a confirmation token
  2. Claude shows the order details to you and waits for explicit approval
  3. ib_submit_order — submits the order only after confirmation (token expires in 5 minutes)

Manual Installation

Prerequisites

  • Python 3.10+
  • TWS or IB Gateway running and logged in
  • TWS API enabled (Edit → Global Configuration → API → Settings)

Setup

git clone https://github.com/danielkristofik/mcp_claude_ibkr.git
cd mcp_claude_ibkr

# Create virtual environment
python3 -m venv venv
source venv/bin/activate

# Install dependencies
pip install -r requirements.txt

Claude Desktop Configuration

Edit ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) and add the IBKR server:

{
  "mcpServers": {
    "ibkr": {
      "command": "/FULL/PATH/TO/claude-tws-connect/venv/bin/python",
      "args": ["/FULL/PATH/TO/claude-tws-connect/ibkr_mcp.py"]
    }
  }
}

Important: Use the full absolute path to the Python binary inside the venv.

See claude_desktop_config_example.json for a complete example.

Claude Code (CLI) Setup

If you use Claude Code, the MCP server can be configured with a single command:

claude mcp add --transport stdio --scope user ibkr -- /FULL/PATH/TO/claude-tws-connect/venv/bin/python /FULL/PATH/TO/claude-tws-connect/ibkr_mcp.py

Alternatively, this repository includes a .mcp.json file that makes the MCP server available automatically when you open the project directory in Claude Code — no manual configuration needed.

Verify

Restart Claude Desktop. The ib_* tools should appear in the tools list. Try:

"Show me my account summary"
"What positions do I have?"
"Get historical data for AAPL for the last month"

Configuration

Edit config.json or the variables at the top of ibkr_mcp.py:

TWS_HOST = "127.0.0.1"   # TWS host
TWS_PORT = 7496           # 7496 = live, 7497 = paper trading
CLIENT_ID = 10            # Unique client ID (avoid conflicts with other TWS connections)

TWS Setup

In TWS: Edit → Global Configuration → API → Settings:

  • Enable ActiveX and Socket Clients
  • Socket port: 7496 (live) or 7497 (paper)
  • Uncheck "Read-Only API" if you want to place orders
  • Add 127.0.0.1 to Trusted IPs

Remote IB Gateway

To connect to a remote IB Gateway, use an SSH tunnel:

ssh -L 4002:127.0.0.1:4002 user@remote-server

Then change TWS_PORT to 4002 in your config.

Troubleshooting

Problem Solution
Connection refused Make sure TWS is running and API is enabled
Port conflict Run lsof -i :7496 to check if something else is using the port
No data A market data subscription is required for the given contract
Timeout Increase CONNECT_TIMEOUT or check your network connection
Token expired Re-run ib_prepare_order — tokens are valid for 5 minutes

Support

If you find this project useful, consider supporting its development:

Disclaimer

This software is provided for educational and informational purposes only. It is not financial advice. Trading securities involves significant risk and may result in the loss of your invested capital.

The authors and contributors are not responsible for any financial losses, damages, or other consequences resulting from the use of this software. Use at your own risk. Always do your own research and consult a qualified financial advisor before making trading decisions.

This project is not affiliated with, endorsed by, or connected to Interactive Brokers LLC.

License

MIT — Copyright (c) 2025 Daniel Kristofik

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured