Example: rest-private-trade.ts

Static snapshot for OKX/Rest/rest-private-trade.ts.

Example Path

OKX/Rest/rest-private-trade.ts

Source Link

Repository source: https://github.com/sieblyio/crypto-api-examples/blob/master/examples/OKX/Rest/rest-private-trade.ts

Code Snapshot

/* eslint-disable @typescript-eslint/no-unused-vars */
import { RestClient } from 'okx-api';
import { OrderRequest } from 'okx-api';

// read from environmental variables
const API_KEY = process.env.API_KEY_COM;
const API_SECRET = process.env.API_SECRET_COM;
const API_PASS = process.env.API_PASS_COM;

// If running from CLI in unix, you can pass env vars as such:
// API_KEY_COM='lkm12n3-2ba3-1mxf-fn13-lkm12n3a' API_SECRET_COM='035B2B9637E1BDFFEE2646BFBDDB8CE4' API_PASSPHRASE_COM='ComplexPa$!23$5^' ts-node examples/rest-private-trade.ts

// note the single quotes, preventing special characters such as $ from being incorrectly passed

if (!API_KEY || !API_SECRET || !API_PASS) {
  throw new Error(
    'Missing api credentials. Use environmental variables or hard code in the script',
  );
}

console.log(new Date(), 'Using credentials: ', {
  API_KEY,
  API_SECRET,
  API_PASS,
});

const client = new RestClient({
  apiKey: API_KEY,
  // apiKey: 'apiKeyHere',
  apiSecret: API_SECRET,
  // apiSecret: 'apiSecretHere',
  apiPass: API_PASS,
  // apiPass: 'apiPassHere',
});

// const wsClient = new WebsocketClient({
//   apiKey: API_KEY,
//   apiSecret: API_SECRET,
//   apiPass: API_PASS,
// });

function logWSEvent(type: string, data: any) {
  console.log(new Date(), `WS ${type} event: `, data);
}

// simple sleep function
function promiseSleep(milliseconds: number) {
  return new Promise((resolve) => setTimeout(resolve, milliseconds));
}

// WARNING: for sensitive math you should be using a library such as decimal.js!
function roundDown(value: any, decimals: number) {
  return Number(
    Math.floor(parseFloat(value + 'e' + decimals)) + 'e-' + decimals,
  );
}

/** This is a simple script wrapped in a immediately invoked function expression, designed to check for any available BTC balance and immediately sell the full amount for USDT */
(async () => {
  try {
    // // Add event listeners to log websocket events on account
    // wsClient.on('update', (data) => logWSEvent('update', data));
    // wsClient.on('open', (data) => logWSEvent('open', data));
    // wsClient.on('response', (data) => logWSEvent('response', data));
    // wsClient.on('reconnect', (data) => logWSEvent('reconnect', data));
    // wsClient.on('reconnected', (data) => logWSEvent('reconnected', data));
    // wsClient.on('authenticated', (data) => logWSEvent('authenticated', data));
    // wsClient.on('exception', (data) => logWSEvent('exception', data));

    // // Subscribe to private account topics
    // wsClient.subscribeTopic('SPBL', 'account');
    // wsClient.subscribeTopic('SPBL', 'orders');

    // wait briefly for ws to be ready (could also use the response or authenticated events, to make sure topics are subscribed to before starting)
    await promiseSleep(2.5 * 1000);

    const allBalances = await client.getBalance();
    // const balances = allBalances.filter((bal) => Number(bal.available) != 0);
    const usdtBalanceResult = allBalances[0].details.find(
      (bal) => bal.ccy === 'USDT',
    );
    console.log('BTC balance result: ', usdtBalanceResult);

    const usdtBalance = Number(usdtBalanceResult?.availBal);
    // console.log('balance: ', JSON.stringify(balances, null, 2));

    if (!usdtBalanceResult || !usdtBalance) {
      console.error('No USDT to trade');
      return;
    }

    console.log(`USDT available: ${usdtBalance}`);

    const symbol = 'BTC-USDT';
    const quantity = 0.002;

    const order: OrderRequest = {
      instId: symbol,
      ordType: 'market',
      side: 'buy',
      sz: String(usdtBalance * 0.5),
      tdMode: 'cash',
      tgtCcy: 'base_ccy',
    };

    const buyResult = await client.submitOrder(order);

    console.log('result: ', buyResult);
    return;
    // example to find minimum allowed size for a symbol and place an order with it
    /*  const symbol = 'BTC-USDT-SWAP';

    const symbolsResult = await client.getInstruments({
      instType: 'SWAP',
    });
    const btcRules = symbolsResult.find((rule) => rule.instId === symbol);
    console.log('btc trading rules: ', btcRules);
    if (!btcRules) {
      return console.log('no rules found for trading ' + symbol);
    }

    const minSize = Number(btcRules.minSz);

    const order = {
      instId: symbol,
      tdMode: 'cross',
      ordType: 'market',
      side: 'sell',
      sz: String(minSize),
    } as const;

    console.log('submitting order: ', order);

    const sellResult = await client.submitOrder(order);

    console.log('sell result: ', sellResult); */
  } catch (e) {
    console.error('request failed: ', e);
  }
})();

This is a static, crawlable snapshot. The interactive app loads after JavaScript starts and can refresh live data.