ccxt 4.2.18 → 4.2.20
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 +100 -100
- package/dist/ccxt.browser.js +34240 -33297
- package/dist/ccxt.browser.min.js +2 -2
- package/dist/cjs/ccxt.js +12 -1
- package/dist/cjs/src/alpaca.js +18 -18
- package/dist/cjs/src/ascendex.js +13 -6
- package/dist/cjs/src/base/Exchange.js +276 -27
- package/dist/cjs/src/bigone.js +434 -168
- package/dist/cjs/src/binance.js +165 -35
- package/dist/cjs/src/binanceus.js +25 -0
- package/dist/cjs/src/bingx.js +185 -42
- package/dist/cjs/src/bitfinex.js +2 -3
- package/dist/cjs/src/bitget.js +84 -47
- package/dist/cjs/src/bitmart.js +5 -5
- package/dist/cjs/src/bitmex.js +4 -6
- package/dist/cjs/src/bitpanda.js +5 -1991
- package/dist/cjs/src/bitstamp.js +8 -0
- package/dist/cjs/src/bitteam.js +1 -1
- package/dist/cjs/src/bybit.js +27 -75
- package/dist/cjs/src/coinbase.js +176 -26
- package/dist/cjs/src/coincheck.js +1 -0
- package/dist/cjs/src/coinex.js +3 -0
- package/dist/cjs/src/coinlist.js +13 -6
- package/dist/cjs/src/coinone.js +2 -2
- package/dist/cjs/src/coinsph.js +4 -5
- package/dist/cjs/src/delta.js +7 -19
- package/dist/cjs/src/deribit.js +17 -4
- package/dist/cjs/src/gate.js +151 -194
- package/dist/cjs/src/gemini.js +1 -1
- package/dist/cjs/src/hitbtc.js +2 -3
- package/dist/cjs/src/htx.js +157 -7
- package/dist/cjs/src/huobijp.js +2 -3
- package/dist/cjs/src/independentreserve.js +7 -5
- package/dist/cjs/src/kraken.js +86 -54
- package/dist/cjs/src/kucoin.js +5 -0
- package/dist/cjs/src/kucoinfutures.js +140 -86
- package/dist/cjs/src/lbank.js +60 -33
- package/dist/cjs/src/luno.js +84 -2
- package/dist/cjs/src/mexc.js +3 -3
- package/dist/cjs/src/oceanex.js +1 -1
- package/dist/cjs/src/okx.js +23 -29
- package/dist/cjs/{js/src/bitpanda.js → src/onetrading.js} +39 -39
- package/dist/cjs/src/phemex.js +37 -27
- package/dist/cjs/src/poloniexfutures.js +1 -0
- package/dist/cjs/src/pro/binance.js +66 -25
- package/dist/cjs/src/pro/bitget.js +1 -1
- package/dist/cjs/src/pro/bitpanda.js +5 -1330
- package/dist/cjs/src/pro/coinbase.js +4 -1
- package/dist/cjs/src/pro/hitbtc.js +5 -4
- package/dist/cjs/src/pro/htx.js +6 -1
- package/dist/cjs/src/pro/kraken.js +1 -1
- package/dist/cjs/src/pro/krakenfutures.js +7 -1
- package/dist/cjs/src/pro/kucoin.js +46 -36
- package/dist/cjs/src/pro/kucoinfutures.js +45 -37
- package/dist/cjs/src/pro/lbank.js +881 -0
- package/dist/cjs/src/pro/okx.js +52 -2
- package/dist/cjs/{js/src/pro/bitpanda.js → src/pro/onetrading.js} +4 -7
- package/dist/cjs/src/pro/poloniex.js +2 -2
- package/dist/cjs/src/pro/poloniexfutures.js +43 -35
- package/dist/cjs/src/pro/woo.js +126 -0
- package/dist/cjs/src/probit.js +4 -2
- package/dist/cjs/src/upbit.js +12 -12
- package/dist/cjs/src/wavesexchange.js +1 -1
- package/dist/cjs/src/whitebit.js +1 -0
- package/dist/cjs/src/woo.js +56 -0
- package/js/ccxt.d.ts +11 -2
- package/js/ccxt.js +8 -2
- package/js/src/abstract/binance.d.ts +1 -0
- package/js/src/abstract/binancecoinm.d.ts +1 -0
- package/js/src/abstract/binanceus.d.ts +1 -0
- package/js/src/abstract/binanceusdm.d.ts +1 -0
- package/js/src/abstract/bitpanda.d.ts +4 -4
- package/js/src/abstract/bitpanda.js +3 -3
- package/js/src/abstract/bitstamp.d.ts +8 -0
- package/js/src/abstract/gate.d.ts +1 -0
- package/js/src/abstract/gateio.d.ts +1 -0
- package/js/src/abstract/htx.d.ts +3 -0
- package/js/src/abstract/huobi.d.ts +3 -0
- package/js/src/abstract/luno.d.ts +1 -0
- package/js/src/abstract/onetrading.d.ts +38 -0
- package/js/src/abstract/onetrading.js +11 -0
- package/js/src/ascendex.js +2 -0
- package/js/src/base/Exchange.d.ts +3 -0
- package/js/src/base/Exchange.js +10 -0
- package/js/src/binance.js +2 -1
- package/js/src/binanceus.js +17 -0
- package/js/src/bingx.js +3 -2
- package/js/src/bitget.d.ts +1 -1
- package/js/src/bitget.js +47 -34
- package/js/src/bitpanda.d.ts +2 -72
- package/js/src/bitpanda.js +5 -1991
- package/js/src/bitstamp.js +8 -0
- package/js/src/bitteam.js +1 -1
- package/js/src/bybit.d.ts +0 -1
- package/js/src/bybit.js +1 -29
- package/js/src/delta.d.ts +0 -1
- package/js/src/delta.js +0 -18
- package/js/src/deribit.js +11 -3
- package/js/src/gate.d.ts +1 -1
- package/js/src/gate.js +50 -135
- package/js/src/htx.js +3 -0
- package/js/src/kraken.d.ts +1 -0
- package/js/src/kraken.js +39 -38
- package/js/src/kucoinfutures.d.ts +6 -6
- package/js/src/kucoinfutures.js +9 -9
- package/js/src/lbank.js +1 -0
- package/js/src/luno.d.ts +3 -1
- package/js/src/luno.js +84 -2
- package/js/src/mexc.js +1 -2
- package/js/src/okx.d.ts +0 -1
- package/js/src/okx.js +0 -18
- package/js/src/onetrading.d.ts +74 -0
- package/js/src/onetrading.js +2003 -0
- package/js/src/poloniexfutures.js +1 -0
- package/js/src/pro/binance.js +6 -1
- package/js/src/pro/bitpanda.d.ts +2 -34
- package/js/src/pro/bitpanda.js +5 -1330
- package/js/src/pro/lbank.d.ts +29 -0
- package/js/src/pro/lbank.js +882 -0
- package/js/src/pro/onetrading.d.ts +36 -0
- package/js/src/pro/onetrading.js +1339 -0
- package/package.json +2 -2
- package/rollup.config.js +2 -0
- package/skip-tests.json +4 -2
- package/test-commonjs.cjs +25 -1
- package/dist/cjs/js/ccxt.js +0 -478
- package/dist/cjs/js/src/abstract/alpaca.js +0 -9
- package/dist/cjs/js/src/abstract/ascendex.js +0 -9
- package/dist/cjs/js/src/abstract/bigone.js +0 -9
- package/dist/cjs/js/src/abstract/binance.js +0 -9
- package/dist/cjs/js/src/abstract/bingx.js +0 -9
- package/dist/cjs/js/src/abstract/bit2c.js +0 -9
- package/dist/cjs/js/src/abstract/bitbank.js +0 -9
- package/dist/cjs/js/src/abstract/bitbns.js +0 -9
- package/dist/cjs/js/src/abstract/bitfinex.js +0 -9
- package/dist/cjs/js/src/abstract/bitfinex2.js +0 -9
- package/dist/cjs/js/src/abstract/bitflyer.js +0 -9
- package/dist/cjs/js/src/abstract/bitforex.js +0 -9
- package/dist/cjs/js/src/abstract/bitget.js +0 -9
- package/dist/cjs/js/src/abstract/bithumb.js +0 -9
- package/dist/cjs/js/src/abstract/bitmart.js +0 -9
- package/dist/cjs/js/src/abstract/bitmex.js +0 -9
- package/dist/cjs/js/src/abstract/bitopro.js +0 -9
- package/dist/cjs/js/src/abstract/bitpanda.js +0 -9
- package/dist/cjs/js/src/abstract/bitrue.js +0 -9
- package/dist/cjs/js/src/abstract/bitso.js +0 -9
- package/dist/cjs/js/src/abstract/bitstamp.js +0 -9
- package/dist/cjs/js/src/abstract/bitteam.js +0 -9
- package/dist/cjs/js/src/abstract/bitvavo.js +0 -9
- package/dist/cjs/js/src/abstract/bl3p.js +0 -9
- package/dist/cjs/js/src/abstract/blockchaincom.js +0 -9
- package/dist/cjs/js/src/abstract/btcalpha.js +0 -9
- package/dist/cjs/js/src/abstract/btcbox.js +0 -9
- package/dist/cjs/js/src/abstract/btcmarkets.js +0 -9
- package/dist/cjs/js/src/abstract/btcturk.js +0 -9
- package/dist/cjs/js/src/abstract/bybit.js +0 -9
- package/dist/cjs/js/src/abstract/cex.js +0 -9
- package/dist/cjs/js/src/abstract/coinbase.js +0 -9
- package/dist/cjs/js/src/abstract/coinbasepro.js +0 -9
- package/dist/cjs/js/src/abstract/coincheck.js +0 -9
- package/dist/cjs/js/src/abstract/coinex.js +0 -9
- package/dist/cjs/js/src/abstract/coinlist.js +0 -9
- package/dist/cjs/js/src/abstract/coinmate.js +0 -9
- package/dist/cjs/js/src/abstract/coinone.js +0 -9
- package/dist/cjs/js/src/abstract/coinsph.js +0 -9
- package/dist/cjs/js/src/abstract/coinspot.js +0 -9
- package/dist/cjs/js/src/abstract/cryptocom.js +0 -9
- package/dist/cjs/js/src/abstract/currencycom.js +0 -9
- package/dist/cjs/js/src/abstract/delta.js +0 -9
- package/dist/cjs/js/src/abstract/deribit.js +0 -9
- package/dist/cjs/js/src/abstract/digifinex.js +0 -9
- package/dist/cjs/js/src/abstract/exmo.js +0 -9
- package/dist/cjs/js/src/abstract/gate.js +0 -9
- package/dist/cjs/js/src/abstract/gemini.js +0 -9
- package/dist/cjs/js/src/abstract/hitbtc.js +0 -9
- package/dist/cjs/js/src/abstract/hollaex.js +0 -9
- package/dist/cjs/js/src/abstract/htx.js +0 -9
- package/dist/cjs/js/src/abstract/huobijp.js +0 -9
- package/dist/cjs/js/src/abstract/idex.js +0 -9
- package/dist/cjs/js/src/abstract/independentreserve.js +0 -9
- package/dist/cjs/js/src/abstract/indodax.js +0 -9
- package/dist/cjs/js/src/abstract/kraken.js +0 -9
- package/dist/cjs/js/src/abstract/krakenfutures.js +0 -9
- package/dist/cjs/js/src/abstract/kucoin.js +0 -9
- package/dist/cjs/js/src/abstract/kucoinfutures.js +0 -9
- package/dist/cjs/js/src/abstract/kuna.js +0 -9
- package/dist/cjs/js/src/abstract/latoken.js +0 -9
- package/dist/cjs/js/src/abstract/lbank.js +0 -9
- package/dist/cjs/js/src/abstract/luno.js +0 -9
- package/dist/cjs/js/src/abstract/lykke.js +0 -9
- package/dist/cjs/js/src/abstract/mercado.js +0 -9
- package/dist/cjs/js/src/abstract/mexc.js +0 -9
- package/dist/cjs/js/src/abstract/ndax.js +0 -9
- package/dist/cjs/js/src/abstract/novadax.js +0 -9
- package/dist/cjs/js/src/abstract/oceanex.js +0 -9
- package/dist/cjs/js/src/abstract/okcoin.js +0 -9
- package/dist/cjs/js/src/abstract/okx.js +0 -9
- package/dist/cjs/js/src/abstract/p2b.js +0 -9
- package/dist/cjs/js/src/abstract/paymium.js +0 -9
- package/dist/cjs/js/src/abstract/phemex.js +0 -9
- package/dist/cjs/js/src/abstract/poloniex.js +0 -9
- package/dist/cjs/js/src/abstract/poloniexfutures.js +0 -9
- package/dist/cjs/js/src/abstract/probit.js +0 -9
- package/dist/cjs/js/src/abstract/timex.js +0 -9
- package/dist/cjs/js/src/abstract/tokocrypto.js +0 -9
- package/dist/cjs/js/src/abstract/upbit.js +0 -9
- package/dist/cjs/js/src/abstract/wavesexchange.js +0 -9
- package/dist/cjs/js/src/abstract/wazirx.js +0 -9
- package/dist/cjs/js/src/abstract/whitebit.js +0 -9
- package/dist/cjs/js/src/abstract/woo.js +0 -9
- package/dist/cjs/js/src/abstract/yobit.js +0 -9
- package/dist/cjs/js/src/abstract/zaif.js +0 -9
- package/dist/cjs/js/src/abstract/zonda.js +0 -9
- package/dist/cjs/js/src/ace.js +0 -1058
- package/dist/cjs/js/src/alpaca.js +0 -1125
- package/dist/cjs/js/src/ascendex.js +0 -3365
- package/dist/cjs/js/src/base/Exchange.js +0 -5260
- package/dist/cjs/js/src/base/Precise.js +0 -263
- package/dist/cjs/js/src/base/errors.js +0 -299
- package/dist/cjs/js/src/base/functions/crypto.js +0 -78
- package/dist/cjs/js/src/base/functions/encode.js +0 -44
- package/dist/cjs/js/src/base/functions/generic.js +0 -193
- package/dist/cjs/js/src/base/functions/misc.js +0 -96
- package/dist/cjs/js/src/base/functions/number.js +0 -297
- package/dist/cjs/js/src/base/functions/platform.js +0 -28
- package/dist/cjs/js/src/base/functions/rsa.js +0 -34
- package/dist/cjs/js/src/base/functions/string.js +0 -48
- package/dist/cjs/js/src/base/functions/throttle.js +0 -66
- package/dist/cjs/js/src/base/functions/time.js +0 -187
- package/dist/cjs/js/src/base/functions/totp.js +0 -24
- package/dist/cjs/js/src/base/functions/type.js +0 -162
- package/dist/cjs/js/src/base/functions.js +0 -157
- package/dist/cjs/js/src/base/ws/Cache.js +0 -254
- package/dist/cjs/js/src/base/ws/Client.js +0 -299
- package/dist/cjs/js/src/base/ws/Future.js +0 -34
- package/dist/cjs/js/src/base/ws/OrderBook.js +0 -107
- package/dist/cjs/js/src/base/ws/OrderBookSide.js +0 -281
- package/dist/cjs/js/src/base/ws/WsClient.js +0 -69
- package/dist/cjs/js/src/bequant.js +0 -33
- package/dist/cjs/js/src/bigone.js +0 -2213
- package/dist/cjs/js/src/binance.js +0 -9851
- package/dist/cjs/js/src/binancecoinm.js +0 -45
- package/dist/cjs/js/src/binanceus.js +0 -92
- package/dist/cjs/js/src/binanceusdm.js +0 -58
- package/dist/cjs/js/src/bingx.js +0 -3872
- package/dist/cjs/js/src/bit2c.js +0 -916
- package/dist/cjs/js/src/bitbank.js +0 -1000
- package/dist/cjs/js/src/bitbay.js +0 -17
- package/dist/cjs/js/src/bitbns.js +0 -1220
- package/dist/cjs/js/src/bitcoincom.js +0 -17
- package/dist/cjs/js/src/bitfinex.js +0 -1670
- package/dist/cjs/js/src/bitfinex2.js +0 -2990
- package/dist/cjs/js/src/bitflyer.js +0 -1045
- package/dist/cjs/js/src/bitforex.js +0 -852
- package/dist/cjs/js/src/bitget.js +0 -8295
- package/dist/cjs/js/src/bithumb.js +0 -1090
- package/dist/cjs/js/src/bitmart.js +0 -4454
- package/dist/cjs/js/src/bitmex.js +0 -2881
- package/dist/cjs/js/src/bitopro.js +0 -1724
- package/dist/cjs/js/src/bitrue.js +0 -3253
- package/dist/cjs/js/src/bitso.js +0 -1753
- package/dist/cjs/js/src/bitstamp.js +0 -2188
- package/dist/cjs/js/src/bitteam.js +0 -2309
- package/dist/cjs/js/src/bitvavo.js +0 -1968
- package/dist/cjs/js/src/bl3p.js +0 -447
- package/dist/cjs/js/src/blockchaincom.js +0 -1160
- package/dist/cjs/js/src/btcalpha.js +0 -929
- package/dist/cjs/js/src/btcbox.js +0 -565
- package/dist/cjs/js/src/btcmarkets.js +0 -1237
- package/dist/cjs/js/src/btcturk.js +0 -929
- package/dist/cjs/js/src/bybit.js +0 -7624
- package/dist/cjs/js/src/cex.js +0 -1693
- package/dist/cjs/js/src/coinbase.js +0 -3424
- package/dist/cjs/js/src/coinbasepro.js +0 -1866
- package/dist/cjs/js/src/coincheck.js +0 -844
- package/dist/cjs/js/src/coinex.js +0 -5417
- package/dist/cjs/js/src/coinlist.js +0 -2337
- package/dist/cjs/js/src/coinmate.js +0 -989
- package/dist/cjs/js/src/coinone.js +0 -1185
- package/dist/cjs/js/src/coinsph.js +0 -1933
- package/dist/cjs/js/src/coinspot.js +0 -548
- package/dist/cjs/js/src/cryptocom.js +0 -3007
- package/dist/cjs/js/src/currencycom.js +0 -2015
- package/dist/cjs/js/src/delta.js +0 -3262
- package/dist/cjs/js/src/deribit.js +0 -3310
- package/dist/cjs/js/src/digifinex.js +0 -4307
- package/dist/cjs/js/src/exmo.js +0 -2645
- package/dist/cjs/js/src/fmfwio.js +0 -34
- package/dist/cjs/js/src/gate.js +0 -7077
- package/dist/cjs/js/src/gateio.js +0 -16
- package/dist/cjs/js/src/gemini.js +0 -1801
- package/dist/cjs/js/src/hitbtc.js +0 -3660
- package/dist/cjs/js/src/hitbtc3.js +0 -19
- package/dist/cjs/js/src/hollaex.js +0 -1882
- package/dist/cjs/js/src/htx.js +0 -9174
- package/dist/cjs/js/src/huobi.js +0 -16
- package/dist/cjs/js/src/huobijp.js +0 -1918
- package/dist/cjs/js/src/idex.js +0 -1770
- package/dist/cjs/js/src/independentreserve.js +0 -761
- package/dist/cjs/js/src/indodax.js +0 -1069
- package/dist/cjs/js/src/kraken.js +0 -2891
- package/dist/cjs/js/src/krakenfutures.js +0 -2407
- package/dist/cjs/js/src/kucoin.js +0 -4494
- package/dist/cjs/js/src/kucoinfutures.js +0 -2529
- package/dist/cjs/js/src/kuna.js +0 -1949
- package/dist/cjs/js/src/latoken.js +0 -1729
- package/dist/cjs/js/src/lbank.js +0 -2851
- package/dist/cjs/js/src/luno.js +0 -1044
- package/dist/cjs/js/src/lykke.js +0 -1303
- package/dist/cjs/js/src/mercado.js +0 -897
- package/dist/cjs/js/src/mexc.js +0 -5407
- package/dist/cjs/js/src/ndax.js +0 -2450
- package/dist/cjs/js/src/novadax.js +0 -1556
- package/dist/cjs/js/src/oceanex.js +0 -964
- package/dist/cjs/js/src/okcoin.js +0 -3115
- package/dist/cjs/js/src/okx.js +0 -7331
- package/dist/cjs/js/src/p2b.js +0 -1243
- package/dist/cjs/js/src/paymium.js +0 -597
- package/dist/cjs/js/src/phemex.js +0 -4725
- package/dist/cjs/js/src/poloniex.js +0 -2356
- package/dist/cjs/js/src/poloniexfutures.js +0 -1794
- package/dist/cjs/js/src/pro/alpaca.js +0 -714
- package/dist/cjs/js/src/pro/ascendex.js +0 -957
- package/dist/cjs/js/src/pro/bequant.js +0 -33
- package/dist/cjs/js/src/pro/binance.js +0 -2796
- package/dist/cjs/js/src/pro/binancecoinm.js +0 -23
- package/dist/cjs/js/src/pro/binanceus.js +0 -51
- package/dist/cjs/js/src/pro/binanceusdm.js +0 -32
- package/dist/cjs/js/src/pro/bingx.js +0 -944
- package/dist/cjs/js/src/pro/bitcoincom.js +0 -29
- package/dist/cjs/js/src/pro/bitfinex.js +0 -672
- package/dist/cjs/js/src/pro/bitfinex2.js +0 -1159
- package/dist/cjs/js/src/pro/bitget.js +0 -1733
- package/dist/cjs/js/src/pro/bitmart.js +0 -1486
- package/dist/cjs/js/src/pro/bitmex.js +0 -1576
- package/dist/cjs/js/src/pro/bitopro.js +0 -327
- package/dist/cjs/js/src/pro/bitrue.js +0 -462
- package/dist/cjs/js/src/pro/bitstamp.js +0 -547
- package/dist/cjs/js/src/pro/bitvavo.js +0 -704
- package/dist/cjs/js/src/pro/blockchaincom.js +0 -794
- package/dist/cjs/js/src/pro/bybit.js +0 -1843
- package/dist/cjs/js/src/pro/cex.js +0 -1510
- package/dist/cjs/js/src/pro/coinbase.js +0 -561
- package/dist/cjs/js/src/pro/coinbasepro.js +0 -968
- package/dist/cjs/js/src/pro/coinex.js +0 -1095
- package/dist/cjs/js/src/pro/cryptocom.js +0 -1020
- package/dist/cjs/js/src/pro/currencycom.js +0 -563
- package/dist/cjs/js/src/pro/deribit.js +0 -825
- package/dist/cjs/js/src/pro/exmo.js +0 -658
- package/dist/cjs/js/src/pro/gate.js +0 -1316
- package/dist/cjs/js/src/pro/gateio.js +0 -16
- package/dist/cjs/js/src/pro/gemini.js +0 -649
- package/dist/cjs/js/src/pro/hitbtc.js +0 -1294
- package/dist/cjs/js/src/pro/hollaex.js +0 -597
- package/dist/cjs/js/src/pro/htx.js +0 -2388
- package/dist/cjs/js/src/pro/huobi.js +0 -16
- package/dist/cjs/js/src/pro/huobijp.js +0 -606
- package/dist/cjs/js/src/pro/idex.js +0 -714
- package/dist/cjs/js/src/pro/independentreserve.js +0 -280
- package/dist/cjs/js/src/pro/kraken.js +0 -1364
- package/dist/cjs/js/src/pro/krakenfutures.js +0 -1506
- package/dist/cjs/js/src/pro/kucoin.js +0 -1062
- package/dist/cjs/js/src/pro/kucoinfutures.js +0 -989
- package/dist/cjs/js/src/pro/luno.js +0 -322
- package/dist/cjs/js/src/pro/mexc.js +0 -1170
- package/dist/cjs/js/src/pro/ndax.js +0 -545
- package/dist/cjs/js/src/pro/okcoin.js +0 -760
- package/dist/cjs/js/src/pro/okx.js +0 -1608
- package/dist/cjs/js/src/pro/phemex.js +0 -1511
- package/dist/cjs/js/src/pro/poloniex.js +0 -1253
- package/dist/cjs/js/src/pro/poloniexfutures.js +0 -1022
- package/dist/cjs/js/src/pro/probit.js +0 -586
- package/dist/cjs/js/src/pro/upbit.js +0 -234
- package/dist/cjs/js/src/pro/wazirx.js +0 -776
- package/dist/cjs/js/src/pro/whitebit.js +0 -927
- package/dist/cjs/js/src/pro/woo.js +0 -895
- package/dist/cjs/js/src/probit.js +0 -1867
- package/dist/cjs/js/src/static_dependencies/fflake/browser.js +0 -401
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +0 -195
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +0 -308
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +0 -554
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +0 -94
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +0 -70
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +0 -91
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +0 -16
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +0 -1760
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +0 -52
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +0 -81
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +0 -376
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +0 -70
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +0 -1580
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +0 -74
- package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +0 -24
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +0 -158
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +0 -429
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +0 -176
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +0 -324
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +0 -163
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +0 -245
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +0 -1018
- package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +0 -383
- package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +0 -258
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +0 -53
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +0 -120
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +0 -69
- package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +0 -7
- package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +0 -83
- package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +0 -240
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +0 -91
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +0 -130
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +0 -214
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +0 -239
- package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +0 -93
- package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +0 -354
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +0 -16
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +0 -20
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +0 -30
- package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +0 -239
- package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +0 -372
- package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +0 -273
- package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +0 -139
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +0 -14
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +0 -16
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +0 -81
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +0 -292
- package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +0 -103
- package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +0 -140
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +0 -175
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +0 -95
- package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +0 -7
- package/dist/cjs/js/src/static_dependencies/scure-base/index.js +0 -383
- package/dist/cjs/js/src/timex.js +0 -1562
- package/dist/cjs/js/src/tokocrypto.js +0 -2542
- package/dist/cjs/js/src/upbit.js +0 -1844
- package/dist/cjs/js/src/wavesexchange.js +0 -2607
- package/dist/cjs/js/src/wazirx.js +0 -953
- package/dist/cjs/js/src/whitebit.js +0 -2310
- package/dist/cjs/js/src/woo.js +0 -2769
- package/dist/cjs/js/src/yobit.js +0 -1314
- package/dist/cjs/js/src/zaif.js +0 -736
- package/dist/cjs/js/src/zonda.js +0 -1883
- package/dist/cjs/src/abstract/bitpanda.js +0 -9
- package/test.ts +0 -0
- /package/dist/cjs/{js/src/abstract/ace.js → src/abstract/onetrading.js} +0 -0
- /package/dist/cjs/{js/src → src}/pro/coincheck.js +0 -0
- /package/dist/cjs/{js/src → src}/pro/coinone.js +0 -0
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var net = require('net');
|
|
6
|
-
var tls = require('tls');
|
|
7
|
-
var require$$0 = require('events');
|
|
8
|
-
var index = require('../agent-base/index.js');
|
|
9
|
-
|
|
10
|
-
function _interopNamespace(e) {
|
|
11
|
-
if (e && e.__esModule) return e;
|
|
12
|
-
var n = Object.create(null);
|
|
13
|
-
if (e) {
|
|
14
|
-
Object.keys(e).forEach(function (k) {
|
|
15
|
-
if (k !== 'default') {
|
|
16
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
17
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
18
|
-
enumerable: true,
|
|
19
|
-
get: function () { return e[k]; }
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
n["default"] = e;
|
|
25
|
-
return Object.freeze(n);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
var net__namespace = /*#__PURE__*/_interopNamespace(net);
|
|
29
|
-
var tls__namespace = /*#__PURE__*/_interopNamespace(tls);
|
|
30
|
-
|
|
31
|
-
function isHTTPS(protocol) {
|
|
32
|
-
return typeof protocol === 'string' ? /^https:?$/i.test(protocol) : false;
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* The `HttpProxyAgent` implements an HTTP Agent subclass that connects
|
|
36
|
-
* to the specified "HTTP proxy server" in order to proxy HTTP requests.
|
|
37
|
-
*/
|
|
38
|
-
class HttpProxyAgent extends index.Agent {
|
|
39
|
-
constructor(proxy, opts) {
|
|
40
|
-
super(opts);
|
|
41
|
-
this.proxy = typeof proxy === 'string' ? new URL(proxy) : proxy;
|
|
42
|
-
this.proxyHeaders = opts?.headers ?? {};
|
|
43
|
-
// debug('Creating new HttpProxyAgent instance: %o', this.proxy.href);
|
|
44
|
-
// Trim off the brackets from IPv6 addresses
|
|
45
|
-
const host = (this.proxy.hostname || this.proxy.host).replace(/^\[|\]$/g, '');
|
|
46
|
-
const port = this.proxy.port
|
|
47
|
-
? parseInt(this.proxy.port, 10)
|
|
48
|
-
: this.secureProxy
|
|
49
|
-
? 443
|
|
50
|
-
: 80;
|
|
51
|
-
this.connectOpts = {
|
|
52
|
-
...(opts ? omit(opts, 'headers') : null),
|
|
53
|
-
host,
|
|
54
|
-
port,
|
|
55
|
-
};
|
|
56
|
-
}
|
|
57
|
-
get secureProxy() {
|
|
58
|
-
return isHTTPS(this.proxy.protocol);
|
|
59
|
-
}
|
|
60
|
-
async connect(req, opts) {
|
|
61
|
-
const { proxy } = this;
|
|
62
|
-
const protocol = opts.secureEndpoint ? 'https:' : 'http:';
|
|
63
|
-
const hostname = req.getHeader('host') || 'localhost';
|
|
64
|
-
const base = `${protocol}//${hostname}`;
|
|
65
|
-
const url = new URL(req.path, base);
|
|
66
|
-
if (opts.port !== 80) {
|
|
67
|
-
url.port = String(opts.port);
|
|
68
|
-
}
|
|
69
|
-
// Change the `http.ClientRequest` instance's "path" field
|
|
70
|
-
// to the absolute path of the URL that will be requested.
|
|
71
|
-
req.path = String(url);
|
|
72
|
-
// Inject the `Proxy-Authorization` header if necessary.
|
|
73
|
-
req._header = null;
|
|
74
|
-
const headers = typeof this.proxyHeaders === 'function'
|
|
75
|
-
? this.proxyHeaders()
|
|
76
|
-
: { ...this.proxyHeaders };
|
|
77
|
-
if (proxy.username || proxy.password) {
|
|
78
|
-
const auth = `${decodeURIComponent(proxy.username)}:${decodeURIComponent(proxy.password)}`;
|
|
79
|
-
headers['Proxy-Authorization'] = `Basic ${Buffer.from(auth).toString('base64')}`;
|
|
80
|
-
}
|
|
81
|
-
if (!headers['Proxy-Connection']) {
|
|
82
|
-
headers['Proxy-Connection'] = this.keepAlive
|
|
83
|
-
? 'Keep-Alive'
|
|
84
|
-
: 'close';
|
|
85
|
-
}
|
|
86
|
-
for (const name of Object.keys(headers)) {
|
|
87
|
-
const value = headers[name];
|
|
88
|
-
if (value) {
|
|
89
|
-
req.setHeader(name, value);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
// Create a socket connection to the proxy server.
|
|
93
|
-
let socket;
|
|
94
|
-
if (this.secureProxy) {
|
|
95
|
-
// debug('Creating `tls.Socket`: %o', this.connectOpts);
|
|
96
|
-
socket = tls__namespace.connect(this.connectOpts);
|
|
97
|
-
}
|
|
98
|
-
else {
|
|
99
|
-
// debug('Creating `net.Socket`: %o', this.connectOpts);
|
|
100
|
-
socket = net__namespace.connect(this.connectOpts);
|
|
101
|
-
}
|
|
102
|
-
// At this point, the http ClientRequest's internal `_header` field
|
|
103
|
-
// might have already been set. If this is the case then we'll need
|
|
104
|
-
// to re-generate the string since we just changed the `req.path`.
|
|
105
|
-
let first;
|
|
106
|
-
let endOfHeaders;
|
|
107
|
-
// debug('Regenerating stored HTTP header string for request');
|
|
108
|
-
req._implicitHeader();
|
|
109
|
-
if (req.outputData && req.outputData.length > 0) {
|
|
110
|
-
// Node >= 12
|
|
111
|
-
// debug(
|
|
112
|
-
// 'Patching connection write() output buffer with updated header'
|
|
113
|
-
// );
|
|
114
|
-
first = req.outputData[0].data;
|
|
115
|
-
endOfHeaders = first.indexOf('\r\n\r\n') + 4;
|
|
116
|
-
req.outputData[0].data =
|
|
117
|
-
req._header + first.substring(endOfHeaders);
|
|
118
|
-
// debug('Output buffer: %o', req.outputData[0].data);
|
|
119
|
-
}
|
|
120
|
-
// Wait for the socket's `connect` event, so that this `callback()`
|
|
121
|
-
// function throws instead of the `http` request machinery. This is
|
|
122
|
-
// important for i.e. `PacProxyAgent` which determines a failed proxy
|
|
123
|
-
// connection via the `callback()` function throwing.
|
|
124
|
-
await require$$0.once(socket, 'connect');
|
|
125
|
-
return socket;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
HttpProxyAgent.protocols = ['http', 'https'];
|
|
129
|
-
function omit(obj, ...keys) {
|
|
130
|
-
const ret = {};
|
|
131
|
-
let key;
|
|
132
|
-
for (key in obj) {
|
|
133
|
-
if (!keys.includes(key)) {
|
|
134
|
-
ret[key] = obj[key];
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
return ret;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
exports.HttpProxyAgent = HttpProxyAgent;
|
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
var net = require('net');
|
|
6
|
-
var tls = require('tls');
|
|
7
|
-
var assert = require('assert');
|
|
8
|
-
var index = require('../agent-base/index.js');
|
|
9
|
-
var parseProxyResponse = require('./parse-proxy-response.js');
|
|
10
|
-
|
|
11
|
-
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
12
|
-
|
|
13
|
-
function _interopNamespace(e) {
|
|
14
|
-
if (e && e.__esModule) return e;
|
|
15
|
-
var n = Object.create(null);
|
|
16
|
-
if (e) {
|
|
17
|
-
Object.keys(e).forEach(function (k) {
|
|
18
|
-
if (k !== 'default') {
|
|
19
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
20
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
21
|
-
enumerable: true,
|
|
22
|
-
get: function () { return e[k]; }
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
});
|
|
26
|
-
}
|
|
27
|
-
n["default"] = e;
|
|
28
|
-
return Object.freeze(n);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
var net__namespace = /*#__PURE__*/_interopNamespace(net);
|
|
32
|
-
var tls__namespace = /*#__PURE__*/_interopNamespace(tls);
|
|
33
|
-
var assert__default = /*#__PURE__*/_interopDefaultLegacy(assert);
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* The `HttpsProxyAgent` implements an HTTP Agent subclass that connects to
|
|
37
|
-
* the specified "HTTP(s) proxy server" in order to proxy HTTPS requests.
|
|
38
|
-
*
|
|
39
|
-
* Outgoing HTTP requests are first tunneled through the proxy server using the
|
|
40
|
-
* `CONNECT` HTTP request method to establish a connection to the proxy server,
|
|
41
|
-
* and then the proxy server connects to the destination target and issues the
|
|
42
|
-
* HTTP request from the proxy server.
|
|
43
|
-
*
|
|
44
|
-
* `https:` requests have their socket connection upgraded to TLS once
|
|
45
|
-
* the connection to the proxy server has been established.
|
|
46
|
-
*/
|
|
47
|
-
class HttpsProxyAgent extends index.Agent {
|
|
48
|
-
constructor(proxy, opts) {
|
|
49
|
-
super(opts);
|
|
50
|
-
this.options = { path: undefined };
|
|
51
|
-
this.proxy = typeof proxy === 'string' ? new URL(proxy) : proxy;
|
|
52
|
-
this.proxyHeaders = opts?.headers ?? {};
|
|
53
|
-
// debug('Creating new HttpsProxyAgent instance: %o', this.proxy.href);
|
|
54
|
-
// Trim off the brackets from IPv6 addresses
|
|
55
|
-
const host = (this.proxy.hostname || this.proxy.host).replace(/^\[|\]$/g, '');
|
|
56
|
-
const port = this.proxy.port
|
|
57
|
-
? parseInt(this.proxy.port, 10)
|
|
58
|
-
: this.secureProxy
|
|
59
|
-
? 443
|
|
60
|
-
: 80;
|
|
61
|
-
this.connectOpts = {
|
|
62
|
-
// Attempt to negotiate http/1.1 for proxy servers that support http/2
|
|
63
|
-
ALPNProtocols: ['http/1.1'],
|
|
64
|
-
...(opts ? omit(opts, 'headers') : null),
|
|
65
|
-
host,
|
|
66
|
-
port,
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
get secureProxy() {
|
|
70
|
-
return isHTTPS(this.proxy.protocol);
|
|
71
|
-
}
|
|
72
|
-
/**
|
|
73
|
-
* Called when the node-core HTTP client library is creating a
|
|
74
|
-
* new HTTP request.
|
|
75
|
-
*/
|
|
76
|
-
async connect(req, opts) {
|
|
77
|
-
const { proxy, secureProxy } = this;
|
|
78
|
-
if (!opts.host) {
|
|
79
|
-
throw new TypeError('No "host" provided');
|
|
80
|
-
}
|
|
81
|
-
// Create a socket connection to the proxy server.
|
|
82
|
-
let socket;
|
|
83
|
-
if (secureProxy) {
|
|
84
|
-
// debug('Creating `tls.Socket`: %o', this.connectOpts);
|
|
85
|
-
socket = tls__namespace.connect(this.connectOpts);
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
// debug('Creating `net.Socket`: %o', this.connectOpts);
|
|
89
|
-
socket = net__namespace.connect(this.connectOpts);
|
|
90
|
-
}
|
|
91
|
-
const headers = typeof this.proxyHeaders === 'function'
|
|
92
|
-
? this.proxyHeaders()
|
|
93
|
-
: { ...this.proxyHeaders };
|
|
94
|
-
const host = net__namespace.isIPv6(opts.host) ? `[${opts.host}]` : opts.host;
|
|
95
|
-
let payload = `CONNECT ${host}:${opts.port} HTTP/1.1\r\n`;
|
|
96
|
-
// Inject the `Proxy-Authorization` header if necessary.
|
|
97
|
-
if (proxy.username || proxy.password) {
|
|
98
|
-
const auth = `${decodeURIComponent(proxy.username)}:${decodeURIComponent(proxy.password)}`;
|
|
99
|
-
headers['Proxy-Authorization'] = `Basic ${Buffer.from(auth).toString('base64')}`;
|
|
100
|
-
}
|
|
101
|
-
headers.Host = `${host}:${opts.port}`;
|
|
102
|
-
if (!headers['Proxy-Connection']) {
|
|
103
|
-
headers['Proxy-Connection'] = this.keepAlive
|
|
104
|
-
? 'Keep-Alive'
|
|
105
|
-
: 'close';
|
|
106
|
-
}
|
|
107
|
-
for (const name of Object.keys(headers)) {
|
|
108
|
-
payload += `${name}: ${headers[name]}\r\n`;
|
|
109
|
-
}
|
|
110
|
-
const proxyResponsePromise = parseProxyResponse.parseProxyResponse(socket);
|
|
111
|
-
socket.write(`${payload}\r\n`);
|
|
112
|
-
const { connect, buffered } = await proxyResponsePromise;
|
|
113
|
-
req.emit('proxyConnect', connect);
|
|
114
|
-
// @ts-ignore
|
|
115
|
-
this.emit('proxyConnect', connect, req);
|
|
116
|
-
if (connect.statusCode === 200) {
|
|
117
|
-
req.once('socket', resume);
|
|
118
|
-
if (opts.secureEndpoint) {
|
|
119
|
-
// The proxy is connecting to a TLS server, so upgrade
|
|
120
|
-
// this socket connection to a TLS connection.
|
|
121
|
-
// debug('Upgrading socket connection to TLS');
|
|
122
|
-
const servername = opts.servername || opts.host;
|
|
123
|
-
return tls__namespace.connect({
|
|
124
|
-
...omit(opts, 'host', 'path', 'port'),
|
|
125
|
-
socket,
|
|
126
|
-
servername: net__namespace.isIP(servername) ? undefined : servername,
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
return socket;
|
|
130
|
-
}
|
|
131
|
-
// Some other status code that's not 200... need to re-play the HTTP
|
|
132
|
-
// header "data" events onto the socket once the HTTP machinery is
|
|
133
|
-
// attached so that the node core `http` can parse and handle the
|
|
134
|
-
// error status code.
|
|
135
|
-
// Close the original socket, and a new "fake" socket is returned
|
|
136
|
-
// instead, so that the proxy doesn't get the HTTP request
|
|
137
|
-
// written to it (which may contain `Authorization` headers or other
|
|
138
|
-
// sensitive data).
|
|
139
|
-
//
|
|
140
|
-
// See: https://hackerone.com/reports/541502
|
|
141
|
-
socket.destroy();
|
|
142
|
-
const fakeSocket = new net__namespace.Socket({ writable: false });
|
|
143
|
-
fakeSocket.readable = true;
|
|
144
|
-
// Need to wait for the "socket" event to re-play the "data" events.
|
|
145
|
-
req.once('socket', (s) => {
|
|
146
|
-
// debug('Replaying proxy buffer for failed request');
|
|
147
|
-
assert__default["default"](s.listenerCount('data') > 0);
|
|
148
|
-
// Replay the "buffered" Buffer onto the fake `socket`, since at
|
|
149
|
-
// this point the HTTP module machinery has been hooked up for
|
|
150
|
-
// the user.
|
|
151
|
-
s.push(buffered);
|
|
152
|
-
s.push(null);
|
|
153
|
-
});
|
|
154
|
-
return fakeSocket;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
HttpsProxyAgent.protocols = ['http', 'https'];
|
|
158
|
-
function resume(socket) {
|
|
159
|
-
socket.resume();
|
|
160
|
-
}
|
|
161
|
-
function isHTTPS(protocol) {
|
|
162
|
-
return typeof protocol === 'string' ? /^https:?$/i.test(protocol) : false;
|
|
163
|
-
}
|
|
164
|
-
function omit(obj, ...keys) {
|
|
165
|
-
const ret = {};
|
|
166
|
-
let key;
|
|
167
|
-
for (key in obj) {
|
|
168
|
-
if (!keys.includes(key)) {
|
|
169
|
-
ret[key] = obj[key];
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
return ret;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
exports.HttpsProxyAgent = HttpsProxyAgent;
|
package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js
DELETED
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
-
|
|
5
|
-
function parseProxyResponse(socket) {
|
|
6
|
-
return new Promise((resolve, reject) => {
|
|
7
|
-
// we need to buffer any HTTP traffic that happens with the proxy before we get
|
|
8
|
-
// the CONNECT response, so that if the response is anything other than an "200"
|
|
9
|
-
// response code, then we can re-play the "data" events on the socket once the
|
|
10
|
-
// HTTP parser is hooked up...
|
|
11
|
-
let buffersLength = 0;
|
|
12
|
-
const buffers = [];
|
|
13
|
-
function read() {
|
|
14
|
-
const b = socket.read();
|
|
15
|
-
if (b)
|
|
16
|
-
ondata(b);
|
|
17
|
-
else
|
|
18
|
-
socket.once('readable', read);
|
|
19
|
-
}
|
|
20
|
-
function cleanup() {
|
|
21
|
-
socket.removeListener('end', onend);
|
|
22
|
-
socket.removeListener('error', onerror);
|
|
23
|
-
socket.removeListener('close', onclose);
|
|
24
|
-
socket.removeListener('readable', read);
|
|
25
|
-
}
|
|
26
|
-
function onclose(err) {
|
|
27
|
-
// debug('onclose had error %o', err);
|
|
28
|
-
}
|
|
29
|
-
function onend() {
|
|
30
|
-
// debug('onend');
|
|
31
|
-
}
|
|
32
|
-
function onerror(err) {
|
|
33
|
-
cleanup();
|
|
34
|
-
// debug('onerror %o', err);
|
|
35
|
-
reject(err);
|
|
36
|
-
}
|
|
37
|
-
function ondata(b) {
|
|
38
|
-
buffers.push(b);
|
|
39
|
-
buffersLength += b.length;
|
|
40
|
-
const buffered = Buffer.concat(buffers, buffersLength);
|
|
41
|
-
const endOfHeaders = buffered.indexOf('\r\n\r\n');
|
|
42
|
-
if (endOfHeaders === -1) {
|
|
43
|
-
// keep buffering
|
|
44
|
-
// debug('have not received end of HTTP headers yet...');
|
|
45
|
-
read();
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
const headerParts = buffered.toString('ascii').split('\r\n');
|
|
49
|
-
const firstLine = headerParts.shift();
|
|
50
|
-
if (!firstLine) {
|
|
51
|
-
throw new Error('No header received');
|
|
52
|
-
}
|
|
53
|
-
const firstLineParts = firstLine.split(' ');
|
|
54
|
-
const statusCode = +firstLineParts[1];
|
|
55
|
-
const statusText = firstLineParts.slice(2).join(' ');
|
|
56
|
-
const headers = {};
|
|
57
|
-
for (const header of headerParts) {
|
|
58
|
-
if (!header)
|
|
59
|
-
continue;
|
|
60
|
-
const firstColon = header.indexOf(':');
|
|
61
|
-
if (firstColon === -1) {
|
|
62
|
-
throw new Error(`Invalid header: "${header}"`);
|
|
63
|
-
}
|
|
64
|
-
const key = header.slice(0, firstColon).toLowerCase();
|
|
65
|
-
const value = header.slice(firstColon + 1).trimStart();
|
|
66
|
-
const current = headers[key];
|
|
67
|
-
if (typeof current === 'string') {
|
|
68
|
-
headers[key] = [current, value];
|
|
69
|
-
}
|
|
70
|
-
else if (Array.isArray(current)) {
|
|
71
|
-
current.push(value);
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
headers[key] = value;
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
// debug('got proxy server response: %o', firstLine);
|
|
78
|
-
cleanup();
|
|
79
|
-
resolve({
|
|
80
|
-
connect: {
|
|
81
|
-
statusCode,
|
|
82
|
-
statusText,
|
|
83
|
-
headers,
|
|
84
|
-
},
|
|
85
|
-
buffered,
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
socket.on('error', onerror);
|
|
89
|
-
socket.on('close', onclose);
|
|
90
|
-
socket.on('end', onend);
|
|
91
|
-
read();
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
exports.parseProxyResponse = parseProxyResponse;
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var _commonjsHelpers = require('../../../../_virtual/_commonjsHelpers.js');
|
|
4
|
-
|
|
5
|
-
var qs = _commonjsHelpers.commonjsRequire("/$$rollup_base$$/js/src/static_dependencies/qs/index.cjs", "/$$rollup_base$$/js/src/static_dependencies/qs");
|
|
6
|
-
|
|
7
|
-
module.exports = qs;
|