Skip to main content
You can request the most recent executed trades (fills) for the authenticated account.

Example Request

{
  "type": "get_user_trades",
  "params": {
    "limit": 10,
    "offset": 0,
    "order_id": "5b309929-206f-40ec-804d-cbe46e81afc1",
    "start_ts": 1746900000,
    "end_ts": 1746908400
  }
}
  • limit (optional) — maximum number of trades to return (default 1000)
  • offset (optional) — pagination offset (default 0)
  • order_id (optional) — filter trades by a specific exchange order ID
  • start_ts (optional) — filter trades from this Unix timestamp (inclusive)
  • end_ts (optional) — filter trades up to this Unix timestamp (inclusive)

Sample Code

# Python (websocket-client)
import json, websocket

API_KEY = "YOUR_API_KEY"

def send(ws, obj): ws.send(json.dumps(obj))

def on_open(ws):
    # Authenticate
    send(ws, {"type": "auth", "params": {"api_key": API_KEY}})
    # Request user trades with optional filters
    send(ws, {
        "type": "get_user_trades",
        "params": {
            "limit": 10,
            "offset": 0,
            "start_ts": 1746900000,
            "end_ts": 1746908400
        }
    })

ws = websocket.WebSocketApp(
    "wss://trade.qfex.com?api_key=YOUR_API_KEY",
    on_open=on_open,
    on_message=lambda _, m: print("Message:", m)
)
ws.run_forever()

Example Response

{
  "user_trades": [
    {
      "trade_id": "92adf4db-1e48-40cf-9e2a-b0ecf079a16a",
      "symbol": "AAPL-USD",
      "price": 200.0,
      "quantity": 1.0,
      "aggressor_side": "BUY",
      "order_id": "5b309929-206f-40ec-804d-cbe46e81afc1",
      "client_order_id": "my-client-oid",
      "fee": 0.002,
      "timestamp": 1746908400
    }
  ],
  "count": 1
}
Only executed trades (fills) are returned. Open orders that have not filled are excluded.