ccxt 4.2.17 → 4.2.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +9 -9
- package/dist/ccxt.browser.js +48992 -47725
- package/dist/ccxt.browser.min.js +3 -3
- package/dist/cjs/ccxt.js +12 -1
- package/dist/cjs/src/alpaca.js +18 -18
- package/dist/cjs/src/ascendex.js +13 -6
- package/dist/cjs/src/base/Exchange.js +266 -27
- package/dist/cjs/src/bigone.js +434 -168
- package/dist/cjs/src/binance.js +163 -34
- package/dist/cjs/src/binanceus.js +8 -0
- package/dist/cjs/src/bingx.js +183 -41
- package/dist/cjs/src/bitfinex.js +2 -3
- package/dist/cjs/src/bitget.js +59 -16
- package/dist/cjs/src/bitmart.js +5 -5
- package/dist/cjs/src/bitmex.js +4 -6
- package/dist/cjs/src/bitpanda.js +5 -1991
- package/dist/cjs/src/bitstamp.js +8 -0
- package/dist/cjs/src/bybit.js +27 -47
- package/dist/cjs/src/coinbase.js +176 -26
- package/dist/cjs/src/coincheck.js +1 -0
- package/dist/cjs/src/coinex.js +3 -0
- package/dist/cjs/src/coinlist.js +13 -6
- package/dist/cjs/src/coinone.js +2 -2
- package/dist/cjs/src/coinsph.js +4 -5
- package/dist/cjs/src/delta.js +7 -1
- package/dist/cjs/src/deribit.js +17 -4
- package/dist/cjs/src/gate.js +151 -169
- package/dist/cjs/src/gemini.js +1 -1
- package/dist/cjs/src/hitbtc.js +2 -3
- package/dist/cjs/src/htx.js +157 -7
- package/dist/cjs/src/huobijp.js +2 -3
- package/dist/cjs/src/independentreserve.js +7 -5
- package/dist/cjs/src/kraken.js +86 -54
- package/dist/cjs/src/kucoin.js +5 -0
- package/dist/cjs/src/kucoinfutures.js +131 -77
- package/dist/cjs/src/lbank.js +60 -33
- package/dist/cjs/src/luno.js +84 -2
- package/dist/cjs/src/mexc.js +3 -3
- package/dist/cjs/src/oceanex.js +1 -1
- package/dist/cjs/src/okx.js +23 -11
- package/dist/cjs/{js/src/bitpanda.js → src/onetrading.js} +39 -39
- package/dist/cjs/src/phemex.js +37 -27
- package/dist/cjs/src/poloniexfutures.js +1 -0
- package/dist/cjs/src/pro/binance.js +66 -25
- package/dist/cjs/src/pro/bitget.js +1 -1
- package/dist/cjs/src/pro/bitpanda.js +5 -1330
- package/dist/cjs/src/pro/coinbase.js +4 -1
- package/dist/cjs/src/pro/coincheck.js +208 -0
- package/dist/cjs/src/pro/hitbtc.js +5 -4
- package/dist/cjs/src/pro/htx.js +6 -1
- package/dist/cjs/src/pro/kraken.js +1 -1
- package/dist/cjs/src/pro/krakenfutures.js +7 -1
- package/dist/cjs/src/pro/kucoin.js +46 -36
- package/dist/cjs/src/pro/kucoinfutures.js +45 -37
- package/dist/cjs/src/pro/lbank.js +881 -0
- package/dist/cjs/src/pro/okx.js +52 -2
- package/dist/cjs/{js/src/pro/bitpanda.js → src/pro/onetrading.js} +4 -7
- package/dist/cjs/src/pro/poloniex.js +2 -2
- package/dist/cjs/src/pro/poloniexfutures.js +43 -35
- package/dist/cjs/src/pro/woo.js +126 -0
- package/dist/cjs/src/probit.js +4 -2
- package/dist/cjs/src/upbit.js +12 -12
- package/dist/cjs/src/wavesexchange.js +1 -1
- package/dist/cjs/src/whitebit.js +1 -0
- package/dist/cjs/src/woo.js +56 -0
- package/js/ccxt.d.ts +14 -2
- package/js/ccxt.js +10 -2
- package/js/src/abstract/bitpanda.d.ts +4 -4
- package/js/src/abstract/bitstamp.d.ts +8 -0
- package/js/src/abstract/gate.d.ts +1 -0
- package/js/src/abstract/gateio.d.ts +1 -0
- package/js/src/abstract/htx.d.ts +3 -0
- package/js/src/abstract/huobi.d.ts +3 -0
- package/js/src/abstract/luno.d.ts +1 -0
- package/js/src/abstract/onetrading.d.ts +38 -0
- package/js/src/ascendex.js +2 -0
- package/js/src/base/Exchange.d.ts +2 -3
- package/js/src/base/Exchange.js +5 -2
- package/js/src/binance.js +7 -1
- package/js/src/bingx.d.ts +1 -0
- package/js/src/bingx.js +26 -0
- package/js/src/bitget.js +22 -3
- package/js/src/bitpanda.d.ts +2 -72
- package/js/src/bitpanda.js +5 -1991
- package/js/src/bitstamp.js +8 -0
- package/js/src/bybit.js +21 -47
- package/js/src/coincheck.js +1 -0
- package/js/src/deribit.js +16 -4
- package/js/src/gate.d.ts +1 -0
- package/js/src/gate.js +50 -110
- package/js/src/htx.js +3 -0
- package/js/src/kraken.d.ts +1 -0
- package/js/src/kraken.js +40 -39
- package/js/src/lbank.js +1 -0
- package/js/src/luno.d.ts +3 -1
- package/js/src/luno.js +84 -2
- package/js/src/mexc.js +1 -2
- package/js/src/onetrading.d.ts +74 -0
- package/js/src/onetrading.js +2003 -0
- package/js/src/poloniexfutures.js +1 -0
- package/js/src/pro/binance.js +7 -2
- package/js/src/pro/bitget.js +1 -1
- package/js/src/pro/bitpanda.d.ts +2 -34
- package/js/src/pro/bitpanda.js +5 -1330
- package/js/src/pro/coincheck.d.ts +12 -0
- package/js/src/pro/coincheck.js +209 -0
- package/js/src/pro/kucoin.js +43 -35
- package/js/src/pro/kucoinfutures.js +45 -37
- package/js/src/pro/lbank.d.ts +29 -0
- package/js/src/pro/lbank.js +882 -0
- package/js/src/pro/onetrading.d.ts +36 -0
- package/js/src/pro/onetrading.js +1339 -0
- package/js/src/pro/poloniexfutures.js +43 -35
- package/js/src/whitebit.js +1 -0
- package/package.json +2 -2
- package/rollup.config.js +2 -0
- package/skip-tests.json +14 -2
- package/test-commonjs.cjs +25 -1
- package/dist/cjs/js/ccxt.js +0 -476
- package/dist/cjs/js/src/abstract/alpaca.js +0 -9
- package/dist/cjs/js/src/abstract/ascendex.js +0 -9
- package/dist/cjs/js/src/abstract/bigone.js +0 -9
- package/dist/cjs/js/src/abstract/binance.js +0 -9
- package/dist/cjs/js/src/abstract/bingx.js +0 -9
- package/dist/cjs/js/src/abstract/bit2c.js +0 -9
- package/dist/cjs/js/src/abstract/bitbank.js +0 -9
- package/dist/cjs/js/src/abstract/bitbns.js +0 -9
- package/dist/cjs/js/src/abstract/bitfinex.js +0 -9
- package/dist/cjs/js/src/abstract/bitfinex2.js +0 -9
- package/dist/cjs/js/src/abstract/bitflyer.js +0 -9
- package/dist/cjs/js/src/abstract/bitforex.js +0 -9
- package/dist/cjs/js/src/abstract/bitget.js +0 -9
- package/dist/cjs/js/src/abstract/bithumb.js +0 -9
- package/dist/cjs/js/src/abstract/bitmart.js +0 -9
- package/dist/cjs/js/src/abstract/bitmex.js +0 -9
- package/dist/cjs/js/src/abstract/bitopro.js +0 -9
- package/dist/cjs/js/src/abstract/bitpanda.js +0 -9
- package/dist/cjs/js/src/abstract/bitrue.js +0 -9
- package/dist/cjs/js/src/abstract/bitso.js +0 -9
- package/dist/cjs/js/src/abstract/bitstamp.js +0 -9
- package/dist/cjs/js/src/abstract/bitteam.js +0 -9
- package/dist/cjs/js/src/abstract/bitvavo.js +0 -9
- package/dist/cjs/js/src/abstract/bl3p.js +0 -9
- package/dist/cjs/js/src/abstract/blockchaincom.js +0 -9
- package/dist/cjs/js/src/abstract/btcalpha.js +0 -9
- package/dist/cjs/js/src/abstract/btcbox.js +0 -9
- package/dist/cjs/js/src/abstract/btcmarkets.js +0 -9
- package/dist/cjs/js/src/abstract/btcturk.js +0 -9
- package/dist/cjs/js/src/abstract/bybit.js +0 -9
- package/dist/cjs/js/src/abstract/cex.js +0 -9
- package/dist/cjs/js/src/abstract/coinbase.js +0 -9
- package/dist/cjs/js/src/abstract/coinbasepro.js +0 -9
- package/dist/cjs/js/src/abstract/coincheck.js +0 -9
- package/dist/cjs/js/src/abstract/coinex.js +0 -9
- package/dist/cjs/js/src/abstract/coinlist.js +0 -9
- package/dist/cjs/js/src/abstract/coinmate.js +0 -9
- package/dist/cjs/js/src/abstract/coinone.js +0 -9
- package/dist/cjs/js/src/abstract/coinsph.js +0 -9
- package/dist/cjs/js/src/abstract/coinspot.js +0 -9
- package/dist/cjs/js/src/abstract/cryptocom.js +0 -9
- package/dist/cjs/js/src/abstract/currencycom.js +0 -9
- package/dist/cjs/js/src/abstract/delta.js +0 -9
- package/dist/cjs/js/src/abstract/deribit.js +0 -9
- package/dist/cjs/js/src/abstract/digifinex.js +0 -9
- package/dist/cjs/js/src/abstract/exmo.js +0 -9
- package/dist/cjs/js/src/abstract/gate.js +0 -9
- package/dist/cjs/js/src/abstract/gemini.js +0 -9
- package/dist/cjs/js/src/abstract/hitbtc.js +0 -9
- package/dist/cjs/js/src/abstract/hollaex.js +0 -9
- package/dist/cjs/js/src/abstract/htx.js +0 -9
- package/dist/cjs/js/src/abstract/huobijp.js +0 -9
- package/dist/cjs/js/src/abstract/idex.js +0 -9
- package/dist/cjs/js/src/abstract/independentreserve.js +0 -9
- package/dist/cjs/js/src/abstract/indodax.js +0 -9
- package/dist/cjs/js/src/abstract/kraken.js +0 -9
- package/dist/cjs/js/src/abstract/krakenfutures.js +0 -9
- package/dist/cjs/js/src/abstract/kucoin.js +0 -9
- package/dist/cjs/js/src/abstract/kucoinfutures.js +0 -9
- package/dist/cjs/js/src/abstract/kuna.js +0 -9
- package/dist/cjs/js/src/abstract/latoken.js +0 -9
- package/dist/cjs/js/src/abstract/lbank.js +0 -9
- package/dist/cjs/js/src/abstract/luno.js +0 -9
- package/dist/cjs/js/src/abstract/lykke.js +0 -9
- package/dist/cjs/js/src/abstract/mercado.js +0 -9
- package/dist/cjs/js/src/abstract/mexc.js +0 -9
- package/dist/cjs/js/src/abstract/ndax.js +0 -9
- package/dist/cjs/js/src/abstract/novadax.js +0 -9
- package/dist/cjs/js/src/abstract/oceanex.js +0 -9
- package/dist/cjs/js/src/abstract/okcoin.js +0 -9
- package/dist/cjs/js/src/abstract/okx.js +0 -9
- package/dist/cjs/js/src/abstract/p2b.js +0 -9
- package/dist/cjs/js/src/abstract/paymium.js +0 -9
- package/dist/cjs/js/src/abstract/phemex.js +0 -9
- package/dist/cjs/js/src/abstract/poloniex.js +0 -9
- package/dist/cjs/js/src/abstract/poloniexfutures.js +0 -9
- package/dist/cjs/js/src/abstract/probit.js +0 -9
- package/dist/cjs/js/src/abstract/timex.js +0 -9
- package/dist/cjs/js/src/abstract/tokocrypto.js +0 -9
- package/dist/cjs/js/src/abstract/upbit.js +0 -9
- package/dist/cjs/js/src/abstract/wavesexchange.js +0 -9
- package/dist/cjs/js/src/abstract/wazirx.js +0 -9
- package/dist/cjs/js/src/abstract/whitebit.js +0 -9
- package/dist/cjs/js/src/abstract/woo.js +0 -9
- package/dist/cjs/js/src/abstract/yobit.js +0 -9
- package/dist/cjs/js/src/abstract/zaif.js +0 -9
- package/dist/cjs/js/src/abstract/zonda.js +0 -9
- package/dist/cjs/js/src/ace.js +0 -1058
- package/dist/cjs/js/src/alpaca.js +0 -1125
- package/dist/cjs/js/src/ascendex.js +0 -3365
- package/dist/cjs/js/src/base/Exchange.js +0 -5257
- package/dist/cjs/js/src/base/Precise.js +0 -263
- package/dist/cjs/js/src/base/errors.js +0 -299
- package/dist/cjs/js/src/base/functions/crypto.js +0 -78
- package/dist/cjs/js/src/base/functions/encode.js +0 -44
- package/dist/cjs/js/src/base/functions/generic.js +0 -193
- package/dist/cjs/js/src/base/functions/misc.js +0 -96
- package/dist/cjs/js/src/base/functions/number.js +0 -297
- package/dist/cjs/js/src/base/functions/platform.js +0 -28
- package/dist/cjs/js/src/base/functions/rsa.js +0 -34
- package/dist/cjs/js/src/base/functions/string.js +0 -48
- package/dist/cjs/js/src/base/functions/throttle.js +0 -66
- package/dist/cjs/js/src/base/functions/time.js +0 -187
- package/dist/cjs/js/src/base/functions/totp.js +0 -24
- package/dist/cjs/js/src/base/functions/type.js +0 -162
- package/dist/cjs/js/src/base/functions.js +0 -157
- package/dist/cjs/js/src/base/ws/Cache.js +0 -254
- package/dist/cjs/js/src/base/ws/Client.js +0 -299
- package/dist/cjs/js/src/base/ws/Future.js +0 -34
- package/dist/cjs/js/src/base/ws/OrderBook.js +0 -107
- package/dist/cjs/js/src/base/ws/OrderBookSide.js +0 -281
- package/dist/cjs/js/src/base/ws/WsClient.js +0 -69
- package/dist/cjs/js/src/bequant.js +0 -33
- package/dist/cjs/js/src/bigone.js +0 -2213
- package/dist/cjs/js/src/binance.js +0 -9845
- package/dist/cjs/js/src/binancecoinm.js +0 -45
- package/dist/cjs/js/src/binanceus.js +0 -92
- package/dist/cjs/js/src/binanceusdm.js +0 -58
- package/dist/cjs/js/src/bingx.js +0 -3846
- package/dist/cjs/js/src/bit2c.js +0 -916
- package/dist/cjs/js/src/bitbank.js +0 -1000
- package/dist/cjs/js/src/bitbay.js +0 -17
- package/dist/cjs/js/src/bitbns.js +0 -1220
- package/dist/cjs/js/src/bitcoincom.js +0 -17
- package/dist/cjs/js/src/bitfinex.js +0 -1670
- package/dist/cjs/js/src/bitfinex2.js +0 -2990
- package/dist/cjs/js/src/bitflyer.js +0 -1045
- package/dist/cjs/js/src/bitforex.js +0 -852
- package/dist/cjs/js/src/bitget.js +0 -8295
- package/dist/cjs/js/src/bithumb.js +0 -1090
- package/dist/cjs/js/src/bitmart.js +0 -4454
- package/dist/cjs/js/src/bitmex.js +0 -2881
- package/dist/cjs/js/src/bitopro.js +0 -1724
- package/dist/cjs/js/src/bitrue.js +0 -3253
- package/dist/cjs/js/src/bitso.js +0 -1753
- package/dist/cjs/js/src/bitstamp.js +0 -2188
- package/dist/cjs/js/src/bitteam.js +0 -2309
- package/dist/cjs/js/src/bitvavo.js +0 -1968
- package/dist/cjs/js/src/bl3p.js +0 -447
- package/dist/cjs/js/src/blockchaincom.js +0 -1160
- package/dist/cjs/js/src/btcalpha.js +0 -929
- package/dist/cjs/js/src/btcbox.js +0 -565
- package/dist/cjs/js/src/btcmarkets.js +0 -1237
- package/dist/cjs/js/src/btcturk.js +0 -929
- package/dist/cjs/js/src/bybit.js +0 -7650
- package/dist/cjs/js/src/cex.js +0 -1693
- package/dist/cjs/js/src/coinbase.js +0 -3424
- package/dist/cjs/js/src/coinbasepro.js +0 -1866
- package/dist/cjs/js/src/coincheck.js +0 -843
- package/dist/cjs/js/src/coinex.js +0 -5417
- package/dist/cjs/js/src/coinlist.js +0 -2337
- package/dist/cjs/js/src/coinmate.js +0 -989
- package/dist/cjs/js/src/coinone.js +0 -1185
- package/dist/cjs/js/src/coinsph.js +0 -1933
- package/dist/cjs/js/src/coinspot.js +0 -548
- package/dist/cjs/js/src/cryptocom.js +0 -3007
- package/dist/cjs/js/src/currencycom.js +0 -2015
- package/dist/cjs/js/src/delta.js +0 -3262
- package/dist/cjs/js/src/deribit.js +0 -3306
- package/dist/cjs/js/src/digifinex.js +0 -4307
- package/dist/cjs/js/src/exmo.js +0 -2645
- package/dist/cjs/js/src/fmfwio.js +0 -34
- package/dist/cjs/js/src/gate.js +0 -7077
- package/dist/cjs/js/src/gateio.js +0 -16
- package/dist/cjs/js/src/gemini.js +0 -1801
- package/dist/cjs/js/src/hitbtc.js +0 -3660
- package/dist/cjs/js/src/hitbtc3.js +0 -19
- package/dist/cjs/js/src/hollaex.js +0 -1882
- package/dist/cjs/js/src/htx.js +0 -9174
- package/dist/cjs/js/src/huobi.js +0 -16
- package/dist/cjs/js/src/huobijp.js +0 -1918
- package/dist/cjs/js/src/idex.js +0 -1770
- package/dist/cjs/js/src/independentreserve.js +0 -761
- package/dist/cjs/js/src/indodax.js +0 -1069
- package/dist/cjs/js/src/kraken.js +0 -2891
- package/dist/cjs/js/src/krakenfutures.js +0 -2407
- package/dist/cjs/js/src/kucoin.js +0 -4494
- package/dist/cjs/js/src/kucoinfutures.js +0 -2529
- package/dist/cjs/js/src/kuna.js +0 -1949
- package/dist/cjs/js/src/latoken.js +0 -1729
- package/dist/cjs/js/src/lbank.js +0 -2851
- package/dist/cjs/js/src/luno.js +0 -1044
- package/dist/cjs/js/src/lykke.js +0 -1303
- package/dist/cjs/js/src/mercado.js +0 -897
- package/dist/cjs/js/src/mexc.js +0 -5407
- package/dist/cjs/js/src/ndax.js +0 -2450
- package/dist/cjs/js/src/novadax.js +0 -1556
- package/dist/cjs/js/src/oceanex.js +0 -964
- package/dist/cjs/js/src/okcoin.js +0 -3115
- package/dist/cjs/js/src/okx.js +0 -7331
- package/dist/cjs/js/src/p2b.js +0 -1243
- package/dist/cjs/js/src/paymium.js +0 -597
- package/dist/cjs/js/src/phemex.js +0 -4725
- package/dist/cjs/js/src/poloniex.js +0 -2356
- package/dist/cjs/js/src/poloniexfutures.js +0 -1794
- package/dist/cjs/js/src/pro/alpaca.js +0 -714
- package/dist/cjs/js/src/pro/ascendex.js +0 -957
- package/dist/cjs/js/src/pro/bequant.js +0 -33
- package/dist/cjs/js/src/pro/binance.js +0 -2796
- package/dist/cjs/js/src/pro/binancecoinm.js +0 -23
- package/dist/cjs/js/src/pro/binanceus.js +0 -51
- package/dist/cjs/js/src/pro/binanceusdm.js +0 -32
- package/dist/cjs/js/src/pro/bingx.js +0 -944
- package/dist/cjs/js/src/pro/bitcoincom.js +0 -29
- package/dist/cjs/js/src/pro/bitfinex.js +0 -672
- package/dist/cjs/js/src/pro/bitfinex2.js +0 -1159
- package/dist/cjs/js/src/pro/bitget.js +0 -1733
- package/dist/cjs/js/src/pro/bitmart.js +0 -1486
- package/dist/cjs/js/src/pro/bitmex.js +0 -1576
- package/dist/cjs/js/src/pro/bitopro.js +0 -327
- package/dist/cjs/js/src/pro/bitrue.js +0 -462
- package/dist/cjs/js/src/pro/bitstamp.js +0 -547
- package/dist/cjs/js/src/pro/bitvavo.js +0 -704
- package/dist/cjs/js/src/pro/blockchaincom.js +0 -794
- package/dist/cjs/js/src/pro/bybit.js +0 -1843
- package/dist/cjs/js/src/pro/cex.js +0 -1510
- package/dist/cjs/js/src/pro/coinbase.js +0 -561
- package/dist/cjs/js/src/pro/coinbasepro.js +0 -968
- package/dist/cjs/js/src/pro/coinex.js +0 -1095
- package/dist/cjs/js/src/pro/cryptocom.js +0 -1020
- package/dist/cjs/js/src/pro/currencycom.js +0 -563
- package/dist/cjs/js/src/pro/deribit.js +0 -825
- package/dist/cjs/js/src/pro/exmo.js +0 -658
- package/dist/cjs/js/src/pro/gate.js +0 -1316
- package/dist/cjs/js/src/pro/gateio.js +0 -16
- package/dist/cjs/js/src/pro/gemini.js +0 -649
- package/dist/cjs/js/src/pro/hitbtc.js +0 -1294
- package/dist/cjs/js/src/pro/hollaex.js +0 -597
- package/dist/cjs/js/src/pro/htx.js +0 -2388
- package/dist/cjs/js/src/pro/huobi.js +0 -16
- package/dist/cjs/js/src/pro/huobijp.js +0 -606
- package/dist/cjs/js/src/pro/idex.js +0 -714
- package/dist/cjs/js/src/pro/independentreserve.js +0 -280
- package/dist/cjs/js/src/pro/kraken.js +0 -1364
- package/dist/cjs/js/src/pro/krakenfutures.js +0 -1506
- package/dist/cjs/js/src/pro/kucoin.js +0 -1054
- package/dist/cjs/js/src/pro/kucoinfutures.js +0 -981
- package/dist/cjs/js/src/pro/luno.js +0 -322
- package/dist/cjs/js/src/pro/mexc.js +0 -1170
- package/dist/cjs/js/src/pro/ndax.js +0 -545
- package/dist/cjs/js/src/pro/okcoin.js +0 -760
- package/dist/cjs/js/src/pro/okx.js +0 -1608
- package/dist/cjs/js/src/pro/phemex.js +0 -1511
- package/dist/cjs/js/src/pro/poloniex.js +0 -1253
- package/dist/cjs/js/src/pro/poloniexfutures.js +0 -1014
- package/dist/cjs/js/src/pro/probit.js +0 -586
- package/dist/cjs/js/src/pro/upbit.js +0 -234
- package/dist/cjs/js/src/pro/wazirx.js +0 -776
- package/dist/cjs/js/src/pro/whitebit.js +0 -927
- package/dist/cjs/js/src/pro/woo.js +0 -895
- package/dist/cjs/js/src/probit.js +0 -1867
- package/dist/cjs/js/src/static_dependencies/fflake/browser.js +0 -401
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +0 -195
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +0 -308
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +0 -554
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +0 -94
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +0 -70
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +0 -91
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +0 -16
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +0 -1760
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +0 -52
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +0 -81
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +0 -376
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +0 -70
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +0 -1580
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +0 -74
- package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +0 -24
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +0 -158
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +0 -429
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +0 -176
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +0 -324
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +0 -163
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +0 -245
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +0 -1018
- package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +0 -383
- package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +0 -258
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +0 -53
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +0 -120
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +0 -69
- package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +0 -7
- package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +0 -83
- package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +0 -240
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +0 -91
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +0 -130
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +0 -214
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +0 -239
- package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +0 -93
- package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +0 -354
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +0 -16
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +0 -20
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +0 -30
- package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +0 -239
- package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +0 -372
- package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +0 -273
- package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +0 -139
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +0 -14
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +0 -16
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +0 -81
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +0 -292
- package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +0 -103
- package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +0 -140
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +0 -175
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +0 -95
- package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +0 -7
- package/dist/cjs/js/src/static_dependencies/scure-base/index.js +0 -383
- package/dist/cjs/js/src/timex.js +0 -1562
- package/dist/cjs/js/src/tokocrypto.js +0 -2542
- package/dist/cjs/js/src/upbit.js +0 -1844
- package/dist/cjs/js/src/wavesexchange.js +0 -2607
- package/dist/cjs/js/src/wazirx.js +0 -953
- package/dist/cjs/js/src/whitebit.js +0 -2309
- package/dist/cjs/js/src/woo.js +0 -2769
- package/dist/cjs/js/src/yobit.js +0 -1314
- package/dist/cjs/js/src/zaif.js +0 -736
- package/dist/cjs/js/src/zonda.js +0 -1883
- package/dist/cjs/src/abstract/bitpanda.js +0 -9
- package/test.ts +0 -0
- /package/dist/cjs/{js/src/abstract/ace.js → src/abstract/onetrading.js} +0 -0
- /package/dist/cjs/{js/src → src}/pro/coinone.js +0 -0
- /package/js/src/abstract/{bitpanda.js → onetrading.js} +0 -0
|
@@ -1,672 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var bitfinex$1 = require('../bitfinex.js');
|
|
4
|
-
var errors = require('../base/errors.js');
|
|
5
|
-
var Cache = require('../base/ws/Cache.js');
|
|
6
|
-
var Precise = require('../base/Precise.js');
|
|
7
|
-
var sha512 = require('../static_dependencies/noble-hashes/sha512.js');
|
|
8
|
-
|
|
9
|
-
// ---------------------------------------------------------------------------
|
|
10
|
-
// ---------------------------------------------------------------------------
|
|
11
|
-
class bitfinex extends bitfinex$1 {
|
|
12
|
-
describe() {
|
|
13
|
-
return this.deepExtend(super.describe(), {
|
|
14
|
-
'has': {
|
|
15
|
-
'ws': true,
|
|
16
|
-
'watchTicker': true,
|
|
17
|
-
'watchTickers': false,
|
|
18
|
-
'watchOrderBook': true,
|
|
19
|
-
'watchTrades': true,
|
|
20
|
-
'watchBalance': false,
|
|
21
|
-
'watchOHLCV': false, // missing on the exchange side in v1
|
|
22
|
-
},
|
|
23
|
-
'urls': {
|
|
24
|
-
'api': {
|
|
25
|
-
'ws': {
|
|
26
|
-
'public': 'wss://api-pub.bitfinex.com/ws/1',
|
|
27
|
-
'private': 'wss://api.bitfinex.com/ws/1',
|
|
28
|
-
},
|
|
29
|
-
},
|
|
30
|
-
},
|
|
31
|
-
'options': {
|
|
32
|
-
'watchOrderBook': {
|
|
33
|
-
'prec': 'P0',
|
|
34
|
-
'freq': 'F0',
|
|
35
|
-
},
|
|
36
|
-
'ordersLimit': 1000,
|
|
37
|
-
},
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
async subscribe(channel, symbol, params = {}) {
|
|
41
|
-
await this.loadMarkets();
|
|
42
|
-
const market = this.market(symbol);
|
|
43
|
-
const marketId = market['id'];
|
|
44
|
-
const url = this.urls['api']['ws']['public'];
|
|
45
|
-
const messageHash = channel + ':' + marketId;
|
|
46
|
-
// const channel = 'trades';
|
|
47
|
-
const request = {
|
|
48
|
-
'event': 'subscribe',
|
|
49
|
-
'channel': channel,
|
|
50
|
-
'symbol': marketId,
|
|
51
|
-
'messageHash': messageHash,
|
|
52
|
-
};
|
|
53
|
-
return await this.watch(url, messageHash, this.deepExtend(request, params), messageHash);
|
|
54
|
-
}
|
|
55
|
-
async watchTrades(symbol, since = undefined, limit = undefined, params = {}) {
|
|
56
|
-
/**
|
|
57
|
-
* @method
|
|
58
|
-
* @name bitfinex#watchTrades
|
|
59
|
-
* @description get the list of most recent trades for a particular symbol
|
|
60
|
-
* @param {string} symbol unified symbol of the market to fetch trades for
|
|
61
|
-
* @param {int} [since] timestamp in ms of the earliest trade to fetch
|
|
62
|
-
* @param {int} [limit] the maximum amount of trades to fetch
|
|
63
|
-
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
64
|
-
* @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
|
|
65
|
-
*/
|
|
66
|
-
await this.loadMarkets();
|
|
67
|
-
symbol = this.symbol(symbol);
|
|
68
|
-
const trades = await this.subscribe('trades', symbol, params);
|
|
69
|
-
if (this.newUpdates) {
|
|
70
|
-
limit = trades.getLimit(symbol, limit);
|
|
71
|
-
}
|
|
72
|
-
return this.filterBySinceLimit(trades, since, limit, 'timestamp', true);
|
|
73
|
-
}
|
|
74
|
-
async watchTicker(symbol, params = {}) {
|
|
75
|
-
/**
|
|
76
|
-
* @method
|
|
77
|
-
* @name bitfinex#watchTicker
|
|
78
|
-
* @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
|
|
79
|
-
* @param {string} symbol unified symbol of the market to fetch the ticker for
|
|
80
|
-
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
81
|
-
* @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
|
|
82
|
-
*/
|
|
83
|
-
return await this.subscribe('ticker', symbol, params);
|
|
84
|
-
}
|
|
85
|
-
handleTrades(client, message, subscription) {
|
|
86
|
-
//
|
|
87
|
-
// initial snapshot
|
|
88
|
-
//
|
|
89
|
-
// [
|
|
90
|
-
// 2,
|
|
91
|
-
// [
|
|
92
|
-
// [ null, 1580565020, 9374.9, 0.005 ],
|
|
93
|
-
// [ null, 1580565004, 9374.9, 0.005 ],
|
|
94
|
-
// [ null, 1580565003, 9374.9, 0.005 ],
|
|
95
|
-
// ]
|
|
96
|
-
// ]
|
|
97
|
-
//
|
|
98
|
-
// when a trade does not have an id yet
|
|
99
|
-
//
|
|
100
|
-
// // channel id, update type, seq, time, price, amount
|
|
101
|
-
// [ 2, "te", "28462857-BTCUSD", 1580565041, 9374.9, 0.005 ],
|
|
102
|
-
//
|
|
103
|
-
// when a trade already has an id
|
|
104
|
-
//
|
|
105
|
-
// // channel id, update type, seq, trade id, time, price, amount
|
|
106
|
-
// [ 2, "tu", "28462857-BTCUSD", 413357662, 1580565041, 9374.9, 0.005 ]
|
|
107
|
-
//
|
|
108
|
-
const channel = this.safeValue(subscription, 'channel');
|
|
109
|
-
const marketId = this.safeString(subscription, 'pair');
|
|
110
|
-
const messageHash = channel + ':' + marketId;
|
|
111
|
-
const tradesLimit = this.safeInteger(this.options, 'tradesLimit', 1000);
|
|
112
|
-
const market = this.safeMarket(marketId);
|
|
113
|
-
const symbol = market['symbol'];
|
|
114
|
-
const data = this.safeValue(message, 1);
|
|
115
|
-
let stored = this.safeValue(this.trades, symbol);
|
|
116
|
-
if (stored === undefined) {
|
|
117
|
-
stored = new Cache.ArrayCache(tradesLimit);
|
|
118
|
-
this.trades[symbol] = stored;
|
|
119
|
-
}
|
|
120
|
-
if (Array.isArray(data)) {
|
|
121
|
-
const trades = this.parseTrades(data, market);
|
|
122
|
-
for (let i = 0; i < trades.length; i++) {
|
|
123
|
-
stored.append(trades[i]);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
else {
|
|
127
|
-
const second = this.safeString(message, 1);
|
|
128
|
-
if (second !== 'tu') {
|
|
129
|
-
return;
|
|
130
|
-
}
|
|
131
|
-
const trade = this.parseTrade(message, market);
|
|
132
|
-
stored.append(trade);
|
|
133
|
-
}
|
|
134
|
-
client.resolve(stored, messageHash);
|
|
135
|
-
return message;
|
|
136
|
-
}
|
|
137
|
-
parseTrade(trade, market = undefined) {
|
|
138
|
-
//
|
|
139
|
-
// snapshot trade
|
|
140
|
-
//
|
|
141
|
-
// // null, time, price, amount
|
|
142
|
-
// [ null, 1580565020, 9374.9, 0.005 ],
|
|
143
|
-
//
|
|
144
|
-
// when a trade does not have an id yet
|
|
145
|
-
//
|
|
146
|
-
// // channel id, update type, seq, time, price, amount
|
|
147
|
-
// [ 2, "te", "28462857-BTCUSD", 1580565041, 9374.9, 0.005 ],
|
|
148
|
-
//
|
|
149
|
-
// when a trade already has an id
|
|
150
|
-
//
|
|
151
|
-
// // channel id, update type, seq, trade id, time, price, amount
|
|
152
|
-
// [ 2, "tu", "28462857-BTCUSD", 413357662, 1580565041, 9374.9, 0.005 ]
|
|
153
|
-
//
|
|
154
|
-
if (!Array.isArray(trade)) {
|
|
155
|
-
return super.parseTrade(trade, market);
|
|
156
|
-
}
|
|
157
|
-
const tradeLength = trade.length;
|
|
158
|
-
const event = this.safeString(trade, 1);
|
|
159
|
-
let id = undefined;
|
|
160
|
-
if (event === 'tu') {
|
|
161
|
-
id = this.safeString(trade, tradeLength - 4);
|
|
162
|
-
}
|
|
163
|
-
const timestamp = this.safeTimestamp(trade, tradeLength - 3);
|
|
164
|
-
const price = this.safeString(trade, tradeLength - 2);
|
|
165
|
-
let amount = this.safeString(trade, tradeLength - 1);
|
|
166
|
-
let side = undefined;
|
|
167
|
-
if (amount !== undefined) {
|
|
168
|
-
side = Precise["default"].stringGt(amount, '0') ? 'buy' : 'sell';
|
|
169
|
-
amount = Precise["default"].stringAbs(amount);
|
|
170
|
-
}
|
|
171
|
-
const seq = this.safeString(trade, 2);
|
|
172
|
-
const parts = seq.split('-');
|
|
173
|
-
let marketId = this.safeString(parts, 1);
|
|
174
|
-
if (marketId !== undefined) {
|
|
175
|
-
marketId = marketId.replace('t', '');
|
|
176
|
-
}
|
|
177
|
-
const symbol = this.safeSymbol(marketId, market);
|
|
178
|
-
const takerOrMaker = undefined;
|
|
179
|
-
const orderId = undefined;
|
|
180
|
-
return this.safeTrade({
|
|
181
|
-
'info': trade,
|
|
182
|
-
'timestamp': timestamp,
|
|
183
|
-
'datetime': this.iso8601(timestamp),
|
|
184
|
-
'symbol': symbol,
|
|
185
|
-
'id': id,
|
|
186
|
-
'order': orderId,
|
|
187
|
-
'type': undefined,
|
|
188
|
-
'takerOrMaker': takerOrMaker,
|
|
189
|
-
'side': side,
|
|
190
|
-
'price': price,
|
|
191
|
-
'amount': amount,
|
|
192
|
-
'cost': undefined,
|
|
193
|
-
'fee': undefined,
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
handleTicker(client, message, subscription) {
|
|
197
|
-
//
|
|
198
|
-
// [
|
|
199
|
-
// 2, // 0 CHANNEL_ID integer Channel ID
|
|
200
|
-
// 236.62, // 1 BID float Price of last highest bid
|
|
201
|
-
// 9.0029, // 2 BID_SIZE float Size of the last highest bid
|
|
202
|
-
// 236.88, // 3 ASK float Price of last lowest ask
|
|
203
|
-
// 7.1138, // 4 ASK_SIZE float Size of the last lowest ask
|
|
204
|
-
// -1.02, // 5 DAILY_CHANGE float Amount that the last price has changed since yesterday
|
|
205
|
-
// 0, // 6 DAILY_CHANGE_PERC float Amount that the price has changed expressed in percentage terms
|
|
206
|
-
// 236.52, // 7 LAST_PRICE float Price of the last trade.
|
|
207
|
-
// 5191.36754297, // 8 VOLUME float Daily volume
|
|
208
|
-
// 250.01, // 9 HIGH float Daily high
|
|
209
|
-
// 220.05, // 10 LOW float Daily low
|
|
210
|
-
// ]
|
|
211
|
-
//
|
|
212
|
-
const marketId = this.safeString(subscription, 'pair');
|
|
213
|
-
const symbol = this.safeSymbol(marketId);
|
|
214
|
-
const channel = 'ticker';
|
|
215
|
-
const messageHash = channel + ':' + marketId;
|
|
216
|
-
const last = this.safeString(message, 7);
|
|
217
|
-
const change = this.safeString(message, 5);
|
|
218
|
-
let open = undefined;
|
|
219
|
-
if ((last !== undefined) && (change !== undefined)) {
|
|
220
|
-
open = Precise["default"].stringSub(last, change);
|
|
221
|
-
}
|
|
222
|
-
const result = {
|
|
223
|
-
'symbol': symbol,
|
|
224
|
-
'timestamp': undefined,
|
|
225
|
-
'datetime': undefined,
|
|
226
|
-
'high': this.safeFloat(message, 9),
|
|
227
|
-
'low': this.safeFloat(message, 10),
|
|
228
|
-
'bid': this.safeFloat(message, 1),
|
|
229
|
-
'bidVolume': undefined,
|
|
230
|
-
'ask': this.safeFloat(message, 3),
|
|
231
|
-
'askVolume': undefined,
|
|
232
|
-
'vwap': undefined,
|
|
233
|
-
'open': this.parseNumber(open),
|
|
234
|
-
'close': this.parseNumber(last),
|
|
235
|
-
'last': this.parseNumber(last),
|
|
236
|
-
'previousClose': undefined,
|
|
237
|
-
'change': this.parseNumber(change),
|
|
238
|
-
'percentage': this.safeFloat(message, 6),
|
|
239
|
-
'average': undefined,
|
|
240
|
-
'baseVolume': this.safeFloat(message, 8),
|
|
241
|
-
'quoteVolume': undefined,
|
|
242
|
-
'info': message,
|
|
243
|
-
};
|
|
244
|
-
this.tickers[symbol] = result;
|
|
245
|
-
client.resolve(result, messageHash);
|
|
246
|
-
}
|
|
247
|
-
async watchOrderBook(symbol, limit = undefined, params = {}) {
|
|
248
|
-
/**
|
|
249
|
-
* @method
|
|
250
|
-
* @name bitfinex#watchOrderBook
|
|
251
|
-
* @description watches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
|
|
252
|
-
* @param {string} symbol unified symbol of the market to fetch the order book for
|
|
253
|
-
* @param {int} [limit] the maximum amount of order book entries to return
|
|
254
|
-
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
255
|
-
* @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
|
|
256
|
-
*/
|
|
257
|
-
if (limit !== undefined) {
|
|
258
|
-
if ((limit !== 25) && (limit !== 100)) {
|
|
259
|
-
throw new errors.ExchangeError(this.id + ' watchOrderBook limit argument must be undefined, 25 or 100');
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
const options = this.safeValue(this.options, 'watchOrderBook', {});
|
|
263
|
-
const prec = this.safeString(options, 'prec', 'P0');
|
|
264
|
-
const freq = this.safeString(options, 'freq', 'F0');
|
|
265
|
-
const request = {
|
|
266
|
-
// "event": "subscribe", // added in subscribe()
|
|
267
|
-
// "channel": channel, // added in subscribe()
|
|
268
|
-
// "symbol": marketId, // added in subscribe()
|
|
269
|
-
'prec': prec,
|
|
270
|
-
'freq': freq,
|
|
271
|
-
'len': limit, // string, number of price points, '25', '100', default = '25'
|
|
272
|
-
};
|
|
273
|
-
const orderbook = await this.subscribe('book', symbol, this.deepExtend(request, params));
|
|
274
|
-
return orderbook.limit();
|
|
275
|
-
}
|
|
276
|
-
handleOrderBook(client, message, subscription) {
|
|
277
|
-
//
|
|
278
|
-
// first message (snapshot)
|
|
279
|
-
//
|
|
280
|
-
// [
|
|
281
|
-
// 18691, // channel id
|
|
282
|
-
// [
|
|
283
|
-
// [ 7364.8, 10, 4.354802 ], // price, count, size > 0 = bid
|
|
284
|
-
// [ 7364.7, 1, 0.00288831 ],
|
|
285
|
-
// [ 7364.3, 12, 0.048 ],
|
|
286
|
-
// [ 7364.9, 3, -0.42028976 ], // price, count, size < 0 = ask
|
|
287
|
-
// [ 7365, 1, -0.25 ],
|
|
288
|
-
// [ 7365.5, 1, -0.00371937 ],
|
|
289
|
-
// ]
|
|
290
|
-
// ]
|
|
291
|
-
//
|
|
292
|
-
// subsequent updates
|
|
293
|
-
//
|
|
294
|
-
// [
|
|
295
|
-
// 30, // channel id
|
|
296
|
-
// 9339.9, // price
|
|
297
|
-
// 0, // count
|
|
298
|
-
// -1, // size > 0 = bid, size < 0 = ask
|
|
299
|
-
// ]
|
|
300
|
-
//
|
|
301
|
-
const marketId = this.safeString(subscription, 'pair');
|
|
302
|
-
const symbol = this.safeSymbol(marketId);
|
|
303
|
-
const channel = 'book';
|
|
304
|
-
const messageHash = channel + ':' + marketId;
|
|
305
|
-
const prec = this.safeString(subscription, 'prec', 'P0');
|
|
306
|
-
const isRaw = (prec === 'R0');
|
|
307
|
-
// if it is an initial snapshot
|
|
308
|
-
if (Array.isArray(message[1])) {
|
|
309
|
-
const limit = this.safeInteger(subscription, 'len');
|
|
310
|
-
if (isRaw) {
|
|
311
|
-
// raw order books
|
|
312
|
-
this.orderbooks[symbol] = this.indexedOrderBook({}, limit);
|
|
313
|
-
}
|
|
314
|
-
else {
|
|
315
|
-
// P0, P1, P2, P3, P4
|
|
316
|
-
this.orderbooks[symbol] = this.countedOrderBook({}, limit);
|
|
317
|
-
}
|
|
318
|
-
const orderbook = this.orderbooks[symbol];
|
|
319
|
-
if (isRaw) {
|
|
320
|
-
const deltas = message[1];
|
|
321
|
-
for (let i = 0; i < deltas.length; i++) {
|
|
322
|
-
const delta = deltas[i];
|
|
323
|
-
const id = this.safeString(delta, 0);
|
|
324
|
-
const price = this.safeFloat(delta, 1);
|
|
325
|
-
const size = (delta[2] < 0) ? -delta[2] : delta[2];
|
|
326
|
-
const side = (delta[2] < 0) ? 'asks' : 'bids';
|
|
327
|
-
const bookside = orderbook[side];
|
|
328
|
-
bookside.store(price, size, id);
|
|
329
|
-
}
|
|
330
|
-
}
|
|
331
|
-
else {
|
|
332
|
-
const deltas = message[1];
|
|
333
|
-
for (let i = 0; i < deltas.length; i++) {
|
|
334
|
-
const delta = deltas[i];
|
|
335
|
-
const size = (delta[2] < 0) ? -delta[2] : delta[2];
|
|
336
|
-
const side = (delta[2] < 0) ? 'asks' : 'bids';
|
|
337
|
-
const bookside = orderbook[side];
|
|
338
|
-
bookside.store(delta[0], size, delta[1]);
|
|
339
|
-
}
|
|
340
|
-
}
|
|
341
|
-
client.resolve(orderbook, messageHash);
|
|
342
|
-
}
|
|
343
|
-
else {
|
|
344
|
-
const orderbook = this.orderbooks[symbol];
|
|
345
|
-
if (isRaw) {
|
|
346
|
-
const id = this.safeString(message, 1);
|
|
347
|
-
const price = this.safeString(message, 2);
|
|
348
|
-
const size = (message[3] < 0) ? -message[3] : message[3];
|
|
349
|
-
const side = (message[3] < 0) ? 'asks' : 'bids';
|
|
350
|
-
const bookside = orderbook[side];
|
|
351
|
-
// price = 0 means that you have to remove the order from your book
|
|
352
|
-
const amount = Precise["default"].stringGt(price, '0') ? size : '0';
|
|
353
|
-
bookside.store(this.parseNumber(price), this.parseNumber(amount), id);
|
|
354
|
-
}
|
|
355
|
-
else {
|
|
356
|
-
const size = (message[3] < 0) ? -message[3] : message[3];
|
|
357
|
-
const side = (message[3] < 0) ? 'asks' : 'bids';
|
|
358
|
-
const bookside = orderbook[side];
|
|
359
|
-
bookside.store(message[1], size, message[2]);
|
|
360
|
-
}
|
|
361
|
-
client.resolve(orderbook, messageHash);
|
|
362
|
-
}
|
|
363
|
-
}
|
|
364
|
-
handleHeartbeat(client, message) {
|
|
365
|
-
//
|
|
366
|
-
// every second (approx) if no other updates are sent
|
|
367
|
-
//
|
|
368
|
-
// { "event": "heartbeat" }
|
|
369
|
-
//
|
|
370
|
-
const event = this.safeString(message, 'event');
|
|
371
|
-
client.resolve(message, event);
|
|
372
|
-
}
|
|
373
|
-
handleSystemStatus(client, message) {
|
|
374
|
-
//
|
|
375
|
-
// todo: answer the question whether handleSystemStatus should be renamed
|
|
376
|
-
// and unified as handleStatus for any usage pattern that
|
|
377
|
-
// involves system status and maintenance updates
|
|
378
|
-
//
|
|
379
|
-
// {
|
|
380
|
-
// "event": "info",
|
|
381
|
-
// "version": 2,
|
|
382
|
-
// "serverId": "e293377e-7bb7-427e-b28c-5db045b2c1d1",
|
|
383
|
-
// "platform": { status: 1 }, // 1 for operative, 0 for maintenance
|
|
384
|
-
// }
|
|
385
|
-
//
|
|
386
|
-
return message;
|
|
387
|
-
}
|
|
388
|
-
handleSubscriptionStatus(client, message) {
|
|
389
|
-
//
|
|
390
|
-
// {
|
|
391
|
-
// "event": "subscribed",
|
|
392
|
-
// "channel": "book",
|
|
393
|
-
// "chanId": 67473,
|
|
394
|
-
// "symbol": "tBTCUSD",
|
|
395
|
-
// "prec": "P0",
|
|
396
|
-
// "freq": "F0",
|
|
397
|
-
// "len": "25",
|
|
398
|
-
// "pair": "BTCUSD"
|
|
399
|
-
// }
|
|
400
|
-
//
|
|
401
|
-
const channelId = this.safeString(message, 'chanId');
|
|
402
|
-
client.subscriptions[channelId] = message;
|
|
403
|
-
return message;
|
|
404
|
-
}
|
|
405
|
-
async authenticate(params = {}) {
|
|
406
|
-
const url = this.urls['api']['ws']['private'];
|
|
407
|
-
const client = this.client(url);
|
|
408
|
-
const future = client.future('authenticated');
|
|
409
|
-
const method = 'auth';
|
|
410
|
-
const authenticated = this.safeValue(client.subscriptions, method);
|
|
411
|
-
if (authenticated === undefined) {
|
|
412
|
-
const nonce = this.milliseconds();
|
|
413
|
-
const payload = 'AUTH' + nonce.toString();
|
|
414
|
-
const signature = this.hmac(this.encode(payload), this.encode(this.secret), sha512.sha384, 'hex');
|
|
415
|
-
const request = {
|
|
416
|
-
'apiKey': this.apiKey,
|
|
417
|
-
'authSig': signature,
|
|
418
|
-
'authNonce': nonce,
|
|
419
|
-
'authPayload': payload,
|
|
420
|
-
'event': method,
|
|
421
|
-
'filter': [
|
|
422
|
-
'trading',
|
|
423
|
-
'wallet',
|
|
424
|
-
],
|
|
425
|
-
};
|
|
426
|
-
this.spawn(this.watch, url, method, request, 1);
|
|
427
|
-
}
|
|
428
|
-
return await future;
|
|
429
|
-
}
|
|
430
|
-
handleAuthenticationMessage(client, message) {
|
|
431
|
-
const status = this.safeString(message, 'status');
|
|
432
|
-
if (status === 'OK') {
|
|
433
|
-
// we resolve the future here permanently so authentication only happens once
|
|
434
|
-
const future = this.safeValue(client.futures, 'authenticated');
|
|
435
|
-
future.resolve(true);
|
|
436
|
-
}
|
|
437
|
-
else {
|
|
438
|
-
const error = new errors.AuthenticationError(this.json(message));
|
|
439
|
-
client.reject(error, 'authenticated');
|
|
440
|
-
// allows further authentication attempts
|
|
441
|
-
const method = this.safeString(message, 'event');
|
|
442
|
-
if (method in client.subscriptions) {
|
|
443
|
-
delete client.subscriptions[method];
|
|
444
|
-
}
|
|
445
|
-
}
|
|
446
|
-
}
|
|
447
|
-
async watchOrder(id, symbol = undefined, params = {}) {
|
|
448
|
-
await this.loadMarkets();
|
|
449
|
-
const url = this.urls['api']['ws']['private'];
|
|
450
|
-
await this.authenticate();
|
|
451
|
-
return await this.watch(url, id, undefined, 1);
|
|
452
|
-
}
|
|
453
|
-
async watchOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
|
|
454
|
-
/**
|
|
455
|
-
* @method
|
|
456
|
-
* @name bitfinex#watchOrders
|
|
457
|
-
* @description watches information on multiple orders made by the user
|
|
458
|
-
* @param {string} symbol unified market symbol of the market orders were made in
|
|
459
|
-
* @param {int} [since] the earliest time in ms to fetch orders for
|
|
460
|
-
* @param {int} [limit] the maximum number of order structures to retrieve
|
|
461
|
-
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
462
|
-
* @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
|
|
463
|
-
*/
|
|
464
|
-
await this.loadMarkets();
|
|
465
|
-
await this.authenticate();
|
|
466
|
-
if (symbol !== undefined) {
|
|
467
|
-
symbol = this.symbol(symbol);
|
|
468
|
-
}
|
|
469
|
-
const url = this.urls['api']['ws']['private'];
|
|
470
|
-
const orders = await this.watch(url, 'os', undefined, 1);
|
|
471
|
-
if (this.newUpdates) {
|
|
472
|
-
limit = orders.getLimit(symbol, limit);
|
|
473
|
-
}
|
|
474
|
-
return this.filterBySymbolSinceLimit(orders, symbol, since, limit, true);
|
|
475
|
-
}
|
|
476
|
-
handleOrders(client, message, subscription) {
|
|
477
|
-
//
|
|
478
|
-
// order snapshot
|
|
479
|
-
//
|
|
480
|
-
// [
|
|
481
|
-
// 0,
|
|
482
|
-
// "os",
|
|
483
|
-
// [
|
|
484
|
-
// [
|
|
485
|
-
// 45287766631,
|
|
486
|
-
// "ETHUST",
|
|
487
|
-
// -0.07,
|
|
488
|
-
// -0.07,
|
|
489
|
-
// "EXCHANGE LIMIT",
|
|
490
|
-
// "ACTIVE",
|
|
491
|
-
// 210,
|
|
492
|
-
// 0,
|
|
493
|
-
// "2020-05-16T13:17:46Z",
|
|
494
|
-
// 0,
|
|
495
|
-
// 0,
|
|
496
|
-
// 0
|
|
497
|
-
// ]
|
|
498
|
-
// ]
|
|
499
|
-
// ]
|
|
500
|
-
//
|
|
501
|
-
// order cancel
|
|
502
|
-
//
|
|
503
|
-
// [
|
|
504
|
-
// 0,
|
|
505
|
-
// "oc",
|
|
506
|
-
// [
|
|
507
|
-
// 45287766631,
|
|
508
|
-
// "ETHUST",
|
|
509
|
-
// -0.07,
|
|
510
|
-
// -0.07,
|
|
511
|
-
// "EXCHANGE LIMIT",
|
|
512
|
-
// "CANCELED",
|
|
513
|
-
// 210,
|
|
514
|
-
// 0,
|
|
515
|
-
// "2020-05-16T13:17:46Z",
|
|
516
|
-
// 0,
|
|
517
|
-
// 0,
|
|
518
|
-
// 0,
|
|
519
|
-
// ]
|
|
520
|
-
// ]
|
|
521
|
-
//
|
|
522
|
-
const data = this.safeValue(message, 2, []);
|
|
523
|
-
const messageType = this.safeString(message, 1);
|
|
524
|
-
if (messageType === 'os') {
|
|
525
|
-
for (let i = 0; i < data.length; i++) {
|
|
526
|
-
const value = data[i];
|
|
527
|
-
this.handleOrder(client, value);
|
|
528
|
-
}
|
|
529
|
-
}
|
|
530
|
-
else {
|
|
531
|
-
this.handleOrder(client, data);
|
|
532
|
-
}
|
|
533
|
-
if (this.orders !== undefined) {
|
|
534
|
-
client.resolve(this.orders, 'os');
|
|
535
|
-
}
|
|
536
|
-
}
|
|
537
|
-
parseWsOrderStatus(status) {
|
|
538
|
-
const statuses = {
|
|
539
|
-
'ACTIVE': 'open',
|
|
540
|
-
'CANCELED': 'canceled',
|
|
541
|
-
};
|
|
542
|
-
return this.safeString(statuses, status, status);
|
|
543
|
-
}
|
|
544
|
-
handleOrder(client, order) {
|
|
545
|
-
// [ 45287766631,
|
|
546
|
-
// "ETHUST",
|
|
547
|
-
// -0.07,
|
|
548
|
-
// -0.07,
|
|
549
|
-
// "EXCHANGE LIMIT",
|
|
550
|
-
// "CANCELED",
|
|
551
|
-
// 210,
|
|
552
|
-
// 0,
|
|
553
|
-
// "2020-05-16T13:17:46Z",
|
|
554
|
-
// 0,
|
|
555
|
-
// 0,
|
|
556
|
-
// 0 ]
|
|
557
|
-
const id = this.safeString(order, 0);
|
|
558
|
-
const marketId = this.safeString(order, 1);
|
|
559
|
-
const symbol = this.safeSymbol(marketId);
|
|
560
|
-
let amount = this.safeString(order, 2);
|
|
561
|
-
let remaining = this.safeString(order, 3);
|
|
562
|
-
let side = 'buy';
|
|
563
|
-
if (Precise["default"].stringLt(amount, '0')) {
|
|
564
|
-
amount = Precise["default"].stringAbs(amount);
|
|
565
|
-
remaining = Precise["default"].stringAbs(remaining);
|
|
566
|
-
side = 'sell';
|
|
567
|
-
}
|
|
568
|
-
let type = this.safeString(order, 4);
|
|
569
|
-
if (type.indexOf('LIMIT') > -1) {
|
|
570
|
-
type = 'limit';
|
|
571
|
-
}
|
|
572
|
-
else if (type.indexOf('MARKET') > -1) {
|
|
573
|
-
type = 'market';
|
|
574
|
-
}
|
|
575
|
-
const status = this.parseWsOrderStatus(this.safeString(order, 5));
|
|
576
|
-
const price = this.safeString(order, 6);
|
|
577
|
-
const rawDatetime = this.safeString(order, 8);
|
|
578
|
-
const timestamp = this.parse8601(rawDatetime);
|
|
579
|
-
const parsed = this.safeOrder({
|
|
580
|
-
'info': order,
|
|
581
|
-
'id': id,
|
|
582
|
-
'clientOrderId': undefined,
|
|
583
|
-
'timestamp': timestamp,
|
|
584
|
-
'datetime': this.iso8601(timestamp),
|
|
585
|
-
'lastTradeTimestamp': undefined,
|
|
586
|
-
'symbol': symbol,
|
|
587
|
-
'type': type,
|
|
588
|
-
'side': side,
|
|
589
|
-
'price': price,
|
|
590
|
-
'stopPrice': undefined,
|
|
591
|
-
'triggerPrice': undefined,
|
|
592
|
-
'average': undefined,
|
|
593
|
-
'amount': amount,
|
|
594
|
-
'remaining': remaining,
|
|
595
|
-
'filled': undefined,
|
|
596
|
-
'status': status,
|
|
597
|
-
'fee': undefined,
|
|
598
|
-
'cost': undefined,
|
|
599
|
-
'trades': undefined,
|
|
600
|
-
});
|
|
601
|
-
if (this.orders === undefined) {
|
|
602
|
-
const limit = this.safeInteger(this.options, 'ordersLimit', 1000);
|
|
603
|
-
this.orders = new Cache.ArrayCacheBySymbolById(limit);
|
|
604
|
-
}
|
|
605
|
-
const orders = this.orders;
|
|
606
|
-
orders.append(parsed);
|
|
607
|
-
client.resolve(parsed, id);
|
|
608
|
-
return parsed;
|
|
609
|
-
}
|
|
610
|
-
handleMessage(client, message) {
|
|
611
|
-
if (Array.isArray(message)) {
|
|
612
|
-
const channelId = this.safeString(message, 0);
|
|
613
|
-
//
|
|
614
|
-
// [
|
|
615
|
-
// 1231,
|
|
616
|
-
// "hb",
|
|
617
|
-
// ]
|
|
618
|
-
//
|
|
619
|
-
if (message[1] === 'hb') {
|
|
620
|
-
return message; // skip heartbeats within subscription channels for now
|
|
621
|
-
}
|
|
622
|
-
const subscription = this.safeValue(client.subscriptions, channelId, {});
|
|
623
|
-
const channel = this.safeString(subscription, 'channel');
|
|
624
|
-
const name = this.safeString(message, 1);
|
|
625
|
-
const methods = {
|
|
626
|
-
'book': this.handleOrderBook,
|
|
627
|
-
// 'ohlc': this.handleOHLCV,
|
|
628
|
-
'ticker': this.handleTicker,
|
|
629
|
-
'trades': this.handleTrades,
|
|
630
|
-
'os': this.handleOrders,
|
|
631
|
-
'on': this.handleOrders,
|
|
632
|
-
'oc': this.handleOrders,
|
|
633
|
-
};
|
|
634
|
-
const method = this.safeValue2(methods, channel, name);
|
|
635
|
-
if (method === undefined) {
|
|
636
|
-
return message;
|
|
637
|
-
}
|
|
638
|
-
else {
|
|
639
|
-
return method.call(this, client, message, subscription);
|
|
640
|
-
}
|
|
641
|
-
}
|
|
642
|
-
else {
|
|
643
|
-
// todo add bitfinex handleErrorMessage
|
|
644
|
-
//
|
|
645
|
-
// {
|
|
646
|
-
// "event": "info",
|
|
647
|
-
// "version": 2,
|
|
648
|
-
// "serverId": "e293377e-7bb7-427e-b28c-5db045b2c1d1",
|
|
649
|
-
// "platform": { status: 1 }, // 1 for operative, 0 for maintenance
|
|
650
|
-
// }
|
|
651
|
-
//
|
|
652
|
-
const event = this.safeString(message, 'event');
|
|
653
|
-
if (event !== undefined) {
|
|
654
|
-
const methods = {
|
|
655
|
-
'info': this.handleSystemStatus,
|
|
656
|
-
// 'book': 'handleOrderBook',
|
|
657
|
-
'subscribed': this.handleSubscriptionStatus,
|
|
658
|
-
'auth': this.handleAuthenticationMessage,
|
|
659
|
-
};
|
|
660
|
-
const method = this.safeValue(methods, event);
|
|
661
|
-
if (method === undefined) {
|
|
662
|
-
return message;
|
|
663
|
-
}
|
|
664
|
-
else {
|
|
665
|
-
return method.call(this, client, message);
|
|
666
|
-
}
|
|
667
|
-
}
|
|
668
|
-
}
|
|
669
|
-
}
|
|
670
|
-
}
|
|
671
|
-
|
|
672
|
-
module.exports = bitfinex;
|