ccxt 4.2.18 → 4.2.19

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 (426) hide show
  1. package/README.md +8 -8
  2. package/dist/ccxt.browser.js +34202 -33193
  3. package/dist/ccxt.browser.min.js +2 -2
  4. package/dist/cjs/ccxt.js +12 -1
  5. package/dist/cjs/src/alpaca.js +18 -18
  6. package/dist/cjs/src/ascendex.js +13 -6
  7. package/dist/cjs/src/base/Exchange.js +266 -27
  8. package/dist/cjs/src/bigone.js +434 -168
  9. package/dist/cjs/src/binance.js +163 -34
  10. package/dist/cjs/src/binanceus.js +8 -0
  11. package/dist/cjs/src/bingx.js +183 -41
  12. package/dist/cjs/src/bitfinex.js +2 -3
  13. package/dist/cjs/src/bitget.js +59 -16
  14. package/dist/cjs/src/bitmart.js +5 -5
  15. package/dist/cjs/src/bitmex.js +4 -6
  16. package/dist/cjs/src/bitpanda.js +5 -1991
  17. package/dist/cjs/src/bitstamp.js +8 -0
  18. package/dist/cjs/src/bybit.js +27 -47
  19. package/dist/cjs/src/coinbase.js +176 -26
  20. package/dist/cjs/src/coincheck.js +1 -0
  21. package/dist/cjs/src/coinex.js +3 -0
  22. package/dist/cjs/src/coinlist.js +13 -6
  23. package/dist/cjs/src/coinone.js +2 -2
  24. package/dist/cjs/src/coinsph.js +4 -5
  25. package/dist/cjs/src/delta.js +7 -1
  26. package/dist/cjs/src/deribit.js +17 -4
  27. package/dist/cjs/src/gate.js +151 -169
  28. package/dist/cjs/src/gemini.js +1 -1
  29. package/dist/cjs/src/hitbtc.js +2 -3
  30. package/dist/cjs/src/htx.js +157 -7
  31. package/dist/cjs/src/huobijp.js +2 -3
  32. package/dist/cjs/src/independentreserve.js +7 -5
  33. package/dist/cjs/src/kraken.js +86 -54
  34. package/dist/cjs/src/kucoin.js +5 -0
  35. package/dist/cjs/src/kucoinfutures.js +131 -77
  36. package/dist/cjs/src/lbank.js +60 -33
  37. package/dist/cjs/src/luno.js +84 -2
  38. package/dist/cjs/src/mexc.js +3 -3
  39. package/dist/cjs/src/oceanex.js +1 -1
  40. package/dist/cjs/src/okx.js +23 -11
  41. package/dist/cjs/{js/src/bitpanda.js → src/onetrading.js} +39 -39
  42. package/dist/cjs/src/phemex.js +37 -27
  43. package/dist/cjs/src/poloniexfutures.js +1 -0
  44. package/dist/cjs/src/pro/binance.js +66 -25
  45. package/dist/cjs/src/pro/bitget.js +1 -1
  46. package/dist/cjs/src/pro/bitpanda.js +5 -1330
  47. package/dist/cjs/src/pro/coinbase.js +4 -1
  48. package/dist/cjs/src/pro/hitbtc.js +5 -4
  49. package/dist/cjs/src/pro/htx.js +6 -1
  50. package/dist/cjs/src/pro/kraken.js +1 -1
  51. package/dist/cjs/src/pro/krakenfutures.js +7 -1
  52. package/dist/cjs/src/pro/kucoin.js +46 -36
  53. package/dist/cjs/src/pro/kucoinfutures.js +45 -37
  54. package/dist/cjs/src/pro/lbank.js +881 -0
  55. package/dist/cjs/src/pro/okx.js +52 -2
  56. package/dist/cjs/{js/src/pro/bitpanda.js → src/pro/onetrading.js} +4 -7
  57. package/dist/cjs/src/pro/poloniex.js +2 -2
  58. package/dist/cjs/src/pro/poloniexfutures.js +43 -35
  59. package/dist/cjs/src/pro/woo.js +126 -0
  60. package/dist/cjs/src/probit.js +4 -2
  61. package/dist/cjs/src/upbit.js +12 -12
  62. package/dist/cjs/src/wavesexchange.js +1 -1
  63. package/dist/cjs/src/whitebit.js +1 -0
  64. package/dist/cjs/src/woo.js +56 -0
  65. package/js/ccxt.d.ts +11 -2
  66. package/js/ccxt.js +8 -2
  67. package/js/src/abstract/bitpanda.d.ts +4 -4
  68. package/js/src/abstract/bitstamp.d.ts +8 -0
  69. package/js/src/abstract/gate.d.ts +1 -0
  70. package/js/src/abstract/gateio.d.ts +1 -0
  71. package/js/src/abstract/htx.d.ts +3 -0
  72. package/js/src/abstract/huobi.d.ts +3 -0
  73. package/js/src/abstract/luno.d.ts +1 -0
  74. package/js/src/abstract/onetrading.d.ts +38 -0
  75. package/js/src/ascendex.js +2 -0
  76. package/js/src/bingx.js +1 -1
  77. package/js/src/bitget.js +22 -3
  78. package/js/src/bitpanda.d.ts +2 -72
  79. package/js/src/bitpanda.js +5 -1991
  80. package/js/src/bitstamp.js +8 -0
  81. package/js/src/deribit.js +11 -3
  82. package/js/src/gate.d.ts +1 -0
  83. package/js/src/gate.js +50 -110
  84. package/js/src/htx.js +3 -0
  85. package/js/src/kraken.d.ts +1 -0
  86. package/js/src/kraken.js +39 -38
  87. package/js/src/lbank.js +1 -0
  88. package/js/src/luno.d.ts +3 -1
  89. package/js/src/luno.js +84 -2
  90. package/js/src/mexc.js +1 -2
  91. package/js/src/onetrading.d.ts +74 -0
  92. package/js/src/onetrading.js +2003 -0
  93. package/js/src/poloniexfutures.js +1 -0
  94. package/js/src/pro/binance.js +6 -1
  95. package/js/src/pro/bitpanda.d.ts +2 -34
  96. package/js/src/pro/bitpanda.js +5 -1330
  97. package/js/src/pro/lbank.d.ts +29 -0
  98. package/js/src/pro/lbank.js +882 -0
  99. package/js/src/pro/onetrading.d.ts +36 -0
  100. package/js/src/pro/onetrading.js +1339 -0
  101. package/package.json +2 -2
  102. package/rollup.config.js +2 -0
  103. package/skip-tests.json +2 -1
  104. package/test-commonjs.cjs +25 -1
  105. package/dist/cjs/js/ccxt.js +0 -478
  106. package/dist/cjs/js/src/abstract/alpaca.js +0 -9
  107. package/dist/cjs/js/src/abstract/ascendex.js +0 -9
  108. package/dist/cjs/js/src/abstract/bigone.js +0 -9
  109. package/dist/cjs/js/src/abstract/binance.js +0 -9
  110. package/dist/cjs/js/src/abstract/bingx.js +0 -9
  111. package/dist/cjs/js/src/abstract/bit2c.js +0 -9
  112. package/dist/cjs/js/src/abstract/bitbank.js +0 -9
  113. package/dist/cjs/js/src/abstract/bitbns.js +0 -9
  114. package/dist/cjs/js/src/abstract/bitfinex.js +0 -9
  115. package/dist/cjs/js/src/abstract/bitfinex2.js +0 -9
  116. package/dist/cjs/js/src/abstract/bitflyer.js +0 -9
  117. package/dist/cjs/js/src/abstract/bitforex.js +0 -9
  118. package/dist/cjs/js/src/abstract/bitget.js +0 -9
  119. package/dist/cjs/js/src/abstract/bithumb.js +0 -9
  120. package/dist/cjs/js/src/abstract/bitmart.js +0 -9
  121. package/dist/cjs/js/src/abstract/bitmex.js +0 -9
  122. package/dist/cjs/js/src/abstract/bitopro.js +0 -9
  123. package/dist/cjs/js/src/abstract/bitpanda.js +0 -9
  124. package/dist/cjs/js/src/abstract/bitrue.js +0 -9
  125. package/dist/cjs/js/src/abstract/bitso.js +0 -9
  126. package/dist/cjs/js/src/abstract/bitstamp.js +0 -9
  127. package/dist/cjs/js/src/abstract/bitteam.js +0 -9
  128. package/dist/cjs/js/src/abstract/bitvavo.js +0 -9
  129. package/dist/cjs/js/src/abstract/bl3p.js +0 -9
  130. package/dist/cjs/js/src/abstract/blockchaincom.js +0 -9
  131. package/dist/cjs/js/src/abstract/btcalpha.js +0 -9
  132. package/dist/cjs/js/src/abstract/btcbox.js +0 -9
  133. package/dist/cjs/js/src/abstract/btcmarkets.js +0 -9
  134. package/dist/cjs/js/src/abstract/btcturk.js +0 -9
  135. package/dist/cjs/js/src/abstract/bybit.js +0 -9
  136. package/dist/cjs/js/src/abstract/cex.js +0 -9
  137. package/dist/cjs/js/src/abstract/coinbase.js +0 -9
  138. package/dist/cjs/js/src/abstract/coinbasepro.js +0 -9
  139. package/dist/cjs/js/src/abstract/coincheck.js +0 -9
  140. package/dist/cjs/js/src/abstract/coinex.js +0 -9
  141. package/dist/cjs/js/src/abstract/coinlist.js +0 -9
  142. package/dist/cjs/js/src/abstract/coinmate.js +0 -9
  143. package/dist/cjs/js/src/abstract/coinone.js +0 -9
  144. package/dist/cjs/js/src/abstract/coinsph.js +0 -9
  145. package/dist/cjs/js/src/abstract/coinspot.js +0 -9
  146. package/dist/cjs/js/src/abstract/cryptocom.js +0 -9
  147. package/dist/cjs/js/src/abstract/currencycom.js +0 -9
  148. package/dist/cjs/js/src/abstract/delta.js +0 -9
  149. package/dist/cjs/js/src/abstract/deribit.js +0 -9
  150. package/dist/cjs/js/src/abstract/digifinex.js +0 -9
  151. package/dist/cjs/js/src/abstract/exmo.js +0 -9
  152. package/dist/cjs/js/src/abstract/gate.js +0 -9
  153. package/dist/cjs/js/src/abstract/gemini.js +0 -9
  154. package/dist/cjs/js/src/abstract/hitbtc.js +0 -9
  155. package/dist/cjs/js/src/abstract/hollaex.js +0 -9
  156. package/dist/cjs/js/src/abstract/htx.js +0 -9
  157. package/dist/cjs/js/src/abstract/huobijp.js +0 -9
  158. package/dist/cjs/js/src/abstract/idex.js +0 -9
  159. package/dist/cjs/js/src/abstract/independentreserve.js +0 -9
  160. package/dist/cjs/js/src/abstract/indodax.js +0 -9
  161. package/dist/cjs/js/src/abstract/kraken.js +0 -9
  162. package/dist/cjs/js/src/abstract/krakenfutures.js +0 -9
  163. package/dist/cjs/js/src/abstract/kucoin.js +0 -9
  164. package/dist/cjs/js/src/abstract/kucoinfutures.js +0 -9
  165. package/dist/cjs/js/src/abstract/kuna.js +0 -9
  166. package/dist/cjs/js/src/abstract/latoken.js +0 -9
  167. package/dist/cjs/js/src/abstract/lbank.js +0 -9
  168. package/dist/cjs/js/src/abstract/luno.js +0 -9
  169. package/dist/cjs/js/src/abstract/lykke.js +0 -9
  170. package/dist/cjs/js/src/abstract/mercado.js +0 -9
  171. package/dist/cjs/js/src/abstract/mexc.js +0 -9
  172. package/dist/cjs/js/src/abstract/ndax.js +0 -9
  173. package/dist/cjs/js/src/abstract/novadax.js +0 -9
  174. package/dist/cjs/js/src/abstract/oceanex.js +0 -9
  175. package/dist/cjs/js/src/abstract/okcoin.js +0 -9
  176. package/dist/cjs/js/src/abstract/okx.js +0 -9
  177. package/dist/cjs/js/src/abstract/p2b.js +0 -9
  178. package/dist/cjs/js/src/abstract/paymium.js +0 -9
  179. package/dist/cjs/js/src/abstract/phemex.js +0 -9
  180. package/dist/cjs/js/src/abstract/poloniex.js +0 -9
  181. package/dist/cjs/js/src/abstract/poloniexfutures.js +0 -9
  182. package/dist/cjs/js/src/abstract/probit.js +0 -9
  183. package/dist/cjs/js/src/abstract/timex.js +0 -9
  184. package/dist/cjs/js/src/abstract/tokocrypto.js +0 -9
  185. package/dist/cjs/js/src/abstract/upbit.js +0 -9
  186. package/dist/cjs/js/src/abstract/wavesexchange.js +0 -9
  187. package/dist/cjs/js/src/abstract/wazirx.js +0 -9
  188. package/dist/cjs/js/src/abstract/whitebit.js +0 -9
  189. package/dist/cjs/js/src/abstract/woo.js +0 -9
  190. package/dist/cjs/js/src/abstract/yobit.js +0 -9
  191. package/dist/cjs/js/src/abstract/zaif.js +0 -9
  192. package/dist/cjs/js/src/abstract/zonda.js +0 -9
  193. package/dist/cjs/js/src/ace.js +0 -1058
  194. package/dist/cjs/js/src/alpaca.js +0 -1125
  195. package/dist/cjs/js/src/ascendex.js +0 -3365
  196. package/dist/cjs/js/src/base/Exchange.js +0 -5260
  197. package/dist/cjs/js/src/base/Precise.js +0 -263
  198. package/dist/cjs/js/src/base/errors.js +0 -299
  199. package/dist/cjs/js/src/base/functions/crypto.js +0 -78
  200. package/dist/cjs/js/src/base/functions/encode.js +0 -44
  201. package/dist/cjs/js/src/base/functions/generic.js +0 -193
  202. package/dist/cjs/js/src/base/functions/misc.js +0 -96
  203. package/dist/cjs/js/src/base/functions/number.js +0 -297
  204. package/dist/cjs/js/src/base/functions/platform.js +0 -28
  205. package/dist/cjs/js/src/base/functions/rsa.js +0 -34
  206. package/dist/cjs/js/src/base/functions/string.js +0 -48
  207. package/dist/cjs/js/src/base/functions/throttle.js +0 -66
  208. package/dist/cjs/js/src/base/functions/time.js +0 -187
  209. package/dist/cjs/js/src/base/functions/totp.js +0 -24
  210. package/dist/cjs/js/src/base/functions/type.js +0 -162
  211. package/dist/cjs/js/src/base/functions.js +0 -157
  212. package/dist/cjs/js/src/base/ws/Cache.js +0 -254
  213. package/dist/cjs/js/src/base/ws/Client.js +0 -299
  214. package/dist/cjs/js/src/base/ws/Future.js +0 -34
  215. package/dist/cjs/js/src/base/ws/OrderBook.js +0 -107
  216. package/dist/cjs/js/src/base/ws/OrderBookSide.js +0 -281
  217. package/dist/cjs/js/src/base/ws/WsClient.js +0 -69
  218. package/dist/cjs/js/src/bequant.js +0 -33
  219. package/dist/cjs/js/src/bigone.js +0 -2213
  220. package/dist/cjs/js/src/binance.js +0 -9851
  221. package/dist/cjs/js/src/binancecoinm.js +0 -45
  222. package/dist/cjs/js/src/binanceus.js +0 -92
  223. package/dist/cjs/js/src/binanceusdm.js +0 -58
  224. package/dist/cjs/js/src/bingx.js +0 -3872
  225. package/dist/cjs/js/src/bit2c.js +0 -916
  226. package/dist/cjs/js/src/bitbank.js +0 -1000
  227. package/dist/cjs/js/src/bitbay.js +0 -17
  228. package/dist/cjs/js/src/bitbns.js +0 -1220
  229. package/dist/cjs/js/src/bitcoincom.js +0 -17
  230. package/dist/cjs/js/src/bitfinex.js +0 -1670
  231. package/dist/cjs/js/src/bitfinex2.js +0 -2990
  232. package/dist/cjs/js/src/bitflyer.js +0 -1045
  233. package/dist/cjs/js/src/bitforex.js +0 -852
  234. package/dist/cjs/js/src/bitget.js +0 -8295
  235. package/dist/cjs/js/src/bithumb.js +0 -1090
  236. package/dist/cjs/js/src/bitmart.js +0 -4454
  237. package/dist/cjs/js/src/bitmex.js +0 -2881
  238. package/dist/cjs/js/src/bitopro.js +0 -1724
  239. package/dist/cjs/js/src/bitrue.js +0 -3253
  240. package/dist/cjs/js/src/bitso.js +0 -1753
  241. package/dist/cjs/js/src/bitstamp.js +0 -2188
  242. package/dist/cjs/js/src/bitteam.js +0 -2309
  243. package/dist/cjs/js/src/bitvavo.js +0 -1968
  244. package/dist/cjs/js/src/bl3p.js +0 -447
  245. package/dist/cjs/js/src/blockchaincom.js +0 -1160
  246. package/dist/cjs/js/src/btcalpha.js +0 -929
  247. package/dist/cjs/js/src/btcbox.js +0 -565
  248. package/dist/cjs/js/src/btcmarkets.js +0 -1237
  249. package/dist/cjs/js/src/btcturk.js +0 -929
  250. package/dist/cjs/js/src/bybit.js +0 -7624
  251. package/dist/cjs/js/src/cex.js +0 -1693
  252. package/dist/cjs/js/src/coinbase.js +0 -3424
  253. package/dist/cjs/js/src/coinbasepro.js +0 -1866
  254. package/dist/cjs/js/src/coincheck.js +0 -844
  255. package/dist/cjs/js/src/coinex.js +0 -5417
  256. package/dist/cjs/js/src/coinlist.js +0 -2337
  257. package/dist/cjs/js/src/coinmate.js +0 -989
  258. package/dist/cjs/js/src/coinone.js +0 -1185
  259. package/dist/cjs/js/src/coinsph.js +0 -1933
  260. package/dist/cjs/js/src/coinspot.js +0 -548
  261. package/dist/cjs/js/src/cryptocom.js +0 -3007
  262. package/dist/cjs/js/src/currencycom.js +0 -2015
  263. package/dist/cjs/js/src/delta.js +0 -3262
  264. package/dist/cjs/js/src/deribit.js +0 -3310
  265. package/dist/cjs/js/src/digifinex.js +0 -4307
  266. package/dist/cjs/js/src/exmo.js +0 -2645
  267. package/dist/cjs/js/src/fmfwio.js +0 -34
  268. package/dist/cjs/js/src/gate.js +0 -7077
  269. package/dist/cjs/js/src/gateio.js +0 -16
  270. package/dist/cjs/js/src/gemini.js +0 -1801
  271. package/dist/cjs/js/src/hitbtc.js +0 -3660
  272. package/dist/cjs/js/src/hitbtc3.js +0 -19
  273. package/dist/cjs/js/src/hollaex.js +0 -1882
  274. package/dist/cjs/js/src/htx.js +0 -9174
  275. package/dist/cjs/js/src/huobi.js +0 -16
  276. package/dist/cjs/js/src/huobijp.js +0 -1918
  277. package/dist/cjs/js/src/idex.js +0 -1770
  278. package/dist/cjs/js/src/independentreserve.js +0 -761
  279. package/dist/cjs/js/src/indodax.js +0 -1069
  280. package/dist/cjs/js/src/kraken.js +0 -2891
  281. package/dist/cjs/js/src/krakenfutures.js +0 -2407
  282. package/dist/cjs/js/src/kucoin.js +0 -4494
  283. package/dist/cjs/js/src/kucoinfutures.js +0 -2529
  284. package/dist/cjs/js/src/kuna.js +0 -1949
  285. package/dist/cjs/js/src/latoken.js +0 -1729
  286. package/dist/cjs/js/src/lbank.js +0 -2851
  287. package/dist/cjs/js/src/luno.js +0 -1044
  288. package/dist/cjs/js/src/lykke.js +0 -1303
  289. package/dist/cjs/js/src/mercado.js +0 -897
  290. package/dist/cjs/js/src/mexc.js +0 -5407
  291. package/dist/cjs/js/src/ndax.js +0 -2450
  292. package/dist/cjs/js/src/novadax.js +0 -1556
  293. package/dist/cjs/js/src/oceanex.js +0 -964
  294. package/dist/cjs/js/src/okcoin.js +0 -3115
  295. package/dist/cjs/js/src/okx.js +0 -7331
  296. package/dist/cjs/js/src/p2b.js +0 -1243
  297. package/dist/cjs/js/src/paymium.js +0 -597
  298. package/dist/cjs/js/src/phemex.js +0 -4725
  299. package/dist/cjs/js/src/poloniex.js +0 -2356
  300. package/dist/cjs/js/src/poloniexfutures.js +0 -1794
  301. package/dist/cjs/js/src/pro/alpaca.js +0 -714
  302. package/dist/cjs/js/src/pro/ascendex.js +0 -957
  303. package/dist/cjs/js/src/pro/bequant.js +0 -33
  304. package/dist/cjs/js/src/pro/binance.js +0 -2796
  305. package/dist/cjs/js/src/pro/binancecoinm.js +0 -23
  306. package/dist/cjs/js/src/pro/binanceus.js +0 -51
  307. package/dist/cjs/js/src/pro/binanceusdm.js +0 -32
  308. package/dist/cjs/js/src/pro/bingx.js +0 -944
  309. package/dist/cjs/js/src/pro/bitcoincom.js +0 -29
  310. package/dist/cjs/js/src/pro/bitfinex.js +0 -672
  311. package/dist/cjs/js/src/pro/bitfinex2.js +0 -1159
  312. package/dist/cjs/js/src/pro/bitget.js +0 -1733
  313. package/dist/cjs/js/src/pro/bitmart.js +0 -1486
  314. package/dist/cjs/js/src/pro/bitmex.js +0 -1576
  315. package/dist/cjs/js/src/pro/bitopro.js +0 -327
  316. package/dist/cjs/js/src/pro/bitrue.js +0 -462
  317. package/dist/cjs/js/src/pro/bitstamp.js +0 -547
  318. package/dist/cjs/js/src/pro/bitvavo.js +0 -704
  319. package/dist/cjs/js/src/pro/blockchaincom.js +0 -794
  320. package/dist/cjs/js/src/pro/bybit.js +0 -1843
  321. package/dist/cjs/js/src/pro/cex.js +0 -1510
  322. package/dist/cjs/js/src/pro/coinbase.js +0 -561
  323. package/dist/cjs/js/src/pro/coinbasepro.js +0 -968
  324. package/dist/cjs/js/src/pro/coinex.js +0 -1095
  325. package/dist/cjs/js/src/pro/cryptocom.js +0 -1020
  326. package/dist/cjs/js/src/pro/currencycom.js +0 -563
  327. package/dist/cjs/js/src/pro/deribit.js +0 -825
  328. package/dist/cjs/js/src/pro/exmo.js +0 -658
  329. package/dist/cjs/js/src/pro/gate.js +0 -1316
  330. package/dist/cjs/js/src/pro/gateio.js +0 -16
  331. package/dist/cjs/js/src/pro/gemini.js +0 -649
  332. package/dist/cjs/js/src/pro/hitbtc.js +0 -1294
  333. package/dist/cjs/js/src/pro/hollaex.js +0 -597
  334. package/dist/cjs/js/src/pro/htx.js +0 -2388
  335. package/dist/cjs/js/src/pro/huobi.js +0 -16
  336. package/dist/cjs/js/src/pro/huobijp.js +0 -606
  337. package/dist/cjs/js/src/pro/idex.js +0 -714
  338. package/dist/cjs/js/src/pro/independentreserve.js +0 -280
  339. package/dist/cjs/js/src/pro/kraken.js +0 -1364
  340. package/dist/cjs/js/src/pro/krakenfutures.js +0 -1506
  341. package/dist/cjs/js/src/pro/kucoin.js +0 -1062
  342. package/dist/cjs/js/src/pro/kucoinfutures.js +0 -989
  343. package/dist/cjs/js/src/pro/luno.js +0 -322
  344. package/dist/cjs/js/src/pro/mexc.js +0 -1170
  345. package/dist/cjs/js/src/pro/ndax.js +0 -545
  346. package/dist/cjs/js/src/pro/okcoin.js +0 -760
  347. package/dist/cjs/js/src/pro/okx.js +0 -1608
  348. package/dist/cjs/js/src/pro/phemex.js +0 -1511
  349. package/dist/cjs/js/src/pro/poloniex.js +0 -1253
  350. package/dist/cjs/js/src/pro/poloniexfutures.js +0 -1022
  351. package/dist/cjs/js/src/pro/probit.js +0 -586
  352. package/dist/cjs/js/src/pro/upbit.js +0 -234
  353. package/dist/cjs/js/src/pro/wazirx.js +0 -776
  354. package/dist/cjs/js/src/pro/whitebit.js +0 -927
  355. package/dist/cjs/js/src/pro/woo.js +0 -895
  356. package/dist/cjs/js/src/probit.js +0 -1867
  357. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +0 -401
  358. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +0 -195
  359. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +0 -308
  360. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +0 -554
  361. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +0 -94
  362. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +0 -70
  363. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +0 -91
  364. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +0 -16
  365. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +0 -1760
  366. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +0 -52
  367. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +0 -81
  368. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +0 -376
  369. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +0 -70
  370. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +0 -1580
  371. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +0 -74
  372. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +0 -24
  373. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +0 -158
  374. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +0 -429
  375. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +0 -176
  376. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +0 -324
  377. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +0 -163
  378. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +0 -245
  379. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +0 -1018
  380. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +0 -383
  381. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +0 -258
  382. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +0 -53
  383. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +0 -120
  384. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +0 -69
  385. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +0 -7
  386. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +0 -83
  387. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +0 -240
  388. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +0 -91
  389. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +0 -130
  390. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +0 -214
  391. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +0 -239
  392. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +0 -93
  393. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +0 -354
  394. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +0 -16
  395. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +0 -20
  396. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +0 -30
  397. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +0 -239
  398. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +0 -372
  399. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +0 -273
  400. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +0 -139
  401. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +0 -14
  402. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +0 -16
  403. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +0 -81
  404. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +0 -292
  405. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +0 -103
  406. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +0 -140
  407. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +0 -175
  408. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +0 -95
  409. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +0 -7
  410. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +0 -383
  411. package/dist/cjs/js/src/timex.js +0 -1562
  412. package/dist/cjs/js/src/tokocrypto.js +0 -2542
  413. package/dist/cjs/js/src/upbit.js +0 -1844
  414. package/dist/cjs/js/src/wavesexchange.js +0 -2607
  415. package/dist/cjs/js/src/wazirx.js +0 -953
  416. package/dist/cjs/js/src/whitebit.js +0 -2310
  417. package/dist/cjs/js/src/woo.js +0 -2769
  418. package/dist/cjs/js/src/yobit.js +0 -1314
  419. package/dist/cjs/js/src/zaif.js +0 -736
  420. package/dist/cjs/js/src/zonda.js +0 -1883
  421. package/dist/cjs/src/abstract/bitpanda.js +0 -9
  422. package/test.ts +0 -0
  423. /package/dist/cjs/{js/src/abstract/ace.js → src/abstract/onetrading.js} +0 -0
  424. /package/dist/cjs/{js/src → src}/pro/coincheck.js +0 -0
  425. /package/dist/cjs/{js/src → src}/pro/coinone.js +0 -0
  426. /package/js/src/abstract/{bitpanda.js → onetrading.js} +0 -0
@@ -1,354 +0,0 @@
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;
@@ -1,16 +0,0 @@
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;
@@ -1,20 +0,0 @@
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;
@@ -1,30 +0,0 @@
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;
@@ -1,239 +0,0 @@
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;