1.1.12 • Published 8 months ago

@orderly.network/orderly-sdk v1.1.12

Weekly downloads
-
License
ISC
Repository
gitlab
Last release
8 months ago

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

  1. contractsApi - asset manager smart contract client;
  2. ftClient - fungible token smart contract client;
  3. restApi - REST API client.
  4. wsPublic - Publis WebSocket. Wallet connection not required.
  5. 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.
      await contract.storage.balance()
    Parameters: None
  • 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 | If true will ignore account balances (burn them) and close the account; if false (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 example usdc.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 nameTypeIs required?Description
    symbolstringYesFor which symbol to get latest market trades
    limitnumberNoHow 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 nameTypeIs required?Description
    symbolstringYesFor which symbol to get funding rate
      await api.public.getPredictedFundingRateForOne('PERP_BTC_USDT')
  • getFundingRateHistoryForOneMarket - Get funding rate for one market.

    Parameter nameTypeIs required?Description
    symbolstringYesFor which symbol to get funding rate
    start_ttimestampNostart 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_ttimestampNoend 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.
    pagenumberNothe page you wish to query.
    sizenumberNoDefault: 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 nameTypeIs required?Description
    symbolstringYesFor which symbol to get funding rate
    start_ttimestampNostart 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_ttimestampNoend 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.
    pagenumberNothe page you wish to query.
    sizenumberNoDefault: 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 nameTypeIs required?Description
    symbolstringYesFor 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 nameTypeIs required?Description
    symbolstringYesFor which symbol to get information
      await api.public.getPositionsUnderLiquidationPerPerpMarket('PERP_BTC_USDT')
  • getLiquidatedPositionsInfo - Get liquidated positions info.

Parameter nameTypeIs required?Description
symbolstringYesFor which symbol to get info
start_ttimestampNostart 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_ttimestampNoend 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.
pagenumberNothe page you wish to query.
sizenumberNoDefault: 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 is MARKET, then is not required, otherwise this parameter is required | | order_quantity | number | No | For MARKET/ASK/BID order, if order_amount is given, it is not required. | | order_amount | number | No | For MARKET/ASK/BID order, the order size in terms of quote currency | | visible_quantity | number | No | The order quantity shown on orderbook. (default: equal to order_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 if client_order_id is not provided | | client_order_id | number | | client_order_id of the order; required if order_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 by client_order_id or order_id. | Parameter name | Type | Is required? | Description | | --- | :---: | :---: | --- | | order_id | number | | ID of the order; required if client_order_id is not provided | | client_order_id | number | | client_order_id of the order; required if order_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 are LIMIT/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 get 1m/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 nameTypeIs required?Description
    symbolstringYesFor which symbol to get funding rate
    start_ttimestampNostart 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_ttimestampNoend 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.
    pagenumberNothe page you wish to query.
    sizenumberNoDefault: 60
      const payload = {
        symbol: 'PERP_BTC_USDC',
        page: 1,
        size: 5
      }
      await api.trade.getFundingFeeHistory(payload)
  • getLiquidatedPositionsByLiquidator - Get liquidated positions by Liquidator.

    Parameter nameTypeIs required?Description
    symbolstringYesFor which symbol to get
    start_ttimestampNostart 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_ttimestampNoend 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.
    pagenumberNothe page you wish to query.
    sizenumberNoDefault: 60
      const payload = {
        symbol: 'PERP_BTC_USDC',
        page: 1,
        size: 5
      }
      await api.trade.getLiquidatedPositionsByLiquidator(payload)
  • getLiquidatedPositionsOfAccount - Get liquidated positions by Liquidator.

    Parameter nameTypeIs required?Description
    symbolstringNoFor which symbol to get
    start_ttimestampNostart time range that you wish to query, noted that the time stamp is a 13-digits timestamp.
    end_ttimestampNoend time range that wish to query, noted the time stamp is 13-digits timestamp.
    pagenumberNothe page you wish to query.
    sizenumberNothe 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 nameTypeIs required?Description
    liquidation_idnumberYesID
    ratio_qty_requestnumberYesWhat ratio of the available liquidated position quantities liquidator is claiming (max 100%)
    extra_liquidation_rationumberNoRange 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 | If true then will return all token even if balance is empty. |
      await api.account.getCurrentHolding(true)
  • getInformation - get account information.
      await api.account.getInformation()
    Parameters: None
  • 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'})