Skip to main content

REST and WebSocket API project for MetaTrader 5

Project description

open-api-mt5

MetaTrader 5 API service with FastAPI.

Important limitation

This API controls a single MT5 terminal/session instance per running service process.

  • A single API instance can be connected to only one account at a time.
  • /account/connect switches that single active session.
  • If you run multiple API services, use separate MT5 terminal instances/data folders for reliable isolation.

Setup

  1. Create a virtual environment:
    • Windows PowerShell: python -m venv .venv
  2. Activate it:
    • .\.venv\Scripts\Activate.ps1
  3. Install dependencies:
    • python -m pip install -U pip
    • pip install -e .

MT5 startup config

The API initializes MetaTrader 5 when FastAPI starts and closes it when FastAPI stops. It also checks MT5 connection every 5 seconds and tries to reconnect automatically if disconnected.

Set these environment variables in PowerShell before running:

$env:MT5_PATH = "C:\Program Files\MetaTrader 5\terminal64.exe"
$env:MT5_LOGIN = "12345678"
$env:MT5_PASSWORD = "your-password"
$env:MT5_SERVER = "YourBroker-Server"

MT5_PATH is optional if MT5 is already discoverable, but setting it is recommended. Mode, apiKey, apiSecret, and registryUrl are startup settings and are not stored by /account/connect.

Run

open-api-mt5

Optional flags:

open-api-mt5 --port 9000
open-api-mt5 --host 0.0.0.0 --port 8000
open-api-mt5 --mode standalone
open-api-mt5 --mode secure --api-key your-api-key
open-api-mt5 --mode secure-client --api-key your-api-key --api-secret your-api-secret
open-api-mt5 --registry-url https://example.com/registry
open-api-mt5 --reload

Default port is 8000.

API docs:

  • Swagger UI: http://127.0.0.1:8000/docs
  • WebSocket docs in Swagger:
    • GET /ws/positions/open/docs

Health endpoint:

  • GET http://127.0.0.1:8000/health

Bars endpoints:

  • GET http://127.0.0.1:8000/bars/{symbol}?timeframe=M1&n=100
  • GET http://127.0.0.1:8000/bars/{symbol}/range?timeframe=M1&fromDate=2026-03-20T08:00:00Z&toDate=2026-03-20T12:00:00Z
  • GET http://127.0.0.1:8000/quotes/{symbol}
  • GET http://127.0.0.1:8000/ticks/{symbol}?count=100
  • GET http://127.0.0.1:8000/market-depth/{symbol}
  • GET http://127.0.0.1:8000/exposure
  • GET http://127.0.0.1:8000/exposure/{symbol}

Account connection endpoints:

  • POST http://127.0.0.1:8000/account/connect
    • Body: username, password, server, optional path
    • Example body:
      {
        "username": "12345678",
        "password": "your-password",
        "server": "YourBroker-Server",
        "path": "C:\\Program Files\\MetaTrader 5\\terminal64.exe"
      }
      
  • POST http://127.0.0.1:8000/account/disconnect
  • If --registry-url is set at startup, the API sends a POST call to that URL with JSON body fields address, port, apiKey, and accountId

Security modes:

  • Set the mode when starting the app with --mode standalone, --mode secure, or --mode secure-client
  • Set the headers credentials when starting the app with --api-key and, for secure-client, --api-secret
  • Set the registry target when starting the app with --registry-url
  • standalone: default mode, no X-apiKey or X-apiSecret header checks
  • secure: every HTTP endpoint and the open positions WebSocket require X-apiKey to match the locally stored apiKey
  • secure-client: every HTTP endpoint and the open positions WebSocket require both X-apiKey and X-apiSecret to match the locally stored values

Server info endpoint:

  • GET http://127.0.0.1:8000/api/server/info
  • Returns JSON with the locally stored apiKey and the detected machine ipAddress

Trade history endpoint:

  • GET http://127.0.0.1:8000/trades/history
  • Optional query params: fromDate, toDate (ISO datetime, UTC recommended)
  • If omitted, it returns the last 7 days by default

Calendar events endpoint:

  • GET http://127.0.0.1:8000/calendar/events
  • Optional query params: fromDate, toDate (ISO datetime), country (example: US), currency (example: USD)
  • Default range when omitted: last 7 days to next 7 days

WebSocket streams

Open positions stream:

  • ws://127.0.0.1:8000/ws/positions/open
  • Optional query param: intervalSeconds (poll interval, bounded to 0.2..60)
  • Events:
    • subscribed
    • positionsSnapshot
    • error
  • positionsSnapshot includes:
    • positions[].pnl (position PnL, sourced from MT5 profit)
    • totalPnl (sum of all open positions PnL)

Example JavaScript client:

const ws = new WebSocket("ws://127.0.0.1:8000/ws/positions/open?intervalSeconds=1");
ws.onmessage = (event) => {
  const payload = JSON.parse(event.data);
  console.log(payload.event, payload);
};

Build and publish package

  1. Build distribution files:
python -m pip install --upgrade build twine
python -m build
  1. Upload to PyPI:
python -m twine upload dist/*
  1. Install from PyPI and run:
pip install open-api-mt5
open-api-mt5 --port 8000

Optional: standalone executable (no Python required on target machine)

If you want users to run it without installing Python, build an executable:

python -m pip install pyinstaller
pyinstaller --onefile --name open-api-mt5 app/cli.py

The executable will be in dist/open-api-mt5.exe.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

open_api_mt5-0.4.0.tar.gz (20.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

open_api_mt5-0.4.0-py3-none-any.whl (23.8 kB view details)

Uploaded Python 3

File details

Details for the file open_api_mt5-0.4.0.tar.gz.

File metadata

  • Download URL: open_api_mt5-0.4.0.tar.gz
  • Upload date:
  • Size: 20.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for open_api_mt5-0.4.0.tar.gz
Algorithm Hash digest
SHA256 7326ed3ad3896b99037cb68c3470f7f3a85c3be83e311b904da018cf72a09163
MD5 3fca8a06f2b1ebe1683c19bbfcbd7938
BLAKE2b-256 8925f513085eb77c0306baede51c79edf9488ef1b125b2e3d768c0262169c24f

See more details on using hashes here.

File details

Details for the file open_api_mt5-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: open_api_mt5-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 23.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for open_api_mt5-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6c2b5bcd9582f295bc7dae1fb53a1feca93bbe75acf5358ac16d735f6157a282
MD5 b1f690f1c97bd44b849eb6df353de084
BLAKE2b-256 83a3b9143d932714ba4f811c5600aa6aad2cec1b6f19c2ae10d43084b88c96ac

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page