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,401 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
// DEFLATE is a complex format; to read this code, you should probably check the RFC first:
|
|
6
|
+
// aliases for shorter compressed code (most minifers don't do this)
|
|
7
|
+
var u8 = Uint8Array, u16 = Uint16Array, u32 = Uint32Array;
|
|
8
|
+
// fixed length extra bits
|
|
9
|
+
var fleb = new u8([0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, /* unused */ 0, 0, /* impossible */ 0]);
|
|
10
|
+
// fixed distance extra bits
|
|
11
|
+
// see fleb note
|
|
12
|
+
var fdeb = new u8([0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, /* unused */ 0, 0]);
|
|
13
|
+
// code length index map
|
|
14
|
+
var clim = new u8([16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]);
|
|
15
|
+
// get base, reverse index map from extra bits
|
|
16
|
+
var freb = function (eb, start) {
|
|
17
|
+
var b = new u16(31);
|
|
18
|
+
for (var i = 0; i < 31; ++i) {
|
|
19
|
+
b[i] = start += 1 << eb[i - 1];
|
|
20
|
+
}
|
|
21
|
+
// numbers here are at max 18 bits
|
|
22
|
+
var r = new u32(b[30]);
|
|
23
|
+
for (var i = 1; i < 30; ++i) {
|
|
24
|
+
for (var j = b[i]; j < b[i + 1]; ++j) {
|
|
25
|
+
r[j] = ((j - b[i]) << 5) | i;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return [b, r];
|
|
29
|
+
};
|
|
30
|
+
var _a = freb(fleb, 2), fl = _a[0], revfl = _a[1];
|
|
31
|
+
// we can ignore the fact that the other numbers are wrong; they never happen anyway
|
|
32
|
+
fl[28] = 258, revfl[258] = 28;
|
|
33
|
+
var _b = freb(fdeb, 0), fd = _b[0];
|
|
34
|
+
// map of value to reverse (assuming 16 bits)
|
|
35
|
+
var rev = new u16(32768);
|
|
36
|
+
for (var i = 0; i < 32768; ++i) {
|
|
37
|
+
// reverse table algorithm from SO
|
|
38
|
+
var x = ((i & 0xAAAA) >>> 1) | ((i & 0x5555) << 1);
|
|
39
|
+
x = ((x & 0xCCCC) >>> 2) | ((x & 0x3333) << 2);
|
|
40
|
+
x = ((x & 0xF0F0) >>> 4) | ((x & 0x0F0F) << 4);
|
|
41
|
+
rev[i] = (((x & 0xFF00) >>> 8) | ((x & 0x00FF) << 8)) >>> 1;
|
|
42
|
+
}
|
|
43
|
+
// create huffman tree from u8 "map": index -> code length for code index
|
|
44
|
+
// mb (max bits) must be at most 15
|
|
45
|
+
// TODO: optimize/split up?
|
|
46
|
+
var hMap = (function (cd, mb, r) {
|
|
47
|
+
var s = cd.length;
|
|
48
|
+
// index
|
|
49
|
+
var i = 0;
|
|
50
|
+
// u16 "map": index -> # of codes with bit length = index
|
|
51
|
+
var l = new u16(mb);
|
|
52
|
+
// length of cd must be 288 (total # of codes)
|
|
53
|
+
for (; i < s; ++i) {
|
|
54
|
+
if (cd[i])
|
|
55
|
+
++l[cd[i] - 1];
|
|
56
|
+
}
|
|
57
|
+
// u16 "map": index -> minimum code for bit length = index
|
|
58
|
+
var le = new u16(mb);
|
|
59
|
+
for (i = 0; i < mb; ++i) {
|
|
60
|
+
le[i] = (le[i - 1] + l[i - 1]) << 1;
|
|
61
|
+
}
|
|
62
|
+
var co;
|
|
63
|
+
if (r) {
|
|
64
|
+
// u16 "map": index -> number of actual bits, symbol for code
|
|
65
|
+
co = new u16(1 << mb);
|
|
66
|
+
// bits to remove for reverser
|
|
67
|
+
var rvb = 15 - mb;
|
|
68
|
+
for (i = 0; i < s; ++i) {
|
|
69
|
+
// ignore 0 lengths
|
|
70
|
+
if (cd[i]) {
|
|
71
|
+
// num encoding both symbol and bits read
|
|
72
|
+
var sv = (i << 4) | cd[i];
|
|
73
|
+
// free bits
|
|
74
|
+
var r_1 = mb - cd[i];
|
|
75
|
+
// start value
|
|
76
|
+
var v = le[cd[i] - 1]++ << r_1;
|
|
77
|
+
// m is end value
|
|
78
|
+
for (var m = v | ((1 << r_1) - 1); v <= m; ++v) {
|
|
79
|
+
// every 16 bit value starting with the code yields the same result
|
|
80
|
+
co[rev[v] >>> rvb] = sv;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
co = new u16(s);
|
|
87
|
+
for (i = 0; i < s; ++i) {
|
|
88
|
+
if (cd[i]) {
|
|
89
|
+
co[i] = rev[le[cd[i] - 1]++] >>> (15 - cd[i]);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return co;
|
|
94
|
+
});
|
|
95
|
+
// fixed length tree
|
|
96
|
+
var flt = new u8(288);
|
|
97
|
+
for (var i = 0; i < 144; ++i)
|
|
98
|
+
flt[i] = 8;
|
|
99
|
+
for (var i = 144; i < 256; ++i)
|
|
100
|
+
flt[i] = 9;
|
|
101
|
+
for (var i = 256; i < 280; ++i)
|
|
102
|
+
flt[i] = 7;
|
|
103
|
+
for (var i = 280; i < 288; ++i)
|
|
104
|
+
flt[i] = 8;
|
|
105
|
+
// fixed distance tree
|
|
106
|
+
var fdt = new u8(32);
|
|
107
|
+
for (var i = 0; i < 32; ++i)
|
|
108
|
+
fdt[i] = 5;
|
|
109
|
+
// fixed length map
|
|
110
|
+
var flrm = /*#__PURE__*/ hMap(flt, 9, 1);
|
|
111
|
+
// fixed distance map
|
|
112
|
+
var fdrm = /*#__PURE__*/ hMap(fdt, 5, 1);
|
|
113
|
+
// find max of array
|
|
114
|
+
var max = function (a) {
|
|
115
|
+
var m = a[0];
|
|
116
|
+
for (var i = 1; i < a.length; ++i) {
|
|
117
|
+
if (a[i] > m)
|
|
118
|
+
m = a[i];
|
|
119
|
+
}
|
|
120
|
+
return m;
|
|
121
|
+
};
|
|
122
|
+
// read d, starting at bit p and mask with m
|
|
123
|
+
var bits = function (d, p, m) {
|
|
124
|
+
var o = (p / 8) | 0;
|
|
125
|
+
return ((d[o] | (d[o + 1] << 8)) >> (p & 7)) & m;
|
|
126
|
+
};
|
|
127
|
+
// read d, starting at bit p continuing for at least 16 bits
|
|
128
|
+
var bits16 = function (d, p) {
|
|
129
|
+
var o = (p / 8) | 0;
|
|
130
|
+
return ((d[o] | (d[o + 1] << 8) | (d[o + 2] << 16)) >> (p & 7));
|
|
131
|
+
};
|
|
132
|
+
// get end of byte
|
|
133
|
+
var shft = function (p) { return ((p + 7) / 8) | 0; };
|
|
134
|
+
// typed array slice - allows garbage collector to free original reference,
|
|
135
|
+
// while being more compatible than .slice
|
|
136
|
+
var slc = function (v, s, e) {
|
|
137
|
+
if (s == null || s < 0)
|
|
138
|
+
s = 0;
|
|
139
|
+
if (e == null || e > v.length)
|
|
140
|
+
e = v.length;
|
|
141
|
+
// can't use .constructor in case user-supplied
|
|
142
|
+
var n = new (v.BYTES_PER_ELEMENT == 2 ? u16 : v.BYTES_PER_ELEMENT == 4 ? u32 : u8)(e - s);
|
|
143
|
+
n.set(v.subarray(s, e));
|
|
144
|
+
return n;
|
|
145
|
+
};
|
|
146
|
+
// error codes
|
|
147
|
+
var ec = [
|
|
148
|
+
'unexpected EOF',
|
|
149
|
+
'invalid block type',
|
|
150
|
+
'invalid length/literal',
|
|
151
|
+
'invalid distance',
|
|
152
|
+
'stream finished',
|
|
153
|
+
'no stream handler',
|
|
154
|
+
,
|
|
155
|
+
'no callback',
|
|
156
|
+
'invalid UTF-8 data',
|
|
157
|
+
'extra field too long',
|
|
158
|
+
'date not in range 1980-2099',
|
|
159
|
+
'filename too long',
|
|
160
|
+
'stream finishing',
|
|
161
|
+
'invalid zip data'
|
|
162
|
+
// determined by unknown compression method
|
|
163
|
+
];
|
|
164
|
+
var err = function (ind, msg, nt) {
|
|
165
|
+
var e = new Error(msg || ec[ind]);
|
|
166
|
+
e.code = ind;
|
|
167
|
+
if (Error.captureStackTrace)
|
|
168
|
+
Error.captureStackTrace(e, err);
|
|
169
|
+
if (!nt)
|
|
170
|
+
throw e;
|
|
171
|
+
return e;
|
|
172
|
+
};
|
|
173
|
+
// expands raw DEFLATE data
|
|
174
|
+
var inflt = function (dat, buf, st) {
|
|
175
|
+
// source length
|
|
176
|
+
var sl = dat.length;
|
|
177
|
+
if (!sl || (st && st.f && !st.l))
|
|
178
|
+
return buf || new u8(0);
|
|
179
|
+
// have to estimate size
|
|
180
|
+
var noBuf = !buf || st;
|
|
181
|
+
// no state
|
|
182
|
+
var noSt = !st || st.i;
|
|
183
|
+
if (!st)
|
|
184
|
+
st = {};
|
|
185
|
+
// Assumes roughly 33% compression ratio average
|
|
186
|
+
if (!buf)
|
|
187
|
+
buf = new u8(sl * 3);
|
|
188
|
+
// ensure buffer can fit at least l elements
|
|
189
|
+
var cbuf = function (l) {
|
|
190
|
+
var bl = buf.length;
|
|
191
|
+
// need to increase size to fit
|
|
192
|
+
if (l > bl) {
|
|
193
|
+
// Double or set to necessary, whichever is greater
|
|
194
|
+
var nbuf = new u8(Math.max(bl * 2, l));
|
|
195
|
+
nbuf.set(buf);
|
|
196
|
+
buf = nbuf;
|
|
197
|
+
}
|
|
198
|
+
};
|
|
199
|
+
// last chunk bitpos bytes
|
|
200
|
+
var final = st.f || 0, pos = st.p || 0, bt = st.b || 0, lm = st.l, dm = st.d, lbt = st.m, dbt = st.n;
|
|
201
|
+
// total bits
|
|
202
|
+
var tbts = sl * 8;
|
|
203
|
+
do {
|
|
204
|
+
if (!lm) {
|
|
205
|
+
// BFINAL - this is only 1 when last chunk is next
|
|
206
|
+
final = bits(dat, pos, 1);
|
|
207
|
+
// type: 0 = no compression, 1 = fixed huffman, 2 = dynamic huffman
|
|
208
|
+
var type = bits(dat, pos + 1, 3);
|
|
209
|
+
pos += 3;
|
|
210
|
+
if (!type) {
|
|
211
|
+
// go to end of byte boundary
|
|
212
|
+
var s = shft(pos) + 4, l = dat[s - 4] | (dat[s - 3] << 8), t = s + l;
|
|
213
|
+
if (t > sl) {
|
|
214
|
+
if (noSt)
|
|
215
|
+
err(0);
|
|
216
|
+
break;
|
|
217
|
+
}
|
|
218
|
+
// ensure size
|
|
219
|
+
if (noBuf)
|
|
220
|
+
cbuf(bt + l);
|
|
221
|
+
// Copy over uncompressed data
|
|
222
|
+
buf.set(dat.subarray(s, t), bt);
|
|
223
|
+
// Get new bitpos, update byte count
|
|
224
|
+
st.b = bt += l, st.p = pos = t * 8, st.f = final;
|
|
225
|
+
continue;
|
|
226
|
+
}
|
|
227
|
+
else if (type == 1)
|
|
228
|
+
lm = flrm, dm = fdrm, lbt = 9, dbt = 5;
|
|
229
|
+
else if (type == 2) {
|
|
230
|
+
// literal lengths
|
|
231
|
+
var hLit = bits(dat, pos, 31) + 257, hcLen = bits(dat, pos + 10, 15) + 4;
|
|
232
|
+
var tl = hLit + bits(dat, pos + 5, 31) + 1;
|
|
233
|
+
pos += 14;
|
|
234
|
+
// length+distance tree
|
|
235
|
+
var ldt = new u8(tl);
|
|
236
|
+
// code length tree
|
|
237
|
+
var clt = new u8(19);
|
|
238
|
+
for (var i = 0; i < hcLen; ++i) {
|
|
239
|
+
// use index map to get real code
|
|
240
|
+
clt[clim[i]] = bits(dat, pos + i * 3, 7);
|
|
241
|
+
}
|
|
242
|
+
pos += hcLen * 3;
|
|
243
|
+
// code lengths bits
|
|
244
|
+
var clb = max(clt), clbmsk = (1 << clb) - 1;
|
|
245
|
+
// code lengths map
|
|
246
|
+
var clm = hMap(clt, clb, 1);
|
|
247
|
+
for (var i = 0; i < tl;) {
|
|
248
|
+
var r = clm[bits(dat, pos, clbmsk)];
|
|
249
|
+
// bits read
|
|
250
|
+
pos += r & 15;
|
|
251
|
+
// symbol
|
|
252
|
+
var s = r >>> 4;
|
|
253
|
+
// code length to copy
|
|
254
|
+
if (s < 16) {
|
|
255
|
+
ldt[i++] = s;
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
// copy count
|
|
259
|
+
var c = 0, n = 0;
|
|
260
|
+
if (s == 16)
|
|
261
|
+
n = 3 + bits(dat, pos, 3), pos += 2, c = ldt[i - 1];
|
|
262
|
+
else if (s == 17)
|
|
263
|
+
n = 3 + bits(dat, pos, 7), pos += 3;
|
|
264
|
+
else if (s == 18)
|
|
265
|
+
n = 11 + bits(dat, pos, 127), pos += 7;
|
|
266
|
+
while (n--)
|
|
267
|
+
ldt[i++] = c;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
// length tree distance tree
|
|
271
|
+
var lt = ldt.subarray(0, hLit), dt = ldt.subarray(hLit);
|
|
272
|
+
// max length bits
|
|
273
|
+
lbt = max(lt);
|
|
274
|
+
// max dist bits
|
|
275
|
+
dbt = max(dt);
|
|
276
|
+
lm = hMap(lt, lbt, 1);
|
|
277
|
+
dm = hMap(dt, dbt, 1);
|
|
278
|
+
}
|
|
279
|
+
else
|
|
280
|
+
err(1);
|
|
281
|
+
if (pos > tbts) {
|
|
282
|
+
if (noSt)
|
|
283
|
+
err(0);
|
|
284
|
+
break;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
// Make sure the buffer can hold this + the largest possible addition
|
|
288
|
+
// Maximum chunk size (practically, theoretically infinite) is 2^17;
|
|
289
|
+
if (noBuf)
|
|
290
|
+
cbuf(bt + 131072);
|
|
291
|
+
var lms = (1 << lbt) - 1, dms = (1 << dbt) - 1;
|
|
292
|
+
var lpos = pos;
|
|
293
|
+
for (;; lpos = pos) {
|
|
294
|
+
// bits read, code
|
|
295
|
+
var c = lm[bits16(dat, pos) & lms], sym = c >>> 4;
|
|
296
|
+
pos += c & 15;
|
|
297
|
+
if (pos > tbts) {
|
|
298
|
+
if (noSt)
|
|
299
|
+
err(0);
|
|
300
|
+
break;
|
|
301
|
+
}
|
|
302
|
+
if (!c)
|
|
303
|
+
err(2);
|
|
304
|
+
if (sym < 256)
|
|
305
|
+
buf[bt++] = sym;
|
|
306
|
+
else if (sym == 256) {
|
|
307
|
+
lpos = pos, lm = null;
|
|
308
|
+
break;
|
|
309
|
+
}
|
|
310
|
+
else {
|
|
311
|
+
var add = sym - 254;
|
|
312
|
+
// no extra bits needed if less
|
|
313
|
+
if (sym > 264) {
|
|
314
|
+
// index
|
|
315
|
+
var i = sym - 257, b = fleb[i];
|
|
316
|
+
add = bits(dat, pos, (1 << b) - 1) + fl[i];
|
|
317
|
+
pos += b;
|
|
318
|
+
}
|
|
319
|
+
// dist
|
|
320
|
+
var d = dm[bits16(dat, pos) & dms], dsym = d >>> 4;
|
|
321
|
+
if (!d)
|
|
322
|
+
err(3);
|
|
323
|
+
pos += d & 15;
|
|
324
|
+
var dt = fd[dsym];
|
|
325
|
+
if (dsym > 3) {
|
|
326
|
+
var b = fdeb[dsym];
|
|
327
|
+
dt += bits16(dat, pos) & ((1 << b) - 1), pos += b;
|
|
328
|
+
}
|
|
329
|
+
if (pos > tbts) {
|
|
330
|
+
if (noSt)
|
|
331
|
+
err(0);
|
|
332
|
+
break;
|
|
333
|
+
}
|
|
334
|
+
if (noBuf)
|
|
335
|
+
cbuf(bt + 131072);
|
|
336
|
+
var end = bt + add;
|
|
337
|
+
for (; bt < end; bt += 4) {
|
|
338
|
+
buf[bt] = buf[bt - dt];
|
|
339
|
+
buf[bt + 1] = buf[bt + 1 - dt];
|
|
340
|
+
buf[bt + 2] = buf[bt + 2 - dt];
|
|
341
|
+
buf[bt + 3] = buf[bt + 3 - dt];
|
|
342
|
+
}
|
|
343
|
+
bt = end;
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
st.l = lm, st.p = lpos, st.b = bt, st.f = final;
|
|
347
|
+
if (lm)
|
|
348
|
+
final = 1, st.m = lbt, st.d = dm, st.n = dbt;
|
|
349
|
+
} while (!final);
|
|
350
|
+
return bt == buf.length ? buf : slc(buf, 0, bt);
|
|
351
|
+
};
|
|
352
|
+
// empty
|
|
353
|
+
var et = /*#__PURE__*/ new u8(0);
|
|
354
|
+
// gzip footer: -8 to -4 = CRC, -4 to -0 is length
|
|
355
|
+
// gzip start
|
|
356
|
+
var gzs = function (d) {
|
|
357
|
+
if (d[0] != 31 || d[1] != 139 || d[2] != 8)
|
|
358
|
+
err(6, 'invalid gzip data');
|
|
359
|
+
var flg = d[3];
|
|
360
|
+
var st = 10;
|
|
361
|
+
if (flg & 4)
|
|
362
|
+
st += d[10] | (d[11] << 8) + 2;
|
|
363
|
+
for (var zs = (flg >> 3 & 1) + (flg >> 4 & 1); zs > 0; zs -= !d[st++])
|
|
364
|
+
;
|
|
365
|
+
return st + (flg & 2);
|
|
366
|
+
};
|
|
367
|
+
// gzip length
|
|
368
|
+
var gzl = function (d) {
|
|
369
|
+
var l = d.length;
|
|
370
|
+
return ((d[l - 4] | d[l - 3] << 8 | d[l - 2] << 16) | (d[l - 1] << 24)) >>> 0;
|
|
371
|
+
};
|
|
372
|
+
/**
|
|
373
|
+
* Expands DEFLATE data with no wrapper
|
|
374
|
+
* @param data The data to decompress
|
|
375
|
+
* @param out Where to write the data. Saves memory if you know the decompressed size and provide an output buffer of that length.
|
|
376
|
+
* @returns The decompressed version of the data
|
|
377
|
+
*/
|
|
378
|
+
function inflateSync(data, out = undefined) {
|
|
379
|
+
return inflt(data, out);
|
|
380
|
+
}
|
|
381
|
+
/**
|
|
382
|
+
* Expands GZIP data
|
|
383
|
+
* @param data The data to decompress
|
|
384
|
+
* @param out Where to write the data. GZIP already encodes the output size, so providing this doesn't save memory.
|
|
385
|
+
* @returns The decompressed version of the data
|
|
386
|
+
*/
|
|
387
|
+
function gunzipSync(data, out = undefined) {
|
|
388
|
+
return inflt(data.subarray(gzs(data), -8), out || new u8(gzl(data)));
|
|
389
|
+
}
|
|
390
|
+
// text decoder
|
|
391
|
+
var td = typeof TextDecoder != 'undefined' && /*#__PURE__*/ new TextDecoder();
|
|
392
|
+
// text decoder stream
|
|
393
|
+
var tds = 0;
|
|
394
|
+
try {
|
|
395
|
+
td.decode(et, { stream: true });
|
|
396
|
+
tds = 1;
|
|
397
|
+
}
|
|
398
|
+
catch (e) { }
|
|
399
|
+
|
|
400
|
+
exports.gunzipSync = gunzipSync;
|
|
401
|
+
exports.inflateSync = inflateSync;
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var base64 = require('./lib/jsbn/base64.js');
|
|
6
|
+
var JSEncryptRSAKey = require('./JSEncryptRSAKey.js');
|
|
7
|
+
|
|
8
|
+
const version = typeof process !== 'undefined'
|
|
9
|
+
? process.env?.npm_package_version
|
|
10
|
+
: undefined;
|
|
11
|
+
/**
|
|
12
|
+
*
|
|
13
|
+
* @param {object} [options = {}] - An object to customize JSEncrypt behaviour
|
|
14
|
+
* possible parameters are:
|
|
15
|
+
* - default_key_size {number} default: 1024 the key size in bit
|
|
16
|
+
* - default_public_exponent {string} default: '010001' the hexadecimal representation of the public exponent
|
|
17
|
+
* - log {boolean} default: false whether log warn/error or not
|
|
18
|
+
* @constructor
|
|
19
|
+
*/
|
|
20
|
+
class JSEncrypt {
|
|
21
|
+
constructor(options = {}) {
|
|
22
|
+
options = options || {};
|
|
23
|
+
this.default_key_size = options.default_key_size
|
|
24
|
+
? parseInt(options.default_key_size, 10)
|
|
25
|
+
: 1024;
|
|
26
|
+
this.default_public_exponent = options.default_public_exponent || "010001"; // 65537 default openssl public exponent for rsa key type
|
|
27
|
+
this.log = options.log || false;
|
|
28
|
+
// The private and public key.
|
|
29
|
+
this.key = null;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Method to set the rsa key parameter (one method is enough to set both the public
|
|
33
|
+
* and the private key, since the private key contains the public key paramenters)
|
|
34
|
+
* Log a warning if logs are enabled
|
|
35
|
+
* @param {Object|string} key the pem encoded string or an object (with or without header/footer)
|
|
36
|
+
* @public
|
|
37
|
+
*/
|
|
38
|
+
setKey(key) {
|
|
39
|
+
if (this.log && this.key) {
|
|
40
|
+
console.warn("A key was already set, overriding existing.");
|
|
41
|
+
}
|
|
42
|
+
this.key = new JSEncryptRSAKey.JSEncryptRSAKey(key);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Proxy method for setKey, for api compatibility
|
|
46
|
+
* @see setKey
|
|
47
|
+
* @public
|
|
48
|
+
*/
|
|
49
|
+
setPrivateKey(privkey) {
|
|
50
|
+
// Create the key.
|
|
51
|
+
this.setKey(privkey);
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Proxy method for setKey, for api compatibility
|
|
55
|
+
* @see setKey
|
|
56
|
+
* @public
|
|
57
|
+
*/
|
|
58
|
+
setPublicKey(pubkey) {
|
|
59
|
+
// Sets the public key.
|
|
60
|
+
this.setKey(pubkey);
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Proxy method for RSAKey object's decrypt, decrypt the string using the private
|
|
64
|
+
* components of the rsa key object. Note that if the object was not set will be created
|
|
65
|
+
* on the fly (by the getKey method) using the parameters passed in the JSEncrypt constructor
|
|
66
|
+
* @param {string} str base64 encoded crypted string to decrypt
|
|
67
|
+
* @return {string} the decrypted string
|
|
68
|
+
* @public
|
|
69
|
+
*/
|
|
70
|
+
decrypt(str) {
|
|
71
|
+
// Return the decrypted string.
|
|
72
|
+
try {
|
|
73
|
+
return this.getKey().decrypt(base64.b64tohex(str));
|
|
74
|
+
}
|
|
75
|
+
catch (ex) {
|
|
76
|
+
return false;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Proxy method for RSAKey object's encrypt, encrypt the string using the public
|
|
81
|
+
* components of the rsa key object. Note that if the object was not set will be created
|
|
82
|
+
* on the fly (by the getKey method) using the parameters passed in the JSEncrypt constructor
|
|
83
|
+
* @param {string} str the string to encrypt
|
|
84
|
+
* @return {string} the encrypted string encoded in base64
|
|
85
|
+
* @public
|
|
86
|
+
*/
|
|
87
|
+
encrypt(str) {
|
|
88
|
+
// Return the encrypted string.
|
|
89
|
+
try {
|
|
90
|
+
return base64.hex2b64(this.getKey().encrypt(str));
|
|
91
|
+
}
|
|
92
|
+
catch (ex) {
|
|
93
|
+
return false;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Proxy method for RSAKey object's sign.
|
|
98
|
+
* @param {string} str the string to sign
|
|
99
|
+
* @param {function} digestMethod hash method
|
|
100
|
+
* @param {string} digestName the name of the hash algorithm
|
|
101
|
+
* @return {string} the signature encoded in base64
|
|
102
|
+
* @public
|
|
103
|
+
*/
|
|
104
|
+
sign(str, digestMethod, digestName) {
|
|
105
|
+
// return the RSA signature of 'str' in 'hex' format.
|
|
106
|
+
try {
|
|
107
|
+
return base64.hex2b64(this.getKey().sign(str, digestMethod, digestName));
|
|
108
|
+
}
|
|
109
|
+
catch (ex) {
|
|
110
|
+
return false;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Proxy method for RSAKey object's verify.
|
|
115
|
+
* @param {string} str the string to verify
|
|
116
|
+
* @param {string} signature the signature encoded in base64 to compare the string to
|
|
117
|
+
* @param {function} digestMethod hash method
|
|
118
|
+
* @return {boolean} whether the data and signature match
|
|
119
|
+
* @public
|
|
120
|
+
*/
|
|
121
|
+
verify(str, signature, digestMethod) {
|
|
122
|
+
// Return the decrypted 'digest' of the signature.
|
|
123
|
+
try {
|
|
124
|
+
return this.getKey().verify(str, base64.b64tohex(signature), digestMethod);
|
|
125
|
+
}
|
|
126
|
+
catch (ex) {
|
|
127
|
+
return false;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Getter for the current JSEncryptRSAKey object. If it doesn't exists a new object
|
|
132
|
+
* will be created and returned
|
|
133
|
+
* @param {callback} [cb] the callback to be called if we want the key to be generated
|
|
134
|
+
* in an async fashion
|
|
135
|
+
* @returns {JSEncryptRSAKey} the JSEncryptRSAKey object
|
|
136
|
+
* @public
|
|
137
|
+
*/
|
|
138
|
+
getKey(cb) {
|
|
139
|
+
// Only create new if it does not exist.
|
|
140
|
+
if (!this.key) {
|
|
141
|
+
// Get a new private key.
|
|
142
|
+
this.key = new JSEncryptRSAKey.JSEncryptRSAKey();
|
|
143
|
+
if (cb && {}.toString.call(cb) === "[object Function]") {
|
|
144
|
+
this.key.generateAsync(this.default_key_size, this.default_public_exponent, cb);
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
// Generate the key.
|
|
148
|
+
this.key.generate(this.default_key_size, this.default_public_exponent);
|
|
149
|
+
}
|
|
150
|
+
return this.key;
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Returns the pem encoded representation of the private key
|
|
154
|
+
* If the key doesn't exists a new key will be created
|
|
155
|
+
* @returns {string} pem encoded representation of the private key WITH header and footer
|
|
156
|
+
* @public
|
|
157
|
+
*/
|
|
158
|
+
getPrivateKey() {
|
|
159
|
+
// Return the private representation of this key.
|
|
160
|
+
return this.getKey().getPrivateKey();
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Returns the pem encoded representation of the private key
|
|
164
|
+
* If the key doesn't exists a new key will be created
|
|
165
|
+
* @returns {string} pem encoded representation of the private key WITHOUT header and footer
|
|
166
|
+
* @public
|
|
167
|
+
*/
|
|
168
|
+
getPrivateKeyB64() {
|
|
169
|
+
// Return the private representation of this key.
|
|
170
|
+
return this.getKey().getPrivateBaseKeyB64();
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Returns the pem encoded representation of the public key
|
|
174
|
+
* If the key doesn't exists a new key will be created
|
|
175
|
+
* @returns {string} pem encoded representation of the public key WITH header and footer
|
|
176
|
+
* @public
|
|
177
|
+
*/
|
|
178
|
+
getPublicKey() {
|
|
179
|
+
// Return the private representation of this key.
|
|
180
|
+
return this.getKey().getPublicKey();
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Returns the pem encoded representation of the public key
|
|
184
|
+
* If the key doesn't exists a new key will be created
|
|
185
|
+
* @returns {string} pem encoded representation of the public key WITHOUT header and footer
|
|
186
|
+
* @public
|
|
187
|
+
*/
|
|
188
|
+
getPublicKeyB64() {
|
|
189
|
+
// Return the private representation of this key.
|
|
190
|
+
return this.getKey().getPublicBaseKeyB64();
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
JSEncrypt.version = version;
|
|
194
|
+
|
|
195
|
+
exports.JSEncrypt = JSEncrypt;
|