Skip to main content

Private HTTP API V4

Private endpoints V4 for trading

Base URL is https://whitebit.com

Endpoint example: https://whitebit.com/api/v4/{endpoint}

All endpoints return time in Unix-time format.

All endpoints return either a JSON object or array.

For receiving responses from API calls please use http method POST

Error messages V4 format:


{
"code": 0,
"message": "MESSAGE",
"errors": {
"PARAM1": [
"MESSAGE"
],
"PARAM2": [
"MESSAGE"
]
}
}

Terminology

Pair:

Stock - currency that you want to buy or sell

Money - currency that you are using to buy or sell something

Maker - person who puts an order and waiting till this order will be finished

Taker - person who finishes existing order

Precision - is the number of digits to the right of the decimal point

Bid - buy order

Ask - sell order

Limit order - to place this order, you need to fill in the 'Price' and 'Amount' fields. If this order finds a corresponding order on the opposite side, it will be executed. Otherwise it will be placed into the orderbook.

Market order - to place this order, you need to fill 'Amount' field using Money value. This order finds a corresponding order on the opposite side and executes. Otherwise it will be cancelled.

Stock market order - to place this order, you need to fill 'Amount' field using Stock value. This order finds a corresponding order on the opposite side and executes. Otherwise it will be cancelled.


Spot

Trading balance

[POST] /api/v4/trade-account/balance

This endpoint retrieves the trade balance by currency ticker or all balances.

Parameters:

NameTypeMandatoryDescription
tickerStringNoCurrency's ticker. Example: BTC

Request BODY raw:

{
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 422 if request validation failed
  • Status 400 if inner validation failed
  • Status 503 if service temporary unavailable
{
"...": {...},
"BTC": {
"available": "0.123", // Available balance of currency for trading
"freeze": "1" // Balance of currency that is currently in active orders
},
"...": {...},
"XMR": {
"available": "3013",
"freeze": "100"
},
"...": {...}
}
Errors:
{
"code": 30,
"message": "Validation failed",
"errors": {
"ticker": [
"Ticker field should be a string."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"ticker": [
"Currency was not found."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}
___

Create limit order

[POST] /api/v4/order/new

This endpoint creates limit trading order.

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'
amountString/NumberYesAmount of stock currency to buy or sell. Example: '0.001' or 0.001
priceString/NumberYesPrice in money currency. Example: '9800' or 9800
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.
postOnlybooleanNoOrders are guaranteed to be the maker order when executed. Variables: 'true' / 'false' Example: 'false'.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.01",
"price": "40000",
"postOnly": false,
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if request validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom client order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "limit", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // if order finished - amount in money currency that is finished
"dealStock": "0", // if order finished - amount in stock currency that is finished
"amount": "0.01", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.001", // if order not finished - rest of the amount that must be finished
"dealFee": "0", // fee in money that you pay if order is finished
"price": "40000" // price
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
  • 32 - amount validation failed
  • 33 - price validation failed
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 35 - incorrect maker fee (it is less than zero or its precision is too big)
  • 36 - clientOrderId validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field is required."
],
"market": [
"Market field is required."
],
"price": [
"Price field is required."
],
"side": [
"Side field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"side": [
"Side field should contain only 'buy' or 'sell' values."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field should be numeric string or number."
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be numeric string or number."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Given amount is less than min amount 0.001",
"Min amount step = 0.000001"
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field should be a string."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field field should contain only latin letters, numbers and dashes."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"This client order id is already used by the current account. It will become available in 24 hours (86400 seconds)."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"total": [
"Total(amount * price) is less than 5.05"
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Min amount step = 0.01" // money/stock precision is not taken into consideration when order was submitted
]
}
}

{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be at least 10",
"Min price step = 0.000001"
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price should be greater than 0."
]
}
}
{
"code": 34,
"message": "Validation failed",
"errors": {
"taker_fee": [
"Incorrect taker fee"
]
}
}
{
"code": 35,
"message": "Validation failed",
"errors": {
"maker_fee": [
"Incorrect maker fee"
]
}
}
{
"code": 10,
"message": "Inner validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}
{
"code": 11,
"message": "Inner validation failed",
"errors": {
"amount": [
"Amount too small."
]
}
}
{
"code": 13,
"message": "Inner validation failed",
"errors": {
"postOnly": [
"This order couldn't be executed as a maker order and was canceled."
]
}
}

Create market order

[POST] /api/v4/order/market

This endpoint creates market trading order.

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'
amountString/NumberYes⚠️ Amount of money currency to buy or amount in stock currency to sell. Example: '5 USDT' for buy (min total) and '0.001 BTC' for sell (min amount).
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "50", // I want to buy BTC for 50 USDT
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}
{
"market": "BTC_USDT",
"side": "sell",
"amount": "0.01", // I want to sell 0.01 BTC
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if request validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom client order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "market", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // amount in money currency that finished
"dealStock": "0", // amount in stock currency that finished
"amount": "0.001", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"left": "0.001", // rest of amount that must be finished
"dealFee": "0" // fee in money that you pay if order is finished
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
  • 32 - amount validation failed
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 36 - clientOrderId validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field is required."
],
"market": [
"Market field is required."
],
"side": [
"Side field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"side": [
"Side field should contain only 'buy' or 'sell' values."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field should be numeric string or number."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Given amount is less than min amount 0.001",
"Min amount step = 0.000001"
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field should be a string."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field field should contain only latin letters, numbers and dashes."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"This client order id is already used by the current account. It will become available in 24 hours (86400 seconds)."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Total amount + fee should be no less than"
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Min total step = = 0.000001"
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount should be greater than 0."
]
}
}

{
"code": 34,
"message": "Validation failed",
"errors": {
"taker_fee": [
"Incorrect taker fee"
]
}
}

{
"code": 10,
"message": "Inner validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}

{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

{
"code": 11,
"message": "Inner validation failed",
"errors": {
"amount": [
"Amount too small."
]
}
}


Create stock market order

[POST] /api/v4/order/stock_market

This endpoint creates buy stock market trading order.

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
sideStringYesOrder type. Available variables: "buy", "sell"
amountString/NumberYes⚠️ Amount in stock currency for buy or sell. Example: "0.0001" or 0.0001.
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.001", // I want to buy 0.001 BTC
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if request validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom client order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "stock market", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // amount in money currency that finished
"dealStock": "0", // amount in stock currency that finished
"amount": "0.001", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"left": "0.001", // rest of amount that must be finished
"dealFee": "0" // fee in money that you pay if order is finished
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
  • 32 - amount validation failed
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 36 - clientOrderId validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field is required."
],
"market": [
"Market field is required."
],
"side": [
"Side field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"side": [
"Side field should contain only 'buy' or 'sell' values."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field should be numeric string or number."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Given amount is less than min amount 0.001",
"Min amount step = 0.000001"
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field should be a string."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field field should contain only latin letters, numbers and dashes."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"This client order id is already used by the current account. It will become available in 24 hours (86400 seconds)."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount should be greater than 0."
]
}
}

{
"code": 34,
"message": "Validation failed",
"errors": {
"taker_fee": [
"Incorrect taker fee"
]
}
}

{
"code": 10,
"message": "Inner validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}

{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

{
"code": 11,
"message": "Inner validation failed",
"errors": {
"amount": [
"Amount too small."
]
}
}


Create stop-limit order

[POST] /api/v4/order/stop_limit

This endpoint creates stop-limit trading order

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'
amountString/NumberYesAmount of stock currency to buy or sell. Example: '0.001' or 0.001
priceString/NumberYesPrice in money currency. Example: '9800' or 9800
activation_priceString/NumberYesActivation price in money currency. Example: '10000' or 10000
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.001",
"price": "40000",
"activation_price": "40000",
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if request validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom client order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "stop limit", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // if order finished - amount in money currency that finished
"dealStock": "0", // if order finished - amount in stock currency that finished
"amount": "0.001", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.001", // if order not finished - rest of amount that must be finished
"dealFee": "0", // fee in money that you pay if order is finished
"price": "40000", // price
"activation_price": "40000" // activation price
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
  • 32 - amount validation failed
  • 33 - price validation failed
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 35 - incorrect maker fee (it is less than zero or its precision is too big)
  • 36 - clientOrderId validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price field is required."
],
"amount": [
"Amount field is required."
],
"market": [
"Market field is required."
],
"price": [
"Price field is required."
],
"side": [
"Side field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"side": [
"Side field should contain only 'buy' or 'sell' values."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field should be numeric string or number."
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be numeric string or number."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Given amount is less than min amount 0.001",
"Min amount step = 0.000001"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"total": [
"Total(amount * price) is less than 5.05"
]
}
}
{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field should be a string."
]
}
}
{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field field should contain only latin letters, numbers and dashes."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"This client order id is already used by the current account. It will become available in 24 hours (86400 seconds)."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount should be greater than 0."
]
}
}

{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be at least 10",
"Min price step = 0.000001"
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price should be greater than 0."
]
}
}
{
"code": 34,
"message": "Validation failed",
"errors": {
"taker_fee": [
"Incorrect taker fee"
]
}
}
{
"code": 35,
"message": "Validation failed",
"errors": {
"maker_fee": [
"Incorrect maker fee"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price should be numeric string."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should be greater than 0."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Empty history"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price = 10"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price step = 0.00001"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"lastPrice": [
"internal error"
]
}
}
{
"code": 10,
"message": "Inner validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}
{
"code": 11,
"message": "Inner validation failed",
"errors": {
"amount": [
"Amount too small."
]
}
}

Create stop-market order

[POST] /api/v4/order/stop_market

This endpoint creates stop-market trading order

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'
amountString/NumberYes⚠️Amount of money currency to buy or amount in stock currency to sell. Example: '0.01' or 0.01 for buy and '0.0001' for sell.
activation_priceString/NumberYesActivation price in money currency. Example: '10000' or 10000
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "50", // I want to buy for 50 USDT
"activation_price": "40000",
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}
{
"market": "BTC_USDT",
"side": "sell",
"amount": "0.001", // I want to sell 0.01 BTC
"activation_price": "40000",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if inner validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom order identifier; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "stop market", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // if order finished - amount in money currency that finished
"dealStock": "0", // if order finished - amount in stock currency that finished
"amount": "0.001", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.001", // if order not finished - rest of amount that must be finished
"dealFee": "0", // fee in money that you pay if order is finished
"activation_price": "40000" // activation price
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
  • 32 - amount validation failed
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 36 - clientOrderId validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price field is required."
],
"amount": [
"Amount field is required."
],
"market": [
"Market field is required."
],
"side": [
"Side field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"side": [
"Side field should contain only 'buy' or 'sell' values."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field should be numeric string or number."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Given amount is less than min amount 0.001",
"Min amount step = 0.000001"
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field should be a string."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field field should contain only latin letters, numbers and dashes."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"This client order id is already used by the current account. It will become available in 24 hours (86400 seconds)."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount should be greater than 0."
]
}
}

{
"code": 34,
"message": "Validation failed",
"errors": {
"taker_fee": [
"Incorrect taker fee"
]
}
}

{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price should be numeric string."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should be greater than 0."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Empty history"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price = 10"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price step = 0.00001"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"lastPrice": [
"internal error"
]
}
}
{
"code": 10,
"message": "Inner validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}
{
"code": 11,
"message": "Inner validation failed",
"errors": {
"amount": [
"Amount too small."
]
}
}

Cancel order

[POST] /api/v4/order/cancel

Cancel existing order

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
orderIdString/IntYesOrder Id. Example: 4180284841 or "4180284841"

Request BODY raw:

{
"market": "BTC_USDT",
"orderId": 4180284841,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "customId11", // custom order identifier; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "stop market", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // if order finished - amount in money currency that is finished
"dealStock": "0", // if order finished - amount in stock currency that is finished
"amount": "0.001", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.001", // if order not finished - rest of the amount that must be finished
"dealFee": "0", // fee in money that you pay if order is finished
"price": "40000", // price if price isset
"activation_price": "40000" // activation price if activation price is set
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"market": [
"Market field is required."
],
"orderId": [
"OrderId field is required."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"orderId": [
"OrderId field should be an integer."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"market": [
"Market field should be a string.",
"Market field format is invalid."
]
}
}
{
"code": 2,
"message": "Inner validation failed",
"errors": {
"orderId": [
"Unexecuted order was not found."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

Query unexecuted(active) orders

[POST] /api/v4/orders

This endpoint retrieves unexecuted orders only.

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
orderIdStringNoAvailable orderId. Example: 3134995325
clientOrderIdStringNoAvailable clientOrderId. Example: customId11
limitIntNoLIMIT is a special clause used to limit records a particular query can return. Default: 50, Min: 1, Max: 100
offsetIntNoIf you want the request to return entries starting from a particular line, you can use OFFSET clause to tell it where it should start. Default: 0, Min: 0, Max: 10000

Request BODY raw:

{
"market": "BTC_USDT",
"orderId": "3134995325", //order Id (optional)
"clientOrderId": "customId11", // custom order id; (optional)
"offset": 0,
"limit": 100,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 422 if request validation failed
  • Status 400 if inner validation failed
  • Status 503 if service temporary unavailable
[
{
"orderId": 3686033640, // unexecuted order ID
"clientOrderId": "customId11", // custom order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // currency market
"side": "buy", // order side
"type": "limit", // unexecuted order type
"timestamp": 1594605801.49815, // current timestamp of unexecuted order
"dealMoney": "0", // executed amount in money
"dealStock": "0", // executed amount in stock
"amount": "2.241379", // active order amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "2.241379", // unexecuted amount in stock
"dealFee": "0", // executed fee by deal
"price": "40000" // unexecuted order price
},
{...}
]

Errors:
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"The market field is required."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should be a string."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field format is invalid."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"message": "Validation failed",
"code": 31,
"errors": {
"market": [
"Market is not available"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"The limit must be an integer."
],
"offset": [
"The offset must be an integer."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"The limit may not be greater than 100."
],
"offset": [
"The offset may not be greater than 10000."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"The limit must be at least 1."
],
"offset": [
"The offset must be at least 0."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

Query executed order history

[POST] /api/v4/trade-account/executed-history

This endpoint retrieves the deals history. Can be sorted by single market if needed.

Parameters:

NameTypeMandatoryDescription
marketStringNoRequested market. Example: BTC_USDT
clientOrderIdStringNoRequested clientOrderId. Example: customId11
limitIntNoLIMIT is a special clause used to limit records a particular query can return. Default: 50, Min: 1, Max: 100
offsetIntNoIf you want the request to return entries starting from a particular line, you can use OFFSET clause to tell it where it should start. Default: 0, Min: 0, Max: 10000

Request BODY raw:

{
"clientOrderId": "customId11", // custom order id; (optional)
"offset": 0,
"limit": 100,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 422 if request validation failed
  • Status 400 if inner validation failed
  • Status 503 if service temporary unavailable
{
"BTC_USDT": [
{
"id": 160305483, // deal ID
"clientOrderId": "customId11", // custom order id; "clientOrderId": "" - if not specified.
"time": 1594667731.724403, // Timestamp of the executed deal
"side": "sell", // Deal side "sell" / "buy"
"role": 2, // Role - 1 - maker, 2 - taker
"amount": "0.000076", // amount in stock
"price": "9264.21", // price
"deal": "0.70407996", // amount in money
"fee": "0.00070407996" // paid fee
},
{...}
],
"DTBC_DUSDT": [...]
}


Errors:
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit field should be an integer."
],
"offset": [
"Offset field should be an integer."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field format is invalid."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should be a string."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit should not be greater than 100."
],
"offset": [
"Offset should not be greater than 10000."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit should be at least 1."
],
"offset": [
"Offset should be at least 0."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

Query executed order deals

[POST] /api/v4/trade-account/order

This endpoint retrieves deals history details on pending or executed order.

Parameters:

NameTypeMandatoryDescription
orderIdIntYesOrder ID. Example: 1234
limitIntNoLIMIT is a special clause used to limit records a particular query can return. Default: 50, Min: 1, Max: 100
offsetIntNoIf you want the request to return entries starting from a particular line, you can use OFFSET clause to tell it where it should start. Default: 0, Min: 0, Max: 10000

Request BODY raw:

{
"orderId": 3135554375,
"offset": 0,
"limit": 100,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 422 if request validation failed
  • Status 400 if inner validation failed
  • Status 503 if service temporary unavailable
{
"records": [
{
"time": 1593342324.613711, // Timestamp of executed order
"fee": "0.00000419198", // fee that you pay
"price": "0.00000701", // price
"amount": "598", // amount in stock
"id": 149156519, // deal id
"dealOrderId": 3134995325, // completed order Id
"clientOrderId": "customId11", // custom order id; "clientOrderId": "" - if not specified.
"role": 2, // Role - 1 - maker, 2 - taker
"deal": "0.00419198" // amount in money
}
],
"offset": 0,
"limit": 100
}


Errors:
{
"code": 30,
"message": "Validation failed",
"errors": {
"orderId": [
"Order was not found."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"orderId": [
"OrderId field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"orderId": [
"OrderId field should be an integer."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit should not be greater than 100."
],
"offset": [
"Offset should not be greater than 10000."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit should be at least 1."
],
"offset": [
"Offset should be at least 0."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

Query executed orders

[POST] /api/v4/trade-account/order/history

This endpoint retrieves executed order history by market.

Parameters:

NameTypeMandatoryDescription
marketStringNoRequested available market. Example: BTC_USDT
orderIdStringNoRequested available orderId. Example: 3134995325
clientOrderIdStringNoRequested available clientOrderId. Example: clientOrderId
limitIntNoLIMIT is a special clause used to limit records a particular query can return. Default: 50, Min: 1, Max: 100
offsetIntNoIf you want the request to return entries starting from a particular line, you can use OFFSET clause to tell it where it should start. Default: 0, Min: 0, Max: 10000

Request BODY raw:

{
"market": "BTC_USDT", //optional
"orderId": "3134995325", //order Id (optional)
"clientOrderId": "clientOrderId", // custom order id; (optional)
"offset": 0,
"limit": 100,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 422 if request validation failed
  • Status 400 if inner validation failed
  • Status 503 if service temporary unavailable

Empty response if order is not yours

{
"BTC_USDT": [
{
"amount": "0.0009", // amount of trade
"price": "40000", // price
"type": "limit", // order type
"id": 4986126152, // order id
"clientOrderId": "customId11", // custom order identifier; "clientOrderId": "" - if not specified.
"side": "sell", // order side
"ctime": 1597486960.311311, // timestamp of order creation
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"ftime": 1597486960.311332, // executed order timestamp
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"dealFee": "0.041258268", // paid fee if order is finished
"dealStock": "0.0009", // amount in stock currency that finished
"dealMoney": "41.258268" // amount in money currency that finished
},
{...}
]
}


Errors:
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit field should be an integer."
],
"offset": [
"Offset field should be an integer."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field format is invalid."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"market": [
"Market field should be a string."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit should not be greater than 100."
],
"offset": [
"Offset should not be greater than 10000."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"Limit should be at least 1."
],
"offset": [
"Offset should be at least 0."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

Collateral

Collateral Account Balance

[POST] /api/v4/collateral-account/balance

This endpoint returns a current collateral balance

Parameters

NameTypeMandatoryDescription
tickerStringNoAsset to be filtered. For example: BTC

Request BODY raw:

{
"ticker": "BTC",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if inner validation failed
  • Status 503 if service temporary unavailable
{
"BTC": 1,
"USDT": 1000
}

Collateral Limit Order

[POST] /api/v4/order/collateral/limit

This endpoint creates limit order using collateral balance

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable margin market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'. For open long position you have to use buy, for short sell. Also to close current position you have to place opposite order with current position amount.
amountStringYes⚠️Amount of stock currency to buy or sell.
priceStringYesPrice in money currency. Example: '9800'
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.
postOnlybooleanNoOrders are guaranteed to be the maker order when executed. Variables: true / false Example: false.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.01",
"price": "40000",
"postOnly": false,
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if inner validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom client order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "limit", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // if order finished - amount in money currency that is finished
"dealStock": "0", // if order finished - amount in stock currency that is finished
"amount": "0.01", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.001", // if order not finished - rest of the amount that must be finished
"dealFee": "0", // fee in money that you pay if order is finished
"price": "40000" // price
}
Errors:

Error codes:

  • 31 - market is disabled for trading
  • 32 - incorrect amount (it is less than or equals zero or its precision is too big)
  • 33 - incorrect price (it is less than or equals zero or its precision is too big)
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 35 - incorrect maker fee (it is less than zero or its precision is too big)
  • 36 - incorrect clientOrderId (invalid string or not unique id)

Detailed information about errors response you can find in Create limit order


Collateral Market Order

[POST] /api/v4/order/collateral/market

This endpoint creates market trading order.

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable margin market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'. For open long position you have to use buy, for short sell. Also to close current position you have to place opposite order with current position amount.
amountStringYes⚠️Amount of stock currency to buy or sell.
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.01", // I want to buy 0.01 BTC
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}
{
"market": "BTC_USDT",
"side": "sell",
"amount": "0.01", // I want to sell 0.01 BTC
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if internal validation failed
  • Status 503 if service is temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom client order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "market", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // amount in money currency that finished
"dealStock": "0", // amount in stock currency that finished
"amount": "0.001", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - its rounded to zero
"left": "0.001", // rest of amount that must be finished
"dealFee": "0" // fee in money that you pay if order is finished
}
Errors:

Error codes:

  • 31 - market is disabled for trading
  • 32 - incorrect amount (it is less than or equals zero or its precision is too big)
  • 33 - incorrect price (it is less than or equals zero or its precision is too big)
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 35 - incorrect maker fee (it is less than zero or its precision is too big)
  • 36 - incorrect clientOrderId (invalid string or not unique id)

Detailed information about errors response you can find in Create market order



Collateral Trigger Market Order

[POST] /api/v4/order/collateral/trigger_market

This endpoint creates margin trigger market order

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable margin market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'. For open long position you have to use buy, for short sell. Also to close current position you have to place opposite order with current position amount.
amountStringYes⚠️Amount of stock currency to buy or sell.
activation_priceStringYesActivation price in money currency. Example: '10000'
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.01", // I want to buy 0.01 BTC
"activation_price": "40000",
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}
{
"market": "BTC_USDT",
"side": "sell",
"amount": "0.01", // I want to sell 0.01 BTC
"activation_price": "40000",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if inner validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom order identifier; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "stop market", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // if order finished - amount in money currency that finished
"dealStock": "0", // if order finished - amount in stock currency that finished
"amount": "0.001", // amount
"takerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.001", // if order not finished - rest of amount that must be finished
"dealFee": "0", // fee in money that you pay if order is finished
"activation_price": "40000" // activation price
}
Errors:

Error codes:

  • 31 - market is disabled for trading
  • 32 - incorrect amount (it is less than or equals zero or its precision is too big)
  • 33 - incorrect price (it is less than or equals zero or its precision is too big)
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 35 - incorrect maker fee (it is less than zero or its precision is too big)
  • 36 - incorrect clientOrderId (invalid string or not unique id)

Collateral Account Summary

[POST] /api/v4/collateral-account/summary

This endpoint retrieves summary of collateral account

Request BODY raw:

{
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 503 if service temporary unavailable
{
"equity": "130970.8947456254113367", // total equity of collateral balance including lending funds in USDT
"margin": "456.58349", // amount of funds in open position USDT
"freeMargin": "129681.3285348840110099", // free funds for trading according to
"unrealizedFunding": "0.0292207414003268", // funding that will be paid on next position stage change (order, liquidation, etc)
"pnl": "-832.9535", // curren profit and loss in USDT
"leverage": 10 // current leverage of account which affect amount of lending funds
}

Open Positions

[POST] /api/v4/collateral-account/positions/open

This endpoint returns all open positions

Parameters:

NameTypeMandatoryDescription
marketStringNoRequested market. Example: BTC_USDT

Request BODY raw:

{
"market": "BTC_USDT",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if inner validation failed
  • Status 503 if service temporary unavailable
[
{
"positionId": 527, // position ID
"market": "BTC_USDT", // market name
"openDate": 1651568067.789679, // date of position opening
"modifyDate": 1651568067.789679, // date of position modifying (this is date of current event)
"amount": "0.1", // amount of order
"basePrice": "45658.349", // base price of position
"liquidationPrice": null, // liquidation price according to current state of position
"liquidationState": null, // state of liquidation. Possible values: null, Margin_call, Liquidation
"leverage": "5", // current collateral balance leverage
"pnl": "-168.42", // current profit and loss in **money**
"pnlPercent": "-0.43", // current profit and loss in percentage
"margin": "8316.74", // amount of funds in open position **money**
"freeMargin": "619385.67", // free funds for trading according to
"funding": "0", // funding that will be paid on next position stage change (order, liquidation, etc)
"unrealizedFunding": "0.0019142920201966", // funding that will be paid on next position stage change (order, liquidation, etc)
},
...
]
  • NOTE: In case of position opening using trigger or limit order you can get situation when basePrice, liquidationPrice, amount, pnl, pnlPercent returns with null value. It happens when funds are lending, and you start to pay funding fee, but position is not completely opened, cos activation price hadn't been triggered yet.

Positions History

[POST] /api/v4/collateral-account/positions/history

This endpoint returns past positions history. Each position represented by position states. Each of them means event that shows current position changes such order, position close, liquidation, etc.

If your request has a "positionId" field, you receive data only with this "positionId". If your request has a "market" field, you receive data only by this "market".

"positionId" field has higher priority then "market" field.

Parameters:

NameTypeMandatoryDescription
marketStringNoRequested market. Example: BTC_USDT
positionIdIntNoRequested position

Request BODY raw:

{
"market": "BTC_USDT", //optional
"positionId": 1, //optional
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if inner validation failed
  • Status 503 if service temporary unavailable
[

{
"positionId": 111, // position ID
"market": "BTC_USDT", // position market
"openDate": 1650400589.882613, // date of position opening
"modifyDate": 1650400589.882613, // date of position modifying (this is date of current event)
"amount": "0.1", // amount of order
"basePrice": "45658.349", // base price of position
"realizedFunding": "0", // funding fee for whole position lifetime till current state
"liquidationPrice": null, // liquidation price according to current state of position
"liquidationState": null, // state of liquidation. Possible values: null, Margin_call, Liquidation
"orderDetail": { // details of order which changes position
"id": 97067934, // order ID
"tradeAmount": "0.1", // trade amount of order
"basePrice": "41507.59", // order's base price
"tradeFee": "415.07", // order's trade fee
"fundingFee": null // funding fee which was captured by this position change (order)
}
},
...
]

Change Collateral Account Leverage

[POST] /api/v4/collateral-account/leverage

This endpoint changes the current leverage of account.

Parameters:

NameTypeMandatoryDescription
leverageIntYesNew collateral account leverage value. Acceptable values: 1, 2, 3, 5, 10, 20

Request BODY raw:

{
"leverage": 5,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 422 if inner validation failed
  • Status 503 if service temporary unavailable
{
"leverage": 5 // current collateral balance leverage
}

Query unexecuted(active) OCO orders

[POST] /api/v4/oco-orders

This endpoint retrieves unexecuted oco orders only.

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
limitIntNoLIMIT is a special clause used to limit records a particular query can return. Default: 50, Min: 1, Max: 100
offsetIntNoIf you want the request to return entries starting from a particular line, you can use OFFSET clause to tell it where it should start. Default: 0, Min: 0, Max: 10000

Request BODY raw:

{
"market": "BTC_USDT",
"offset": 0,
"limit": 100,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 422 if request validation failed
  • Status 400 if inner validation failed
  • Status 503 if service temporary unavailable
[
{
"id": 117703764513, // oco order id
"stop_loss": {
"orderId": 117703764514, // unexecuted order ID
"clientOrderId": "", // custom order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // currency market
"side": "buy", // order side
"type": "stop limit", // unexecuted order type
"timestamp": 1594605801.49815, // current timestamp of unexecuted order
"dealMoney": "0", // executed amount in money
"dealStock": "0", // executed amount in stock
"amount": "2.241379", // active order amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "2.241379", // unexecuted amount in stock
"dealFee": "0", // executed fee by deal
"post_only": false, // orders are guaranteed to be the maker order when executed.
"mtime": 1662478154.941582,
"price": "19928.79", // unexecuted order price
"activation_price": "29928.79", // activation price
"activation_condition": "gte", // activation condition
"activated": 0 // activation status
},
"take_profit": {
"orderId": 117703764515, // unexecuted order ID
"clientOrderId": "", // custom order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // currency market
"side": "buy", // order side
"type": "limit", // unexecuted order type
"timestamp": 1662478154.941582, // current timestamp of unexecuted order
"dealMoney": "0", // executed amount in money
"dealStock": "0", // executed amount in stock
"amount": "0.635709", // active order amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.635709", // unexecuted amount in stock
"dealFee": "0", // executed fee by deal
"post_only": false, // orders are guaranteed to be the maker order when executed.
"mtime": 1662478154.941582,
"price": "9928.79" // unexecuted order price
}
},
{...}
]

Errors:
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"The market field is required."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should be a string."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field format is invalid."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"message": "Validation failed",
"code": 31,
"errors": {
"market": [
"Market is not available"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"The limit must be an integer."
],
"offset": [
"The offset must be an integer."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"The limit may not be greater than 100."
],
"offset": [
"The offset may not be greater than 10000."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"limit": [
"The limit must be at least 1."
],
"offset": [
"The offset must be at least 0."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}

Create collateral OCO order

[POST] /api/v4/order/collateral/oco

This endpoint creates collateral trading OCO order

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'
amountString/NumberYesAmount of stock currency to buy or sell. Example: '0.001' or 0.001
priceString/NumberYesPrice in money currency for limit order. Example: '9800' or 9800
activation_priceString/NumberYesActivation price in money currency. Example: '10000' or 10000
stop_limit_priceString/NumberYesPrice in money currency for stop limit order. Example: '10100' or 10100
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.001",
"price": "40000",
"activation_price": "41000",
"stop_limit_price": "42000",
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if request validation failed
  • Status 503 if service temporary unavailable
{
"id": 117703764513, // oco order id
"stop_loss": {
"orderId": 117703764514, // unexecuted order ID
"clientOrderId": "", // custom order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // currency market
"side": "buy", // order side
"type": "stop limit", // unexecuted order type
"timestamp": 1594605801.49815, // current timestamp of unexecuted order
"dealMoney": "0", // executed amount in money
"dealStock": "0", // executed amount in stock
"amount": "2.241379", // active order amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "2.241379", // unexecuted amount in stock
"dealFee": "0", // executed fee by deal
"post_only": false, // orders are guaranteed to be the maker order when executed.
"mtime": 1662478154.941582,
"price": "19928.79", // unexecuted order price
"activation_price": "29928.79", // activation price
"activation_condition": "gte", // activation condition
"activated": 0 // activation status
},
"take_profit": {
"orderId": 117703764515, // unexecuted order ID
"clientOrderId": "", // custom order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // currency market
"side": "buy", // order side
"type": "limit", // unexecuted order type
"timestamp": 1662478154.941582, // current timestamp of unexecuted order
"dealMoney": "0", // executed amount in money
"dealStock": "0", // executed amount in stock
"amount": "0.635709", // active order amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.635709", // unexecuted amount in stock
"dealFee": "0", // executed fee by deal
"post_only": false, // orders are guaranteed to be the maker order when executed.
"mtime": 1662478154.941582,
"price": "9928.79" // unexecuted order price
}
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
  • 32 - amount validation failed
  • 33 - price validation failed
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 35 - incorrect maker fee (it is less than zero or its precision is too big)
  • 36 - clientOrderId validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price field is required."
],
"amount": [
"Amount field is required."
],
"market": [
"Market field is required."
],
"price": [
"Price field is required."
],
"side": [
"Side field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"side": [
"Side field should contain only 'buy' or 'sell' values."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field should be numeric string or number."
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be numeric string or number."
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"stop_limit_price": [
"Stop_limit_price field should be numeric string or number."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Given amount is less than min amount 0.001",
"Min amount step = 0.000001"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"total": [
"Total(amount * price) is less than 5.05"
]
}
}
{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field should be a string."
]
}
}
{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field field should contain only latin letters, numbers and dashes."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"This client order id is already used by the current account. It will become available in 24 hours (86400 seconds)."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount should be greater than 0."
]
}
}

{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be at least 10",
"Min price step = 0.000001"
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"stop_limit_price": [
"Stop_limit_price field should be at least 10",
"Min price step = 0.000001"
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price should be greater than 0."
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"stop_limit_price": [
"Stop_limit_price should be greater than 0."
]
}
}
{
"code": 34,
"message": "Validation failed",
"errors": {
"taker_fee": [
"Incorrect taker fee"
]
}
}
{
"code": 35,
"message": "Validation failed",
"errors": {
"maker_fee": [
"Incorrect maker fee"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price should be numeric string."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should be greater than 0."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Empty history"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price = 10"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price step = 0.00001"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"lastPrice": [
"internal error"
]
}
}
{
"code": 10,
"message": "Inner validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}
{
"code": 11,
"message": "Inner validation failed",
"errors": {
"amount": [
"Amount too small."
]
}
}
{
"code": 16,
"message": "Inner validation failed",
"errors": {
"error": [
"Please try again later."
]
}
}
{
"code": 15,
"message": "Inner validation failed",
"errors": {
"error": [
"Please try again later."
]
}
}
{
"code": 14,
"message": "Inner validation failed",
"errors": {
"postOnly": [
"This order couldn't be executed as a maker order and was canceled."
]
}
}
{
"code": 153,
"message": "Inner validation failed",
"errors": {
"price": [
"Not enough balance for limit order."
]
}
}
{
"code": 150,
"message": "Inner validation failed",
"errors": {
"price": [
"Can't place limit order."
]
}
}
{
"code": 151,
"message": "Inner validation failed",
"errors": {
"activation_price": [
"Wrong activation price for stop loss."
]
}
}
{
"code": 152,
"message": "Inner validation failed",
"errors": {
"price": [
"Not enough balance for stop limit order."
]
}
}

Create collateral stop-limit order

[POST] /api/v4/order/collateral/stop-limit

This endpoint creates collateral stop-limit trading order

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
sideStringYesOrder type. Variables: 'buy' / 'sell' Example: 'buy'
amountString/NumberYesAmount of stock currency to buy or sell. Example: '0.001' or 0.001
priceString/NumberYesPrice in money currency. Example: '9800' or 9800
activation_priceString/NumberYesActivation price in money currency. Example: '10000' or 10000
clientOrderIdStringNoIdentifier should be unique and contain letters, dashes or numbers only. The identifier must be unique for the next 24 hours.

Request BODY raw:

{
"market": "BTC_USDT",
"side": "buy",
"amount": "0.001",
"price": "40000",
"activation_price": "40000",
"clientOrderId": "order1987111",
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response: Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if request validation failed
  • Status 503 if service temporary unavailable
{
"orderId": 4180284841, // order id
"clientOrderId": "order1987111", // custom client order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // deal market
"side": "buy", // order side
"type": "stop limit", // order type
"timestamp": 1595792396.165973, // current timestamp
"dealMoney": "0", // if order finished - amount in money currency that finished
"dealStock": "0", // if order finished - amount in stock currency that finished
"amount": "0.001", // amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.001", // if order not finished - rest of amount that must be finished
"dealFee": "0", // fee in money that you pay if order is finished
"price": "40000", // price
"activation_price": "40000" // activation price
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
  • 32 - amount validation failed
  • 33 - price validation failed
  • 34 - incorrect taker fee (it is less than zero or its precision is too big)
  • 35 - incorrect maker fee (it is less than zero or its precision is too big)
  • 36 - clientOrderId validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price field is required."
],
"amount": [
"Amount field is required."
],
"market": [
"Market field is required."
],
"price": [
"Price field is required."
],
"side": [
"Side field is required."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"side": [
"Side field should contain only 'buy' or 'sell' values."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount field should be numeric string or number."
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be numeric string or number."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market field should not be empty string."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Given amount is less than min amount 0.001",
"Min amount step = 0.000001"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"total": [
"Total(amount * price) is less than 5.05"
]
}
}
{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field should be a string."
]
}
}
{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"ClientOrderId field field should contain only latin letters, numbers and dashes."
]
}
}

{
"code": 36,
"message": "Validation failed",
"errors": {
"clientOrderId": [
"This client order id is already used by the current account. It will become available in 24 hours (86400 seconds)."
]
}
}

{
"code": 32,
"message": "Validation failed",
"errors": {
"amount": [
"Amount should be greater than 0."
]
}
}

{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price field should be at least 10",
"Min price step = 0.000001"
]
}
}
{
"code": 33,
"message": "Validation failed",
"errors": {
"price": [
"Price should be greater than 0."
]
}
}
{
"code": 34,
"message": "Validation failed",
"errors": {
"taker_fee": [
"Incorrect taker fee"
]
}
}
{
"code": 35,
"message": "Validation failed",
"errors": {
"maker_fee": [
"Incorrect maker fee"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activation_price": [
"Activation price should be numeric string."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should be greater than 0."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Empty history"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price = 10"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Min activation price step = 0.00001"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"activationPrice": [
"Activation price should not be equal to the last price"
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"lastPrice": [
"internal error"
]
}
}
{
"code": 10,
"message": "Inner validation failed",
"errors": {
"amount": [
"Not enough balance."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}
{
"code": 11,
"message": "Inner validation failed",
"errors": {
"amount": [
"Amount too small."
]
}
}

Cancel Oco order

[POST] /api/v4/order/oco-cancel

Cancel existing order

Parameters:

NameTypeMandatoryDescription
marketStringYesAvailable market. Example: BTC_USDT
orderIdString/IntYesOCO order Id. Example: 4180284841 or "4180284841"

Request BODY raw:

{
"market": "BTC_USDT",
"orderId": 117703764514,
"request": "{{request}}",
"nonce": "{{nonce}}"
}

Response:

Available statuses:

  • Status 200
  • Status 400 if inner validation failed
  • Status 422 if validation failed
  • Status 503 if service temporary unavailable
{
"id": 117703764513, // oco order id
"stop_loss": {
"orderId": 117703764514, // unexecuted order ID
"clientOrderId": "", // custom order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // currency market
"side": "buy", // order side
"type": "stop limit", // unexecuted order type
"timestamp": 1594605801.49815, // current timestamp of unexecuted order
"dealMoney": "0", // executed amount in money
"dealStock": "0", // executed amount in stock
"amount": "2.241379", // active order amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "2.241379", // unexecuted amount in stock
"dealFee": "0", // executed fee by deal
"post_only": false, // orders are guaranteed to be the maker order when executed.
"mtime": 1662478154.941582,
"price": "19928.79", // unexecuted order price
"activation_price": "29928.79", // activation price
"activation_condition": "gte", // activation condition
"activated": 0 // activation status
},
"take_profit": {
"orderId": 117703764515, // unexecuted order ID
"clientOrderId": "", // custom order id; "clientOrderId": "" - if not specified.
"market": "BTC_USDT", // currency market
"side": "buy", // order side
"type": "limit", // unexecuted order type
"timestamp": 1662478154.941582, // current timestamp of unexecuted order
"dealMoney": "0", // executed amount in money
"dealStock": "0", // executed amount in stock
"amount": "0.635709", // active order amount
"takerFee": "0.001", // taker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"makerFee": "0.001", // maker fee ratio. If the number less than 0.0001 - it will be rounded to zero
"left": "0.635709", // unexecuted amount in stock
"dealFee": "0", // executed fee by deal
"post_only": false, // orders are guaranteed to be the maker order when executed.
"mtime": 1662478154.941582,
"price": "9928.79" // unexecuted order price
}
}
Errors:

Error codes:

  • 30 - default validation error code
  • 31 - market validation failed
{
"code": 30,
"message": "Validation failed",
"errors": {
"market": [
"Market field is required."
],
"orderId": [
"OrderId field is required."
]
}
}
{
"code": 31,
"message": "Validation failed",
"errors": {
"market": [
"Market is not available."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"orderId": [
"OrderId field should be an integer."
]
}
}
{
"code": 30,
"message": "Validation failed",
"errors": {
"market": [
"Market field should be a string.",
"Market field format is invalid."
]
}
}
{
"code": 2,
"message": "Inner validation failed",
"errors": {
"orderId": [
"Unexecuted order was not found."
]
}
}
{
"code": 1,
"message": "Inner validation failed",
"errors": {
"amount": [
"Invalid argument."
]
}
}