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.
Files changed (392) hide show
  1. package/README.md +5 -5
  2. package/build.sh +2 -2
  3. package/dist/ccxt.browser.js +1347 -490
  4. package/dist/ccxt.browser.min.js +3 -3
  5. package/dist/cjs/_virtual/agent.js +7 -0
  6. package/dist/cjs/_virtual/parse-proxy-response.js +7 -0
  7. package/dist/cjs/_virtual/promisify.js +7 -0
  8. package/dist/cjs/ccxt.js +1 -1
  9. package/dist/cjs/js/ccxt.js +474 -0
  10. package/dist/cjs/js/src/abstract/ace.js +9 -0
  11. package/dist/cjs/js/src/abstract/alpaca.js +9 -0
  12. package/dist/cjs/js/src/abstract/ascendex.js +9 -0
  13. package/dist/cjs/js/src/abstract/bigone.js +9 -0
  14. package/dist/cjs/js/src/abstract/binance.js +9 -0
  15. package/dist/cjs/js/src/abstract/bingx.js +9 -0
  16. package/dist/cjs/js/src/abstract/bit2c.js +9 -0
  17. package/dist/cjs/js/src/abstract/bitbank.js +9 -0
  18. package/dist/cjs/js/src/abstract/bitbns.js +9 -0
  19. package/dist/cjs/js/src/abstract/bitfinex.js +9 -0
  20. package/dist/cjs/js/src/abstract/bitfinex2.js +9 -0
  21. package/dist/cjs/js/src/abstract/bitflyer.js +9 -0
  22. package/dist/cjs/js/src/abstract/bitforex.js +9 -0
  23. package/dist/cjs/js/src/abstract/bitget.js +9 -0
  24. package/dist/cjs/js/src/abstract/bithumb.js +9 -0
  25. package/dist/cjs/js/src/abstract/bitmart.js +9 -0
  26. package/dist/cjs/js/src/abstract/bitmex.js +9 -0
  27. package/dist/cjs/js/src/abstract/bitopro.js +9 -0
  28. package/dist/cjs/js/src/abstract/bitpanda.js +9 -0
  29. package/dist/cjs/js/src/abstract/bitrue.js +9 -0
  30. package/dist/cjs/js/src/abstract/bitso.js +9 -0
  31. package/dist/cjs/js/src/abstract/bitstamp.js +9 -0
  32. package/dist/cjs/js/src/abstract/bitteam.js +9 -0
  33. package/dist/cjs/js/src/abstract/bitvavo.js +9 -0
  34. package/dist/cjs/js/src/abstract/bl3p.js +9 -0
  35. package/dist/cjs/js/src/abstract/blockchaincom.js +9 -0
  36. package/dist/cjs/js/src/abstract/btcalpha.js +9 -0
  37. package/dist/cjs/js/src/abstract/btcbox.js +9 -0
  38. package/dist/cjs/js/src/abstract/btcmarkets.js +9 -0
  39. package/dist/cjs/js/src/abstract/btcturk.js +9 -0
  40. package/dist/cjs/js/src/abstract/bybit.js +9 -0
  41. package/dist/cjs/js/src/abstract/cex.js +9 -0
  42. package/dist/cjs/js/src/abstract/coinbase.js +9 -0
  43. package/dist/cjs/js/src/abstract/coinbasepro.js +9 -0
  44. package/dist/cjs/js/src/abstract/coincheck.js +9 -0
  45. package/dist/cjs/js/src/abstract/coinex.js +9 -0
  46. package/dist/cjs/js/src/abstract/coinlist.js +9 -0
  47. package/dist/cjs/js/src/abstract/coinmate.js +9 -0
  48. package/dist/cjs/js/src/abstract/coinone.js +9 -0
  49. package/dist/cjs/js/src/abstract/coinsph.js +9 -0
  50. package/dist/cjs/js/src/abstract/coinspot.js +9 -0
  51. package/dist/cjs/js/src/abstract/cryptocom.js +9 -0
  52. package/dist/cjs/js/src/abstract/currencycom.js +9 -0
  53. package/dist/cjs/js/src/abstract/delta.js +9 -0
  54. package/dist/cjs/js/src/abstract/deribit.js +9 -0
  55. package/dist/cjs/js/src/abstract/digifinex.js +9 -0
  56. package/dist/cjs/js/src/abstract/exmo.js +9 -0
  57. package/dist/cjs/js/src/abstract/gate.js +9 -0
  58. package/dist/cjs/js/src/abstract/gemini.js +9 -0
  59. package/dist/cjs/js/src/abstract/hitbtc.js +9 -0
  60. package/dist/cjs/js/src/abstract/hollaex.js +9 -0
  61. package/dist/cjs/js/src/abstract/htx.js +9 -0
  62. package/dist/cjs/js/src/abstract/huobijp.js +9 -0
  63. package/dist/cjs/js/src/abstract/idex.js +9 -0
  64. package/dist/cjs/js/src/abstract/independentreserve.js +9 -0
  65. package/dist/cjs/js/src/abstract/indodax.js +9 -0
  66. package/dist/cjs/js/src/abstract/kraken.js +9 -0
  67. package/dist/cjs/js/src/abstract/krakenfutures.js +9 -0
  68. package/dist/cjs/js/src/abstract/kucoin.js +9 -0
  69. package/dist/cjs/js/src/abstract/kucoinfutures.js +9 -0
  70. package/dist/cjs/js/src/abstract/kuna.js +9 -0
  71. package/dist/cjs/js/src/abstract/latoken.js +9 -0
  72. package/dist/cjs/js/src/abstract/lbank.js +9 -0
  73. package/dist/cjs/js/src/abstract/luno.js +9 -0
  74. package/dist/cjs/js/src/abstract/lykke.js +9 -0
  75. package/dist/cjs/js/src/abstract/mercado.js +9 -0
  76. package/dist/cjs/js/src/abstract/mexc.js +9 -0
  77. package/dist/cjs/js/src/abstract/ndax.js +9 -0
  78. package/dist/cjs/js/src/abstract/novadax.js +9 -0
  79. package/dist/cjs/js/src/abstract/oceanex.js +9 -0
  80. package/dist/cjs/js/src/abstract/okcoin.js +9 -0
  81. package/dist/cjs/js/src/abstract/okx.js +9 -0
  82. package/dist/cjs/js/src/abstract/p2b.js +9 -0
  83. package/dist/cjs/js/src/abstract/paymium.js +9 -0
  84. package/dist/cjs/js/src/abstract/phemex.js +9 -0
  85. package/dist/cjs/js/src/abstract/poloniex.js +9 -0
  86. package/dist/cjs/js/src/abstract/poloniexfutures.js +9 -0
  87. package/dist/cjs/js/src/abstract/probit.js +9 -0
  88. package/dist/cjs/js/src/abstract/timex.js +9 -0
  89. package/dist/cjs/js/src/abstract/tokocrypto.js +9 -0
  90. package/dist/cjs/js/src/abstract/upbit.js +9 -0
  91. package/dist/cjs/js/src/abstract/wavesexchange.js +9 -0
  92. package/dist/cjs/js/src/abstract/wazirx.js +9 -0
  93. package/dist/cjs/js/src/abstract/whitebit.js +9 -0
  94. package/dist/cjs/js/src/abstract/woo.js +9 -0
  95. package/dist/cjs/js/src/abstract/yobit.js +9 -0
  96. package/dist/cjs/js/src/abstract/zaif.js +9 -0
  97. package/dist/cjs/js/src/abstract/zonda.js +9 -0
  98. package/dist/cjs/js/src/ace.js +1058 -0
  99. package/dist/cjs/js/src/alpaca.js +1125 -0
  100. package/dist/cjs/js/src/ascendex.js +3360 -0
  101. package/dist/cjs/js/src/base/Exchange.js +5110 -0
  102. package/dist/cjs/js/src/base/Precise.js +263 -0
  103. package/dist/cjs/js/src/base/errors.js +299 -0
  104. package/dist/cjs/js/src/base/functions/crypto.js +78 -0
  105. package/dist/cjs/js/src/base/functions/encode.js +44 -0
  106. package/dist/cjs/js/src/base/functions/generic.js +193 -0
  107. package/dist/cjs/js/src/base/functions/misc.js +96 -0
  108. package/dist/cjs/js/src/base/functions/number.js +297 -0
  109. package/dist/cjs/js/src/base/functions/platform.js +28 -0
  110. package/dist/cjs/js/src/base/functions/rsa.js +34 -0
  111. package/dist/cjs/js/src/base/functions/string.js +48 -0
  112. package/dist/cjs/js/src/base/functions/throttle.js +66 -0
  113. package/dist/cjs/js/src/base/functions/time.js +187 -0
  114. package/dist/cjs/js/src/base/functions/totp.js +24 -0
  115. package/dist/cjs/js/src/base/functions/type.js +162 -0
  116. package/dist/cjs/js/src/base/functions.js +157 -0
  117. package/dist/cjs/js/src/base/ws/Cache.js +254 -0
  118. package/dist/cjs/js/src/base/ws/Client.js +299 -0
  119. package/dist/cjs/js/src/base/ws/Future.js +34 -0
  120. package/dist/cjs/js/src/base/ws/OrderBook.js +107 -0
  121. package/dist/cjs/js/src/base/ws/OrderBookSide.js +281 -0
  122. package/dist/cjs/js/src/base/ws/WsClient.js +69 -0
  123. package/dist/cjs/js/src/bequant.js +33 -0
  124. package/dist/cjs/js/src/bigone.js +2209 -0
  125. package/dist/cjs/js/src/binance.js +9736 -0
  126. package/dist/cjs/js/src/binancecoinm.js +45 -0
  127. package/dist/cjs/js/src/binanceus.js +84 -0
  128. package/dist/cjs/js/src/binanceusdm.js +58 -0
  129. package/dist/cjs/js/src/bingx.js +3807 -0
  130. package/dist/cjs/js/src/bit2c.js +916 -0
  131. package/dist/cjs/js/src/bitbank.js +1000 -0
  132. package/dist/cjs/js/src/bitbay.js +17 -0
  133. package/dist/cjs/js/src/bitbns.js +1220 -0
  134. package/dist/cjs/js/src/bitcoincom.js +17 -0
  135. package/dist/cjs/js/src/bitfinex.js +1670 -0
  136. package/dist/cjs/js/src/bitfinex2.js +2990 -0
  137. package/dist/cjs/js/src/bitflyer.js +1045 -0
  138. package/dist/cjs/js/src/bitforex.js +852 -0
  139. package/dist/cjs/js/src/bitget.js +8291 -0
  140. package/dist/cjs/js/src/bithumb.js +1090 -0
  141. package/dist/cjs/js/src/bitmart.js +4454 -0
  142. package/dist/cjs/js/src/bitmex.js +2884 -0
  143. package/dist/cjs/js/src/bitopro.js +1724 -0
  144. package/dist/cjs/js/src/bitpanda.js +2002 -0
  145. package/dist/cjs/js/src/bitrue.js +3253 -0
  146. package/dist/cjs/js/src/bitso.js +1753 -0
  147. package/dist/cjs/js/src/bitstamp.js +2188 -0
  148. package/dist/cjs/js/src/bitteam.js +2309 -0
  149. package/dist/cjs/js/src/bitvavo.js +1968 -0
  150. package/dist/cjs/js/src/bl3p.js +447 -0
  151. package/dist/cjs/js/src/blockchaincom.js +1160 -0
  152. package/dist/cjs/js/src/btcalpha.js +929 -0
  153. package/dist/cjs/js/src/btcbox.js +565 -0
  154. package/dist/cjs/js/src/btcmarkets.js +1237 -0
  155. package/dist/cjs/js/src/btcturk.js +929 -0
  156. package/dist/cjs/js/src/bybit.js +7646 -0
  157. package/dist/cjs/js/src/cex.js +1693 -0
  158. package/dist/cjs/js/src/coinbase.js +3424 -0
  159. package/dist/cjs/js/src/coinbasepro.js +1866 -0
  160. package/dist/cjs/js/src/coincheck.js +843 -0
  161. package/dist/cjs/js/src/coinex.js +5414 -0
  162. package/dist/cjs/js/src/coinlist.js +2329 -0
  163. package/dist/cjs/js/src/coinmate.js +989 -0
  164. package/dist/cjs/js/src/coinone.js +1185 -0
  165. package/dist/cjs/js/src/coinsph.js +1933 -0
  166. package/dist/cjs/js/src/coinspot.js +548 -0
  167. package/dist/cjs/js/src/cryptocom.js +3007 -0
  168. package/dist/cjs/js/src/currencycom.js +2015 -0
  169. package/dist/cjs/js/src/delta.js +3256 -0
  170. package/dist/cjs/js/src/deribit.js +3306 -0
  171. package/dist/cjs/js/src/digifinex.js +4307 -0
  172. package/dist/cjs/js/src/exmo.js +2645 -0
  173. package/dist/cjs/js/src/fmfwio.js +34 -0
  174. package/dist/cjs/js/src/gate.js +7072 -0
  175. package/dist/cjs/js/src/gateio.js +16 -0
  176. package/dist/cjs/js/src/gemini.js +1801 -0
  177. package/dist/cjs/js/src/hitbtc.js +3660 -0
  178. package/dist/cjs/js/src/hitbtc3.js +19 -0
  179. package/dist/cjs/js/src/hollaex.js +1882 -0
  180. package/dist/cjs/js/src/htx.js +9049 -0
  181. package/dist/cjs/js/src/huobi.js +16 -0
  182. package/dist/cjs/js/src/huobijp.js +1918 -0
  183. package/dist/cjs/js/src/idex.js +1770 -0
  184. package/dist/cjs/js/src/independentreserve.js +761 -0
  185. package/dist/cjs/js/src/indodax.js +1069 -0
  186. package/dist/cjs/js/src/kraken.js +2857 -0
  187. package/dist/cjs/js/src/krakenfutures.js +2407 -0
  188. package/dist/cjs/js/src/kucoin.js +4489 -0
  189. package/dist/cjs/js/src/kucoinfutures.js +2475 -0
  190. package/dist/cjs/js/src/kuna.js +1949 -0
  191. package/dist/cjs/js/src/latoken.js +1729 -0
  192. package/dist/cjs/js/src/lbank.js +2851 -0
  193. package/dist/cjs/js/src/luno.js +1044 -0
  194. package/dist/cjs/js/src/lykke.js +1303 -0
  195. package/dist/cjs/js/src/mercado.js +897 -0
  196. package/dist/cjs/js/src/mexc.js +5407 -0
  197. package/dist/cjs/js/src/ndax.js +2450 -0
  198. package/dist/cjs/js/src/novadax.js +1556 -0
  199. package/dist/cjs/js/src/oceanex.js +964 -0
  200. package/dist/cjs/js/src/okcoin.js +3115 -0
  201. package/dist/cjs/js/src/okx.js +7330 -0
  202. package/dist/cjs/js/src/p2b.js +1243 -0
  203. package/dist/cjs/js/src/paymium.js +597 -0
  204. package/dist/cjs/js/src/phemex.js +4722 -0
  205. package/dist/cjs/js/src/poloniex.js +2356 -0
  206. package/dist/cjs/js/src/poloniexfutures.js +1794 -0
  207. package/dist/cjs/js/src/pro/alpaca.js +714 -0
  208. package/dist/cjs/js/src/pro/ascendex.js +957 -0
  209. package/dist/cjs/js/src/pro/bequant.js +33 -0
  210. package/dist/cjs/js/src/pro/binance.js +2796 -0
  211. package/dist/cjs/js/src/pro/binancecoinm.js +23 -0
  212. package/dist/cjs/js/src/pro/binanceus.js +51 -0
  213. package/dist/cjs/js/src/pro/binanceusdm.js +32 -0
  214. package/dist/cjs/js/src/pro/bingx.js +944 -0
  215. package/dist/cjs/js/src/pro/bitcoincom.js +29 -0
  216. package/dist/cjs/js/src/pro/bitfinex.js +672 -0
  217. package/dist/cjs/js/src/pro/bitfinex2.js +1159 -0
  218. package/dist/cjs/js/src/pro/bitget.js +1733 -0
  219. package/dist/cjs/js/src/pro/bitmart.js +1486 -0
  220. package/dist/cjs/js/src/pro/bitmex.js +1576 -0
  221. package/dist/cjs/js/src/pro/bitopro.js +327 -0
  222. package/dist/cjs/js/src/pro/bitpanda.js +1341 -0
  223. package/dist/cjs/js/src/pro/bitrue.js +462 -0
  224. package/dist/cjs/js/src/pro/bitstamp.js +547 -0
  225. package/dist/cjs/js/src/pro/bitvavo.js +704 -0
  226. package/dist/cjs/js/src/pro/blockchaincom.js +794 -0
  227. package/dist/cjs/js/src/pro/bybit.js +1843 -0
  228. package/dist/cjs/js/src/pro/cex.js +1510 -0
  229. package/dist/cjs/js/src/pro/coinbase.js +561 -0
  230. package/dist/cjs/js/src/pro/coinbasepro.js +968 -0
  231. package/dist/cjs/js/src/pro/coinex.js +1095 -0
  232. package/dist/cjs/js/src/pro/cryptocom.js +1020 -0
  233. package/dist/cjs/js/src/pro/currencycom.js +563 -0
  234. package/dist/cjs/js/src/pro/deribit.js +825 -0
  235. package/dist/cjs/js/src/pro/exmo.js +658 -0
  236. package/dist/cjs/js/src/pro/gate.js +1316 -0
  237. package/dist/cjs/js/src/pro/gateio.js +16 -0
  238. package/dist/cjs/js/src/pro/gemini.js +649 -0
  239. package/dist/cjs/js/src/pro/hitbtc.js +1293 -0
  240. package/dist/cjs/js/src/pro/hollaex.js +597 -0
  241. package/dist/cjs/js/src/pro/htx.js +2383 -0
  242. package/dist/cjs/js/src/pro/huobi.js +16 -0
  243. package/dist/cjs/js/src/pro/huobijp.js +606 -0
  244. package/dist/cjs/js/src/pro/idex.js +714 -0
  245. package/dist/cjs/js/src/pro/independentreserve.js +280 -0
  246. package/dist/cjs/js/src/pro/kraken.js +1364 -0
  247. package/dist/cjs/js/src/pro/krakenfutures.js +1500 -0
  248. package/dist/cjs/js/src/pro/kucoin.js +1052 -0
  249. package/dist/cjs/js/src/pro/kucoinfutures.js +981 -0
  250. package/dist/cjs/js/src/pro/luno.js +322 -0
  251. package/dist/cjs/js/src/pro/mexc.js +1170 -0
  252. package/dist/cjs/js/src/pro/ndax.js +545 -0
  253. package/dist/cjs/js/src/pro/okcoin.js +760 -0
  254. package/dist/cjs/js/src/pro/okx.js +1608 -0
  255. package/dist/cjs/js/src/pro/phemex.js +1511 -0
  256. package/dist/cjs/js/src/pro/poloniex.js +1253 -0
  257. package/dist/cjs/js/src/pro/poloniexfutures.js +1014 -0
  258. package/dist/cjs/js/src/pro/probit.js +586 -0
  259. package/dist/cjs/js/src/pro/upbit.js +234 -0
  260. package/dist/cjs/js/src/pro/wazirx.js +776 -0
  261. package/dist/cjs/js/src/pro/whitebit.js +927 -0
  262. package/dist/cjs/js/src/pro/woo.js +769 -0
  263. package/dist/cjs/js/src/probit.js +1867 -0
  264. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +401 -0
  265. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +195 -0
  266. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +308 -0
  267. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +554 -0
  268. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
  269. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
  270. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
  271. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +16 -0
  272. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1760 -0
  273. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +52 -0
  274. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +81 -0
  275. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +376 -0
  276. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +70 -0
  277. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1580 -0
  278. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +74 -0
  279. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +24 -0
  280. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +158 -0
  281. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +429 -0
  282. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +176 -0
  283. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +324 -0
  284. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +163 -0
  285. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +245 -0
  286. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +1018 -0
  287. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +383 -0
  288. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +258 -0
  289. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +53 -0
  290. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +120 -0
  291. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +69 -0
  292. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +7 -0
  293. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +83 -0
  294. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +240 -0
  295. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +91 -0
  296. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +130 -0
  297. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +214 -0
  298. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +239 -0
  299. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +93 -0
  300. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +354 -0
  301. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +16 -0
  302. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +20 -0
  303. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +30 -0
  304. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +239 -0
  305. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +372 -0
  306. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +273 -0
  307. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +139 -0
  308. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +14 -0
  309. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +16 -0
  310. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +81 -0
  311. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +292 -0
  312. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +103 -0
  313. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +140 -0
  314. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +175 -0
  315. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
  316. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +7 -0
  317. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +383 -0
  318. package/dist/cjs/js/src/timex.js +1562 -0
  319. package/dist/cjs/js/src/tokocrypto.js +2542 -0
  320. package/dist/cjs/js/src/upbit.js +1844 -0
  321. package/dist/cjs/js/src/wavesexchange.js +2607 -0
  322. package/dist/cjs/js/src/wazirx.js +953 -0
  323. package/dist/cjs/js/src/whitebit.js +2309 -0
  324. package/dist/cjs/js/src/woo.js +2765 -0
  325. package/dist/cjs/js/src/yobit.js +1314 -0
  326. package/dist/cjs/js/src/zaif.js +736 -0
  327. package/dist/cjs/js/src/zonda.js +1883 -0
  328. package/js/ccxt.d.ts +1 -1
  329. package/js/ccxt.js +1 -1
  330. package/js/src/abstract/bigone.d.ts +18 -0
  331. package/js/src/abstract/binance.d.ts +2 -0
  332. package/js/src/abstract/binancecoinm.d.ts +2 -0
  333. package/js/src/abstract/binanceus.d.ts +2 -0
  334. package/js/src/abstract/binanceusdm.d.ts +2 -0
  335. package/js/src/abstract/bingx.d.ts +2 -0
  336. package/js/src/abstract/bybit.d.ts +1 -0
  337. package/js/src/abstract/gate.d.ts +11 -0
  338. package/js/src/abstract/gateio.d.ts +11 -0
  339. package/js/src/abstract/okx.d.ts +1 -0
  340. package/js/src/alpaca.js +18 -18
  341. package/js/src/base/Exchange.d.ts +5 -1
  342. package/js/src/base/Exchange.js +101 -12
  343. package/js/src/bigone.d.ts +3 -2
  344. package/js/src/bigone.js +429 -167
  345. package/js/src/binance.js +48 -34
  346. package/js/src/bingx.js +115 -38
  347. package/js/src/bitfinex.d.ts +2 -2
  348. package/js/src/bitfinex.js +2 -3
  349. package/js/src/bitget.js +33 -13
  350. package/js/src/bitmart.d.ts +2 -2
  351. package/js/src/bitmart.js +5 -5
  352. package/js/src/bitmex.js +1 -0
  353. package/js/src/bybit.js +2 -0
  354. package/js/src/coinbase.d.ts +26 -3
  355. package/js/src/coinbase.js +176 -26
  356. package/js/src/coinlist.js +3 -4
  357. package/js/src/coinone.js +1 -1
  358. package/js/src/coinsph.js +2 -3
  359. package/js/src/deribit.js +1 -0
  360. package/js/src/gate.d.ts +4 -4
  361. package/js/src/gate.js +96 -59
  362. package/js/src/gemini.js +1 -1
  363. package/js/src/hitbtc.d.ts +4 -4
  364. package/js/src/hitbtc.js +2 -3
  365. package/js/src/htx.d.ts +1 -0
  366. package/js/src/htx.js +29 -7
  367. package/js/src/huobijp.js +2 -3
  368. package/js/src/independentreserve.js +7 -5
  369. package/js/src/kraken.js +3 -6
  370. package/js/src/lbank.js +59 -33
  371. package/js/src/mexc.js +2 -1
  372. package/js/src/oceanex.js +1 -1
  373. package/js/src/okx.js +14 -3
  374. package/js/src/phemex.js +9 -2
  375. package/js/src/pro/binance.d.ts +2 -23
  376. package/js/src/pro/binance.js +58 -22
  377. package/js/src/pro/coinbase.d.ts +2 -2
  378. package/js/src/pro/coinbase.js +4 -1
  379. package/js/src/pro/coinbasepro.d.ts +2 -2
  380. package/js/src/pro/hitbtc.d.ts +2 -2
  381. package/js/src/pro/kraken.js +1 -1
  382. package/js/src/pro/okx.d.ts +1 -0
  383. package/js/src/pro/okx.js +52 -2
  384. package/js/src/pro/poloniex.d.ts +2 -2
  385. package/js/src/probit.js +4 -2
  386. package/js/src/upbit.d.ts +3 -101
  387. package/js/src/upbit.js +12 -12
  388. package/js/src/wavesexchange.js +1 -1
  389. package/js/src/woo.d.ts +2 -0
  390. package/js/src/woo.js +52 -0
  391. package/package.json +1 -1
  392. package/skip-tests.json +5 -0
@@ -0,0 +1,372 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var http = require('node:http');
6
+ var https = require('node:https');
7
+ var zlib = require('node:zlib');
8
+ var Stream = require('node:stream');
9
+ var node_buffer = require('node:buffer');
10
+ var body = require('./body.js');
11
+ var response = require('./response.js');
12
+ var headers = require('./headers.js');
13
+ var request = require('./request.js');
14
+ var fetchError = require('./errors/fetch-error.js');
15
+ var abortError = require('./errors/abort-error.js');
16
+ var isRedirect = require('./utils/is-redirect.js');
17
+ var is = require('./utils/is.js');
18
+ var referrer = require('./utils/referrer.js');
19
+
20
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
21
+
22
+ var http__default = /*#__PURE__*/_interopDefaultLegacy(http);
23
+ var https__default = /*#__PURE__*/_interopDefaultLegacy(https);
24
+ var zlib__default = /*#__PURE__*/_interopDefaultLegacy(zlib);
25
+ var Stream__default = /*#__PURE__*/_interopDefaultLegacy(Stream);
26
+
27
+ /**
28
+ * Index.js
29
+ *
30
+ * a request API compatible with window.fetch
31
+ *
32
+ * All spec algorithm step numbers are based on https://fetch.spec.whatwg.org/commit-snapshots/ae716822cb3a61843226cd090eefc6589446c1d2/.
33
+ */
34
+ const supportedSchemas = new Set(['data:', 'http:', 'https:']);
35
+ /**
36
+ * Fetch function
37
+ *
38
+ * @param {string | URL | import('./request').default} url - Absolute url or Request instance
39
+ * @param {*} [options_] - Fetch options
40
+ * @return {Promise<import('./response').default>}
41
+ */
42
+ async function fetch(url, options_) {
43
+ return new Promise((resolve, reject) => {
44
+ // Build request object
45
+ const request$1 = new request["default"](url, options_);
46
+ const { parsedURL, options } = request.getNodeRequestOptions(request$1);
47
+ if (!supportedSchemas.has(parsedURL.protocol)) {
48
+ throw new TypeError(`node-fetch cannot load ${url}. URL scheme "${parsedURL.protocol.replace(/:$/, '')}" is not supported.`);
49
+ }
50
+ /*if (parsedURL.protocol === 'data:') {
51
+ const data = dataUriToBuffer(request.url);
52
+ const response = new Response(data, {headers: {'Content-Type': data.typeFull}});
53
+ resolve(response);
54
+ return;
55
+ }*/
56
+ // Wrap http.request into fetch
57
+ const send = (parsedURL.protocol === 'https:' ? https__default["default"] : http__default["default"]).request;
58
+ const { signal } = request$1;
59
+ let response$1 = null;
60
+ const abort = () => {
61
+ const error = new abortError.AbortError('The operation was aborted.');
62
+ reject(error);
63
+ if (request$1.body && request$1.body instanceof Stream__default["default"].Readable) {
64
+ request$1.body.destroy(error);
65
+ }
66
+ if (!response$1 || !response$1.body) {
67
+ return;
68
+ }
69
+ response$1.body.emit('error', error);
70
+ };
71
+ if (signal && signal.aborted) {
72
+ abort();
73
+ return;
74
+ }
75
+ const abortAndFinalize = () => {
76
+ abort();
77
+ finalize();
78
+ };
79
+ // Send request
80
+ const request_ = send(parsedURL.toString(), options);
81
+ if (signal) {
82
+ signal.addEventListener('abort', abortAndFinalize);
83
+ }
84
+ const finalize = () => {
85
+ request_.abort();
86
+ if (signal) {
87
+ signal.removeEventListener('abort', abortAndFinalize);
88
+ }
89
+ };
90
+ request_.on('error', error => {
91
+ reject(new fetchError.FetchError(`request to ${request$1.url} failed, reason: ${error.message}`, 'system', error));
92
+ finalize();
93
+ });
94
+ fixResponseChunkedTransferBadEnding(request_, error => {
95
+ if (response$1 && response$1.body) {
96
+ response$1.body.destroy(error);
97
+ }
98
+ });
99
+ /* c8 ignore next 18 */
100
+ if (process.version < 'v14') {
101
+ // Before Node.js 14, pipeline() does not fully support async iterators and does not always
102
+ // properly handle when the socket close/end events are out of order.
103
+ request_.on('socket', s => {
104
+ let endedWithEventsCount;
105
+ s.prependListener('end', () => {
106
+ endedWithEventsCount = s._eventsCount;
107
+ });
108
+ s.prependListener('close', hadError => {
109
+ // if end happened before close but the socket didn't emit an error, do it now
110
+ if (response$1 && endedWithEventsCount < s._eventsCount && !hadError) {
111
+ const error = new Error('Premature close');
112
+ error.code = 'ERR_STREAM_PREMATURE_CLOSE';
113
+ response$1.body.emit('error', error);
114
+ }
115
+ });
116
+ });
117
+ }
118
+ request_.on('response', response_ => {
119
+ request_.setTimeout(0);
120
+ const headers$1 = headers.fromRawHeaders(response_.rawHeaders);
121
+ // HTTP fetch step 5
122
+ if (isRedirect.isRedirect(response_.statusCode)) {
123
+ // HTTP fetch step 5.2
124
+ const location = headers$1.get('Location');
125
+ // HTTP fetch step 5.3
126
+ let locationURL = null;
127
+ try {
128
+ locationURL = location === null ? null : new URL(location, request$1.url);
129
+ }
130
+ catch {
131
+ // error here can only be invalid URL in Location: header
132
+ // do not throw when options.redirect == manual
133
+ // let the user extract the errorneous redirect URL
134
+ if (request$1.redirect !== 'manual') {
135
+ reject(new fetchError.FetchError(`uri requested responds with an invalid redirect URL: ${location}`, 'invalid-redirect'));
136
+ finalize();
137
+ return;
138
+ }
139
+ }
140
+ // HTTP fetch step 5.5
141
+ switch (request$1.redirect) {
142
+ case 'error':
143
+ reject(new fetchError.FetchError(`uri requested responds with a redirect, redirect mode is set to error: ${request$1.url}`, 'no-redirect'));
144
+ finalize();
145
+ return;
146
+ case 'manual':
147
+ // Nothing to do
148
+ break;
149
+ case 'follow': {
150
+ // HTTP-redirect fetch step 2
151
+ if (locationURL === null) {
152
+ break;
153
+ }
154
+ // HTTP-redirect fetch step 5
155
+ if (request$1.counter >= request$1.follow) {
156
+ reject(new fetchError.FetchError(`maximum redirect reached at: ${request$1.url}`, 'max-redirect'));
157
+ finalize();
158
+ return;
159
+ }
160
+ // HTTP-redirect fetch step 6 (counter increment)
161
+ // Create a new Request object.
162
+ const requestOptions = {
163
+ headers: new headers["default"](request$1.headers),
164
+ follow: request$1.follow,
165
+ counter: request$1.counter + 1,
166
+ agent: request$1.agent,
167
+ compress: request$1.compress,
168
+ method: request$1.method,
169
+ body: body.clone(request$1),
170
+ signal: request$1.signal,
171
+ size: request$1.size,
172
+ referrer: request$1.referrer,
173
+ referrerPolicy: request$1.referrerPolicy
174
+ };
175
+ // when forwarding sensitive headers like "Authorization",
176
+ // "WWW-Authenticate", and "Cookie" to untrusted targets,
177
+ // headers will be ignored when following a redirect to a domain
178
+ // that is not a subdomain match or exact match of the initial domain.
179
+ // For example, a redirect from "foo.com" to either "foo.com" or "sub.foo.com"
180
+ // will forward the sensitive headers, but a redirect to "bar.com" will not.
181
+ // headers will also be ignored when following a redirect to a domain using
182
+ // a different protocol. For example, a redirect from "https://foo.com" to "http://foo.com"
183
+ // will not forward the sensitive headers
184
+ if (!is.isDomainOrSubdomain(request$1.url, locationURL) || !is.isSameProtocol(request$1.url, locationURL)) {
185
+ for (const name of ['authorization', 'www-authenticate', 'cookie', 'cookie2']) {
186
+ requestOptions.headers.delete(name);
187
+ }
188
+ }
189
+ // HTTP-redirect fetch step 9
190
+ if (response_.statusCode !== 303 && request$1.body && options_.body instanceof Stream__default["default"].Readable) {
191
+ reject(new fetchError.FetchError('Cannot follow redirect with body being a readable stream', 'unsupported-redirect'));
192
+ finalize();
193
+ return;
194
+ }
195
+ // HTTP-redirect fetch step 11
196
+ if (response_.statusCode === 303 || ((response_.statusCode === 301 || response_.statusCode === 302) && request$1.method === 'POST')) {
197
+ requestOptions.method = 'GET';
198
+ requestOptions.body = undefined;
199
+ requestOptions.headers.delete('content-length');
200
+ }
201
+ // HTTP-redirect fetch step 14
202
+ const responseReferrerPolicy = referrer.parseReferrerPolicyFromHeader(headers$1);
203
+ if (responseReferrerPolicy) {
204
+ requestOptions.referrerPolicy = responseReferrerPolicy;
205
+ }
206
+ // HTTP-redirect fetch step 15
207
+ resolve(fetch(new request["default"](locationURL, requestOptions)));
208
+ finalize();
209
+ return;
210
+ }
211
+ default:
212
+ return reject(new TypeError(`Redirect option '${request$1.redirect}' is not a valid value of RequestRedirect`));
213
+ }
214
+ }
215
+ // Prepare response
216
+ if (signal) {
217
+ response_.once('end', () => {
218
+ signal.removeEventListener('abort', abortAndFinalize);
219
+ });
220
+ }
221
+ let body$1 = Stream.pipeline(response_, new Stream.PassThrough(), error => {
222
+ if (error) {
223
+ reject(error);
224
+ }
225
+ });
226
+ // see https://github.com/nodejs/node/pull/29376
227
+ /* c8 ignore next 3 */
228
+ if (process.version < 'v12.10') {
229
+ response_.on('aborted', abortAndFinalize);
230
+ }
231
+ const responseOptions = {
232
+ url: request$1.url,
233
+ status: response_.statusCode,
234
+ statusText: response_.statusMessage,
235
+ headers: headers$1,
236
+ size: request$1.size,
237
+ counter: request$1.counter,
238
+ highWaterMark: request$1.highWaterMark
239
+ };
240
+ // HTTP-network fetch step 12.1.1.3
241
+ const codings = headers$1.get('Content-Encoding');
242
+ // HTTP-network fetch step 12.1.1.4: handle content codings
243
+ // in following scenarios we ignore compression support
244
+ // 1. compression support is disabled
245
+ // 2. HEAD request
246
+ // 3. no Content-Encoding header
247
+ // 4. no content response (204)
248
+ // 5. content not modified response (304)
249
+ if (!request$1.compress || request$1.method === 'HEAD' || codings === null || response_.statusCode === 204 || response_.statusCode === 304) {
250
+ response$1 = new response(body$1, responseOptions);
251
+ resolve(response$1);
252
+ return;
253
+ }
254
+ // For Node v6+
255
+ // Be less strict when decoding compressed responses, since sometimes
256
+ // servers send slightly invalid responses that are still accepted
257
+ // by common browsers.
258
+ // Always using Z_SYNC_FLUSH is what cURL does.
259
+ const zlibOptions = {
260
+ flush: zlib__default["default"].Z_SYNC_FLUSH,
261
+ finishFlush: zlib__default["default"].Z_SYNC_FLUSH
262
+ };
263
+ // For gzip
264
+ if (codings === 'gzip' || codings === 'x-gzip') {
265
+ body$1 = Stream.pipeline(body$1, zlib__default["default"].createGunzip(zlibOptions), error => {
266
+ if (error) {
267
+ reject(error);
268
+ }
269
+ });
270
+ response$1 = new response(body$1, responseOptions);
271
+ resolve(response$1);
272
+ return;
273
+ }
274
+ // For deflate
275
+ if (codings === 'deflate' || codings === 'x-deflate') {
276
+ // Handle the infamous raw deflate response from old servers
277
+ // a hack for old IIS and Apache servers
278
+ const raw = Stream.pipeline(response_, new Stream.PassThrough(), error => {
279
+ if (error) {
280
+ reject(error);
281
+ }
282
+ });
283
+ raw.once('data', chunk => {
284
+ // See http://stackoverflow.com/questions/37519828
285
+ if ((chunk[0] & 0x0F) === 0x08) {
286
+ body$1 = Stream.pipeline(body$1, zlib__default["default"].createInflate(), error => {
287
+ if (error) {
288
+ reject(error);
289
+ }
290
+ });
291
+ }
292
+ else {
293
+ body$1 = Stream.pipeline(body$1, zlib__default["default"].createInflateRaw(), error => {
294
+ if (error) {
295
+ reject(error);
296
+ }
297
+ });
298
+ }
299
+ response$1 = new response(body$1, responseOptions);
300
+ resolve(response$1);
301
+ });
302
+ raw.once('end', () => {
303
+ // Some old IIS servers return zero-length OK deflate responses, so
304
+ // 'data' is never emitted. See https://github.com/node-fetch/node-fetch/pull/903
305
+ if (!response$1) {
306
+ response$1 = new response(body$1, responseOptions);
307
+ resolve(response$1);
308
+ }
309
+ });
310
+ return;
311
+ }
312
+ // For br
313
+ if (codings === 'br') {
314
+ body$1 = Stream.pipeline(body$1, zlib__default["default"].createBrotliDecompress(), error => {
315
+ if (error) {
316
+ reject(error);
317
+ }
318
+ });
319
+ response$1 = new response(body$1, responseOptions);
320
+ resolve(response$1);
321
+ return;
322
+ }
323
+ // Otherwise, use response as-is
324
+ response$1 = new response(body$1, responseOptions);
325
+ resolve(response$1);
326
+ });
327
+ // eslint-disable-next-line promise/prefer-await-to-then
328
+ body.writeToStream(request_, request$1).catch(reject);
329
+ });
330
+ }
331
+ function fixResponseChunkedTransferBadEnding(request, errorCallback) {
332
+ const LAST_CHUNK = node_buffer.Buffer.from('0\r\n\r\n');
333
+ let isChunkedTransfer = false;
334
+ let properLastChunkReceived = false;
335
+ let previousChunk;
336
+ request.on('response', response => {
337
+ const { headers } = response;
338
+ isChunkedTransfer = headers['transfer-encoding'] === 'chunked' && !headers['content-length'];
339
+ });
340
+ request.on('socket', socket => {
341
+ const onSocketClose = () => {
342
+ if (isChunkedTransfer && !properLastChunkReceived) {
343
+ const error = new Error('Premature close');
344
+ error.code = 'ERR_STREAM_PREMATURE_CLOSE';
345
+ errorCallback(error);
346
+ }
347
+ };
348
+ const onData = buf => {
349
+ properLastChunkReceived = node_buffer.Buffer.compare(buf.slice(-5), LAST_CHUNK) === 0;
350
+ // Sometimes final 0-length chunk and end of message code are in separate packets
351
+ if (!properLastChunkReceived && previousChunk) {
352
+ properLastChunkReceived = (node_buffer.Buffer.compare(previousChunk.slice(-3), LAST_CHUNK.slice(0, 3)) === 0 &&
353
+ node_buffer.Buffer.compare(buf.slice(-2), LAST_CHUNK.slice(3)) === 0);
354
+ }
355
+ previousChunk = buf;
356
+ };
357
+ socket.prependListener('close', onSocketClose);
358
+ socket.on('data', onData);
359
+ request.on('close', () => {
360
+ socket.removeListener('close', onSocketClose);
361
+ socket.removeListener('data', onData);
362
+ });
363
+ });
364
+ }
365
+
366
+ exports.Response = response;
367
+ exports.Headers = headers["default"];
368
+ exports.Request = request["default"];
369
+ exports.FetchError = fetchError.FetchError;
370
+ exports.AbortError = abortError.AbortError;
371
+ exports.isRedirect = isRedirect.isRedirect;
372
+ exports["default"] = fetch;
@@ -0,0 +1,273 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var node_url = require('node:url');
6
+ var node_util = require('node:util');
7
+ var headers = require('./headers.js');
8
+ var body = require('./body.js');
9
+ var is = require('./utils/is.js');
10
+ var getSearch = require('./utils/get-search.js');
11
+ var referrer = require('./utils/referrer.js');
12
+
13
+ /**
14
+ * Request.js
15
+ *
16
+ * Request class contains server only options
17
+ *
18
+ * All spec algorithm step numbers are based on https://fetch.spec.whatwg.org/commit-snapshots/ae716822cb3a61843226cd090eefc6589446c1d2/.
19
+ */
20
+ const INTERNALS = Symbol('Request internals');
21
+ /**
22
+ * Check if `obj` is an instance of Request.
23
+ *
24
+ * @param {*} object
25
+ * @return {boolean}
26
+ */
27
+ const isRequest = object => {
28
+ return (typeof object === 'object' &&
29
+ typeof object[INTERNALS] === 'object');
30
+ };
31
+ const doBadDataWarn = node_util.deprecate(() => { }, '.data is not a valid RequestInit property, use .body instead', 'https://github.com/node-fetch/node-fetch/issues/1000 (request)');
32
+ /**
33
+ * Request class
34
+ *
35
+ * Ref: https://fetch.spec.whatwg.org/#request-class
36
+ *
37
+ * @param Mixed input Url or Request instance
38
+ * @param Object init Custom options
39
+ * @return Void
40
+ */
41
+ class Request extends body["default"] {
42
+ constructor(input, init = {}) {
43
+ let parsedURL;
44
+ // Normalize input and force URL to be encoded as UTF-8 (https://github.com/node-fetch/node-fetch/issues/245)
45
+ if (isRequest(input)) {
46
+ parsedURL = new URL(input.url);
47
+ }
48
+ else {
49
+ parsedURL = new URL(input);
50
+ input = {};
51
+ }
52
+ if (parsedURL.username !== '' || parsedURL.password !== '') {
53
+ throw new TypeError(`${parsedURL} is an url with embedded credentials.`);
54
+ }
55
+ let method = init.method || input.method || 'GET';
56
+ if (/^(delete|get|head|options|post|put)$/i.test(method)) {
57
+ method = method.toUpperCase();
58
+ }
59
+ if (!isRequest(init) && 'data' in init) {
60
+ doBadDataWarn();
61
+ }
62
+ // eslint-disable-next-line no-eq-null, eqeqeq
63
+ if ((init.body != null || (isRequest(input) && input.body !== null)) &&
64
+ (method === 'GET' || method === 'HEAD')) {
65
+ throw new TypeError('Request with GET/HEAD method cannot have body');
66
+ }
67
+ const inputBody = init.body ?
68
+ init.body :
69
+ (isRequest(input) && input.body !== null ?
70
+ body.clone(input) :
71
+ null);
72
+ super(inputBody, {
73
+ size: init.size || input.size || 0
74
+ });
75
+ const headers$1 = new headers["default"](init.headers || input.headers || {});
76
+ if (inputBody !== null && !headers$1.has('Content-Type')) {
77
+ const contentType = body.extractContentType(inputBody);
78
+ if (contentType) {
79
+ headers$1.set('Content-Type', contentType);
80
+ }
81
+ }
82
+ let signal = isRequest(input) ?
83
+ input.signal :
84
+ null;
85
+ if ('signal' in init) {
86
+ signal = init.signal;
87
+ }
88
+ // eslint-disable-next-line no-eq-null, eqeqeq
89
+ if (signal != null && !is.isAbortSignal(signal)) {
90
+ throw new TypeError('Expected signal to be an instanceof AbortSignal or EventTarget');
91
+ }
92
+ // §5.4, Request constructor steps, step 15.1
93
+ // eslint-disable-next-line no-eq-null, eqeqeq
94
+ let referrer = init.referrer == null ? input.referrer : init.referrer;
95
+ if (referrer === '') {
96
+ // §5.4, Request constructor steps, step 15.2
97
+ referrer = 'no-referrer';
98
+ }
99
+ else if (referrer) {
100
+ // §5.4, Request constructor steps, step 15.3.1, 15.3.2
101
+ const parsedReferrer = new URL(referrer);
102
+ // §5.4, Request constructor steps, step 15.3.3, 15.3.4
103
+ referrer = /^about:(\/\/)?client$/.test(parsedReferrer) ? 'client' : parsedReferrer;
104
+ }
105
+ else {
106
+ referrer = undefined;
107
+ }
108
+ this[INTERNALS] = {
109
+ method,
110
+ redirect: init.redirect || input.redirect || 'follow',
111
+ headers: headers$1,
112
+ parsedURL,
113
+ signal,
114
+ referrer
115
+ };
116
+ // Node-fetch-only options
117
+ this.follow = init.follow === undefined ? (input.follow === undefined ? 20 : input.follow) : init.follow;
118
+ this.compress = init.compress === undefined ? (input.compress === undefined ? true : input.compress) : init.compress;
119
+ this.counter = init.counter || input.counter || 0;
120
+ this.agent = init.agent || input.agent;
121
+ this.highWaterMark = init.highWaterMark || input.highWaterMark || 16384;
122
+ this.insecureHTTPParser = init.insecureHTTPParser || input.insecureHTTPParser || false;
123
+ // §5.4, Request constructor steps, step 16.
124
+ // Default is empty string per https://fetch.spec.whatwg.org/#concept-request-referrer-policy
125
+ this.referrerPolicy = init.referrerPolicy || input.referrerPolicy || '';
126
+ }
127
+ /** @returns {string} */
128
+ get method() {
129
+ return this[INTERNALS].method;
130
+ }
131
+ /** @returns {string} */
132
+ get url() {
133
+ return node_url.format(this[INTERNALS].parsedURL);
134
+ }
135
+ /** @returns {Headers} */
136
+ get headers() {
137
+ return this[INTERNALS].headers;
138
+ }
139
+ get redirect() {
140
+ return this[INTERNALS].redirect;
141
+ }
142
+ /** @returns {AbortSignal} */
143
+ get signal() {
144
+ return this[INTERNALS].signal;
145
+ }
146
+ // https://fetch.spec.whatwg.org/#dom-request-referrer
147
+ get referrer() {
148
+ if (this[INTERNALS].referrer === 'no-referrer') {
149
+ return '';
150
+ }
151
+ if (this[INTERNALS].referrer === 'client') {
152
+ return 'about:client';
153
+ }
154
+ if (this[INTERNALS].referrer) {
155
+ return this[INTERNALS].referrer.toString();
156
+ }
157
+ return undefined;
158
+ }
159
+ get referrerPolicy() {
160
+ return this[INTERNALS].referrerPolicy;
161
+ }
162
+ set referrerPolicy(referrerPolicy) {
163
+ this[INTERNALS].referrerPolicy = referrer.validateReferrerPolicy(referrerPolicy);
164
+ }
165
+ /**
166
+ * Clone this request
167
+ *
168
+ * @return Request
169
+ */
170
+ clone() {
171
+ return new Request(this);
172
+ }
173
+ get [Symbol.toStringTag]() {
174
+ return 'Request';
175
+ }
176
+ }
177
+ Object.defineProperties(Request.prototype, {
178
+ method: { enumerable: true },
179
+ url: { enumerable: true },
180
+ headers: { enumerable: true },
181
+ redirect: { enumerable: true },
182
+ clone: { enumerable: true },
183
+ signal: { enumerable: true },
184
+ referrer: { enumerable: true },
185
+ referrerPolicy: { enumerable: true }
186
+ });
187
+ /**
188
+ * Convert a Request to Node.js http request options.
189
+ *
190
+ * @param {Request} request - A Request instance
191
+ * @return The options object to be passed to http.request
192
+ */
193
+ const getNodeRequestOptions = request => {
194
+ const { parsedURL } = request[INTERNALS];
195
+ const headers$1 = new headers["default"](request[INTERNALS].headers);
196
+ // Fetch step 1.3
197
+ if (!headers$1.has('Accept')) {
198
+ headers$1.set('Accept', '*/*');
199
+ }
200
+ // HTTP-network-or-cache fetch steps 2.4-2.7
201
+ let contentLengthValue = null;
202
+ if (request.body === null && /^(post|put)$/i.test(request.method)) {
203
+ contentLengthValue = '0';
204
+ }
205
+ if (request.body !== null) {
206
+ const totalBytes = body.getTotalBytes(request);
207
+ // Set Content-Length if totalBytes is a number (that is not NaN)
208
+ if (typeof totalBytes === 'number' && !Number.isNaN(totalBytes)) {
209
+ contentLengthValue = String(totalBytes);
210
+ }
211
+ }
212
+ if (contentLengthValue) {
213
+ headers$1.set('Content-Length', contentLengthValue);
214
+ }
215
+ // 4.1. Main fetch, step 2.6
216
+ // > If request's referrer policy is the empty string, then set request's referrer policy to the
217
+ // > default referrer policy.
218
+ if (request.referrerPolicy === '') {
219
+ request.referrerPolicy = referrer.DEFAULT_REFERRER_POLICY;
220
+ }
221
+ // 4.1. Main fetch, step 2.7
222
+ // > If request's referrer is not "no-referrer", set request's referrer to the result of invoking
223
+ // > determine request's referrer.
224
+ if (request.referrer && request.referrer !== 'no-referrer') {
225
+ request[INTERNALS].referrer = referrer.determineRequestsReferrer(request);
226
+ }
227
+ else {
228
+ request[INTERNALS].referrer = 'no-referrer';
229
+ }
230
+ // 4.5. HTTP-network-or-cache fetch, step 6.9
231
+ // > If httpRequest's referrer is a URL, then append `Referer`/httpRequest's referrer, serialized
232
+ // > and isomorphic encoded, to httpRequest's header list.
233
+ if (request[INTERNALS].referrer instanceof URL) {
234
+ headers$1.set('Referer', request.referrer);
235
+ }
236
+ // HTTP-network-or-cache fetch step 2.11
237
+ if (!headers$1.has('User-Agent')) {
238
+ headers$1.set('User-Agent', 'node-fetch');
239
+ }
240
+ // HTTP-network-or-cache fetch step 2.15
241
+ if (request.compress && !headers$1.has('Accept-Encoding')) {
242
+ headers$1.set('Accept-Encoding', 'gzip, deflate, br');
243
+ }
244
+ let { agent } = request;
245
+ if (typeof agent === 'function') {
246
+ agent = agent(parsedURL);
247
+ }
248
+ if (!headers$1.has('Connection') && !agent) {
249
+ headers$1.set('Connection', 'close');
250
+ }
251
+ // HTTP-network fetch step 4.2
252
+ // chunked encoding is handled by Node.js
253
+ const search = getSearch.getSearch(parsedURL);
254
+ // Pass the full URL directly to request(), but overwrite the following
255
+ // options:
256
+ const options = {
257
+ // Overwrite search to retain trailing ? (issue #776)
258
+ path: parsedURL.pathname + search,
259
+ // The following options are not expressed in the URL
260
+ method: request.method,
261
+ headers: headers$1[Symbol.for('nodejs.util.inspect.custom')](),
262
+ insecureHTTPParser: request.insecureHTTPParser,
263
+ agent
264
+ };
265
+ return {
266
+ /** @type {URL} */
267
+ parsedURL,
268
+ options
269
+ };
270
+ };
271
+
272
+ exports["default"] = Request;
273
+ exports.getNodeRequestOptions = getNodeRequestOptions;