A Model Context Protocol (MCP) server for MetaTrader 5, allowing AI assistants to interact with the MetaTrader 5 platform for trading and market data analysis.
- Connect to MetaTrader 5 terminal
- Access market data (symbols, rates, ticks)
- Place and manage trades
- Analyze trading history
- Integrate with AI assistants through the Model Context Protocol
pip install mcp-metatrader5-server
git clone https://github.com/yourusername/mcp-metatrader5-server.git
cd mcp-metatrader5-server
pip install -e .
- Python 3.11 or higher
- MetaTrader 5 terminal installed
- MetaTrader 5 account (demo or real)
To run the server in development mode:
mt5-mcp dev
This will start the server at http://127.0.0.1:8000 by default.
You can specify a different host and port:
mt5-mcp dev --host 0.0.0.0 --port 8080
To install the server for Claude Desktop:
mt5-mcp install
initialize()
: Initialize the MT5 terminallogin(account, password, server)
: Log in to a trading accountshutdown()
: Close the connection to the MT5 terminal
get_symbols()
: Get all available symbolsget_symbols_by_group(group)
: Get symbols by groupget_symbol_info(symbol)
: Get information about a specific symbolget_symbol_info_tick(symbol)
: Get the latest tick for a symbolcopy_rates_from_pos(symbol, timeframe, start_pos, count)
: Get bars from a specific positioncopy_rates_from_date(symbol, timeframe, date_from, count)
: Get bars from a specific datecopy_rates_range(symbol, timeframe, date_from, date_to)
: Get bars within a date rangecopy_ticks_from_pos(symbol, start_pos, count)
: Get ticks from a specific positioncopy_ticks_from_date(symbol, date_from, count)
: Get ticks from a specific datecopy_ticks_range(symbol, date_from, date_to)
: Get ticks within a date range
order_send(request)
: Send an order to the trade serverorder_check(request)
: Check if an order can be placed with the specified parameterspositions_get(symbol, group)
: Get open positionspositions_get_by_ticket(ticket)
: Get an open position by its ticketorders_get(symbol, group)
: Get active ordersorders_get_by_ticket(ticket)
: Get an active order by its tickethistory_orders_get(symbol, group, ticket, position, from_date, to_date)
: Get orders from historyhistory_deals_get(symbol, group, ticket, position, from_date, to_date)
: Get deals from history
# Initialize MT5
initialize()
# Log in to your trading account
login(account=123456, password="your_password", server="your_server")
# Get available symbols
symbols = get_symbols()
# Get recent price data for EURUSD
rates = copy_rates_from_pos(symbol="EURUSD", timeframe=15, start_pos=0, count=100)
# Shut down the connection
shutdown()
# Initialize and log in
initialize()
login(account=123456, password="your_password", server="your_server")
# Create an order request
request = OrderRequest(
action=mt5.TRADE_ACTION_DEAL,
symbol="EURUSD",
volume=0.1,
type=mt5.ORDER_TYPE_BUY,
price=mt5.symbol_info_tick("EURUSD").ask,
deviation=20,
magic=123456,
comment="Buy order",
type_time=mt5.ORDER_TIME_GTC,
type_filling=mt5.ORDER_FILLING_IOC
)
# Send the order
result = order_send(request)
# Shut down the connection
shutdown()
The server provides the following resources to help AI assistants understand how to use the MetaTrader 5 API:
mt5://getting_started
: Basic workflow for using the MetaTrader 5 APImt5://trading_guide
: Guide for placing and managing tradesmt5://market_data_guide
: Guide for accessing and analyzing market datamt5://order_types
: Information about order typesmt5://order_filling_types
: Information about order filling typesmt5://order_time_types
: Information about order time typesmt5://trade_actions
: Information about trade request actions
The server provides the following prompts to help AI assistants interact with users:
connect_to_mt5(account, password, server)
: Connect to MetaTrader 5 and log inanalyze_market_data(symbol, timeframe)
: Analyze market data for a specific symbolplace_trade(symbol, order_type, volume)
: Place a trade for a specific symbolmanage_positions()
: Manage open positionsanalyze_trading_history(days)
: Analyze trading history
mcp-metatrader5-server/
├── src/
│ └── mcp_metatrader5_server/
│ ├── __init__.py
│ ├── server.py
│ ├── market_data.py
│ ├── trading.py
│ ├── main.py
│ └── cli.py
├── run.py
├── README.md
└── pyproject.toml
To build the package:
python -m pip install build
python -m build
Or using uv:
uv build
To publish the package to PyPI:
python -m pip install twine
python -m twine upload dist/*
Or using uv:
uv publish
MIT
- MetaQuotes for the MetaTrader 5 platform
- FastMCP for the MCP server implementation