ccxt 4.2.11 → 4.2.12

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 (375) hide show
  1. package/README.md +5 -5
  2. package/build.sh +2 -2
  3. package/dist/ccxt.browser.js +640 -261
  4. package/dist/ccxt.browser.min.js +3 -3
  5. package/dist/cjs/_virtual/agent.js +7 -0
  6. package/dist/cjs/_virtual/parse-proxy-response.js +7 -0
  7. package/dist/cjs/_virtual/promisify.js +7 -0
  8. package/dist/cjs/ccxt.js +1 -1
  9. package/dist/cjs/js/ccxt.js +474 -0
  10. package/dist/cjs/js/src/abstract/ace.js +9 -0
  11. package/dist/cjs/js/src/abstract/alpaca.js +9 -0
  12. package/dist/cjs/js/src/abstract/ascendex.js +9 -0
  13. package/dist/cjs/js/src/abstract/bigone.js +9 -0
  14. package/dist/cjs/js/src/abstract/binance.js +9 -0
  15. package/dist/cjs/js/src/abstract/bingx.js +9 -0
  16. package/dist/cjs/js/src/abstract/bit2c.js +9 -0
  17. package/dist/cjs/js/src/abstract/bitbank.js +9 -0
  18. package/dist/cjs/js/src/abstract/bitbns.js +9 -0
  19. package/dist/cjs/js/src/abstract/bitfinex.js +9 -0
  20. package/dist/cjs/js/src/abstract/bitfinex2.js +9 -0
  21. package/dist/cjs/js/src/abstract/bitflyer.js +9 -0
  22. package/dist/cjs/js/src/abstract/bitforex.js +9 -0
  23. package/dist/cjs/js/src/abstract/bitget.js +9 -0
  24. package/dist/cjs/js/src/abstract/bithumb.js +9 -0
  25. package/dist/cjs/js/src/abstract/bitmart.js +9 -0
  26. package/dist/cjs/js/src/abstract/bitmex.js +9 -0
  27. package/dist/cjs/js/src/abstract/bitopro.js +9 -0
  28. package/dist/cjs/js/src/abstract/bitpanda.js +9 -0
  29. package/dist/cjs/js/src/abstract/bitrue.js +9 -0
  30. package/dist/cjs/js/src/abstract/bitso.js +9 -0
  31. package/dist/cjs/js/src/abstract/bitstamp.js +9 -0
  32. package/dist/cjs/js/src/abstract/bitteam.js +9 -0
  33. package/dist/cjs/js/src/abstract/bitvavo.js +9 -0
  34. package/dist/cjs/js/src/abstract/bl3p.js +9 -0
  35. package/dist/cjs/js/src/abstract/blockchaincom.js +9 -0
  36. package/dist/cjs/js/src/abstract/btcalpha.js +9 -0
  37. package/dist/cjs/js/src/abstract/btcbox.js +9 -0
  38. package/dist/cjs/js/src/abstract/btcmarkets.js +9 -0
  39. package/dist/cjs/js/src/abstract/btcturk.js +9 -0
  40. package/dist/cjs/js/src/abstract/bybit.js +9 -0
  41. package/dist/cjs/js/src/abstract/cex.js +9 -0
  42. package/dist/cjs/js/src/abstract/coinbase.js +9 -0
  43. package/dist/cjs/js/src/abstract/coinbasepro.js +9 -0
  44. package/dist/cjs/js/src/abstract/coincheck.js +9 -0
  45. package/dist/cjs/js/src/abstract/coinex.js +9 -0
  46. package/dist/cjs/js/src/abstract/coinlist.js +9 -0
  47. package/dist/cjs/js/src/abstract/coinmate.js +9 -0
  48. package/dist/cjs/js/src/abstract/coinone.js +9 -0
  49. package/dist/cjs/js/src/abstract/coinsph.js +9 -0
  50. package/dist/cjs/js/src/abstract/coinspot.js +9 -0
  51. package/dist/cjs/js/src/abstract/cryptocom.js +9 -0
  52. package/dist/cjs/js/src/abstract/currencycom.js +9 -0
  53. package/dist/cjs/js/src/abstract/delta.js +9 -0
  54. package/dist/cjs/js/src/abstract/deribit.js +9 -0
  55. package/dist/cjs/js/src/abstract/digifinex.js +9 -0
  56. package/dist/cjs/js/src/abstract/exmo.js +9 -0
  57. package/dist/cjs/js/src/abstract/gate.js +9 -0
  58. package/dist/cjs/js/src/abstract/gemini.js +9 -0
  59. package/dist/cjs/js/src/abstract/hitbtc.js +9 -0
  60. package/dist/cjs/js/src/abstract/hollaex.js +9 -0
  61. package/dist/cjs/js/src/abstract/htx.js +9 -0
  62. package/dist/cjs/js/src/abstract/huobijp.js +9 -0
  63. package/dist/cjs/js/src/abstract/idex.js +9 -0
  64. package/dist/cjs/js/src/abstract/independentreserve.js +9 -0
  65. package/dist/cjs/js/src/abstract/indodax.js +9 -0
  66. package/dist/cjs/js/src/abstract/kraken.js +9 -0
  67. package/dist/cjs/js/src/abstract/krakenfutures.js +9 -0
  68. package/dist/cjs/js/src/abstract/kucoin.js +9 -0
  69. package/dist/cjs/js/src/abstract/kucoinfutures.js +9 -0
  70. package/dist/cjs/js/src/abstract/kuna.js +9 -0
  71. package/dist/cjs/js/src/abstract/latoken.js +9 -0
  72. package/dist/cjs/js/src/abstract/lbank.js +9 -0
  73. package/dist/cjs/js/src/abstract/luno.js +9 -0
  74. package/dist/cjs/js/src/abstract/lykke.js +9 -0
  75. package/dist/cjs/js/src/abstract/mercado.js +9 -0
  76. package/dist/cjs/js/src/abstract/mexc.js +9 -0
  77. package/dist/cjs/js/src/abstract/ndax.js +9 -0
  78. package/dist/cjs/js/src/abstract/novadax.js +9 -0
  79. package/dist/cjs/js/src/abstract/oceanex.js +9 -0
  80. package/dist/cjs/js/src/abstract/okcoin.js +9 -0
  81. package/dist/cjs/js/src/abstract/okx.js +9 -0
  82. package/dist/cjs/js/src/abstract/p2b.js +9 -0
  83. package/dist/cjs/js/src/abstract/paymium.js +9 -0
  84. package/dist/cjs/js/src/abstract/phemex.js +9 -0
  85. package/dist/cjs/js/src/abstract/poloniex.js +9 -0
  86. package/dist/cjs/js/src/abstract/poloniexfutures.js +9 -0
  87. package/dist/cjs/js/src/abstract/probit.js +9 -0
  88. package/dist/cjs/js/src/abstract/timex.js +9 -0
  89. package/dist/cjs/js/src/abstract/tokocrypto.js +9 -0
  90. package/dist/cjs/js/src/abstract/upbit.js +9 -0
  91. package/dist/cjs/js/src/abstract/wavesexchange.js +9 -0
  92. package/dist/cjs/js/src/abstract/wazirx.js +9 -0
  93. package/dist/cjs/js/src/abstract/whitebit.js +9 -0
  94. package/dist/cjs/js/src/abstract/woo.js +9 -0
  95. package/dist/cjs/js/src/abstract/yobit.js +9 -0
  96. package/dist/cjs/js/src/abstract/zaif.js +9 -0
  97. package/dist/cjs/js/src/abstract/zonda.js +9 -0
  98. package/dist/cjs/js/src/ace.js +1058 -0
  99. package/dist/cjs/js/src/alpaca.js +1125 -0
  100. package/dist/cjs/js/src/ascendex.js +3360 -0
  101. package/dist/cjs/js/src/base/Exchange.js +5110 -0
  102. package/dist/cjs/js/src/base/Precise.js +263 -0
  103. package/dist/cjs/js/src/base/errors.js +299 -0
  104. package/dist/cjs/js/src/base/functions/crypto.js +78 -0
  105. package/dist/cjs/js/src/base/functions/encode.js +44 -0
  106. package/dist/cjs/js/src/base/functions/generic.js +193 -0
  107. package/dist/cjs/js/src/base/functions/misc.js +96 -0
  108. package/dist/cjs/js/src/base/functions/number.js +297 -0
  109. package/dist/cjs/js/src/base/functions/platform.js +28 -0
  110. package/dist/cjs/js/src/base/functions/rsa.js +34 -0
  111. package/dist/cjs/js/src/base/functions/string.js +48 -0
  112. package/dist/cjs/js/src/base/functions/throttle.js +66 -0
  113. package/dist/cjs/js/src/base/functions/time.js +187 -0
  114. package/dist/cjs/js/src/base/functions/totp.js +24 -0
  115. package/dist/cjs/js/src/base/functions/type.js +162 -0
  116. package/dist/cjs/js/src/base/functions.js +157 -0
  117. package/dist/cjs/js/src/base/ws/Cache.js +254 -0
  118. package/dist/cjs/js/src/base/ws/Client.js +299 -0
  119. package/dist/cjs/js/src/base/ws/Future.js +34 -0
  120. package/dist/cjs/js/src/base/ws/OrderBook.js +107 -0
  121. package/dist/cjs/js/src/base/ws/OrderBookSide.js +281 -0
  122. package/dist/cjs/js/src/base/ws/WsClient.js +69 -0
  123. package/dist/cjs/js/src/bequant.js +33 -0
  124. package/dist/cjs/js/src/bigone.js +2142 -0
  125. package/dist/cjs/js/src/binance.js +9729 -0
  126. package/dist/cjs/js/src/binancecoinm.js +45 -0
  127. package/dist/cjs/js/src/binanceus.js +84 -0
  128. package/dist/cjs/js/src/binanceusdm.js +58 -0
  129. package/dist/cjs/js/src/bingx.js +3737 -0
  130. package/dist/cjs/js/src/bit2c.js +916 -0
  131. package/dist/cjs/js/src/bitbank.js +1000 -0
  132. package/dist/cjs/js/src/bitbay.js +17 -0
  133. package/dist/cjs/js/src/bitbns.js +1220 -0
  134. package/dist/cjs/js/src/bitcoincom.js +17 -0
  135. package/dist/cjs/js/src/bitfinex.js +1670 -0
  136. package/dist/cjs/js/src/bitfinex2.js +2990 -0
  137. package/dist/cjs/js/src/bitflyer.js +1045 -0
  138. package/dist/cjs/js/src/bitforex.js +852 -0
  139. package/dist/cjs/js/src/bitget.js +8284 -0
  140. package/dist/cjs/js/src/bithumb.js +1090 -0
  141. package/dist/cjs/js/src/bitmart.js +4454 -0
  142. package/dist/cjs/js/src/bitmex.js +2884 -0
  143. package/dist/cjs/js/src/bitopro.js +1724 -0
  144. package/dist/cjs/js/src/bitpanda.js +2002 -0
  145. package/dist/cjs/js/src/bitrue.js +3253 -0
  146. package/dist/cjs/js/src/bitso.js +1753 -0
  147. package/dist/cjs/js/src/bitstamp.js +2188 -0
  148. package/dist/cjs/js/src/bitteam.js +2309 -0
  149. package/dist/cjs/js/src/bitvavo.js +1968 -0
  150. package/dist/cjs/js/src/bl3p.js +447 -0
  151. package/dist/cjs/js/src/blockchaincom.js +1160 -0
  152. package/dist/cjs/js/src/btcalpha.js +929 -0
  153. package/dist/cjs/js/src/btcbox.js +565 -0
  154. package/dist/cjs/js/src/btcmarkets.js +1237 -0
  155. package/dist/cjs/js/src/btcturk.js +929 -0
  156. package/dist/cjs/js/src/bybit.js +7646 -0
  157. package/dist/cjs/js/src/cex.js +1693 -0
  158. package/dist/cjs/js/src/coinbase.js +3274 -0
  159. package/dist/cjs/js/src/coinbasepro.js +1866 -0
  160. package/dist/cjs/js/src/coincheck.js +843 -0
  161. package/dist/cjs/js/src/coinex.js +5414 -0
  162. package/dist/cjs/js/src/coinlist.js +2329 -0
  163. package/dist/cjs/js/src/coinmate.js +989 -0
  164. package/dist/cjs/js/src/coinone.js +1185 -0
  165. package/dist/cjs/js/src/coinsph.js +1933 -0
  166. package/dist/cjs/js/src/coinspot.js +548 -0
  167. package/dist/cjs/js/src/cryptocom.js +3007 -0
  168. package/dist/cjs/js/src/currencycom.js +2015 -0
  169. package/dist/cjs/js/src/delta.js +3256 -0
  170. package/dist/cjs/js/src/deribit.js +3306 -0
  171. package/dist/cjs/js/src/digifinex.js +4307 -0
  172. package/dist/cjs/js/src/exmo.js +2645 -0
  173. package/dist/cjs/js/src/fmfwio.js +34 -0
  174. package/dist/cjs/js/src/gate.js +7054 -0
  175. package/dist/cjs/js/src/gateio.js +16 -0
  176. package/dist/cjs/js/src/gemini.js +1801 -0
  177. package/dist/cjs/js/src/hitbtc.js +3660 -0
  178. package/dist/cjs/js/src/hitbtc3.js +19 -0
  179. package/dist/cjs/js/src/hollaex.js +1882 -0
  180. package/dist/cjs/js/src/htx.js +9024 -0
  181. package/dist/cjs/js/src/huobi.js +16 -0
  182. package/dist/cjs/js/src/huobijp.js +1918 -0
  183. package/dist/cjs/js/src/idex.js +1770 -0
  184. package/dist/cjs/js/src/independentreserve.js +759 -0
  185. package/dist/cjs/js/src/indodax.js +1069 -0
  186. package/dist/cjs/js/src/kraken.js +2861 -0
  187. package/dist/cjs/js/src/krakenfutures.js +2407 -0
  188. package/dist/cjs/js/src/kucoin.js +4489 -0
  189. package/dist/cjs/js/src/kucoinfutures.js +2475 -0
  190. package/dist/cjs/js/src/kuna.js +1949 -0
  191. package/dist/cjs/js/src/latoken.js +1729 -0
  192. package/dist/cjs/js/src/lbank.js +2825 -0
  193. package/dist/cjs/js/src/luno.js +1044 -0
  194. package/dist/cjs/js/src/lykke.js +1303 -0
  195. package/dist/cjs/js/src/mercado.js +897 -0
  196. package/dist/cjs/js/src/mexc.js +5407 -0
  197. package/dist/cjs/js/src/ndax.js +2450 -0
  198. package/dist/cjs/js/src/novadax.js +1556 -0
  199. package/dist/cjs/js/src/oceanex.js +964 -0
  200. package/dist/cjs/js/src/okcoin.js +3115 -0
  201. package/dist/cjs/js/src/okx.js +7329 -0
  202. package/dist/cjs/js/src/p2b.js +1243 -0
  203. package/dist/cjs/js/src/paymium.js +597 -0
  204. package/dist/cjs/js/src/phemex.js +4715 -0
  205. package/dist/cjs/js/src/poloniex.js +2356 -0
  206. package/dist/cjs/js/src/poloniexfutures.js +1794 -0
  207. package/dist/cjs/js/src/pro/alpaca.js +714 -0
  208. package/dist/cjs/js/src/pro/ascendex.js +957 -0
  209. package/dist/cjs/js/src/pro/bequant.js +33 -0
  210. package/dist/cjs/js/src/pro/binance.js +2796 -0
  211. package/dist/cjs/js/src/pro/binancecoinm.js +23 -0
  212. package/dist/cjs/js/src/pro/binanceus.js +51 -0
  213. package/dist/cjs/js/src/pro/binanceusdm.js +32 -0
  214. package/dist/cjs/js/src/pro/bingx.js +944 -0
  215. package/dist/cjs/js/src/pro/bitcoincom.js +29 -0
  216. package/dist/cjs/js/src/pro/bitfinex.js +672 -0
  217. package/dist/cjs/js/src/pro/bitfinex2.js +1159 -0
  218. package/dist/cjs/js/src/pro/bitget.js +1733 -0
  219. package/dist/cjs/js/src/pro/bitmart.js +1486 -0
  220. package/dist/cjs/js/src/pro/bitmex.js +1576 -0
  221. package/dist/cjs/js/src/pro/bitopro.js +327 -0
  222. package/dist/cjs/js/src/pro/bitpanda.js +1341 -0
  223. package/dist/cjs/js/src/pro/bitrue.js +462 -0
  224. package/dist/cjs/js/src/pro/bitstamp.js +547 -0
  225. package/dist/cjs/js/src/pro/bitvavo.js +704 -0
  226. package/dist/cjs/js/src/pro/blockchaincom.js +794 -0
  227. package/dist/cjs/js/src/pro/bybit.js +1843 -0
  228. package/dist/cjs/js/src/pro/cex.js +1510 -0
  229. package/dist/cjs/js/src/pro/coinbase.js +561 -0
  230. package/dist/cjs/js/src/pro/coinbasepro.js +968 -0
  231. package/dist/cjs/js/src/pro/coinex.js +1095 -0
  232. package/dist/cjs/js/src/pro/cryptocom.js +1020 -0
  233. package/dist/cjs/js/src/pro/currencycom.js +563 -0
  234. package/dist/cjs/js/src/pro/deribit.js +825 -0
  235. package/dist/cjs/js/src/pro/exmo.js +658 -0
  236. package/dist/cjs/js/src/pro/gate.js +1316 -0
  237. package/dist/cjs/js/src/pro/gateio.js +16 -0
  238. package/dist/cjs/js/src/pro/gemini.js +649 -0
  239. package/dist/cjs/js/src/pro/hitbtc.js +1293 -0
  240. package/dist/cjs/js/src/pro/hollaex.js +597 -0
  241. package/dist/cjs/js/src/pro/htx.js +2383 -0
  242. package/dist/cjs/js/src/pro/huobi.js +16 -0
  243. package/dist/cjs/js/src/pro/huobijp.js +606 -0
  244. package/dist/cjs/js/src/pro/idex.js +714 -0
  245. package/dist/cjs/js/src/pro/independentreserve.js +280 -0
  246. package/dist/cjs/js/src/pro/kraken.js +1364 -0
  247. package/dist/cjs/js/src/pro/krakenfutures.js +1500 -0
  248. package/dist/cjs/js/src/pro/kucoin.js +1052 -0
  249. package/dist/cjs/js/src/pro/kucoinfutures.js +981 -0
  250. package/dist/cjs/js/src/pro/luno.js +322 -0
  251. package/dist/cjs/js/src/pro/mexc.js +1170 -0
  252. package/dist/cjs/js/src/pro/ndax.js +545 -0
  253. package/dist/cjs/js/src/pro/okcoin.js +760 -0
  254. package/dist/cjs/js/src/pro/okx.js +1558 -0
  255. package/dist/cjs/js/src/pro/phemex.js +1511 -0
  256. package/dist/cjs/js/src/pro/poloniex.js +1253 -0
  257. package/dist/cjs/js/src/pro/poloniexfutures.js +1014 -0
  258. package/dist/cjs/js/src/pro/probit.js +586 -0
  259. package/dist/cjs/js/src/pro/upbit.js +234 -0
  260. package/dist/cjs/js/src/pro/wazirx.js +776 -0
  261. package/dist/cjs/js/src/pro/whitebit.js +927 -0
  262. package/dist/cjs/js/src/pro/woo.js +769 -0
  263. package/dist/cjs/js/src/probit.js +1865 -0
  264. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +401 -0
  265. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +195 -0
  266. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +308 -0
  267. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +554 -0
  268. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
  269. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
  270. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
  271. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +16 -0
  272. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1760 -0
  273. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +52 -0
  274. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +81 -0
  275. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +376 -0
  276. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +70 -0
  277. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1580 -0
  278. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +74 -0
  279. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +24 -0
  280. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +158 -0
  281. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +429 -0
  282. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +176 -0
  283. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +324 -0
  284. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +163 -0
  285. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +245 -0
  286. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +1018 -0
  287. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +383 -0
  288. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +258 -0
  289. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +53 -0
  290. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +120 -0
  291. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +69 -0
  292. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +7 -0
  293. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +83 -0
  294. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +240 -0
  295. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +91 -0
  296. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +130 -0
  297. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +214 -0
  298. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +239 -0
  299. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +93 -0
  300. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +354 -0
  301. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +16 -0
  302. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +20 -0
  303. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +30 -0
  304. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +239 -0
  305. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +372 -0
  306. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +273 -0
  307. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +139 -0
  308. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +14 -0
  309. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +16 -0
  310. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +81 -0
  311. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +292 -0
  312. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +103 -0
  313. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +140 -0
  314. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +175 -0
  315. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
  316. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +7 -0
  317. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +383 -0
  318. package/dist/cjs/js/src/timex.js +1562 -0
  319. package/dist/cjs/js/src/tokocrypto.js +2542 -0
  320. package/dist/cjs/js/src/upbit.js +1844 -0
  321. package/dist/cjs/js/src/wavesexchange.js +2607 -0
  322. package/dist/cjs/js/src/wazirx.js +953 -0
  323. package/dist/cjs/js/src/whitebit.js +2309 -0
  324. package/dist/cjs/js/src/woo.js +2715 -0
  325. package/dist/cjs/js/src/yobit.js +1314 -0
  326. package/dist/cjs/js/src/zaif.js +736 -0
  327. package/dist/cjs/js/src/zonda.js +1883 -0
  328. package/js/ccxt.d.ts +1 -1
  329. package/js/ccxt.js +1 -1
  330. package/js/src/abstract/bigone.d.ts +18 -0
  331. package/js/src/abstract/binance.d.ts +2 -0
  332. package/js/src/abstract/binancecoinm.d.ts +2 -0
  333. package/js/src/abstract/binanceus.d.ts +2 -0
  334. package/js/src/abstract/binanceusdm.d.ts +2 -0
  335. package/js/src/abstract/bybit.d.ts +1 -0
  336. package/js/src/abstract/gate.d.ts +11 -0
  337. package/js/src/abstract/gateio.d.ts +11 -0
  338. package/js/src/alpaca.js +18 -18
  339. package/js/src/base/Exchange.d.ts +5 -1
  340. package/js/src/base/Exchange.js +101 -12
  341. package/js/src/bigone.d.ts +1 -2
  342. package/js/src/bigone.js +340 -145
  343. package/js/src/binance.js +15 -8
  344. package/js/src/bingx.js +9 -2
  345. package/js/src/bitfinex.d.ts +2 -2
  346. package/js/src/bitfinex.js +2 -3
  347. package/js/src/bitget.js +21 -8
  348. package/js/src/bitmart.d.ts +2 -2
  349. package/js/src/bitmart.js +3 -3
  350. package/js/src/bitmex.js +1 -0
  351. package/js/src/bybit.js +2 -0
  352. package/js/src/coinlist.js +2 -3
  353. package/js/src/coinsph.js +2 -3
  354. package/js/src/deribit.js +1 -0
  355. package/js/src/gate.d.ts +4 -4
  356. package/js/src/gate.js +22 -3
  357. package/js/src/hitbtc.d.ts +4 -4
  358. package/js/src/hitbtc.js +2 -3
  359. package/js/src/htx.js +4 -7
  360. package/js/src/huobijp.js +2 -3
  361. package/js/src/kraken.js +1 -0
  362. package/js/src/mexc.js +2 -1
  363. package/js/src/okx.js +13 -3
  364. package/js/src/pro/binance.d.ts +2 -23
  365. package/js/src/pro/binance.js +58 -22
  366. package/js/src/pro/coinbase.d.ts +2 -2
  367. package/js/src/pro/coinbase.js +4 -1
  368. package/js/src/pro/coinbasepro.d.ts +2 -2
  369. package/js/src/pro/hitbtc.d.ts +2 -2
  370. package/js/src/pro/poloniex.d.ts +2 -2
  371. package/js/src/upbit.d.ts +3 -101
  372. package/js/src/upbit.js +12 -12
  373. package/js/src/woo.js +2 -0
  374. package/package.json +1 -1
  375. package/skip-tests.json +5 -0
@@ -0,0 +1,1293 @@
1
+ 'use strict';
2
+
3
+ var hitbtc$1 = require('../hitbtc.js');
4
+ var Cache = require('../base/ws/Cache.js');
5
+ var sha256 = require('../static_dependencies/noble-hashes/sha256.js');
6
+ var errors = require('../base/errors.js');
7
+
8
+ // ---------------------------------------------------------------------------
9
+ // ---------------------------------------------------------------------------
10
+ class hitbtc extends hitbtc$1 {
11
+ describe() {
12
+ return this.deepExtend(super.describe(), {
13
+ 'has': {
14
+ 'ws': true,
15
+ 'watchTicker': true,
16
+ 'watchTickers': true,
17
+ 'watchTrades': true,
18
+ 'watchOrderBook': true,
19
+ 'watchBalance': true,
20
+ 'watchOrders': true,
21
+ 'watchOHLCV': true,
22
+ 'watchMyTrades': false,
23
+ 'createOrderWs': true,
24
+ 'cancelOrderWs': true,
25
+ 'fetchOpenOrdersWs': true,
26
+ 'cancelAllOrdersWs': true,
27
+ },
28
+ 'urls': {
29
+ 'api': {
30
+ 'ws': {
31
+ 'public': 'wss://api.hitbtc.com/api/3/ws/public',
32
+ 'private': 'wss://api.hitbtc.com/api/3/ws/trading',
33
+ },
34
+ },
35
+ },
36
+ 'options': {
37
+ 'tradesLimit': 1000,
38
+ 'watchTicker': {
39
+ 'method': 'ticker/{speed}', // 'ticker/{speed}' or 'ticker/price/{speed}'
40
+ },
41
+ 'watchTickers': {
42
+ 'method': 'ticker/{speed}', // 'ticker/{speed}','ticker/price/{speed}', 'ticker/{speed}/batch', or 'ticker/{speed}/price/batch''
43
+ },
44
+ 'watchOrderBook': {
45
+ 'method': 'orderbook/full', // 'orderbook/full', 'orderbook/{depth}/{speed}', 'orderbook/{depth}/{speed}/batch', 'orderbook/top/{speed}', or 'orderbook/top/{speed}/batch'
46
+ },
47
+ },
48
+ 'timeframes': {
49
+ '1m': 'M1',
50
+ '3m': 'M3',
51
+ '5m': 'M5',
52
+ '15m': 'M15',
53
+ '30m': 'M30',
54
+ '1h': 'H1',
55
+ '4h': 'H4',
56
+ '1d': 'D1',
57
+ '1w': 'D7',
58
+ '1M': '1M',
59
+ },
60
+ 'streaming': {
61
+ 'keepAlive': 4000,
62
+ },
63
+ });
64
+ }
65
+ async authenticate() {
66
+ /**
67
+ * @ignore
68
+ * @method
69
+ * @description authenticates the user to access private web socket channels
70
+ * @see https://api.hitbtc.com/#socket-authentication
71
+ * @returns {object} response from exchange
72
+ */
73
+ this.checkRequiredCredentials();
74
+ const url = this.urls['api']['ws']['private'];
75
+ const messageHash = 'authenticated';
76
+ const client = this.client(url);
77
+ const future = client.future(messageHash);
78
+ const authenticated = this.safeValue(client.subscriptions, messageHash);
79
+ if (authenticated === undefined) {
80
+ const timestamp = this.milliseconds();
81
+ const signature = this.hmac(this.encode(this.numberToString(timestamp)), this.encode(this.secret), sha256.sha256, 'hex');
82
+ const request = {
83
+ 'method': 'login',
84
+ 'params': {
85
+ 'type': 'HS256',
86
+ 'api_key': this.apiKey,
87
+ 'timestamp': timestamp,
88
+ 'signature': signature,
89
+ },
90
+ };
91
+ this.watch(url, messageHash, request, messageHash);
92
+ //
93
+ // {
94
+ // "jsonrpc": "2.0",
95
+ // "result": true
96
+ // }
97
+ //
98
+ // # Failure to return results
99
+ //
100
+ // {
101
+ // "jsonrpc": "2.0",
102
+ // "error": {
103
+ // "code": 1002,
104
+ // "message": "Authorization is required or has been failed",
105
+ // "description": "invalid signature format"
106
+ // }
107
+ // }
108
+ //
109
+ }
110
+ return future;
111
+ }
112
+ async subscribePublic(name, symbols = undefined, params = {}) {
113
+ /**
114
+ * @ignore
115
+ * @method
116
+ * @param {string} name websocket endpoint name
117
+ * @param {string[]} [symbols] unified CCXT symbol(s)
118
+ * @param {object} [params] extra parameters specific to the hitbtc api
119
+ */
120
+ await this.loadMarkets();
121
+ const url = this.urls['api']['ws']['public'];
122
+ let messageHash = name;
123
+ if (symbols !== undefined) {
124
+ messageHash = messageHash + '::' + symbols.join(',');
125
+ }
126
+ const subscribe = {
127
+ 'method': 'subscribe',
128
+ 'id': this.nonce(),
129
+ 'ch': name,
130
+ };
131
+ const request = this.extend(subscribe, params);
132
+ return await this.watch(url, messageHash, request, messageHash);
133
+ }
134
+ async subscribePrivate(name, symbol = undefined, params = {}) {
135
+ /**
136
+ * @ignore
137
+ * @method
138
+ * @param {string} name websocket endpoint name
139
+ * @param {string} [symbol] unified CCXT symbol
140
+ * @param {object} [params] extra parameters specific to the hitbtc api
141
+ */
142
+ await this.loadMarkets();
143
+ await this.authenticate();
144
+ const url = this.urls['api']['ws']['private'];
145
+ const splitName = name.split('_subscribe');
146
+ let messageHash = this.safeString(splitName, 0);
147
+ if (symbol !== undefined) {
148
+ messageHash = messageHash + '::' + symbol;
149
+ }
150
+ const subscribe = {
151
+ 'method': name,
152
+ 'params': params,
153
+ 'id': this.nonce(),
154
+ };
155
+ return await this.watch(url, messageHash, subscribe, messageHash);
156
+ }
157
+ async tradeRequest(name, params = {}) {
158
+ /**
159
+ * @ignore
160
+ * @method
161
+ * @param {string} name websocket endpoint name
162
+ * @param {string} [symbol] unified CCXT symbol
163
+ * @param {object} [params] extra parameters specific to the hitbtc api
164
+ */
165
+ await this.loadMarkets();
166
+ await this.authenticate();
167
+ const url = this.urls['api']['ws']['private'];
168
+ const messageHash = this.nonce();
169
+ const subscribe = {
170
+ 'method': name,
171
+ 'params': params,
172
+ 'id': messageHash,
173
+ };
174
+ return await this.watch(url, messageHash, subscribe, messageHash);
175
+ }
176
+ async watchOrderBook(symbol, limit = undefined, params = {}) {
177
+ /**
178
+ * @method
179
+ * @name hitbtc#watchOrderBook
180
+ * @description watches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
181
+ * @see https://api.hitbtc.com/#subscribe-to-full-order-book
182
+ * @see https://api.hitbtc.com/#subscribe-to-partial-order-book
183
+ * @see https://api.hitbtc.com/#subscribe-to-partial-order-book-in-batches
184
+ * @see https://api.hitbtc.com/#subscribe-to-top-of-book
185
+ * @see https://api.hitbtc.com/#subscribe-to-top-of-book-in-batches
186
+ * @param {string} symbol unified symbol of the market to fetch the order book for
187
+ * @param {int} [limit] the maximum amount of order book entries to return
188
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
189
+ * @param {string} [params.method] 'orderbook/full', 'orderbook/{depth}/{speed}', 'orderbook/{depth}/{speed}/batch', 'orderbook/top/{speed}', or 'orderbook/top/{speed}/batch'
190
+ * @param {int} [params.depth] 5 , 10, or 20 (default)
191
+ * @param {int} [params.speed] 100 (default), 500, or 1000
192
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
193
+ */
194
+ const options = this.safeValue(this.options, 'watchOrderBook');
195
+ const defaultMethod = this.safeString(options, 'method', 'orderbook/full');
196
+ let name = this.safeString2(params, 'method', 'defaultMethod', defaultMethod);
197
+ const depth = this.safeString(params, 'depth', '20');
198
+ const speed = this.safeString(params, 'depth', '100');
199
+ if (name === 'orderbook/{depth}/{speed}') {
200
+ name = 'orderbook/D' + depth + '/' + speed + 'ms';
201
+ }
202
+ else if (name === 'orderbook/{depth}/{speed}/batch') {
203
+ name = 'orderbook/D' + depth + '/' + speed + 'ms/batch';
204
+ }
205
+ else if (name === 'orderbook/top/{speed}') {
206
+ name = 'orderbook/top/' + speed + 'ms';
207
+ }
208
+ else if (name === 'orderbook/top/{speed}/batch') {
209
+ name = 'orderbook/top/' + speed + 'ms/batch';
210
+ }
211
+ const market = this.market(symbol);
212
+ const request = {
213
+ 'params': {
214
+ 'symbols': [market['id']],
215
+ },
216
+ };
217
+ const orderbook = await this.subscribePublic(name, [symbol], this.deepExtend(request, params));
218
+ return orderbook.limit();
219
+ }
220
+ handleOrderBook(client, message) {
221
+ //
222
+ // {
223
+ // "ch": "orderbook/full", // Channel
224
+ // "snapshot": {
225
+ // "ETHBTC": {
226
+ // "t": 1626866578796, // Timestamp in milliseconds
227
+ // "s": 27617207, // Sequence number
228
+ // "a": [ // Asks
229
+ // ["0.060506", "0"],
230
+ // ["0.060549", "12.6431"],
231
+ // ["0.060570", "0"],
232
+ // ["0.060612", "0"]
233
+ // ],
234
+ // "b": [ // Bids
235
+ // ["0.060439", "4.4095"],
236
+ // ["0.060414", "0"],
237
+ // ["0.060407", "7.3349"],
238
+ // ["0.060390", "0"]
239
+ // ]
240
+ // }
241
+ // }
242
+ // }
243
+ //
244
+ const data = this.safeValue2(message, 'snapshot', 'update', {});
245
+ const marketIds = Object.keys(data);
246
+ const channel = this.safeString(message, 'ch');
247
+ for (let i = 0; i < marketIds.length; i++) {
248
+ const marketId = marketIds[i];
249
+ const market = this.safeMarket(marketId);
250
+ const symbol = market['symbol'];
251
+ const item = data[marketId];
252
+ const messageHash = channel + '::' + symbol;
253
+ if (!(symbol in this.orderbooks)) {
254
+ const subscription = this.safeValue(client.subscriptions, messageHash, {});
255
+ const limit = this.safeInteger(subscription, 'limit');
256
+ this.orderbooks[symbol] = this.orderBook({}, limit);
257
+ }
258
+ const timestamp = this.safeInteger(item, 't');
259
+ const nonce = this.safeInteger(item, 's');
260
+ const orderbook = this.orderbooks[symbol];
261
+ const asks = this.safeValue(item, 'a', []);
262
+ const bids = this.safeValue(item, 'b', []);
263
+ this.handleDeltas(orderbook['asks'], asks);
264
+ this.handleDeltas(orderbook['bids'], bids);
265
+ orderbook['timestamp'] = timestamp;
266
+ orderbook['datetime'] = this.iso8601(timestamp);
267
+ orderbook['nonce'] = nonce;
268
+ orderbook['symbol'] = symbol;
269
+ this.orderbooks[symbol] = orderbook;
270
+ client.resolve(orderbook, messageHash);
271
+ }
272
+ }
273
+ handleDelta(bookside, delta) {
274
+ const price = this.safeNumber(delta, 0);
275
+ const amount = this.safeNumber(delta, 1);
276
+ bookside.store(price, amount);
277
+ }
278
+ handleDeltas(bookside, deltas) {
279
+ for (let i = 0; i < deltas.length; i++) {
280
+ this.handleDelta(bookside, deltas[i]);
281
+ }
282
+ }
283
+ async watchTicker(symbol, params = {}) {
284
+ /**
285
+ * @method
286
+ * @name hitbtc#watchTicker
287
+ * @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
288
+ * @see https://api.hitbtc.com/#subscribe-to-ticker
289
+ * @see https://api.hitbtc.com/#subscribe-to-ticker-in-batches
290
+ * @see https://api.hitbtc.com/#subscribe-to-mini-ticker
291
+ * @see https://api.hitbtc.com/#subscribe-to-mini-ticker-in-batches
292
+ * @param {string} symbol unified symbol of the market to fetch the ticker for
293
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
294
+ * @param {string} [params.method] 'ticker/{speed}' (default), or 'ticker/price/{speed}'
295
+ * @param {string} [params.speed] '1s' (default), or '3s'
296
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
297
+ */
298
+ const options = this.safeValue(this.options, 'watchTicker');
299
+ const defaultMethod = this.safeString(options, 'method', 'ticker/{speed}');
300
+ const method = this.safeString2(params, 'method', 'defaultMethod', defaultMethod);
301
+ const speed = this.safeString(params, 'speed', '1s');
302
+ const name = this.implodeParams(method, { 'speed': speed });
303
+ params = this.omit(params, ['method', 'speed']);
304
+ const market = this.market(symbol);
305
+ const request = {
306
+ 'params': {
307
+ 'symbols': [market['id']],
308
+ },
309
+ };
310
+ return await this.subscribePublic(name, [symbol], this.deepExtend(request, params));
311
+ }
312
+ async watchTickers(symbols = undefined, params = {}) {
313
+ /**
314
+ * @method
315
+ * @name hitbtc#watchTicker
316
+ * @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
317
+ * @param {string} symbol unified symbol of the market to fetch the ticker for
318
+ * @param {object} params extra parameters specific to the exchange API endpoint
319
+ * @param {string} params.method 'ticker/{speed}' (default),'ticker/price/{speed}', 'ticker/{speed}/batch', or 'ticker/{speed}/price/batch''
320
+ * @param {string} params.speed '1s' (default), or '3s'
321
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/en/latest/manual.html#ticker-structure}
322
+ */
323
+ await this.loadMarkets();
324
+ const options = this.safeValue(this.options, 'watchTicker');
325
+ const defaultMethod = this.safeString(options, 'method', 'ticker/{speed}');
326
+ const method = this.safeString2(params, 'method', 'defaultMethod', defaultMethod);
327
+ const speed = this.safeString(params, 'speed', '1s');
328
+ const name = this.implodeParams(method, { 'speed': speed });
329
+ params = this.omit(params, ['method', 'speed']);
330
+ const marketIds = [];
331
+ if (symbols === undefined) {
332
+ marketIds.push('*');
333
+ }
334
+ else {
335
+ for (let i = 0; i < symbols.length; i++) {
336
+ const marketId = this.marketId(symbols[i]);
337
+ marketIds.push(marketId);
338
+ }
339
+ }
340
+ const request = {
341
+ 'params': {
342
+ 'symbols': marketIds,
343
+ },
344
+ };
345
+ const tickers = await this.subscribePublic(name, symbols, this.deepExtend(request, params));
346
+ if (this.newUpdates) {
347
+ return tickers;
348
+ }
349
+ return this.filterByArray(this.tickers, 'symbol', symbols);
350
+ }
351
+ handleTicker(client, message) {
352
+ //
353
+ // {
354
+ // "ch": "ticker/1s",
355
+ // "data": {
356
+ // "ETHBTC": {
357
+ // "t": 1614815872000, // Timestamp in milliseconds
358
+ // "a": "0.031175", // Best ask
359
+ // "A": "0.03329", // Best ask quantity
360
+ // "b": "0.031148", // Best bid
361
+ // "B": "0.10565", // Best bid quantity
362
+ // "c": "0.031210", // Last price
363
+ // "o": "0.030781", // Open price
364
+ // "h": "0.031788", // High price
365
+ // "l": "0.030733", // Low price
366
+ // "v": "62.587", // Base asset volume
367
+ // "q": "1.951420577", // Quote asset volume
368
+ // "p": "0.000429", // Price change
369
+ // "P": "1.39", // Price change percent
370
+ // "L": 1182694927 // Last trade identifier
371
+ // }
372
+ // }
373
+ // }
374
+ //
375
+ // {
376
+ // "ch": "ticker/price/1s",
377
+ // "data": {
378
+ // "BTCUSDT": {
379
+ // "t": 1614815872030,
380
+ // "o": "32636.79",
381
+ // "c": "32085.51",
382
+ // "h": "33379.92",
383
+ // "l": "30683.28",
384
+ // "v": "11.90667",
385
+ // "q": "384081.1955629"
386
+ // }
387
+ // }
388
+ // }
389
+ //
390
+ const data = this.safeValue(message, 'data', {});
391
+ const marketIds = Object.keys(data);
392
+ const channel = this.safeString(message, 'ch');
393
+ const newTickers = [];
394
+ for (let i = 0; i < marketIds.length; i++) {
395
+ const marketId = marketIds[i];
396
+ const market = this.safeMarket(marketId);
397
+ const symbol = market['symbol'];
398
+ const ticker = this.parseWsTicker(data[marketId], market);
399
+ this.tickers[symbol] = ticker;
400
+ newTickers.push(ticker);
401
+ const messageHash = channel + '::' + symbol;
402
+ client.resolve(this.tickers[symbol], messageHash);
403
+ }
404
+ const messageHashes = this.findMessageHashes(client, channel + '::');
405
+ for (let i = 0; i < messageHashes.length; i++) {
406
+ const messageHash = messageHashes[i];
407
+ const parts = messageHash.split('::');
408
+ const symbolsString = parts[1];
409
+ const symbols = symbolsString.split(',');
410
+ const tickers = this.filterByArray(newTickers, 'symbol', symbols);
411
+ const tickersSymbols = Object.keys(tickers);
412
+ const numTickers = tickersSymbols.length;
413
+ if (numTickers > 0) {
414
+ client.resolve(tickers, messageHash);
415
+ }
416
+ }
417
+ client.resolve(this.tickers, channel);
418
+ return message;
419
+ }
420
+ parseWsTicker(ticker, market = undefined) {
421
+ //
422
+ // {
423
+ // "t": 1614815872000, // Timestamp in milliseconds
424
+ // "a": "0.031175", // Best ask
425
+ // "A": "0.03329", // Best ask quantity
426
+ // "b": "0.031148", // Best bid
427
+ // "B": "0.10565", // Best bid quantity
428
+ // "c": "0.031210", // Last price
429
+ // "o": "0.030781", // Open price
430
+ // "h": "0.031788", // High price
431
+ // "l": "0.030733", // Low price
432
+ // "v": "62.587", // Base asset volume
433
+ // "q": "1.951420577", // Quote asset volume
434
+ // "p": "0.000429", // Price change
435
+ // "P": "1.39", // Price change percent
436
+ // "L": 1182694927 // Last trade identifier
437
+ // }
438
+ //
439
+ // {
440
+ // "t": 1614815872030,
441
+ // "o": "32636.79",
442
+ // "c": "32085.51",
443
+ // "h": "33379.92",
444
+ // "l": "30683.28",
445
+ // "v": "11.90667",
446
+ // "q": "384081.1955629"
447
+ // }
448
+ //
449
+ const timestamp = this.safeInteger(ticker, 't');
450
+ const symbol = this.safeSymbol(undefined, market);
451
+ const last = this.safeString(ticker, 'c');
452
+ return this.safeTicker({
453
+ 'symbol': symbol,
454
+ 'timestamp': timestamp,
455
+ 'datetime': this.iso8601(timestamp),
456
+ 'high': this.safeString(ticker, 'h'),
457
+ 'low': this.safeString(ticker, 'l'),
458
+ 'bid': this.safeString(ticker, 'b'),
459
+ 'bidVolume': this.safeString(ticker, 'B'),
460
+ 'ask': this.safeString(ticker, 'a'),
461
+ 'askVolume': this.safeString(ticker, 'A'),
462
+ 'vwap': undefined,
463
+ 'open': this.safeString(ticker, 'o'),
464
+ 'close': last,
465
+ 'last': last,
466
+ 'previousClose': undefined,
467
+ 'change': undefined,
468
+ 'percentage': undefined,
469
+ 'average': undefined,
470
+ 'baseVolume': this.safeString(ticker, 'v'),
471
+ 'quoteVolume': this.safeString(ticker, 'q'),
472
+ 'info': ticker,
473
+ }, market);
474
+ }
475
+ async watchTrades(symbol, since = undefined, limit = undefined, params = {}) {
476
+ /**
477
+ * @method
478
+ * @name hitbtc#watchTrades
479
+ * @description get the list of most recent trades for a particular symbol
480
+ * @see https://api.hitbtc.com/#subscribe-to-trades
481
+ * @param {string} symbol unified symbol of the market to fetch trades for
482
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
483
+ * @param {int} [limit] the maximum amount of trades to fetch
484
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
485
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
486
+ */
487
+ await this.loadMarkets();
488
+ const market = this.market(symbol);
489
+ const request = {
490
+ 'params': {
491
+ 'symbols': [market['id']],
492
+ },
493
+ };
494
+ if (limit !== undefined) {
495
+ request['limit'] = limit;
496
+ }
497
+ const trades = await this.subscribePublic('trades', [symbol], this.deepExtend(request, params));
498
+ if (this.newUpdates) {
499
+ limit = trades.getLimit(symbol, limit);
500
+ }
501
+ return this.filterBySinceLimit(trades, since, limit, 'timestamp');
502
+ }
503
+ handleTrades(client, message) {
504
+ //
505
+ // {
506
+ // "result": {
507
+ // "ch": "trades", // Channel
508
+ // "subscriptions": ["ETHBTC", "BTCUSDT"]
509
+ // },
510
+ // "id": 123
511
+ // }
512
+ //
513
+ // Notification snapshot
514
+ //
515
+ // {
516
+ // "ch": "trades", // Channel
517
+ // "snapshot": {
518
+ // "BTCUSDT": [{
519
+ // "t": 1626861109494, // Timestamp in milliseconds
520
+ // "i": 1555634969, // Trade identifier
521
+ // "p": "30881.96", // Price
522
+ // "q": "12.66828", // Quantity
523
+ // "s": "buy" // Side
524
+ // }]
525
+ // }
526
+ // }
527
+ //
528
+ // Notification update
529
+ //
530
+ // {
531
+ // "ch": "trades",
532
+ // "update": {
533
+ // "BTCUSDT": [{
534
+ // "t": 1626861123552,
535
+ // "i": 1555634969,
536
+ // "p": "30877.68",
537
+ // "q": "0.00006",
538
+ // "s": "sell"
539
+ // }]
540
+ // }
541
+ // }
542
+ //
543
+ const data = this.safeValue2(message, 'snapshot', 'update', {});
544
+ const marketIds = Object.keys(data);
545
+ for (let i = 0; i < marketIds.length; i++) {
546
+ const marketId = marketIds[i];
547
+ const market = this.safeMarket(marketId);
548
+ const tradesLimit = this.safeInteger(this.options, 'tradesLimit', 1000);
549
+ const symbol = market['symbol'];
550
+ let stored = this.safeValue(this.trades, symbol);
551
+ if (stored === undefined) {
552
+ stored = new Cache.ArrayCache(tradesLimit);
553
+ this.trades[symbol] = stored;
554
+ }
555
+ const trades = this.parseWsTrades(data[marketId], market);
556
+ for (let j = 0; j < trades.length; j++) {
557
+ stored.append(trades[j]);
558
+ }
559
+ const messageHash = 'trades::' + symbol;
560
+ client.resolve(stored, messageHash);
561
+ }
562
+ return message;
563
+ }
564
+ parseWsTrades(trades, market = undefined, since = undefined, limit = undefined, params = {}) {
565
+ trades = this.toArray(trades);
566
+ let result = [];
567
+ for (let i = 0; i < trades.length; i++) {
568
+ const trade = this.extend(this.parseWsTrade(trades[i], market), params);
569
+ result.push(trade);
570
+ }
571
+ result = this.sortBy2(result, 'timestamp', 'id');
572
+ const symbol = this.safeString(market, 'symbol');
573
+ return this.filterBySymbolSinceLimit(result, symbol, since, limit);
574
+ }
575
+ parseWsTrade(trade, market = undefined) {
576
+ //
577
+ // {
578
+ // "t": 1626861123552, // Timestamp in milliseconds
579
+ // "i": 1555634969, // Trade identifier
580
+ // "p": "30877.68", // Price
581
+ // "q": "0.00006", // Quantity
582
+ // "s": "sell" // Side
583
+ // }
584
+ //
585
+ const timestamp = this.safeInteger(trade, 't');
586
+ return this.safeTrade({
587
+ 'info': trade,
588
+ 'id': this.safeString(trade, 'i'),
589
+ 'order': undefined,
590
+ 'timestamp': timestamp,
591
+ 'datetime': this.iso8601(timestamp),
592
+ 'symbol': this.safeString(market, 'symbol'),
593
+ 'type': undefined,
594
+ 'side': this.safeString(trade, 's'),
595
+ 'takerOrMaker': undefined,
596
+ 'price': this.safeString(trade, 'p'),
597
+ 'amount': this.safeString(trade, 'q'),
598
+ 'cost': undefined,
599
+ 'fee': undefined,
600
+ }, market);
601
+ }
602
+ async watchOHLCV(symbol, timeframe = '1m', since = undefined, limit = undefined, params = {}) {
603
+ /**
604
+ * @method
605
+ * @name hitbtc#watchOHLCV
606
+ * @description watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
607
+ * @see https://api.hitbtc.com/#subscribe-to-candles
608
+ * @param {string} symbol unified symbol of the market to fetch OHLCV data for
609
+ * @param {string} [timeframe] the length of time each candle represents
610
+ * @param {int} [since] not used by hitbtc watchOHLCV
611
+ * @param {int} [limit] 0 – 1000, default value = 0 (no history returned)
612
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
613
+ * @returns {int[][]} A list of candles ordered as timestamp, open, high, low, close, volume
614
+ */
615
+ const period = this.safeString(this.timeframes, timeframe, timeframe);
616
+ const name = 'candles/' + period;
617
+ const market = this.market(symbol);
618
+ const request = {
619
+ 'params': {
620
+ 'symbols': [market['id']],
621
+ },
622
+ };
623
+ if (limit !== undefined) {
624
+ request['params']['limit'] = limit;
625
+ }
626
+ const ohlcv = await this.subscribePublic(name, [symbol], this.deepExtend(request, params));
627
+ if (this.newUpdates) {
628
+ limit = ohlcv.getLimit(symbol, limit);
629
+ }
630
+ return this.filterBySinceLimit(ohlcv, since, limit, 0);
631
+ }
632
+ handleOHLCV(client, message) {
633
+ //
634
+ // {
635
+ // "ch": "candles/M1", // Channel
636
+ // "snapshot": {
637
+ // "BTCUSDT": [{
638
+ // "t": 1626860340000, // Message timestamp
639
+ // "o": "30881.95", // Open price
640
+ // "c": "30890.96", // Last price
641
+ // "h": "30900.8", // High price
642
+ // "l": "30861.27", // Low price
643
+ // "v": "1.27852", // Base asset volume
644
+ // "q": "39493.9021811" // Quote asset volume
645
+ // }
646
+ // ...
647
+ // ]
648
+ // }
649
+ // }
650
+ //
651
+ // {
652
+ // "ch": "candles/M1",
653
+ // "update": {
654
+ // "ETHBTC": [{
655
+ // "t": 1626860880000,
656
+ // "o": "0.060711",
657
+ // "c": "0.060749",
658
+ // "h": "0.060749",
659
+ // "l": "0.060711",
660
+ // "v": "12.2800",
661
+ // "q": "0.7455339675"
662
+ // }]
663
+ // }
664
+ // }
665
+ //
666
+ const data = this.safeValue2(message, 'snapshot', 'update', {});
667
+ const marketIds = Object.keys(data);
668
+ const channel = this.safeString(message, 'ch');
669
+ const splitChannel = channel.split('/');
670
+ const period = this.safeString(splitChannel, 1);
671
+ const timeframe = this.findTimeframe(period);
672
+ for (let i = 0; i < marketIds.length; i++) {
673
+ const marketId = marketIds[i];
674
+ const market = this.safeMarket(marketId);
675
+ const symbol = market['symbol'];
676
+ this.ohlcvs[symbol] = this.safeValue(this.ohlcvs, symbol, {});
677
+ let stored = this.safeValue(this.ohlcvs[symbol], timeframe);
678
+ if (stored === undefined) {
679
+ const limit = this.safeInteger(this.options, 'OHLCVLimit', 1000);
680
+ stored = new Cache.ArrayCacheByTimestamp(limit);
681
+ this.ohlcvs[symbol][timeframe] = stored;
682
+ }
683
+ const ohlcvs = this.parseWsOHLCVs(data[marketId], market);
684
+ for (let j = 0; j < ohlcvs.length; j++) {
685
+ stored.append(ohlcvs[j]);
686
+ }
687
+ const messageHash = channel + '::' + symbol;
688
+ client.resolve(stored, messageHash);
689
+ }
690
+ return message;
691
+ }
692
+ parseWsOHLCV(ohlcv, market = undefined) {
693
+ //
694
+ // {
695
+ // "t": 1626860340000, // Message timestamp
696
+ // "o": "30881.95", // Open price
697
+ // "c": "30890.96", // Last price
698
+ // "h": "30900.8", // High price
699
+ // "l": "30861.27", // Low price
700
+ // "v": "1.27852", // Base asset volume
701
+ // "q": "39493.9021811" // Quote asset volume
702
+ // }
703
+ //
704
+ return [
705
+ this.safeInteger(ohlcv, 't'),
706
+ this.safeNumber(ohlcv, 'o'),
707
+ this.safeNumber(ohlcv, 'h'),
708
+ this.safeNumber(ohlcv, 'l'),
709
+ this.safeNumber(ohlcv, 'c'),
710
+ this.safeNumber(ohlcv, 'v'),
711
+ ];
712
+ }
713
+ async watchOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
714
+ /**
715
+ * @method
716
+ * @name hitbtc#watchOrders
717
+ * @description watches information on multiple orders made by the user
718
+ * @see https://api.hitbtc.com/#subscribe-to-reports
719
+ * @see https://api.hitbtc.com/#subscribe-to-reports-2
720
+ * @see https://api.hitbtc.com/#subscribe-to-reports-3
721
+ * @param {string} [symbol] unified CCXT market symbol
722
+ * @param {int} [since] timestamp in ms of the earliest order to fetch
723
+ * @param {int} [limit] the maximum amount of orders to fetch
724
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
725
+ * @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/en/latest/manual.html#order-structure}
726
+ */
727
+ await this.loadMarkets();
728
+ let marketType = undefined;
729
+ let market = undefined;
730
+ if (symbol !== undefined) {
731
+ market = this.market(symbol);
732
+ }
733
+ [marketType, params] = this.handleMarketTypeAndParams('watchOrders', market, params);
734
+ const name = this.getSupportedMapping(marketType, {
735
+ 'spot': 'spot_subscribe',
736
+ 'margin': 'margin_subscribe',
737
+ 'swap': 'futures_subscribe',
738
+ 'future': 'futures_subscribe',
739
+ });
740
+ const orders = await this.subscribePrivate(name, symbol, params);
741
+ if (this.newUpdates) {
742
+ limit = orders.getLimit(symbol, limit);
743
+ }
744
+ return this.filterBySinceLimit(orders, since, limit, 'timestamp');
745
+ }
746
+ handleOrder(client, message) {
747
+ //
748
+ // {
749
+ // "jsonrpc": "2.0",
750
+ // "method": "spot_order", // "margin_order", "future_order"
751
+ // "params": {
752
+ // "id": 584244931496,
753
+ // "client_order_id": "b5acd79c0a854b01b558665bcf379456",
754
+ // "symbol": "BTCUSDT",
755
+ // "side": "buy",
756
+ // "status": "new",
757
+ // "type": "limit",
758
+ // "time_in_force": "GTC",
759
+ // "quantity": "0.01000",
760
+ // "quantity_cumulative": "0",
761
+ // "price": "0.01", // only updates and snapshots
762
+ // "post_only": false,
763
+ // "reduce_only": false, // only margin and contract
764
+ // "display_quantity": "0", // only updates and snapshot
765
+ // "created_at": "2021-07-02T22:52:32.864Z",
766
+ // "updated_at": "2021-07-02T22:52:32.864Z",
767
+ // "trade_id": 1361977606, // only trades
768
+ // "trade_quantity": "0.00001", // only trades
769
+ // "trade_price": "49595.04", // only trades
770
+ // "trade_fee": "0.001239876000", // only trades
771
+ // "trade_taker": true, // only trades, only spot
772
+ // "trade_position_id": 485308, // only trades, only margin
773
+ // "report_type": "new" // "trade", "status" (snapshot)
774
+ // }
775
+ // }
776
+ //
777
+ // {
778
+ // "jsonrpc": "2.0",
779
+ // "method": "spot_orders", // "margin_orders", "future_orders"
780
+ // "params": [
781
+ // {
782
+ // "id": 584244931496,
783
+ // "client_order_id": "b5acd79c0a854b01b558665bcf379456",
784
+ // "symbol": "BTCUSDT",
785
+ // "side": "buy",
786
+ // "status": "new",
787
+ // "type": "limit",
788
+ // "time_in_force": "GTC",
789
+ // "quantity": "0.01000",
790
+ // "quantity_cumulative": "0",
791
+ // "price": "0.01", // only updates and snapshots
792
+ // "post_only": false,
793
+ // "reduce_only": false, // only margin and contract
794
+ // "display_quantity": "0", // only updates and snapshot
795
+ // "created_at": "2021-07-02T22:52:32.864Z",
796
+ // "updated_at": "2021-07-02T22:52:32.864Z",
797
+ // "trade_id": 1361977606, // only trades
798
+ // "trade_quantity": "0.00001", // only trades
799
+ // "trade_price": "49595.04", // only trades
800
+ // "trade_fee": "0.001239876000", // only trades
801
+ // "trade_taker": true, // only trades, only spot
802
+ // "trade_position_id": 485308, // only trades, only margin
803
+ // "report_type": "new" // "trade", "status" (snapshot)
804
+ // }
805
+ // ]
806
+ // }
807
+ //
808
+ if (this.orders === undefined) {
809
+ const limit = this.safeInteger(this.options, 'ordersLimit');
810
+ this.orders = new Cache.ArrayCacheBySymbolById(limit);
811
+ }
812
+ const data = this.safeValue(message, 'params', []);
813
+ if (Array.isArray(data)) {
814
+ for (let i = 0; i < data.length; i++) {
815
+ const order = data[i];
816
+ this.handleOrderHelper(client, message, order);
817
+ }
818
+ }
819
+ else {
820
+ this.handleOrderHelper(client, message, data);
821
+ }
822
+ return message;
823
+ }
824
+ handleOrderHelper(client, message, order) {
825
+ const orders = this.orders;
826
+ const marketId = this.safeStringLower2(order, 'instrument', 'symbol');
827
+ const method = this.safeString(message, 'method');
828
+ const splitMethod = method.split('_order');
829
+ const messageHash = this.safeString(splitMethod, 0);
830
+ const symbol = this.safeSymbol(marketId);
831
+ const parsed = this.parseOrder(order);
832
+ orders.append(parsed);
833
+ client.resolve(orders, messageHash);
834
+ client.resolve(orders, messageHash + '::' + symbol);
835
+ }
836
+ parseWsOrderTrade(trade, market = undefined) {
837
+ //
838
+ // {
839
+ // "id": 584244931496,
840
+ // "client_order_id": "b5acd79c0a854b01b558665bcf379456",
841
+ // "symbol": "BTCUSDT",
842
+ // "side": "buy",
843
+ // "status": "new",
844
+ // "type": "limit",
845
+ // "time_in_force": "GTC",
846
+ // "quantity": "0.01000",
847
+ // "quantity_cumulative": "0",
848
+ // "price": "0.01", // only updates and snapshots
849
+ // "post_only": false,
850
+ // "reduce_only": false, // only margin and contract
851
+ // "display_quantity": "0", // only updates and snapshot
852
+ // "created_at": "2021-07-02T22:52:32.864Z",
853
+ // "updated_at": "2021-07-02T22:52:32.864Z",
854
+ // "trade_id": 1361977606, // only trades
855
+ // "trade_quantity": "0.00001", // only trades
856
+ // "trade_price": "49595.04", // only trades
857
+ // "trade_fee": "0.001239876000", // only trades
858
+ // "trade_taker": true, // only trades, only spot
859
+ // "trade_position_id": 485308, // only trades, only margin
860
+ // "report_type": "new" // "trade", "status" (snapshot)
861
+ // }
862
+ //
863
+ const timestamp = this.safeInteger(trade, 'created_at');
864
+ const marketId = this.safeString(trade, 'symbol');
865
+ return this.safeTrade({
866
+ 'info': trade,
867
+ 'id': this.safeString(trade, 'trade_id'),
868
+ 'order': this.safeString(trade, 'id'),
869
+ 'timestamp': timestamp,
870
+ 'datetime': this.iso8601(timestamp),
871
+ 'symbol': this.safeMarket(marketId, market),
872
+ 'type': undefined,
873
+ 'side': this.safeString(trade, 'side'),
874
+ 'takerOrMaker': this.safeString(trade, 'trade_taker'),
875
+ 'price': this.safeString(trade, 'trade_price'),
876
+ 'amount': this.safeString(trade, 'trade_quantity'),
877
+ 'cost': undefined,
878
+ 'fee': {
879
+ 'cost': this.safeString(trade, 'trade_fee'),
880
+ 'currency': undefined,
881
+ 'rate': undefined,
882
+ },
883
+ }, market);
884
+ }
885
+ parseWsOrder(order, market = undefined) {
886
+ //
887
+ // {
888
+ // "id": 584244931496,
889
+ // "client_order_id": "b5acd79c0a854b01b558665bcf379456",
890
+ // "symbol": "BTCUSDT",
891
+ // "side": "buy",
892
+ // "status": "new",
893
+ // "type": "limit",
894
+ // "time_in_force": "GTC",
895
+ // "quantity": "0.01000",
896
+ // "quantity_cumulative": "0",
897
+ // "price": "0.01", // only updates and snapshots
898
+ // "post_only": false,
899
+ // "reduce_only": false, // only margin and contract
900
+ // "display_quantity": "0", // only updates and snapshot
901
+ // "created_at": "2021-07-02T22:52:32.864Z",
902
+ // "updated_at": "2021-07-02T22:52:32.864Z",
903
+ // "trade_id": 1361977606, // only trades
904
+ // "trade_quantity": "0.00001", // only trades
905
+ // "trade_price": "49595.04", // only trades
906
+ // "trade_fee": "0.001239876000", // only trades
907
+ // "trade_taker": true, // only trades, only spot
908
+ // "trade_position_id": 485308, // only trades, only margin
909
+ // "report_type": "new" // "trade", "status" (snapshot)
910
+ // }
911
+ //
912
+ const timestamp = this.safeString(order, 'created_at');
913
+ const marketId = this.safeString(order, 'symbol');
914
+ market = this.safeMarket(marketId, market);
915
+ const tradeId = this.safeString(order, 'trade_id');
916
+ let trades = undefined;
917
+ if (tradeId !== undefined) {
918
+ const trade = this.parseWsOrderTrade(order, market);
919
+ trades = [trade];
920
+ }
921
+ const rawStatus = this.safeString(order, 'status');
922
+ const report_type = this.safeString(order, 'report_type');
923
+ let parsedStatus = undefined;
924
+ if (report_type === 'canceled') {
925
+ parsedStatus = this.parseOrderStatus(report_type);
926
+ }
927
+ else {
928
+ parsedStatus = this.parseOrderStatus(rawStatus);
929
+ }
930
+ return this.safeOrder({
931
+ 'info': order,
932
+ 'id': this.safeString(order, 'id'),
933
+ 'clientOrderId': this.safeString(order, 'client_order_id'),
934
+ 'timestamp': timestamp,
935
+ 'datetime': this.iso8601(timestamp),
936
+ 'lastTradeTimestamp': undefined,
937
+ 'symbol': market['symbol'],
938
+ 'price': this.safeString(order, 'price'),
939
+ 'amount': this.safeString(order, 'quantity'),
940
+ 'type': this.safeString(order, 'type'),
941
+ 'side': this.safeStringUpper(order, 'side'),
942
+ 'timeInForce': this.safeString(order, 'time_in_force'),
943
+ 'postOnly': this.safeString(order, 'post_only'),
944
+ 'reduceOnly': this.safeValue(order, 'reduce_only'),
945
+ 'filled': undefined,
946
+ 'remaining': undefined,
947
+ 'cost': undefined,
948
+ 'status': parsedStatus,
949
+ 'average': undefined,
950
+ 'trades': trades,
951
+ 'fee': undefined,
952
+ }, market);
953
+ }
954
+ async watchBalance(params = {}) {
955
+ /**
956
+ * @method
957
+ * @name hitbtc#watchBalance
958
+ * @description watches balance updates, cannot subscribe to margin account balances
959
+ * @see https://api.hitbtc.com/#subscribe-to-spot-balances
960
+ * @see https://api.hitbtc.com/#subscribe-to-futures-balances
961
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
962
+ * @param {string} [params.type] 'spot', 'swap', or 'future'
963
+ *
964
+ * EXCHANGE SPECIFIC PARAMETERS
965
+ * @param {string} [params.mode] 'updates' or 'batches' (default), 'updates' = messages arrive after balance updates, 'batches' = messages arrive at equal intervals if there were any updates
966
+ * @returns {object[]} a list of [balance structures]{@link https://docs.ccxt.com/#/?id=balance-structure}
967
+ */
968
+ await this.loadMarkets();
969
+ let type = undefined;
970
+ [type, params] = this.handleMarketTypeAndParams('watchBalance', undefined, params);
971
+ const name = this.getSupportedMapping(type, {
972
+ 'spot': 'spot_balance_subscribe',
973
+ 'swap': 'futures_balance_subscribe',
974
+ 'future': 'futures_balance_subscribe',
975
+ });
976
+ const mode = this.safeString(params, 'mode', 'batches');
977
+ params = this.omit(params, 'mode');
978
+ const request = {
979
+ 'mode': mode,
980
+ };
981
+ return await this.subscribePrivate(name, undefined, this.extend(request, params));
982
+ }
983
+ async createOrderWs(symbol, type, side, amount, price = undefined, params = {}) {
984
+ /**
985
+ * @method
986
+ * @name hitbtc#createOrder
987
+ * @description create a trade order
988
+ * @see https://api.hitbtc.com/#create-new-spot-order
989
+ * @see https://api.hitbtc.com/#create-margin-order
990
+ * @see https://api.hitbtc.com/#create-futures-order
991
+ * @param {string} symbol unified symbol of the market to create an order in
992
+ * @param {string} type 'market' or 'limit'
993
+ * @param {string} side 'buy' or 'sell'
994
+ * @param {float} amount how much of currency you want to trade in units of base currency
995
+ * @param {float} [price] the price at which the order is to be fullfilled, in units of the quote currency, ignored in market orders
996
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
997
+ * @param {string} [params.marginMode] 'cross' or 'isolated' only 'isolated' is supported for spot-margin, swap supports both, default is 'cross'
998
+ * @param {bool} [params.margin] true for creating a margin order
999
+ * @param {float} [params.triggerPrice] The price at which a trigger order is triggered at
1000
+ * @param {bool} [params.postOnly] if true, the order will only be posted to the order book and not executed immediately
1001
+ * @param {string} [params.timeInForce] "GTC", "IOC", "FOK", "Day", "GTD"
1002
+ * @returns {object} an [order structure]{@link https://github.com/ccxt/ccxt/wiki/Manual#order-structure}
1003
+ */
1004
+ await this.loadMarkets();
1005
+ const market = this.market(symbol);
1006
+ let request = undefined;
1007
+ let marketType = undefined;
1008
+ [marketType, params] = this.handleMarketTypeAndParams('createOrder', market, params);
1009
+ let marginMode = undefined;
1010
+ [marginMode, params] = this.handleMarginModeAndParams('createOrder', params);
1011
+ [request, params] = this.createOrderRequest(market, marketType, type, side, amount, price, marginMode, params);
1012
+ request = this.extend(request, params);
1013
+ if (marketType === 'swap') {
1014
+ return await this.tradeRequest('futures_new_order', request);
1015
+ }
1016
+ else if ((marketType === 'margin') || (marginMode !== undefined)) {
1017
+ return await this.tradeRequest('margin_new_order', request);
1018
+ }
1019
+ else {
1020
+ return await this.tradeRequest('spot_new_order', request);
1021
+ }
1022
+ }
1023
+ async cancelOrderWs(id, symbol = undefined, params = {}) {
1024
+ /**
1025
+ * @method
1026
+ * @name hitbtc#cancelOrderWs
1027
+ * @see https://api.hitbtc.com/#cancel-spot-order-2
1028
+ * @see https://api.hitbtc.com/#cancel-futures-order-2
1029
+ * @see https://api.hitbtc.com/#cancel-margin-order-2
1030
+ * @description cancels an open order
1031
+ * @param {string} id order id
1032
+ * @param {string} symbol unified symbol of the market the order was made in
1033
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1034
+ * @param {string} [params.marginMode] 'cross' or 'isolated' only 'isolated' is supported
1035
+ * @param {bool} [params.margin] true for canceling a margin order
1036
+ * @returns {object} An [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1037
+ */
1038
+ await this.loadMarkets();
1039
+ let market = undefined;
1040
+ let request = {
1041
+ 'client_order_id': id,
1042
+ };
1043
+ if (symbol !== undefined) {
1044
+ market = this.market(symbol);
1045
+ }
1046
+ let marketType = undefined;
1047
+ [marketType, params] = this.handleMarketTypeAndParams('cancelOrderWs', market, params);
1048
+ const [marginMode, query] = this.handleMarginModeAndParams('cancelOrderWs', params);
1049
+ request = this.extend(request, query);
1050
+ if (marketType === 'swap') {
1051
+ return await this.tradeRequest('futures_cancel_order', request);
1052
+ }
1053
+ else if ((marketType === 'margin') || (marginMode !== undefined)) {
1054
+ return await this.tradeRequest('margin_cancel_order', request);
1055
+ }
1056
+ else {
1057
+ return await this.tradeRequest('spot_cancel_order', request);
1058
+ }
1059
+ }
1060
+ async cancelAllOrdersWs(symbol = undefined, params = {}) {
1061
+ /**
1062
+ * @method
1063
+ * @name hitbtc#cancelAllOrdersWs
1064
+ * @see https://api.hitbtc.com/#cancel-spot-orders
1065
+ * @see https://api.hitbtc.com/#cancel-futures-order-3
1066
+ * @description cancel all open orders
1067
+ * @param {string} symbol unified market symbol, only orders in the market of this symbol are cancelled when symbol is not undefined
1068
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1069
+ * @param {string} [params.marginMode] 'cross' or 'isolated' only 'isolated' is supported
1070
+ * @param {bool} [params.margin] true for canceling margin orders
1071
+ * @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1072
+ */
1073
+ await this.loadMarkets();
1074
+ let market = undefined;
1075
+ if (symbol !== undefined) {
1076
+ market = this.market(symbol);
1077
+ }
1078
+ let marketType = undefined;
1079
+ [marketType, params] = this.handleMarketTypeAndParams('cancelAllOrdersWs', market, params);
1080
+ let marginMode = undefined;
1081
+ [marginMode, params] = this.handleMarginModeAndParams('cancelAllOrdersWs', params);
1082
+ if (marketType === 'swap') {
1083
+ return await this.tradeRequest('futures_cancel_orders', params);
1084
+ }
1085
+ else if ((marketType === 'margin') || (marginMode !== undefined)) {
1086
+ throw new errors.NotSupported(this.id + ' cancelAllOrdersWs is not supported for margin orders');
1087
+ }
1088
+ else {
1089
+ return await this.tradeRequest('spot_cancel_orders', params);
1090
+ }
1091
+ }
1092
+ async fetchOpenOrdersWs(symbol = undefined, since = undefined, limit = undefined, params = {}) {
1093
+ /**
1094
+ * @method
1095
+ * @name hitbtc#fetchOpenOrdersWs
1096
+ * @see https://api.hitbtc.com/#get-active-futures-orders-2
1097
+ * @see https://api.hitbtc.com/#get-margin-orders
1098
+ * @see https://api.hitbtc.com/#get-active-spot-orders
1099
+ * @description fetch all unfilled currently open orders
1100
+ * @param {string} symbol unified market symbol
1101
+ * @param {int} [since] the earliest time in ms to fetch open orders for
1102
+ * @param {int} [limit] the maximum number of open orders structures to retrieve
1103
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1104
+ * @param {string} [params.marginMode] 'cross' or 'isolated' only 'isolated' is supported
1105
+ * @param {bool} [params.margin] true for fetching open margin orders
1106
+ * @returns {Order[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1107
+ */
1108
+ await this.loadMarkets();
1109
+ let market = undefined;
1110
+ const request = {};
1111
+ if (symbol !== undefined) {
1112
+ market = this.market(symbol);
1113
+ request['symbol'] = market['id'];
1114
+ }
1115
+ let marketType = undefined;
1116
+ [marketType, params] = this.handleMarketTypeAndParams('fetchOpenOrdersWs', market, params);
1117
+ let marginMode = undefined;
1118
+ [marginMode, params] = this.handleMarginModeAndParams('fetchOpenOrdersWs', params);
1119
+ if (marketType === 'swap') {
1120
+ return await this.tradeRequest('futures_get_orders', request);
1121
+ }
1122
+ else if ((marketType === 'margin') || (marginMode !== undefined)) {
1123
+ return await this.tradeRequest('margin_get_orders', request);
1124
+ }
1125
+ else {
1126
+ return await this.tradeRequest('spot_get_orders', request);
1127
+ }
1128
+ }
1129
+ handleBalance(client, message) {
1130
+ //
1131
+ // {
1132
+ // "jsonrpc": "2.0",
1133
+ // "method": "futures_balance",
1134
+ // "params": [
1135
+ // {
1136
+ // "currency": "BCN",
1137
+ // "available": "100.000000000000",
1138
+ // "reserved": "0",
1139
+ // "reserved_margin": "0"
1140
+ // },
1141
+ // ...
1142
+ // ]
1143
+ // }
1144
+ //
1145
+ const messageHash = this.safeString(message, 'method');
1146
+ const params = this.safeValue(message, 'params');
1147
+ const balance = this.parseBalance(params);
1148
+ this.balance = this.deepExtend(this.balance, balance);
1149
+ client.resolve(this.balance, messageHash);
1150
+ }
1151
+ handleNotification(client, message) {
1152
+ //
1153
+ // { jsonrpc: "2.0", result: true, id: null }
1154
+ //
1155
+ return message;
1156
+ }
1157
+ handleOrderRequest(client, message) {
1158
+ //
1159
+ // createOrderWs, cancelOrderWs
1160
+ //
1161
+ // {
1162
+ // "jsonrpc": "2.0",
1163
+ // "result": {
1164
+ // "id": 1130310696965,
1165
+ // "client_order_id": "OPC2oyHSkEBqIpPtniLqeW-597hUL3Yo",
1166
+ // "symbol": "ADAUSDT",
1167
+ // "side": "buy",
1168
+ // "status": "new",
1169
+ // "type": "limit",
1170
+ // "time_in_force": "GTC",
1171
+ // "quantity": "4",
1172
+ // "quantity_cumulative": "0",
1173
+ // "price": "0.3300000",
1174
+ // "post_only": false,
1175
+ // "created_at": "2023-11-17T14:58:15.903Z",
1176
+ // "updated_at": "2023-11-17T14:58:15.903Z",
1177
+ // "original_client_order_id": "d6b645556af740b1bd1683400fd9cbce", // spot_replace_order only
1178
+ // "report_type": "new"
1179
+ // "margin_mode": "isolated", // margin and future only
1180
+ // "reduce_only": false, // margin and future only
1181
+ // },
1182
+ // "id": 1700233093414
1183
+ // }
1184
+ //
1185
+ const messageHash = this.safeInteger(message, 'id');
1186
+ const result = this.safeValue(message, 'result', {});
1187
+ if (Array.isArray(result)) {
1188
+ const parsedOrders = [];
1189
+ for (let i = 0; i < result.length; i++) {
1190
+ const parsedOrder = this.parseWsOrder(result[i]);
1191
+ parsedOrders.push(parsedOrder);
1192
+ }
1193
+ client.resolve(parsedOrders, messageHash);
1194
+ }
1195
+ else {
1196
+ const parsedOrder = this.parseWsOrder(result);
1197
+ client.resolve(parsedOrder, messageHash);
1198
+ }
1199
+ return message;
1200
+ }
1201
+ handleMessage(client, message) {
1202
+ this.handleError(client, message);
1203
+ let channel = this.safeString2(message, 'ch', 'method');
1204
+ if (channel !== undefined) {
1205
+ const splitChannel = channel.split('/');
1206
+ channel = this.safeString(splitChannel, 0);
1207
+ const methods = {
1208
+ 'candles': this.handleOHLCV,
1209
+ 'ticker': this.handleTicker,
1210
+ 'trades': this.handleTrades,
1211
+ 'orderbook': this.handleOrderBook,
1212
+ 'spot_order': this.handleOrder,
1213
+ 'spot_orders': this.handleOrder,
1214
+ 'margin_order': this.handleOrder,
1215
+ 'margin_orders': this.handleOrder,
1216
+ 'futures_order': this.handleOrder,
1217
+ 'futures_orders': this.handleOrder,
1218
+ 'spot_balance': this.handleBalance,
1219
+ 'futures_balance': this.handleBalance,
1220
+ };
1221
+ const method = this.safeValue(methods, channel);
1222
+ if (method !== undefined) {
1223
+ method.call(this, client, message);
1224
+ }
1225
+ }
1226
+ else {
1227
+ const result = this.safeValue(message, 'result');
1228
+ const clientOrderId = this.safeString(result, 'client_order_id');
1229
+ if (clientOrderId !== undefined) {
1230
+ this.handleOrderRequest(client, message);
1231
+ }
1232
+ if ((result === true) && !('id' in message)) {
1233
+ this.handleAuthenticate(client, message);
1234
+ }
1235
+ if (Array.isArray(result)) {
1236
+ // to do improve this, not very reliable right now
1237
+ const first = this.safeValue(result, 0, {});
1238
+ const arrayLength = result.length;
1239
+ if ((arrayLength === 0) || ('client_order_id' in first)) {
1240
+ this.handleOrderRequest(client, message);
1241
+ }
1242
+ }
1243
+ }
1244
+ }
1245
+ handleAuthenticate(client, message) {
1246
+ //
1247
+ // {
1248
+ // "jsonrpc": "2.0",
1249
+ // "result": true
1250
+ // }
1251
+ //
1252
+ const success = this.safeValue(message, 'result');
1253
+ const messageHash = 'authenticated';
1254
+ if (success) {
1255
+ const future = this.safeValue(client.futures, messageHash);
1256
+ future.resolve(true);
1257
+ }
1258
+ else {
1259
+ const error = new errors.AuthenticationError(this.id + ' ' + this.json(message));
1260
+ client.reject(error, messageHash);
1261
+ if (messageHash in client.subscriptions) {
1262
+ delete client.subscriptions[messageHash];
1263
+ }
1264
+ }
1265
+ return message;
1266
+ }
1267
+ handleError(client, message) {
1268
+ //
1269
+ // {
1270
+ // jsonrpc: '2.0',
1271
+ // error: {
1272
+ // code: 20001,
1273
+ // message: 'Insufficient funds',
1274
+ // description: 'Check that the funds are sufficient, given commissions'
1275
+ // },
1276
+ // id: 1700228604325
1277
+ // }
1278
+ //
1279
+ const error = this.safeValue(message, 'error');
1280
+ if (error !== undefined) {
1281
+ const code = this.safeValue(error, 'code');
1282
+ const errorMessage = this.safeString(error, 'message');
1283
+ const description = this.safeString(error, 'description');
1284
+ const feedback = this.id + ' ' + description;
1285
+ this.throwExactlyMatchedException(this.exceptions['exact'], code, feedback);
1286
+ this.throwBroadlyMatchedException(this.exceptions['broad'], errorMessage, feedback);
1287
+ throw new errors.ExchangeError(feedback); // unknown message
1288
+ }
1289
+ return undefined;
1290
+ }
1291
+ }
1292
+
1293
+ module.exports = hitbtc;