forked from bitfinexcom/bitfinex-api-node
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathws2_manager.js
68 lines (55 loc) · 1.73 KB
/
ws2_manager.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
'use strict'
process.env.DEBUG = 'bfx:examples:*'
const _flatten = require('lodash/flatten')
const debug = require('debug')('bfx:examples:ws2-manager')
const runExample = require('./util/run_example')
const Manager = require('../lib/ws2_manager')
module.exports = runExample({
name: 'ws2-manager',
rest: { transform: true }
}, async ({ rest, env }) => {
debug('fetching symbol details...')
const details = await rest.symbolDetails()
const symbols = details.map(d => `t${d.pair.toUpperCase()}`)
const timeFrames = ['1m', '5m', '30m', '1h', '6h']
const keys = _flatten(symbols.map(s => {
return timeFrames.map(tf => `trade:${tf}:${s}`)
}))
const m = new Manager({ ...env })
m.on('error', (err) => {
debug('error: %s', err)
})
m.once('open', () => {
debug('open')
keys.forEach(key => {
m.subscribeCandles(key)
m.onCandle({ key }, (candles) => {
debug('recv %d candles on channel %s', candles.length, key)
})
})
symbols.forEach(symbol => {
m.subscribeTrades(symbol)
m.onTrades({ symbol }, (trades) => {
debug('recv %d trades on channel %s', trades.length, symbol)
})
})
symbols.forEach(symbol => {
m.subscribeTicker(symbol)
m.onTicker({ symbol }, (ticker) => {
debug('recv ticker on channel %s: %j', symbol, ticker)
})
})
symbols.forEach(symbol => {
m.subscribeOrderBook(symbol)
m.onOrderBook({ symbol }, (update) => {
debug('recv book update on channel %s: %j', symbol, update)
})
})
setInterval(() => {
debug('num keys: %d', keys.length)
debug('num sockets: %d', m.getNumSockets())
debug('socket info: %j', m.getSocketInfo())
}, 5000)
})
m.openSocket()
})