ccxt 4.2.17 → 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 (439) hide show
  1. package/README.md +9 -9
  2. package/dist/ccxt.browser.js +48992 -47725
  3. package/dist/ccxt.browser.min.js +3 -3
  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/coincheck.js +208 -0
  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 +14 -2
  67. package/js/ccxt.js +10 -2
  68. package/js/src/abstract/bitpanda.d.ts +4 -4
  69. package/js/src/abstract/bitstamp.d.ts +8 -0
  70. package/js/src/abstract/gate.d.ts +1 -0
  71. package/js/src/abstract/gateio.d.ts +1 -0
  72. package/js/src/abstract/htx.d.ts +3 -0
  73. package/js/src/abstract/huobi.d.ts +3 -0
  74. package/js/src/abstract/luno.d.ts +1 -0
  75. package/js/src/abstract/onetrading.d.ts +38 -0
  76. package/js/src/ascendex.js +2 -0
  77. package/js/src/base/Exchange.d.ts +2 -3
  78. package/js/src/base/Exchange.js +5 -2
  79. package/js/src/binance.js +7 -1
  80. package/js/src/bingx.d.ts +1 -0
  81. package/js/src/bingx.js +26 -0
  82. package/js/src/bitget.js +22 -3
  83. package/js/src/bitpanda.d.ts +2 -72
  84. package/js/src/bitpanda.js +5 -1991
  85. package/js/src/bitstamp.js +8 -0
  86. package/js/src/bybit.js +21 -47
  87. package/js/src/coincheck.js +1 -0
  88. package/js/src/deribit.js +16 -4
  89. package/js/src/gate.d.ts +1 -0
  90. package/js/src/gate.js +50 -110
  91. package/js/src/htx.js +3 -0
  92. package/js/src/kraken.d.ts +1 -0
  93. package/js/src/kraken.js +40 -39
  94. package/js/src/lbank.js +1 -0
  95. package/js/src/luno.d.ts +3 -1
  96. package/js/src/luno.js +84 -2
  97. package/js/src/mexc.js +1 -2
  98. package/js/src/onetrading.d.ts +74 -0
  99. package/js/src/onetrading.js +2003 -0
  100. package/js/src/poloniexfutures.js +1 -0
  101. package/js/src/pro/binance.js +7 -2
  102. package/js/src/pro/bitget.js +1 -1
  103. package/js/src/pro/bitpanda.d.ts +2 -34
  104. package/js/src/pro/bitpanda.js +5 -1330
  105. package/js/src/pro/coincheck.d.ts +12 -0
  106. package/js/src/pro/coincheck.js +209 -0
  107. package/js/src/pro/kucoin.js +43 -35
  108. package/js/src/pro/kucoinfutures.js +45 -37
  109. package/js/src/pro/lbank.d.ts +29 -0
  110. package/js/src/pro/lbank.js +882 -0
  111. package/js/src/pro/onetrading.d.ts +36 -0
  112. package/js/src/pro/onetrading.js +1339 -0
  113. package/js/src/pro/poloniexfutures.js +43 -35
  114. package/js/src/whitebit.js +1 -0
  115. package/package.json +2 -2
  116. package/rollup.config.js +2 -0
  117. package/skip-tests.json +14 -2
  118. package/test-commonjs.cjs +25 -1
  119. package/dist/cjs/js/ccxt.js +0 -476
  120. package/dist/cjs/js/src/abstract/alpaca.js +0 -9
  121. package/dist/cjs/js/src/abstract/ascendex.js +0 -9
  122. package/dist/cjs/js/src/abstract/bigone.js +0 -9
  123. package/dist/cjs/js/src/abstract/binance.js +0 -9
  124. package/dist/cjs/js/src/abstract/bingx.js +0 -9
  125. package/dist/cjs/js/src/abstract/bit2c.js +0 -9
  126. package/dist/cjs/js/src/abstract/bitbank.js +0 -9
  127. package/dist/cjs/js/src/abstract/bitbns.js +0 -9
  128. package/dist/cjs/js/src/abstract/bitfinex.js +0 -9
  129. package/dist/cjs/js/src/abstract/bitfinex2.js +0 -9
  130. package/dist/cjs/js/src/abstract/bitflyer.js +0 -9
  131. package/dist/cjs/js/src/abstract/bitforex.js +0 -9
  132. package/dist/cjs/js/src/abstract/bitget.js +0 -9
  133. package/dist/cjs/js/src/abstract/bithumb.js +0 -9
  134. package/dist/cjs/js/src/abstract/bitmart.js +0 -9
  135. package/dist/cjs/js/src/abstract/bitmex.js +0 -9
  136. package/dist/cjs/js/src/abstract/bitopro.js +0 -9
  137. package/dist/cjs/js/src/abstract/bitpanda.js +0 -9
  138. package/dist/cjs/js/src/abstract/bitrue.js +0 -9
  139. package/dist/cjs/js/src/abstract/bitso.js +0 -9
  140. package/dist/cjs/js/src/abstract/bitstamp.js +0 -9
  141. package/dist/cjs/js/src/abstract/bitteam.js +0 -9
  142. package/dist/cjs/js/src/abstract/bitvavo.js +0 -9
  143. package/dist/cjs/js/src/abstract/bl3p.js +0 -9
  144. package/dist/cjs/js/src/abstract/blockchaincom.js +0 -9
  145. package/dist/cjs/js/src/abstract/btcalpha.js +0 -9
  146. package/dist/cjs/js/src/abstract/btcbox.js +0 -9
  147. package/dist/cjs/js/src/abstract/btcmarkets.js +0 -9
  148. package/dist/cjs/js/src/abstract/btcturk.js +0 -9
  149. package/dist/cjs/js/src/abstract/bybit.js +0 -9
  150. package/dist/cjs/js/src/abstract/cex.js +0 -9
  151. package/dist/cjs/js/src/abstract/coinbase.js +0 -9
  152. package/dist/cjs/js/src/abstract/coinbasepro.js +0 -9
  153. package/dist/cjs/js/src/abstract/coincheck.js +0 -9
  154. package/dist/cjs/js/src/abstract/coinex.js +0 -9
  155. package/dist/cjs/js/src/abstract/coinlist.js +0 -9
  156. package/dist/cjs/js/src/abstract/coinmate.js +0 -9
  157. package/dist/cjs/js/src/abstract/coinone.js +0 -9
  158. package/dist/cjs/js/src/abstract/coinsph.js +0 -9
  159. package/dist/cjs/js/src/abstract/coinspot.js +0 -9
  160. package/dist/cjs/js/src/abstract/cryptocom.js +0 -9
  161. package/dist/cjs/js/src/abstract/currencycom.js +0 -9
  162. package/dist/cjs/js/src/abstract/delta.js +0 -9
  163. package/dist/cjs/js/src/abstract/deribit.js +0 -9
  164. package/dist/cjs/js/src/abstract/digifinex.js +0 -9
  165. package/dist/cjs/js/src/abstract/exmo.js +0 -9
  166. package/dist/cjs/js/src/abstract/gate.js +0 -9
  167. package/dist/cjs/js/src/abstract/gemini.js +0 -9
  168. package/dist/cjs/js/src/abstract/hitbtc.js +0 -9
  169. package/dist/cjs/js/src/abstract/hollaex.js +0 -9
  170. package/dist/cjs/js/src/abstract/htx.js +0 -9
  171. package/dist/cjs/js/src/abstract/huobijp.js +0 -9
  172. package/dist/cjs/js/src/abstract/idex.js +0 -9
  173. package/dist/cjs/js/src/abstract/independentreserve.js +0 -9
  174. package/dist/cjs/js/src/abstract/indodax.js +0 -9
  175. package/dist/cjs/js/src/abstract/kraken.js +0 -9
  176. package/dist/cjs/js/src/abstract/krakenfutures.js +0 -9
  177. package/dist/cjs/js/src/abstract/kucoin.js +0 -9
  178. package/dist/cjs/js/src/abstract/kucoinfutures.js +0 -9
  179. package/dist/cjs/js/src/abstract/kuna.js +0 -9
  180. package/dist/cjs/js/src/abstract/latoken.js +0 -9
  181. package/dist/cjs/js/src/abstract/lbank.js +0 -9
  182. package/dist/cjs/js/src/abstract/luno.js +0 -9
  183. package/dist/cjs/js/src/abstract/lykke.js +0 -9
  184. package/dist/cjs/js/src/abstract/mercado.js +0 -9
  185. package/dist/cjs/js/src/abstract/mexc.js +0 -9
  186. package/dist/cjs/js/src/abstract/ndax.js +0 -9
  187. package/dist/cjs/js/src/abstract/novadax.js +0 -9
  188. package/dist/cjs/js/src/abstract/oceanex.js +0 -9
  189. package/dist/cjs/js/src/abstract/okcoin.js +0 -9
  190. package/dist/cjs/js/src/abstract/okx.js +0 -9
  191. package/dist/cjs/js/src/abstract/p2b.js +0 -9
  192. package/dist/cjs/js/src/abstract/paymium.js +0 -9
  193. package/dist/cjs/js/src/abstract/phemex.js +0 -9
  194. package/dist/cjs/js/src/abstract/poloniex.js +0 -9
  195. package/dist/cjs/js/src/abstract/poloniexfutures.js +0 -9
  196. package/dist/cjs/js/src/abstract/probit.js +0 -9
  197. package/dist/cjs/js/src/abstract/timex.js +0 -9
  198. package/dist/cjs/js/src/abstract/tokocrypto.js +0 -9
  199. package/dist/cjs/js/src/abstract/upbit.js +0 -9
  200. package/dist/cjs/js/src/abstract/wavesexchange.js +0 -9
  201. package/dist/cjs/js/src/abstract/wazirx.js +0 -9
  202. package/dist/cjs/js/src/abstract/whitebit.js +0 -9
  203. package/dist/cjs/js/src/abstract/woo.js +0 -9
  204. package/dist/cjs/js/src/abstract/yobit.js +0 -9
  205. package/dist/cjs/js/src/abstract/zaif.js +0 -9
  206. package/dist/cjs/js/src/abstract/zonda.js +0 -9
  207. package/dist/cjs/js/src/ace.js +0 -1058
  208. package/dist/cjs/js/src/alpaca.js +0 -1125
  209. package/dist/cjs/js/src/ascendex.js +0 -3365
  210. package/dist/cjs/js/src/base/Exchange.js +0 -5257
  211. package/dist/cjs/js/src/base/Precise.js +0 -263
  212. package/dist/cjs/js/src/base/errors.js +0 -299
  213. package/dist/cjs/js/src/base/functions/crypto.js +0 -78
  214. package/dist/cjs/js/src/base/functions/encode.js +0 -44
  215. package/dist/cjs/js/src/base/functions/generic.js +0 -193
  216. package/dist/cjs/js/src/base/functions/misc.js +0 -96
  217. package/dist/cjs/js/src/base/functions/number.js +0 -297
  218. package/dist/cjs/js/src/base/functions/platform.js +0 -28
  219. package/dist/cjs/js/src/base/functions/rsa.js +0 -34
  220. package/dist/cjs/js/src/base/functions/string.js +0 -48
  221. package/dist/cjs/js/src/base/functions/throttle.js +0 -66
  222. package/dist/cjs/js/src/base/functions/time.js +0 -187
  223. package/dist/cjs/js/src/base/functions/totp.js +0 -24
  224. package/dist/cjs/js/src/base/functions/type.js +0 -162
  225. package/dist/cjs/js/src/base/functions.js +0 -157
  226. package/dist/cjs/js/src/base/ws/Cache.js +0 -254
  227. package/dist/cjs/js/src/base/ws/Client.js +0 -299
  228. package/dist/cjs/js/src/base/ws/Future.js +0 -34
  229. package/dist/cjs/js/src/base/ws/OrderBook.js +0 -107
  230. package/dist/cjs/js/src/base/ws/OrderBookSide.js +0 -281
  231. package/dist/cjs/js/src/base/ws/WsClient.js +0 -69
  232. package/dist/cjs/js/src/bequant.js +0 -33
  233. package/dist/cjs/js/src/bigone.js +0 -2213
  234. package/dist/cjs/js/src/binance.js +0 -9845
  235. package/dist/cjs/js/src/binancecoinm.js +0 -45
  236. package/dist/cjs/js/src/binanceus.js +0 -92
  237. package/dist/cjs/js/src/binanceusdm.js +0 -58
  238. package/dist/cjs/js/src/bingx.js +0 -3846
  239. package/dist/cjs/js/src/bit2c.js +0 -916
  240. package/dist/cjs/js/src/bitbank.js +0 -1000
  241. package/dist/cjs/js/src/bitbay.js +0 -17
  242. package/dist/cjs/js/src/bitbns.js +0 -1220
  243. package/dist/cjs/js/src/bitcoincom.js +0 -17
  244. package/dist/cjs/js/src/bitfinex.js +0 -1670
  245. package/dist/cjs/js/src/bitfinex2.js +0 -2990
  246. package/dist/cjs/js/src/bitflyer.js +0 -1045
  247. package/dist/cjs/js/src/bitforex.js +0 -852
  248. package/dist/cjs/js/src/bitget.js +0 -8295
  249. package/dist/cjs/js/src/bithumb.js +0 -1090
  250. package/dist/cjs/js/src/bitmart.js +0 -4454
  251. package/dist/cjs/js/src/bitmex.js +0 -2881
  252. package/dist/cjs/js/src/bitopro.js +0 -1724
  253. package/dist/cjs/js/src/bitrue.js +0 -3253
  254. package/dist/cjs/js/src/bitso.js +0 -1753
  255. package/dist/cjs/js/src/bitstamp.js +0 -2188
  256. package/dist/cjs/js/src/bitteam.js +0 -2309
  257. package/dist/cjs/js/src/bitvavo.js +0 -1968
  258. package/dist/cjs/js/src/bl3p.js +0 -447
  259. package/dist/cjs/js/src/blockchaincom.js +0 -1160
  260. package/dist/cjs/js/src/btcalpha.js +0 -929
  261. package/dist/cjs/js/src/btcbox.js +0 -565
  262. package/dist/cjs/js/src/btcmarkets.js +0 -1237
  263. package/dist/cjs/js/src/btcturk.js +0 -929
  264. package/dist/cjs/js/src/bybit.js +0 -7650
  265. package/dist/cjs/js/src/cex.js +0 -1693
  266. package/dist/cjs/js/src/coinbase.js +0 -3424
  267. package/dist/cjs/js/src/coinbasepro.js +0 -1866
  268. package/dist/cjs/js/src/coincheck.js +0 -843
  269. package/dist/cjs/js/src/coinex.js +0 -5417
  270. package/dist/cjs/js/src/coinlist.js +0 -2337
  271. package/dist/cjs/js/src/coinmate.js +0 -989
  272. package/dist/cjs/js/src/coinone.js +0 -1185
  273. package/dist/cjs/js/src/coinsph.js +0 -1933
  274. package/dist/cjs/js/src/coinspot.js +0 -548
  275. package/dist/cjs/js/src/cryptocom.js +0 -3007
  276. package/dist/cjs/js/src/currencycom.js +0 -2015
  277. package/dist/cjs/js/src/delta.js +0 -3262
  278. package/dist/cjs/js/src/deribit.js +0 -3306
  279. package/dist/cjs/js/src/digifinex.js +0 -4307
  280. package/dist/cjs/js/src/exmo.js +0 -2645
  281. package/dist/cjs/js/src/fmfwio.js +0 -34
  282. package/dist/cjs/js/src/gate.js +0 -7077
  283. package/dist/cjs/js/src/gateio.js +0 -16
  284. package/dist/cjs/js/src/gemini.js +0 -1801
  285. package/dist/cjs/js/src/hitbtc.js +0 -3660
  286. package/dist/cjs/js/src/hitbtc3.js +0 -19
  287. package/dist/cjs/js/src/hollaex.js +0 -1882
  288. package/dist/cjs/js/src/htx.js +0 -9174
  289. package/dist/cjs/js/src/huobi.js +0 -16
  290. package/dist/cjs/js/src/huobijp.js +0 -1918
  291. package/dist/cjs/js/src/idex.js +0 -1770
  292. package/dist/cjs/js/src/independentreserve.js +0 -761
  293. package/dist/cjs/js/src/indodax.js +0 -1069
  294. package/dist/cjs/js/src/kraken.js +0 -2891
  295. package/dist/cjs/js/src/krakenfutures.js +0 -2407
  296. package/dist/cjs/js/src/kucoin.js +0 -4494
  297. package/dist/cjs/js/src/kucoinfutures.js +0 -2529
  298. package/dist/cjs/js/src/kuna.js +0 -1949
  299. package/dist/cjs/js/src/latoken.js +0 -1729
  300. package/dist/cjs/js/src/lbank.js +0 -2851
  301. package/dist/cjs/js/src/luno.js +0 -1044
  302. package/dist/cjs/js/src/lykke.js +0 -1303
  303. package/dist/cjs/js/src/mercado.js +0 -897
  304. package/dist/cjs/js/src/mexc.js +0 -5407
  305. package/dist/cjs/js/src/ndax.js +0 -2450
  306. package/dist/cjs/js/src/novadax.js +0 -1556
  307. package/dist/cjs/js/src/oceanex.js +0 -964
  308. package/dist/cjs/js/src/okcoin.js +0 -3115
  309. package/dist/cjs/js/src/okx.js +0 -7331
  310. package/dist/cjs/js/src/p2b.js +0 -1243
  311. package/dist/cjs/js/src/paymium.js +0 -597
  312. package/dist/cjs/js/src/phemex.js +0 -4725
  313. package/dist/cjs/js/src/poloniex.js +0 -2356
  314. package/dist/cjs/js/src/poloniexfutures.js +0 -1794
  315. package/dist/cjs/js/src/pro/alpaca.js +0 -714
  316. package/dist/cjs/js/src/pro/ascendex.js +0 -957
  317. package/dist/cjs/js/src/pro/bequant.js +0 -33
  318. package/dist/cjs/js/src/pro/binance.js +0 -2796
  319. package/dist/cjs/js/src/pro/binancecoinm.js +0 -23
  320. package/dist/cjs/js/src/pro/binanceus.js +0 -51
  321. package/dist/cjs/js/src/pro/binanceusdm.js +0 -32
  322. package/dist/cjs/js/src/pro/bingx.js +0 -944
  323. package/dist/cjs/js/src/pro/bitcoincom.js +0 -29
  324. package/dist/cjs/js/src/pro/bitfinex.js +0 -672
  325. package/dist/cjs/js/src/pro/bitfinex2.js +0 -1159
  326. package/dist/cjs/js/src/pro/bitget.js +0 -1733
  327. package/dist/cjs/js/src/pro/bitmart.js +0 -1486
  328. package/dist/cjs/js/src/pro/bitmex.js +0 -1576
  329. package/dist/cjs/js/src/pro/bitopro.js +0 -327
  330. package/dist/cjs/js/src/pro/bitrue.js +0 -462
  331. package/dist/cjs/js/src/pro/bitstamp.js +0 -547
  332. package/dist/cjs/js/src/pro/bitvavo.js +0 -704
  333. package/dist/cjs/js/src/pro/blockchaincom.js +0 -794
  334. package/dist/cjs/js/src/pro/bybit.js +0 -1843
  335. package/dist/cjs/js/src/pro/cex.js +0 -1510
  336. package/dist/cjs/js/src/pro/coinbase.js +0 -561
  337. package/dist/cjs/js/src/pro/coinbasepro.js +0 -968
  338. package/dist/cjs/js/src/pro/coinex.js +0 -1095
  339. package/dist/cjs/js/src/pro/cryptocom.js +0 -1020
  340. package/dist/cjs/js/src/pro/currencycom.js +0 -563
  341. package/dist/cjs/js/src/pro/deribit.js +0 -825
  342. package/dist/cjs/js/src/pro/exmo.js +0 -658
  343. package/dist/cjs/js/src/pro/gate.js +0 -1316
  344. package/dist/cjs/js/src/pro/gateio.js +0 -16
  345. package/dist/cjs/js/src/pro/gemini.js +0 -649
  346. package/dist/cjs/js/src/pro/hitbtc.js +0 -1294
  347. package/dist/cjs/js/src/pro/hollaex.js +0 -597
  348. package/dist/cjs/js/src/pro/htx.js +0 -2388
  349. package/dist/cjs/js/src/pro/huobi.js +0 -16
  350. package/dist/cjs/js/src/pro/huobijp.js +0 -606
  351. package/dist/cjs/js/src/pro/idex.js +0 -714
  352. package/dist/cjs/js/src/pro/independentreserve.js +0 -280
  353. package/dist/cjs/js/src/pro/kraken.js +0 -1364
  354. package/dist/cjs/js/src/pro/krakenfutures.js +0 -1506
  355. package/dist/cjs/js/src/pro/kucoin.js +0 -1054
  356. package/dist/cjs/js/src/pro/kucoinfutures.js +0 -981
  357. package/dist/cjs/js/src/pro/luno.js +0 -322
  358. package/dist/cjs/js/src/pro/mexc.js +0 -1170
  359. package/dist/cjs/js/src/pro/ndax.js +0 -545
  360. package/dist/cjs/js/src/pro/okcoin.js +0 -760
  361. package/dist/cjs/js/src/pro/okx.js +0 -1608
  362. package/dist/cjs/js/src/pro/phemex.js +0 -1511
  363. package/dist/cjs/js/src/pro/poloniex.js +0 -1253
  364. package/dist/cjs/js/src/pro/poloniexfutures.js +0 -1014
  365. package/dist/cjs/js/src/pro/probit.js +0 -586
  366. package/dist/cjs/js/src/pro/upbit.js +0 -234
  367. package/dist/cjs/js/src/pro/wazirx.js +0 -776
  368. package/dist/cjs/js/src/pro/whitebit.js +0 -927
  369. package/dist/cjs/js/src/pro/woo.js +0 -895
  370. package/dist/cjs/js/src/probit.js +0 -1867
  371. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +0 -401
  372. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +0 -195
  373. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +0 -308
  374. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +0 -554
  375. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +0 -94
  376. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +0 -70
  377. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +0 -91
  378. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +0 -16
  379. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +0 -1760
  380. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +0 -52
  381. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +0 -81
  382. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +0 -376
  383. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +0 -70
  384. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +0 -1580
  385. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +0 -74
  386. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +0 -24
  387. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +0 -158
  388. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +0 -429
  389. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +0 -176
  390. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +0 -324
  391. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +0 -163
  392. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +0 -245
  393. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +0 -1018
  394. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +0 -383
  395. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +0 -258
  396. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +0 -53
  397. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +0 -120
  398. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +0 -69
  399. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +0 -7
  400. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +0 -83
  401. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +0 -240
  402. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +0 -91
  403. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +0 -130
  404. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +0 -214
  405. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +0 -239
  406. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +0 -93
  407. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +0 -354
  408. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +0 -16
  409. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +0 -20
  410. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +0 -30
  411. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +0 -239
  412. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +0 -372
  413. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +0 -273
  414. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +0 -139
  415. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +0 -14
  416. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +0 -16
  417. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +0 -81
  418. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +0 -292
  419. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +0 -103
  420. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +0 -140
  421. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +0 -175
  422. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +0 -95
  423. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +0 -7
  424. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +0 -383
  425. package/dist/cjs/js/src/timex.js +0 -1562
  426. package/dist/cjs/js/src/tokocrypto.js +0 -2542
  427. package/dist/cjs/js/src/upbit.js +0 -1844
  428. package/dist/cjs/js/src/wavesexchange.js +0 -2607
  429. package/dist/cjs/js/src/wazirx.js +0 -953
  430. package/dist/cjs/js/src/whitebit.js +0 -2309
  431. package/dist/cjs/js/src/woo.js +0 -2769
  432. package/dist/cjs/js/src/yobit.js +0 -1314
  433. package/dist/cjs/js/src/zaif.js +0 -736
  434. package/dist/cjs/js/src/zonda.js +0 -1883
  435. package/dist/cjs/src/abstract/bitpanda.js +0 -9
  436. package/test.ts +0 -0
  437. /package/dist/cjs/{js/src/abstract/ace.js → src/abstract/onetrading.js} +0 -0
  438. /package/dist/cjs/{js/src → src}/pro/coinone.js +0 -0
  439. /package/js/src/abstract/{bitpanda.js → onetrading.js} +0 -0
@@ -1,52 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- // prng4.js - uses Arcfour as a PRNG
6
- class Arcfour {
7
- constructor() {
8
- this.i = 0;
9
- this.j = 0;
10
- this.S = [];
11
- }
12
- // Arcfour.prototype.init = ARC4init;
13
- // Initialize arcfour context from key, an array of ints, each from [0..255]
14
- init(key) {
15
- let i;
16
- let j;
17
- let t;
18
- for (i = 0; i < 256; ++i) {
19
- this.S[i] = i;
20
- }
21
- j = 0;
22
- for (i = 0; i < 256; ++i) {
23
- j = (j + this.S[i] + key[i % key.length]) & 255;
24
- t = this.S[i];
25
- this.S[i] = this.S[j];
26
- this.S[j] = t;
27
- }
28
- this.i = 0;
29
- this.j = 0;
30
- }
31
- // Arcfour.prototype.next = ARC4next;
32
- next() {
33
- let t;
34
- this.i = (this.i + 1) & 255;
35
- this.j = (this.j + this.S[this.i]) & 255;
36
- t = this.S[this.i];
37
- this.S[this.i] = this.S[this.j];
38
- this.S[this.j] = t;
39
- return this.S[(t + this.S[this.i]) & 255];
40
- }
41
- }
42
- // Plug in your RNG constructor here
43
- function prng_newstate() {
44
- return new Arcfour();
45
- }
46
- // Pool size must be a multiple of 4 and greater than 32.
47
- // An array of bytes the size of the pool will be passed to init()
48
- let rng_psize = 256;
49
-
50
- exports.Arcfour = Arcfour;
51
- exports.prng_newstate = prng_newstate;
52
- exports.rng_psize = rng_psize;
@@ -1,81 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var prng4 = require('./prng4.js');
6
-
7
- // Random number generator - requires a PRNG backend, e.g. prng4.js
8
- let rng_state;
9
- let rng_pool = null;
10
- let rng_pptr;
11
- // Initialize the pool with junk if needed.
12
- if (rng_pool == null) {
13
- rng_pool = [];
14
- rng_pptr = 0;
15
- let t;
16
- if (typeof window !== 'undefined' && window.crypto && window.crypto.getRandomValues) {
17
- // Extract entropy (2048 bits) from RNG if available
18
- const z = new Uint32Array(256);
19
- window.crypto.getRandomValues(z);
20
- for (t = 0; t < z.length; ++t) {
21
- rng_pool[rng_pptr++] = z[t] & 255;
22
- }
23
- }
24
- // Use mouse events for entropy, if we do not have enough entropy by the time
25
- // we need it, entropy will be generated by Math.random.
26
- var count = 0;
27
- const onMouseMoveListener = function (ev) {
28
- count = count || 0;
29
- if (count >= 256 || rng_pptr >= prng4.rng_psize) {
30
- if (window.removeEventListener) {
31
- window.removeEventListener("mousemove", onMouseMoveListener, false);
32
- }
33
- else if (window.detachEvent) {
34
- window.detachEvent("onmousemove", onMouseMoveListener);
35
- }
36
- return;
37
- }
38
- try {
39
- const mouseCoordinates = ev.x + ev.y;
40
- rng_pool[rng_pptr++] = mouseCoordinates & 255;
41
- count += 1;
42
- }
43
- catch (e) {
44
- // Sometimes Firefox will deny permission to access event properties for some reason. Ignore.
45
- }
46
- };
47
- if (typeof window !== 'undefined') {
48
- if (window.addEventListener) {
49
- window.addEventListener("mousemove", onMouseMoveListener, false);
50
- }
51
- else if (window.attachEvent) {
52
- window.attachEvent("onmousemove", onMouseMoveListener);
53
- }
54
- }
55
- }
56
- function rng_get_byte() {
57
- if (rng_state == null) {
58
- rng_state = prng4.prng_newstate();
59
- // At this point, we may not have collected enough entropy. If not, fall back to Math.random
60
- while (rng_pptr < prng4.rng_psize) {
61
- const random = Math.floor(65536 * Math.random());
62
- rng_pool[rng_pptr++] = random & 255;
63
- }
64
- rng_state.init(rng_pool);
65
- for (rng_pptr = 0; rng_pptr < rng_pool.length; ++rng_pptr) {
66
- rng_pool[rng_pptr] = 0;
67
- }
68
- rng_pptr = 0;
69
- }
70
- // TODO: allow reseeding after first request
71
- return rng_state.next();
72
- }
73
- class SecureRandom {
74
- nextBytes(ba) {
75
- for (let i = 0; i < ba.length; ++i) {
76
- ba[i] = rng_get_byte();
77
- }
78
- }
79
- }
80
-
81
- exports.SecureRandom = SecureRandom;
@@ -1,376 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var jsbn = require('./jsbn.js');
6
- var rng = require('./rng.js');
7
-
8
- // Depends on jsbn.js and rng.js
9
- // function linebrk(s,n) {
10
- // var ret = "";
11
- // var i = 0;
12
- // while(i + n < s.length) {
13
- // ret += s.substring(i,i+n) + "\n";
14
- // i += n;
15
- // }
16
- // return ret + s.substring(i,s.length);
17
- // }
18
- // function byte2Hex(b) {
19
- // if(b < 0x10)
20
- // return "0" + b.toString(16);
21
- // else
22
- // return b.toString(16);
23
- // }
24
- function pkcs1pad1(s, n) {
25
- if (n < s.length + 22) {
26
- console.error("Message too long for RSA");
27
- return null;
28
- }
29
- const len = n - s.length - 6;
30
- let filler = "";
31
- for (let f = 0; f < len; f += 2) {
32
- filler += "ff";
33
- }
34
- const m = "0001" + filler + "00" + s;
35
- return jsbn.parseBigInt(m, 16);
36
- }
37
- // PKCS#1 (type 2, random) pad input string s to n bytes, and return a bigint
38
- function pkcs1pad2(s, n) {
39
- if (n < s.length + 11) { // TODO: fix for utf-8
40
- console.error("Message too long for RSA");
41
- return null;
42
- }
43
- const ba = [];
44
- let i = s.length - 1;
45
- while (i >= 0 && n > 0) {
46
- const c = s.charCodeAt(i--);
47
- if (c < 128) { // encode using utf-8
48
- ba[--n] = c;
49
- }
50
- else if ((c > 127) && (c < 2048)) {
51
- ba[--n] = (c & 63) | 128;
52
- ba[--n] = (c >> 6) | 192;
53
- }
54
- else {
55
- ba[--n] = (c & 63) | 128;
56
- ba[--n] = ((c >> 6) & 63) | 128;
57
- ba[--n] = (c >> 12) | 224;
58
- }
59
- }
60
- ba[--n] = 0;
61
- const rng$1 = new rng.SecureRandom();
62
- const x = [];
63
- while (n > 2) { // random non-zero pad
64
- x[0] = 0;
65
- while (x[0] == 0) {
66
- rng$1.nextBytes(x);
67
- }
68
- ba[--n] = x[0];
69
- }
70
- ba[--n] = 2;
71
- ba[--n] = 0;
72
- return new jsbn.BigInteger(ba);
73
- }
74
- // "empty" RSA key constructor
75
- class RSAKey {
76
- constructor() {
77
- this.n = null;
78
- this.e = 0;
79
- this.d = null;
80
- this.p = null;
81
- this.q = null;
82
- this.dmp1 = null;
83
- this.dmq1 = null;
84
- this.coeff = null;
85
- }
86
- //#region PROTECTED
87
- // protected
88
- // RSAKey.prototype.doPublic = RSADoPublic;
89
- // Perform raw public operation on "x": return x^e (mod n)
90
- doPublic(x) {
91
- return x.modPowInt(this.e, this.n);
92
- }
93
- // RSAKey.prototype.doPrivate = RSADoPrivate;
94
- // Perform raw private operation on "x": return x^d (mod n)
95
- doPrivate(x) {
96
- if (this.p == null || this.q == null) {
97
- return x.modPow(this.d, this.n);
98
- }
99
- // TODO: re-calculate any missing CRT params
100
- let xp = x.mod(this.p).modPow(this.dmp1, this.p);
101
- const xq = x.mod(this.q).modPow(this.dmq1, this.q);
102
- while (xp.compareTo(xq) < 0) {
103
- xp = xp.add(this.p);
104
- }
105
- return xp.subtract(xq).multiply(this.coeff).mod(this.p).multiply(this.q).add(xq);
106
- }
107
- //#endregion PROTECTED
108
- //#region PUBLIC
109
- // RSAKey.prototype.setPublic = RSASetPublic;
110
- // Set the public key fields N and e from hex strings
111
- setPublic(N, E) {
112
- if (N != null && E != null && N.length > 0 && E.length > 0) {
113
- this.n = jsbn.parseBigInt(N, 16);
114
- this.e = parseInt(E, 16);
115
- }
116
- else {
117
- console.error("Invalid RSA public key");
118
- }
119
- }
120
- // RSAKey.prototype.encrypt = RSAEncrypt;
121
- // Return the PKCS#1 RSA encryption of "text" as an even-length hex string
122
- encrypt(text) {
123
- const maxLength = (this.n.bitLength() + 7) >> 3;
124
- const m = pkcs1pad2(text, maxLength);
125
- if (m == null) {
126
- return null;
127
- }
128
- const c = this.doPublic(m);
129
- if (c == null) {
130
- return null;
131
- }
132
- let h = c.toString(16);
133
- let length = h.length;
134
- // fix zero before result
135
- for (let i = 0; i < maxLength * 2 - length; i++) {
136
- h = "0" + h;
137
- }
138
- return h;
139
- }
140
- // RSAKey.prototype.setPrivate = RSASetPrivate;
141
- // Set the private key fields N, e, and d from hex strings
142
- setPrivate(N, E, D) {
143
- if (N != null && E != null && N.length > 0 && E.length > 0) {
144
- this.n = jsbn.parseBigInt(N, 16);
145
- this.e = parseInt(E, 16);
146
- this.d = jsbn.parseBigInt(D, 16);
147
- }
148
- else {
149
- console.error("Invalid RSA private key");
150
- }
151
- }
152
- // RSAKey.prototype.setPrivateEx = RSASetPrivateEx;
153
- // Set the private key fields N, e, d and CRT params from hex strings
154
- setPrivateEx(N, E, D, P, Q, DP, DQ, C) {
155
- if (N != null && E != null && N.length > 0 && E.length > 0) {
156
- this.n = jsbn.parseBigInt(N, 16);
157
- this.e = parseInt(E, 16);
158
- this.d = jsbn.parseBigInt(D, 16);
159
- this.p = jsbn.parseBigInt(P, 16);
160
- this.q = jsbn.parseBigInt(Q, 16);
161
- this.dmp1 = jsbn.parseBigInt(DP, 16);
162
- this.dmq1 = jsbn.parseBigInt(DQ, 16);
163
- this.coeff = jsbn.parseBigInt(C, 16);
164
- }
165
- else {
166
- console.error("Invalid RSA private key");
167
- }
168
- }
169
- // RSAKey.prototype.generate = RSAGenerate;
170
- // Generate a new random private key B bits long, using public expt E
171
- generate(B, E) {
172
- const rng$1 = new rng.SecureRandom();
173
- const qs = B >> 1;
174
- this.e = parseInt(E, 16);
175
- const ee = new jsbn.BigInteger(E, 16);
176
- for (;;) {
177
- for (;;) {
178
- this.p = new jsbn.BigInteger(B - qs, 1, rng$1);
179
- if (this.p.subtract(jsbn.BigInteger.ONE).gcd(ee).compareTo(jsbn.BigInteger.ONE) == 0 && this.p.isProbablePrime(10)) {
180
- break;
181
- }
182
- }
183
- for (;;) {
184
- this.q = new jsbn.BigInteger(qs, 1, rng$1);
185
- if (this.q.subtract(jsbn.BigInteger.ONE).gcd(ee).compareTo(jsbn.BigInteger.ONE) == 0 && this.q.isProbablePrime(10)) {
186
- break;
187
- }
188
- }
189
- if (this.p.compareTo(this.q) <= 0) {
190
- const t = this.p;
191
- this.p = this.q;
192
- this.q = t;
193
- }
194
- const p1 = this.p.subtract(jsbn.BigInteger.ONE);
195
- const q1 = this.q.subtract(jsbn.BigInteger.ONE);
196
- const phi = p1.multiply(q1);
197
- if (phi.gcd(ee).compareTo(jsbn.BigInteger.ONE) == 0) {
198
- this.n = this.p.multiply(this.q);
199
- this.d = ee.modInverse(phi);
200
- this.dmp1 = this.d.mod(p1);
201
- this.dmq1 = this.d.mod(q1);
202
- this.coeff = this.q.modInverse(this.p);
203
- break;
204
- }
205
- }
206
- }
207
- // RSAKey.prototype.decrypt = RSADecrypt;
208
- // Return the PKCS#1 RSA decryption of "ctext".
209
- // "ctext" is an even-length hex string and the output is a plain string.
210
- decrypt(ctext) {
211
- const c = jsbn.parseBigInt(ctext, 16);
212
- const m = this.doPrivate(c);
213
- if (m == null) {
214
- return null;
215
- }
216
- return pkcs1unpad2(m, (this.n.bitLength() + 7) >> 3);
217
- }
218
- // Generate a new random private key B bits long, using public expt E
219
- generateAsync(B, E, callback) {
220
- const rng$1 = new rng.SecureRandom();
221
- const qs = B >> 1;
222
- this.e = parseInt(E, 16);
223
- const ee = new jsbn.BigInteger(E, 16);
224
- const rsa = this;
225
- // These functions have non-descript names because they were originally for(;;) loops.
226
- // I don't know about cryptography to give them better names than loop1-4.
227
- const loop1 = function () {
228
- const loop4 = function () {
229
- if (rsa.p.compareTo(rsa.q) <= 0) {
230
- const t = rsa.p;
231
- rsa.p = rsa.q;
232
- rsa.q = t;
233
- }
234
- const p1 = rsa.p.subtract(jsbn.BigInteger.ONE);
235
- const q1 = rsa.q.subtract(jsbn.BigInteger.ONE);
236
- const phi = p1.multiply(q1);
237
- if (phi.gcd(ee).compareTo(jsbn.BigInteger.ONE) == 0) {
238
- rsa.n = rsa.p.multiply(rsa.q);
239
- rsa.d = ee.modInverse(phi);
240
- rsa.dmp1 = rsa.d.mod(p1);
241
- rsa.dmq1 = rsa.d.mod(q1);
242
- rsa.coeff = rsa.q.modInverse(rsa.p);
243
- setTimeout(function () { callback(); }, 0); // escape
244
- }
245
- else {
246
- setTimeout(loop1, 0);
247
- }
248
- };
249
- const loop3 = function () {
250
- rsa.q = jsbn.nbi();
251
- rsa.q.fromNumberAsync(qs, 1, rng$1, function () {
252
- rsa.q.subtract(jsbn.BigInteger.ONE).gcda(ee, function (r) {
253
- if (r.compareTo(jsbn.BigInteger.ONE) == 0 && rsa.q.isProbablePrime(10)) {
254
- setTimeout(loop4, 0);
255
- }
256
- else {
257
- setTimeout(loop3, 0);
258
- }
259
- });
260
- });
261
- };
262
- const loop2 = function () {
263
- rsa.p = jsbn.nbi();
264
- rsa.p.fromNumberAsync(B - qs, 1, rng$1, function () {
265
- rsa.p.subtract(jsbn.BigInteger.ONE).gcda(ee, function (r) {
266
- if (r.compareTo(jsbn.BigInteger.ONE) == 0 && rsa.p.isProbablePrime(10)) {
267
- setTimeout(loop3, 0);
268
- }
269
- else {
270
- setTimeout(loop2, 0);
271
- }
272
- });
273
- });
274
- };
275
- setTimeout(loop2, 0);
276
- };
277
- setTimeout(loop1, 0);
278
- }
279
- sign(text, digestMethod, digestName) {
280
- const header = getDigestHeader(digestName);
281
- const digest = header + digestMethod(text).toString();
282
- const m = pkcs1pad1(digest, this.n.bitLength() / 4);
283
- if (m == null) {
284
- return null;
285
- }
286
- const c = this.doPrivate(m);
287
- if (c == null) {
288
- return null;
289
- }
290
- const h = c.toString(16);
291
- if ((h.length & 1) == 0) {
292
- return h;
293
- }
294
- else {
295
- return "0" + h;
296
- }
297
- }
298
- verify(text, signature, digestMethod) {
299
- const c = jsbn.parseBigInt(signature, 16);
300
- const m = this.doPublic(c);
301
- if (m == null) {
302
- return null;
303
- }
304
- const unpadded = m.toString(16).replace(/^1f+00/, "");
305
- const digest = removeDigestHeader(unpadded);
306
- return digest == digestMethod(text).toString();
307
- }
308
- }
309
- // Undo PKCS#1 (type 2, random) padding and, if valid, return the plaintext
310
- function pkcs1unpad2(d, n) {
311
- const b = d.toByteArray();
312
- let i = 0;
313
- while (i < b.length && b[i] == 0) {
314
- ++i;
315
- }
316
- if (b.length - i != n - 1 || b[i] != 2) {
317
- return null;
318
- }
319
- ++i;
320
- while (b[i] != 0) {
321
- if (++i >= b.length) {
322
- return null;
323
- }
324
- }
325
- let ret = "";
326
- while (++i < b.length) {
327
- const c = b[i] & 255;
328
- if (c < 128) { // utf-8 decode
329
- ret += String.fromCharCode(c);
330
- }
331
- else if ((c > 191) && (c < 224)) {
332
- ret += String.fromCharCode(((c & 31) << 6) | (b[i + 1] & 63));
333
- ++i;
334
- }
335
- else {
336
- ret += String.fromCharCode(((c & 15) << 12) | ((b[i + 1] & 63) << 6) | (b[i + 2] & 63));
337
- i += 2;
338
- }
339
- }
340
- return ret;
341
- }
342
- // https://tools.ietf.org/html/rfc3447#page-43
343
- const DIGEST_HEADERS = {
344
- md2: "3020300c06082a864886f70d020205000410",
345
- md5: "3020300c06082a864886f70d020505000410",
346
- sha1: "3021300906052b0e03021a05000414",
347
- sha224: "302d300d06096086480165030402040500041c",
348
- sha256: "3031300d060960864801650304020105000420",
349
- sha384: "3041300d060960864801650304020205000430",
350
- sha512: "3051300d060960864801650304020305000440",
351
- ripemd160: "3021300906052b2403020105000414"
352
- };
353
- function getDigestHeader(name) {
354
- return DIGEST_HEADERS[name] || "";
355
- }
356
- function removeDigestHeader(str) {
357
- for (const name in DIGEST_HEADERS) {
358
- if (DIGEST_HEADERS.hasOwnProperty(name)) {
359
- const header = DIGEST_HEADERS[name];
360
- const len = header.length;
361
- if (str.substr(0, len) == header) {
362
- return str.substr(len);
363
- }
364
- }
365
- }
366
- return str;
367
- }
368
- // Return the PKCS#1 RSA encryption of "text" as a Base64-encoded string
369
- // function RSAEncryptB64(text) {
370
- // var h = this.encrypt(text);
371
- // if(h) return hex2b64(h); else return null;
372
- // }
373
- // public
374
- // RSAKey.prototype.encrypt_b64 = RSAEncryptB64;
375
-
376
- exports.RSAKey = RSAKey;
@@ -1,70 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- const BI_RM = "0123456789abcdefghijklmnopqrstuvwxyz";
6
- function int2char(n) {
7
- return BI_RM.charAt(n);
8
- }
9
- //#region BIT_OPERATIONS
10
- // (public) this & a
11
- function op_and(x, y) {
12
- return x & y;
13
- }
14
- // (public) this | a
15
- function op_or(x, y) {
16
- return x | y;
17
- }
18
- // (public) this ^ a
19
- function op_xor(x, y) {
20
- return x ^ y;
21
- }
22
- // (public) this & ~a
23
- function op_andnot(x, y) {
24
- return x & ~y;
25
- }
26
- // return index of lowest 1-bit in x, x < 2^31
27
- function lbit(x) {
28
- if (x == 0) {
29
- return -1;
30
- }
31
- let r = 0;
32
- if ((x & 0xffff) == 0) {
33
- x >>= 16;
34
- r += 16;
35
- }
36
- if ((x & 0xff) == 0) {
37
- x >>= 8;
38
- r += 8;
39
- }
40
- if ((x & 0xf) == 0) {
41
- x >>= 4;
42
- r += 4;
43
- }
44
- if ((x & 3) == 0) {
45
- x >>= 2;
46
- r += 2;
47
- }
48
- if ((x & 1) == 0) {
49
- ++r;
50
- }
51
- return r;
52
- }
53
- // return number of 1 bits in x
54
- function cbit(x) {
55
- let r = 0;
56
- while (x != 0) {
57
- x &= x - 1;
58
- ++r;
59
- }
60
- return r;
61
- }
62
- //#endregion BIT_OPERATIONS
63
-
64
- exports.cbit = cbit;
65
- exports.int2char = int2char;
66
- exports.lbit = lbit;
67
- exports.op_and = op_and;
68
- exports.op_andnot = op_andnot;
69
- exports.op_or = op_or;
70
- exports.op_xor = op_xor;