ccxt 4.2.18 → 4.2.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (446) hide show
  1. package/README.md +100 -100
  2. package/dist/ccxt.browser.js +34240 -33297
  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 +276 -27
  8. package/dist/cjs/src/bigone.js +434 -168
  9. package/dist/cjs/src/binance.js +165 -35
  10. package/dist/cjs/src/binanceus.js +25 -0
  11. package/dist/cjs/src/bingx.js +185 -42
  12. package/dist/cjs/src/bitfinex.js +2 -3
  13. package/dist/cjs/src/bitget.js +84 -47
  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/bitteam.js +1 -1
  19. package/dist/cjs/src/bybit.js +27 -75
  20. package/dist/cjs/src/coinbase.js +176 -26
  21. package/dist/cjs/src/coincheck.js +1 -0
  22. package/dist/cjs/src/coinex.js +3 -0
  23. package/dist/cjs/src/coinlist.js +13 -6
  24. package/dist/cjs/src/coinone.js +2 -2
  25. package/dist/cjs/src/coinsph.js +4 -5
  26. package/dist/cjs/src/delta.js +7 -19
  27. package/dist/cjs/src/deribit.js +17 -4
  28. package/dist/cjs/src/gate.js +151 -194
  29. package/dist/cjs/src/gemini.js +1 -1
  30. package/dist/cjs/src/hitbtc.js +2 -3
  31. package/dist/cjs/src/htx.js +157 -7
  32. package/dist/cjs/src/huobijp.js +2 -3
  33. package/dist/cjs/src/independentreserve.js +7 -5
  34. package/dist/cjs/src/kraken.js +86 -54
  35. package/dist/cjs/src/kucoin.js +5 -0
  36. package/dist/cjs/src/kucoinfutures.js +140 -86
  37. package/dist/cjs/src/lbank.js +60 -33
  38. package/dist/cjs/src/luno.js +84 -2
  39. package/dist/cjs/src/mexc.js +3 -3
  40. package/dist/cjs/src/oceanex.js +1 -1
  41. package/dist/cjs/src/okx.js +23 -29
  42. package/dist/cjs/{js/src/bitpanda.js → src/onetrading.js} +39 -39
  43. package/dist/cjs/src/phemex.js +37 -27
  44. package/dist/cjs/src/poloniexfutures.js +1 -0
  45. package/dist/cjs/src/pro/binance.js +66 -25
  46. package/dist/cjs/src/pro/bitget.js +1 -1
  47. package/dist/cjs/src/pro/bitpanda.js +5 -1330
  48. package/dist/cjs/src/pro/coinbase.js +4 -1
  49. package/dist/cjs/src/pro/hitbtc.js +5 -4
  50. package/dist/cjs/src/pro/htx.js +6 -1
  51. package/dist/cjs/src/pro/kraken.js +1 -1
  52. package/dist/cjs/src/pro/krakenfutures.js +7 -1
  53. package/dist/cjs/src/pro/kucoin.js +46 -36
  54. package/dist/cjs/src/pro/kucoinfutures.js +45 -37
  55. package/dist/cjs/src/pro/lbank.js +881 -0
  56. package/dist/cjs/src/pro/okx.js +52 -2
  57. package/dist/cjs/{js/src/pro/bitpanda.js → src/pro/onetrading.js} +4 -7
  58. package/dist/cjs/src/pro/poloniex.js +2 -2
  59. package/dist/cjs/src/pro/poloniexfutures.js +43 -35
  60. package/dist/cjs/src/pro/woo.js +126 -0
  61. package/dist/cjs/src/probit.js +4 -2
  62. package/dist/cjs/src/upbit.js +12 -12
  63. package/dist/cjs/src/wavesexchange.js +1 -1
  64. package/dist/cjs/src/whitebit.js +1 -0
  65. package/dist/cjs/src/woo.js +56 -0
  66. package/js/ccxt.d.ts +11 -2
  67. package/js/ccxt.js +8 -2
  68. package/js/src/abstract/binance.d.ts +1 -0
  69. package/js/src/abstract/binancecoinm.d.ts +1 -0
  70. package/js/src/abstract/binanceus.d.ts +1 -0
  71. package/js/src/abstract/binanceusdm.d.ts +1 -0
  72. package/js/src/abstract/bitpanda.d.ts +4 -4
  73. package/js/src/abstract/bitpanda.js +3 -3
  74. package/js/src/abstract/bitstamp.d.ts +8 -0
  75. package/js/src/abstract/gate.d.ts +1 -0
  76. package/js/src/abstract/gateio.d.ts +1 -0
  77. package/js/src/abstract/htx.d.ts +3 -0
  78. package/js/src/abstract/huobi.d.ts +3 -0
  79. package/js/src/abstract/luno.d.ts +1 -0
  80. package/js/src/abstract/onetrading.d.ts +38 -0
  81. package/js/src/abstract/onetrading.js +11 -0
  82. package/js/src/ascendex.js +2 -0
  83. package/js/src/base/Exchange.d.ts +3 -0
  84. package/js/src/base/Exchange.js +10 -0
  85. package/js/src/binance.js +2 -1
  86. package/js/src/binanceus.js +17 -0
  87. package/js/src/bingx.js +3 -2
  88. package/js/src/bitget.d.ts +1 -1
  89. package/js/src/bitget.js +47 -34
  90. package/js/src/bitpanda.d.ts +2 -72
  91. package/js/src/bitpanda.js +5 -1991
  92. package/js/src/bitstamp.js +8 -0
  93. package/js/src/bitteam.js +1 -1
  94. package/js/src/bybit.d.ts +0 -1
  95. package/js/src/bybit.js +1 -29
  96. package/js/src/delta.d.ts +0 -1
  97. package/js/src/delta.js +0 -18
  98. package/js/src/deribit.js +11 -3
  99. package/js/src/gate.d.ts +1 -1
  100. package/js/src/gate.js +50 -135
  101. package/js/src/htx.js +3 -0
  102. package/js/src/kraken.d.ts +1 -0
  103. package/js/src/kraken.js +39 -38
  104. package/js/src/kucoinfutures.d.ts +6 -6
  105. package/js/src/kucoinfutures.js +9 -9
  106. package/js/src/lbank.js +1 -0
  107. package/js/src/luno.d.ts +3 -1
  108. package/js/src/luno.js +84 -2
  109. package/js/src/mexc.js +1 -2
  110. package/js/src/okx.d.ts +0 -1
  111. package/js/src/okx.js +0 -18
  112. package/js/src/onetrading.d.ts +74 -0
  113. package/js/src/onetrading.js +2003 -0
  114. package/js/src/poloniexfutures.js +1 -0
  115. package/js/src/pro/binance.js +6 -1
  116. package/js/src/pro/bitpanda.d.ts +2 -34
  117. package/js/src/pro/bitpanda.js +5 -1330
  118. package/js/src/pro/lbank.d.ts +29 -0
  119. package/js/src/pro/lbank.js +882 -0
  120. package/js/src/pro/onetrading.d.ts +36 -0
  121. package/js/src/pro/onetrading.js +1339 -0
  122. package/package.json +2 -2
  123. package/rollup.config.js +2 -0
  124. package/skip-tests.json +4 -2
  125. package/test-commonjs.cjs +25 -1
  126. package/dist/cjs/js/ccxt.js +0 -478
  127. package/dist/cjs/js/src/abstract/alpaca.js +0 -9
  128. package/dist/cjs/js/src/abstract/ascendex.js +0 -9
  129. package/dist/cjs/js/src/abstract/bigone.js +0 -9
  130. package/dist/cjs/js/src/abstract/binance.js +0 -9
  131. package/dist/cjs/js/src/abstract/bingx.js +0 -9
  132. package/dist/cjs/js/src/abstract/bit2c.js +0 -9
  133. package/dist/cjs/js/src/abstract/bitbank.js +0 -9
  134. package/dist/cjs/js/src/abstract/bitbns.js +0 -9
  135. package/dist/cjs/js/src/abstract/bitfinex.js +0 -9
  136. package/dist/cjs/js/src/abstract/bitfinex2.js +0 -9
  137. package/dist/cjs/js/src/abstract/bitflyer.js +0 -9
  138. package/dist/cjs/js/src/abstract/bitforex.js +0 -9
  139. package/dist/cjs/js/src/abstract/bitget.js +0 -9
  140. package/dist/cjs/js/src/abstract/bithumb.js +0 -9
  141. package/dist/cjs/js/src/abstract/bitmart.js +0 -9
  142. package/dist/cjs/js/src/abstract/bitmex.js +0 -9
  143. package/dist/cjs/js/src/abstract/bitopro.js +0 -9
  144. package/dist/cjs/js/src/abstract/bitpanda.js +0 -9
  145. package/dist/cjs/js/src/abstract/bitrue.js +0 -9
  146. package/dist/cjs/js/src/abstract/bitso.js +0 -9
  147. package/dist/cjs/js/src/abstract/bitstamp.js +0 -9
  148. package/dist/cjs/js/src/abstract/bitteam.js +0 -9
  149. package/dist/cjs/js/src/abstract/bitvavo.js +0 -9
  150. package/dist/cjs/js/src/abstract/bl3p.js +0 -9
  151. package/dist/cjs/js/src/abstract/blockchaincom.js +0 -9
  152. package/dist/cjs/js/src/abstract/btcalpha.js +0 -9
  153. package/dist/cjs/js/src/abstract/btcbox.js +0 -9
  154. package/dist/cjs/js/src/abstract/btcmarkets.js +0 -9
  155. package/dist/cjs/js/src/abstract/btcturk.js +0 -9
  156. package/dist/cjs/js/src/abstract/bybit.js +0 -9
  157. package/dist/cjs/js/src/abstract/cex.js +0 -9
  158. package/dist/cjs/js/src/abstract/coinbase.js +0 -9
  159. package/dist/cjs/js/src/abstract/coinbasepro.js +0 -9
  160. package/dist/cjs/js/src/abstract/coincheck.js +0 -9
  161. package/dist/cjs/js/src/abstract/coinex.js +0 -9
  162. package/dist/cjs/js/src/abstract/coinlist.js +0 -9
  163. package/dist/cjs/js/src/abstract/coinmate.js +0 -9
  164. package/dist/cjs/js/src/abstract/coinone.js +0 -9
  165. package/dist/cjs/js/src/abstract/coinsph.js +0 -9
  166. package/dist/cjs/js/src/abstract/coinspot.js +0 -9
  167. package/dist/cjs/js/src/abstract/cryptocom.js +0 -9
  168. package/dist/cjs/js/src/abstract/currencycom.js +0 -9
  169. package/dist/cjs/js/src/abstract/delta.js +0 -9
  170. package/dist/cjs/js/src/abstract/deribit.js +0 -9
  171. package/dist/cjs/js/src/abstract/digifinex.js +0 -9
  172. package/dist/cjs/js/src/abstract/exmo.js +0 -9
  173. package/dist/cjs/js/src/abstract/gate.js +0 -9
  174. package/dist/cjs/js/src/abstract/gemini.js +0 -9
  175. package/dist/cjs/js/src/abstract/hitbtc.js +0 -9
  176. package/dist/cjs/js/src/abstract/hollaex.js +0 -9
  177. package/dist/cjs/js/src/abstract/htx.js +0 -9
  178. package/dist/cjs/js/src/abstract/huobijp.js +0 -9
  179. package/dist/cjs/js/src/abstract/idex.js +0 -9
  180. package/dist/cjs/js/src/abstract/independentreserve.js +0 -9
  181. package/dist/cjs/js/src/abstract/indodax.js +0 -9
  182. package/dist/cjs/js/src/abstract/kraken.js +0 -9
  183. package/dist/cjs/js/src/abstract/krakenfutures.js +0 -9
  184. package/dist/cjs/js/src/abstract/kucoin.js +0 -9
  185. package/dist/cjs/js/src/abstract/kucoinfutures.js +0 -9
  186. package/dist/cjs/js/src/abstract/kuna.js +0 -9
  187. package/dist/cjs/js/src/abstract/latoken.js +0 -9
  188. package/dist/cjs/js/src/abstract/lbank.js +0 -9
  189. package/dist/cjs/js/src/abstract/luno.js +0 -9
  190. package/dist/cjs/js/src/abstract/lykke.js +0 -9
  191. package/dist/cjs/js/src/abstract/mercado.js +0 -9
  192. package/dist/cjs/js/src/abstract/mexc.js +0 -9
  193. package/dist/cjs/js/src/abstract/ndax.js +0 -9
  194. package/dist/cjs/js/src/abstract/novadax.js +0 -9
  195. package/dist/cjs/js/src/abstract/oceanex.js +0 -9
  196. package/dist/cjs/js/src/abstract/okcoin.js +0 -9
  197. package/dist/cjs/js/src/abstract/okx.js +0 -9
  198. package/dist/cjs/js/src/abstract/p2b.js +0 -9
  199. package/dist/cjs/js/src/abstract/paymium.js +0 -9
  200. package/dist/cjs/js/src/abstract/phemex.js +0 -9
  201. package/dist/cjs/js/src/abstract/poloniex.js +0 -9
  202. package/dist/cjs/js/src/abstract/poloniexfutures.js +0 -9
  203. package/dist/cjs/js/src/abstract/probit.js +0 -9
  204. package/dist/cjs/js/src/abstract/timex.js +0 -9
  205. package/dist/cjs/js/src/abstract/tokocrypto.js +0 -9
  206. package/dist/cjs/js/src/abstract/upbit.js +0 -9
  207. package/dist/cjs/js/src/abstract/wavesexchange.js +0 -9
  208. package/dist/cjs/js/src/abstract/wazirx.js +0 -9
  209. package/dist/cjs/js/src/abstract/whitebit.js +0 -9
  210. package/dist/cjs/js/src/abstract/woo.js +0 -9
  211. package/dist/cjs/js/src/abstract/yobit.js +0 -9
  212. package/dist/cjs/js/src/abstract/zaif.js +0 -9
  213. package/dist/cjs/js/src/abstract/zonda.js +0 -9
  214. package/dist/cjs/js/src/ace.js +0 -1058
  215. package/dist/cjs/js/src/alpaca.js +0 -1125
  216. package/dist/cjs/js/src/ascendex.js +0 -3365
  217. package/dist/cjs/js/src/base/Exchange.js +0 -5260
  218. package/dist/cjs/js/src/base/Precise.js +0 -263
  219. package/dist/cjs/js/src/base/errors.js +0 -299
  220. package/dist/cjs/js/src/base/functions/crypto.js +0 -78
  221. package/dist/cjs/js/src/base/functions/encode.js +0 -44
  222. package/dist/cjs/js/src/base/functions/generic.js +0 -193
  223. package/dist/cjs/js/src/base/functions/misc.js +0 -96
  224. package/dist/cjs/js/src/base/functions/number.js +0 -297
  225. package/dist/cjs/js/src/base/functions/platform.js +0 -28
  226. package/dist/cjs/js/src/base/functions/rsa.js +0 -34
  227. package/dist/cjs/js/src/base/functions/string.js +0 -48
  228. package/dist/cjs/js/src/base/functions/throttle.js +0 -66
  229. package/dist/cjs/js/src/base/functions/time.js +0 -187
  230. package/dist/cjs/js/src/base/functions/totp.js +0 -24
  231. package/dist/cjs/js/src/base/functions/type.js +0 -162
  232. package/dist/cjs/js/src/base/functions.js +0 -157
  233. package/dist/cjs/js/src/base/ws/Cache.js +0 -254
  234. package/dist/cjs/js/src/base/ws/Client.js +0 -299
  235. package/dist/cjs/js/src/base/ws/Future.js +0 -34
  236. package/dist/cjs/js/src/base/ws/OrderBook.js +0 -107
  237. package/dist/cjs/js/src/base/ws/OrderBookSide.js +0 -281
  238. package/dist/cjs/js/src/base/ws/WsClient.js +0 -69
  239. package/dist/cjs/js/src/bequant.js +0 -33
  240. package/dist/cjs/js/src/bigone.js +0 -2213
  241. package/dist/cjs/js/src/binance.js +0 -9851
  242. package/dist/cjs/js/src/binancecoinm.js +0 -45
  243. package/dist/cjs/js/src/binanceus.js +0 -92
  244. package/dist/cjs/js/src/binanceusdm.js +0 -58
  245. package/dist/cjs/js/src/bingx.js +0 -3872
  246. package/dist/cjs/js/src/bit2c.js +0 -916
  247. package/dist/cjs/js/src/bitbank.js +0 -1000
  248. package/dist/cjs/js/src/bitbay.js +0 -17
  249. package/dist/cjs/js/src/bitbns.js +0 -1220
  250. package/dist/cjs/js/src/bitcoincom.js +0 -17
  251. package/dist/cjs/js/src/bitfinex.js +0 -1670
  252. package/dist/cjs/js/src/bitfinex2.js +0 -2990
  253. package/dist/cjs/js/src/bitflyer.js +0 -1045
  254. package/dist/cjs/js/src/bitforex.js +0 -852
  255. package/dist/cjs/js/src/bitget.js +0 -8295
  256. package/dist/cjs/js/src/bithumb.js +0 -1090
  257. package/dist/cjs/js/src/bitmart.js +0 -4454
  258. package/dist/cjs/js/src/bitmex.js +0 -2881
  259. package/dist/cjs/js/src/bitopro.js +0 -1724
  260. package/dist/cjs/js/src/bitrue.js +0 -3253
  261. package/dist/cjs/js/src/bitso.js +0 -1753
  262. package/dist/cjs/js/src/bitstamp.js +0 -2188
  263. package/dist/cjs/js/src/bitteam.js +0 -2309
  264. package/dist/cjs/js/src/bitvavo.js +0 -1968
  265. package/dist/cjs/js/src/bl3p.js +0 -447
  266. package/dist/cjs/js/src/blockchaincom.js +0 -1160
  267. package/dist/cjs/js/src/btcalpha.js +0 -929
  268. package/dist/cjs/js/src/btcbox.js +0 -565
  269. package/dist/cjs/js/src/btcmarkets.js +0 -1237
  270. package/dist/cjs/js/src/btcturk.js +0 -929
  271. package/dist/cjs/js/src/bybit.js +0 -7624
  272. package/dist/cjs/js/src/cex.js +0 -1693
  273. package/dist/cjs/js/src/coinbase.js +0 -3424
  274. package/dist/cjs/js/src/coinbasepro.js +0 -1866
  275. package/dist/cjs/js/src/coincheck.js +0 -844
  276. package/dist/cjs/js/src/coinex.js +0 -5417
  277. package/dist/cjs/js/src/coinlist.js +0 -2337
  278. package/dist/cjs/js/src/coinmate.js +0 -989
  279. package/dist/cjs/js/src/coinone.js +0 -1185
  280. package/dist/cjs/js/src/coinsph.js +0 -1933
  281. package/dist/cjs/js/src/coinspot.js +0 -548
  282. package/dist/cjs/js/src/cryptocom.js +0 -3007
  283. package/dist/cjs/js/src/currencycom.js +0 -2015
  284. package/dist/cjs/js/src/delta.js +0 -3262
  285. package/dist/cjs/js/src/deribit.js +0 -3310
  286. package/dist/cjs/js/src/digifinex.js +0 -4307
  287. package/dist/cjs/js/src/exmo.js +0 -2645
  288. package/dist/cjs/js/src/fmfwio.js +0 -34
  289. package/dist/cjs/js/src/gate.js +0 -7077
  290. package/dist/cjs/js/src/gateio.js +0 -16
  291. package/dist/cjs/js/src/gemini.js +0 -1801
  292. package/dist/cjs/js/src/hitbtc.js +0 -3660
  293. package/dist/cjs/js/src/hitbtc3.js +0 -19
  294. package/dist/cjs/js/src/hollaex.js +0 -1882
  295. package/dist/cjs/js/src/htx.js +0 -9174
  296. package/dist/cjs/js/src/huobi.js +0 -16
  297. package/dist/cjs/js/src/huobijp.js +0 -1918
  298. package/dist/cjs/js/src/idex.js +0 -1770
  299. package/dist/cjs/js/src/independentreserve.js +0 -761
  300. package/dist/cjs/js/src/indodax.js +0 -1069
  301. package/dist/cjs/js/src/kraken.js +0 -2891
  302. package/dist/cjs/js/src/krakenfutures.js +0 -2407
  303. package/dist/cjs/js/src/kucoin.js +0 -4494
  304. package/dist/cjs/js/src/kucoinfutures.js +0 -2529
  305. package/dist/cjs/js/src/kuna.js +0 -1949
  306. package/dist/cjs/js/src/latoken.js +0 -1729
  307. package/dist/cjs/js/src/lbank.js +0 -2851
  308. package/dist/cjs/js/src/luno.js +0 -1044
  309. package/dist/cjs/js/src/lykke.js +0 -1303
  310. package/dist/cjs/js/src/mercado.js +0 -897
  311. package/dist/cjs/js/src/mexc.js +0 -5407
  312. package/dist/cjs/js/src/ndax.js +0 -2450
  313. package/dist/cjs/js/src/novadax.js +0 -1556
  314. package/dist/cjs/js/src/oceanex.js +0 -964
  315. package/dist/cjs/js/src/okcoin.js +0 -3115
  316. package/dist/cjs/js/src/okx.js +0 -7331
  317. package/dist/cjs/js/src/p2b.js +0 -1243
  318. package/dist/cjs/js/src/paymium.js +0 -597
  319. package/dist/cjs/js/src/phemex.js +0 -4725
  320. package/dist/cjs/js/src/poloniex.js +0 -2356
  321. package/dist/cjs/js/src/poloniexfutures.js +0 -1794
  322. package/dist/cjs/js/src/pro/alpaca.js +0 -714
  323. package/dist/cjs/js/src/pro/ascendex.js +0 -957
  324. package/dist/cjs/js/src/pro/bequant.js +0 -33
  325. package/dist/cjs/js/src/pro/binance.js +0 -2796
  326. package/dist/cjs/js/src/pro/binancecoinm.js +0 -23
  327. package/dist/cjs/js/src/pro/binanceus.js +0 -51
  328. package/dist/cjs/js/src/pro/binanceusdm.js +0 -32
  329. package/dist/cjs/js/src/pro/bingx.js +0 -944
  330. package/dist/cjs/js/src/pro/bitcoincom.js +0 -29
  331. package/dist/cjs/js/src/pro/bitfinex.js +0 -672
  332. package/dist/cjs/js/src/pro/bitfinex2.js +0 -1159
  333. package/dist/cjs/js/src/pro/bitget.js +0 -1733
  334. package/dist/cjs/js/src/pro/bitmart.js +0 -1486
  335. package/dist/cjs/js/src/pro/bitmex.js +0 -1576
  336. package/dist/cjs/js/src/pro/bitopro.js +0 -327
  337. package/dist/cjs/js/src/pro/bitrue.js +0 -462
  338. package/dist/cjs/js/src/pro/bitstamp.js +0 -547
  339. package/dist/cjs/js/src/pro/bitvavo.js +0 -704
  340. package/dist/cjs/js/src/pro/blockchaincom.js +0 -794
  341. package/dist/cjs/js/src/pro/bybit.js +0 -1843
  342. package/dist/cjs/js/src/pro/cex.js +0 -1510
  343. package/dist/cjs/js/src/pro/coinbase.js +0 -561
  344. package/dist/cjs/js/src/pro/coinbasepro.js +0 -968
  345. package/dist/cjs/js/src/pro/coinex.js +0 -1095
  346. package/dist/cjs/js/src/pro/cryptocom.js +0 -1020
  347. package/dist/cjs/js/src/pro/currencycom.js +0 -563
  348. package/dist/cjs/js/src/pro/deribit.js +0 -825
  349. package/dist/cjs/js/src/pro/exmo.js +0 -658
  350. package/dist/cjs/js/src/pro/gate.js +0 -1316
  351. package/dist/cjs/js/src/pro/gateio.js +0 -16
  352. package/dist/cjs/js/src/pro/gemini.js +0 -649
  353. package/dist/cjs/js/src/pro/hitbtc.js +0 -1294
  354. package/dist/cjs/js/src/pro/hollaex.js +0 -597
  355. package/dist/cjs/js/src/pro/htx.js +0 -2388
  356. package/dist/cjs/js/src/pro/huobi.js +0 -16
  357. package/dist/cjs/js/src/pro/huobijp.js +0 -606
  358. package/dist/cjs/js/src/pro/idex.js +0 -714
  359. package/dist/cjs/js/src/pro/independentreserve.js +0 -280
  360. package/dist/cjs/js/src/pro/kraken.js +0 -1364
  361. package/dist/cjs/js/src/pro/krakenfutures.js +0 -1506
  362. package/dist/cjs/js/src/pro/kucoin.js +0 -1062
  363. package/dist/cjs/js/src/pro/kucoinfutures.js +0 -989
  364. package/dist/cjs/js/src/pro/luno.js +0 -322
  365. package/dist/cjs/js/src/pro/mexc.js +0 -1170
  366. package/dist/cjs/js/src/pro/ndax.js +0 -545
  367. package/dist/cjs/js/src/pro/okcoin.js +0 -760
  368. package/dist/cjs/js/src/pro/okx.js +0 -1608
  369. package/dist/cjs/js/src/pro/phemex.js +0 -1511
  370. package/dist/cjs/js/src/pro/poloniex.js +0 -1253
  371. package/dist/cjs/js/src/pro/poloniexfutures.js +0 -1022
  372. package/dist/cjs/js/src/pro/probit.js +0 -586
  373. package/dist/cjs/js/src/pro/upbit.js +0 -234
  374. package/dist/cjs/js/src/pro/wazirx.js +0 -776
  375. package/dist/cjs/js/src/pro/whitebit.js +0 -927
  376. package/dist/cjs/js/src/pro/woo.js +0 -895
  377. package/dist/cjs/js/src/probit.js +0 -1867
  378. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +0 -401
  379. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +0 -195
  380. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +0 -308
  381. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +0 -554
  382. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +0 -94
  383. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +0 -70
  384. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +0 -91
  385. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +0 -16
  386. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +0 -1760
  387. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +0 -52
  388. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +0 -81
  389. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +0 -376
  390. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +0 -70
  391. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +0 -1580
  392. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +0 -74
  393. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +0 -24
  394. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +0 -158
  395. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +0 -429
  396. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +0 -176
  397. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +0 -324
  398. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +0 -163
  399. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +0 -245
  400. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +0 -1018
  401. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +0 -383
  402. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +0 -258
  403. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +0 -53
  404. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +0 -120
  405. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +0 -69
  406. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +0 -7
  407. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +0 -83
  408. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +0 -240
  409. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +0 -91
  410. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +0 -130
  411. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +0 -214
  412. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +0 -239
  413. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +0 -93
  414. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +0 -354
  415. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +0 -16
  416. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +0 -20
  417. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +0 -30
  418. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +0 -239
  419. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +0 -372
  420. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +0 -273
  421. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +0 -139
  422. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +0 -14
  423. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +0 -16
  424. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +0 -81
  425. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +0 -292
  426. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +0 -103
  427. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +0 -140
  428. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +0 -175
  429. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +0 -95
  430. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +0 -7
  431. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +0 -383
  432. package/dist/cjs/js/src/timex.js +0 -1562
  433. package/dist/cjs/js/src/tokocrypto.js +0 -2542
  434. package/dist/cjs/js/src/upbit.js +0 -1844
  435. package/dist/cjs/js/src/wavesexchange.js +0 -2607
  436. package/dist/cjs/js/src/wazirx.js +0 -953
  437. package/dist/cjs/js/src/whitebit.js +0 -2310
  438. package/dist/cjs/js/src/woo.js +0 -2769
  439. package/dist/cjs/js/src/yobit.js +0 -1314
  440. package/dist/cjs/js/src/zaif.js +0 -736
  441. package/dist/cjs/js/src/zonda.js +0 -1883
  442. package/dist/cjs/src/abstract/bitpanda.js +0 -9
  443. package/test.ts +0 -0
  444. /package/dist/cjs/{js/src/abstract/ace.js → src/abstract/onetrading.js} +0 -0
  445. /package/dist/cjs/{js/src → src}/pro/coincheck.js +0 -0
  446. /package/dist/cjs/{js/src → src}/pro/coinone.js +0 -0
@@ -1,139 +0,0 @@
1
- 'use strict';
2
-
3
- var headers = require('./headers.js');
4
- var body = require('./body.js');
5
- var isRedirect = require('./utils/is-redirect.js');
6
-
7
- /**
8
- * Response.js
9
- *
10
- * Response class provides content decoding
11
- */
12
- const INTERNALS = Symbol('Response internals');
13
- /**
14
- * Response class
15
- *
16
- * Ref: https://fetch.spec.whatwg.org/#response-class
17
- *
18
- * @param Stream body Readable stream
19
- * @param Object opts Response options
20
- * @return Void
21
- */
22
- class Response extends body["default"] {
23
- constructor(body$1 = null, options = {}) {
24
- super(body$1, options);
25
- // eslint-disable-next-line no-eq-null, eqeqeq, no-negated-condition
26
- const status = options.status != null ? options.status : 200;
27
- const headers$1 = new headers["default"](options.headers);
28
- if (body$1 !== null && !headers$1.has('Content-Type')) {
29
- const contentType = body.extractContentType(body$1);
30
- if (contentType) {
31
- headers$1.append('Content-Type', contentType);
32
- }
33
- }
34
- this[INTERNALS] = {
35
- type: 'default',
36
- url: options.url,
37
- status,
38
- statusText: options.statusText || '',
39
- headers: headers$1,
40
- counter: options.counter,
41
- highWaterMark: options.highWaterMark
42
- };
43
- }
44
- get type() {
45
- return this[INTERNALS].type;
46
- }
47
- get url() {
48
- return this[INTERNALS].url || '';
49
- }
50
- get status() {
51
- return this[INTERNALS].status;
52
- }
53
- /**
54
- * Convenience property representing if the request ended normally
55
- */
56
- get ok() {
57
- return this[INTERNALS].status >= 200 && this[INTERNALS].status < 300;
58
- }
59
- get redirected() {
60
- return this[INTERNALS].counter > 0;
61
- }
62
- get statusText() {
63
- return this[INTERNALS].statusText;
64
- }
65
- get headers() {
66
- return this[INTERNALS].headers;
67
- }
68
- get highWaterMark() {
69
- return this[INTERNALS].highWaterMark;
70
- }
71
- /**
72
- * Clone this response
73
- *
74
- * @return Response
75
- */
76
- clone() {
77
- return new Response(body.clone(this, this.highWaterMark), {
78
- type: this.type,
79
- url: this.url,
80
- status: this.status,
81
- statusText: this.statusText,
82
- headers: this.headers,
83
- ok: this.ok,
84
- redirected: this.redirected,
85
- size: this.size,
86
- highWaterMark: this.highWaterMark
87
- });
88
- }
89
- /**
90
- * @param {string} url The URL that the new response is to originate from.
91
- * @param {number} status An optional status code for the response (e.g., 302.)
92
- * @returns {Response} A Response object.
93
- */
94
- static redirect(url, status = 302) {
95
- if (!isRedirect.isRedirect(status)) {
96
- throw new RangeError('Failed to execute "redirect" on "response": Invalid status code');
97
- }
98
- return new Response(null, {
99
- headers: {
100
- location: new URL(url).toString()
101
- },
102
- status
103
- });
104
- }
105
- static error() {
106
- const response = new Response(null, { status: 0, statusText: '' });
107
- response[INTERNALS].type = 'error';
108
- return response;
109
- }
110
- static json(data = undefined, init = {}) {
111
- const body = JSON.stringify(data);
112
- if (body === undefined) {
113
- throw new TypeError('data is not JSON serializable');
114
- }
115
- const headers$1 = new headers["default"](init && init.headers);
116
- if (!headers$1.has('content-type')) {
117
- headers$1.set('content-type', 'application/json');
118
- }
119
- return new Response(body, {
120
- ...init,
121
- headers: headers$1
122
- });
123
- }
124
- get [Symbol.toStringTag]() {
125
- return 'Response';
126
- }
127
- }
128
- Object.defineProperties(Response.prototype, {
129
- type: { enumerable: true },
130
- url: { enumerable: true },
131
- status: { enumerable: true },
132
- ok: { enumerable: true },
133
- redirected: { enumerable: true },
134
- statusText: { enumerable: true },
135
- headers: { enumerable: true },
136
- clone: { enumerable: true }
137
- });
138
-
139
- module.exports = Response;
@@ -1,14 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- const getSearch = parsedURL => {
6
- if (parsedURL.search) {
7
- return parsedURL.search;
8
- }
9
- const lastOffset = parsedURL.href.length - 1;
10
- const hash = parsedURL.hash || (parsedURL.href[lastOffset] === '#' ? '#' : '');
11
- return parsedURL.href[lastOffset - hash.length] === '?' ? '?' : '';
12
- };
13
-
14
- exports.getSearch = getSearch;
@@ -1,16 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- const redirectStatus = new Set([301, 302, 303, 307, 308]);
6
- /**
7
- * Redirect code matching
8
- *
9
- * @param {number} code - Status code
10
- * @return {boolean}
11
- */
12
- const isRedirect = code => {
13
- return redirectStatus.has(code);
14
- };
15
-
16
- exports.isRedirect = isRedirect;
@@ -1,81 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- /**
6
- * Is.js
7
- *
8
- * Object type checks.
9
- */
10
- const NAME = Symbol.toStringTag;
11
- /**
12
- * Check if `obj` is a URLSearchParams object
13
- * ref: https://github.com/node-fetch/node-fetch/issues/296#issuecomment-307598143
14
- * @param {*} object - Object to check for
15
- * @return {boolean}
16
- */
17
- const isURLSearchParameters = object => {
18
- return (typeof object === 'object' &&
19
- typeof object.append === 'function' &&
20
- typeof object.delete === 'function' &&
21
- typeof object.get === 'function' &&
22
- typeof object.getAll === 'function' &&
23
- typeof object.has === 'function' &&
24
- typeof object.set === 'function' &&
25
- typeof object.sort === 'function' &&
26
- object[NAME] === 'URLSearchParams');
27
- };
28
- /**
29
- * Check if `object` is a W3C `Blob` object (which `File` inherits from)
30
- * @param {*} object - Object to check for
31
- * @return {boolean}
32
- */
33
- const isBlob = object => {
34
- return (object &&
35
- typeof object === 'object' &&
36
- typeof object.arrayBuffer === 'function' &&
37
- typeof object.type === 'string' &&
38
- typeof object.stream === 'function' &&
39
- typeof object.constructor === 'function' &&
40
- /^(Blob|File)$/.test(object[NAME]));
41
- };
42
- /**
43
- * Check if `obj` is an instance of AbortSignal.
44
- * @param {*} object - Object to check for
45
- * @return {boolean}
46
- */
47
- const isAbortSignal = object => {
48
- return (typeof object === 'object' && (object[NAME] === 'AbortSignal' ||
49
- object[NAME] === 'EventTarget'));
50
- };
51
- /**
52
- * isDomainOrSubdomain reports whether sub is a subdomain (or exact match) of
53
- * the parent domain.
54
- *
55
- * Both domains must already be in canonical form.
56
- * @param {string|URL} original
57
- * @param {string|URL} destination
58
- */
59
- const isDomainOrSubdomain = (destination, original) => {
60
- const orig = new URL(original).hostname;
61
- const dest = new URL(destination).hostname;
62
- return orig === dest || orig.endsWith(`.${dest}`);
63
- };
64
- /**
65
- * isSameProtocol reports whether the two provided URLs use the same protocol.
66
- *
67
- * Both domains must already be in canonical form.
68
- * @param {string|URL} original
69
- * @param {string|URL} destination
70
- */
71
- const isSameProtocol = (destination, original) => {
72
- const orig = new URL(original).protocol;
73
- const dest = new URL(destination).protocol;
74
- return orig === dest;
75
- };
76
-
77
- exports.isAbortSignal = isAbortSignal;
78
- exports.isBlob = isBlob;
79
- exports.isDomainOrSubdomain = isDomainOrSubdomain;
80
- exports.isSameProtocol = isSameProtocol;
81
- exports.isURLSearchParameters = isURLSearchParameters;
@@ -1,292 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var node_net = require('node:net');
6
-
7
- /**
8
- * @external URL
9
- * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/URL|URL}
10
- */
11
- /**
12
- * @module utils/referrer
13
- * @private
14
- */
15
- /**
16
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#strip-url|Referrer Policy §8.4. Strip url for use as a referrer}
17
- * @param {string} URL
18
- * @param {boolean} [originOnly=false]
19
- */
20
- function stripURLForUseAsAReferrer(url, originOnly = false) {
21
- // 1. If url is null, return no referrer.
22
- if (url == null) { // eslint-disable-line no-eq-null, eqeqeq
23
- return 'no-referrer';
24
- }
25
- url = new URL(url);
26
- // 2. If url's scheme is a local scheme, then return no referrer.
27
- if (/^(about|blob|data):$/.test(url.protocol)) {
28
- return 'no-referrer';
29
- }
30
- // 3. Set url's username to the empty string.
31
- url.username = '';
32
- // 4. Set url's password to null.
33
- // Note: `null` appears to be a mistake as this actually results in the password being `"null"`.
34
- url.password = '';
35
- // 5. Set url's fragment to null.
36
- // Note: `null` appears to be a mistake as this actually results in the fragment being `"#null"`.
37
- url.hash = '';
38
- // 6. If the origin-only flag is true, then:
39
- if (originOnly) {
40
- // 6.1. Set url's path to null.
41
- // Note: `null` appears to be a mistake as this actually results in the path being `"/null"`.
42
- url.pathname = '';
43
- // 6.2. Set url's query to null.
44
- // Note: `null` appears to be a mistake as this actually results in the query being `"?null"`.
45
- url.search = '';
46
- }
47
- // 7. Return url.
48
- return url;
49
- }
50
- /**
51
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#enumdef-referrerpolicy|enum ReferrerPolicy}
52
- */
53
- const ReferrerPolicy = new Set([
54
- '',
55
- 'no-referrer',
56
- 'no-referrer-when-downgrade',
57
- 'same-origin',
58
- 'origin',
59
- 'strict-origin',
60
- 'origin-when-cross-origin',
61
- 'strict-origin-when-cross-origin',
62
- 'unsafe-url'
63
- ]);
64
- /**
65
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#default-referrer-policy|default referrer policy}
66
- */
67
- const DEFAULT_REFERRER_POLICY = 'strict-origin-when-cross-origin';
68
- /**
69
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#referrer-policies|Referrer Policy §3. Referrer Policies}
70
- * @param {string} referrerPolicy
71
- * @returns {string} referrerPolicy
72
- */
73
- function validateReferrerPolicy(referrerPolicy) {
74
- if (!ReferrerPolicy.has(referrerPolicy)) {
75
- throw new TypeError(`Invalid referrerPolicy: ${referrerPolicy}`);
76
- }
77
- return referrerPolicy;
78
- }
79
- /**
80
- * @see {@link https://w3c.github.io/webappsec-secure-contexts/#is-origin-trustworthy|Referrer Policy §3.2. Is origin potentially trustworthy?}
81
- * @param {external:URL} url
82
- * @returns `true`: "Potentially Trustworthy", `false`: "Not Trustworthy"
83
- */
84
- function isOriginPotentiallyTrustworthy(url) {
85
- // 1. If origin is an opaque origin, return "Not Trustworthy".
86
- // Not applicable
87
- // 2. Assert: origin is a tuple origin.
88
- // Not for implementations
89
- // 3. If origin's scheme is either "https" or "wss", return "Potentially Trustworthy".
90
- if (/^(http|ws)s:$/.test(url.protocol)) {
91
- return true;
92
- }
93
- // 4. If origin's host component matches one of the CIDR notations 127.0.0.0/8 or ::1/128 [RFC4632], return "Potentially Trustworthy".
94
- const hostIp = url.host.replace(/(^\[)|(]$)/g, '');
95
- const hostIPVersion = node_net.isIP(hostIp);
96
- if (hostIPVersion === 4 && /^127\./.test(hostIp)) {
97
- return true;
98
- }
99
- if (hostIPVersion === 6 && /^(((0+:){7})|(::(0+:){0,6}))0*1$/.test(hostIp)) {
100
- return true;
101
- }
102
- // 5. If origin's host component is "localhost" or falls within ".localhost", and the user agent conforms to the name resolution rules in [let-localhost-be-localhost], return "Potentially Trustworthy".
103
- // We are returning FALSE here because we cannot ensure conformance to
104
- // let-localhost-be-loalhost (https://tools.ietf.org/html/draft-west-let-localhost-be-localhost)
105
- if (url.host === 'localhost' || url.host.endsWith('.localhost')) {
106
- return false;
107
- }
108
- // 6. If origin's scheme component is file, return "Potentially Trustworthy".
109
- if (url.protocol === 'file:') {
110
- return true;
111
- }
112
- // 7. If origin's scheme component is one which the user agent considers to be authenticated, return "Potentially Trustworthy".
113
- // Not supported
114
- // 8. If origin has been configured as a trustworthy origin, return "Potentially Trustworthy".
115
- // Not supported
116
- // 9. Return "Not Trustworthy".
117
- return false;
118
- }
119
- /**
120
- * @see {@link https://w3c.github.io/webappsec-secure-contexts/#is-url-trustworthy|Referrer Policy §3.3. Is url potentially trustworthy?}
121
- * @param {external:URL} url
122
- * @returns `true`: "Potentially Trustworthy", `false`: "Not Trustworthy"
123
- */
124
- function isUrlPotentiallyTrustworthy(url) {
125
- // 1. If url is "about:blank" or "about:srcdoc", return "Potentially Trustworthy".
126
- if (/^about:(blank|srcdoc)$/.test(url)) {
127
- return true;
128
- }
129
- // 2. If url's scheme is "data", return "Potentially Trustworthy".
130
- if (url.protocol === 'data:') {
131
- return true;
132
- }
133
- // Note: The origin of blob: and filesystem: URLs is the origin of the context in which they were
134
- // created. Therefore, blobs created in a trustworthy origin will themselves be potentially
135
- // trustworthy.
136
- if (/^(blob|filesystem):$/.test(url.protocol)) {
137
- return true;
138
- }
139
- // 3. Return the result of executing §3.2 Is origin potentially trustworthy? on url's origin.
140
- return isOriginPotentiallyTrustworthy(url);
141
- }
142
- /**
143
- * Modifies the referrerURL to enforce any extra security policy considerations.
144
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#determine-requests-referrer|Referrer Policy §8.3. Determine request's Referrer}, step 7
145
- * @callback module:utils/referrer~referrerURLCallback
146
- * @param {external:URL} referrerURL
147
- * @returns {external:URL} modified referrerURL
148
- */
149
- /**
150
- * Modifies the referrerOrigin to enforce any extra security policy considerations.
151
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#determine-requests-referrer|Referrer Policy §8.3. Determine request's Referrer}, step 7
152
- * @callback module:utils/referrer~referrerOriginCallback
153
- * @param {external:URL} referrerOrigin
154
- * @returns {external:URL} modified referrerOrigin
155
- */
156
- /**
157
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#determine-requests-referrer|Referrer Policy §8.3. Determine request's Referrer}
158
- * @param {Request} request
159
- * @param {object} o
160
- * @param {module:utils/referrer~referrerURLCallback} o.referrerURLCallback
161
- * @param {module:utils/referrer~referrerOriginCallback} o.referrerOriginCallback
162
- * @returns {external:URL} Request's referrer
163
- */
164
- function determineRequestsReferrer(request, { referrerURLCallback, referrerOriginCallback } = {}) {
165
- // There are 2 notes in the specification about invalid pre-conditions. We return null, here, for
166
- // these cases:
167
- // > Note: If request's referrer is "no-referrer", Fetch will not call into this algorithm.
168
- // > Note: If request's referrer policy is the empty string, Fetch will not call into this
169
- // > algorithm.
170
- if (request.referrer === 'no-referrer' || request.referrerPolicy === '') {
171
- return null;
172
- }
173
- // 1. Let policy be request's associated referrer policy.
174
- const policy = request.referrerPolicy;
175
- // 2. Let environment be request's client.
176
- // not applicable to node.js
177
- // 3. Switch on request's referrer:
178
- if (request.referrer === 'about:client') {
179
- return 'no-referrer';
180
- }
181
- // "a URL": Let referrerSource be request's referrer.
182
- const referrerSource = request.referrer;
183
- // 4. Let request's referrerURL be the result of stripping referrerSource for use as a referrer.
184
- let referrerURL = stripURLForUseAsAReferrer(referrerSource);
185
- // 5. Let referrerOrigin be the result of stripping referrerSource for use as a referrer, with the
186
- // origin-only flag set to true.
187
- let referrerOrigin = stripURLForUseAsAReferrer(referrerSource, true);
188
- // 6. If the result of serializing referrerURL is a string whose length is greater than 4096, set
189
- // referrerURL to referrerOrigin.
190
- if (referrerURL.toString().length > 4096) {
191
- referrerURL = referrerOrigin;
192
- }
193
- // 7. The user agent MAY alter referrerURL or referrerOrigin at this point to enforce arbitrary
194
- // policy considerations in the interests of minimizing data leakage. For example, the user
195
- // agent could strip the URL down to an origin, modify its host, replace it with an empty
196
- // string, etc.
197
- if (referrerURLCallback) {
198
- referrerURL = referrerURLCallback(referrerURL);
199
- }
200
- if (referrerOriginCallback) {
201
- referrerOrigin = referrerOriginCallback(referrerOrigin);
202
- }
203
- // 8.Execute the statements corresponding to the value of policy:
204
- const currentURL = new URL(request.url);
205
- switch (policy) {
206
- case 'no-referrer':
207
- return 'no-referrer';
208
- case 'origin':
209
- return referrerOrigin;
210
- case 'unsafe-url':
211
- return referrerURL;
212
- case 'strict-origin':
213
- // 1. If referrerURL is a potentially trustworthy URL and request's current URL is not a
214
- // potentially trustworthy URL, then return no referrer.
215
- if (isUrlPotentiallyTrustworthy(referrerURL) && !isUrlPotentiallyTrustworthy(currentURL)) {
216
- return 'no-referrer';
217
- }
218
- // 2. Return referrerOrigin.
219
- return referrerOrigin.toString();
220
- case 'strict-origin-when-cross-origin':
221
- // 1. If the origin of referrerURL and the origin of request's current URL are the same, then
222
- // return referrerURL.
223
- if (referrerURL.origin === currentURL.origin) {
224
- return referrerURL;
225
- }
226
- // 2. If referrerURL is a potentially trustworthy URL and request's current URL is not a
227
- // potentially trustworthy URL, then return no referrer.
228
- if (isUrlPotentiallyTrustworthy(referrerURL) && !isUrlPotentiallyTrustworthy(currentURL)) {
229
- return 'no-referrer';
230
- }
231
- // 3. Return referrerOrigin.
232
- return referrerOrigin;
233
- case 'same-origin':
234
- // 1. If the origin of referrerURL and the origin of request's current URL are the same, then
235
- // return referrerURL.
236
- if (referrerURL.origin === currentURL.origin) {
237
- return referrerURL;
238
- }
239
- // 2. Return no referrer.
240
- return 'no-referrer';
241
- case 'origin-when-cross-origin':
242
- // 1. If the origin of referrerURL and the origin of request's current URL are the same, then
243
- // return referrerURL.
244
- if (referrerURL.origin === currentURL.origin) {
245
- return referrerURL;
246
- }
247
- // Return referrerOrigin.
248
- return referrerOrigin;
249
- case 'no-referrer-when-downgrade':
250
- // 1. If referrerURL is a potentially trustworthy URL and request's current URL is not a
251
- // potentially trustworthy URL, then return no referrer.
252
- if (isUrlPotentiallyTrustworthy(referrerURL) && !isUrlPotentiallyTrustworthy(currentURL)) {
253
- return 'no-referrer';
254
- }
255
- // 2. Return referrerURL.
256
- return referrerURL;
257
- default:
258
- throw new TypeError(`Invalid referrerPolicy: ${policy}`);
259
- }
260
- }
261
- /**
262
- * @see {@link https://w3c.github.io/webappsec-referrer-policy/#parse-referrer-policy-from-header|Referrer Policy §8.1. Parse a referrer policy from a Referrer-Policy header}
263
- * @param {Headers} headers Response headers
264
- * @returns {string} policy
265
- */
266
- function parseReferrerPolicyFromHeader(headers) {
267
- // 1. Let policy-tokens be the result of extracting header list values given `Referrer-Policy`
268
- // and response’s header list.
269
- const policyTokens = (headers.get('referrer-policy') || '').split(/[,\s]+/);
270
- // 2. Let policy be the empty string.
271
- let policy = '';
272
- // 3. For each token in policy-tokens, if token is a referrer policy and token is not the empty
273
- // string, then set policy to token.
274
- // Note: This algorithm loops over multiple policy values to allow deployment of new policy
275
- // values with fallbacks for older user agents, as described in § 11.1 Unknown Policy Values.
276
- for (const token of policyTokens) {
277
- if (token && ReferrerPolicy.has(token)) {
278
- policy = token;
279
- }
280
- }
281
- // 4. Return policy.
282
- return policy;
283
- }
284
-
285
- exports.DEFAULT_REFERRER_POLICY = DEFAULT_REFERRER_POLICY;
286
- exports.ReferrerPolicy = ReferrerPolicy;
287
- exports.determineRequestsReferrer = determineRequestsReferrer;
288
- exports.isOriginPotentiallyTrustworthy = isOriginPotentiallyTrustworthy;
289
- exports.isUrlPotentiallyTrustworthy = isUrlPotentiallyTrustworthy;
290
- exports.parseReferrerPolicyFromHeader = parseReferrerPolicyFromHeader;
291
- exports.stripURLForUseAsAReferrer = stripURLForUseAsAReferrer;
292
- exports.validateReferrerPolicy = validateReferrerPolicy;
@@ -1,103 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var http = require('http');
6
- require('https');
7
-
8
- function _interopNamespace(e) {
9
- if (e && e.__esModule) return e;
10
- var n = Object.create(null);
11
- if (e) {
12
- Object.keys(e).forEach(function (k) {
13
- if (k !== 'default') {
14
- var d = Object.getOwnPropertyDescriptor(e, k);
15
- Object.defineProperty(n, k, d.get ? d : {
16
- enumerable: true,
17
- get: function () { return e[k]; }
18
- });
19
- }
20
- });
21
- }
22
- n["default"] = e;
23
- return Object.freeze(n);
24
- }
25
-
26
- var http__namespace = /*#__PURE__*/_interopNamespace(http);
27
-
28
- function isSecureEndpoint() {
29
- const { stack } = new Error();
30
- if (typeof stack !== 'string')
31
- return false;
32
- return stack
33
- .split('\n')
34
- .some((l) => l.indexOf('(https.js:') !== -1 ||
35
- l.indexOf('node:https:') !== -1);
36
- }
37
- const INTERNAL = Symbol('AgentBaseInternalState');
38
- class Agent extends http__namespace.Agent {
39
- constructor(opts) {
40
- super(opts);
41
- this[INTERNAL] = {};
42
- }
43
- createSocket(req, options, cb) {
44
- // Need to determine whether this is an `http` or `https` request.
45
- // First check the `secureEndpoint` property explicitly, since this
46
- // means that a parent `Agent` is "passing through" to this instance.
47
- let secureEndpoint = typeof options.secureEndpoint === 'boolean'
48
- ? options.secureEndpoint
49
- : undefined;
50
- // If no explicit `secure` endpoint, check if `protocol` property is
51
- // set. This will usually be the case since using a full string URL
52
- // or `URL` instance should be the most common case.
53
- if (typeof secureEndpoint === 'undefined' &&
54
- typeof options.protocol === 'string') {
55
- secureEndpoint = options.protocol === 'https:';
56
- }
57
- // Finally, if no `protocol` property was set, then fall back to
58
- // checking the stack trace of the current call stack, and try to
59
- // detect the "https" module.
60
- if (typeof secureEndpoint === 'undefined') {
61
- secureEndpoint = isSecureEndpoint();
62
- }
63
- const connectOpts = { ...options, secureEndpoint };
64
- Promise.resolve()
65
- .then(() => this.connect(req, connectOpts))
66
- .then((socket) => {
67
- if (socket instanceof http__namespace.Agent) {
68
- // @ts-expect-error `addRequest()` isn't defined in `@types/node`
69
- return socket.addRequest(req, connectOpts);
70
- }
71
- this[INTERNAL].currentSocket = socket;
72
- // @ts-expect-error `createSocket()` isn't defined in `@types/node`
73
- super.createSocket(req, options, cb);
74
- }, cb);
75
- }
76
- createConnection() {
77
- const socket = this[INTERNAL].currentSocket;
78
- this[INTERNAL].currentSocket = undefined;
79
- if (!socket) {
80
- throw new Error('No socket was returned in the `connect()` function');
81
- }
82
- return socket;
83
- }
84
- get defaultPort() {
85
- return (this[INTERNAL].defaultPort ??
86
- (this.protocol === 'https:' ? 443 : 80));
87
- }
88
- set defaultPort(v) {
89
- if (this[INTERNAL]) {
90
- this[INTERNAL].defaultPort = v;
91
- }
92
- }
93
- get protocol() {
94
- return (this[INTERNAL].protocol ?? (isSecureEndpoint() ? 'https:' : 'http:'));
95
- }
96
- set protocol(v) {
97
- if (this[INTERNAL]) {
98
- this[INTERNAL].protocol = v;
99
- }
100
- }
101
- }
102
-
103
- exports.Agent = Agent;