ccxt 4.2.11 → 4.2.13
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 +5 -5
- package/build.sh +2 -2
- package/dist/ccxt.browser.js +1347 -490
- package/dist/ccxt.browser.min.js +3 -3
- package/dist/cjs/_virtual/agent.js +7 -0
- package/dist/cjs/_virtual/parse-proxy-response.js +7 -0
- package/dist/cjs/_virtual/promisify.js +7 -0
- package/dist/cjs/ccxt.js +1 -1
- package/dist/cjs/js/ccxt.js +474 -0
- package/dist/cjs/js/src/abstract/ace.js +9 -0
- package/dist/cjs/js/src/abstract/alpaca.js +9 -0
- package/dist/cjs/js/src/abstract/ascendex.js +9 -0
- package/dist/cjs/js/src/abstract/bigone.js +9 -0
- package/dist/cjs/js/src/abstract/binance.js +9 -0
- package/dist/cjs/js/src/abstract/bingx.js +9 -0
- package/dist/cjs/js/src/abstract/bit2c.js +9 -0
- package/dist/cjs/js/src/abstract/bitbank.js +9 -0
- package/dist/cjs/js/src/abstract/bitbns.js +9 -0
- package/dist/cjs/js/src/abstract/bitfinex.js +9 -0
- package/dist/cjs/js/src/abstract/bitfinex2.js +9 -0
- package/dist/cjs/js/src/abstract/bitflyer.js +9 -0
- package/dist/cjs/js/src/abstract/bitforex.js +9 -0
- package/dist/cjs/js/src/abstract/bitget.js +9 -0
- package/dist/cjs/js/src/abstract/bithumb.js +9 -0
- package/dist/cjs/js/src/abstract/bitmart.js +9 -0
- package/dist/cjs/js/src/abstract/bitmex.js +9 -0
- package/dist/cjs/js/src/abstract/bitopro.js +9 -0
- package/dist/cjs/js/src/abstract/bitpanda.js +9 -0
- package/dist/cjs/js/src/abstract/bitrue.js +9 -0
- package/dist/cjs/js/src/abstract/bitso.js +9 -0
- package/dist/cjs/js/src/abstract/bitstamp.js +9 -0
- package/dist/cjs/js/src/abstract/bitteam.js +9 -0
- package/dist/cjs/js/src/abstract/bitvavo.js +9 -0
- package/dist/cjs/js/src/abstract/bl3p.js +9 -0
- package/dist/cjs/js/src/abstract/blockchaincom.js +9 -0
- package/dist/cjs/js/src/abstract/btcalpha.js +9 -0
- package/dist/cjs/js/src/abstract/btcbox.js +9 -0
- package/dist/cjs/js/src/abstract/btcmarkets.js +9 -0
- package/dist/cjs/js/src/abstract/btcturk.js +9 -0
- package/dist/cjs/js/src/abstract/bybit.js +9 -0
- package/dist/cjs/js/src/abstract/cex.js +9 -0
- package/dist/cjs/js/src/abstract/coinbase.js +9 -0
- package/dist/cjs/js/src/abstract/coinbasepro.js +9 -0
- package/dist/cjs/js/src/abstract/coincheck.js +9 -0
- package/dist/cjs/js/src/abstract/coinex.js +9 -0
- package/dist/cjs/js/src/abstract/coinlist.js +9 -0
- package/dist/cjs/js/src/abstract/coinmate.js +9 -0
- package/dist/cjs/js/src/abstract/coinone.js +9 -0
- package/dist/cjs/js/src/abstract/coinsph.js +9 -0
- package/dist/cjs/js/src/abstract/coinspot.js +9 -0
- package/dist/cjs/js/src/abstract/cryptocom.js +9 -0
- package/dist/cjs/js/src/abstract/currencycom.js +9 -0
- package/dist/cjs/js/src/abstract/delta.js +9 -0
- package/dist/cjs/js/src/abstract/deribit.js +9 -0
- package/dist/cjs/js/src/abstract/digifinex.js +9 -0
- package/dist/cjs/js/src/abstract/exmo.js +9 -0
- package/dist/cjs/js/src/abstract/gate.js +9 -0
- package/dist/cjs/js/src/abstract/gemini.js +9 -0
- package/dist/cjs/js/src/abstract/hitbtc.js +9 -0
- package/dist/cjs/js/src/abstract/hollaex.js +9 -0
- package/dist/cjs/js/src/abstract/htx.js +9 -0
- package/dist/cjs/js/src/abstract/huobijp.js +9 -0
- package/dist/cjs/js/src/abstract/idex.js +9 -0
- package/dist/cjs/js/src/abstract/independentreserve.js +9 -0
- package/dist/cjs/js/src/abstract/indodax.js +9 -0
- package/dist/cjs/js/src/abstract/kraken.js +9 -0
- package/dist/cjs/js/src/abstract/krakenfutures.js +9 -0
- package/dist/cjs/js/src/abstract/kucoin.js +9 -0
- package/dist/cjs/js/src/abstract/kucoinfutures.js +9 -0
- package/dist/cjs/js/src/abstract/kuna.js +9 -0
- package/dist/cjs/js/src/abstract/latoken.js +9 -0
- package/dist/cjs/js/src/abstract/lbank.js +9 -0
- package/dist/cjs/js/src/abstract/luno.js +9 -0
- package/dist/cjs/js/src/abstract/lykke.js +9 -0
- package/dist/cjs/js/src/abstract/mercado.js +9 -0
- package/dist/cjs/js/src/abstract/mexc.js +9 -0
- package/dist/cjs/js/src/abstract/ndax.js +9 -0
- package/dist/cjs/js/src/abstract/novadax.js +9 -0
- package/dist/cjs/js/src/abstract/oceanex.js +9 -0
- package/dist/cjs/js/src/abstract/okcoin.js +9 -0
- package/dist/cjs/js/src/abstract/okx.js +9 -0
- package/dist/cjs/js/src/abstract/p2b.js +9 -0
- package/dist/cjs/js/src/abstract/paymium.js +9 -0
- package/dist/cjs/js/src/abstract/phemex.js +9 -0
- package/dist/cjs/js/src/abstract/poloniex.js +9 -0
- package/dist/cjs/js/src/abstract/poloniexfutures.js +9 -0
- package/dist/cjs/js/src/abstract/probit.js +9 -0
- package/dist/cjs/js/src/abstract/timex.js +9 -0
- package/dist/cjs/js/src/abstract/tokocrypto.js +9 -0
- package/dist/cjs/js/src/abstract/upbit.js +9 -0
- package/dist/cjs/js/src/abstract/wavesexchange.js +9 -0
- package/dist/cjs/js/src/abstract/wazirx.js +9 -0
- package/dist/cjs/js/src/abstract/whitebit.js +9 -0
- package/dist/cjs/js/src/abstract/woo.js +9 -0
- package/dist/cjs/js/src/abstract/yobit.js +9 -0
- package/dist/cjs/js/src/abstract/zaif.js +9 -0
- package/dist/cjs/js/src/abstract/zonda.js +9 -0
- package/dist/cjs/js/src/ace.js +1058 -0
- package/dist/cjs/js/src/alpaca.js +1125 -0
- package/dist/cjs/js/src/ascendex.js +3360 -0
- package/dist/cjs/js/src/base/Exchange.js +5110 -0
- package/dist/cjs/js/src/base/Precise.js +263 -0
- package/dist/cjs/js/src/base/errors.js +299 -0
- package/dist/cjs/js/src/base/functions/crypto.js +78 -0
- package/dist/cjs/js/src/base/functions/encode.js +44 -0
- package/dist/cjs/js/src/base/functions/generic.js +193 -0
- package/dist/cjs/js/src/base/functions/misc.js +96 -0
- package/dist/cjs/js/src/base/functions/number.js +297 -0
- package/dist/cjs/js/src/base/functions/platform.js +28 -0
- package/dist/cjs/js/src/base/functions/rsa.js +34 -0
- package/dist/cjs/js/src/base/functions/string.js +48 -0
- package/dist/cjs/js/src/base/functions/throttle.js +66 -0
- package/dist/cjs/js/src/base/functions/time.js +187 -0
- package/dist/cjs/js/src/base/functions/totp.js +24 -0
- package/dist/cjs/js/src/base/functions/type.js +162 -0
- package/dist/cjs/js/src/base/functions.js +157 -0
- package/dist/cjs/js/src/base/ws/Cache.js +254 -0
- package/dist/cjs/js/src/base/ws/Client.js +299 -0
- package/dist/cjs/js/src/base/ws/Future.js +34 -0
- package/dist/cjs/js/src/base/ws/OrderBook.js +107 -0
- package/dist/cjs/js/src/base/ws/OrderBookSide.js +281 -0
- package/dist/cjs/js/src/base/ws/WsClient.js +69 -0
- package/dist/cjs/js/src/bequant.js +33 -0
- package/dist/cjs/js/src/bigone.js +2209 -0
- package/dist/cjs/js/src/binance.js +9736 -0
- package/dist/cjs/js/src/binancecoinm.js +45 -0
- package/dist/cjs/js/src/binanceus.js +84 -0
- package/dist/cjs/js/src/binanceusdm.js +58 -0
- package/dist/cjs/js/src/bingx.js +3807 -0
- package/dist/cjs/js/src/bit2c.js +916 -0
- package/dist/cjs/js/src/bitbank.js +1000 -0
- package/dist/cjs/js/src/bitbay.js +17 -0
- package/dist/cjs/js/src/bitbns.js +1220 -0
- package/dist/cjs/js/src/bitcoincom.js +17 -0
- package/dist/cjs/js/src/bitfinex.js +1670 -0
- package/dist/cjs/js/src/bitfinex2.js +2990 -0
- package/dist/cjs/js/src/bitflyer.js +1045 -0
- package/dist/cjs/js/src/bitforex.js +852 -0
- package/dist/cjs/js/src/bitget.js +8291 -0
- package/dist/cjs/js/src/bithumb.js +1090 -0
- package/dist/cjs/js/src/bitmart.js +4454 -0
- package/dist/cjs/js/src/bitmex.js +2884 -0
- package/dist/cjs/js/src/bitopro.js +1724 -0
- package/dist/cjs/js/src/bitpanda.js +2002 -0
- package/dist/cjs/js/src/bitrue.js +3253 -0
- package/dist/cjs/js/src/bitso.js +1753 -0
- package/dist/cjs/js/src/bitstamp.js +2188 -0
- package/dist/cjs/js/src/bitteam.js +2309 -0
- package/dist/cjs/js/src/bitvavo.js +1968 -0
- package/dist/cjs/js/src/bl3p.js +447 -0
- package/dist/cjs/js/src/blockchaincom.js +1160 -0
- package/dist/cjs/js/src/btcalpha.js +929 -0
- package/dist/cjs/js/src/btcbox.js +565 -0
- package/dist/cjs/js/src/btcmarkets.js +1237 -0
- package/dist/cjs/js/src/btcturk.js +929 -0
- package/dist/cjs/js/src/bybit.js +7646 -0
- package/dist/cjs/js/src/cex.js +1693 -0
- package/dist/cjs/js/src/coinbase.js +3424 -0
- package/dist/cjs/js/src/coinbasepro.js +1866 -0
- package/dist/cjs/js/src/coincheck.js +843 -0
- package/dist/cjs/js/src/coinex.js +5414 -0
- package/dist/cjs/js/src/coinlist.js +2329 -0
- package/dist/cjs/js/src/coinmate.js +989 -0
- package/dist/cjs/js/src/coinone.js +1185 -0
- package/dist/cjs/js/src/coinsph.js +1933 -0
- package/dist/cjs/js/src/coinspot.js +548 -0
- package/dist/cjs/js/src/cryptocom.js +3007 -0
- package/dist/cjs/js/src/currencycom.js +2015 -0
- package/dist/cjs/js/src/delta.js +3256 -0
- package/dist/cjs/js/src/deribit.js +3306 -0
- package/dist/cjs/js/src/digifinex.js +4307 -0
- package/dist/cjs/js/src/exmo.js +2645 -0
- package/dist/cjs/js/src/fmfwio.js +34 -0
- package/dist/cjs/js/src/gate.js +7072 -0
- package/dist/cjs/js/src/gateio.js +16 -0
- package/dist/cjs/js/src/gemini.js +1801 -0
- package/dist/cjs/js/src/hitbtc.js +3660 -0
- package/dist/cjs/js/src/hitbtc3.js +19 -0
- package/dist/cjs/js/src/hollaex.js +1882 -0
- package/dist/cjs/js/src/htx.js +9049 -0
- package/dist/cjs/js/src/huobi.js +16 -0
- package/dist/cjs/js/src/huobijp.js +1918 -0
- package/dist/cjs/js/src/idex.js +1770 -0
- package/dist/cjs/js/src/independentreserve.js +761 -0
- package/dist/cjs/js/src/indodax.js +1069 -0
- package/dist/cjs/js/src/kraken.js +2857 -0
- package/dist/cjs/js/src/krakenfutures.js +2407 -0
- package/dist/cjs/js/src/kucoin.js +4489 -0
- package/dist/cjs/js/src/kucoinfutures.js +2475 -0
- package/dist/cjs/js/src/kuna.js +1949 -0
- package/dist/cjs/js/src/latoken.js +1729 -0
- package/dist/cjs/js/src/lbank.js +2851 -0
- package/dist/cjs/js/src/luno.js +1044 -0
- package/dist/cjs/js/src/lykke.js +1303 -0
- package/dist/cjs/js/src/mercado.js +897 -0
- package/dist/cjs/js/src/mexc.js +5407 -0
- package/dist/cjs/js/src/ndax.js +2450 -0
- package/dist/cjs/js/src/novadax.js +1556 -0
- package/dist/cjs/js/src/oceanex.js +964 -0
- package/dist/cjs/js/src/okcoin.js +3115 -0
- package/dist/cjs/js/src/okx.js +7330 -0
- package/dist/cjs/js/src/p2b.js +1243 -0
- package/dist/cjs/js/src/paymium.js +597 -0
- package/dist/cjs/js/src/phemex.js +4722 -0
- package/dist/cjs/js/src/poloniex.js +2356 -0
- package/dist/cjs/js/src/poloniexfutures.js +1794 -0
- package/dist/cjs/js/src/pro/alpaca.js +714 -0
- package/dist/cjs/js/src/pro/ascendex.js +957 -0
- package/dist/cjs/js/src/pro/bequant.js +33 -0
- package/dist/cjs/js/src/pro/binance.js +2796 -0
- package/dist/cjs/js/src/pro/binancecoinm.js +23 -0
- package/dist/cjs/js/src/pro/binanceus.js +51 -0
- package/dist/cjs/js/src/pro/binanceusdm.js +32 -0
- package/dist/cjs/js/src/pro/bingx.js +944 -0
- package/dist/cjs/js/src/pro/bitcoincom.js +29 -0
- package/dist/cjs/js/src/pro/bitfinex.js +672 -0
- package/dist/cjs/js/src/pro/bitfinex2.js +1159 -0
- package/dist/cjs/js/src/pro/bitget.js +1733 -0
- package/dist/cjs/js/src/pro/bitmart.js +1486 -0
- package/dist/cjs/js/src/pro/bitmex.js +1576 -0
- package/dist/cjs/js/src/pro/bitopro.js +327 -0
- package/dist/cjs/js/src/pro/bitpanda.js +1341 -0
- package/dist/cjs/js/src/pro/bitrue.js +462 -0
- package/dist/cjs/js/src/pro/bitstamp.js +547 -0
- package/dist/cjs/js/src/pro/bitvavo.js +704 -0
- package/dist/cjs/js/src/pro/blockchaincom.js +794 -0
- package/dist/cjs/js/src/pro/bybit.js +1843 -0
- package/dist/cjs/js/src/pro/cex.js +1510 -0
- package/dist/cjs/js/src/pro/coinbase.js +561 -0
- package/dist/cjs/js/src/pro/coinbasepro.js +968 -0
- package/dist/cjs/js/src/pro/coinex.js +1095 -0
- package/dist/cjs/js/src/pro/cryptocom.js +1020 -0
- package/dist/cjs/js/src/pro/currencycom.js +563 -0
- package/dist/cjs/js/src/pro/deribit.js +825 -0
- package/dist/cjs/js/src/pro/exmo.js +658 -0
- package/dist/cjs/js/src/pro/gate.js +1316 -0
- package/dist/cjs/js/src/pro/gateio.js +16 -0
- package/dist/cjs/js/src/pro/gemini.js +649 -0
- package/dist/cjs/js/src/pro/hitbtc.js +1293 -0
- package/dist/cjs/js/src/pro/hollaex.js +597 -0
- package/dist/cjs/js/src/pro/htx.js +2383 -0
- package/dist/cjs/js/src/pro/huobi.js +16 -0
- package/dist/cjs/js/src/pro/huobijp.js +606 -0
- package/dist/cjs/js/src/pro/idex.js +714 -0
- package/dist/cjs/js/src/pro/independentreserve.js +280 -0
- package/dist/cjs/js/src/pro/kraken.js +1364 -0
- package/dist/cjs/js/src/pro/krakenfutures.js +1500 -0
- package/dist/cjs/js/src/pro/kucoin.js +1052 -0
- package/dist/cjs/js/src/pro/kucoinfutures.js +981 -0
- package/dist/cjs/js/src/pro/luno.js +322 -0
- package/dist/cjs/js/src/pro/mexc.js +1170 -0
- package/dist/cjs/js/src/pro/ndax.js +545 -0
- package/dist/cjs/js/src/pro/okcoin.js +760 -0
- package/dist/cjs/js/src/pro/okx.js +1608 -0
- package/dist/cjs/js/src/pro/phemex.js +1511 -0
- package/dist/cjs/js/src/pro/poloniex.js +1253 -0
- package/dist/cjs/js/src/pro/poloniexfutures.js +1014 -0
- package/dist/cjs/js/src/pro/probit.js +586 -0
- package/dist/cjs/js/src/pro/upbit.js +234 -0
- package/dist/cjs/js/src/pro/wazirx.js +776 -0
- package/dist/cjs/js/src/pro/whitebit.js +927 -0
- package/dist/cjs/js/src/pro/woo.js +769 -0
- package/dist/cjs/js/src/probit.js +1867 -0
- package/dist/cjs/js/src/static_dependencies/fflake/browser.js +401 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +195 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +308 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +554 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +16 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1760 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +52 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +81 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +376 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +70 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1580 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +74 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +24 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +158 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +429 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +176 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +324 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +163 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +245 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +1018 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +383 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +258 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +53 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +120 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +69 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +7 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +83 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +240 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +91 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +130 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +214 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +239 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +93 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +354 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +16 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +20 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +30 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +239 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +372 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +273 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +139 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +14 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +16 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +81 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +292 -0
- package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +103 -0
- package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +140 -0
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +175 -0
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
- package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +7 -0
- package/dist/cjs/js/src/static_dependencies/scure-base/index.js +383 -0
- package/dist/cjs/js/src/timex.js +1562 -0
- package/dist/cjs/js/src/tokocrypto.js +2542 -0
- package/dist/cjs/js/src/upbit.js +1844 -0
- package/dist/cjs/js/src/wavesexchange.js +2607 -0
- package/dist/cjs/js/src/wazirx.js +953 -0
- package/dist/cjs/js/src/whitebit.js +2309 -0
- package/dist/cjs/js/src/woo.js +2765 -0
- package/dist/cjs/js/src/yobit.js +1314 -0
- package/dist/cjs/js/src/zaif.js +736 -0
- package/dist/cjs/js/src/zonda.js +1883 -0
- package/js/ccxt.d.ts +1 -1
- package/js/ccxt.js +1 -1
- package/js/src/abstract/bigone.d.ts +18 -0
- package/js/src/abstract/binance.d.ts +2 -0
- package/js/src/abstract/binancecoinm.d.ts +2 -0
- package/js/src/abstract/binanceus.d.ts +2 -0
- package/js/src/abstract/binanceusdm.d.ts +2 -0
- package/js/src/abstract/bingx.d.ts +2 -0
- package/js/src/abstract/bybit.d.ts +1 -0
- package/js/src/abstract/gate.d.ts +11 -0
- package/js/src/abstract/gateio.d.ts +11 -0
- package/js/src/abstract/okx.d.ts +1 -0
- package/js/src/alpaca.js +18 -18
- package/js/src/base/Exchange.d.ts +5 -1
- package/js/src/base/Exchange.js +101 -12
- package/js/src/bigone.d.ts +3 -2
- package/js/src/bigone.js +429 -167
- package/js/src/binance.js +48 -34
- package/js/src/bingx.js +115 -38
- package/js/src/bitfinex.d.ts +2 -2
- package/js/src/bitfinex.js +2 -3
- package/js/src/bitget.js +33 -13
- package/js/src/bitmart.d.ts +2 -2
- package/js/src/bitmart.js +5 -5
- package/js/src/bitmex.js +1 -0
- package/js/src/bybit.js +2 -0
- package/js/src/coinbase.d.ts +26 -3
- package/js/src/coinbase.js +176 -26
- package/js/src/coinlist.js +3 -4
- package/js/src/coinone.js +1 -1
- package/js/src/coinsph.js +2 -3
- package/js/src/deribit.js +1 -0
- package/js/src/gate.d.ts +4 -4
- package/js/src/gate.js +96 -59
- package/js/src/gemini.js +1 -1
- package/js/src/hitbtc.d.ts +4 -4
- package/js/src/hitbtc.js +2 -3
- package/js/src/htx.d.ts +1 -0
- package/js/src/htx.js +29 -7
- package/js/src/huobijp.js +2 -3
- package/js/src/independentreserve.js +7 -5
- package/js/src/kraken.js +3 -6
- package/js/src/lbank.js +59 -33
- package/js/src/mexc.js +2 -1
- package/js/src/oceanex.js +1 -1
- package/js/src/okx.js +14 -3
- package/js/src/phemex.js +9 -2
- package/js/src/pro/binance.d.ts +2 -23
- package/js/src/pro/binance.js +58 -22
- package/js/src/pro/coinbase.d.ts +2 -2
- package/js/src/pro/coinbase.js +4 -1
- package/js/src/pro/coinbasepro.d.ts +2 -2
- package/js/src/pro/hitbtc.d.ts +2 -2
- package/js/src/pro/kraken.js +1 -1
- package/js/src/pro/okx.d.ts +1 -0
- package/js/src/pro/okx.js +52 -2
- package/js/src/pro/poloniex.d.ts +2 -2
- package/js/src/probit.js +4 -2
- package/js/src/upbit.d.ts +3 -101
- package/js/src/upbit.js +12 -12
- package/js/src/wavesexchange.js +1 -1
- package/js/src/woo.d.ts +2 -0
- package/js/src/woo.js +52 -0
- package/package.json +1 -1
- package/skip-tests.json +5 -0
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var type = require('./type.js');
|
|
6
|
+
|
|
7
|
+
// ----------------------------------------------------------------------------
|
|
8
|
+
// ----------------------------------------------------------------------------
|
|
9
|
+
const keys = Object.keys; // eslint-disable-line padding-line-between-statements
|
|
10
|
+
const values = (x) => ((!type.isArray(x)) ? Object.values(x) : x); // don't copy arrays if they're already arrays
|
|
11
|
+
const index = (x) => new Set(values(x));
|
|
12
|
+
const extend = (...args) => Object.assign({}, ...args); // NB: side-effect free
|
|
13
|
+
const clone = (x) => (type.isArray(x) ? Array.from(x) : extend(x)); // clone arrays or objects
|
|
14
|
+
// ----------------------------------------------------------------------------
|
|
15
|
+
const ordered = (x) => x; // a stub to keep assoc keys in order (in JS it does nothing, it's mostly for Python)
|
|
16
|
+
const unique = (x) => Array.from(index(x));
|
|
17
|
+
const arrayConcat = (a, b) => a.concat(b);
|
|
18
|
+
// ------------------------------------------------------------------------
|
|
19
|
+
const inArray = (needle, haystack) => haystack.includes(needle);
|
|
20
|
+
const toArray = (object) => Object.values(object);
|
|
21
|
+
const isEmpty = (object) => {
|
|
22
|
+
if (!object) {
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
return (Array.isArray(object) ? object : Object.keys(object)).length < 1;
|
|
26
|
+
};
|
|
27
|
+
const keysort = (x, out = {}) => {
|
|
28
|
+
for (const k of keys(x).sort()) {
|
|
29
|
+
out[k] = x[k];
|
|
30
|
+
}
|
|
31
|
+
return out;
|
|
32
|
+
};
|
|
33
|
+
/*
|
|
34
|
+
Accepts a map/array of objects and a key name to be used as an index:
|
|
35
|
+
array = [
|
|
36
|
+
{ someKey: 'value1', anotherKey: 'anotherValue1' },
|
|
37
|
+
{ someKey: 'value2', anotherKey: 'anotherValue2' },
|
|
38
|
+
{ someKey: 'value3', anotherKey: 'anotherValue3' },
|
|
39
|
+
]
|
|
40
|
+
key = 'someKey'
|
|
41
|
+
Returns a map:
|
|
42
|
+
{
|
|
43
|
+
value1: { someKey: 'value1', anotherKey: 'anotherValue1' },
|
|
44
|
+
value2: { someKey: 'value2', anotherKey: 'anotherValue2' },
|
|
45
|
+
value3: { someKey: 'value3', anotherKey: 'anotherValue3' },
|
|
46
|
+
}
|
|
47
|
+
*/
|
|
48
|
+
const groupBy = (x, k, out = {}) => {
|
|
49
|
+
for (const v of values(x)) {
|
|
50
|
+
if (k in v) {
|
|
51
|
+
const p = v[k];
|
|
52
|
+
out[p] = out[p] || [];
|
|
53
|
+
out[p].push(v);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
return out;
|
|
57
|
+
};
|
|
58
|
+
const indexBy = (x, k, out = {}) => {
|
|
59
|
+
for (const v of values(x)) {
|
|
60
|
+
if (k in v) {
|
|
61
|
+
out[v[k]] = v;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
return out;
|
|
65
|
+
};
|
|
66
|
+
const filterBy = (x, k, value = undefined, out = []) => {
|
|
67
|
+
for (const v of values(x)) {
|
|
68
|
+
if (v[k] === value) {
|
|
69
|
+
out.push(v);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return out;
|
|
73
|
+
};
|
|
74
|
+
const sortBy = (array, key, descending = false, defaultValue = 0, direction = descending ? -1 : 1) => array.sort((a, b) => {
|
|
75
|
+
const first = (key in a) ? a[key] : defaultValue;
|
|
76
|
+
const second = (key in b) ? b[key] : defaultValue;
|
|
77
|
+
if (first < second) {
|
|
78
|
+
return -direction;
|
|
79
|
+
}
|
|
80
|
+
else if (first > second) {
|
|
81
|
+
return direction;
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
return 0;
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
const sortBy2 = (array, key1, key2, descending = false, direction = descending ? -1 : 1) => array.sort((a, b) => {
|
|
88
|
+
if (a[key1] < b[key1]) {
|
|
89
|
+
return -direction;
|
|
90
|
+
}
|
|
91
|
+
else if (a[key1] > b[key1]) {
|
|
92
|
+
return direction;
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
if (a[key2] < b[key2]) {
|
|
96
|
+
return -direction;
|
|
97
|
+
}
|
|
98
|
+
else if (a[key2] > b[key2]) {
|
|
99
|
+
return direction;
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
return 0;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
const flatten = function flatten(x, out = []) {
|
|
107
|
+
for (const v of x) {
|
|
108
|
+
if (type.isArray(v)) {
|
|
109
|
+
flatten(v, out);
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
out.push(v);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
return out;
|
|
116
|
+
};
|
|
117
|
+
const pluck = (x, k) => values(x).filter((v) => k in v).map((v) => v[k]);
|
|
118
|
+
const omit = (x, ...args) => {
|
|
119
|
+
if (!Array.isArray(x)) {
|
|
120
|
+
const out = clone(x);
|
|
121
|
+
for (const k of args) {
|
|
122
|
+
if (type.isArray(k)) { // omit (x, ['a', 'b'])
|
|
123
|
+
for (const kk of k) {
|
|
124
|
+
delete out[kk];
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
delete out[k]; // omit (x, 'a', 'b')
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
return out;
|
|
132
|
+
}
|
|
133
|
+
return x;
|
|
134
|
+
};
|
|
135
|
+
const sum = (...xs) => {
|
|
136
|
+
const ns = xs.filter(type.isNumber); // leave only numbers
|
|
137
|
+
return (ns.length > 0) ? ns.reduce((a, b) => a + b, 0) : undefined;
|
|
138
|
+
};
|
|
139
|
+
const deepExtend = function deepExtend(...xs) {
|
|
140
|
+
let out = undefined;
|
|
141
|
+
for (const x of xs) {
|
|
142
|
+
if (type.isDictionary(x)) {
|
|
143
|
+
if (!type.isDictionary(out)) {
|
|
144
|
+
out = {};
|
|
145
|
+
}
|
|
146
|
+
for (const k in x) {
|
|
147
|
+
out[k] = deepExtend(out[k], x[k]);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
out = x;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
return out;
|
|
155
|
+
};
|
|
156
|
+
const merge = (target, ...args) => {
|
|
157
|
+
// doesn't overwrite defined keys with undefined
|
|
158
|
+
const overwrite = {};
|
|
159
|
+
const merged = Object.assign({}, ...args);
|
|
160
|
+
const keys = Object.keys(merged);
|
|
161
|
+
for (let i = 0; i < keys.length; i++) {
|
|
162
|
+
const key = keys[i];
|
|
163
|
+
if (target[key] === undefined) {
|
|
164
|
+
overwrite[key] = merged[key];
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
// eslint-disable-next-line
|
|
168
|
+
return Object.assign({}, target, overwrite);
|
|
169
|
+
};
|
|
170
|
+
|
|
171
|
+
exports.arrayConcat = arrayConcat;
|
|
172
|
+
exports.clone = clone;
|
|
173
|
+
exports.deepExtend = deepExtend;
|
|
174
|
+
exports.extend = extend;
|
|
175
|
+
exports.filterBy = filterBy;
|
|
176
|
+
exports.flatten = flatten;
|
|
177
|
+
exports.groupBy = groupBy;
|
|
178
|
+
exports.inArray = inArray;
|
|
179
|
+
exports.index = index;
|
|
180
|
+
exports.indexBy = indexBy;
|
|
181
|
+
exports.isEmpty = isEmpty;
|
|
182
|
+
exports.keys = keys;
|
|
183
|
+
exports.keysort = keysort;
|
|
184
|
+
exports.merge = merge;
|
|
185
|
+
exports.omit = omit;
|
|
186
|
+
exports.ordered = ordered;
|
|
187
|
+
exports.pluck = pluck;
|
|
188
|
+
exports.sortBy = sortBy;
|
|
189
|
+
exports.sortBy2 = sortBy2;
|
|
190
|
+
exports.sum = sum;
|
|
191
|
+
exports.toArray = toArray;
|
|
192
|
+
exports.unique = unique;
|
|
193
|
+
exports.values = values;
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var number = require('./number.js');
|
|
6
|
+
var type = require('./type.js');
|
|
7
|
+
var errors = require('../errors.js');
|
|
8
|
+
|
|
9
|
+
//-------------------------------------------------------------------------
|
|
10
|
+
// converts timeframe to seconds
|
|
11
|
+
const parseTimeframe = (timeframe) => {
|
|
12
|
+
const amount = type.asFloat(timeframe.slice(0, -1));
|
|
13
|
+
const unit = timeframe.slice(-1);
|
|
14
|
+
let scale = undefined;
|
|
15
|
+
if (unit === 'y') {
|
|
16
|
+
scale = 60 * 60 * 24 * 365;
|
|
17
|
+
}
|
|
18
|
+
else if (unit === 'M') {
|
|
19
|
+
scale = 60 * 60 * 24 * 30;
|
|
20
|
+
}
|
|
21
|
+
else if (unit === 'w') {
|
|
22
|
+
scale = 60 * 60 * 24 * 7;
|
|
23
|
+
}
|
|
24
|
+
else if (unit === 'd') {
|
|
25
|
+
scale = 60 * 60 * 24;
|
|
26
|
+
}
|
|
27
|
+
else if (unit === 'h') {
|
|
28
|
+
scale = 60 * 60;
|
|
29
|
+
}
|
|
30
|
+
else if (unit === 'm') {
|
|
31
|
+
scale = 60;
|
|
32
|
+
}
|
|
33
|
+
else if (unit === 's') {
|
|
34
|
+
scale = 1;
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
throw new errors.NotSupported('timeframe unit ' + unit + ' is not supported');
|
|
38
|
+
}
|
|
39
|
+
return amount * scale;
|
|
40
|
+
};
|
|
41
|
+
const roundTimeframe = (timeframe, timestamp, direction = number.ROUND_DOWN) => {
|
|
42
|
+
const ms = parseTimeframe(timeframe) * 1000;
|
|
43
|
+
// Get offset based on timeframe in milliseconds
|
|
44
|
+
const offset = timestamp % ms;
|
|
45
|
+
return timestamp - offset + ((direction === number.ROUND_UP) ? ms : 0);
|
|
46
|
+
};
|
|
47
|
+
const extractParams = (string) => {
|
|
48
|
+
/**
|
|
49
|
+
* @ignore
|
|
50
|
+
* @method
|
|
51
|
+
* @param string usually a url path
|
|
52
|
+
* @returns {[string]} all substrings surrounded by {} from parameter string
|
|
53
|
+
*/
|
|
54
|
+
const re = /{([\w-]+)}/g;
|
|
55
|
+
const matches = [];
|
|
56
|
+
let match = re.exec(string);
|
|
57
|
+
while (match) {
|
|
58
|
+
matches.push(match[1]);
|
|
59
|
+
match = re.exec(string);
|
|
60
|
+
}
|
|
61
|
+
return matches;
|
|
62
|
+
};
|
|
63
|
+
const implodeParams = (string, params) => {
|
|
64
|
+
if (!Array.isArray(params)) {
|
|
65
|
+
const keys = Object.keys(params);
|
|
66
|
+
for (let i = 0; i < keys.length; i++) {
|
|
67
|
+
const key = keys[i];
|
|
68
|
+
if (!Array.isArray(params[key])) {
|
|
69
|
+
string = string.replace('{' + key + '}', params[key]);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return string;
|
|
74
|
+
};
|
|
75
|
+
function vwap(baseVolume, quoteVolume) {
|
|
76
|
+
return ((baseVolume !== undefined) && (quoteVolume !== undefined) && (baseVolume > 0)) ? (quoteVolume / baseVolume) : undefined;
|
|
77
|
+
}
|
|
78
|
+
/* ------------------------------------------------------------------------ */
|
|
79
|
+
function aggregate(bidasks) {
|
|
80
|
+
const result = {};
|
|
81
|
+
for (let i = 0; i < bidasks.length; i++) {
|
|
82
|
+
const [price, volume] = bidasks[i];
|
|
83
|
+
if (volume > 0) {
|
|
84
|
+
result[price] = (result[price] || 0) + volume;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return Object.keys(result).map((price) => [parseFloat(price), parseFloat(result[price])]);
|
|
88
|
+
}
|
|
89
|
+
/* ------------------------------------------------------------------------ */
|
|
90
|
+
|
|
91
|
+
exports.aggregate = aggregate;
|
|
92
|
+
exports.extractParams = extractParams;
|
|
93
|
+
exports.implodeParams = implodeParams;
|
|
94
|
+
exports.parseTimeframe = parseTimeframe;
|
|
95
|
+
exports.roundTimeframe = roundTimeframe;
|
|
96
|
+
exports.vwap = vwap;
|
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
// ------------------------------------------------------------------------
|
|
6
|
+
//
|
|
7
|
+
// NB: initially, I used objects for options passing:
|
|
8
|
+
//
|
|
9
|
+
// decimalToPrecision ('123.456', { digits: 2, round: true, afterPoint: true })
|
|
10
|
+
//
|
|
11
|
+
// ...but it turns out it's hard to port that across different languages and it is also
|
|
12
|
+
// probably has a performance penalty -- while it's a performance critical code! So
|
|
13
|
+
// I switched to using named constants instead, as it is actually more readable and
|
|
14
|
+
// succinct, and surely doesn't come with any inherent performance downside:
|
|
15
|
+
//
|
|
16
|
+
// decimalToPrecision ('123.456', ROUND, 2, DECIMAL_PLACES)
|
|
17
|
+
const TRUNCATE = 0; // rounding mode
|
|
18
|
+
const ROUND = 1;
|
|
19
|
+
const ROUND_UP = 2;
|
|
20
|
+
const ROUND_DOWN = 3;
|
|
21
|
+
const DECIMAL_PLACES = 2; // digits counting mode
|
|
22
|
+
const SIGNIFICANT_DIGITS = 3;
|
|
23
|
+
const TICK_SIZE = 4;
|
|
24
|
+
const NO_PADDING = 5; // zero-padding mode
|
|
25
|
+
const PAD_WITH_ZERO = 6;
|
|
26
|
+
const precisionConstants = {
|
|
27
|
+
ROUND,
|
|
28
|
+
TRUNCATE,
|
|
29
|
+
ROUND_UP,
|
|
30
|
+
ROUND_DOWN,
|
|
31
|
+
DECIMAL_PLACES,
|
|
32
|
+
SIGNIFICANT_DIGITS,
|
|
33
|
+
TICK_SIZE,
|
|
34
|
+
NO_PADDING,
|
|
35
|
+
PAD_WITH_ZERO,
|
|
36
|
+
};
|
|
37
|
+
/* ------------------------------------------------------------------------ */
|
|
38
|
+
// See https://stackoverflow.com/questions/1685680/how-to-avoid-scientific-notation-for-large-numbers-in-javascript for discussion
|
|
39
|
+
function numberToString(x) {
|
|
40
|
+
if (x === undefined)
|
|
41
|
+
return undefined;
|
|
42
|
+
if (typeof x !== 'number')
|
|
43
|
+
return x.toString();
|
|
44
|
+
const s = x.toString();
|
|
45
|
+
if (Math.abs(x) < 1.0) {
|
|
46
|
+
const n_e = s.split('e-');
|
|
47
|
+
const n = n_e[0].replace('.', '');
|
|
48
|
+
const e = parseInt(n_e[1]);
|
|
49
|
+
const neg = (s[0] === '-');
|
|
50
|
+
if (e) {
|
|
51
|
+
x = (neg ? '-' : '') + '0.' + (new Array(e)).join('0') + n.substring(neg);
|
|
52
|
+
return x;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
const parts = s.split('e');
|
|
57
|
+
if (parts[1]) {
|
|
58
|
+
let e = parseInt(parts[1]);
|
|
59
|
+
const m = parts[0].split('.');
|
|
60
|
+
let part = '';
|
|
61
|
+
if (m[1]) {
|
|
62
|
+
e -= m[1].length;
|
|
63
|
+
part = m[1];
|
|
64
|
+
}
|
|
65
|
+
return m[0] + part + (new Array(e + 1)).join('0');
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return s;
|
|
69
|
+
}
|
|
70
|
+
//-----------------------------------------------------------------------------
|
|
71
|
+
// expects non-scientific notation
|
|
72
|
+
const truncate_regExpCache = [];
|
|
73
|
+
const truncate_to_string = (num, precision = 0) => {
|
|
74
|
+
num = numberToString(num);
|
|
75
|
+
if (precision > 0) {
|
|
76
|
+
const re = truncate_regExpCache[precision] || (truncate_regExpCache[precision] = new RegExp('([-]*\\d+\\.\\d{' + precision + '})(\\d)'));
|
|
77
|
+
const [, result] = num.toString().match(re) || [null, num];
|
|
78
|
+
return result.toString();
|
|
79
|
+
}
|
|
80
|
+
return parseInt(num).toString();
|
|
81
|
+
};
|
|
82
|
+
const truncate = (num, precision = 0) => parseFloat(truncate_to_string(num, precision));
|
|
83
|
+
function precisionFromString(str) {
|
|
84
|
+
// support string formats like '1e-4'
|
|
85
|
+
if (str.indexOf('e') > -1) {
|
|
86
|
+
const numStr = str.replace(/\de/, '');
|
|
87
|
+
return parseInt(numStr) * -1;
|
|
88
|
+
}
|
|
89
|
+
// support integer formats (without dot) like '1', '10' etc [Note: bug in decimalToPrecision, so this should not be used atm]
|
|
90
|
+
// if (str.indexOf ('.') === -1) {
|
|
91
|
+
// return str.length * -1
|
|
92
|
+
// }
|
|
93
|
+
// default strings like '0.0001'
|
|
94
|
+
const split = str.replace(/0+$/g, '').split('.');
|
|
95
|
+
return (split.length > 1) ? (split[1].length) : 0;
|
|
96
|
+
}
|
|
97
|
+
/* ------------------------------------------------------------------------ */
|
|
98
|
+
const decimalToPrecision = (x, roundingMode, numPrecisionDigits, countingMode = DECIMAL_PLACES, paddingMode = NO_PADDING) => {
|
|
99
|
+
if (countingMode === TICK_SIZE) {
|
|
100
|
+
if (typeof numPrecisionDigits === 'string') {
|
|
101
|
+
numPrecisionDigits = parseFloat(numPrecisionDigits);
|
|
102
|
+
}
|
|
103
|
+
if (numPrecisionDigits <= 0) {
|
|
104
|
+
throw new Error('TICK_SIZE cant be used with negative or zero numPrecisionDigits');
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
if (numPrecisionDigits < 0) {
|
|
108
|
+
const toNearest = Math.pow(10, -numPrecisionDigits);
|
|
109
|
+
if (roundingMode === ROUND) {
|
|
110
|
+
return (toNearest * decimalToPrecision(x / toNearest, roundingMode, 0, countingMode, paddingMode)).toString();
|
|
111
|
+
}
|
|
112
|
+
if (roundingMode === TRUNCATE) {
|
|
113
|
+
return (x - (x % toNearest)).toString();
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
/* handle tick size */
|
|
117
|
+
if (countingMode === TICK_SIZE) {
|
|
118
|
+
const precisionDigitsString = decimalToPrecision(numPrecisionDigits, ROUND, 22, DECIMAL_PLACES, NO_PADDING);
|
|
119
|
+
const newNumPrecisionDigits = precisionFromString(precisionDigitsString);
|
|
120
|
+
let missing = x % numPrecisionDigits;
|
|
121
|
+
// See: https://github.com/ccxt/ccxt/pull/6486
|
|
122
|
+
missing = Number(decimalToPrecision(missing, ROUND, 8, DECIMAL_PLACES, NO_PADDING));
|
|
123
|
+
const fpError = decimalToPrecision(missing / numPrecisionDigits, ROUND, Math.max(newNumPrecisionDigits, 8), DECIMAL_PLACES, NO_PADDING);
|
|
124
|
+
if (precisionFromString(fpError) !== 0) {
|
|
125
|
+
if (roundingMode === ROUND) {
|
|
126
|
+
if (x > 0) {
|
|
127
|
+
if (missing >= numPrecisionDigits / 2) {
|
|
128
|
+
x = x - missing + numPrecisionDigits;
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
x = x - missing;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
if (missing >= numPrecisionDigits / 2) {
|
|
136
|
+
x = Number(x) - missing;
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
x = Number(x) - missing - numPrecisionDigits;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
else if (roundingMode === TRUNCATE) {
|
|
144
|
+
x = x - missing;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
return decimalToPrecision(x, ROUND, newNumPrecisionDigits, DECIMAL_PLACES, paddingMode);
|
|
148
|
+
}
|
|
149
|
+
/* Convert to a string (if needed), skip leading minus sign (if any) */
|
|
150
|
+
const str = numberToString(x);
|
|
151
|
+
const isNegative = str[0] === '-';
|
|
152
|
+
const strStart = isNegative ? 1 : 0;
|
|
153
|
+
const strEnd = str.length;
|
|
154
|
+
/* Find the dot position in the source buffer */
|
|
155
|
+
for (var strDot = 0; strDot < strEnd; strDot++) {
|
|
156
|
+
if (str[strDot] === '.')
|
|
157
|
+
break;
|
|
158
|
+
}
|
|
159
|
+
const hasDot = strDot < str.length;
|
|
160
|
+
/* Char code constants */
|
|
161
|
+
const MINUS = 45;
|
|
162
|
+
const DOT = 46;
|
|
163
|
+
const ZERO = 48;
|
|
164
|
+
const ONE = (ZERO + 1);
|
|
165
|
+
const FIVE = (ZERO + 5);
|
|
166
|
+
const NINE = (ZERO + 9);
|
|
167
|
+
/* For -123.4567 the `chars` array will hold 01234567 (leading zero is reserved for rounding cases when 099 → 100) */
|
|
168
|
+
const chars = new Uint8Array((strEnd - strStart) + (hasDot ? 0 : 1));
|
|
169
|
+
chars[0] = ZERO;
|
|
170
|
+
/* Validate & copy digits, determine certain locations in the resulting buffer */
|
|
171
|
+
let afterDot = chars.length;
|
|
172
|
+
let digitsStart = -1; // significant digits
|
|
173
|
+
let digitsEnd = -1;
|
|
174
|
+
for (var i = 1, j = strStart; j < strEnd; j++, i++) {
|
|
175
|
+
const c = str.charCodeAt(j);
|
|
176
|
+
if (c === DOT) {
|
|
177
|
+
afterDot = i--;
|
|
178
|
+
}
|
|
179
|
+
else if ((c < ZERO) || (c > NINE)) {
|
|
180
|
+
throw new Error(`${str}: invalid number (contains an illegal character '${str[i - 1]}')`);
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
chars[i] = c;
|
|
184
|
+
if ((c !== ZERO) && (digitsStart < 0))
|
|
185
|
+
digitsStart = i;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
if (digitsStart < 0)
|
|
189
|
+
digitsStart = 1;
|
|
190
|
+
/* Determine the range to cut */
|
|
191
|
+
let precisionStart = (countingMode === DECIMAL_PLACES) ? afterDot // 0.(0)001234567
|
|
192
|
+
: digitsStart; // 0.00(1)234567
|
|
193
|
+
let precisionEnd = precisionStart
|
|
194
|
+
+ numPrecisionDigits;
|
|
195
|
+
/* Reset the last significant digit index, as it will change during the rounding/truncation. */
|
|
196
|
+
digitsEnd = -1;
|
|
197
|
+
// Perform rounding/truncation per digit, from digitsEnd to digitsStart, by using the following
|
|
198
|
+
// algorithm (rounding 999 → 1000, as an example):
|
|
199
|
+
//
|
|
200
|
+
// step = i=3 i=2 i=1 i=0
|
|
201
|
+
//
|
|
202
|
+
// chars = 0999 0999 0900 1000
|
|
203
|
+
// memo = ---0 --1- -1-- 0---
|
|
204
|
+
let allZeros = true;
|
|
205
|
+
let signNeeded = isNegative;
|
|
206
|
+
for (let i = chars.length - 1, memo = 0; i >= 0; i--) {
|
|
207
|
+
let c = chars[i];
|
|
208
|
+
if (i !== 0) {
|
|
209
|
+
c += memo;
|
|
210
|
+
if (i >= (precisionStart + numPrecisionDigits)) {
|
|
211
|
+
const ceil = (roundingMode === ROUND)
|
|
212
|
+
&& (c >= FIVE)
|
|
213
|
+
&& !((c === FIVE) && memo); // prevents rounding of 1.45 to 2
|
|
214
|
+
c = ceil ? (NINE + 1) : ZERO;
|
|
215
|
+
}
|
|
216
|
+
if (c > NINE) {
|
|
217
|
+
c = ZERO;
|
|
218
|
+
memo = 1;
|
|
219
|
+
}
|
|
220
|
+
else
|
|
221
|
+
memo = 0;
|
|
222
|
+
}
|
|
223
|
+
else if (memo)
|
|
224
|
+
c = ONE; // leading extra digit (0900 → 1000)
|
|
225
|
+
chars[i] = c;
|
|
226
|
+
if (c !== ZERO) {
|
|
227
|
+
allZeros = false;
|
|
228
|
+
digitsStart = i;
|
|
229
|
+
digitsEnd = (digitsEnd < 0) ? (i + 1) : digitsEnd;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
/* Update the precision range, as `digitsStart` may have changed... & the need for a negative sign if it is only 0 */
|
|
233
|
+
if (countingMode === SIGNIFICANT_DIGITS) {
|
|
234
|
+
precisionStart = digitsStart;
|
|
235
|
+
precisionEnd = precisionStart + numPrecisionDigits;
|
|
236
|
+
}
|
|
237
|
+
if (allZeros) {
|
|
238
|
+
signNeeded = false;
|
|
239
|
+
}
|
|
240
|
+
/* Determine the input character range */
|
|
241
|
+
const readStart = ((digitsStart >= afterDot) || allZeros) ? (afterDot - 1) : digitsStart; // 0.000(1)234 ----> (0).0001234
|
|
242
|
+
const readEnd = (digitsEnd < afterDot) ? (afterDot) : digitsEnd; // 12(3)000 ----> 123000( )
|
|
243
|
+
/* Compute various sub-ranges */
|
|
244
|
+
const nSign = (signNeeded ? 1 : 0); // (-)123.456
|
|
245
|
+
const nBeforeDot = (nSign + (afterDot - readStart)); // (-123).456
|
|
246
|
+
const nAfterDot = Math.max(readEnd - afterDot, 0); // -123.(456)
|
|
247
|
+
const actualLength = (readEnd - readStart); // -(123.456)
|
|
248
|
+
const desiredLength = (paddingMode === NO_PADDING)
|
|
249
|
+
? (actualLength) // -(123.456)
|
|
250
|
+
: (precisionEnd - readStart); // -(123.456 )
|
|
251
|
+
const pad = Math.max(desiredLength - actualLength, 0); // -123.456( )
|
|
252
|
+
const padStart = (nBeforeDot + 1 + nAfterDot); // -123.456( )
|
|
253
|
+
const padEnd = (padStart + pad); // -123.456 ( )
|
|
254
|
+
const isInteger = (nAfterDot + pad) === 0; // -123
|
|
255
|
+
/* Fill the output buffer with characters */
|
|
256
|
+
const out = new Uint8Array(nBeforeDot + (isInteger ? 0 : 1) + nAfterDot + pad);
|
|
257
|
+
// ------------------------------------------------------------------------------------------ // ---------------------
|
|
258
|
+
if (signNeeded)
|
|
259
|
+
out[0] = MINUS; // - minus sign
|
|
260
|
+
for (i = nSign, j = readStart; i < nBeforeDot; i++, j++)
|
|
261
|
+
out[i] = chars[j]; // 123 before dot
|
|
262
|
+
if (!isInteger)
|
|
263
|
+
out[nBeforeDot] = DOT; // . dot
|
|
264
|
+
for (i = nBeforeDot + 1, j = afterDot; i < padStart; i++, j++)
|
|
265
|
+
out[i] = chars[j]; // 456 after dot
|
|
266
|
+
for (i = padStart; i < padEnd; i++)
|
|
267
|
+
out[i] = ZERO; // 000 padding
|
|
268
|
+
/* Build a string from the output buffer */
|
|
269
|
+
return String.fromCharCode(...out);
|
|
270
|
+
};
|
|
271
|
+
function omitZero(stringNumber) {
|
|
272
|
+
if (stringNumber === undefined || stringNumber === '') {
|
|
273
|
+
return undefined;
|
|
274
|
+
}
|
|
275
|
+
if (parseFloat(stringNumber) === 0) {
|
|
276
|
+
return undefined;
|
|
277
|
+
}
|
|
278
|
+
return stringNumber;
|
|
279
|
+
}
|
|
280
|
+
/* ------------------------------------------------------------------------ */
|
|
281
|
+
|
|
282
|
+
exports.DECIMAL_PLACES = DECIMAL_PLACES;
|
|
283
|
+
exports.NO_PADDING = NO_PADDING;
|
|
284
|
+
exports.PAD_WITH_ZERO = PAD_WITH_ZERO;
|
|
285
|
+
exports.ROUND = ROUND;
|
|
286
|
+
exports.ROUND_DOWN = ROUND_DOWN;
|
|
287
|
+
exports.ROUND_UP = ROUND_UP;
|
|
288
|
+
exports.SIGNIFICANT_DIGITS = SIGNIFICANT_DIGITS;
|
|
289
|
+
exports.TICK_SIZE = TICK_SIZE;
|
|
290
|
+
exports.TRUNCATE = TRUNCATE;
|
|
291
|
+
exports.decimalToPrecision = decimalToPrecision;
|
|
292
|
+
exports.numberToString = numberToString;
|
|
293
|
+
exports.omitZero = omitZero;
|
|
294
|
+
exports.precisionConstants = precisionConstants;
|
|
295
|
+
exports.precisionFromString = precisionFromString;
|
|
296
|
+
exports.truncate = truncate;
|
|
297
|
+
exports.truncate_to_string = truncate_to_string;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
// @ts-nocheck
|
|
6
|
+
// ----------------------------------------------------------------------------
|
|
7
|
+
// There's been a lot of messing with this code...
|
|
8
|
+
// The problem is to satisfy the following requirements:
|
|
9
|
+
// - properly detect isNode == true on server side and isNode == false in the browser (on client side)
|
|
10
|
+
// - make sure create-react-app, react-starter-kit and other react frameworks work
|
|
11
|
+
// - make sure it does not break the browserified version (when linked into a html from a cdn)
|
|
12
|
+
// - make sure it does not break the webpacking and babel-transpiled scripts
|
|
13
|
+
// - make sure it works in Electron
|
|
14
|
+
// - make sure it works with Angular.js
|
|
15
|
+
// - make sure it does not break other possible usage scenarios
|
|
16
|
+
const isBrowser = typeof window !== 'undefined';
|
|
17
|
+
const isElectron = typeof process !== 'undefined' &&
|
|
18
|
+
typeof process.versions !== 'undefined' &&
|
|
19
|
+
typeof process.versions.electron !== 'undefined';
|
|
20
|
+
const isWebWorker = typeof WorkerGlobalScope !== 'undefined' && (self instanceof WorkerGlobalScope);
|
|
21
|
+
const isWindows = typeof process !== 'undefined' && process.platform === "win32";
|
|
22
|
+
const isNode = !(isBrowser || isWebWorker);
|
|
23
|
+
|
|
24
|
+
exports.isBrowser = isBrowser;
|
|
25
|
+
exports.isElectron = isElectron;
|
|
26
|
+
exports.isNode = isNode;
|
|
27
|
+
exports.isWebWorker = isWebWorker;
|
|
28
|
+
exports.isWindows = isWindows;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var JSEncrypt = require('../../static_dependencies/jsencrypt/JSEncrypt.js');
|
|
6
|
+
var index = require('../../static_dependencies/scure-base/index.js');
|
|
7
|
+
var encode = require('./encode.js');
|
|
8
|
+
var crypto = require('./crypto.js');
|
|
9
|
+
|
|
10
|
+
function rsa(request, secret, hash) {
|
|
11
|
+
const RSA = new JSEncrypt.JSEncrypt();
|
|
12
|
+
const digester = (input) => index.base16.encode(hash(input));
|
|
13
|
+
RSA.setPrivateKey(secret);
|
|
14
|
+
const name = (hash.create()).constructor.name.toLowerCase();
|
|
15
|
+
return RSA.sign(request, digester, name);
|
|
16
|
+
}
|
|
17
|
+
function jwt(request, secret, hash, isRSA = false) {
|
|
18
|
+
const alg = (isRSA ? 'RS' : 'HS') + (hash.outputLen * 8);
|
|
19
|
+
const encodedHeader = encode.urlencodeBase64(encode.stringToBase64(JSON.stringify({ 'alg': alg, 'typ': 'JWT' })));
|
|
20
|
+
const encodedData = encode.urlencodeBase64(encode.stringToBase64(JSON.stringify(request)));
|
|
21
|
+
const token = [encodedHeader, encodedData].join('.');
|
|
22
|
+
const algoType = alg.slice(0, 2);
|
|
23
|
+
let signature = undefined;
|
|
24
|
+
if (algoType === 'HS') {
|
|
25
|
+
signature = encode.urlencodeBase64(crypto.hmac(token, secret, hash, 'base64'));
|
|
26
|
+
}
|
|
27
|
+
else if (algoType === 'RS') {
|
|
28
|
+
signature = encode.urlencodeBase64(rsa(token, index.utf8.encode(secret), hash));
|
|
29
|
+
}
|
|
30
|
+
return [token, signature].join('.');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
exports.jwt = jwt;
|
|
34
|
+
exports.rsa = rsa;
|