This ExchangeGate SDK library supports web browsers and NodeJS.
You can use any NPM-compatible package manager, including NPM itself and Yarn.
npm i @exchange-gate.io/eg-sdk-js
Then:
import { ExchangeGate } from '@exchange-gate.io/eg-sdk-js';
Or, if you're not using ES6 modules:
const ExchangeGate = require('@exchange-gate.io/eg-sdk-js').ExchangeGate;
const egRest = new ExchangeGate.Rest(API_KEY);
Fetch latest x100 public trades
const publicTrades = await egRest.fetchPublicTradesSnapshot('binance', 'btc-usdt');
Fetch OrderBook snapshot x100 Bids/Asks
const orderBook = await egRest.fetchOrderBookSnapshot('binance', 'btc-usdt');
Fetch available Exchanger Markets
const exchangerMarkets = await egRest.fetchExchangerMarkets();
Fetch price ticker for selected markets based from last trade price
const priceTicker = await egRest.fetchPriceTicker('binance', ['btc-usdt', 'btc-eth']);
Fetch order book ticker for selected markets based from best bid/ask
const orderBookTicker = await egRest.fetchOrderBookTicker('binance', ['btc-usdt', 'btc-eth']);
Fetch Exchanger account wallet balance
const walletBalance = await egRest.fetchWalletBalance('binance', 'btc-usdt');
Fetch Exchanger account open orders
const openOrders = await egRest.fetchOpenOrders('binance', 'btc-usdt');
Fetch Exchanger account trades
const myTrades = await egRest.fetchMyTrades('binance', 'btc-usdt');
Create Market order
const side = 'buy'; // sell
const marketOrder = await egRest.createMarketOrder('binance', 'btc-usdt', side, amount);
Create Limit order
const side = 'buy'; // sell
const limitOrder = await egRest.createLimitOrder('binance', 'btc-usdt', side, amount, limitPrice);
Cancel open order
const order = await egRest.cancelOrder('binance', 'btc-usdt', uuid);
const egRealtime = new ExchangeGate.Realtime(API_KEY);
Listen for socket events
const socketEvents = ['connect', 'connecting', 'error', 'disconnect', 'close'];
for (const socketEvent of socketEvents) {
egRealtime.onSocketEvent(socketEvent, (e) => {
console.log('onSocketEvent', socketEvent, e);
});
}
Any of REST API methods also available over WS as RPC
const publicTrades = await egRealtime.rpc.fetchPublicTradesSnapshot('binance', 'btc-usdt');
Subscribe public trades stream
const streamSubscription = egRealtime.stream.publicTrades('binance', 'btc-usdt');
const streamConsumerA = streamSubscription.consumer();
const streamConsumerB = streamSubscription.consumer();
(async () => {
for await (const event of streamConsumerA) {
console.log('event-A', event.name, event.data);
}
console.log('stream-A closed');
})();
(async () => {
for await (const event of streamConsumerB) {
console.log('event-B', event.name, event.data);
}
console.log('stream-B closed');
})();
Kill consumer-A but preserve subscription and any other consumers
streamConsumerA.kill();
UnSubscribe stream and close all stream consumers
streamSubscription.close();
// OR
egRealtime.stream.publicTrades('binance', 'btc-usdt').close();
!NOTE! It is safe to issue stream subscription multiple times within single connection
egRealtime.stream.publicTrades('binance', 'btc-usdt');
// this will be same subscription - no double spend
egRealtime.stream.publicTrades('binance', 'btc-usdt');
Disconnect from socket server
egRealtime.disconnect();
Subscribe order book stream.
Always verified and synchronized with server snapshot,
even after dropped connection silently sync's back to guarantee bid/ask precision;
emitTimeoutMs - default 500, set to 0 for realtime.
const streamSubscription = egRealtime.stream.orderBook('binance', 'btc-usdt', emitTimeoutMs);
(async () => {
for await (const event of streamSubscription.consumer()) {
console.log('event', event.name, event.data);
}
})();
Subscribe market price ticker stream.
Price ticker for selected markets based from last trade price, published once per second
const streamSubscription = egRealtime.stream.priceTicker('binance', ['btc-usdt', 'btc-eth']);
(async () => {
for await (const event of streamSubscription.consumer()) {
console.log('event', event.name, event.data);
}
})();
Subscribe market order book ticker stream.
Order book ticker for selected markets based from best bid/ask, published once per second
const streamSubscription = egRealtime.stream.orderBookTicker('binance', ['btc-usdt', 'btc-eth']);
(async () => {
for await (const event of streamSubscription.consumer()) {
console.log('event', event.name, event.data);
}
})();
Subscribe my trades stream
const streamSubscription = egRealtime.stream.myTrades('binance', 'btc-usdt');
(async () => {
for await (const event of streamSubscription.consumer()) {
console.log('event', event.name, event.data);
}
})();
Subscribe Open orders stream.
New orders or any existing order changes
const streamSubscription = egRealtime.stream.openOrders('binance', 'btc-usdt');
(async () => {
for await (const event of streamSubscription.consumer()) {
console.log('event', event.name, event.data);
}
})();
Subscribe Wallet balance stream.
const streamSubscription = egRealtime.stream.walletBalance('binance', 'btc-usdt');
(async () => {
for await (const event of streamSubscription.consumer()) {
console.log('event', event.name, event.data);
}
})();
Subscribe Subscription details stream.
Remaining credits, available/used socket connections
const streamSubscription = egRealtime.stream.subscriptionDetails();
(async () => {
for await (const event of streamSubscription.consumer()) {
console.log('event', event.name, event.data);
}
})();