Change Log
Version 3.4.14 (6th November 2024)
- Add maximum days of trade history explanation for API Query User Trades Fills
Version 3.4.13 (30th October 2024)
- Add TIMEOUT status in API Enum for APIs Create new order, Amend order, and Cancel order
Version 3.4.12 (16th September 2024)
- Update the permission-related content in the description of all APIs
Version 3.4.11 (21st Aug 2024)
- Description of the Index Order only supports USD quotes. Create new order
Version 3.4.10 (10th Jul 2024)
- Add
Rate Limit Mechanism Description
description
Version 3.4.9 (29th March 2024)
- Description of the maximum number of days for querying historical records. Query Trades Fills
Version 3.4.8 (25th October 2023)
- Add an new API Query Order
Version 3.4.7 (20th October 2023)
- Add two new response field
isMarketOpenToOtc
,isMarketOpenToSpot
in Market Summary
Version 3.4.6 (18th Sep 2023)
- Correct the data types of parameters in order related APIs and remove 451 status code
Version 3.4.5 (3rd September 2023)
- Remove the slide parameter from
amend-order
Version 3.4.4 (29th Aug 2023)
- Add 451 status code in
API Status Codes
and makeOrder Book Websocket Streams
as independent paragraph
Version 3.4.3 (17th Aug 2023)
- Update
Notifications
response data format from array to object.
Version 3.4.2 (29th May 2023)
- Update the error message format of Orderbook Stream Service(OSS). The scheduled effective date is
June 6, 2023, at 10:00 AM (UTC+0)
.- Before
{ "severity": "ERROR", "error": [ { "arg": "update:BTCC-USD_0", "errorCode": "MARKET_PAIR_NOT_SUPPORT" } ] }
- After
{ "severity": "ERROR", "errors": [ { "arg": "update:BTCC-USD_0", "error": { "code": 1000, "message": "Market pair provided is currently not supported." } } ] }
- Before
Version 3.4.1 (17th May 2023)
- Add
Ping/Pong
for websocket streams
Version 3.4.0 (12th April 2023)
- Deprecated two websokcet topics
Orderbook Snapshot (By grouping)
andOrderbook Snapshot (By depth)
today. Please use the following websokcet topic through the endpointwss://ws.btse.com/ws/oss/spot
to get orderbook data
Version 3.3.9 (6th April 2023)
Version 3.3.8 (29th March 2023)
- Update the http status code for authentication failed to
401
Version 3.3.7 (1th March 2023)
- update the format of args for Orderbook incremental update.
Version 3.3.6 (7th February 2023)
- Update
symbol
parameter as optional inopen_orders
- Add funding fee data in Query User Trades Fills.
Version 3.3.5 (28th November 2022)
- Add Orderbook incremental update error messages.
Version 3.3.4 (2nd September 2022)
- Remove unnecessary parameter
includeOld
in Query Trades Fills and Query User’s Trades Fills - Remove inaccurate parameters
beforeSerialId
andafterSerialId
in Query Trades Fills and Query User’s Trades Fills
Version 3.3.3 (15th August 2022)
- Merge document section
Create new algo order
into Create new order - Add more request / response samples in Trade Endpoints
- Correct document for request
type
ofTRIGGER
toTRIGGERPRICE
in Amend Order
Version 3.3.2 (29th March 2022)
- Add new
HALFMIN
time_in_force option in Create new order
Version 3.3.1 (2nd March 2022)
- Remove unnecessary field
reduceOnly
in Create new order
Version 3.3.0 (21st January 2022)
- Add new two new response fields
remainingSize
andoriginalSize
in Create new order and Create new algo order *[NOTE]: This change will be effective on Jan 25th 2022 (UTC+0)
Version 3.2.9 (13th January 2022)
- Migrate wallet-related endpoints to
Wallet
section - Migrate wallet-investment endpoints to
Earn
section
Version 3.2.8 (8th December 2021)
Version 3.2.7 (23rd November 2021)
- Update orderbook incremental updates decription Orderbook websocket feed
Version 3.2.6 (19th November 2021)
- Addition of
isMatchSymbol
parameter to trade_history
Version 3.2.5 (25th October 2021)
- Addition of orderbook incremental updates Orderbook websocket feed
Version 3.2.4 (1st July 2021)
- Addition of
fills
websocket topic to subscribe to user trade fills - Addition of attribute
depth
for Orderbook websocket feed
Version 3.2.3 (2nd June 2021)
- Introduction of new notification topic. Refer to
notificationsApiV2
for details.
Version 3.2.2 (29th January 2021)
- Websockets endpoint will be updated to the following:
- Spot: wss://ws.btse.com/ws/spot
- Futures: wss://ws.btse.com/ws/futures
Existing endpoints will continue to be made available.
- Login topic will now respond with a JSON success / failure message {"event":"login","success":true}
- When subscribing or unsubscribing to websocket topics, an acknowledgement will return indicating which topics are successfully subscribed / unsubscribed. Unsuccessful topics will not be returned in the response.
- Websocket notifications will have in addition the following indicators:
- maker - Boolean indicating if an order is a maker / taker order
- remainingSize - Value indicating the remaining size on the order
- time_in_force - Value indicating the time in force set on the order
Version 3.2.1 (28th September 2020)
- New Amend Order API. Allows users to edit price, size and trigger prices for pending orders
Version 3.2 (23rd June 2020)
- Deprecated v1 API
- Removed fees field for public API /api/v3.1/trades (not needed)
- Added new wallet APIs to create address, get wallet addresses and withdrawals
- Enhanced /user/wallet_historyAPI to return wallet details
- Introduction of API permissions. All current API keys will have Read, Trading and Transfer permissions. Refer to the tags beside the titles to see which category they are classified under
- Fixed incorrect messages returned on some APIs
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:
- Login with your username / email and password into the BTSE website
- Click on
Account
on the top right hand corner - Select the API tab
- Click on
New API
button to create an API key and passphrase. (Note: the passphrase will only appear once) - Use your API key and passphrase to construct a signature.
Endpoints
- Production
- HTTP
https://api.btse.com/spot
- Websocket
wss://ws.btse.com/ws/spot
- Websocket (for orderbook stream)
wss://ws.btse.com/ws/oss/spot
(Used for Orderbook incremental update stream)
- HTTP
- Testnet
- HTTP
https://testapi.btse.io/spot
- Websocket
wss://testws.btse.io/ws/spot
- Websocket (for orderbook stream)
wss://testws.btse.io/ws/oss/spot
(Used for Orderbook incremental update stream)
- HTTP
Authentication
API Key (request-api)
- Parameter Name:
request-api
, in: header. API key is obtained from BTSE platform as a string
- Parameter Name:
API Key (request-nonce)
- Parameter Name:
request-nonce
, in: header. Representation of current timestamp in long format
- Parameter Name:
API Key (request-sign)
- Parameter Name:
request-sign
, in: header. A composite signature produced based on the following algorithm: Signature=HMAC.Sha384 (secretkey, (urlpath + request-nonce + bodyStr)) (note: bodyStr = '' when no data):
- Parameter Name:
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
- Endpoint to place an order is
https://api.btse.com/spot/api/v3.2/order
- Assume we have the values as follows:
- request-nonce:
1624985375123
- request-api:
4e9536c79f0fdd72bf04f2430982d3f61d9d76c996f0175bbba470d69d59816x
- secret:
848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx
- Path:
/api/v3.2/order
- Body:
{"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"}
- Encrypted Text:
/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"}
- request-nonce:
- Generated signature will be:
- request-sign:
e9cd0babdf497b536d1e48bc9cf1fadad3426b36406b5747d77ae4e3cdc9ab556863f2d0cf78e0228c39a064ad43afb7
- request-sign:
Rate Limits
- The following rate limits are enforced:
Rate limits for BTSE is as follows:
Query
- Per API:
15 requests/second
- Per User:
30 requests/second
Orders
- Per API:
75 requests/second
- Per User:
75 requests/second
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
- 1 sec
- 5 min
- 15 min
API Status Codes
Each API will return one of the following HTTP status:
- 200 - API request was successful, refer to the specific API response for expected payload
- 400 - Bad Request. Server will not process this request. This is usually due to invalid parameters sent in request
- 401 - Unauthorized request. Server will not process this request as it does not have valid authentication credentials
- 403 - Forbidden request. Credentials were provided but they were insufficient to perform the request
- 404 - Not found. Indicates that the server understood the request but could not find a correct representation for the target resource
- 405 - Method not allowed. Indicates that the request method is not known to the requested server
- 408 - Request timeout. Indicates that the server did not complete the request. BTSE API timeouts are set at 30secs
- 429 - Too many requests. Indicates that the client has exceeded the rates limits set by the server. Refer to Rate Limits for more details
- 500 - Internal server error. Indicates that the server encountered an unexpected condition resulting in not being able to fulfill the request
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.
- -1: TIMEOUT= Request timeout, please check the order status
- 1: MARKET_UNAVAILABLE = Futures market is 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
- 7: ORDER_REFUNDED = Order is refunded
- 8: INSUFFICIENT_BALANCE = Insufficient balance in account
- 9: TRIGGER_INSERTED = Trigger Order is inserted successfully
- 10: TRIGGER_ACTIVATED = Trigger Order is activated successfully
- 11: ERROR_INVALID_CURRENCY
- 12: ERROR_UPDATE_RISK_LIMIT = Error in updating risk limit
- 13: ERROR_INVALID_LEVERAGE
- 15: ORDER_REJECTED = Order is rejected
- 16: ORDER_NOTFOUND = Order is not found with the order ID or clOrderID provided
- 17: REQUEST_FAILED = Failed to complete the request, please check order status
- 20: SUCCESS = Action succeeded.
- 21: FREEZE_SUCCESSFUL
- 27: TRANSFER_SUCCESSFUL = Transfer funds between futures and spot is successful
- 28: TRANSFER_UNSUCCESSFUL = Transfer funds between spot and futures is unsuccessful
- 29: QUERY_GET_ORDERS
- 31: QUERY_GET_POSITIONS
- 33: QUERY_GET_ALL_POSITIONS_ORDERS
- 34: QUERY_WALLET
- 36: QUERY_FUTURES_MARGIN
- 41: ERROR_INVALID_RISK_LIMIT = Invalid risk limit was specified
- 51: QUERY_GET_ORDERS_WITH_LIMIT
- 64: STATUS_LIQUIDATION = Account is undergoing liquidation
- 65: STATUS_ACITVE = Order is active
- 66: MODE_BUY
- 76: ORDER_TYPE_LIMIT = Limit order
- 77: ORDER_TYPE_MARKET = Market order
- 80: ORDER_TYPE_PEG = Peg/Algo order
- 81: ORDER_TYPE_OTC = Otc order
- 83: MODE_SELL
- 85: STATUS_PROCESSING = Order is inactive
- 88: STATUS_INACTIVE = Order is inactive
- 101: FUTURES_ORDER_PRICE_OUTSIDE_LIQUIDATION_PRICE = Futures order is outside of liquidation price
- 110: FUTURES_FUNDING
- 123: AMEND_ORDER = Order amended
- 124: UNFREEZE_SUCCESSFUL
- 300: ERROR_MAX_ORDER_SIZE_EXCEEDED
- 301: ERROR_INVALID_ORDER_SIZE
- 302: ERROR_INVALID_ORDER_PRICE
- 303: ERROR_RATE_LIMITS_EXCEEDED
- 304: ERROR_MAX_OPEN_ORDER_EXCEEDED
- 1003: ORDER_LIQUIDATION = Order is undergoing liquidation
- 1004: ORDER_ADL = Order is undergoing ADL
- 30410: BLOCK_TRADE_COMPLETE_SUCCESS
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 |
- maximum days of trade fills
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 mandatoryTRIGGER: Trigger order, triggerPrice is mandatoryLIMIT: 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 amendmentPRICE : To amend order priceSIZE : To amend order sizeTRIGGERPRICE : To amend trigger priceALL : 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
- If set correctly, a HTTP 200 response code will be returned
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 sideBUY 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 |
- maximum days of trade history
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
- Production
wss://ws.btse.com/ws/oss/spot
- Testnet
wss://testws.btse.io/ws/oss/spot
OSS L1 Snapshot
Request
{
"op": "subscribe",
"args": [
"snapshotL1:BTC-USD"
]
}
{
"op": "unsubscribe",
"args": [
"snapshotL1:BTC-USD"
]
}
Response
{
"topic": "snapshotL1:BTC-USD",
"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
.
symbol
indicates the market symbol
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 levelsdelta - 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
- Production
wss://ws.btse.com/ws/spot
- Testnet
wss://testws.btse.io/ws/spot
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:
request-nonce
: 1624985375123request-api
: 4e9536c79f0fdd72bf04f2430982d3f61d9d76c996f0175bbba470d69d59816xsecret
: 848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx
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 |