json

Change Log

Version 3.4.14 (6th November 2024)

Version 3.4.13 (30th October 2024)

Version 3.4.12 (16th September 2024)

Version 3.4.11 (21st Aug 2024)

Version 3.4.10 (10th Jul 2024)

Version 3.4.9 (29th March 2024)

Version 3.4.8 (25th October 2023)

Version 3.4.7 (20th October 2023)

Version 3.4.6 (18th Sep 2023)

Version 3.4.5 (3rd September 2023)

Version 3.4.4 (29th Aug 2023)

Version 3.4.3 (17th Aug 2023)

Version 3.4.2 (29th May 2023)

Version 3.4.1 (17th May 2023)

Version 3.4.0 (12th April 2023)

Version 3.3.9 (6th April 2023)

Version 3.3.8 (29th March 2023)

Version 3.3.7 (1th March 2023)

Version 3.3.6 (7th February 2023)

Version 3.3.5 (28th November 2022)

Version 3.3.4 (2nd September 2022)

Version 3.3.3 (15th August 2022)

Version 3.3.2 (29th March 2022)

Version 3.3.1 (2nd March 2022)

Version 3.3.0 (21st January 2022)

Version 3.2.9 (13th January 2022)

Version 3.2.8 (8th December 2021)

Version 3.2.7 (23rd November 2021)

Version 3.2.6 (19th November 2021)

Version 3.2.5 (25th October 2021)

Version 3.2.4 (1st July 2021)

Version 3.2.3 (2nd June 2021)

Version 3.2.2 (29th January 2021)

Existing endpoints will continue to be made available.

Version 3.2.1 (28th September 2020)

Version 3.2 (23rd June 2020)

Overview

Generating API Key

You will need to create an API key on the BTSE platform before you can use authenticated APIs. To create API keys, you can follow the steps below:

Endpoints

Authentication

Example 1: Place an order

HMAC SHA384 Signature

$ echo -n "/api/v3.2/order1624985375123{\"postOnly\":false,\"price\":8500.0,\"side\":\"BUY\",\"size\":0.002,\"stopPrice\":0.0,\"symbol\":\"BTC-USD\",\"time_in_force\":\"GTC\",\"trailValue\":0.0,\"triggerPrice\":0.0,\"txType\":\"LIMIT\",\"type\":\"LIMIT\"}" | openssl dgst -sha384 -hmac "848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx"
(stdin)=e9cd0babdf497b536d1e48bc9cf1fadad3426b36406b5747d77ae4e3cdc9ab556863f2d0cf78e0228c39a064ad43afb7

Rate Limits

Rate limits for BTSE is as follows:

Query

Orders

Mechanism Description

Our system implements a tiered blocking mechanism with three distinct durations: 1 second, 5 minutes, and 15 minutes. The duration of the block begins calculation from the moment the first block is imposed. Additionally, the calculation duration will be reset if the IP address or user does not exceed the rate limit within a span of 1 hour or the 15 mins blocking duration is ended.

A Retry-After header is included with a 429 response and will give the unlocked timestamp.

Rate limit tiers

API Status Codes

Each API will return one of the following HTTP status:

API Enum

When connecting up the BTSE API, you will come across number codes that represents different states or status types in BTSE. The following section provides a list of codes that you are expecting to see.

Public Endpoints

Market Summary

Response

[
  {
    "symbol": "BTC-USD",
    "last": 36976,
    "lowestAsk": 37012,
    "highestBid": 36972,
    "percentageChange": -4.633438649,
    "volume": 81456627.51106991,
    "high24Hr": 39478.5,
    "low24Hr": 36821.5,
    "base": "BTC",
    "quote": "USD",
    "active": true,
    "size": 2117.88522,
    "minValidPrice": 0.01,
    "minPriceIncrement": 0.5,
    "minOrderSize": 0.00001,
    "maxOrderSize": 2000,
    "minSizeIncrement": 0.00001,
    "openInterest": 0,
    "openInterestUSD": 0,
    "contractStart": 0,
    "contractEnd": 0,
    "timeBasedContract": false,
    "openTime": 0,
    "closeTime": 0,
    "startMatching": 0,
    "inactiveTime": 0,
    "fundingRate": 0,
    "contractSize": 0,
    "maxPosition": 0,
    "minRiskLimit": 0,
    "maxRiskLimit": 0,
    "availableSettlement": null,
    "futures": false,
    "isMarketOpenToOtc": false,
    "isMarketOpenToSpot": true
  }
]

GET /api/v3.2/market_summary

Gets market summary information. If no symbol parameter is sent, then all markets will be retrieved.

Request Parameters

name type required description
symbol string no market symbol

Response Content

Name Type Required Description
symbol string Yes Market symbol
last double Yes Last price
lowestAsk double Yes Lowest ask price in the orderbook
highestBid double Yes Highest bid price in the orderbook
percentageChange double Yes Percentage change against the price within the last 24hours
volume double Yes Transacted volume
high24Hr double Yes Highest price over the last 24hours
low24Hr double Yes Lowest price over the last 24hours
base string Yes Base currency
quote string Yes Quote currency
active boolean Yes Indicator if market is active
size double Yes Transacted size
minValidPrice double Yes Minimum valid price
minPriceIncrement double Yes Price increment
minOrderSize double Yes Minimum tick size
minSizeIncrement double Yes Tick size
maxOrderSize double Yes Maximum order size
openInterest double No Not valid for spot
openInterestUSD double No Not valid for spot
contractStart date No Not valid for spot
contractEnd date No Not valid for spot
timeBasedContract boolean No Not valid for spot
openTime date Yes Market opening time
closeTime date Yes Market closing time
startMatching date Yes Matching start time
inactiveTime date Yes Time where market is inactive
fundingRate double No Not valid for spot
contractSize double No Not valid for spot
maxPosition double No Not valid for spot
minRiskLimit double No Not valid for spot
maxRiskLimit double No Not valid for spot
availableSettlement array No Not valid for spot
futures boolean Yes Indicator if symbol is a futures contract
isMarketOpenToOtc boolean Yes Indicator if market is open to otc
isMarketOpenToSpot boolean Yes Indicator if market is open to spot

Charting Data

Response

[
  [
    1624987380,
    36477,
    36477,
    36473.5,
    36473.5,
    693.049
  ],
  [
    1624987320,
    36476.5,
    36481.5,
    36466,
    36466,
    2370.8095
  ]
]

GET /api/v3.2/ohlcv

Gets candle stick charting data. Default of 300 data points will be returned at any one time.

Request Parameters

name type required description
symbol string yes market symbol
start long no starting time in milliseconds (eg. 1624987283000)
end long no ending time in milliseconds (eg. 1624987283000)
resolution string yes supported resolutions are:
1: 1 min
5: 5 mins
15: 15 mins
30: 30 mins
60: 60 mins
240: 4 hours
360: 6 hours
1440: 1day
10080: 1 week
43200: 1 month

Response Content

Returns a 2D array with the indexes described in the table below

Index Type Required Description
0 long Yes Unix time
1 double Yes Open price
2 double Yes High Price
3 double Yes Low price
4 double Yes Closing price
5 double Yes Volume

Query Market price

Response

[
  {
    "symbol": "BTC-USD",
    "indexPrice": 36288.949684967,
    "lastPrice": 36286.5,
    "markPrice": 0
  }
]

GET /api/v3.2/price

Retrieve current prices on the platform. If no symbol specified, all symbols will be returned.

Request Parameters

Name Type Required Description
symbol string Yes Market symbol

Response Content

Name Type Required Description
symbol double Yes Market symbol
indexPrice double Yes Index price
lastPrice double Yes Last transacted price
markPrice double Yes Not valid for spot

Orderbook (By grouping)

Response

{
  "buyQuote": [
    {
      "price": "36371.0",
      "size": "0.01485"
    }
  ],
  "sellQuote": [
    {
      "price": "36380.5",
      "size": "0.01782"
    }
  ],
  "timestamp": 1624989459489,
  "symbol": "BTC-USD"
}

GET /api/v3.2/orderbook

Retrieves a Level 2 snapshot of the orderbook and allows you to specify grouping and also bid / asks depth

Request Parameters

Name Type Required Description
symbol string Yes Market symbol
group integer No Orderbook grouping. Valid values are:
0-8 where 0 indicates level 0 grouping (eg. for BTC, it will be 0.1)
Level 1 grouping for BTC would be 0.5
Level 1 grouping for BTC would be 1
limit_bids integer No Orderbook depth on the bid side
limit_asks integer No Orderbook depth on the ask side

Response Content

Orderbook

Name Type Required Description
symbol string Yes Market symbol
buyQuote Quote Yes Array of Buy quotes
sellQuote Quote Yes Array of Sell quotes
timestamp double Yes Timestamp of orderbook

Quote

Name Type Required Description
price double Yes order price
size double Yes order size

Orderbook

Response

{
  "buyQuote": [
    {
      "price": "36235.0",
      "size": "7.67500"
    }
  ],
  "sellQuote": [
    {
      "price": "36241.5",
      "size": "0.60200"
    }
  ],
  "timestamp": 1624989977940,
  "symbol": "BTC-USD"
}

GET /api/v3.2/orderbook/L2

Retrieves a Level 2 snapshot of the orderbook

Request Parameters

Name Type Required Description
symbol string Yes Market symbol
depth integer No Orderbook depth

Response Content

Orderbook

Name Type Required Description
symbol string Yes Market symbol
buyQuote Quote Yes Array of Buy quotes
sellQuote Quote Yes Array of Sell quotes
timestamp double Yes Timestamp of orderbook

Quote

Name Type Required Description
price double Yes order price
size double Yes order size

Query Trades Fills

Response

[
  {
    "price": 36164,
    "size": 0.035,
    "side": "SELL",
    "symbol": "BTC-USD",
    "serialId": 85997835,
    "timestamp": 1624990097000
  }
]

GET /api/v3.2/trades

Get trade fills for the market specified by symbol

Request Parameters

Name Type Required Description
symbol string Yes Market symbol
startTime long No Starting time in milliseconds (eg. 1624987283000)
endTime long No Ending time in milliseconds (eg. 1624987283000)
count integer No Number of records to return
Time Interval Maximum Days Explanation
startTime / endTime 30 Maximum 30 days within the specified interval
startTime / - 3 If the end time is not specified, then 3 days after the start time
- / endTime 3 If the start time is not specified, then 3 days before the end time
- / - 3 If neither start nor end time is specified, then 3 days before the current time

Response Content

Name Type Required Description
symbol string Yes Market symbol
side string Yes Trade side. Values are: [BUY, SELL]
price double Yes Transacted price
size double Yes Transacted size
serialId double Yes Serial Id, running sequence number
timestamp double Yes Transacted timestamp

Query Server Time

Response

{
  "iso": "2021-06-29T18:14:30.886Z",
  "epoch": 1624990470
}

GET /api/v3.2/time

Gets server time

Response Content

Name Type Required Description
iso long Yes Time in YYYY-MM-DDTHH24:MI:SS.Z format
epoch long Yes Returns epoch timestamp

Trade Endpoints

Create New Order

Request (create MARKET order)

{
  "symbol": "BTC-USD",
  "size": 1,
  "side": "BUY",
  "type": "MARKET"
}

Request (create LIMIT order)

{
  "symbol": "BTC-USD",
  "size": 1,
  "price": 34000,
  "side": "BUY",
  "type": "LIMIT"
}

Request (create OCO order)

{
  "symbol": "BTC-USD",
  "size": 1,
  "price": 24000,
  "side": "BUY",
  "type": "OCO",
  "txType": "LIMIT",
  "stopPrice": 40010,
  "triggerPrice": 40000
}

Request (create PEG order)

{
  "symbol": "BTC-USD",
  "size": 1,
  "price": 25000,
  "side": "BUY",
  "type": "PEG",
  "deviation": -10,
  "stealth": 10
}

Response (general)

[
  {
    "status": 2,
    "symbol": "BTC-USD",
    "orderType": 80,
    "price": 22062.5,
    "side": "BUY",
    "size": 1.0,
    "orderID": "990db9b6-2ed4-4c68-b46e-827c88cc3884",
    "timestamp": 1660208800123,
    "triggerPrice": 0.0,
    "stopPrice": null,
    "trigger": false,
    "message": "",
    "averageFillPrice": 0.0,
    "fillSize": 0.0,
    "clOrderID": null,
    "stealth": 0.1,
    "deviation": -0.1,
    "postOnly": false,
    "originalSize": 1.0,
    "remainingSize": 1.0,
    "time_in_force": "GTC"
  }
]

Response (for OCO order)

[
    {
        "status": 2,
        "symbol": "BTC-USD",
        "orderType": 76,
        "price": 24000.0,
        "side": "BUY",
        "size": 1.0,
        "orderID": "2b672b4b-77c1-4abf-ba30-df3e82a147b0",
        "timestamp": 1660211562864,
        "triggerPrice": 0.0,
        "stopPrice": null,
        "trigger": false,
        "message": "",
        "averageFillPrice": 0.0,
        "fillSize": 0.0,
        "clOrderID": null,
        "stealth": 1.0,
        "deviation": 1.0,
        "postOnly": false,
        "originalSize": 1.0,
        "remainingSize": 1.0,
        "time_in_force": "GTC"
    },
    {
        "status": 9,
        "symbol": "BTC-USD",
        "orderType": 76,
        "price": 40010.0,
        "side": "BUY",
        "size": 1.0,
        "orderID": "7ccf5398-fddd-4d07-a89c-a4f2e72b64ce",
        "timestamp": 1660211562864,
        "triggerPrice": 40000.0,
        "stopPrice": null,
        "trigger": true,
        "message": "",
        "averageFillPrice": 0.0,
        "fillSize": 0.0,
        "clOrderID": null,
        "stealth": 1.0,
        "deviation": 1.0,
        "postOnly": false,
        "originalSize": 1.0,
        "remainingSize": 0.0,
        "time_in_force": "GTC"
    }
]

POST /api/v3.2/order or POST /api/v3.2/order/peg (The 2 endpoints work identically)

Creates a new order. Requires Trading permission. Please note that Index Order only supports USD quotes.

Request Parameters

Name Type Required Description
symbol string Yes Market symbol
price double No Mandatory unless creating a MARKET order. Minimum price for a sell order, this is the lowest price that a user is willing to sell at. Maximum price for a buy order, this is the maximum price a user is willing to buy at.
size double Yes Order size
side string Yes 'BUY' or 'SELL'
time_in_force string No Time validity of the order
GTC: Good till Cancel
IOC: Immediate or Cancel
FOK: Fill or Kill
HALFMIN: Order valid for 30 seconds
FIVEMIN: Order valid for 5 mins
HOUR: Order valid for an hour
TWELVEHOUR: Order valid for 12 hours
DAY: Order valid for a day
WEEK: Order valid for a week
MONTH: Order valid for a month
type string Yes Order type
LIMIT: Limit Orders
MARKET: Market Orders
OCO: One cancel the other
PEG: price is according to a deviation to the Index price
txType string No Used for Stop orders or trigger orders
STOP: Stop Order, stopPrice is mandatory
TRIGGER: Trigger order, triggerPrice is mandatory
LIMIT: Default, used when its not a Stop order nor Trigger order
stopPrice double No Mandatory when creating a Stop or OCO order. Indicates the stop price
triggerPrice double No Mandatory when creating a Trigger or OCO order. Indicates the trigger price
trailValue double No Trail value
postOnly boolean No Boolean to indicate if this is a post only order. For post only orders, traders are charged maker fees
clOrderID string No Custom order Id
stealth double No Mandatory when creating a PEG order. How many percent of the order is to be displayed on the orderbook.
deviation double No For PEG order. How much should the order price deviate from index price. Value is in percentage and can range from -10 to 10

Response Content

Name Type Required Description
symbol string Yes Market symbol
clOrderID string Yes Customer tag sent in by trader
fillSize double Yes Trade filled size
orderID string Yes Order ID
orderType integer Yes Order type
76: Limit order
77: Market order
80: Peg/Algo order
postOnly boolean Yes Indicates if order is a post only order
price double Yes Order price
side string Yes Order side
BUY or SELL
size double Yes Order size
status integer Yes Order status
2: Order Inserted
4: Order Fully Transacted
5: Order Partially Transacted
6: Order Cancelled
7: Order Refunded
8: Insufficient Balance
9: Trigger Inserted
10: Trigger Activated
15: Order Rejected
16: Order Not Found
17: Request Failed
stopPrice double Yes Stop price
time_in_force string Yes Order validity
timestamp long Yes Order timestamp
trigger boolean Yes Indicator if order is a trigger order
triggerPrice double Yes Order trigger price, returns 0 if order is not a trigger order
averageFillPrice double Yes Average filled price. Returns the average filled price for partially transacted orders
message string Yes Trade messages
stealth double Yes Stealth value of order
deviation double Yes Deviation value of order
remainingSize double Yes Size left to be transacted
originalSize double Yes Original order size

Query Order

Response

{
  "orderID": "<Order UUID>",
  "symbol": "BTC-USDT",
  "quote": "USDT",
  "status": 6,
  "orderType": 76,
  "price": 30000,
  "size": 0.00001,
  "side": "SELL",
  "orderValue": 0.300102,
  "trailValue": 0,
  "filledSize": 0,
  "remainingSize": 0.00001,
  "averageFillPrice": 0,
  "clOrderID": "<Client OrderID>",
  "timeInForce": "GTC",
  "timestamp": 1697766317422,
  "pegPriceMin": 0,
  "pegPriceMax": 0,
  "pegPriceDeviation": 0,
  "triggerOrder": false,
  "triggerPrice": 0,
  "triggerOriginalPrice": 0,
  "triggerOrderType": 0,
  "triggerTrailingStopDeviation": 0,
  "triggerStopPrice": 0,
  "triggered": false
}

GET /api/v3.2/order

Query order detail for a specified orderID/clOrderID, for the open orders and cancelled order which is cancelled in 30 minutes only. Please note that this API is Trading permission required.

Request Parameters

Name Type Required Description
orderID String No Unique identifier for an order. Mandatory when clOrderID is not provided. If orderID is provided, clOrderID will be ignored.
clOrderID String No Client custom order ID. Mandatory when orderID is not provided.

Response Content

Name Type Required Description
orderID String Yes Order ID
symbol String Yes Market symbol
quote String Yes Quote symbol
orderType Integer Yes Order type
side String Yes Order side
price Double Yes Order price
size Double Yes Order size
orderValue Double Yes Total value of of this order
filledSize Double Yes Filled Size
pegPriceMin Double Yes Minimum possible peg price this takes precedence over pegPriceDeviation
pegPriceMax Double Yes Peg Price Max (New Entry)
pegPriceDeviation Double Yes Percentage deviation from Index price
timestamp Long Yes Order timestamp
triggerOrder Boolean Yes Indicator if order is a trigger order
triggerPrice Double Yes Order trigger price, returns 0 if order is not a trigger order
triggerOriginalPrice Double Yes Price of the original order. Only valid if it's a triggered order
triggerOrderType Integer Yes Order type
triggerTrailingStopDeviation Double Yes Percentage deviation from stop price
triggerStopPrice Double Yes Stop price, Algo Order only
triggered Boolean Yes Indicate whether the order is triggered
trailValue Double Yes Trail value
clOrderID String Yes Customer tag sent in by trader
averageFillPrice Double Yes Average filled price. Returns the average filled price for partially transacted orders
remainingSize Double Yes remainingSize
status Integer Yes Order status. Please refer to API Enum
timeInForce String Yes Order validity

Amend Order

Request (amend price)

{
  "symbol": "BTC-USD",
  "orderID": "25248336-66d8-41ff-99fd-83489c4e6029",
  "type": "PRICE",
  "value": 35000
}

Request (amend size)

{
  "orderID": "689bf733-4879-4e32-8d1f-cb81f63d24d4",
  "type": "SIZE",
  "value": 1.05,
  "symbol": "BTC-USD"
}

Request (amend trigger price)

{
  "orderID": "cb2785b0-558e-4b30-bf1f-8a8c56174d0c",
  "type": "TRIGGERPRICE",
  "value": 40020,
  "symbol": "BTC-USD"
}

Request (amend multiple attributes)

{
  "symbol": "BTC-USD",
  "orderID": "cb2785b0-558e-4b30-bf1f-8a8c56174d0c",
  "type": "ALL",
  "orderPrice": 40010,
  "orderSize": 1.05,
  "triggerPrice": 40000
}

Response

[
  {
    "status": 15,
    "symbol": "BTC-null",
    "orderType": 0,
    "price": 0.0,
    "side": "BUY",
    "size": 1.0,
    "orderID": "25248336-66d8-41ff-99fd-83489c4e6029",
    "timestamp": 1660277763249,
    "triggerPrice": 0.0,
    "stopPrice": null,
    "trigger": false,
    "message": "",
    "averageFillPrice": 0.0,
    "fillSize": 0.0,
    "clOrderID": "",
    "stealth": 0.0,
    "deviation": 0.0,
    "postOnly": false,
    "originalSize": 1.0,
    "remainingSize": 1.0,
    "time_in_force": "GTC"
  }
]

PUT /api/v3.2/order

Amend the price or size or trigger price of an order. For trigger orders, if the order has already been triggered, the trigger price cannot be further amended. Amend order does not apply to algo orders. Requires Trading permission.

Request Parameters

Name Type Required Description
symbol string Yes Market symbol
orderID string No Internal order ID. Mandatory when clOrderID is not provided. If orderID is provided, clOrderID will be ignored.
clOrderID string No Custom order ID. Mandatory when orderID is not provided.
type string Yes Type of amendment
PRICE: To amend order price
SIZE: To amend order size
TRIGGERPRICE: To amend trigger price
ALL: to amend multiple fields
value double No Mandatory for types: PRICE, SIZE, TRIGGERPRICE. The value to be amended to. Value depends on the type being set.
orderPrice double No For type: ALL, order price to be amended
orderSize double No For type: ALL, order size to be amended
triggerPrice double No For type: ALL, trigger price to be amended

Response Content

Name Type Required Description
symbol string Yes Market symbol
clOrderID string Yes Customer tag sent in by trader
fillSize double Yes Trade filled size
orderID string Yes Order ID
orderType integer Yes Order type
76: Limit order
77: Market order
80: Peg/Algo order
postOnly boolean Yes Indicates if order is a post only order
price double Yes Order price
side string Yes Order side
BUY or SELL
size double Yes Order size
status integer Yes Order status
2: Order Inserted
4: Order Fully Transacted
5: Order Partially Transacted
6: Order Cancelled
7: Order Refunded
8: Insufficient Balance
9: Trigger Inserted
10: Trigger Activated
15: Order Rejected
16: Order Not Found
17: Request Failed
stopPrice double Yes Stop price
time_in_force string Yes Order validity
timestamp long Yes Order timestamp
trigger boolean Yes Indicator if order is a trigger order
triggerPrice double Yes Order trigger price, returns 0 if order is not a trigger order
averageFillPrice double Yes Average filled price. Returns the average filled price for partially transacted orders
message string Yes Trade messages
stealth double Yes Stealth value of order
deviation double Yes Deviation value of order

Cancel Order

Request

/api/v3.2/order?symbol=BTC-USD&clOrderID=my-order-id

Response (general)

[
  {
    "status": 6,
    "symbol": "BTC-USD",
    "orderType": 76,
    "price": 24000.0,
    "side": "BUY",
    "size": 1.0,
    "orderID": "9be4a6bb-bf56-4a81-a105-2a22c9629a48",
    "timestamp": 1660278598333,
    "triggerPrice": 0.0,
    "stopPrice": null,
    "trigger": false,
    "message": "",
    "averageFillPrice": 0.0,
    "fillSize": 0.0,
    "clOrderID": "jack-test-1",
    "stealth": 1.0,
    "deviation": 1.0,
    "postOnly": false,
    "originalSize": 1.0,
    "remainingSize": 1.0,
    "time_in_force": "GTC"
  }
]

Response (for OCO order)

[
  {
    "status": 6,
    "symbol": "BTC-USD",
    "orderType": 76,
    "price": 23000.0,
    "side": "BUY",
    "size": 1.0,
    "orderID": "e3806536-776c-4d8f-8436-bde12a79620b",
    "timestamp": 1660286055127,
    "triggerPrice": 0.0,
    "stopPrice": null,
    "trigger": false,
    "message": "",
    "averageFillPrice": 0.0,
    "fillSize": 0.0,
    "clOrderID": "",
    "stealth": 1.0,
    "deviation": 1.0,
    "postOnly": false,
    "originalSize": 1.0,
    "remainingSize": 1.0,
    "time_in_force": "GTC"
  },
  {
    "status": 6,
    "symbol": "BTC-USD",
    "orderType": 76,
    "price": 0.0,
    "side": "BUY",
    "size": 1.0,
    "orderID": "ad4d0eeb-81a1-48f4-86c3-90436bb53718",
    "timestamp": 1660286055128,
    "triggerPrice": 40010.0,
    "stopPrice": null,
    "trigger": true,
    "message": "",
    "averageFillPrice": 0.0,
    "fillSize": 0.0,
    "clOrderID": "",
    "stealth": 1.0,
    "deviation": 1.0,
    "postOnly": false,
    "originalSize": 1.0,
    "remainingSize": 0.0,
    "time_in_force": "GTC"
  }
]

DELETE /api/v3.2/order

Cancels pending orders that has not yet been transacted. The orderID is a unique identifier to cancel a particular order. clOrderID is a custom ID sent in by the trader. When cancel by clOrderID, all orders having the same ID will be cancelled. If orderID and clOrderID is not sent in, then cancellation will be for all orders in the current market. Requires Trading permission.

Request Parameters

Name Type Required Description
symbol string Yes Market symbol
orderID string No Unique identifier for an order. Mandatory when clOrderID is not provided. If orderID is provided, clOrderID will be ignored.
clOrderID string No Client custom order ID. Mandatory when orderID is not provided.

Response Content

Name Type Required Description
symbol string Yes Market symbol
clOrderID string Yes Customer tag sent in by trader
fillSize double Yes Trade filled size
orderID string Yes Order ID
orderType integer Yes Order type
76: Limit order
77: Market order
80: Peg/Algo order
postOnly boolean Yes Indicates if order is a post only order
price double Yes Order price
side string Yes Order side
BUY or SELL
size double Yes Cancelled size
status integer Yes Order status
2: Order Inserted
3: Order Transacted
4: Order Fully Transacted
5: Order Partially Transacted
6: Order Cancelled
7: Order Refunded
9: Trigger Inserted
10: Trigger Activated
15: Order Rejected
16: Order Not Found
17: Request failed
stopPrice double Yes Stop price
time_in_force string Yes Order validity
timestamp long Yes Order timestamp
trigger boolean Yes Indicator if order is a trigger order
triggerPrice double Yes Order trigger price, returns 0 if order is not a trigger order
averageFillPrice double Yes Average filled price. Returns the average filled price for partially transacted orders
message string Yes Trade messages
stealth double Yes Stealth value of order
deviation double Yes Deviation value of order

Dead Man's Switch (Cancel All After)

Request

{
  "timeout": 60000
}

POST /api/v3.2/order/cancelAllAfter

Dead-man's switch allows the trader to send in a timeout value which is a Time to live (TTL) value for an order. Extension of the timeout is done by sending another cancelAllAfter request. If the server does not receive another request before the timeout is reached, all orders will be cancelled. Requires Trading permission.

Request Parameters

Name Type Required Description
timeout long Yes Timeout value in milliseconds

Response Content

Query Open Orders

Response

[
  {
    "orderType": 76,
    "price": 35000.0,
    "size": 0.01,
    "side": "BUY",
    "orderValue": 350.0,
    "filledSize": 0.0,
    "pegPriceMin": 0.0,
    "pegPriceMax": 0.0,
    "pegPriceDeviation": 0.0,
    "cancelDuration": 0,
    "timestamp": 1660291619263,
    "orderID": "3c9c9c1f-8fef-43d0-82c7-ccef67435b14",
    "triggerOrder": false,
    "triggerPrice": 0.0,
    "triggerOriginalPrice": 0.0,
    "triggerOrderType": 0,
    "triggerTrailingStopDeviation": 0.0,
    "triggerStopPrice": 0.0,
    "symbol": "BTC-USD",
    "trailValue": 0.0,
    "averageFillPrice": 0.0,
    "fillSize": 0.0,
    "clOrderID": "_yndef1660291619198",
    "orderState": "STATUS_ACTIVE",
    "timeInForce": "GTC",
    "triggered": false
  }
]

GET /api/v3.2/user/open_orders

Retrieves open orders that have not yet been matched or matched recently. Requires Trading permission.

Request Parameters

Name Type Required Description
symbol string No Market symbol
orderID string No Query using internal order ID
clOrderID string No Query using custom order ID. If orderID is provided, clOrderID will be ignored.

Response Content

Name Type Required Description
orderType integer Yes Order type
76: Limit order
77: Market order
80: Peg/Algo order
price double Yes Order price
size double Yes Order size
side string Yes Order side
BUY or SELL
orderValue double Yes Total value of of this order
filledSize double Yes Filled size
pegPriceMin double Yes Minimum possible peg price this takes precedence over pegPriceDeviation
pegPriceMax double Yes Maximum possible peg price this takes precedence over pegPriceDeviation
pegPriceDeviation double Yes Percentage deviation from Index price
cancelDuration double Yes Order expiration time if not 0
timestamp long Yes Order placement time
orderID string Yes Order Id
triggerOrder bool Yes Indicator if order is a trigger order
triggerPrice double Yes Order trigger price, returns 0 if order is not a trigger order
triggerOriginalPrice double Yes Price of the original order. Only valid if it's a triggered order
triggerOrderType double Yes Order type
76: Limit order
77: Market order
80: Peg/Algo order
triggerTrailingStopDeviation double Yes Percentage deviation from stop price
triggerStopPrice double Yes Stop price, Algo Order only
symbol string Yes Market name (e.g. BTC-USD)
trailValue double Yes Trail value
averageFillPrice double Yes Average filled price. Returns the average filled price for partially transacted orders
fillSize double Yes Fill size
clOrderID string Yes Customer order ID
orderState string Yes STATUS_ACTIVE, STATUS_INACTIVE
timeInForce string Yes Order validity
triggered bool Yes Indicate whether the order is triiggered

Query User Trades Fills

Response

[
  {
    "tradeId": "9c6d016f-fbe3-4f82-aecc-8163e9220397",
    "orderId": "ba0b69ae-991e-494a-afcb-bfbaeb1adc55",
    "clOrderID": "_W_dmoryhbw1698118893191",
    "username": "btse",
    "side": "BUY",
    "orderType": 77,
    "triggerType": 0,
    "price": 34799.000000025,
    "size": 0.4,
    "filledPrice": 34799.000000025,
    "filledSize": 0.00001,
    "triggerPrice": 0,
    "base": "BTC",
    "quote": "USDT",
    "symbol": "BTC-USDT",
    "feeCurrency": "BTC",
    "feeAmount": 0.000000006,
    "wallet": "SPOT@",
    "realizedPnl": 0,
    "total": 0,
    "serialId": 94711228,
    "timestamp": 1698118893000,
    "averageFillPrice": 34799.000000025
  }
]

GET /api/v3.2/user/trade_history

Retrieves a user's trade history which includes funding fee data. Requires Read permission.

Request Parameters

Name Type Required Description
symbol string Yes Market symbol
startTime long No Starting time in milliseconds (eg. 1624987283000)
endTime long No Ending time in milliseconds (eg. 1624987283000)
count integer No Number of records to return
clOrderID string No Query trade history by custom order ID
orderID string No Query trade history by order ID
isMatchSymbol boolean No Exact match on symbol. If this sets to true, will only match records for that symbol only
Time Interval Maximum Days Explanation
startTime / endTime 7 Maximum 7 days within the specified interval. If specified interval exceeds 7 days, the start time will be set to 7 days before the end time
startTime / - 7 If the end time is not specified, then 7 days after the start time
- / endTime 7 If the start time is not specified, then 7 days before the end time
- / - 7 If neither start nor end time is specified, then 7 days before the current time

Response Content

Name Type Required Description
symbol string Yes Market symbol
side string Yes Trade side. Values are: [BUY, SELL]
price double yes Transacted price
size double yes Original order size
serialId long yes Serial id, running sequence number
tradeId string yes Trade identifier
timestamp long yes Transacted timestamp
base long yes Base currency
quote long yes Quote currency
clOrderID long yes Custom order id
orderId long yes Order id
feeAmount long yes Fee amount
feeCurrency long yes Fee currency
filledPrice long yes Filled price
filledSize long yes Filled size
orderType integer yes Order type
realizedPnl long yes Not used in spot
total long yes Not used in spot
triggerType integer yes 1001: Stop Loss 1002: Take Profit
triggerPrice double yes Trigger price
wallet string yes SPOT@ for spot transactions
averageFillPrice string yes Average fill price
username string yes Username

query account fees

response

{
  "makerfee": 0,
  "symbol": "btc-usd",
  "takerfee": 0
}

GET /api/v3.2/user/fees

Retrieve user's trading fees. Requires Read permission.

request parameters

name type required description
symbol string no market symbol to filter for specific market

response content

name type required description
symbol string yes market symbol
makerfee double yes maker fees
takerfee double yes taker fees

Investment Endpoints

Query Investment Products

response

[
  {
    "id": "openeth00001",
    "name": "eth flex savings",
    "currency": "eth",
    "type": "flex",
    "startdate": 1610685918000,
    "intereststartdate": 1610719200000,
    "rates":
    [
      {
        "days": 1,
        "rate": 1.15
      }
    ],
    "compounding": true,
    "autorenewsupported": false,
    "dailylimit": 10.0,
    "minsize": 1.00000000,
    "incrementalsize": 1.00000000
  }
]

GET /api/v3.2/invest/products

Get all investment products. Requires Read permission.

request parameters

(none)

response content

name type required description
id string yes product id
name string yes product name
currency string yes currency
type string yes product type
startdate long yes inventment start date
intereststartdate long yes interest start date
rates rateobject[] yes interest rate information
compounding double yes is product compounding
autorenewsupported double yes is product supported renew automatically
dailylimit double yes daily invent amount limit
minsize double yes minimum invest size
incrementalsize double yes invest step size

rateobject

name type required description
days integer yes duration in days
rate double yes interest rate

Deposit Investment

request

{
    "productId": "openusdt0001",
    "amount": 100.99
}

POST /api/v3.2/invest/deposit

Deposit an investment. Requires Wallet permission.

request parameters

name type required description
productId string yes invest product id
amount double yes invest amount

Renew Investment

request

{
    "orderId": 1,
    "autoRenew": false
}

response

{
    "orderId": 1,
    "autoRenew": false
}

POST /api/v3.2/invest/renew

Renew an investment order. Requires Wallet permission.

request parameters

name type required description
orderId integer yes investment order id
autoRenew boolean yes renew automatically

response content

name type required description
orderId integer yes investment order id
autoRenew boolean yes status of autoRenew flag

Redeem Investment

request

{
    "orderId": 1,
    "amount": 12.34
}

POST /api/v3.2/invest/redeem

Redeem an investment order. Requires Wallet permission.

request parameters

name type required description
orderId integer yes investment order id
amount double yes redeem amount

Query Investment Orders

response

[
  {
    "id": 456,
    "name": "eth flex savings",
    "currency": "eth",
    "type": "flex",
    "rate": 1.15,
    "investamt": 10.00000000,
    "interestearned": 0.00031507,
    "nextinterestpayouttime": 1610632800000,
    "starttime": 0,
    "endtime": 0,
    "duration": 86400000,
    "payoutlocktime": 300000,
    "autorenew": false,
    "compounding": true,
    "autorenewsupported": false,
    "dailylimit": 0,
    "redemptionprocessing": false
  }
]

GET /api/v3.2/invest/orders

Query investment orders. Requires Wallet permission.

response content

name type required description
id integer yes order id
name string yes product name
currency string yes currency
type string yes product type
rate double yes interest rate
investment double yes amount
interestearned double yes intereset earned
nextinterestpayouttime integer yes next interest payout time
starttime integer yes start time
endtime integer yes end time
duration integer yes duration
payoutlocktime integer yes lock time of payout
autorenew boolean yes renew automatically
compounding boolean yes is compounding
autorenewsupported boolean yes is renew automatically supported
redemptionprocessing boolean yes is redemption processing

Query Investment History

response

[
  {
    "txntime": 1598918400000,
    "name": "usdt flex savings",
    "currency": "usdt",
    "rate": 0.5,
    "type": "flex",
    "txntype": "invest_service_type_deposit",
    "amount": 100,
    "totalamount": 2000,
    "interestearned": 1.22,
    "duration": 0
  }
]

GET /api/v3.2/invest/history

Query investment history. Requires Wallet permission.

response content

name type required description
txntime integer yes transaction time
name string yes product name
currency string yes currency
rate string yes interest rate
type boolean yes product type
txntype string yes transaction type
amount double yes transaction amount
totalamount double yes total amount of the investment
interestearned double yes interest earned
duration boolean yes duration

Order Book Websocket Streams

Endpoints

OSS L1 Snapshot (By grouping)

Request

{
  "op": "subscribe",
  "args": [
    "snapshotL1:BTC-USD_0"
  ]
}

{
  "op": "unsubscribe",
  "args": [
    "snapshotL1:BTC-USD_0"
  ]
}

Response

{
  "topic": "snapshotL1:BTC-USD_0",
  "data": {
    "bids": [
      [
          "28016.7",
          "1.48063"
      ]
    ],
    "asks": [
      [
          "28033.6",
          "1.34133"
      ]
    ],
    "type": "snapshotL1",
    "symbol": "BTC-USD",
    "timestamp": 1680750154232
  }
}

Subscribe to the Level 1 Orderbook through the endpoint wss://ws.btse.com/ws/oss/spot. The format to subscribe to will be symbol_grouping.

Response Content

Orderbook Object

Name Type Required Description
topic string Yes Websocket topic
data Data Object Yes Refer to data object below

Data Object

Name Type Required Description
bids Quote Object Yes Bid quotes
asks Quote Object Yes Asks quotes
symbol string Yes Market symbol
type string Yes snapshotL1 - L1 data refers to the best bid / best ask of a trading pair’s order book.
timestamp long Yes Orderbook timestamp

Orderbook Incremental Updates

Request

{
  "op": "subscribe",
  "args": [
    "update:BTC-USD_0"
  ]
}
{
  "op": "unsubscribe",
  "args": [
    "update:BTC-USD_0"
  ]
}

Response

{
  "topic": "update:BTC-USD_0",
  "data": {
    "bids": [
      [
        "59252.5",
        "0.06865"
      ],
      [
        "59249.0",
        "0.24000"
      ],
      [
        "59235.5",
        "0.16073"
      ],
      [
        "59235.0",
        "0.26626"
      ],
      [
        "59233.0",
        "0.50000"
      ]
    ],
    "asks": [
      [
        "59292.0",
        "0.50000"
      ],
      [
        "59285.5",
        "0.24000"
      ],
      [
        "59285.0",
        "0.15598"
      ],
      [
        "59282.5",
        "0.06829"
      ],
      [
        "59278.5",
        "0.01472"
      ]
    ],
    "seqNum": 628282,
    "prevSeqNum": 628281,
    "type": "snapshot",
    "timestamp": 1565135165600,
    "symbol": "BTC-USD"
  }
}
{
  "topic": "update:BTC-USD",
  "data": {
    "bids": [],
    "asks": [
      [
        "59367.5",
        "2.15622"
      ],
      [
        "59325.5",
        "0"
      ]
    ],
    "seqNum": 628283,
    "prevSeqNum": 628282,
    "type": "delta",
    "timestamp": 1565135165600,
    "symbol": "BTC-USD"
  }
}

Subscribe to Orderbook incremental updates through the endpoint wss://ws.btse.com/ws/oss/spot. The format of topic will be update:symbol_grouping (eg. update:BTC-USD_0). The first response received will be a snapshot of the current orderbook (this is indicated in the type field) and 50 levels will be returned. Incremental updates will be sent in subsequent packets with type delta.

Bids and asks will be sent in price and size tuples. The size sent will be the new updated size for the price. If a value of 0 is sent, the price should be removed from the local copy of the orderbook.

To ensure that the updates are received in sequence, seqNum indicates the current sequence and prevSeqNum refers to the packet before. seqNum will always be one after the prevSeqNum. If the sequence is out of order, you will need to unsubscribe and re-subscribe to the topic again.

Also if crossed orderbook ever occurs when the best bid higher or equal to the best ask, please unsubscribe and re-subscribe to the topic again.

Response Content

Orderbook Object

Name Type Required Description
topic string Yes Websocket topic
data Data Object Yes Refer to data object below

Data Object

Name Type Required Description
bids Quote Object Yes Bid quotes
asks Quote Object Yes Asks quotes
seqNum int Yes Current sequence number
prevSeqNum int Yes Previous sequence number
type string Yes snapshot - Snapshot of the orderbook with a maximum of 50 levels
delta - Updates of the orderbook
timestamp long Yes Timestamp of the orderbook
symbol string Yes Orderbook symbol

Orderbook Error Response

Error Code Message
1000 Market pair provided is currently not supported.
1001 Operation provided is currently not supported.
1002 Invalid request. Please check again your request and provide all information required.
1005 Topic provided does not exist.
1007 User message buffer is full.
1008 Reached maximum failed attempts, closing the session.

Websocket Streams

Endpoints

Ping/Pong

For all our WebSocket servers, simply send a 'ping' message, and the WebSocket server will respond with a 'pong' message if the WebSocket connection is established and active.

Request

ping

Response

pong

Subscription

request

{
  "op": "subscribe",
  "args": [
    "tradeHistoryApi:BTC-USD"
  ]
}

response

{
  "event": "subscribe",
  "channel": [
    "tradeHistoryApi:BTC-USD"
  ]
}

to subscribe to a websocket public trade fill

request parameters

name type required description
op string yes operation. subscribe will subscribe to the topics provided in args. unsubscribe will unsubscribe from the topics
args array yes topics to subscribe to.

response content

Name Type Required Description
event string Yes Respond with the event type
channel array Yes Topics which have been sucessfully subscribed

Public Trade Fills

Request

{
  "op": "subscribe",
  "args": [
    "tradeHistoryApi:BTC-USD"
  ]
}

Response

{
  "topic": "tradeHistoryApi:BTC-USD",
  "data": [
  {
    "symbol": "BTC-USD",
    "side": "SELL",
    "size": 0.007,
    "price": 5302.8,
    "tradeId": 118974855,
    "timestamp": 1584446020295
  }
  ]
}

Subscribe to recent trade feed for a market. The topic will be tradeHistoryApi:<market> where <market> is the market symbol.

Response Content

TradeHistory Object

Name Type Required Description
topic string Yes Websocket topic
data Data Object Yes Refer to data object below

Data Object

Name Type Required Description
symbol string Yes Market symbol
side string Yes Trade Side, BUY or SELL
size double Yes Transacted size
price double Yes Transacted price
tradeId long Yes Trade sequence Id
timestamp long Yes Trade timestamp

Authentication

Request

{
  "op":"authKeyExpires",
  "args":["APIKey", "nonce", "signature"]
}

Authenticate the websocket session to subscribe to authenticated websocket topics. Assume we have values as follows:

Our subscription request will be:

{
  "op":"authKeyExpires",
  "args":["4e9536c79f0fdd72bf04f2430982d3f61d9d76c996f0175bbba470d69d59816x", "1624985375123", "c410d38c681579adb335885800cff24c66171b7cc8376cfe43da1408c581748156b89bcc5a115bb496413bda481139fb"]
}

Request Parameters

Below details the arguments needed to be sent in.

Index Type Required Description
0 string Yes First argument is the API key
1 long Yes Nonce which is the current timestamp
2 string Yes Generated signature

Generating a signature

echo -n "/ws/spot1624985375123"  | openssl dgst -sha384 -hmac "848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx"
(stdin)= c410d38c681579adb335885800cff24c66171b7cc8376cfe43da1408c581748156b89bcc5a115bb496413bda481139fb

Notifications

Request

{
  "op": "subscribe",
  "args": [
    "notificationApiV2"
  ]
}

Response

{
  "topic": "notificationApiV2",
  "data": {
      "symbol": "Market Symbol (eg. BTC-USD)",
      "orderID": "BTSE internal order ID",
      "side": "BUY",
      "type": "76",
      "price": "Order price or transacted price",
      "size": "Order size or transacted size",
      "originalSize": "Order size",
      "avgFillPrice": 35000,
      "fillSize": 0.001,
      "status": "<Refer to Status description on the left>",
      "clOrderID": "<Client order ID>",
      "maker": "<Maker flag, if true indicates that trade is a maker trade>",
      "stealth": 1,
      "timestamp": 1624985375123,
      "pegPriceDeviation": "Indicate the deviation percentage. Valid for only algo orders.",
      "remainingSize": "<Remaining size on the order>",
      "time_in_force": "<Time where this order is valid>",
      "txType": 0,
      "triggerPrice": "Trade Trigger Price"
    }
}

Receive trade notifications by subscribing to the topic notificationApiV2. The websocket feed will push trade level notifications to the subscriber. If topic is subscribed without being authenticated, no messages will be sent.

Response Content

Name Type Required Description
symbol string Yes Market symbol
orderID string Yes Internal order ID
side string Yes Trade side. BUY or SELL
type int Yes Order type. Valid values are:
76: Limit order
77: Market order
80: Peg/Algo order
price double Yes Order price or transcated price
size double Yes Order size or transacted size
originalSize double Yes Original order size
avgFilledPrice double Yes Average filled price
fillSize double Yes Filled size of order
status integer Yes Status with values as follows:
1: MARKET_UNAVAILABLE, Market is currently unavailable
2: ORDER_INSERTED, Order is inserted successfully
4: ORDER_FULLY_TRANSACTED, Order is fully transacted
5: ORDER_PARTIALLY_TRANSACTED, Order is partially transacted
6: ORDER_CANCELLED, Order is cancelled successfully
8: INSUFFICIENT_BALANCE, Insufficient balance in account
9: TRIGGER_INSERTED, Trigger Order is inserted successfully
10: TRIGGER_ACTIVATED, Trigger Order is activated successfully
12: ERROR_UPDATE_RISK_LIMIT, Error in updating risk limit
15: ORDER_REJECTED, Change made to the order was unsuccessful
27: TRANSFER_SUCCESSFUL, Transfer funds between futures and spot is successful
28: TRANSFER_UNSUCCESSFUL, Transfer funds between spot and futures is unsuccessful
41: ERROR_INVALID_RISK_LIMIT, Invalid risk limit was specified
64: STATUS_LIQUIDATION, Account is undergoing liquidation
101: FUTURES_ORDER_PRICE_OUTSIDE_LIQUIDATION_PRICE, Futures order is outside of liquidation price
1003: ORDER_LIQUIDATION, Order is undergoing liquidation
1004: ORDER_ADL, Order is undergoing ADL
clOrderID string Yes Custom order ID
maker boolean Yes Indicator to indicate if trade is a maker trade
remainingSize double Yes Remaining size on the order
time_in_force string Yes Validity of the order
timestamp long Yes Order timestamp or transacted timestamp
txType integer Yes Used by trigger or OCO orders. STOP indicates its a Stop order, TAKEPROFIT indicates its a take profit order, and LIMIT is when its not any of the above
stealth double Yes Percentage of orders to show on orderbook. Only for Algo orders
pegPriceDeviation double Yes Deviation percentage. Only for Algo orders
triggerPrice double Yes Trigger Price

User Trade Fills

Request

{
    "op":"subscribe",
    "args":["fills"]
}

Response

{
  "topic": "fills",
  "data": [{
    "orderId": "order id",
    "serialId": "serial ID after insertion into DB",
    "clOrderId": "Client Order ID",
    "type": "order type",
    "symbol": "ex: BTC-USD",
    "side": "BUY|SELL",
    "price": "filled price",
    "size": "filled size",
    "feeAmount": "Fees charged to user, value to be String on API",
    "feeCurrency": "Fee currency, eg. Buy would be BTC, Sell would be USD",
    "base": "Base currency, eg. BTC",
    "quote": "Quote currency eg. USD",
    "maker": "maker or taker",
    "timestamp": "Time trade was matched in the engine",
    "tradeId": "Trade Unique ID"
  }]
}


When a trade has been transacted, this topic will send the trade information back to the subscriber.

Response Content

Name Type Required Description
symbol string Yes Market symbol
orderId string Yes Internal order ID
clOrderId string Yes Custom order ID
serialId string Yes Trade sequence ID
tradeId string Yes Trade unique identifier
type int Yes Order type. Valid values are:
76: Limit order
77: Market order
80: Peg/Algo order
side string Yes Trade side. BUY or SELL
price double Yes Transcated price
size double Yes Transacted size
feeAmount double Yes Fee amount charged
feeCurrency string Yes Fee currency
base string Yes Base currency
quote string Yes Quote currency
maker boolean Yes Indicator to indicate if trade is a maker trade
timestamp long Yes Order timestamp or transacted timestamp