@orderly.network/orderly-sdk v1.1.12
Orderly SDK
Orderly SDK is a complete library to interact with Orderly contracts and rest api. You can use it in the browser. Orderly contracts are built on NEAR network.
Typescript
Library is written fully in Typescript, so no additional types installation is needed.
Usage
Available clients
contractsApi
- asset manager smart contract client;ftClient
- fungible token smart contract client;restApi
- REST API client.wsPublic
- Publis WebSocket. Wallet connection not required.wsPrivate
- Private WebSocket. Wallet connection required.
Initialization
To initialize these clients you will need: 1. For asset manager contract client - SDK configration options; 2. For fungible token contract client - contract URL and SDK configration options; 3. For REST client - SDK configration options;
SDK configuration options is an object with the next properties:
1. networkId
- NEAR network id to which we want to connect when we are working with the SDK. Currently Orderly contracts are deployed to testnet
and mainnet
(fungible token contract is deployed only to testnet
).
Note: You can read about NEAR CLI here
Also, for smart contract clients, if you want to change the NEAR configuration options, pass them as the last parameter in their constructors.
First steps
After instantiating the smart contract client, call the connect
function.
import { AuthClient } from 'orderly-sdk';
const authClient = new AuthClient({
networkId: 'testnet',
contractId: 'asset-manager.orderly.testnet'
});
// you can bind that to connection button
await authClient.connect()
const api = await authClient.restApi()
const contract = await authClient.contractsApi();
const ft = await authClient.ftClient();
Also you can use public API as well without connection.
import { AuthClient } from 'orderly-sdk';
const authClient = new AuthClient({
networkId: 'testnet',
contractId: 'asset-manager.orderly.testnet',
debug: true
});
const pubClient = authClient.publicClient();
await pubClient.getAvailableSymbols()
To avoid version conflicts of near-js-api
you can import it from SDK.
import { AuthClient } from 'orderly-sdk';
const authClient = new AuthClient({
networkId: 'testnet',
contractId: 'asset-manager.orderly.testnet',
debug: true
});
const nearApi = authClient.nearJsApi
Public WebSocket
Note: When user not connected you can use public key for wsPublic
bf6eb263984c964a0cda3e9a35aa486268eea085d9b90fe792c8f9ad7e129a2c
const [wsClientPublic, setWsClientPublic] = useState(null);
const initPublicWs = () => {
const authClient = new AuthClient({
networkId: 'testnet',
contractId: 'asset-manager.orderly.testnet',
debug: true
});
const publicKeyOrWalletID = 'bf6eb263984c964a0cda3e9a35aa486268eea085d9b90fe792c8f9ad7e129a2c'
const wsPublic = authClient.wsClientPublic('testnet', publicKeyOrWalletID);
wsPublic.connect();
setWsClientPublic(wsPublic)
}
const subscribe = () => {
const subscription = { id: 'client_id1', event: 'subscribe', topic: 'SPOT_WOO_USDC@trade' };
wsClientPublic.sendSubscription(subscription);
}
const setPublicWsCallback = () => {
wsClientPublic.setMessageCallback((message) => {
// Process the received message
console.log('Received data:', message);
});
}
Private WebSocket
Required wallet connection
const [wsClientPrivate, setWsClientPrivate] = useState(null);
const initPrivateWs = async () => {
const authClient = new AuthClient({
networkId: 'testnet',
contractId: 'asset-manager.orderly.testnet',
debug: true
});
const wsPrivate = await authClient.wsClientPrivate();
await wsPrivate.connectPrivate();
setWsClientPrivate(wsPrivate);
}
const subscribePrivate = () => {
const subscription = {
"id": "123r",
"topic": "balance",
"event": "subscribe"
}
wsClientPrivate.sendPrivateSubscription(subscription);
}
const setPublicWsCallback = () => {
wsClientPrivate.setPrivateMessageCallback((message) => {
// Process the received message
console.log('Received data:', message);
});
}
Asset manager contract
Documentation can be found here.
Storage
Path: <Asset Manager Contract Client Instance>.storage.<method (described above)>
Orderly asset manager contract implements NEP-145 protocol, so has next methods according to it:
deposit
- method to deposit NEAR into storage from account. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |amount
|number
| Yes | Amount of NEAR to add to storage deposit |await contract.storage.deposit(100000)
withdraw
- method to withdraw NEAR from storage into account. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |amount
|string
| No | Amount of NEAR to withdraw from storage into account; can be ommited, then whole available deposit will be returned into account |await contract.storage.withdraw('1')
balance
- method to get current storage balance.
Parameters: Noneawait contract.storage.balance()
unregister
- unregisters user from contract, withdraws available deposit and removes all keys.await contract.storage.unregister()
Right now throws an error, because is planned for the next release | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |
force
|boolean
| No | Iftrue
will ignore account balances (burn them) and close the account; iffalse
(or omitted) and caller has a positive registered balance it will throw an error |
Other methods
Path: <Asset Manager Contract Client Instance>.<method (described above)>
depositNEAR
- this method is used to deposit NEAR to your account. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |amount
|number
| Yes | How much NEAR to deposit |await contract.depositNEAR(amount)
withdraw
- this method is used to withdraw tokens from your account in contract. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |token
|string
| Yes | Token to withdraw from account | |amount
|number
| Yes | How much tokens to withdraw |await contract.withdraw({token: 'usdc.orderly.testnet', amount: 50000000})
isTokenListed
- this method is used to check if token is whitelisted for your account on the contract. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |token
|string
| Yes | Token to check |await contract.isTokenListed('usdc.orderly.testnet')
isSymbolPairListed
- this method is used to check if symbol pair is whitelisted for your account on the contract. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |pair
|string
| Yes | Symbol pair to check |await contract.isSymbolPairListed('SPOT_NEAR_USDC')
getPossibleTokens
- this method is used to get all whitelisted tokens for your account on the contract.await contract.getPossibleTokens()
userRequestSettlement
- Public payable method enabling the user to request to settle the account's futures positions PnL.await contract.userRequestSettlement()
getUserTokenBalance
- this method is used to check account tokens balance. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |user
|string
| No | Wallet address. If empty then will return balance of connected user |await contract.getUserTokenBalance('user.near')
storageBalanceOf
- this method is used to get storage balance of user. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |accountId
|string
| Yes | Account id of user |await contract.storageBalanceOf(accountId)
storageUsageOf
- this method is used to get storage usage of user. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |accountId
|string
| Yes | Account id of user |await contract.storageUsageOf(accountId)
Parameters: None
Fungible token contract
deposit
- this method is used to deposit fungible token to your account. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |amount
|number
| Yes | How much tokens to deposit | |ftTokenContract
|string
| Yes | Token contract address, for exampleusdc.orderly.testnet
|await ft.deposit(100000000, 'usdc.orderly.testnet')
REST client
Documentation can be found here
REST client consists of the next clients:
public
- public methods client;orders
- orders methods client;trade
- trade methods client;user
- user methods client.
Public methods
getSymbolOrderRules
- this endpoint provides all the values for the rules that an order need to fulfil in order for it to be placed successfully. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| Yes | Symbol for which to get order rules |await api.public.getSymbolOrderRules('SPOT_NEAR_USDC')
getAvailableSymbols
- get available symbols that Orderly Network supports, and also send order rules for each symbol.await api.public.getAvailableSymbols()
Parameters: None
getFeeInformation
- get the latest Orderly Network fee structure.await api.public.getFeeInformation()
Parameters: None
getMarketTrades
- get latest market trades.Parameter name Type Is required? Description symbol
string
Yes For which symbol to get latest market trades limit
number
No How may records to return await api.public.getMarketTrades('SPOT_NEAR_USDC', 10)
getPredictedFundingRateForAll
- get predicted funding rate for all.Get the:
last_funding_rate
: latest hourly funding rate for all the markets for the last funding period (dt = 60s)last_average_funding_rate
: average of all funding rates on the last hour (ex: 10am-11am)est_funding_rate
: rolling average of all funding rates over the last hour (ex: current time - 1hour : 10:15 -11:15 am)
await api.public.getPredictedFundingRateForAll()
getPredictedFundingRateForOne
- get predicted funding rate for symbol.Parameter name Type Is required? Description symbol
string
Yes For which symbol to get funding rate await api.public.getPredictedFundingRateForOne('PERP_BTC_USDT')
getFundingRateHistoryForOneMarket
- Get funding rate for one market.Parameter name Type Is required? Description symbol
string
Yes For which symbol to get funding rate start_t
timestamp
No start time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. end_t
timestamp
No end time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. page
number
No the page you wish to query. size
number
No Default: 60 const payload = { symbol: 'PERP_BTC_USDC', page: 1, size: 5 } await api.public.getFundingRateHistoryForOneMarket(payload)
getFundingRateHistoryPerHourForOneMarket
- Get average funding rate per hour for one market.Put a limit to the time window : if between start_t and end_t , the number of data is larger than limit, return data from start_t to start_t + limit.
Parameter name Type Is required? Description symbol
string
Yes For which symbol to get funding rate start_t
timestamp
No start time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. end_t
timestamp
No end time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. page
number
No the page you wish to query. size
number
No Default: 60 const payload = { symbol: 'PERP_BTC_USDC', page: 1, size: 5 } await api.public.getFundingRateHistoryPerHourForOneMarket(payload)
getFuturesInfoForAllMarkets
- Get basic futures information for all the markets.await api.public.getFuturesInfoForAllMarkets()
getFuturesForOneMarket
- Get basic futures information for one market.Parameter name Type Is required? Description symbol
string
Yes For which symbol to get futures information await api.public.getFuturesForOneMarket('PERP_BTC_USDT')
getPositionsUnderLiquidation
- Get positions under liquidation.await api.public.getPositionsUnderLiquidation()
getPositionsUnderLiquidationPerPerpMarket
- Get positions under liquidation by symbol.Parameter name Type Is required? Description symbol
string
Yes For which symbol to get information await api.public.getPositionsUnderLiquidationPerPerpMarket('PERP_BTC_USDT')
getLiquidatedPositionsInfo
- Get liquidated positions info.
Parameter name | Type | Is required? | Description |
---|---|---|---|
symbol | string | Yes | For which symbol to get info |
start_t | timestamp | No | start time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. |
end_t | timestamp | No | end time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. |
page | number | No | the page you wish to query. |
size | number | No | Default: 60 |
const payload = {
symbol: 'PERP_BTC_USDC',
page: 1,
size: 5
}
await api.public.getLiquidatedPositionsInfo(payload)
getInsuranceFundInfo
- Get insurance fund info.await api.public.getInsuranceFundInfo()
getFuturesFeeInformation
- Get the current Orderly Network fee structure.await api.public.getFuturesFeeInformation()
Orders client
create
- place order. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| Yes | Token symbol | |client_order_id
|string
| No | Customized order_id, a unique id among open orders | |order_type
|enum
| Yes | Order type. Possible values are:LIMIT
/MARKET
/IOC
/FOK
/POST_ONLY
/ASK
/BID
. | |order_price
|number
| No | If order_type isMARKET
, then is not required, otherwise this parameter is required | |order_quantity
|number
| No | ForMARKET
/ASK
/BID
order, iforder_amount
is given, it is not required. | |order_amount
|number
| No | ForMARKET
/ASK
/BID
order, the order size in terms of quote currency | |visible_quantity
|number
| No | The order quantity shown on orderbook. (default: equal toorder_quantity
) | |side
|enum
| Yes | Order side. Possible values are:SELL
/BUY
. |const order = { symbol: 'SPOT_NEAR_USDC', order_type: 'LIMIT', side: 'BUY', order_price: 1.11, order_quantity: 2.00000000 } await api.orders.create(order)
createBatch
- places multiple orders at once. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |orders
|array
| Yes | Array of objects used for create order request |const order1 = { symbol: 'SPOT_NEAR_USDC', order_type: 'LIMIT', side: 'BUY', order_price: 1.11, order_quantity: 2.00000000 } const order2 = { symbol: 'SPOT_WOO_USDC', order_type: 'LIMIT', side: 'BUY', order_price: 0.12, order_quantity: 10.00000000 } await api.orders.createBatch([order1, order2])
cancel
- cancels placed request. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| Yes | Token symbol | |order_id
|number
| | ID of the order; required ifclient_order_id
is not provided | |client_order_id
|number
| |client_order_id
of the order; required iforder_id
is not provided |const cancleOrderRequest = { symbol: 'SPOT_NEAR_USDC', order_id: 12345 } await api.orders.cancle(cancleOrderRequest)
cancelBatch
- cancels multiple placed orders for symbol. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| Yes | Token symbol |await api.orders.cancelBatch({symbol: 'SPOT_NEAR_USDC'})
getOrder
- gets order byclient_order_id
ororder_id
. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |order_id
|number
| | ID of the order; required ifclient_order_id
is not provided | |client_order_id
|number
| |client_order_id
of the order; required iforder_id
is not provided |await api.orders.getOrder({order_id: 12345})
getOrders
- gets multiple orders by provided params. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| No | Which token to query orders for | |side
|enum
| No | Which order side orders to get. Possible values are:BUY
/SELL
. | |order_type
|enum
| No | Which order type orders to get. Possible values areLIMIT
/MARKET
| |order_tag
|string
| No | An optional tag for the order. | |status
|enum
| No | Which order status orders to get. Possible values are:NEW
/CANCELLED
/PARTIAL_FILLED
/FILLED
/REJECTED
/INCOMPLETE
/COMPLETED
| |start_t
|number
| No | Start time range that wish to query, noted the time stamp is 13-digits timestamp. | |end_t
|number
| No | End time range that wish to query, noted the time stamp is 13-digits timestamp. | |page
|number
| No | The page wish to query (default: 1). | |size
|number
| No | The page size wish to query (default: 25, max: 500) |await api.orders.getOrders({})
getOrderbook
- get snapshot of current orderbook. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| Yes | Token symbol for which to get the snapshot | |max_level
|number
| No | The levels wish to show on both side (default: 100). |await api.orders.getOrderbook('SPOT_NEAR_USDC', 10)
Trade client
getKline
- get the latest klines of the trading pairs. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| Yes | Token symbol for which to get klines | |type
|enum
| Yes | Which kline type to get1m
/5m
/15m
/30m
/1h
/4h
/12h
/1d
/1w
/1mon
/1y
| |limit
|number
| No | Number of klines to get (default: 100, maximum: 1000). |const getKlineData = { symbol: 'SPOT_NEAR_USDC', type: '1h', limit: 100 } await api.trade.getKline(getKlineData)
getOrderTrades
- get specific order trades by order_id. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |order_id
|number
| Yes | ID of the order |await api.trade.getOrderTrades(12345)
getTrades
- get client’s trades history in a range of time. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| No | Token symbol for which to get trades | |tag
|string
| No | An optional tag for the order. | |start_t
|number
| No | Start time range that wish to query, noted the time stamp is 13-digits timestamp. | |end_t
|number
| No | End time range that wish to query, noted the time stamp is 13-digits timestamp. | |page
|number
| No | The page wish to query (default: 1). | |size
|number
| No | The page size wish to query (default: 25) |await api.trade.getTrades({symbol: 'SPOT_NEAR_USDC'})
getTrade
- get specific transaction detail by trade id. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |tradeId
|number
| Yes | ID of the trade |await api.trade.getTrade(54321)
getFundingFeeHistory
- Get funding fee history. Put a limit to the time window : if between start_t and end_t , the number of data is larger than limit, return data from start_t to start_t + limit.- Max (24h) = 8640
- Default (3 hour of data)= 1080
Parameter name Type Is required? Description symbol
string
Yes For which symbol to get funding rate start_t
timestamp
No start time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. end_t
timestamp
No end time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. page
number
No the page you wish to query. size
number
No Default: 60 const payload = { symbol: 'PERP_BTC_USDC', page: 1, size: 5 } await api.trade.getFundingFeeHistory(payload)
getLiquidatedPositionsByLiquidator
- Get liquidated positions by Liquidator.Parameter name Type Is required? Description symbol
string
Yes For which symbol to get start_t
timestamp
No start time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. end_t
timestamp
No end time range that you wish to query, noted that the time stamp is a 13-digits timestamp. If start_t and end_t are not filled, the newest funding rate will be returned. page
number
No the page you wish to query. size
number
No Default: 60 const payload = { symbol: 'PERP_BTC_USDC', page: 1, size: 5 } await api.trade.getLiquidatedPositionsByLiquidator(payload)
getLiquidatedPositionsOfAccount
- Get liquidated positions by Liquidator.Parameter name Type Is required? Description symbol
string
No For which symbol to get start_t
timestamp
No start time range that you wish to query, noted that the time stamp is a 13-digits timestamp. end_t
timestamp
No end time range that wish to query, noted the time stamp is 13-digits timestamp. page
number
No the page you wish to query. size
number
No the page size you wish to query. (max: 500) const payload = { symbol: 'PERP_BTC_USDC', page: 1, size: 5 } await api.trade.getLiquidatedPositionsOfAccount(payload)
claimLiquidatedPosition
- claim liquidated position.Parameter name Type Is required? Description liquidation_id
number
Yes ID ratio_qty_request
number
Yes What ratio of the available liquidated position quantities liquidator is claiming (max 100%) extra_liquidation_ratio
number
No Range between 0-1. Only if ratio_qty_request is equal to 100% : this represents the extra ratio the liquidator is ready to claim in case the real position quantities to be liquidated at the real time mark price is higher than the ones posted on endpoints. const payload = { liquidation_id: 123, ratio_qty_request: 1, } await api.trade.claimLiquidatedPosition(payload)
getAllPositionInfo
- get all positions info.await api.trade.getAllPositionInfo(54321)
getOnePositionInfo
- get position info by symbop. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |symbol
|string
| Yes | For which symbol to get |await api.trade.getOnePositionInfo('PERP_BTC_USDC')
User client
getCurrentHolding
- get holding summary of the user. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |all
|boolean
| No | Iftrue
then will return all token even if balance is empty. |await api.account.getCurrentHolding(true)
getInformation
- get account information.
Parameters: Noneawait api.account.getInformation()
getAssetHistory
- get asset history, includes token deposit/withdraw and collateral deposit/withdraw. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | |token
|string
| No | Token name you want to search | |side
|enum
| No | Which history record type to query. Possible values are:DEPOSIT
/WITHDRAW
| |status
|enum
| No | Which status to search. Possible values are:NEW
/CONFIRM
/PROCESSING
/COMPLETED
/FAILED
| |start_t
|number
| No | Start time range that wish to query, noted the time stamp is 13-digits timestamp. | |end_t
|number
| No | End time range that wish to query, noted the time stamp is 13-digits timestamp. | |page
|number
| No | The page wish to query (default: 1). |await api.account.getAssetHistory({side: 'DEPOSIT'})