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,354 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var Stream = require('node:stream');
|
|
6
|
+
var node_util = require('node:util');
|
|
7
|
+
var node_buffer = require('node:buffer');
|
|
8
|
+
var fetchError = require('./errors/fetch-error.js');
|
|
9
|
+
var base = require('./errors/base.js');
|
|
10
|
+
var is = require('./utils/is.js');
|
|
11
|
+
|
|
12
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
13
|
+
|
|
14
|
+
var Stream__default = /*#__PURE__*/_interopDefaultLegacy(Stream);
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Body.js
|
|
18
|
+
*
|
|
19
|
+
* Body interface provides common methods for Request and Response
|
|
20
|
+
*/
|
|
21
|
+
const pipeline = node_util.promisify(Stream__default["default"].pipeline);
|
|
22
|
+
const INTERNALS = Symbol('Body internals');
|
|
23
|
+
/**
|
|
24
|
+
* Body mixin
|
|
25
|
+
*
|
|
26
|
+
* Ref: https://fetch.spec.whatwg.org/#body
|
|
27
|
+
*
|
|
28
|
+
* @param Stream body Readable stream
|
|
29
|
+
* @param Object opts Response options
|
|
30
|
+
* @return Void
|
|
31
|
+
*/
|
|
32
|
+
class Body {
|
|
33
|
+
constructor(body, { size = 0 } = {}) {
|
|
34
|
+
let boundary = null;
|
|
35
|
+
if (body === null) {
|
|
36
|
+
// Body is undefined or null
|
|
37
|
+
body = null;
|
|
38
|
+
}
|
|
39
|
+
else if (is.isURLSearchParameters(body)) {
|
|
40
|
+
// Body is a URLSearchParams
|
|
41
|
+
body = node_buffer.Buffer.from(body.toString());
|
|
42
|
+
}
|
|
43
|
+
else if (is.isBlob(body)) ;
|
|
44
|
+
else if (node_buffer.Buffer.isBuffer(body)) ;
|
|
45
|
+
else if (node_util.types.isAnyArrayBuffer(body)) {
|
|
46
|
+
// Body is ArrayBuffer
|
|
47
|
+
body = node_buffer.Buffer.from(body);
|
|
48
|
+
}
|
|
49
|
+
else if (ArrayBuffer.isView(body)) {
|
|
50
|
+
// Body is ArrayBufferView
|
|
51
|
+
body = node_buffer.Buffer.from(body.buffer, body.byteOffset, body.byteLength);
|
|
52
|
+
}
|
|
53
|
+
else if (body instanceof Stream__default["default"]) ; /* else if (body instanceof FormData) {
|
|
54
|
+
Body is FormData
|
|
55
|
+
body = formDataToBlob(body);
|
|
56
|
+
boundary = body.type.split('=')[1];
|
|
57
|
+
} */
|
|
58
|
+
else {
|
|
59
|
+
// None of the above
|
|
60
|
+
// coerce to string then buffer
|
|
61
|
+
body = node_buffer.Buffer.from(String(body));
|
|
62
|
+
}
|
|
63
|
+
let stream = body;
|
|
64
|
+
if (node_buffer.Buffer.isBuffer(body)) {
|
|
65
|
+
stream = Stream__default["default"].Readable.from(body);
|
|
66
|
+
}
|
|
67
|
+
else if (is.isBlob(body)) {
|
|
68
|
+
stream = Stream__default["default"].Readable.from(body.stream());
|
|
69
|
+
}
|
|
70
|
+
this[INTERNALS] = {
|
|
71
|
+
body,
|
|
72
|
+
stream,
|
|
73
|
+
boundary,
|
|
74
|
+
disturbed: false,
|
|
75
|
+
error: null
|
|
76
|
+
};
|
|
77
|
+
this.size = size;
|
|
78
|
+
if (body instanceof Stream__default["default"]) {
|
|
79
|
+
body.on('error', error_ => {
|
|
80
|
+
const error = error_ instanceof base.FetchBaseError ?
|
|
81
|
+
error_ :
|
|
82
|
+
new fetchError.FetchError(`Invalid response body while trying to fetch ${this.url}: ${error_.message}`, 'system', error_);
|
|
83
|
+
this[INTERNALS].error = error;
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
get body() {
|
|
88
|
+
return this[INTERNALS].stream;
|
|
89
|
+
}
|
|
90
|
+
get bodyUsed() {
|
|
91
|
+
return this[INTERNALS].disturbed;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Decode response as ArrayBuffer
|
|
95
|
+
*
|
|
96
|
+
* @return Promise
|
|
97
|
+
*/
|
|
98
|
+
async arrayBuffer() {
|
|
99
|
+
const { buffer, byteOffset, byteLength } = await consumeBody(this);
|
|
100
|
+
return buffer.slice(byteOffset, byteOffset + byteLength);
|
|
101
|
+
}
|
|
102
|
+
/*async formData() {
|
|
103
|
+
const ct = this.headers.get('content-type');
|
|
104
|
+
|
|
105
|
+
if (ct.startsWith('application/x-www-form-urlencoded')) {
|
|
106
|
+
const formData = new FormData();
|
|
107
|
+
const parameters = new URLSearchParams(await this.text());
|
|
108
|
+
|
|
109
|
+
for (const [name, value] of parameters) {
|
|
110
|
+
formData.append(name, value);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
return formData;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
const {toFormData} = await import('./utils/multipart-parser.js');
|
|
117
|
+
return toFormData(this.body, ct);
|
|
118
|
+
}*/
|
|
119
|
+
/**
|
|
120
|
+
* Return raw response as Blob
|
|
121
|
+
*
|
|
122
|
+
* @return Promise
|
|
123
|
+
*/
|
|
124
|
+
async blob() {
|
|
125
|
+
const ct = (this.headers && this.headers.get('content-type')) || (this[INTERNALS].body && this[INTERNALS].body.type) || '';
|
|
126
|
+
const buf = await this.arrayBuffer();
|
|
127
|
+
return new Blob([buf], {
|
|
128
|
+
type: ct
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Decode response as json
|
|
133
|
+
*
|
|
134
|
+
* @return Promise
|
|
135
|
+
*/
|
|
136
|
+
async json() {
|
|
137
|
+
const text = await this.text();
|
|
138
|
+
return JSON.parse(text);
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Decode response as text
|
|
142
|
+
*
|
|
143
|
+
* @return Promise
|
|
144
|
+
*/
|
|
145
|
+
async text() {
|
|
146
|
+
const buffer = await consumeBody(this);
|
|
147
|
+
return new TextDecoder().decode(buffer);
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Decode response as buffer (non-spec api)
|
|
151
|
+
*
|
|
152
|
+
* @return Promise
|
|
153
|
+
*/
|
|
154
|
+
buffer() {
|
|
155
|
+
return consumeBody(this);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
Body.prototype.buffer = node_util.deprecate(Body.prototype.buffer, 'Please use \'response.arrayBuffer()\' instead of \'response.buffer()\'', 'node-fetch#buffer');
|
|
159
|
+
// In browsers, all properties are enumerable.
|
|
160
|
+
Object.defineProperties(Body.prototype, {
|
|
161
|
+
body: { enumerable: true },
|
|
162
|
+
bodyUsed: { enumerable: true },
|
|
163
|
+
arrayBuffer: { enumerable: true },
|
|
164
|
+
blob: { enumerable: true },
|
|
165
|
+
json: { enumerable: true },
|
|
166
|
+
text: { enumerable: true },
|
|
167
|
+
data: { get: node_util.deprecate(() => { }, 'data doesn\'t exist, use json(), text(), arrayBuffer(), or body instead', 'https://github.com/node-fetch/node-fetch/issues/1000 (response)') }
|
|
168
|
+
});
|
|
169
|
+
/**
|
|
170
|
+
* Consume and convert an entire Body to a Buffer.
|
|
171
|
+
*
|
|
172
|
+
* Ref: https://fetch.spec.whatwg.org/#concept-body-consume-body
|
|
173
|
+
*
|
|
174
|
+
* @return Promise
|
|
175
|
+
*/
|
|
176
|
+
async function consumeBody(data) {
|
|
177
|
+
if (data[INTERNALS].disturbed) {
|
|
178
|
+
throw new TypeError(`body used already for: ${data.url}`);
|
|
179
|
+
}
|
|
180
|
+
data[INTERNALS].disturbed = true;
|
|
181
|
+
if (data[INTERNALS].error) {
|
|
182
|
+
throw data[INTERNALS].error;
|
|
183
|
+
}
|
|
184
|
+
const { body } = data;
|
|
185
|
+
// Body is null
|
|
186
|
+
if (body === null) {
|
|
187
|
+
return node_buffer.Buffer.alloc(0);
|
|
188
|
+
}
|
|
189
|
+
/* c8 ignore next 3 */
|
|
190
|
+
if (!(body instanceof Stream__default["default"])) {
|
|
191
|
+
return node_buffer.Buffer.alloc(0);
|
|
192
|
+
}
|
|
193
|
+
// Body is stream
|
|
194
|
+
// get ready to actually consume the body
|
|
195
|
+
const accum = [];
|
|
196
|
+
let accumBytes = 0;
|
|
197
|
+
try {
|
|
198
|
+
for await (const chunk of body) {
|
|
199
|
+
if (data.size > 0 && accumBytes + chunk.length > data.size) {
|
|
200
|
+
const error = new fetchError.FetchError(`content size at ${data.url} over limit: ${data.size}`, 'max-size');
|
|
201
|
+
body.destroy(error);
|
|
202
|
+
throw error;
|
|
203
|
+
}
|
|
204
|
+
accumBytes += chunk.length;
|
|
205
|
+
accum.push(chunk);
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
catch (error) {
|
|
209
|
+
const error_ = error instanceof base.FetchBaseError ? error : new fetchError.FetchError(`Invalid response body while trying to fetch ${data.url}: ${error.message}`, 'system', error);
|
|
210
|
+
throw error_;
|
|
211
|
+
}
|
|
212
|
+
if (body.readableEnded === true || body._readableState.ended === true) {
|
|
213
|
+
try {
|
|
214
|
+
if (accum.every(c => typeof c === 'string')) {
|
|
215
|
+
return node_buffer.Buffer.from(accum.join(''));
|
|
216
|
+
}
|
|
217
|
+
return node_buffer.Buffer.concat(accum, accumBytes);
|
|
218
|
+
}
|
|
219
|
+
catch (error) {
|
|
220
|
+
throw new fetchError.FetchError(`Could not create Buffer from response body for ${data.url}: ${error.message}`, 'system', error);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
else {
|
|
224
|
+
throw new fetchError.FetchError(`Premature close of server response while trying to fetch ${data.url}`);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
/**
|
|
228
|
+
* Clone body given Res/Req instance
|
|
229
|
+
*
|
|
230
|
+
* @param Mixed instance Response or Request instance
|
|
231
|
+
* @param String highWaterMark highWaterMark for both PassThrough body streams
|
|
232
|
+
* @return Mixed
|
|
233
|
+
*/
|
|
234
|
+
const clone = (instance, highWaterMark) => {
|
|
235
|
+
let p1;
|
|
236
|
+
let p2;
|
|
237
|
+
let { body } = instance[INTERNALS];
|
|
238
|
+
// Don't allow cloning a used body
|
|
239
|
+
if (instance.bodyUsed) {
|
|
240
|
+
throw new Error('cannot clone body after it is used');
|
|
241
|
+
}
|
|
242
|
+
// Check that body is a stream and not form-data object
|
|
243
|
+
// note: we can't clone the form-data object without having it as a dependency
|
|
244
|
+
if ((body instanceof Stream__default["default"]) && (typeof body.getBoundary !== 'function')) {
|
|
245
|
+
// Tee instance body
|
|
246
|
+
p1 = new Stream.PassThrough({ highWaterMark });
|
|
247
|
+
p2 = new Stream.PassThrough({ highWaterMark });
|
|
248
|
+
body.pipe(p1);
|
|
249
|
+
body.pipe(p2);
|
|
250
|
+
// Set instance body to teed body and return the other teed body
|
|
251
|
+
instance[INTERNALS].stream = p1;
|
|
252
|
+
body = p2;
|
|
253
|
+
}
|
|
254
|
+
return body;
|
|
255
|
+
};
|
|
256
|
+
const getNonSpecFormDataBoundary = node_util.deprecate(body => body.getBoundary(), 'form-data doesn\'t follow the spec and requires special treatment. Use alternative package', 'https://github.com/node-fetch/node-fetch/issues/1167');
|
|
257
|
+
/**
|
|
258
|
+
* Performs the operation "extract a `Content-Type` value from |object|" as
|
|
259
|
+
* specified in the specification:
|
|
260
|
+
* https://fetch.spec.whatwg.org/#concept-bodyinit-extract
|
|
261
|
+
*
|
|
262
|
+
* This function assumes that instance.body is present.
|
|
263
|
+
*
|
|
264
|
+
* @param {any} body Any options.body input
|
|
265
|
+
* @returns {string | null}
|
|
266
|
+
*/
|
|
267
|
+
const extractContentType = (body, request) => {
|
|
268
|
+
// Body is null or undefined
|
|
269
|
+
if (body === null) {
|
|
270
|
+
return null;
|
|
271
|
+
}
|
|
272
|
+
// Body is string
|
|
273
|
+
if (typeof body === 'string') {
|
|
274
|
+
return 'text/plain;charset=UTF-8';
|
|
275
|
+
}
|
|
276
|
+
// Body is a URLSearchParams
|
|
277
|
+
if (is.isURLSearchParameters(body)) {
|
|
278
|
+
return 'application/x-www-form-urlencoded;charset=UTF-8';
|
|
279
|
+
}
|
|
280
|
+
// Body is blob
|
|
281
|
+
if (is.isBlob(body)) {
|
|
282
|
+
return body.type || null;
|
|
283
|
+
}
|
|
284
|
+
// Body is a Buffer (Buffer, ArrayBuffer or ArrayBufferView)
|
|
285
|
+
if (node_buffer.Buffer.isBuffer(body) || node_util.types.isAnyArrayBuffer(body) || ArrayBuffer.isView(body)) {
|
|
286
|
+
return null;
|
|
287
|
+
}
|
|
288
|
+
// if (body instanceof FormData) {
|
|
289
|
+
// return `multipart/form-data; boundary=${request[INTERNALS].boundary}`;
|
|
290
|
+
// }
|
|
291
|
+
// Detect form data input from form-data module
|
|
292
|
+
if (body && typeof body.getBoundary === 'function') {
|
|
293
|
+
return `multipart/form-data;boundary=${getNonSpecFormDataBoundary(body)}`;
|
|
294
|
+
}
|
|
295
|
+
// Body is stream - can't really do much about this
|
|
296
|
+
if (body instanceof Stream__default["default"]) {
|
|
297
|
+
return null;
|
|
298
|
+
}
|
|
299
|
+
// Body constructor defaults other things to string
|
|
300
|
+
return 'text/plain;charset=UTF-8';
|
|
301
|
+
};
|
|
302
|
+
/**
|
|
303
|
+
* The Fetch Standard treats this as if "total bytes" is a property on the body.
|
|
304
|
+
* For us, we have to explicitly get it with a function.
|
|
305
|
+
*
|
|
306
|
+
* ref: https://fetch.spec.whatwg.org/#concept-body-total-bytes
|
|
307
|
+
*
|
|
308
|
+
* @param {any} obj.body Body object from the Body instance.
|
|
309
|
+
* @returns {number | null}
|
|
310
|
+
*/
|
|
311
|
+
const getTotalBytes = request => {
|
|
312
|
+
const { body } = request[INTERNALS];
|
|
313
|
+
// Body is null or undefined
|
|
314
|
+
if (body === null) {
|
|
315
|
+
return 0;
|
|
316
|
+
}
|
|
317
|
+
// Body is Blob
|
|
318
|
+
if (is.isBlob(body)) {
|
|
319
|
+
return body.size;
|
|
320
|
+
}
|
|
321
|
+
// Body is Buffer
|
|
322
|
+
if (node_buffer.Buffer.isBuffer(body)) {
|
|
323
|
+
return body.length;
|
|
324
|
+
}
|
|
325
|
+
// Detect form data input from form-data module
|
|
326
|
+
if (body && typeof body.getLengthSync === 'function') {
|
|
327
|
+
return body.hasKnownLength && body.hasKnownLength() ? body.getLengthSync() : null;
|
|
328
|
+
}
|
|
329
|
+
// Body is stream
|
|
330
|
+
return null;
|
|
331
|
+
};
|
|
332
|
+
/**
|
|
333
|
+
* Write a Body to a Node.js WritableStream (e.g. http.Request) object.
|
|
334
|
+
*
|
|
335
|
+
* @param {Stream.Writable} dest The stream to write to.
|
|
336
|
+
* @param obj.body Body object from the Body instance.
|
|
337
|
+
* @returns {Promise<void>}
|
|
338
|
+
*/
|
|
339
|
+
const writeToStream = async (dest, { body }) => {
|
|
340
|
+
if (body === null) {
|
|
341
|
+
// Body is null
|
|
342
|
+
dest.end();
|
|
343
|
+
}
|
|
344
|
+
else {
|
|
345
|
+
// Body is stream
|
|
346
|
+
await pipeline(body, dest);
|
|
347
|
+
}
|
|
348
|
+
};
|
|
349
|
+
|
|
350
|
+
exports.clone = clone;
|
|
351
|
+
exports["default"] = Body;
|
|
352
|
+
exports.extractContentType = extractContentType;
|
|
353
|
+
exports.getTotalBytes = getTotalBytes;
|
|
354
|
+
exports.writeToStream = writeToStream;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var base = require('./base.js');
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* AbortError interface for cancelled requests
|
|
9
|
+
*/
|
|
10
|
+
class AbortError extends base.FetchBaseError {
|
|
11
|
+
constructor(message, type = 'aborted') {
|
|
12
|
+
super(message, type);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
exports.AbortError = AbortError;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
class FetchBaseError extends Error {
|
|
6
|
+
constructor(message, type) {
|
|
7
|
+
super(message);
|
|
8
|
+
// Hide custom error implementation details from end-users
|
|
9
|
+
Error.captureStackTrace(this, this.constructor);
|
|
10
|
+
this.type = type;
|
|
11
|
+
}
|
|
12
|
+
get name() {
|
|
13
|
+
return this.constructor.name;
|
|
14
|
+
}
|
|
15
|
+
get [Symbol.toStringTag]() {
|
|
16
|
+
return this.constructor.name;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
exports.FetchBaseError = FetchBaseError;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var base = require('./base.js');
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* @typedef {{ address?: string, code: string, dest?: string, errno: number, info?: object, message: string, path?: string, port?: number, syscall: string}} SystemError
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* FetchError interface for operational errors
|
|
12
|
+
*/
|
|
13
|
+
class FetchError extends base.FetchBaseError {
|
|
14
|
+
/**
|
|
15
|
+
* @param {string} message - Error message for human
|
|
16
|
+
* @param {string} [type] - Error type for machine
|
|
17
|
+
* @param {SystemError} [systemError] - For Node.js system error
|
|
18
|
+
*/
|
|
19
|
+
constructor(message, type, systemError) {
|
|
20
|
+
super(message, type);
|
|
21
|
+
// When err.type is `system`, err.erroredSysCall contains system error and err.code contains system error code
|
|
22
|
+
if (systemError) {
|
|
23
|
+
// eslint-disable-next-line no-multi-assign
|
|
24
|
+
this.code = this.errno = systemError.code;
|
|
25
|
+
this.erroredSysCall = systemError.syscall;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
exports.FetchError = FetchError;
|
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var node_util = require('node:util');
|
|
6
|
+
var http = require('node:http');
|
|
7
|
+
|
|
8
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
9
|
+
|
|
10
|
+
var http__default = /*#__PURE__*/_interopDefaultLegacy(http);
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Headers.js
|
|
14
|
+
*
|
|
15
|
+
* Headers class offers convenient helpers
|
|
16
|
+
*/
|
|
17
|
+
/* c8 ignore next 9 */
|
|
18
|
+
const validateHeaderName = typeof http__default["default"].validateHeaderName === 'function' ?
|
|
19
|
+
http__default["default"].validateHeaderName :
|
|
20
|
+
name => {
|
|
21
|
+
if (!/^[\^`\-\w!#$%&'*+.|~]+$/.test(name)) {
|
|
22
|
+
const error = new TypeError(`Header name must be a valid HTTP token [${name}]`);
|
|
23
|
+
Object.defineProperty(error, 'code', { value: 'ERR_INVALID_HTTP_TOKEN' });
|
|
24
|
+
throw error;
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
/* c8 ignore next 9 */
|
|
28
|
+
const validateHeaderValue = typeof http__default["default"].validateHeaderValue === 'function' ?
|
|
29
|
+
http__default["default"].validateHeaderValue :
|
|
30
|
+
(name, value) => {
|
|
31
|
+
if (/[^\t\u0020-\u007E\u0080-\u00FF]/.test(value)) {
|
|
32
|
+
const error = new TypeError(`Invalid character in header content ["${name}"]`);
|
|
33
|
+
Object.defineProperty(error, 'code', { value: 'ERR_INVALID_CHAR' });
|
|
34
|
+
throw error;
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
/**
|
|
38
|
+
* @typedef {Headers | Record<string, string> | Iterable<readonly [string, string]> | Iterable<Iterable<string>>} HeadersInit
|
|
39
|
+
*/
|
|
40
|
+
/**
|
|
41
|
+
* This Fetch API interface allows you to perform various actions on HTTP request and response headers.
|
|
42
|
+
* These actions include retrieving, setting, adding to, and removing.
|
|
43
|
+
* A Headers object has an associated header list, which is initially empty and consists of zero or more name and value pairs.
|
|
44
|
+
* You can add to this using methods like append() (see Examples.)
|
|
45
|
+
* In all methods of this interface, header names are matched by case-insensitive byte sequence.
|
|
46
|
+
*
|
|
47
|
+
*/
|
|
48
|
+
class Headers extends URLSearchParams {
|
|
49
|
+
/**
|
|
50
|
+
* Headers class
|
|
51
|
+
*
|
|
52
|
+
* @constructor
|
|
53
|
+
* @param {HeadersInit} [init] - Response headers
|
|
54
|
+
*/
|
|
55
|
+
constructor(init) {
|
|
56
|
+
// Validate and normalize init object in [name, value(s)][]
|
|
57
|
+
/** @type {string[][]} */
|
|
58
|
+
let result = [];
|
|
59
|
+
if (init instanceof Headers) {
|
|
60
|
+
const raw = init.raw();
|
|
61
|
+
for (const [name, values] of Object.entries(raw)) {
|
|
62
|
+
result.push(...values.map(value => [name, value]));
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
else if (init == null) ;
|
|
66
|
+
else if (typeof init === 'object' && !node_util.types.isBoxedPrimitive(init)) {
|
|
67
|
+
const method = init[Symbol.iterator];
|
|
68
|
+
// eslint-disable-next-line no-eq-null, eqeqeq
|
|
69
|
+
if (method == null) {
|
|
70
|
+
// Record<ByteString, ByteString>
|
|
71
|
+
result.push(...Object.entries(init));
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
if (typeof method !== 'function') {
|
|
75
|
+
throw new TypeError('Header pairs must be iterable');
|
|
76
|
+
}
|
|
77
|
+
// Sequence<sequence<ByteString>>
|
|
78
|
+
// Note: per spec we have to first exhaust the lists then process them
|
|
79
|
+
result = [...init]
|
|
80
|
+
.map(pair => {
|
|
81
|
+
if (typeof pair !== 'object' || node_util.types.isBoxedPrimitive(pair)) {
|
|
82
|
+
throw new TypeError('Each header pair must be an iterable object');
|
|
83
|
+
}
|
|
84
|
+
return [...pair];
|
|
85
|
+
}).map(pair => {
|
|
86
|
+
if (pair.length !== 2) {
|
|
87
|
+
throw new TypeError('Each header pair must be a name/value tuple');
|
|
88
|
+
}
|
|
89
|
+
return [...pair];
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
throw new TypeError('Failed to construct \'Headers\': The provided value is not of type \'(sequence<sequence<ByteString>> or record<ByteString, ByteString>)');
|
|
95
|
+
}
|
|
96
|
+
// Validate and lowercase
|
|
97
|
+
result =
|
|
98
|
+
result.length > 0 ?
|
|
99
|
+
result.map(([name, value]) => {
|
|
100
|
+
validateHeaderName(name);
|
|
101
|
+
validateHeaderValue(name, String(value));
|
|
102
|
+
return [String(name).toLowerCase(), String(value)];
|
|
103
|
+
}) :
|
|
104
|
+
undefined;
|
|
105
|
+
super(result);
|
|
106
|
+
// Returning a Proxy that will lowercase key names, validate parameters and sort keys
|
|
107
|
+
// eslint-disable-next-line no-constructor-return
|
|
108
|
+
return new Proxy(this, {
|
|
109
|
+
get(target, p, receiver) {
|
|
110
|
+
switch (p) {
|
|
111
|
+
case 'append':
|
|
112
|
+
case 'set':
|
|
113
|
+
return (name, value) => {
|
|
114
|
+
validateHeaderName(name);
|
|
115
|
+
validateHeaderValue(name, String(value));
|
|
116
|
+
return URLSearchParams.prototype[p].call(target, String(name).toLowerCase(), String(value));
|
|
117
|
+
};
|
|
118
|
+
case 'delete':
|
|
119
|
+
case 'has':
|
|
120
|
+
case 'getAll':
|
|
121
|
+
return name => {
|
|
122
|
+
validateHeaderName(name);
|
|
123
|
+
return URLSearchParams.prototype[p].call(target, String(name).toLowerCase());
|
|
124
|
+
};
|
|
125
|
+
case 'keys':
|
|
126
|
+
return () => {
|
|
127
|
+
target.sort();
|
|
128
|
+
return new Set(URLSearchParams.prototype.keys.call(target)).keys();
|
|
129
|
+
};
|
|
130
|
+
default:
|
|
131
|
+
return Reflect.get(target, p, receiver);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
/* c8 ignore next */
|
|
136
|
+
}
|
|
137
|
+
get [Symbol.toStringTag]() {
|
|
138
|
+
return this.constructor.name;
|
|
139
|
+
}
|
|
140
|
+
toString() {
|
|
141
|
+
return Object.prototype.toString.call(this);
|
|
142
|
+
}
|
|
143
|
+
get(name) {
|
|
144
|
+
const values = this.getAll(name);
|
|
145
|
+
if (values.length === 0) {
|
|
146
|
+
return null;
|
|
147
|
+
}
|
|
148
|
+
let value = values.join(', ');
|
|
149
|
+
if (/^content-encoding$/i.test(name)) {
|
|
150
|
+
value = value.toLowerCase();
|
|
151
|
+
}
|
|
152
|
+
return value;
|
|
153
|
+
}
|
|
154
|
+
forEach(callback, thisArg = undefined) {
|
|
155
|
+
for (const name of this.keys()) {
|
|
156
|
+
Reflect.apply(callback, thisArg, [this.get(name), name, this]);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
*values() {
|
|
160
|
+
for (const name of this.keys()) {
|
|
161
|
+
yield this.get(name);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* @type {() => IterableIterator<[string, string]>}
|
|
166
|
+
*/
|
|
167
|
+
*entries() {
|
|
168
|
+
for (const name of this.keys()) {
|
|
169
|
+
yield [name, this.get(name)];
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
[Symbol.iterator]() {
|
|
173
|
+
return this.entries();
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Node-fetch non-spec method
|
|
177
|
+
* returning all headers and their values as array
|
|
178
|
+
* @returns {Record<string, string[]>}
|
|
179
|
+
*/
|
|
180
|
+
raw() {
|
|
181
|
+
return [...this.keys()].reduce((result, key) => {
|
|
182
|
+
result[key] = this.getAll(key);
|
|
183
|
+
return result;
|
|
184
|
+
}, {});
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* For better console.log(headers) and also to convert Headers into Node.js Request compatible format
|
|
188
|
+
*/
|
|
189
|
+
[Symbol.for('nodejs.util.inspect.custom')]() {
|
|
190
|
+
return [...this.keys()].reduce((result, key) => {
|
|
191
|
+
const values = this.getAll(key);
|
|
192
|
+
// Http.request() only supports string as Host header.
|
|
193
|
+
// This hack makes specifying custom Host header possible.
|
|
194
|
+
if (key === 'host') {
|
|
195
|
+
result[key] = values[0];
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
result[key] = values.length > 1 ? values : values[0];
|
|
199
|
+
}
|
|
200
|
+
return result;
|
|
201
|
+
}, {});
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
/**
|
|
205
|
+
* Re-shaping object for Web IDL tests
|
|
206
|
+
* Only need to do it for overridden methods
|
|
207
|
+
*/
|
|
208
|
+
Object.defineProperties(Headers.prototype, ['get', 'entries', 'forEach', 'values'].reduce((result, property) => {
|
|
209
|
+
result[property] = { enumerable: true };
|
|
210
|
+
return result;
|
|
211
|
+
}, {}));
|
|
212
|
+
/**
|
|
213
|
+
* Create a Headers object from an http.IncomingMessage.rawHeaders, ignoring those that do
|
|
214
|
+
* not conform to HTTP grammar productions.
|
|
215
|
+
* @param {import('http').IncomingMessage['rawHeaders']} headers
|
|
216
|
+
*/
|
|
217
|
+
function fromRawHeaders(headers = []) {
|
|
218
|
+
return new Headers(headers
|
|
219
|
+
// Split into pairs
|
|
220
|
+
.reduce((result, value, index, array) => {
|
|
221
|
+
if (index % 2 === 0) {
|
|
222
|
+
result.push(array.slice(index, index + 2));
|
|
223
|
+
}
|
|
224
|
+
return result;
|
|
225
|
+
}, [])
|
|
226
|
+
.filter(([name, value]) => {
|
|
227
|
+
try {
|
|
228
|
+
validateHeaderName(name);
|
|
229
|
+
validateHeaderValue(name, String(value));
|
|
230
|
+
return true;
|
|
231
|
+
}
|
|
232
|
+
catch {
|
|
233
|
+
return false;
|
|
234
|
+
}
|
|
235
|
+
}));
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
exports["default"] = Headers;
|
|
239
|
+
exports.fromRawHeaders = fromRawHeaders;
|