Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@claude-tws-connectShow me my current portfolio positions and their P&L"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
claude-tws-connect
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.shLinux (Ubuntu/Debian):
git clone https://github.com/danielkristofik/mcp_claude_ibkr.git
cd mcp_claude_ibkr
./install-linux.shThe installer will:
Find or install Python 3.10+
Create a virtual environment and install dependencies
Let you choose Paper or Live trading port
Configure Claude Desktop automatically
Configure Claude Code (CLI) if installed
Features
Tool | Description | Read-only |
| Account overview — liquidation value, cash, margin, buying power | Yes |
| Portfolio positions with market value and P&L | Yes |
| Daily P&L — realized and unrealized | Yes |
| Fundamentals — P/E, EPS, market cap, dividends, 52-week range | Yes |
| Margin impact estimate for a hypothetical order (what-if) | Yes |
| Real-time snapshot (bid/ask/last/volume) + Greeks for options | Yes |
| Historical OHLCV bars | Yes |
| Market scanner (top gainers, losers, most active, etc.) | Yes |
| Contract details | Yes |
| Option expirations and strikes | Yes |
| Active orders | Yes |
| Today's executions / fills | Yes |
| Prepare an order for review (step 1/2) | Yes |
| Submit a confirmed order (step 2/2) | No |
| Cancel an active order | No |
Order Safety
Orders use a two-step confirmation flow:
ib_prepare_order— validates the contract, builds the order, and returns a confirmation tokenClaude shows the order details to you and waits for explicit approval
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.txtClaude 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.pyAlternatively, 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.1to 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-serverThen 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 |
No data | A market data subscription is required for the given contract |
Timeout | Increase |
Token expired | Re-run |
Support
If you find this project useful, consider supporting its development:
Buy Me a Coffee (link coming soon)
Ko-fi (link coming soon)
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
This server cannot be installed
Resources
Looking for Admin?
Admins can modify the Dockerfile, update the server description, and track usage metrics. If you are the server author, to access the admin panel.