Capital.com MCP Server for Amazon Q and other LLMs
Project description
Capital.com MCP Server
This is a Model Context Protocol (MCP) server that exposes the Capital.com trading API as tools that can be used by Amazon Q, Claude Desktop, and other LLMs that support the MCP protocol.
Available Tools
The following tools are exposed by the MCP server:
Core Trading Tools
get_account_info: Get account information and balancesearch_markets: Search for markets/instruments (supports both search terms and epic codes)get_prices: Get current prices with configurable time resolution (MINUTE, HOUR, DAY, etc.)get_historical_prices: Get historical price data with custom time ranges and resolutionget_positions: Get all open trading positionscreate_position: Create a new trading position (buy/sell) with optional stop loss and take profitclose_position: Close an open position by deal IDupdate_position: Update position stop loss or take profit levelsget_watchlists: Get all saved watchlists
Session & Account Management
get_session_info: Get current session information including active financial accountchange_financial_account: Switch between different financial accountsget_accounts: Get list of all financial accountsget_account_preferences: Get account preferences including leverage settings and hedging modeupdate_account_preferences: Update account preferences such as leverage settingstop_up_demo_account: Add funds to demo trading account for testing
Market Navigation & Discovery
get_market_navigation: Get hierarchical structure of asset groups available for tradingget_market_navigation_node: Get all assets/instruments under a specific navigation nodeget_watchlist_contents: Get contents of a specific watchlist
Working Orders Management
create_working_order: Create stop or limit orders that execute when market reaches specified level (returns dealReference for tracking)get_working_orders: Get all pending working orders (note: newly created orders may not appear immediately)update_working_order: Update parameters of existing working orders (requires working order ID from get_working_orders, not dealReference)delete_working_order: Cancel and remove working orders (requires working order ID from get_working_orders, not dealReference)
History & Reporting
get_activity_history: Get trading activity history with lastPeriod support (max 24h), deal ID filtering, and FIQL filtering (date ranges documented but currently limited)get_transaction_history: Get financial transaction history with full date range support and transaction type filtering (all parameters optional per API spec)confirm_deal: Confirm position status after creation and get dealId for management
Utilities
ping_api: Test connection to the Capital.com APIget_server_time: Get current server time from Capital.com API
✨ Key Features
- Complete API Coverage: Full access to all Capital.com REST API endpoints (25+ tools)
- Automatic Authentication: Handles login and session token refresh automatically
- Advanced Trading: Create positions, working orders (stop/limit), manage portfolios
- Account Management: Switch accounts, update leverage settings, manage preferences
- Market Discovery: Navigate asset hierarchies, explore watchlists, search instruments
- Smart Historical Data: Trading activity (lastPeriod up to 24h) and transaction history (full date range support) with real-world tested functionality
- Enhanced Search: Search markets by name or use specific epic codes (e.g., "Apple" or "AAPL")
- Multiple Time Resolutions: MINUTE, HOUR, DAY, WEEK for price data
- Position Confirmation: Verify trades and get deal IDs for position management
- Robust Error Handling: Built-in retry logic for expired sessions
- No Manual Auth: No separate authentication tool needed - handled behind the scenes
- API-Compliant Formatting: Automatic timezone handling and proper date format conversion
Configuration
Required Environment Variables
The MCP server requires the following environment variables:
CAPITAL_BASE_URL: The Capital.com API base URL (e.g.,https://demo-api-capital.backend-capital.com)CAPITAL_API_KEY: Your Capital.com API keyCAPITAL_PASSWORD: Your Capital.com passwordCAPITAL_IDENTIFIER: Your Capital.com email/identifier
Optional Environment Variables
CAPITAL_MCP_DEBUG: Set to1to enable debug loggingFASTMCP_LOG_LEVEL: Set toDEBUG,INFO,WARNING,ERROR, orCRITICALto control logging level
Installation & Setup
Install via pip
pip install capital-com-mcp-server
Running Manually
# Run with stdio transport (default)
capital-com-mcp-server
# Run with debug logging
capital-com-mcp-server --debug
# Get help with all options
capital-com-mcp-server --help
Example Usage
Searching for Markets
You: Search for Apple stock on Capital.com
AI: I'll search for Apple stock on Capital.com for you.
[Uses search_markets tool]
I found Apple Inc. (AAPL) on Capital.com. Here are the details:
- Epic: AAPL
- Market name: Apple Inc.
- Current bid price: $184.25
- Current ask price: $184.30
- Market status: OPEN
Getting Historical Price Data
You: Show me Tesla's daily price data for the last week
AI: I'll get Tesla's daily price data for you.
[Uses get_prices with epic="TSLA" and resolution="DAY"]
Tesla (TSLA) daily prices:
- Day 1: Open $248.50, Close $252.30, High $254.80, Low $247.90
- Day 2: Open $252.30, Close $249.75, High $253.20, Low $248.40
- Volume and price trends show recent volatility
Getting Account Information
You: What's my account balance on Capital.com?
AI: Let me check your Capital.com account information.
[Uses get_account_info tool]
Your Capital.com account information:
- Account ID: ABC123456
- Account type: Demo
- Currency: USD
- Balance: $10,000.00
- Available funds: $9,500.00
- Margin used: $500.00
Creating a Position
You: Buy 10 shares of Apple stock
AI: I'll create a buy position for Apple stock on Capital.com.
[Uses create_position tool]
Successfully created a BUY position for Apple Inc. (AAPL):
- Deal ID: DEF789012
- Size: 10 shares
- Opening price: $184.30
- Position status: OPEN
Creating Working Orders
You: Set a stop order to buy Tesla at $240 with a stop loss at $230
AI: I'll create a stop order for Tesla with your specified levels.
[Uses create_working_order tool]
Successfully created a STOP order for Tesla (TSLA):
- Deal Reference: o_17a6e937-6947-4825-92f1-9c690df802a9
- Direction: BUY
- Level: $240.00
- Stop loss: $230.00
- Note: Order created successfully. Use get_working_orders() to find the working order ID for management operations.
Managing Account Preferences
You: Check my current leverage settings and change FOREX leverage to 50:1
AI: Let me check your account preferences and update the FOREX leverage.
[Uses get_account_preferences and update_account_preferences tools]
Current account preferences:
- Hedging mode: Enabled
- FOREX leverage: 30:1
- STOCKS leverage: 5:1
Successfully updated FOREX leverage to 50:1.
History and Transaction Queries
You: Show me my trading activity from the last 24 hours with detailed information
AI: I'll get your detailed trading activity from the last 24 hours.
[Uses get_activity_history with last_period=86400, detailed=true]
Trading activity (last 24 hours):
- Position opened: AAPL BUY 10 shares at $184.30
- Stop loss updated: TSLA position, new SL at $240.00
- Working order filled: NVDA LIMIT order executed at $520.00
Total activities: 3
You: Get my transaction history for the last week, filter for deposits only
AI: I'll retrieve your deposit transactions from the last week.
[Uses get_transaction_history with from_date="2024-06-07T00:00:00", to_date="2024-06-14T23:59:59", transaction_type="DEPOSIT"]
Deposit transactions (last 7 days):
- 2024-06-10: $1,000.00 deposit via bank transfer
- 2024-06-08: $500.00 deposit via credit card
Total deposits: $1,500.00
Prerequisites for using with LLMs
Make sure you have uv installed on your system:
curl -LsSf https://astral.sh/uv/install.sh | sh
Using with Amazon Q
-
Create an
mcp.jsonconfiguration file in your Amazon Q configuration directory (~/.aws/amazonq/mcp.json):{ "mcpServers": { "capital-com-mcp-server": { "command": "uvx", "args": ["capital-com-mcp-server"], "env": { "CAPITAL_BASE_URL": "https://demo-api-capital.backend-capital.com", "CAPITAL_API_KEY": "your_api_key_here", "CAPITAL_PASSWORD": "your_password_here", "CAPITAL_IDENTIFIER": "your_email@example.com", "FASTMCP_LOG_LEVEL": "ERROR" } } } }
-
Run Amazon Q with:
q chat -
Amazon Q will automatically start the MCP server and connect to it.
Using with Claude Desktop
-
In Claude Desktop, go to Settings > Developer section and click on "Edit Config"
-
This will open the configuration file. Add the following to the JSON:
{ "mcpServers": { "capital-com-mcp-server": { "command": "uvx", "args": ["capital-com-mcp-server"], "env": { "CAPITAL_BASE_URL": "https://demo-api-capital.backend-capital.com", "CAPITAL_API_KEY": "your_api_key_here", "CAPITAL_PASSWORD": "your_password_here", "CAPITAL_IDENTIFIER": "your_email@example.com", "FASTMCP_LOG_LEVEL": "ERROR" } } } }
Resources
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file capital_com_mcp_server-0.2.4.tar.gz.
File metadata
- Download URL: capital_com_mcp_server-0.2.4.tar.gz
- Upload date:
- Size: 52.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ebe0d29a8958e9231d1d380851bf8b93f5e931ac660ca9d569c8a5bf93a6de5a
|
|
| MD5 |
3a4eb0aa3cf67558c733ed83f9c8d3bf
|
|
| BLAKE2b-256 |
7d328993a180ed65002522d417f1ab3eaff331775498ef8478a3468d5e874a02
|
Provenance
The following attestation bundles were made for capital_com_mcp_server-0.2.4.tar.gz:
Publisher:
python-publish.yml on syedair/mcp-servers
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
capital_com_mcp_server-0.2.4.tar.gz -
Subject digest:
ebe0d29a8958e9231d1d380851bf8b93f5e931ac660ca9d569c8a5bf93a6de5a - Sigstore transparency entry: 238264200
- Sigstore integration time:
-
Permalink:
syedair/mcp-servers@6dea810945d5a3dd77943a85e76d4867f802f23b -
Branch / Tag:
refs/tags/v0.2.4 - Owner: https://github.com/syedair
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@6dea810945d5a3dd77943a85e76d4867f802f23b -
Trigger Event:
release
-
Statement type:
File details
Details for the file capital_com_mcp_server-0.2.4-py3-none-any.whl.
File metadata
- Download URL: capital_com_mcp_server-0.2.4-py3-none-any.whl
- Upload date:
- Size: 23.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0510f1e8d081eea6a4c2651e5c618e332c2d7500155a6aee30890ce7e34e159d
|
|
| MD5 |
c65d77ee245f172c49fdc63fab3755e7
|
|
| BLAKE2b-256 |
222b1091c8cb3fba6a5c257d0d8b0eeab3ef23a87a31a51030601449caa03aa8
|
Provenance
The following attestation bundles were made for capital_com_mcp_server-0.2.4-py3-none-any.whl:
Publisher:
python-publish.yml on syedair/mcp-servers
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
capital_com_mcp_server-0.2.4-py3-none-any.whl -
Subject digest:
0510f1e8d081eea6a4c2651e5c618e332c2d7500155a6aee30890ce7e34e159d - Sigstore transparency entry: 238264204
- Sigstore integration time:
-
Permalink:
syedair/mcp-servers@6dea810945d5a3dd77943a85e76d4867f802f23b -
Branch / Tag:
refs/tags/v0.2.4 - Owner: https://github.com/syedair
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@6dea810945d5a3dd77943a85e76d4867f802f23b -
Trigger Event:
release
-
Statement type: