IBKR MCP Server
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., "@IBKR MCP Serverget SPX 0DTE option chain with Greeks"
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.
IBKR MCP Server
A comprehensive Model Context Protocol (MCP) server for Interactive Brokers TWS API integration, designed for algorithmic trading with a focus on 0DTE SPX options.
🚀 Features
Market Data
Real-time stock quotes with bid/ask spreads
Option chain retrieval with Greeks (Delta, Gamma, Theta, Vega)
Index quotes (SPX, NDX, VIX)
Historical price data for analysis
Order Management
Market Orders: Immediate execution at best price
Limit Orders: Execute at specified price or better
Stop Orders: Trigger orders at stop price
Bracket Orders: Entry + Take Profit + Stop Loss
Trailing Stop Orders: Dynamic stop that follows price
Manual/Auto Transmission: Option for TWS confirmation
Account Management
Portfolio positions with P&L tracking
Account summary (Net Liquidation, Cash, Buying Power)
Real-time order status tracking
Execution reports with commissions
Risk Management
Position sizing tools
Risk/reward calculation for brackets
Greeks analysis for options
Idempotent order submission
Related MCP server: Interactive Brokers MCP Server
📋 Prerequisites
Interactive Brokers Account
Active IB account (Paper or Live)
TWS or IB Gateway installed
TWS Configuration
Enable API connections in TWS
Configure socket port (7497 for paper, 7496 for live)
Set "Read-Only API" to unchecked for trading
Python Environment
Python 3.9 or higher
MCP-compatible environment (Claude Desktop)
🔧 Installation
1. Clone Repository
git clone https://github.com/yourusername/ibkr-mcp-server.git
cd ibkr-mcp-server2. Create Virtual Environment
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate3. Install Dependencies
pip install -r requirements.txt4. Configure Claude Desktop
Add to Claude Desktop configuration (claude_desktop_config.json):
{
"mcpServers": {
"ibkr": {
"command": "python",
"args": [
"C:/path/to/ibkr-mcp-server/src/ibkr_mcp_server.py"
]
}
}
}🎯 Usage Examples
Connect to TWS
# Paper trading
ibkr_connect(mode="paper")
# Live trading
ibkr_connect(mode="live")Get Market Data
# Stock quote
ibkr_get_stock_quote(symbol="SPY")
# Option chain for 0DTE SPX
ibkr_get_option_chain(underlying="SPX", include_greeks=True)Place Orders
# Market order
ibkr_place_market_order(
symbol="SPY",
action="BUY",
quantity=100,
transmit=True
)
# Limit order
ibkr_place_limit_order(
symbol="AAPL",
action="BUY",
quantity=50,
limit_price=175.50
)
# Bracket order for 0DTE options
ibkr_place_bracket_order(
symbol="SPX",
sec_type="OPT",
action="BUY",
quantity=1,
entry_price=10.00,
take_profit_price=15.00, # +50% target
stop_loss_price=7.00 # -30% stop
)Account Information
# Get positions
ibkr_get_positions()
# Get account summary
ibkr_get_account_summary()
# Check order status
ibkr_get_order_status(order_id=123)🛠️ Available Tools
Tool | Description |
| Connect to TWS/IB Gateway |
| Disconnect from TWS |
| Check connection status |
| Get real-time stock quote |
| Get option chain with Greeks |
| Place market order |
| Place limit order |
| Place bracket order |
| Cancel pending order |
| Get order status |
| Get current positions |
| Get account metrics |
| Get historical bars |
| Get server information |
🎮 TWS Setup Guide
1. Enable API Access
Open TWS
Go to File → Global Configuration
Select API → Settings
Enable Enable ActiveX and Socket Clients
Configure port:
Paper: 7497
Live: 7496
Optional: Set Master API client ID to "0"
2. Security Settings
Under API → Precautions:
Uncheck Read-Only API for trading
Set Bypass Order Precautions based on preference
Add trusted IP: 127.0.0.1
3. Market Data Subscriptions
Ensure you have appropriate market data subscriptions:
US Stocks (Network A/B)
Options (OPRA)
Index data (for SPX)
📊 0DTE Trading Workflow
Example 0DTE SPX Strategy
# 1. Connect
ibkr_connect(mode="paper")
# 2. Get SPX price
spx_quote = ibkr_get_stock_quote(symbol="SPX")
# 3. Get 0DTE options (today's expiry)
options = ibkr_get_option_chain(
underlying="SPX",
strike_range=(5500, 5600), # Near ATM
include_greeks=True
)
# 4. Place bracket order on selected option
ibkr_place_bracket_order(
symbol="SPX",
sec_type="OPT",
action="BUY",
quantity=1,
entry_price=8.50,
take_profit_price=12.75, # +50% target
stop_loss_price=5.95 # -30% stop
)
# 5. Monitor position
ibkr_get_positions()🔒 Security Considerations
API Credentials: Never hardcode credentials
Paper vs Live: Always test in paper first
Order Validation: Use
transmit=Falsefor manual reviewPosition Limits: Implement position sizing rules
Rate Limiting: Respect IB API rate limits
🐛 Troubleshooting
Connection Issues
Error: Failed to connect to TWSSolution:
Verify TWS is running
Check API settings enabled
Confirm correct port (7497/7496)
Check firewall settings
No Market Data
Error: No market data availableSolution:
Verify market data subscriptions
Check if market is open
Ensure proper contract specification
Order Rejected
Error: Order rejected - insufficient buying powerSolution:
Check account balance
Verify position limits
Review margin requirements
📈 Performance Tips
Connection Management: Keep persistent connection
Data Caching: Cache frequently used data
Batch Operations: Group related requests
Error Handling: Implement retry logic
Logging: Enable detailed logging for debugging
📝 License
MIT License - See LICENSE file for details
🤝 Contributing
Contributions welcome! Please read CONTRIBUTING.md
📧 Support
For issues and questions:
GitHub Issues: Create Issue
IB API Docs: Official Documentation
🏗️ Roadmap
Advanced order types (OCO, Conditional)
Options strategies (Spreads, Straddles)
Real-time P&L tracking
Risk analytics dashboard
Backtesting integration
Machine learning signals
⚠️ Disclaimer
This software is for educational purposes. Trading involves substantial risk of loss. Past performance does not guarantee future results. Always test thoroughly in paper trading before using with real funds.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/MTCMarkFranco/ibkr-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server