This is a reference adapter for receiving realtime data from the BitMEX API.
The following is runnable in example.js.
To get started, create a new client:
const BitMEXClient = require('bitmex-realtime-api');
// See 'options' reference below
const client = new BitMEXClient({testnet: true});
Then subscribe to a symbol and table, and pass a callback.
client.addStream('XBTUSD', 'instrument', function(data, symbol, tableName) {
// Do something with the table data...
});
Options:
{
testnet: false, // set `true` to connect to the testnet site (testnet.bitmex.com)
// Set API Key ID and Secret to subscribe to private streams.
// See `Available Private Streams` below.
apiKeyID: '',
apiKeySecret: ''
}
Subscribe to a data stream. Pass a symbol to subscribe to all public data for an instrument.
Pass an optional tableName
to only receive data for a specific table.
The client also doubles as a basic EventEmitter. The following events are fired:
"data", # Raw data from the websocket
"error"
"open"
"close"
"initialize"
- Note: Don't forget to attach an
error
handler! If one is not attached, errors will be thrown and crash your client.
Use this function to access data directly. Pass either a symbol, or tableName, or both. Data returned by this method is safe to modify as it is cloned from the internal stores.
If speed is a concern, all data is accessible directly inside the client via the client._data
property.
Do not modify this data, or you will corrupt further updates!
Same as above, but returns all tables for a given symbol.
Same as above, but returns all symbols for a given table.
The streams below echo the models described in the API Explorer.
"chat", # Trollbox
"instrument", # Instrument updates including turnover and bid/ask
"liquidation", # Liquidations
"orderBookL2", # Full orderBook using deltas
"quote", # Top level of the book
"trade" # Trades
The following streams require authentication via an API key. Use this Python script to easily create a key.
"execution", # Individual order placements and executions, settlements, commissions
"margin", # Your account's margin details
"order", # Order creations, cancellations, and updates
"position" # Your positions, per instrument
For much more information on what this module is doing, run it with the DEBUG
environment variable. For example:
# Display all debug messages
DEBUG=* node example.js
# Display all high-level debug messages
DEBUG=BitMEX:* node example.js