Change Log
Version 2.7.8 (16th September 2024)
- Update the permission-related content in the description of all APIs
Version 2.7.7 (1st August 2024)
- Add API for querying
User Initial Margin Percentage And Maintenance Margin Percentage
Version 2.7.6 (10th Jul 2024)
Version 2.7.5 (27th May 2024)
- Add contractSize field in the following APIs and WebSocket topics. The scheduled effective date is
May 29, 2024, at 10:00 AM (UTC+0)
Version 2.7.4 (29th March 2024)
- Description of the maximum number of days for querying historical records.
Query Trade History
/ Query Wallet History
Version 2.7.3 (19th February 2024)
- Add Spam Order Detection Mechanism : BTSE Support link
- Change description for spam order with a notional value below 5 USDT
- Change threshold for spam account to 20 USDT
Version 2.7.2 (31st January 2024)
- Add price protection related status
Version 2.7.1 (30th January 2024)
- Add API for querying
Funding History
Version 2.7.0 (29th January 2024)
- Support Cross Leverage
- Add marginMode field in
Get leverage
andSet Leverage
- Add marginMode field in
Version 2.6.16 (5th January 2024)
- Change description for
walletSrc
andwalletDest
forWallet Transfer
andSub-account Wallet Transfer
which is required only for relatedwalletSrcType
andwalletDestType
isISOLATED
Version 2.6.15 (8th November 2023)
- Add API for querying
Query Position Mode
and changingChange Position Mode
- API related to order and position have added the fields or parameter: positionMode and positionId and positionDirection
Version 2.6.14 (7th November 2023)
- Update fundingRate description in
Market Summary
- Add listFullAttributes parameter in
Market Summary
- Add optional fundingIntervalMinutes and fundingTime in
Market Summary
- The new funding rate interval scheduled effective date is
Nov 14, 2023
- Add new API
Query Order
Version 2.6.13 (31th October 2023)
error code format
{
"status": 400,
"errorCode": 400,
"message": "BAD_REQUEST: Order doesn't exist"
}
- [IMPORTANT] Adjust the HTTP status codes and error messages for trading-related API. The scheduled effective date is
November 7, 2023, at 10:00 AM (UTC+0)
. This includes but is not limited to the following situations.- Order not found
- Change status code to 400
- Change errorCode to 400
- Order rejected
- Change status code to 400
- Change errorCode to 400
- Max open order reached
- Change status code to 400
- Change errorCode to 304
- rate limit reached
- Change status code to 429
- Change errorCode to 303
- market unavailable
- Change status code to 400
- Change errorCode to 400
- Order not found
Version 2.6.12 (23th October 2023)
- Add
positions
in websocket streams for user to get all positions includes closed position
Version 2.6.11 (16th October 2023)
- Add TP/SL (Take Profit/Stop Loss) parameters in
Create New Order
- Add API
Bind TP/SL
in Trade Endpoints to bind TP/SL with an existing position - Add TP/SL fields in Trade Endpoints
Query Open Orders
andQuery Positions
- Add TP/SL fields in Websocket Streams
All Position
Version 2.6.10 (3rd October 2023)
- Correct response data type
Version 2.6.9 (11th September 2023)
- Add
Get leverage
to get leverage for market
Version 2.6.8 (3rd September 2023)
- Remove the slide parameter from
Amend Order
Version 2.6.7 (29th August 2023)
- Add 451 status code in
API Status Codes
and makeOrder Book Websocket Streams
as independent paragraph
Version 2.6.6 (28th August 2023)
- Add postOnly parameter on
Close Position
Version 2.6.5 (27th July 2023)
- We have introduced a new addition to our futures market: 1,000 Floki Perpetual Futures Contracts (1KFLOKI-PERP or 1KFLOKIPFC)
Version 2.6.4 (7th June 2023)
- Update wallet/transfer
URL
from /api/v2.1/wallet/transfer to /api/v2.1/user/wallet/transfer
Version 2.6.3 (6th June 2023)
- Update the format of
Wallet Detail Request
Version 2.6.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 2.6.1 (24th May 2023)
- Add group parameter on
Orderbook by grouping
Version 2.6.0 (17th May 2023)
- Add
Ping/Pong
for websocket streams
Version 2.5.9 (21th April 2023)
Version 2.5.8 (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/futures
to get orderbook data
Version 2.5.7 (6th April 2023)
Version 2.5.6 (29th March 2023)
- [IMPORTANT] BTSE will change futures market naming convention in April 2023 to provide more clarity to retail users and here are the rules:
- Change the suffix for perpetual markets from
PFC
toPERP
(ex: BTCPFC -> BTC-PERP) - Change the suffix for time-based markets from
delivery month + year
tosettlement date (YYMMDD)
(ex: BTCM23 -> BTC-230630) - Reference
- Futures API updated (Generally added a new optional parameter
useNewSymbolNaming
to specify if the market name is in the new format): Market Summary
Query Open Orders
Orderbook by grouping
Orderbook
Charting Data
Query Wallet History
Query Wallet Balance
Set Leverage
Get Leverage
Set Risk Limit
Query Market Price
Change Contract Settlement Currency
Query Account Fee
Query Position
Close Position
Query Wallet Margin
Create New Order
Query Trade History
- Existing websocket topics will return data with the current market name (ex: BTCPFC) and new set of websocket topics are added for new market name (ex: BTC-PERP) where
the response fields will be the same
and here's the mapping table - tradeHistoryApi -> tradeHistoryApiV2
- orderbookApi -> orderbookApiV2
- orderbookL2Api -> orderbookL2ApiV2
- fills -> fillsV2
- allPosition -> allPositionV2
- notificationApiV2 -> notificationApiV3
- Change the suffix for perpetual markets from
Version 2.5.5 (29th March 2023)
- Update the http status code for authentication failed to
401
Version 2.5.4 (1th March 2023)
- Update the format of args for Orderbook incremental update.
Version 2.5.3 (23th December 2022)
- [IMPORTANT] BTSE will change futures market naming convention in 2023. The changes are shown in Version 2.5.0 (16th November 2022).
Version 2.5.2 (28th November 2022)
- Add Orderbook incremental update error messages.
Version 2.5.1 (25th November 2022)
- [IMPORTANT] BTSE will adjust the formula to calculate futures risk limit level and some api will be affected.
Market Summary
maxPosition
in response will no longer be applicable since it will be determined by max_risk_limit / futures_market_priceminRiskLimit
now in contract size and will be updated to beusd notional value
maxRiskLimit
now in contract size and will be updated to beusd notional value
Order size
remains incontract size
but notusd value
for backward compatibility- Reference
- Can ask question in BTSE api TG group if any
Version 2.5.0 (16th November 2022)
- [IMPORTANT] BTSE will change futures market naming convention in December 2022 to provide more clarity to retail users and here are the rules:
- Change the suffix for perpetual markets from
PFC
toPERP
(ex: BTCPFC -> BTC-PERP) - Change the suffix for time-based markets from
delivery month + year
tosettlement date (YYMMDD)
(ex: BTCZ22 -> BTC-221230) - Reference
- Futures API updated (Generally added a new optional parameter
useNewSymbolNaming
to specify if the market name is in the new format): Market Summary
Query Open Orders
Orderbook by grouping
Orderbook
Charting Data
Query Wallet History
Query Wallet Balance
Set Leverage
Set Risk Limit
Query Market Price
Change Contract Settlement Currency
Query Account Fee
Query Position
Close Position
Query Wallet Margin
Create New Order
Query Trade History
- Existing websocket topics will return data with the current market name (ex: BTCPFC) and new set of websocket topics are added for new market name (ex: BTC-PERP) where
the response fields will be the same
and here's the mapping table - tradeHistoryApi -> tradeHistoryApiV2
- orderbookApi -> orderbookApiV2
- orderbookL2Api -> orderbookL2ApiV2
- fills -> fillsV2
- allPosition -> allPositionV2
- notificationApiV2 -> notificationApiV3
- Change the suffix for perpetual markets from
Version 2.4.1 (17th August 2022)
- Add more request / response samples in Trade Endpoints
- Correct document in Trade Endpoints
Version 2.4.0 (30th March 2022)
- Add new websocket topic
allPosition
to get all open position All Position
Version 2.3.1 (29th March 2022)
- Add new
HALFMIN
time_in_force option in Create new order
Version 2.3.0 (21st Jan 2022)
- Add new two new response fields
remainingSize
andoriginalSize
in Create new order, Create new algo order, and Close Position [NOTE]: This change will be effective on Jan 25th 2022 (UTC+0)
Version 2.2.1 (26th Nov 2021)
- Update market name for futures Orderbook websocket feed
Version 2.2.0 (23rd Nov 2021)
- Addition of orderbook incremental updates Orderbook websocket feed
Version 2.1.8 (1st July 2021)
- Addition of
fills
websocket topic to subscribe to user trade fills - Addition of attribute
depth
for Orderbook websocket feed
Version 2.1.7 (4th February 2021)
- Addition of
avgFilledPrice
in open_orders AP
Version 2.1.6 (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 2.1.5 (28th September 2020)
- New Amend Order API. Allows users to edit price, size and trigger prices for pending orders
Version 2.1.4 (24th July 2020)
- New Settle In API added, allows users to set the currency to settle the current position in via API
Version 2.1.3 (23rd June 2020)
- Introduction of Spam Order detection mechanism
- Websocket topic notificationApiV2 introduced. Topic is meant to standardize response codes returned. Notifications are returned as an Array
- 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
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/futures
- Websocket
wss://ws.btse.com/ws/futures
- Websocket (for orderbook stream)
wss://ws.btse.com/ws/oss/futures
(Used for Orderbook incremental update stream)
- HTTP
- Testnet
- HTTP
https://testapi.btse.io/futures
- Websocket
wss://testws.btse.io/ws/futures
- Websocket (for orderbook stream)
wss://testws.btse.io/ws/oss/futures
(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: Get Wallet
HMAC SHA384 Signature
$ echo -n "/api/v2.1/user/wallet1624984297330" | openssl dgst -sha384 -hmac "848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx"
(stdin)= ea4f1f2b43a0f4d750ae560c5274d6214d140fcab3093da5f4a83e36828535bd2ba7b12160cd12199596f422c8883333
- Endpoint to get wallet is
https://api.btse.com/futures/api/v2.1/user/wallet
- Assume we have the values as follows:
- request-nonce:
1624984297330
- request-api:
4e9536c79f0fdd72bf04f2430982d3f61d9d76c996f0175bbba470d69d59816x
- secret:
848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx
- Path:
/api/v2.1/user/wallet
- request-nonce:
- Generated signature will be:
- request-sign:
ea4f1f2b43a0f4d750ae560c5274d6214d140fcab3093da5f4a83e36828535bd2ba7b12160cd12199596f422c8883333
- request-sign:
Example 2: Place an order
HMAC SHA384 Signature
$ echo -n "/api/v2.1/order1624985375123{\"postOnly\":false,\"price\":8500.0,\"reduceOnly\":false,\"side\":\"BUY\",\"size\":1,\"stopPrice\":0.0,\"symbol\":\"BTCPFC\",\"time_in_force\":\"GTC\",\"trailValue\":0.0,\"triggerPrice\":0.0,\"txType\":\"LIMIT\",\"type\":\"LIMIT\"}" | openssl dgst -sha384 -hmac "848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx"
(stdin)= 943adfce43b609a28506274976b96e08cf4bdc4ea53ca0b4cac0eb2cf0773a7d0807efc0aeab779d47fadcd9a60eea13
- Endpoint to place an order is
https://api.btse.com/futures/api/v2.1/order
- Assume we have the values as follows:
- request-nonce:
1624985375123
- request-api:
4e9536c79f0fdd72bf04f2430982d3f61d9d76c996f0175bbba470d69d59816x
- secret:
848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx
- Path:
/api/v2.1/order
- Body:
{"postOnly":false,"price":8500.0,"reduceOnly":false,"side":"BUY","size":1,"stopPrice":0.0,"symbol":"BTCPFC","time_in_force":"GTC","trailValue":0.0,"triggerPrice":0.0,"txType":"LIMIT","type":"LIMIT"}
- Encrypted Text:
/api/v2.1/order1624985375123{"postOnly":false,"price":8500.0,"reduceOnly":false,"side":"BUY","size":1,"stopPrice":0.0,"symbol":"BTCPFC","time_in_force":"GTC","trailValue":0.0,"triggerPrice":0.0,"txType":"LIMIT","type":"LIMIT"}
- request-nonce:
- Generated signature will be:
- request-sign:
943adfce43b609a28506274976b96e08cf4bdc4ea53ca0b4cac0eb2cf0773a7d0807efc0aeab779d47fadcd9a60eea13
- 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
- 451 - Unavailable For Legal Reasons. Indicates that the client has been banned because abnormal behavior
- 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: 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
- 129: FUTURES_CONFIG_MODE_CHANGE
- 131: FUTURES_STATUS_PROCESSING_LEVERAGE
- 132: FUTURES_STATUS_PROCESSING_RISK_LIMIT
- 133: FUTURES_POSITION_MODE_INVALID
- 134: POSITION_MODE_UNCHANGEABLE
- 138: POSITION_MODE_CHANGE_PROCESSING
- 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
- 305: ERROR_ORDER_PRICE_OUT_OF_PRICE_PROTECTION_RANGE
- 1003: ORDER_LIQUIDATION = Order is undergoing liquidation
- 1004: ORDER_ADL = Order is undergoing ADL
- 30410: BLOCK_TRADE_COMPLETE_SUCCESS
Spam Orders
Spam orders are large number of small order sizes that is placed. In order to ensure that the platform and user's interests are protected from malicious players, we will apply the following for users placing small sized orders.
Spam Order Detection Mechanism : BTSE Support
- Orders with a notional value below 5 USDT will be marked as a spam order and will automatically become hidden orders.
- Orders marked as spam always pay the taker fee.
- Post-Only API orders marked as spam will be rejected instead of being hidden.
- Too many spam orders may be grounds to temporarily ban an account from trading.
- API accounts placing >= 4 resting orders, with total size less than 20 USDT are at risk of being marked as a spam account.
- Accounts marked as spam may have limitations placed on the account, including order rate limits, position limits, or have API functions disabled. For questions regarding the new spam order mechanism, please email mm@btse.com.
Public Endpoints
Market Summary
Response
[
{
"symbol": "BTCPFC",
"last": 36365,
"lowestAsk": 36377,
"highestBid": 36376,
"percentageChange": 4.973731309,
"volume": 172418318.7575521,
"high24Hr": 36447,
"low24Hr": 33989.5,
"base": "BTC",
"quote": "USD",
"active": true,
"size": 4916.8266,
"minValidPrice": 0.5,
"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,
"fundingIntervalMinutes": 480,
"fundingTime": 1699347600000
}
]
GET /api/v2.1/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 |
useNewSymbolNaming | boolean | No | True to return futures market name in the new format, default to False |
listFullAttributes | boolean | No | True to return all attributes of the market summary |
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 | Number of open positions in the futures market |
openInterestUSD | double | No | Number of open positions in the futures market in USD notional value |
contractStart | long | No | Contract start time |
contractEnd | long | No | Contract end time |
timeBasedContract | boolean | No | Indicator to indicate if it is a time based contract |
openTime | long | Yes | Market opening time |
closeTime | long | Yes | Market closing time |
startMatching | long | Yes | Matching start time |
inactiveTime | long | Yes | Time where market is inactive |
fundingRate | double | No | The funding rate |
contractSize | double | No | Size of one contract |
maxPosition | double | No | Maximum position a user is allowed to have Will no longer be applicable after risk limit adjustment |
minRiskLimit | double | No | Minimum risk limit in contract size Will be changed to USD value |
maxRiskLimit | double | No | Maximum risk limit int contract size Will be changed to USD value |
availableSettlement | array | No | Currencies available for settlement |
futures | boolean | Yes | Indicator if symbol is a futures contract |
fundingIntervalMinutes | integer | No | Funding interval, only display when param listFullAttributes is true |
fundingTime | long | No | Next funding time, only display when param listFullAttributes is true |
Charting Data
Response
[
[
1624987380,
36477,
36477,
36473.5,
36473.5,
693.049
],
[
1624987320,
36476.5,
36481.5,
36466,
36466,
2370.8095
]
]
GET /api/v2.1/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 millisecond (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 |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
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": "BTCPFC",
"indexPrice": 36288.949684967,
"lastPrice": 36286.5,
"markPrice": 0
}
]
GET /api/v2.1/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 |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
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 | Mark price |
Orderbook (By grouping)
Response
{
"buyQuote": [
{
"price": "36371.0",
"size": "100"
}
],
"sellQuote": [
{
"price": "36380.5",
"size": "100"
}
],
"timestamp": 1624989459489,
"symbol": "BTCPFC"
}
GET /api/v2.1/orderbook
Retrieves a snapshot of the orderbook.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol, entered as a path variable |
group | integer | No | Orderbook grouping. Valid values are: 0-8 where 0 indicates level 0 grouping (eg. for BTC-PERP, it will be 0.1) Level 1 grouping for BTC-PERP would be 0.5 Level 2 grouping for BTC-PERP would be 1 |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
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 | long | 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": "700"
}
],
"sellQuote": [
{
"price": "36241.5",
"size": "600"
}
],
"timestamp": 1624989977940,
"symbol": "BTCPFC"
}
GET /api/v2.1/orderbook/L2
Retrieves a Level 2 snapshot of the orderbook
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
depth | long | No | Orderbook depth |
useNewSymbolNaming | boolean | No | True to return futures market name in the new format, default to False |
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 | long | 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": 100,
"side": "SELL",
"symbol": "BTCPFC",
"serialId": 85997835,
"timestamp": 1624990097000
}
]
GET /api/v2.1/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) |
beforeSerialId | long | No | Used for pagination to retrieve records when the order volume exceeds 500 per millisecond. For typical scenarios, it is recommended to use the startTime and endTime parameters instead. |
afterSerialId | long | No | Used for pagination to retrieve records when the order volume exceeds 500 per millisecond. For typical scenarios, it is recommended to use the startTime and endTime parameters instead. |
count | long | Yes | Number of records to return |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
- maximum days of history records
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 | long | Yes | Transacted timestamp |
Funding History
Response
{
"BTC-PERP": [
{
"time": 1706515200,
"rate": 0.000011405,
"symbol": "BTC-PERP"
}
]
}
GET /api/v2.1/funding_history
Get funding rate history for certain symbols
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | No | Market symbol (e.g., BTC-PERP) |
count | int | No | Number of records to return (mutually exclusive with from/to) |
from | long | No | Starting time in milliseconds (e.g., 1624987283000; mutually exclusive with count) |
to | long | No | Ending time in milliseconds (e.g., 1624987283000; mutually exclusive with count) |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
time | long | Yes | The epoch timestamp in second of the funding rate |
rate | double | Yes | Funding rate |
Trade Endpoints
Create New Order
Request (create
MARKET
order)
{
"symbol": "BTCPFC",
"size": 1,
"side": "BUY",
"type": "MARKET"
}
Request (create
LIMIT
order)
{
"symbol": "BTCPFC",
"size": 1,
"price": 21000,
"side": "BUY",
"type": "LIMIT"
}
Request (create
LIMIT
TRIGGER
order)
{
"symbol": "BTCPFC",
"size": 1,
"price": 21000,
"side": "BUY",
"type": "LIMIT",
"txType": "TRIGGER",
"triggerPrice": 30000
}
Request (create
LIMIT
STOP
order)
{
"symbol": "BTCPFC",
"size": 1,
"price": 21000,
"side": "BUY",
"type": "LIMIT",
"txType": "STOP",
"triggerPrice": 30000
}
Request (create
OCO
order)
{
"symbol": "BTCPFC",
"size": 1,
"price": 21000,
"side": "BUY",
"type": "OCO",
"txType": "LIMIT",
"trigger": "markPrice",
"stopPrice": 30010,
"triggerPrice": 30000
}
Request (create
Limit
order withTP/SL
)
{
"symbol": "BTC-PERP",
"size": 10,
"price": 29000,
"side": "BUY",
"type": "LIMIT",
"takeProfitPrice": 31000,
"takeProfitTrigger": "markPrice",
"stopLossPrice": 27000,
"stopLossTrigger": "lastPrice"
}
Request (create
Limit
order withTP
only)
{
"symbol": "BTC-PERP",
"size": 10,
"price": 29000,
"side": "BUY",
"type": "LIMIT",
"takeProfitPrice": 31000,
"takeProfitTrigger": "markPrice"
}
Request (create
Limit
order withSL
only)
{
"symbol": "BTC-PERP",
"size": 10,
"price": 29000,
"side": "BUY",
"type": "LIMIT",
"stopLossPrice": 27000,
"stopLossTrigger": "lastPrice"
}
Request (create hedge mode long position
MARKET
order)
{
"symbol": "BTCPFC",
"size": 1,
"side": "BUY",
"type": "MARKET",
"positionMode": "HEDGE"
}
Request (create hedge mode short position
MARKET
reduce order)
{
"symbol": "BTCPFC",
"size": 1,
"side": "BUY",
"type": "MARKET",
"reduceOnly": true,
"positionMode": "HEDGE"
}
Response (general)
[
{
"status": 4,
"symbol": "BTCPFC",
"orderType": 76,
"price": 21000.0,
"side": "BUY",
"size": 1,
"orderID": "abb3f457-fdc0-4bdb-a46b-8e4aa49a57c2",
"timestamp": 1660558270207,
"triggerPrice": 0.0,
"trigger": false,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 21000.0,
"fillSize": 1.0,
"clOrderID": "",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 0.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"time_in_force": "GTC"
}
]
Response (for
OCO
order)
[
{
"status": 9,
"symbol": "BTCPFC",
"orderType": 76,
"price": 23000.0,
"side": "BUY",
"size": 1,
"orderID": "4c9d16c1-9869-4734-bfb8-56318e961ef2",
"timestamp": 1660558185243,
"triggerPrice": 30000.0,
"trigger": true,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 0.0,
"fillSize": 0.0,
"clOrderID": "",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 1.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"time_in_force": "GTC"
},
{
"status": 2,
"symbol": "BTCPFC",
"orderType": 76,
"price": 21000.0,
"side": "BUY",
"size": 1,
"orderID": "53749446-39d3-4b72-87c9-92e9fc7e4b8c",
"timestamp": 1660558185225,
"triggerPrice": 0.0,
"trigger": false,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 0.0,
"fillSize": 0.0,
"clOrderID": "",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 1.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"time_in_force": "GTC"
}
]
Response (for hedge mode order)
[
{
"status": 4,
"symbol": "BTCPFC",
"orderType": 76,
"price": 21000.0,
"side": "BUY",
"size": 1,
"orderID": "abb3f457-fdc0-4bdb-a46b-8e4aa49a57c2",
"timestamp": 1660558270207,
"triggerPrice": 0.0,
"trigger": false,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 21000.0,
"fillSize": 1.0,
"clOrderID": "",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 0.0,
"positionMode": "HEDGE",
"positionDirection": "LONG",
"positionId": "BTCPFC-USD|LONG",
"time_in_force": "GTC"
}
]
POST /api/v2.1/order
Creates a new order. Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
price | double | No | Mandatory unless creating a MARKET order. Order price |
size | long | Yes | Order size in contract size (this remains unchanged even after risk limit adjustment) |
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 |
txType | string | No | Used for Stop orders or trigger orders STOP: Stop Order, triggerPrice is mandatoryTRIGGER: Trigger order, triggerPrice is mandatoryLIMIT: Default, used when its not a Stop order nor Trigger order |
stopPrice | double | No | Mandatory when creating an OCO order. Indicates the stop price |
triggerPrice | double | No | Mandatory when creating a Stop, Trigger, 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 |
reduceOnly | boolean | No | Boolean to indicate if this is a reduce only order, if in hedge mode, it is used to reduce the specified position, ex: sell to reduce long position, buy to reduce short position. |
clOrderID | string | No | Custom order Id |
trigger | string | No | For creating order with txType: STOP or TRIGGER . Valid options: markPrice (default) or lastPrice |
takeProfitPrice | double | No | Mandatory when creating new order with take profit order. Indicates the trigger price |
takeProfitTrigger | string | No | For creating order with take profit order. Valid options: markPrice (default) or lastPrice |
stopLossPrice | double | No | Mandatory when creating new order with stop loss order. Indicates the trigger price |
stopLossTrigger | string | No | For creating order with stop loss order. Valid options: markPrice (default) or lastPrice |
positionMode | string | No | For creating order and wanting to specify the positionMode. Valid options: ONE_WAY (default) or HEDGE |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
clOrderID | string | Yes | Customer tag sent in by trader |
fillSize | number | Yes | Trade filled size |
orderID | string | Yes | Order ID |
orderType | integer | Yes | Order type 76: Limit Order 77: Market order 80: 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 | long | Yes | Order size in contract size (this remains unchanged even after risk limit adjustment) |
status | long | 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 |
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 |
avgFillPrice | double | Yes | Average filled price. Returns the average filled price for partially transacted orders |
message | string | Yes | Trade messages |
stealth | double | Yes | Only valid for Algo orders |
deviation | double | Yes | Only valid for Algo orders |
remainingSize | double | Yes | Size left to be transacted |
originalSize | double | Yes | Original order size |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | The current order belongs to the id of position. |
Create new algo order
Request
{
"symbol": "BTCPFC",
"price": 21500,
"size": 1,
"side": "BUY",
"clOrderID": "60a30188-f2a2-4498-b061-7d72126c18c2",
"stealth": 10,
"deviation": -10
}
Response
[
{
"status": 2,
"symbol": "BTCPFC",
"orderType": 80,
"price": 21500.0,
"side": "BUY",
"size": 1,
"orderID": "de9f94bb-0ca0-470b-830e-9bc2e109c719",
"timestamp": 1660554373317,
"triggerPrice": 0.0,
"trigger": false,
"deviation": -10.0,
"stealth": 10.0,
"message": "",
"avgFillPrice": 0.0,
"fillSize": 0.0,
"clOrderID": "60a30188-f2a2-4498-b061-7d72126c18c2",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 1.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"time_in_force": "GTC"
}
]
POST /api/v2.1/order/peg
Creates a new algo order. Algo order is an order that price will change according to market price. To create an algo order, user will need to enter additional parameters:
price
: What is the min price (for a sell order) or maximum price (for a buy order) that a user will be willing to list his order atdeviation
: How much should the order price deviate from index price. Value is in percentage and can range from-10
to10
stealth
: How many percent of the order is to be displayed on the orderbook.
This API Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
price | double | Yes | 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 | long | Yes | Order size |
side | string | Yes | Order side BUY or SELL |
clOrderID | string | No | Custom order Id |
deviation | double | No | How much should the order price deviate from index price. Value is in percentage and can range from -10 to 10 |
stealth | double | No | How many percent of the order is to be displayed on the orderbook. |
positionMode | string | No | For creating order and wanting to specify the positionMode. Valid options: ONE_WAY (default) or HEDGE |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
clOrderID | string | Yes | Customer tag sent in by trader |
fillSize | number | Yes | Trade filled size |
orderID | string | Yes | Order ID |
orderType | integer | Yes | Order type 76: Limit Order 77: Market order 80: 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 | long | Yes | Order size in contract size (this remains unchanged even after risk limit adjustment) |
status | long | 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 |
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 |
avgFillPrice | 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 |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | The current order belongs to the id of position. |
Query Order
Response
{
"orderType": 76,
"price": 1,
"size": 111,
"side": "BUY",
"filledSize": 0,
"orderValue": 0.111,
"pegPriceMin": 0,
"pegPriceMax": 0,
"pegPriceDeviation": 1,
"timestamp": 1698757024617,
"orderID": "<Order UUID>",
"stealth": 1,
"triggerOrder": false,
"triggered": false,
"triggerPrice": 0,
"triggerOriginalPrice": 0,
"triggerOrderType": 0,
"triggerTrailingStopDeviation": 0,
"triggerStopPrice": 0,
"symbol": "BTCPFC",
"trailValue": 0,
"remainingSize": 111,
"clOrderID": "<Order clOrderID>",
"reduceOnly": false,
"status": 2,
"triggerUseLastPrice": false,
"avgFilledPrice": 0,
"timeInForce": "GTC",
"takeProfitOrder": null,
"stopLossOrder": null,
"closeOrder": false,
"contractSize": 0.001
}
GET /api/v2.1/order
Query order detail for a specified orderID/clOrderID, please note that a canceled order will only exist for 30 minutes. Requires Trading
permission.
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 |
takeProfitOrder | TakeProfitOrder object | No | Take profit order info |
stopLossOrder | StopLossOrder object | No | Stop loss order info |
closeOrder | bool | Yes | Whether it is an order to close this position |
timeInForce | String | Yes | Order validity |
contractSize | double | Yes | The order contract size |
Amend Order
Request (amend price)
{
"symbol": "BTCPFC",
"orderID": "604c3ebf-d7fa-468d-9ff0-f6ad030221b4",
"type": "PRICE",
"value": 22000
}
Request (amend all)
{
"symbol": "BTCPFC",
"orderID": "604c3ebf-d7fa-468d-9ff0-f6ad030221b4",
"type": "ALL",
"orderPrice": 30010,
"orderSize": 1,
"triggerPrice": 30000
}
Response
[
{
"status": 123,
"symbol": "BTCPFC",
"orderType": 76,
"price": 20000.0,
"side": "BUY",
"size": 1,
"orderID": "604c3ebf-d7fa-468d-9ff0-f6ad030221b4",
"timestamp": 1660639762254,
"triggerPrice": 0.0,
"trigger": true,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 0.0,
"fillSize": 0.0,
"clOrderID": "",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 1.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"time_in_force": "GTC"
}
]
PUT /api/v2.1/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 amendmendPRICE : To amend order priceSIZE : To amend order sizeTRIGGERPRICE : To amend trigger priceALL : to amend multiple fields |
value | number | Yes | The value to be amended to. Value depends on the type being set. |
orderPrice | number | No | For type: ALL , order price to be amended |
orderSize | number | No | For type: ALL , order size in contract size to be amended |
triggerPrice | number | 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 | string | Yes | Trade filled size |
orderID | string | Yes | Order ID |
orderType | integer | Yes | Order type 76: Limit Order 77: Market order 80: 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 | long | Yes | Order size in contract size (this remains unchanged even after risk limit adjustment) |
status | long | 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 |
time_in_force | string | Yes | Order validity |
timestamp | long | Yes | Order timestamp |
trigger | string | Yes | Indicator if order is a trigger order |
triggerPrice | string | Yes | Order trigger price, returns 0 if order is not a trigger order |
avgFillPrice | string | 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 | string | Yes | Deviation value of order |
remainingSize | double | Yes | Size left to be transacted |
originalSize | double | Yes | Original order size |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | The current order belongs to the id of position. |
Cancel Order
Request
/api/v2.1/order?symbol=BTC-USD&clOrderID=my-order-id
Response
[
{
"status": 6,
"symbol": "BTCPFC",
"orderType": 76,
"price": 19000.0,
"side": "BUY",
"size": 1,
"orderID": "ae5b1b27-d5fe-41e2-89f8-f17b60fb3def",
"timestamp": 1660640879996,
"triggerPrice": 0.0,
"trigger": false,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 0.0,
"fillSize": 0.0,
"clOrderID": "string",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 1.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"time_in_force": "GTC"
}
]
DELETE /api/v2.1/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: 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 | long | Yes | Order size in contract size (this remains unchanged even after risk limit adjustment) |
status | long | 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 |
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 |
avgFillPrice | 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 |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | The current order belongs to the id of position. |
Dead Man's Switch (Cancel All After)
Request
{
"timeout": 60000
}
POST /api/v2.1/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
Request
/api/v2.1/user/open_orders?symbol=BTCPFC
Response
[
{
"orderType": 76,
"price": 21000.0,
"size": 1,
"side": "BUY",
"filledSize": 0,
"orderValue": 21.0,
"pegPriceMin": 0.0,
"pegPriceMax": 0.0,
"pegPriceDeviation": 1.0,
"cancelDuration": 0,
"timestamp": 1660645487032,
"orderID": "2eb1c6f5-2ab2-4706-ab88-eea6b710a78b",
"stealth": 1.0,
"triggerOrder": false,
"triggered": false,
"triggerPrice": 0.0,
"triggerOriginalPrice": 0.0,
"triggerOrderType": 0,
"triggerTrailingStopDeviation": 0.0,
"triggerStopPrice": 0.0,
"symbol": "BTCPFC",
"trailValue": 0.0,
"clOrderID": "string",
"reduceOnly": false,
"orderState": "STATUS_ACTIVE",
"triggerUseLastPrice": false,
"avgFilledPrice": 0.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"timeInForce": "GTC",
"averageFillPrice": 0.0,
"contractSize": 0.0001,
"takeProfitOrder": {
"orderId": "ea1ab233-c79a-4503-a475-f8633ecc9d79",
"side": "SELL",
"triggerPrice": 31000.0,
"triggerUseLastPrice": false
},
"stopLossOrder": {
"orderId": "48523190-77b9-44ea-bee0-d67a428a51b8",
"side": "SELL",
"triggerPrice": 27000.0,
"triggerUseLastPrice": true
},
"closeOrder": false
}
]
GET /api/v2.1/user/open_orders
Retrieves open orders that have not yet been matched or matched recently. Requires Read
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. |
useNewSymbolNaming | boolean | No | True to return futures market name in the new format, default to False |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
clOrderID | string | Yes | Customer tag sent in by trader |
filledSize | long | Yes | Trade filled size |
orderValue | double | Yes | Notional value |
pegPriceMin | double | Yes | peg price min |
pegPriceMax | double | Yes | peg price max |
pegPriceDeviation | double | Yes | Deviation percentage. Only for Algo orders |
cancelDuration | long | Yes | Expire in milliseconds. 0: GTC -1: IOC |
orderID | string | Yes | Order ID |
orderType | integer | Yes | Order type 76: Limit Order 77: Market order 80: Algo order |
timeInForce | string | Yes | Order validity |
price | double | Yes | Order price |
side | string | Yes | Order side BUY or SELL |
size | long | Yes | Order size in contract size |
timestamp | long | Yes | Order timestamp |
triggerOrder | bool | Yes | Indicate if this is a trigger order |
triggered | bool | Yes | Indicate if this order has been triggered |
triggerUseLastPrice | bool | Yes | Indicate if this trigger order uses last price |
triggerPrice | double | Yes | Order trigger price, returns 0 if order is not a trigger order |
triggerOriginalPrice | double | Yes | Original trigger price |
triggerOrderType | string | Yes | Trigger order type 1001: Trigger stop loss 1002: Trigger take profit |
triggerTrailingStopDeviation | double | Yes | Reserved attribute |
triggerStopPrice | double | Yes | Reserved attribute |
trailValue | double | Yes | Reserved attribute |
reduceOnly | bool | Yes | Indicate if this order is reduce only |
avgFilledPrice | double | Yes | Average filled price. Returns the average filled price for partially transacted orders |
averageFillPrice | double | Yes | Average fill price |
stealth | double | Yes | Stealth value of order |
orderState | string | Yes | STATUS_ACTIVE , STATUS_INACTIVE |
takeProfitOrder | TakeProfitOrder object | No | Take profit order info |
stopLossOrder | StopLossOrder object | No | Stop loss order info |
closeOrder | bool | Yes | Whether it is an order to close this position |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | The current order belongs to the id of position. |
contractSize | double | Yes | The order contract size |
Query Trade History
Request
/api/v2.1/user/trade_history?symbol=BTCPFC
Response
[
{
"base": "string",
"clOrderID": "string",
"feeAmount": 0,
"feeCurrency": "string",
"filledPrice": 0,
"filledSize": 0,
"averageFillPrice": 0,
"orderId": "string",
"orderType": 0,
"price": 0,
"quote": "string",
"realizedPnl": 0,
"serialId": 0,
"side": "string",
"size": 0,
"symbol": "string",
"timestamp": 0,
"total": 0,
"tradeId": "string",
"triggerPrice": 0,
"triggerType": 0,
"username": "string",
"positionId": null,
"wallet": "string",
"tradeId": "string",
"orderId": "string",
"contractSize": "number"
}
]
GET /api/v2.1/user/trade_history
Retrieves a user's trade history. Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | No | Market symbol |
startTime | long | No | Starting time (eg. 1624987283000) |
endTime | long | No | Ending time (eg. 1624987283000) |
beforeSerialId | long | No | Used for pagination to retrieve records when the order volume exceeds 500 per millisecond. For typical scenarios, it is recommended to use the startTime and endTime parameters instead. |
afterSerialId | long | No | Used for pagination to retrieve records when the order volume exceeds 500 per millisecond. For typical scenarios, it is recommended to use the startTime and endTime parameters instead. |
count | long | No | Number of records to return |
orderID | string | No | Query trade history by order ID |
clOrderID | string | No | Query trade history by custom order ID |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
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 | long | Yes | Original order size |
serialId | long | Yes | Serial Id, running sequence number |
tradeId | string | Yes | Trade identifier |
timestamp | long | Yes | Transacted timestamp |
base | string | Yes | Base currency |
quote | string | Yes | Quote currency |
wallet | string | Yes | Wallet nameCROSS@ : Cross walletISOLATED@market : Market refers to the current symbol with -USD appended. Eg. BTCPFC isolated wallet would be ISOLATED@BTCPFC-USD |
clOrderID | string | Yes | Custom order ID |
orderId | string | Yes | Order ID |
username | string | Yes | btse username |
triggerType | long | Yes | Trigger type 1001: Stop Loss 1002: Take Profit |
feeAmount | long | Yes | Fee amount |
feeCurrency | long | Yes | Fee currency |
filledPrice | double | Yes | Filled price |
averageFillPrice | double | Yes | Average filled price |
triggerPrice | double | Yes | Trigger price |
filledSize | long | Yes | Filled size |
orderType | integer | Yes | Order Type |
realizedPnL | double | Yes | Not used in Spot |
total | long | Yes | Not used in Spot |
positionId | string | Yes | The current order belongs to the id of position. |
contractSize | double | Yes | The trade contract size |
Query Position
Request
/api/v2.1/user/positions
Response
[
{
"marginType": 0,
"entryPrice": 0,
"markPrice": 29286.4,
"symbol": "BTCPFC",
"side": "BUY",
"orderValue": 441.8492,
"settleWithAsset": "BTC",
"unrealizedProfitLoss": -0.23538014,
"totalMaintenanceMargin": 2.366912551,
"size": 62,
"liquidationPrice": 0,
"isolatedLeverage": 25,
"adlScoreBucket": 2,
"liquidationInProgress": false,
"timestamp": 1576661434072,
"currentLeverage": 0,
"takeProfitOrder": {
"orderId": "ea1ab233-c79a-4503-a475-f8633ecc9d79",
"side": "SELL",
"triggerPrice": 31000.0,
"triggerUseLastPrice": false
},
"stopLossOrder": {
"orderId": "48523190-77b9-44ea-bee0-d67a428a51b8",
"side": "SELL",
"triggerPrice": 27000.0,
"triggerUseLastPrice": true
},
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD"
},{
"marginType": 91,
"entryPrice": 1631.106666667,
"markPrice": 1630.398947255,
"symbol": "ETHPFC",
"side": "BUY",
"orderValue": 48.9119684176,
"settleWithAsset": "USDT",
"unrealizedProfitLoss": -0.02123158,
"totalMaintenanceMargin": 0.254871114,
"size": 3,
"liquidationPrice": 0,
"isolatedLeverage": 0,
"adlScoreBucket": 2,
"liquidationInProgress": false,
"timestamp": 0,
"takeProfitOrder": null,
"stopLossOrder": null,
"positionMode": "HEDGE",
"positionDirection": "LONG",
"positionId": "ETHPFC-USD|LONG",
"currentLeverage": 0.0340349245,
"takeProfitOrder": null,
"stopLossOrder": null
}
]
GET /api/v2.1/user/positions
Queries user's current position. When no symbol is specified, positions for all markets will be returned.
Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | No | Market symbol |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
side | string | Yes | Position side. Values are: [Buy , SELL ] |
size | long | Yes | Position size |
entryPrice | double | Yes | Entry price |
markPrice | double | Yes | Mark price |
marginType | long | Yes | Margin Type. Values as follows 91: CROSS wallet 92: Isolated wallet |
orderValue | double | Yes | Notional value |
settleWithAsset | string | Yes | Settlement currency |
totalMaintenanceMargin | double | Yes | Maintenance margin |
unrealizedProfitLoss | double | Yes | Unrealized profit and loss |
liquidationPrice | double | Yes | Liquidation Price |
isolatedLeverage | double | Yes | Isolated leverage value |
adlScoreBucket | double | Yes | ADL Score probability |
liquidationInProgress | boolean | Yes | Indicator if liquidation is in progress |
currentLeverage | double | Yes | Current leverage |
timestamp | long | Yes | Timestamp when position was queried |
takeProfitOrder | TakeProfitOrder object | No | Take profit order info |
stopLossOrder | StopLossOrder object | No | Stop loss order info |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | Position id |
Close Position
Request
{
"price": 0,
"symbol": "BTCPFC",
"type": "MARKET"
}
Request(For hedge mode position)
{
"price": 0,
"symbol": "BTCPFC",
"type": "MARKET",
"positionId": "BTCPFC-USD|LONG"
}
Response
[
{
"status": 4,
"symbol": "BTCPFC",
"orderType": 76,
"price": 24010.0,
"side": "SELL",
"size": 1,
"orderID": "93cf814a-595e-4b20-bba9-5c5340ca947d",
"timestamp": 1660710188450,
"triggerPrice": 0.0,
"trigger": false,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 24010.0,
"fillSize": 1.0,
"clOrderID": "",
"originalSize": 1.0,
"postOnly": false,
"remainingSize": 0.0,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": null,
"time_in_force": "GTC"
}
]
POST /api/v2.1/order/close_position
Closes a user's position for the particular market as specified by symbol. If type is specified as LIMIT, then price is mandatory. When type is MARKET, it closes the position at market price. Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
type | string | Yes | Close position type with values: LIMIT: Close at price MARKET: Close at market price |
price | double | No | Close price. Mandatory when type is LIMIT |
postOnly | boolean | No | Boolean to indicate if this is a post only order. For post only orders, traders are charged maker fees |
positionId | string | No | The position ID that you want to close. Mandatory when positionMode is HEDGE |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
clOrderID | string | Yes | Customer tag sent in by trader |
fillSize | string | Yes | Trade filled size |
orderID | string | Yes | Order ID |
orderType | integer | Yes | Order type 76: Limit Order 77: Market order 80: 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 | long | Yes | Cancelled size |
status | long | 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 |
time_in_force | string | Yes | Order validity |
timestamp | long | Yes | Order timestamp |
trigger | string | Yes | Indicator if order is a trigger order |
triggerPrice | string | Yes | Order trigger price, returns 0 if order is not a trigger order |
avgFillPrice | string | 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 | string | Yes | Deviation value of order |
remainingSize | double | Yes | Size left to be transacted |
originalSize | double | Yes | Original order size |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | Position id |
Get Risk Limit
Request
/api/v2.1/risk_limit?symbol=BTCPFC
Response
{
"symbol": "BTCPFC",
"riskLimit": 100000
}
GET /api/v2.1/risk_limit
Query risk limit for the specified market. Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
riskLimit | long | Yes | Risk limit value now in position size, but will be changed to USD value along with futures market name change |
Set Risk Limit
Request
{
"symbol": "BTCPFC",
"riskLimit": 0
}
Request (When positionMode is
HEDGE
)
{
"symbol": "BTCPFC",
"riskLimit": 100000,
"positionMode": "HEDGE"
}
Response
{
"symbol": "BTCPFC",
"timestamp": 1577093486551,
"status": 20,
"type": 94,
"message": "false"
}
POST /api/v2.1/risk_limit
Changes risk limit for the specified market. Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
riskLimit | long | Yes | Risk limit value now in position size, but it will be changed to USD value in the future. |
positionMode | string | no | ONE_WAY(default) or HEDGE. Mandatory when positionMode is HEDGE |
useNewSymbolNaming | boolean | No | True if use new futures market name as symbol , default to False |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
status | long | Yes | Status of the request. Values are: 8: Insufficient Balance 12: Error in updating risk limit 20: Success 41: Invalid risk limit |
type | double | Yes | Value will be 94 indicating that type is Risk Limit |
timestamp | long | Yes | Timestamp where risk limit was set |
message | long | Yes | Message |
Set Leverage
Request
{
"symbol": "BTCPFC",
"leverage": 0,
"marginMode": "CROSS"
}
Request (When positionMode is
HEDGE
)
{
"symbol": "BTCPFC",
"leverage": 0,
"positionMode": "HEDGE",
"marginMode": "CROSS"
}
Response
{
"symbol": "BTCPFC",
"timestamp": 1660711246942,
"status": 20,
"type": 93,
"message": ""
}
POST /api/v2.1/leverage
Change leverage values for the specified market. Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
leverage | double | Yes | Leverage value, 0 means cross maximum leverage |
useNewSymbolNaming | boolean | No | True if use new futures market name in symbol default to False |
positionMode | string | no | ONE_WAY(default) or HEDGE. Mandatory when positionMode is HEDGE |
marginMode | string | no | CROSS or ISOLATED(default) |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
status | long | Yes | Status of the request. Values are: 8: Insufficient Balance 13: Invalid leverage 20: Success 64: Undergoing liquidation |
type | double | Yes | Value will be 93 indicating that type is Leverage |
timestamp | long | Yes | Timestamp where leverage was set |
message | long | Yes | Message |
Get Leverage
Response
{
"symbol": "BTC-PERP",
"leverage": 100.0,
"marginMode": "ISOLATED"
}
Get /api/v2.1/leverage
Get leverage value for the specified market. Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
leverage | double | Yes | Current leverage value for the market, return 0 means the leverage is the maximum cross leverage |
marginMode | string | Yes | Current margin mode |
Change Contract Settlement Currency
Request
{
"symbol": "BTCPFC",
"currency": "BTC"
}
Request (When positionMode is
HEDGE
)
{
"symbol": "BTCPFC",
"currency": "USDT",
"positionId": "BTCPFC-USD|LONG"
}
Response (only available when an error occurs)
{
"status": 0,
"errorCode": 0,
"message": "string"
}
POST /api/v2.1/settle_in
Changes the settlement currency for the position in the current market. Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
currency | string | Yes | Settlement currency to set |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
positionId | string | No | The position ID that you want to set. Mandatory when positionMode is HEDGE |
Response Content
Name | Type | Required | Description |
---|---|---|---|
status | long | No | Status. Only available when an error occurs. |
errorCode | long | No | Error code. Only available when an error occurs. |
message | string | No | Response message. Only available when an error occurs. |
Query Account Fee
Response
{
"makerFee": 0,
"symbol": "BTCPFC",
"takerFee": 0
}
GET /api/v2.1/user/fees
Retrieve user's trading fees. Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | No | Market symbol |
useNewSymbolNaming | boolean | No | True to use new futures market name in symbol, default to False |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
makerFee | double | Yes | Maker fees |
takerFee | double | Yes | Taker fees |
Bind TP/SL
Request
{
"symbol": "BTC-PERP",
"takeProfitPrice": 31000,
"takeProfitTrigger": "markPrice",
"stopLossPrice": 22000,
"stopLossTrigger": "lastPrice"
}
Response
[
{
"status": 9,
"symbol": "BTCPFC",
"orderType": 77,
"price": 0.0,
"side": "SELL",
"size": 100,
"orderID": "4820b20a-e41b-4273-b3ad-4b19920aeeb5",
"timestamp": 1691974463934,
"triggerPrice": 31000.0,
"trigger": true,
"deviation": 100.0,
"stealth": 100.0,
"message": "",
"avgFillPrice": 0.0,
"fillSize": 0.0,
"clOrderID": "",
"originalSize": 100.0,
"postOnly": false,
"remainingSize": 100.0,
"orderDetailType": null,
"positionMode": "ONE_WAY",
"positionDirection": null,
"positionId": "BTCPFC-USD",
"time_in_force": "GTC"
}
]
POST /api/v2.1/order/bind/tpsl
Bind TP/SL with an existing position. Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | yes | Market symbol |
side | string | yes | "BUY" or "SELL" Mandatory when positionMode is HEDGE , in hedge mode, it is used to clsoe the specified position, ex: sell to close long position, buy to close short position |
takeProfitPrice | double | No | Mandatory when creating new order with take profit order. Indicates the trigger price. Must set takeProfitPrice or stopLossPrice at least when using this API. |
takeProfitTrigger | string | No | For creating order with take profit order. Valid options: markPrice (default) or lastPrice |
stopLossPrice | double | No | Mandatory when creating new order with stop loss order. Indicates the trigger price |
stopLossTrigger | string | No | For creating order with stop loss order. Valid options: markPrice (default) or lastPrice |
positionMode | string | no | ONE_WAY(default) or HEDGE. Mandatory when positionMode is HEDGE |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
clOrderID | string | Yes | Customer tag sent in by trader |
fillSize | number | Yes | Trade filled size |
orderID | string | Yes | Order ID |
orderType | string | Yes | Order type 76: Limit Order 77: Market order 80: 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 | long | Yes | Order size in contract size (this remains unchanged even after risk limit adjustment) |
status | long | 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 |
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 |
avgFillPrice | double | Yes | Average filled price. Returns the average filled price for partially transacted orders |
message | string | Yes | Trade messages |
stealth | string | Yes | Only valid for Algo orders |
deviation | double | Yes | Only valid for Algo |
remainingSize | double | Yes | Size left to be transacted |
originalSize | double | Yes | Original order size |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | Position id |
Query Position Mode
Response
[
{
"symbol": "ETH-PERP",
"positionMode": "HEDGE"
},
{
"symbol": "BTC-PERP",
"positionMode": "ONE_WAY"
}
]
GET /api/v2.1/position_mode
Retrieve user's position mode. Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | No | Market symbol |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
positionMode | string | Yes | ONE_WAY or HEDGE |
Change Position Mode
Request
{
"symbol": "BTC-PERP",
"positionMode": "HEDGE"
}
POST /api/v2.1/position_mode
Changes position mode. Requires Trading
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
positionMode | string | Yes | ONE_WAY or HEDGE |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
timestamp | long | No | Timestamp where position mode was set |
status | string | No | Status of the request. Values are: 20: Success |
type | string | No | Value will be 129 indicating that type is Futures Config Mode Change |
message | string | No | Message |
Query User Initial Margin Percentage And Maintenance Margin Percentage
Response
[
{
"symbol": "ETH-PERP",
"initialMarginPercentage": 0.01,
"maintenanceMarginPercentage": 0.005
},
{
"symbol": "BTC-PERP",
"initialMarginPercentage": 0.01,
"maintenanceMarginPercentage": 0.005
}
]
GET /api/v2.1/user/margin_setting
Queries user's initial margin percentage and maintenance margin percentage. When no symbol is specified, margin percentage for all markets will be returned. Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | No | Market symbol |
useNewSymbolNaming | boolean | No | True to return market symbol name in the new format, default to False |
Response Content
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
initialMarginPercentage | double | Yes | Current initial margin percentage |
maintenanceMarginPercentage | double | Yes | Current maintenance margin percentage |
Wallet Endpoints
Query Wallet Balance
Response
[
{
"trackingID": 0,
"queryType": 0,
"activeWalletName": "string",
"wallet": "CROSS@",
"username": "string",
"walletTotalValue": 0,
"totalValue": 100,
"marginBalance": 100,
"availableBalance": 100,
"unrealisedProfitLoss": 0,
"maintenanceMargin": 0,
"leverage": 0,
"openMargin": 0,
"assets": [
{
"balance": 0.20183537,
"assetPrice": 7158.844999999999,
"currency": "BTC"
}
],
"assetsInUse": [
{
"balance": 0.01,
"assetPrice": 7158.844999999999,
"currency": "BTC"
}
]
}
]
GET /api/v2.1/user/wallet
Query user's wallet balance. Requires Read
permissions on the API key.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
wallet | string | Yes | Wallet nameCROSS@ : Cross walletISOLATED@market : Market refers to the current symbol with -USD appended. Eg. BTCPFC isolated wallet would be ISOLATED@BTCPFC-USD |
useNewSymbolNaming | boolean | No | True to return futures market name in the new format, default to False |
Response Content
Wallet
Name | Type | Required | Description |
---|---|---|---|
wallet | string | Yes | Wallet name |
activeWalletName | string | Yes | Active wallet name |
queryType | integer | Yes | Query type |
trackingID | long | Yes | Internal tracking ID, not being used |
walletTotalValue | double | Yes | Wallet total value |
totalValue | double | Yes | Total value |
marginBalance | double | Yes | Margin balance |
availableBalance | double | Yes | Available Balance |
unrealisedProfitLoss | double | Yes | Unrealised Profit / Loss |
maintenanceMargin | double | Yes | Maintenance margin |
leverage | double | Yes | Leverage. In CROSS wallet, this field is current leverage, not leverage setting |
openMargin | double | Yes | Open margin |
assets | Asset object | Yes | Assets available |
assetsInUse | Asset object | Yes | Assets in use |
Assets / Asset in Use
Name | Type | Required | Description |
---|---|---|---|
balance | double | Yes | Balance |
assetPrice | double | Yes | Asset price |
currency | string | Yes | Currency |
Query Wallet History
Response
[
{
"amount": 21.35823825,
"currency": "USD",
"description": "string",
"fees": 0.06,
"orderId": 20181213000239,
"status": 10,
"timestamp": 1571630174639,
"type": 1,
"username": "btseUser",
"wallet": "Wallet",
"txid": "<Blockchain Transaction ID>",
"currencyNetwork": "<Blockchain currency network>"
}
]
GET /api/v2.1/user/wallet_history
Get user's wallet history records on the futures wallet. Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
wallet | string | No | Wallet, if not specified will return all wallets. Valid values are: CROSS@ : Cross walletISOLATED@BTCPFC-USD : Isolated wallets |
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 |
useNewSymbolNaming | boolean | No | True to return futures market name in the new format, default to False |
- maximum days of history records
Time Interval | Maximum Days | Explanation |
---|---|---|
startTime / endTime | 30 | Maximum 30 days within the specified interval |
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 |
---|---|---|---|
currency | string | Yes | Currency |
amount | double | Yes | Amount in the record |
fees | double | Yes | Fees charged if any |
orderId | string | Yes | Internal wallet order ID |
wallet | string | Yes | Wallet type. For futures will return CROSS@ or ISOLATED@ |
description | string | Yes | Description of the transaction |
status | integer | Yes | 1: PENDING 2: PROCESSING 10: COMPLETED 16: CANCELLED |
type | integer | Yes | 105: Wallet Transfer 106: Wallet Liquidation 108: Realized PnL 110: Funding 121: Asset Conversion |
Query Wallet Margin
Response
[
{
"trackingID": 0,
"requestId": 0,
"queryType": 0,
"wallet": "CROSS@",
"walletTotalValue": 0,
"totalValue": 100,
"marginBalance": 100,
"availableBalance": 100,
"unrealisedProfitLoss": 0,
"maintenanceMargin": 0,
"leverage": 0,
"openMargin": 0,
"assets": [
{
"balance": 0.20183537,
"assetPrice": 7158.844999999999,
"currency": "BTC"
}
],
"assetsInUse": [
{
"balance": 0.01,
"assetPrice": 7158.844999999999,
"currency": "BTC"
}
]
}
]
GET /api/v2.1/user/margin
Gets margin information for the specified wallet so that users can know which wallet they are currently using in the market.
Requires Read
permission.
Request Parameters
Name | Type | Required | Description |
---|---|---|---|
symbol | string | Yes | Market symbol |
Response Content
Wallet
Name | Type | Required | Description |
---|---|---|---|
wallet | string | Yes | Wallet name |
queryType | integer | Yes | Query type |
trackingID | long | Yes | Internal tracking ID, not being used |
requestId | long | Yes | Internal request ID, not being used |
walletTotalValue | double | Yes | Wallet total value |
totalValue | double | Yes | Total value |
marginBalance | double | Yes | Margin balance |
availableBalance | double | Yes | Available Balance |
unrealisedProfitLoss | double | Yes | Unrealised Profit / Loss |
maintenanceMargin | double | Yes | Maintenance margin |
leverage | double | Yes | Leverage |
openMargin | double | Yes | Open margin |
assets | Asset object | Yes | Assets available |
assetsInUse | Asset object | Yes | Assets in use |
Assets / Asset in Use
Name | Type | Required | Description |
---|---|---|---|
balance | double | Yes | Balance |
assetPrice | double | Yes | Asset price |
currency | string | Yes | Currency |
Transfer funds between Futures wallet
Request
{
"walletSrc": "",
"walletSrcType": "SPOT",
"walletDest": "",
"walletDestType": "CROSS",
"apiWallets": [
{
"currency": "USD",
"allBalance": true
},
{
"currency": "BTC",
"allBalance": true
}
]
}
Response
[
{
"trackingID": 0,
"queryType": 0,
"activeWalletName": "",
"wallet": "CROSS@",
"username": "string",
"walletTotalValue": 0,
"totalValue": 100,
"marginBalance": 100,
"availableBalance": 100,
"unrealisedProfitLoss": 0,
"maintenanceMargin": 0,
"leverage": 0,
"openMargin": 0,
"assets": [
{
"balance": 0.20183537,
"assetPrice": 7158.844999999999,
"currency": "BTC"
}
],
"assetsInUse": [
{
"balance": 0.01,
"assetPrice": 7158.844999999999,
"currency": "BTC"
}
]
}
]
POST /api/v2.1/user/wallet/transfer
Transfers funds between user's wallet. User can specify the source and target wallet to transfer funds.
Requires Transfer
permission.
Request Parameters
Wallet Request
Name | Type | Required | Description |
---|---|---|---|
walletSrc | string | No | Source wallet, required if walletSrcType is ISOLATED |
walletSrcType | string | Yes | Source type, valid values are:SPOT : Spot WalletCROSS : Cross WalletISOLATED : Isolated wallet for the market where market the market symbol |
walletDest | string | No | Destination wallet, required if walletDestType is ISOLATED |
walletDestType | string | Yes | Destination type, valid values are:SPOT : Spot WalletCROSS : Cross WalletISOLATED : Isolated wallet for the market where market the market symbol |
apiWallets | Wallet Detail | Yes | Transfer details |
Wallet Detail Request
Name | Type | Required | Description |
---|---|---|---|
currency | string | Yes | Wallet Currency |
allBalance | boolean | Yes | Indicator if all wallet balance is to be transferred |
balance | double | No | The value of the balance is to be transferred, example: 10 |
Response Content
Wallet
Name | Type | Required | Description |
---|---|---|---|
wallet | string | Yes | Wallet name |
activeWalletName | string | Yes | Active wallet name |
queryType | integer | Yes | Query type |
trackingID | long | Yes | Internal tracking ID, not being used |
walletTotalValue | double | Yes | Wallet total value |
totalValue | double | Yes | Total value |
marginBalance | double | Yes | Margin balance |
availableBalance | double | Yes | Available Balance |
unrealisedProfitLoss | double | Yes | Unrealised Profit / Loss |
maintenanceMargin | double | Yes | Maintenance margin |
leverage | double | Yes | Leverage |
openMargin | double | Yes | Open margin |
assets | Asset object | Yes | Assets available |
assetsInUse | Asset object | Yes | Assets in use |
Assets / Asset in Use
Name | Type | Required | Description |
---|---|---|---|
balance | double | Yes | Balance |
assetPrice | double | Yes | Asset price |
currency | string | Yes | Currency |
Sub-Account Wallet Transfer
POST /api/v2.1/subaccount/wallet/transfer
Transfers funds between user and sub-account wallet. User can specify the source and target wallet to transfer funds
, Wallet
permission is required. To get supported currency list please check Available currency list for action.
Request Parameters
Wallet Request
Name | Type | Required | Description |
---|---|---|---|
walletSrc | string | No | Source wallet, required when walletSrcType is ISOLATED |
walletSrcType | string | Yes | Source type, valid values are:SPOT : Spot WalletCROSS : Cross WalletISOLATED : Isolated wallet for the market where market the market symbol |
walletDest | string | No | Destination wallet, required when walletDestType is ISOLATED |
walletDestType | string | Yes | Destination type, valid values are:SPOT : Spot WalletCROSS : Cross WalletISOLATED : Isolated wallet for the market where market the market symbol |
fromUser | string | Yes | Source username |
receiver | string | Yes | Receiver username |
apiWallets | Wallet Detail | Yes | Transfer details |
Wallet Detail Request
Name | Type | Required | Description |
---|---|---|---|
currency | string | Yes | Wallet Currency |
allBalance | boolean | Yes | Indicator if all wallet balance is to be transferred |
balance | double | No | The value of the balance is to be transferred, example: 10 |
Response Content
Wallet
Name | Type | Required | Description |
---|---|---|---|
code | integer | Yes | Response code |
msg | string | Yes | Response message |
time | integer | Yes | Response Time |
data | object | No | |
success | boolean | Yes | Is transfer success |
Transfer Error Code
Code | Description |
---|---|
-2 | Invalid request parameter |
-1046 | Transfer fromUser Futures asset to DestWallet failed |
-1047 | Transfer fromUser to receiver failed |
-1048 | Transfer receiver Spot wallet to Futures wallet failed |
Order Book Websocket Streams
Endpoints
- Production
wss://ws.btse.com/ws/oss/futures
- Testnet
wss://testws.btse.io/ws/oss/futures
OSS L1 Snapshot (By grouping)
Request
{
"op": "subscribe",
"args": [
"snapshotL1:BTCPFC_0"
]
}
{
"op": "unsubscribe",
"args": [
"snapshotL1:BTCPFC_0"
]
}
Response
{
"topic": "snapshotL1:BTCPFC_0",
"data": {
"bids": [
[
"28064.9",
"1268"
]
],
"asks": [
[
"28065.0",
"1015"
]
],
"type": "snapshotL1",
"symbol": "BTCPFC",
"timestamp": 1680751558529
}
}
Subscribe to the Level 1 Orderbook through the endpoint wss://ws.btse.com/ws/oss/futures
. The format to subscribe to will be symbol_grouping
.
symbol
indicates the market symbolgrouping
indicates the grouping granularity. Valid values are 0-8.
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:BTCPFC_0"
]
}
{
"op": "unsubscribe",
"args": [
"update:BTCPFC_0"
]
}
Response
{
"topic": "update:BTCPFC_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"
],
[
"59278.5",
"0.01472"
]
],
"seqNum": 628282,
"prevSeqNum": 628281,
"type": "snapshot",
"timestamp": 1565135165600,
"symbol": "BTCPFC"
}
}
{
"topic": "update:BTCPFC",
"data": {
"bids": [],
"asks": [
[
"59367.5",
"2.15622"
],
[
"59325.5",
"0"
]
],
"seqNum": 628283,
"prevSeqNum": 628282,
"type": "delta",
"timestamp": 1565135165600,
"symbol": "BTCPFC"
}
}
Subscribe to Orderbook incremental updates through the endpoint wss://ws.btse.com/ws/oss/futures
. The format of topic will be update:symbol_grouping
(eg. update:BTCPFC_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/futures
- Testnet
wss://testws.btse.io/ws/futures
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
Here is an example for topic subscription.
Request
{
"op": "subscribe",
"args": [
"tradeHistoryApi:BTCPFC"
]
}
Response
{
"event": "subscribe",
"channel": [
"tradeHistoryApi:BTCPFC"
]
}
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:BTCPFC"
]
}
Response
{
"topic": "tradeHistoryApi:BTCPFC",
"data": [
{
"symbol": "BTCPFC",
"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/futures1624985375123" | openssl dgst -sha384 -hmac "848db84ac252b6726e5f6e7a711d9c96d9fd77d020151b45839a5b59c37203bx"
(stdin)= bd8afb8bee58ba0a2c67f84dcfe6e64d0274f55d064bb26ea84a0fe6dd8c621b541b511982fb0c0b8c244e9521a80ea1
Notifications
Request
{
"op": "subscribe",
"args": [
"notificationApiV2"
]
}
Response
{
"topic": "notificationApiV2",
"data": [
{
"symbol": "Market Symbol (eg. BTCPFC)",
"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": "STOP | TAKE_PROFIT",
"positionId": "BTCPFC-USD",
"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: Algo orders |
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 20: SUCCESS, Trade finished successfully 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 96: FUTURES_CONFIG_SETTLE_WITH_ASSET, Set futures settle currency 101: FUTURES_ORDER_PRICE_OUTSIDE_LIQUIDATION_PRICE, Futures order is outside of liquidation price 305: ERROR_ORDER_PRICE_OUT_OF_PRICE_PROTECTION_RANGE, order price is out of the protection range 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 | string | 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 |
positionId | string | Yes | Position ID |
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",
"contractSize": "The contract size of fills",
"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: Algo orders |
side | string | Yes | Trade side. BUY or SELL |
price | double | Yes | Transacted 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 |
All Position
Request
{
"op":"subscribe",
"args":["allPosition"]
}
Response
{
"topic": "allPosition",
"data": [{
"requestId": 0,
"username": "btse",
"marketName": "BTCPFC-USD",
"orderType": 90,
"orderMode": 66,
"originalAmount": 0.001,
"maxPriceHeld": 0.0,
"pegPriceMin": 0.0,
"stealth": 1.0,
"orderID": null,
"maxStealthDisplayAmount": 0.0,
"sellexchangeRate": 0.0,
"triggerPrice": 0.0,
"closeOrder": false,
"liquidationInProgress": false,
"marginType": 91,
"entryPrice": 29286.404761929,
"liquidationPrice": 0.0,
"markedPrice": 29267.967916154,
"unrealizedProfitLoss": -0.13236859,
"totalMaintenanceMargin": 3.484381756,
"totalContracts": 14.0,
"isolatedLeverage": 0.0,
"totalFees": 0.0,
"totalValue": 662.115298076,
"adlScoreBucket": 2.0,
"orderTypeName": "TYPE_FUTURES_POSITION",
"orderModeName": "MODE_BUY",
"marginTypeName": "FUTURES_MARGIN_CROSS",
"currentLeverage": 0.02,
"avgFillPrice": 0.0,
"positionId": "BTCPFC-USD|SHORT",
"positionMode": "HEDGE",
"positionDirection": "SHORT",
"settleWithNonUSDAsset": "BTC",
"contractSize": 0.001,
"takeProfitOrder": {
"orderId": "4820b20a-e41b-4273-b3ad-4b19920aeeb5",
"side": "SELL",
"triggerPrice": 31000.0,
"triggerUseLastPrice": false
},
"stopLossOrder": {
"orderId": "eff2b232-e2ce-4562-b0b4-0bd3713c11ec",
"side": "SELL",
"triggerPrice": 27000.0,
"triggerUseLastPrice": true
}
},{
"requestId": 0,
"username": "btse",
"userCurrency": null,
"marketName": "LTCPFC-USD",
"orderType": 90,
"orderMode": 83,
"originalAmount": 0.01,
"maxPriceHeld": 0,
"pegPriceMin": 0,
"stealth": 1,
"orderID": null,
"maxStealthDisplayAmount": 0,
"sellexchangeRate": 0,
"triggerPrice": 0,
"closeOrder": false,
"liquidationInProgress": false,
"marginType": 91,
"entryPrice": 69.9,
"liquidationPrice": 29684.3743872669,
"markedPrice": 70.062346733,
"unrealizedProfitLoss": -0.04870402,
"totalMaintenanceMargin": 0.319484301,
"totalContracts": 30,
"isolatedLeverage": 0,
"totalFees": 0,
"totalValue": -21.01870402,
"adlScoreBucket": 1,
"booleanVar1": false,
"orderTypeName": "TYPE_FUTURES_POSITION",
"orderModeName": "MODE_SELL",
"marginTypeName": "FUTURES_MARGIN_CROSS",
"currentLeverage": 0.1116510969,
"contractSize": 0.001,
"takeProfitOrder": null,
"stopLossOrder": null,
"settleWithNonUSDAsset": "USDT",
"positionId": "LTCPFC-USD|SHORT",
"positionMode": "HEDGE",
"positionDirection": "SHORT",
}]
}
All futures positions will be pushed via this topic once the position changes.
Response Content
Name | Type | Required | Description |
---|---|---|---|
requestId | integer | Yes | request id |
username | string | Yes | btse username |
marketName | string | Yes | market name |
orderType | integer | Yes | 90: Futures Position |
orderTypeName | string | Yes | String representation of orderType |
orderMode | integer | Yes | 66: BUY 83: SELL |
orderModeName | string | Yes | String representation of orderModeName |
originalAmount | double | Yes | order amount |
maxPriceHeld | double | Yes | max price of all time |
pegPriceMin | double | Yes | peg price min |
stealth | double | Yes | used for peg order |
orderID | string | Yes | order id |
maxStealthDisplayAmount | double | Yes | used for peg order |
sellexchangeRate | double | Yes | |
triggerPrice | double | Yes | OCO order |
closeOrder | boolean | Yes | whether it has an order to close this position |
liquidationInProgress | boolean | Yes | whether is in liquidation |
marginType | integer | Yes | WALLET TYPE: 91: CROSS 92: ISOLDATED |
marginTypeName | string | Yes | String representation of marginType |
entryPrice | double | Yes | entry price |
liquidationPrice | double | Yes | liquidation price |
markPrice | double | Yes | mark price |
unrealizedProfitLoss | double | Yes | unrealized pnl |
totalMaintenanceMargin | double | Yes | maintenance margin |
totalContract | double | Yes | size of the contract |
isolatedLeverage | double | Yes | |
totalFees | double | Yes | |
totalValue | double | Yes | |
adlScoreBucket | double | Yes | |
currentLeverage | double | Yes | |
avgFillPrice | double | Yes | |
settleWithNonUSDAsset | string | Yes | |
takeProfitOrder | TakeProfitOrder object | No | Take profit order info |
stopLossOrder | StopLossOrder object | No | Stop loss order info |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | Position id |
contractSize | double | Yes | The position contract size |
Positions
Request
{
"op":"subscribe",
"args":["positions"]
}
Response
{
"topic": "positions",
"data": [{
"orderID": null,
"requestId": 0,
"username": "btse",
"marketName": "BTCPFC-USD",
"orderType": 90,
"orderMode": 66,
"originalAmount": 0.001,
"maxPriceHeld": 0.0,
"pegPriceMin": 0.0,
"stealth": 1.0,
"orderID": null,
"maxStealthDisplayAmount": 0.0,
"sellexchangeRate": 0.0,
"triggerPrice": 0.0,
"closeOrder": false,
"liquidationInProgress": false,
"marginType": 91,
"entryPrice": 29286.404761929,
"liquidationPrice": 0.0,
"markedPrice": 29267.967916154,
"unrealizedProfitLoss": -0.13236859,
"totalMaintenanceMargin": 3.484381756,
"totalContracts": 14.0,
"isolatedLeverage": 0.0,
"totalFees": 0.0,
"totalValue": 662.115298076,
"adlScoreBucket": 2.0,
"orderTypeName": "TYPE_FUTURES_POSITION",
"orderModeName": "MODE_BUY",
"marginTypeName": "FUTURES_MARGIN_CROSS",
"currentLeverage": 0.02,
"avgFillPrice": 0.0,
"settleWithNonUSDAsset": "BTC",
"contractSize": 0.001,
"takeProfitOrder": {
"orderId": "4820b20a-e41b-4273-b3ad-4b19920aeeb5",
"side": "SELL",
"triggerPrice": 31000.0,
"triggerUseLastPrice": false
},
"stopLossOrder": {
"orderId": "eff2b232-e2ce-4562-b0b4-0bd3713c11ec",
"side": "SELL",
"triggerPrice": 27000.0,
"triggerUseLastPrice": true
}
},{
"orderID": null,
"requestId": 0,
"username": "btse",
"marketName": "LTCPFC-USD",
"orderType": 90,
"orderMode": 83,
"originalAmount": 0.01,
"maxPriceHeld": 0,
"pegPriceMin": 0,
"stealth": 1,
"maxStealthDisplayAmount": 0,
"sellexchangeRate": 0,
"triggerPrice": 0,
"closeOrder": false,
"liquidationInProgress": false,
"marginType": 91,
"entryPrice": 69.9,
"liquidationPrice": 29682.415101008,
"markedPrice": 69.685573595,
"unrealizedProfitLoss": 0.06432792,
"totalMaintenanceMargin": 0.318744,
"totalContracts": 30,
"isolatedLeverage": 0,
"totalFees": 0,
"totalValue": -20.905672079,
"adlScoreBucket": 2,
"orderTypeName": "TYPE_FUTURES_POSITION",
"orderModeName": "MODE_SELL",
"marginTypeName": "FUTURES_MARGIN_CROSS",
"currentLeverage": 0.1113820366,
"averageFillPrice": 0,
"filledSize": 0,
"contractSize": 0.001,
"takeProfitOrder": null,
"stopLossOrder": null,
"positionId": "LTCPFC-USD|SHORT",
"positionMode": "HEDGE",
"positionDirection": "SHORT",
"settleWithNonUSDAsset": "USDT"
}
]
}
Response (The position has been closed)
{
"topic": "positions",
"data": [{
"requestId": 0,
"username": "btse",
"marketName": "BTCPFC-USD",
"orderType": 0,
"orderMode": 0,
"originalAmount": 0,
"maxPriceHeld": 0,
"pegPriceMin": 0,
"stealth": 0,
"orderID": null,
"maxStealthDisplayAmount": 0,
"sellexchangeRate": 0,
"triggerPrice": 0,
"closeOrder": false,
"liquidationInProgress": false,
"marginType": 0,
"entryPrice": 0,
"liquidationPrice": 0,
"markedPrice": 0,
"unrealizedProfitLoss": 0,
"totalMaintenanceMargin": 0,
"totalContracts": 0,
"isolatedLeverage": 0,
"totalFees": 0,
"totalValue": 0,
"adlScoreBucket": 0,
"orderTypeName": null,
"orderModeName": null,
"marginTypeName": null,
"currentLeverage": 0,
"avgFillPrice": 0,
"settleWithNonUSDAsset": "BTC",
"contractSize": 0.001,
"takeProfitOrder": null,
"stopLossOrder": null,
"positionId": "BTCPFC-USD|SHORT",
"positionMode": null,
"positionDirection": null,
}]
}
All futures positions will be pushed via this topic once the position changes. If the user reduces the position to 0, the topic will push data with the totalContracts value of 0 once.
Response Content
Name | Type | Required | Description |
---|---|---|---|
requestId | integer | Yes | request id |
username | string | Yes | btse username |
marketName | string | Yes | market name |
orderType | integer | Yes | 90: Futures Position |
orderTypeName | string | Yes | String representation of orderType |
orderMode | integer | Yes | 66: BUY 83: SELL |
orderModeName | string | Yes | String representation of orderModeName |
originalAmount | double | Yes | order amount |
maxPriceHeld | double | Yes | max price of all time |
pegPriceMin | double | Yes | peg price min |
stealth | double | Yes | used for peg order |
orderID | string | Yes | order id |
maxStealthDisplayAmount | double | Yes | used for peg order |
sellexchangeRate | double | Yes | |
triggerPrice | double | Yes | OCO order |
closeOrder | boolean | Yes | whether it has an order to close this position |
liquidationInProgress | boolean | Yes | whether is in liquidation |
marginType | integer | Yes | WALLET TYPE: 91: CROSS 92: ISOLDATED |
marginTypeName | string | Yes | String representation of marginType |
entryPrice | double | Yes | entry price |
liquidationPrice | double | Yes | liquidation price |
markPrice | double | Yes | mark price |
unrealizedProfitLoss | double | Yes | unrealized pnl |
totalMaintenanceMargin | double | Yes | maintenance margin |
totalContract | double | Yes | size of the contract |
isolatedLeverage | double | Yes | |
totalFees | double | Yes | |
totalValue | double | Yes | |
adlScoreBucket | double | Yes | |
currentLeverage | double | Yes | |
avgFillPrice | double | Yes | |
settleWithNonUSDAsset | string | Yes | |
takeProfitOrder | TakeProfitOrder object | No | Take profit order info |
stopLossOrder | StopLossOrder object | No | Stop loss order info |
positionMode | string | Yes | Position mode ONE_WAY or HEDGE |
positionDirection | string | Yes | Position direction |
positionId | string | Yes | Position id |
contractSize | double | Yes | The position contract size |