ccxt 4.2.11 → 4.2.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (392) hide show
  1. package/README.md +5 -5
  2. package/build.sh +2 -2
  3. package/dist/ccxt.browser.js +1347 -490
  4. package/dist/ccxt.browser.min.js +3 -3
  5. package/dist/cjs/_virtual/agent.js +7 -0
  6. package/dist/cjs/_virtual/parse-proxy-response.js +7 -0
  7. package/dist/cjs/_virtual/promisify.js +7 -0
  8. package/dist/cjs/ccxt.js +1 -1
  9. package/dist/cjs/js/ccxt.js +474 -0
  10. package/dist/cjs/js/src/abstract/ace.js +9 -0
  11. package/dist/cjs/js/src/abstract/alpaca.js +9 -0
  12. package/dist/cjs/js/src/abstract/ascendex.js +9 -0
  13. package/dist/cjs/js/src/abstract/bigone.js +9 -0
  14. package/dist/cjs/js/src/abstract/binance.js +9 -0
  15. package/dist/cjs/js/src/abstract/bingx.js +9 -0
  16. package/dist/cjs/js/src/abstract/bit2c.js +9 -0
  17. package/dist/cjs/js/src/abstract/bitbank.js +9 -0
  18. package/dist/cjs/js/src/abstract/bitbns.js +9 -0
  19. package/dist/cjs/js/src/abstract/bitfinex.js +9 -0
  20. package/dist/cjs/js/src/abstract/bitfinex2.js +9 -0
  21. package/dist/cjs/js/src/abstract/bitflyer.js +9 -0
  22. package/dist/cjs/js/src/abstract/bitforex.js +9 -0
  23. package/dist/cjs/js/src/abstract/bitget.js +9 -0
  24. package/dist/cjs/js/src/abstract/bithumb.js +9 -0
  25. package/dist/cjs/js/src/abstract/bitmart.js +9 -0
  26. package/dist/cjs/js/src/abstract/bitmex.js +9 -0
  27. package/dist/cjs/js/src/abstract/bitopro.js +9 -0
  28. package/dist/cjs/js/src/abstract/bitpanda.js +9 -0
  29. package/dist/cjs/js/src/abstract/bitrue.js +9 -0
  30. package/dist/cjs/js/src/abstract/bitso.js +9 -0
  31. package/dist/cjs/js/src/abstract/bitstamp.js +9 -0
  32. package/dist/cjs/js/src/abstract/bitteam.js +9 -0
  33. package/dist/cjs/js/src/abstract/bitvavo.js +9 -0
  34. package/dist/cjs/js/src/abstract/bl3p.js +9 -0
  35. package/dist/cjs/js/src/abstract/blockchaincom.js +9 -0
  36. package/dist/cjs/js/src/abstract/btcalpha.js +9 -0
  37. package/dist/cjs/js/src/abstract/btcbox.js +9 -0
  38. package/dist/cjs/js/src/abstract/btcmarkets.js +9 -0
  39. package/dist/cjs/js/src/abstract/btcturk.js +9 -0
  40. package/dist/cjs/js/src/abstract/bybit.js +9 -0
  41. package/dist/cjs/js/src/abstract/cex.js +9 -0
  42. package/dist/cjs/js/src/abstract/coinbase.js +9 -0
  43. package/dist/cjs/js/src/abstract/coinbasepro.js +9 -0
  44. package/dist/cjs/js/src/abstract/coincheck.js +9 -0
  45. package/dist/cjs/js/src/abstract/coinex.js +9 -0
  46. package/dist/cjs/js/src/abstract/coinlist.js +9 -0
  47. package/dist/cjs/js/src/abstract/coinmate.js +9 -0
  48. package/dist/cjs/js/src/abstract/coinone.js +9 -0
  49. package/dist/cjs/js/src/abstract/coinsph.js +9 -0
  50. package/dist/cjs/js/src/abstract/coinspot.js +9 -0
  51. package/dist/cjs/js/src/abstract/cryptocom.js +9 -0
  52. package/dist/cjs/js/src/abstract/currencycom.js +9 -0
  53. package/dist/cjs/js/src/abstract/delta.js +9 -0
  54. package/dist/cjs/js/src/abstract/deribit.js +9 -0
  55. package/dist/cjs/js/src/abstract/digifinex.js +9 -0
  56. package/dist/cjs/js/src/abstract/exmo.js +9 -0
  57. package/dist/cjs/js/src/abstract/gate.js +9 -0
  58. package/dist/cjs/js/src/abstract/gemini.js +9 -0
  59. package/dist/cjs/js/src/abstract/hitbtc.js +9 -0
  60. package/dist/cjs/js/src/abstract/hollaex.js +9 -0
  61. package/dist/cjs/js/src/abstract/htx.js +9 -0
  62. package/dist/cjs/js/src/abstract/huobijp.js +9 -0
  63. package/dist/cjs/js/src/abstract/idex.js +9 -0
  64. package/dist/cjs/js/src/abstract/independentreserve.js +9 -0
  65. package/dist/cjs/js/src/abstract/indodax.js +9 -0
  66. package/dist/cjs/js/src/abstract/kraken.js +9 -0
  67. package/dist/cjs/js/src/abstract/krakenfutures.js +9 -0
  68. package/dist/cjs/js/src/abstract/kucoin.js +9 -0
  69. package/dist/cjs/js/src/abstract/kucoinfutures.js +9 -0
  70. package/dist/cjs/js/src/abstract/kuna.js +9 -0
  71. package/dist/cjs/js/src/abstract/latoken.js +9 -0
  72. package/dist/cjs/js/src/abstract/lbank.js +9 -0
  73. package/dist/cjs/js/src/abstract/luno.js +9 -0
  74. package/dist/cjs/js/src/abstract/lykke.js +9 -0
  75. package/dist/cjs/js/src/abstract/mercado.js +9 -0
  76. package/dist/cjs/js/src/abstract/mexc.js +9 -0
  77. package/dist/cjs/js/src/abstract/ndax.js +9 -0
  78. package/dist/cjs/js/src/abstract/novadax.js +9 -0
  79. package/dist/cjs/js/src/abstract/oceanex.js +9 -0
  80. package/dist/cjs/js/src/abstract/okcoin.js +9 -0
  81. package/dist/cjs/js/src/abstract/okx.js +9 -0
  82. package/dist/cjs/js/src/abstract/p2b.js +9 -0
  83. package/dist/cjs/js/src/abstract/paymium.js +9 -0
  84. package/dist/cjs/js/src/abstract/phemex.js +9 -0
  85. package/dist/cjs/js/src/abstract/poloniex.js +9 -0
  86. package/dist/cjs/js/src/abstract/poloniexfutures.js +9 -0
  87. package/dist/cjs/js/src/abstract/probit.js +9 -0
  88. package/dist/cjs/js/src/abstract/timex.js +9 -0
  89. package/dist/cjs/js/src/abstract/tokocrypto.js +9 -0
  90. package/dist/cjs/js/src/abstract/upbit.js +9 -0
  91. package/dist/cjs/js/src/abstract/wavesexchange.js +9 -0
  92. package/dist/cjs/js/src/abstract/wazirx.js +9 -0
  93. package/dist/cjs/js/src/abstract/whitebit.js +9 -0
  94. package/dist/cjs/js/src/abstract/woo.js +9 -0
  95. package/dist/cjs/js/src/abstract/yobit.js +9 -0
  96. package/dist/cjs/js/src/abstract/zaif.js +9 -0
  97. package/dist/cjs/js/src/abstract/zonda.js +9 -0
  98. package/dist/cjs/js/src/ace.js +1058 -0
  99. package/dist/cjs/js/src/alpaca.js +1125 -0
  100. package/dist/cjs/js/src/ascendex.js +3360 -0
  101. package/dist/cjs/js/src/base/Exchange.js +5110 -0
  102. package/dist/cjs/js/src/base/Precise.js +263 -0
  103. package/dist/cjs/js/src/base/errors.js +299 -0
  104. package/dist/cjs/js/src/base/functions/crypto.js +78 -0
  105. package/dist/cjs/js/src/base/functions/encode.js +44 -0
  106. package/dist/cjs/js/src/base/functions/generic.js +193 -0
  107. package/dist/cjs/js/src/base/functions/misc.js +96 -0
  108. package/dist/cjs/js/src/base/functions/number.js +297 -0
  109. package/dist/cjs/js/src/base/functions/platform.js +28 -0
  110. package/dist/cjs/js/src/base/functions/rsa.js +34 -0
  111. package/dist/cjs/js/src/base/functions/string.js +48 -0
  112. package/dist/cjs/js/src/base/functions/throttle.js +66 -0
  113. package/dist/cjs/js/src/base/functions/time.js +187 -0
  114. package/dist/cjs/js/src/base/functions/totp.js +24 -0
  115. package/dist/cjs/js/src/base/functions/type.js +162 -0
  116. package/dist/cjs/js/src/base/functions.js +157 -0
  117. package/dist/cjs/js/src/base/ws/Cache.js +254 -0
  118. package/dist/cjs/js/src/base/ws/Client.js +299 -0
  119. package/dist/cjs/js/src/base/ws/Future.js +34 -0
  120. package/dist/cjs/js/src/base/ws/OrderBook.js +107 -0
  121. package/dist/cjs/js/src/base/ws/OrderBookSide.js +281 -0
  122. package/dist/cjs/js/src/base/ws/WsClient.js +69 -0
  123. package/dist/cjs/js/src/bequant.js +33 -0
  124. package/dist/cjs/js/src/bigone.js +2209 -0
  125. package/dist/cjs/js/src/binance.js +9736 -0
  126. package/dist/cjs/js/src/binancecoinm.js +45 -0
  127. package/dist/cjs/js/src/binanceus.js +84 -0
  128. package/dist/cjs/js/src/binanceusdm.js +58 -0
  129. package/dist/cjs/js/src/bingx.js +3807 -0
  130. package/dist/cjs/js/src/bit2c.js +916 -0
  131. package/dist/cjs/js/src/bitbank.js +1000 -0
  132. package/dist/cjs/js/src/bitbay.js +17 -0
  133. package/dist/cjs/js/src/bitbns.js +1220 -0
  134. package/dist/cjs/js/src/bitcoincom.js +17 -0
  135. package/dist/cjs/js/src/bitfinex.js +1670 -0
  136. package/dist/cjs/js/src/bitfinex2.js +2990 -0
  137. package/dist/cjs/js/src/bitflyer.js +1045 -0
  138. package/dist/cjs/js/src/bitforex.js +852 -0
  139. package/dist/cjs/js/src/bitget.js +8291 -0
  140. package/dist/cjs/js/src/bithumb.js +1090 -0
  141. package/dist/cjs/js/src/bitmart.js +4454 -0
  142. package/dist/cjs/js/src/bitmex.js +2884 -0
  143. package/dist/cjs/js/src/bitopro.js +1724 -0
  144. package/dist/cjs/js/src/bitpanda.js +2002 -0
  145. package/dist/cjs/js/src/bitrue.js +3253 -0
  146. package/dist/cjs/js/src/bitso.js +1753 -0
  147. package/dist/cjs/js/src/bitstamp.js +2188 -0
  148. package/dist/cjs/js/src/bitteam.js +2309 -0
  149. package/dist/cjs/js/src/bitvavo.js +1968 -0
  150. package/dist/cjs/js/src/bl3p.js +447 -0
  151. package/dist/cjs/js/src/blockchaincom.js +1160 -0
  152. package/dist/cjs/js/src/btcalpha.js +929 -0
  153. package/dist/cjs/js/src/btcbox.js +565 -0
  154. package/dist/cjs/js/src/btcmarkets.js +1237 -0
  155. package/dist/cjs/js/src/btcturk.js +929 -0
  156. package/dist/cjs/js/src/bybit.js +7646 -0
  157. package/dist/cjs/js/src/cex.js +1693 -0
  158. package/dist/cjs/js/src/coinbase.js +3424 -0
  159. package/dist/cjs/js/src/coinbasepro.js +1866 -0
  160. package/dist/cjs/js/src/coincheck.js +843 -0
  161. package/dist/cjs/js/src/coinex.js +5414 -0
  162. package/dist/cjs/js/src/coinlist.js +2329 -0
  163. package/dist/cjs/js/src/coinmate.js +989 -0
  164. package/dist/cjs/js/src/coinone.js +1185 -0
  165. package/dist/cjs/js/src/coinsph.js +1933 -0
  166. package/dist/cjs/js/src/coinspot.js +548 -0
  167. package/dist/cjs/js/src/cryptocom.js +3007 -0
  168. package/dist/cjs/js/src/currencycom.js +2015 -0
  169. package/dist/cjs/js/src/delta.js +3256 -0
  170. package/dist/cjs/js/src/deribit.js +3306 -0
  171. package/dist/cjs/js/src/digifinex.js +4307 -0
  172. package/dist/cjs/js/src/exmo.js +2645 -0
  173. package/dist/cjs/js/src/fmfwio.js +34 -0
  174. package/dist/cjs/js/src/gate.js +7072 -0
  175. package/dist/cjs/js/src/gateio.js +16 -0
  176. package/dist/cjs/js/src/gemini.js +1801 -0
  177. package/dist/cjs/js/src/hitbtc.js +3660 -0
  178. package/dist/cjs/js/src/hitbtc3.js +19 -0
  179. package/dist/cjs/js/src/hollaex.js +1882 -0
  180. package/dist/cjs/js/src/htx.js +9049 -0
  181. package/dist/cjs/js/src/huobi.js +16 -0
  182. package/dist/cjs/js/src/huobijp.js +1918 -0
  183. package/dist/cjs/js/src/idex.js +1770 -0
  184. package/dist/cjs/js/src/independentreserve.js +761 -0
  185. package/dist/cjs/js/src/indodax.js +1069 -0
  186. package/dist/cjs/js/src/kraken.js +2857 -0
  187. package/dist/cjs/js/src/krakenfutures.js +2407 -0
  188. package/dist/cjs/js/src/kucoin.js +4489 -0
  189. package/dist/cjs/js/src/kucoinfutures.js +2475 -0
  190. package/dist/cjs/js/src/kuna.js +1949 -0
  191. package/dist/cjs/js/src/latoken.js +1729 -0
  192. package/dist/cjs/js/src/lbank.js +2851 -0
  193. package/dist/cjs/js/src/luno.js +1044 -0
  194. package/dist/cjs/js/src/lykke.js +1303 -0
  195. package/dist/cjs/js/src/mercado.js +897 -0
  196. package/dist/cjs/js/src/mexc.js +5407 -0
  197. package/dist/cjs/js/src/ndax.js +2450 -0
  198. package/dist/cjs/js/src/novadax.js +1556 -0
  199. package/dist/cjs/js/src/oceanex.js +964 -0
  200. package/dist/cjs/js/src/okcoin.js +3115 -0
  201. package/dist/cjs/js/src/okx.js +7330 -0
  202. package/dist/cjs/js/src/p2b.js +1243 -0
  203. package/dist/cjs/js/src/paymium.js +597 -0
  204. package/dist/cjs/js/src/phemex.js +4722 -0
  205. package/dist/cjs/js/src/poloniex.js +2356 -0
  206. package/dist/cjs/js/src/poloniexfutures.js +1794 -0
  207. package/dist/cjs/js/src/pro/alpaca.js +714 -0
  208. package/dist/cjs/js/src/pro/ascendex.js +957 -0
  209. package/dist/cjs/js/src/pro/bequant.js +33 -0
  210. package/dist/cjs/js/src/pro/binance.js +2796 -0
  211. package/dist/cjs/js/src/pro/binancecoinm.js +23 -0
  212. package/dist/cjs/js/src/pro/binanceus.js +51 -0
  213. package/dist/cjs/js/src/pro/binanceusdm.js +32 -0
  214. package/dist/cjs/js/src/pro/bingx.js +944 -0
  215. package/dist/cjs/js/src/pro/bitcoincom.js +29 -0
  216. package/dist/cjs/js/src/pro/bitfinex.js +672 -0
  217. package/dist/cjs/js/src/pro/bitfinex2.js +1159 -0
  218. package/dist/cjs/js/src/pro/bitget.js +1733 -0
  219. package/dist/cjs/js/src/pro/bitmart.js +1486 -0
  220. package/dist/cjs/js/src/pro/bitmex.js +1576 -0
  221. package/dist/cjs/js/src/pro/bitopro.js +327 -0
  222. package/dist/cjs/js/src/pro/bitpanda.js +1341 -0
  223. package/dist/cjs/js/src/pro/bitrue.js +462 -0
  224. package/dist/cjs/js/src/pro/bitstamp.js +547 -0
  225. package/dist/cjs/js/src/pro/bitvavo.js +704 -0
  226. package/dist/cjs/js/src/pro/blockchaincom.js +794 -0
  227. package/dist/cjs/js/src/pro/bybit.js +1843 -0
  228. package/dist/cjs/js/src/pro/cex.js +1510 -0
  229. package/dist/cjs/js/src/pro/coinbase.js +561 -0
  230. package/dist/cjs/js/src/pro/coinbasepro.js +968 -0
  231. package/dist/cjs/js/src/pro/coinex.js +1095 -0
  232. package/dist/cjs/js/src/pro/cryptocom.js +1020 -0
  233. package/dist/cjs/js/src/pro/currencycom.js +563 -0
  234. package/dist/cjs/js/src/pro/deribit.js +825 -0
  235. package/dist/cjs/js/src/pro/exmo.js +658 -0
  236. package/dist/cjs/js/src/pro/gate.js +1316 -0
  237. package/dist/cjs/js/src/pro/gateio.js +16 -0
  238. package/dist/cjs/js/src/pro/gemini.js +649 -0
  239. package/dist/cjs/js/src/pro/hitbtc.js +1293 -0
  240. package/dist/cjs/js/src/pro/hollaex.js +597 -0
  241. package/dist/cjs/js/src/pro/htx.js +2383 -0
  242. package/dist/cjs/js/src/pro/huobi.js +16 -0
  243. package/dist/cjs/js/src/pro/huobijp.js +606 -0
  244. package/dist/cjs/js/src/pro/idex.js +714 -0
  245. package/dist/cjs/js/src/pro/independentreserve.js +280 -0
  246. package/dist/cjs/js/src/pro/kraken.js +1364 -0
  247. package/dist/cjs/js/src/pro/krakenfutures.js +1500 -0
  248. package/dist/cjs/js/src/pro/kucoin.js +1052 -0
  249. package/dist/cjs/js/src/pro/kucoinfutures.js +981 -0
  250. package/dist/cjs/js/src/pro/luno.js +322 -0
  251. package/dist/cjs/js/src/pro/mexc.js +1170 -0
  252. package/dist/cjs/js/src/pro/ndax.js +545 -0
  253. package/dist/cjs/js/src/pro/okcoin.js +760 -0
  254. package/dist/cjs/js/src/pro/okx.js +1608 -0
  255. package/dist/cjs/js/src/pro/phemex.js +1511 -0
  256. package/dist/cjs/js/src/pro/poloniex.js +1253 -0
  257. package/dist/cjs/js/src/pro/poloniexfutures.js +1014 -0
  258. package/dist/cjs/js/src/pro/probit.js +586 -0
  259. package/dist/cjs/js/src/pro/upbit.js +234 -0
  260. package/dist/cjs/js/src/pro/wazirx.js +776 -0
  261. package/dist/cjs/js/src/pro/whitebit.js +927 -0
  262. package/dist/cjs/js/src/pro/woo.js +769 -0
  263. package/dist/cjs/js/src/probit.js +1867 -0
  264. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +401 -0
  265. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +195 -0
  266. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +308 -0
  267. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +554 -0
  268. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
  269. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
  270. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
  271. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +16 -0
  272. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1760 -0
  273. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +52 -0
  274. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +81 -0
  275. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +376 -0
  276. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +70 -0
  277. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1580 -0
  278. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +74 -0
  279. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +24 -0
  280. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +158 -0
  281. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +429 -0
  282. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +176 -0
  283. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +324 -0
  284. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +163 -0
  285. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +245 -0
  286. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +1018 -0
  287. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +383 -0
  288. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +258 -0
  289. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +53 -0
  290. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +120 -0
  291. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +69 -0
  292. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +7 -0
  293. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +83 -0
  294. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +240 -0
  295. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +91 -0
  296. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +130 -0
  297. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +214 -0
  298. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +239 -0
  299. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +93 -0
  300. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +354 -0
  301. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +16 -0
  302. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +20 -0
  303. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +30 -0
  304. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +239 -0
  305. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +372 -0
  306. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +273 -0
  307. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +139 -0
  308. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +14 -0
  309. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +16 -0
  310. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +81 -0
  311. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +292 -0
  312. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +103 -0
  313. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +140 -0
  314. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +175 -0
  315. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
  316. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +7 -0
  317. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +383 -0
  318. package/dist/cjs/js/src/timex.js +1562 -0
  319. package/dist/cjs/js/src/tokocrypto.js +2542 -0
  320. package/dist/cjs/js/src/upbit.js +1844 -0
  321. package/dist/cjs/js/src/wavesexchange.js +2607 -0
  322. package/dist/cjs/js/src/wazirx.js +953 -0
  323. package/dist/cjs/js/src/whitebit.js +2309 -0
  324. package/dist/cjs/js/src/woo.js +2765 -0
  325. package/dist/cjs/js/src/yobit.js +1314 -0
  326. package/dist/cjs/js/src/zaif.js +736 -0
  327. package/dist/cjs/js/src/zonda.js +1883 -0
  328. package/js/ccxt.d.ts +1 -1
  329. package/js/ccxt.js +1 -1
  330. package/js/src/abstract/bigone.d.ts +18 -0
  331. package/js/src/abstract/binance.d.ts +2 -0
  332. package/js/src/abstract/binancecoinm.d.ts +2 -0
  333. package/js/src/abstract/binanceus.d.ts +2 -0
  334. package/js/src/abstract/binanceusdm.d.ts +2 -0
  335. package/js/src/abstract/bingx.d.ts +2 -0
  336. package/js/src/abstract/bybit.d.ts +1 -0
  337. package/js/src/abstract/gate.d.ts +11 -0
  338. package/js/src/abstract/gateio.d.ts +11 -0
  339. package/js/src/abstract/okx.d.ts +1 -0
  340. package/js/src/alpaca.js +18 -18
  341. package/js/src/base/Exchange.d.ts +5 -1
  342. package/js/src/base/Exchange.js +101 -12
  343. package/js/src/bigone.d.ts +3 -2
  344. package/js/src/bigone.js +429 -167
  345. package/js/src/binance.js +48 -34
  346. package/js/src/bingx.js +115 -38
  347. package/js/src/bitfinex.d.ts +2 -2
  348. package/js/src/bitfinex.js +2 -3
  349. package/js/src/bitget.js +33 -13
  350. package/js/src/bitmart.d.ts +2 -2
  351. package/js/src/bitmart.js +5 -5
  352. package/js/src/bitmex.js +1 -0
  353. package/js/src/bybit.js +2 -0
  354. package/js/src/coinbase.d.ts +26 -3
  355. package/js/src/coinbase.js +176 -26
  356. package/js/src/coinlist.js +3 -4
  357. package/js/src/coinone.js +1 -1
  358. package/js/src/coinsph.js +2 -3
  359. package/js/src/deribit.js +1 -0
  360. package/js/src/gate.d.ts +4 -4
  361. package/js/src/gate.js +96 -59
  362. package/js/src/gemini.js +1 -1
  363. package/js/src/hitbtc.d.ts +4 -4
  364. package/js/src/hitbtc.js +2 -3
  365. package/js/src/htx.d.ts +1 -0
  366. package/js/src/htx.js +29 -7
  367. package/js/src/huobijp.js +2 -3
  368. package/js/src/independentreserve.js +7 -5
  369. package/js/src/kraken.js +3 -6
  370. package/js/src/lbank.js +59 -33
  371. package/js/src/mexc.js +2 -1
  372. package/js/src/oceanex.js +1 -1
  373. package/js/src/okx.js +14 -3
  374. package/js/src/phemex.js +9 -2
  375. package/js/src/pro/binance.d.ts +2 -23
  376. package/js/src/pro/binance.js +58 -22
  377. package/js/src/pro/coinbase.d.ts +2 -2
  378. package/js/src/pro/coinbase.js +4 -1
  379. package/js/src/pro/coinbasepro.d.ts +2 -2
  380. package/js/src/pro/hitbtc.d.ts +2 -2
  381. package/js/src/pro/kraken.js +1 -1
  382. package/js/src/pro/okx.d.ts +1 -0
  383. package/js/src/pro/okx.js +52 -2
  384. package/js/src/pro/poloniex.d.ts +2 -2
  385. package/js/src/probit.js +4 -2
  386. package/js/src/upbit.d.ts +3 -101
  387. package/js/src/upbit.js +12 -12
  388. package/js/src/wavesexchange.js +1 -1
  389. package/js/src/woo.d.ts +2 -0
  390. package/js/src/woo.js +52 -0
  391. package/package.json +1 -1
  392. package/skip-tests.json +5 -0
@@ -0,0 +1,1316 @@
1
+ 'use strict';
2
+
3
+ var gate$1 = require('../gate.js');
4
+ var errors = require('../base/errors.js');
5
+ var Cache = require('../base/ws/Cache.js');
6
+ var sha512 = require('../static_dependencies/noble-hashes/sha512.js');
7
+
8
+ // ---------------------------------------------------------------------------
9
+ // ---------------------------------------------------------------------------
10
+ class gate extends gate$1 {
11
+ describe() {
12
+ return this.deepExtend(super.describe(), {
13
+ 'has': {
14
+ 'ws': true,
15
+ 'watchOrderBook': true,
16
+ 'watchTicker': true,
17
+ 'watchTickers': true,
18
+ 'watchTrades': true,
19
+ 'watchTradesForSymbols': true,
20
+ 'watchMyTrades': true,
21
+ 'watchOHLCV': true,
22
+ 'watchBalance': true,
23
+ 'watchOrders': true,
24
+ 'watchPositions': true,
25
+ },
26
+ 'urls': {
27
+ 'api': {
28
+ 'ws': 'wss://ws.gate.io/v4',
29
+ 'spot': 'wss://api.gateio.ws/ws/v4/',
30
+ 'swap': {
31
+ 'usdt': 'wss://fx-ws.gateio.ws/v4/ws/usdt',
32
+ 'btc': 'wss://fx-ws.gateio.ws/v4/ws/btc',
33
+ },
34
+ 'future': {
35
+ 'usdt': 'wss://fx-ws.gateio.ws/v4/ws/delivery/usdt',
36
+ 'btc': 'wss://fx-ws.gateio.ws/v4/ws/delivery/btc',
37
+ },
38
+ 'option': {
39
+ 'usdt': 'wss://op-ws.gateio.live/v4/ws/usdt',
40
+ 'btc': 'wss://op-ws.gateio.live/v4/ws/btc',
41
+ },
42
+ },
43
+ 'test': {
44
+ 'swap': {
45
+ 'usdt': 'wss://fx-ws-testnet.gateio.ws/v4/ws/usdt',
46
+ 'btc': 'wss://fx-ws-testnet.gateio.ws/v4/ws/btc',
47
+ },
48
+ 'future': {
49
+ 'usdt': 'wss://fx-ws-testnet.gateio.ws/v4/ws/usdt',
50
+ 'btc': 'wss://fx-ws-testnet.gateio.ws/v4/ws/btc',
51
+ },
52
+ 'option': {
53
+ 'usdt': 'wss://op-ws-testnet.gateio.live/v4/ws/usdt',
54
+ 'btc': 'wss://op-ws-testnet.gateio.live/v4/ws/btc',
55
+ },
56
+ },
57
+ },
58
+ 'options': {
59
+ 'tradesLimit': 1000,
60
+ 'OHLCVLimit': 1000,
61
+ 'watchTradesSubscriptions': {},
62
+ 'watchTickerSubscriptions': {},
63
+ 'watchOrderBookSubscriptions': {},
64
+ 'watchTicker': {
65
+ 'name': 'tickers', // or book_ticker
66
+ },
67
+ 'watchOrderBook': {
68
+ 'interval': '100ms',
69
+ 'snapshotDelay': 10,
70
+ 'snapshotMaxRetries': 3,
71
+ },
72
+ 'watchBalance': {
73
+ 'settle': 'usdt',
74
+ 'spot': 'spot.balances', // spot.margin_balances, spot.funding_balances or spot.cross_balances
75
+ },
76
+ 'watchPositions': {
77
+ 'fetchPositionsSnapshot': true,
78
+ 'awaitPositionsSnapshot': true, // whether to wait for the positions snapshot before providing updates
79
+ },
80
+ },
81
+ 'exceptions': {
82
+ 'ws': {
83
+ 'exact': {
84
+ '2': errors.BadRequest,
85
+ '4': errors.AuthenticationError,
86
+ '6': errors.AuthenticationError,
87
+ '11': errors.AuthenticationError,
88
+ },
89
+ },
90
+ },
91
+ });
92
+ }
93
+ async watchOrderBook(symbol, limit = undefined, params = {}) {
94
+ /**
95
+ * @method
96
+ * @name gate#watchOrderBook
97
+ * @description watches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
98
+ * @param {string} symbol unified symbol of the market to fetch the order book for
99
+ * @param {int} [limit] the maximum amount of order book entries to return
100
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
101
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
102
+ */
103
+ await this.loadMarkets();
104
+ const market = this.market(symbol);
105
+ symbol = market['symbol'];
106
+ const marketId = market['id'];
107
+ const [interval, query] = this.handleOptionAndParams(params, 'watchOrderBook', 'interval', '100ms');
108
+ const messageType = this.getTypeByMarket(market);
109
+ const channel = messageType + '.order_book_update';
110
+ const messageHash = 'orderbook' + ':' + symbol;
111
+ const url = this.getUrlByMarket(market);
112
+ const payload = [marketId, interval];
113
+ if (limit === undefined) {
114
+ limit = 100;
115
+ }
116
+ if (market['contract']) {
117
+ const stringLimit = limit.toString();
118
+ payload.push(stringLimit);
119
+ }
120
+ const subscription = {
121
+ 'symbol': symbol,
122
+ 'limit': limit,
123
+ };
124
+ const orderbook = await this.subscribePublic(url, messageHash, payload, channel, query, subscription);
125
+ return orderbook.limit();
126
+ }
127
+ handleOrderBookSubscription(client, message, subscription) {
128
+ const symbol = this.safeString(subscription, 'symbol');
129
+ const limit = this.safeInteger(subscription, 'limit');
130
+ this.orderbooks[symbol] = this.orderBook({}, limit);
131
+ }
132
+ handleOrderBook(client, message) {
133
+ //
134
+ // spot
135
+ //
136
+ // {
137
+ // "time": 1650189272,
138
+ // "channel": "spot.order_book_update",
139
+ // "event": "update",
140
+ // "result": {
141
+ // "t": 1650189272515,
142
+ // "e": "depthUpdate",
143
+ // "E": 1650189272,
144
+ // "s": "GMT_USDT",
145
+ // "U": 140595902,
146
+ // "u": 140595902,
147
+ // "b": [
148
+ // [ '2.51518', "228.119" ],
149
+ // [ '2.50587', "1510.11" ],
150
+ // [ '2.49944', "67.6" ],
151
+ // ],
152
+ // "a": [
153
+ // [ '2.5182', "4.199" ],
154
+ // [ "2.51926", "1874" ],
155
+ // [ '2.53528', "96.529" ],
156
+ // ]
157
+ // }
158
+ // }
159
+ //
160
+ // swap
161
+ //
162
+ // {
163
+ // "id": null,
164
+ // "time": 1650188898,
165
+ // "channel": "futures.order_book_update",
166
+ // "event": "update",
167
+ // "error": null,
168
+ // "result": {
169
+ // "t": 1650188898938,
170
+ // "s": "GMT_USDT",
171
+ // "U": 1577718307,
172
+ // "u": 1577719254,
173
+ // "b": [
174
+ // { p: "2.5178", s: 0 },
175
+ // { p: "2.5179", s: 0 },
176
+ // { p: "2.518", s: 0 },
177
+ // ],
178
+ // "a": [
179
+ // { p: "2.52", s: 0 },
180
+ // { p: "2.5201", s: 0 },
181
+ // { p: "2.5203", s: 0 },
182
+ // ]
183
+ // }
184
+ // }
185
+ //
186
+ const channel = this.safeString(message, 'channel');
187
+ const channelParts = channel.split('.');
188
+ const rawMarketType = this.safeString(channelParts, 0);
189
+ const isSpot = rawMarketType === 'spot';
190
+ const marketType = isSpot ? 'spot' : 'contract';
191
+ const delta = this.safeValue(message, 'result');
192
+ const deltaStart = this.safeInteger(delta, 'U');
193
+ const deltaEnd = this.safeInteger(delta, 'u');
194
+ const marketId = this.safeString(delta, 's');
195
+ const symbol = this.safeSymbol(marketId, undefined, '_', marketType);
196
+ const messageHash = 'orderbook:' + symbol;
197
+ const storedOrderBook = this.safeValue(this.orderbooks, symbol, this.orderBook({}));
198
+ const nonce = this.safeInteger(storedOrderBook, 'nonce');
199
+ if (nonce === undefined) {
200
+ let cacheLength = 0;
201
+ if (storedOrderBook !== undefined) {
202
+ cacheLength = storedOrderBook.cache.length;
203
+ }
204
+ const snapshotDelay = this.handleOption('watchOrderBook', 'snapshotDelay', 10);
205
+ const waitAmount = isSpot ? snapshotDelay : 0;
206
+ if (cacheLength === waitAmount) {
207
+ // max limit is 100
208
+ const subscription = client.subscriptions[messageHash];
209
+ const limit = this.safeInteger(subscription, 'limit');
210
+ this.spawn(this.loadOrderBook, client, messageHash, symbol, limit);
211
+ }
212
+ storedOrderBook.cache.push(delta);
213
+ return;
214
+ }
215
+ else if (nonce >= deltaEnd) {
216
+ return;
217
+ }
218
+ else if (nonce >= deltaStart - 1) {
219
+ this.handleDelta(storedOrderBook, delta);
220
+ }
221
+ else {
222
+ const error = new errors.InvalidNonce(this.id + ' orderbook update has a nonce bigger than u');
223
+ delete client.subscriptions[messageHash];
224
+ delete this.orderbooks[symbol];
225
+ client.reject(error, messageHash);
226
+ }
227
+ client.resolve(storedOrderBook, messageHash);
228
+ }
229
+ getCacheIndex(orderBook, cache) {
230
+ const nonce = this.safeInteger(orderBook, 'nonce');
231
+ const firstDelta = cache[0];
232
+ const firstDeltaStart = this.safeInteger(firstDelta, 'U');
233
+ if (nonce < firstDeltaStart) {
234
+ return -1;
235
+ }
236
+ for (let i = 0; i < cache.length; i++) {
237
+ const delta = cache[i];
238
+ const deltaStart = this.safeInteger(delta, 'U');
239
+ const deltaEnd = this.safeInteger(delta, 'u');
240
+ if ((nonce >= deltaStart - 1) && (nonce < deltaEnd)) {
241
+ return i;
242
+ }
243
+ }
244
+ return cache.length;
245
+ }
246
+ handleBidAsks(bookSide, bidAsks) {
247
+ for (let i = 0; i < bidAsks.length; i++) {
248
+ const bidAsk = bidAsks[i];
249
+ if (Array.isArray(bidAsk)) {
250
+ bookSide.storeArray(this.parseBidAsk(bidAsk));
251
+ }
252
+ else {
253
+ const price = this.safeFloat(bidAsk, 'p');
254
+ const amount = this.safeFloat(bidAsk, 's');
255
+ bookSide.store(price, amount);
256
+ }
257
+ }
258
+ }
259
+ handleDelta(orderbook, delta) {
260
+ const timestamp = this.safeInteger(delta, 't');
261
+ orderbook['timestamp'] = timestamp;
262
+ orderbook['datetime'] = this.iso8601(timestamp);
263
+ orderbook['nonce'] = this.safeInteger(delta, 'u');
264
+ const bids = this.safeValue(delta, 'b', []);
265
+ const asks = this.safeValue(delta, 'a', []);
266
+ const storedBids = orderbook['bids'];
267
+ const storedAsks = orderbook['asks'];
268
+ this.handleBidAsks(storedBids, bids);
269
+ this.handleBidAsks(storedAsks, asks);
270
+ }
271
+ async watchTicker(symbol, params = {}) {
272
+ /**
273
+ * @method
274
+ * @name gate#watchTicker
275
+ * @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
276
+ * @param {string} symbol unified symbol of the market to fetch the ticker for
277
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
278
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
279
+ */
280
+ await this.loadMarkets();
281
+ const market = this.market(symbol);
282
+ symbol = market['symbol'];
283
+ const marketId = market['id'];
284
+ const url = this.getUrlByMarket(market);
285
+ const messageType = this.getTypeByMarket(market);
286
+ const [topic, query] = this.handleOptionAndParams(params, 'watchTicker', 'name', 'tickers');
287
+ const channel = messageType + '.' + topic;
288
+ const messageHash = 'ticker:' + symbol;
289
+ const payload = [marketId];
290
+ return await this.subscribePublic(url, messageHash, payload, channel, query);
291
+ }
292
+ async watchTickers(symbols = undefined, params = {}) {
293
+ /**
294
+ * @method
295
+ * @name gate#watchTickers
296
+ * @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for all markets of a specific list
297
+ * @param {string[]} symbols unified symbol of the market to fetch the ticker for
298
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
299
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
300
+ */
301
+ await this.loadMarkets();
302
+ symbols = this.marketSymbols(symbols);
303
+ if (symbols === undefined) {
304
+ throw new errors.ArgumentsRequired(this.id + ' watchTickers requires symbols');
305
+ }
306
+ const market = this.market(symbols[0]);
307
+ const messageType = this.getTypeByMarket(market);
308
+ const marketIds = this.marketIds(symbols);
309
+ const [topic, query] = this.handleOptionAndParams(params, 'watchTicker', 'method', 'tickers');
310
+ const channel = messageType + '.' + topic;
311
+ const messageHash = 'tickers';
312
+ const url = this.getUrlByMarket(market);
313
+ const ticker = await this.subscribePublic(url, messageHash, marketIds, channel, query);
314
+ let result = {};
315
+ if (this.newUpdates) {
316
+ result[ticker['symbol']] = ticker;
317
+ }
318
+ else {
319
+ result = this.tickers;
320
+ }
321
+ return this.filterByArray(result, 'symbol', symbols, true);
322
+ }
323
+ handleTicker(client, message) {
324
+ //
325
+ // {
326
+ // "time": 1649326221,
327
+ // "channel": "spot.tickers",
328
+ // "event": "update",
329
+ // "result": {
330
+ // "currency_pair": "BTC_USDT",
331
+ // "last": "43444.82",
332
+ // "lowest_ask": "43444.82",
333
+ // "highest_bid": "43444.81",
334
+ // "change_percentage": "-4.0036",
335
+ // "base_volume": "5182.5412425462",
336
+ // "quote_volume": "227267634.93123952",
337
+ // "high_24h": "47698",
338
+ // "low_24h": "42721.03"
339
+ // }
340
+ // }
341
+ // {
342
+ // "time": 1671363004,
343
+ // "time_ms": 1671363004235,
344
+ // "channel": "spot.book_ticker",
345
+ // "event": "update",
346
+ // "result": {
347
+ // "t": 1671363004228,
348
+ // "u": 9793320464,
349
+ // "s": "BTC_USDT",
350
+ // "b": "16716.8",
351
+ // "B": "0.0134",
352
+ // "a": "16716.9",
353
+ // "A": "0.0353"
354
+ // }
355
+ // }
356
+ //
357
+ const channel = this.safeString(message, 'channel');
358
+ const parts = channel.split('.');
359
+ const rawMarketType = this.safeString(parts, 0);
360
+ const marketType = (rawMarketType === 'futures') ? 'contract' : 'spot';
361
+ let result = this.safeValue(message, 'result');
362
+ if (!Array.isArray(result)) {
363
+ result = [result];
364
+ }
365
+ for (let i = 0; i < result.length; i++) {
366
+ const ticker = result[i];
367
+ const marketId = this.safeString(ticker, 's');
368
+ const market = this.safeMarket(marketId, undefined, '_', marketType);
369
+ const parsed = this.parseTicker(ticker, market);
370
+ const symbol = parsed['symbol'];
371
+ this.tickers[symbol] = parsed;
372
+ const messageHash = 'ticker:' + symbol;
373
+ client.resolve(parsed, messageHash);
374
+ client.resolve(parsed, 'tickers');
375
+ }
376
+ }
377
+ async watchTrades(symbol, since = undefined, limit = undefined, params = {}) {
378
+ /**
379
+ * @method
380
+ * @name gate#watchTrades
381
+ * @description get the list of most recent trades for a particular symbol
382
+ * @param {string} symbol unified symbol of the market to fetch trades for
383
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
384
+ * @param {int} [limit] the maximum amount of trades to fetch
385
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
386
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
387
+ */
388
+ return await this.watchTradesForSymbols([symbol], since, limit, params);
389
+ }
390
+ async watchTradesForSymbols(symbols, since = undefined, limit = undefined, params = {}) {
391
+ /**
392
+ * @method
393
+ * @name gate#watchTradesForSymbols
394
+ * @description get the list of most recent trades for a particular symbol
395
+ * @param {string} symbol unified symbol of the market to fetch trades for
396
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
397
+ * @param {int} [limit] the maximum amount of trades to fetch
398
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
399
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
400
+ */
401
+ await this.loadMarkets();
402
+ symbols = this.marketSymbols(symbols);
403
+ const marketIds = this.marketIds(symbols);
404
+ const market = this.market(symbols[0]);
405
+ const messageType = this.getTypeByMarket(market);
406
+ const channel = messageType + '.trades';
407
+ const messageHashes = [];
408
+ for (let i = 0; i < symbols.length; i++) {
409
+ const symbol = symbols[i];
410
+ messageHashes.push('trades:' + symbol);
411
+ }
412
+ const url = this.getUrlByMarket(market);
413
+ const trades = await this.subscribePublicMultiple(url, messageHashes, marketIds, channel, params);
414
+ if (this.newUpdates) {
415
+ const first = this.safeValue(trades, 0);
416
+ const tradeSymbol = this.safeString(first, 'symbol');
417
+ limit = trades.getLimit(tradeSymbol, limit);
418
+ }
419
+ return this.filterBySinceLimit(trades, since, limit, 'timestamp', true);
420
+ }
421
+ handleTrades(client, message) {
422
+ //
423
+ // {
424
+ // "time": 1648725035,
425
+ // "channel": "spot.trades",
426
+ // "event": "update",
427
+ // "result": [{
428
+ // "id": 3130257995,
429
+ // "create_time": 1648725035,
430
+ // "create_time_ms": "1648725035923.0",
431
+ // "side": "sell",
432
+ // "currency_pair": "LTC_USDT",
433
+ // "amount": "0.0116",
434
+ // "price": "130.11"
435
+ // }]
436
+ // }
437
+ //
438
+ let result = this.safeValue(message, 'result');
439
+ if (!Array.isArray(result)) {
440
+ result = [result];
441
+ }
442
+ const parsedTrades = this.parseTrades(result);
443
+ for (let i = 0; i < parsedTrades.length; i++) {
444
+ const trade = parsedTrades[i];
445
+ const symbol = trade['symbol'];
446
+ let cachedTrades = this.safeValue(this.trades, symbol);
447
+ if (cachedTrades === undefined) {
448
+ const limit = this.safeInteger(this.options, 'tradesLimit', 1000);
449
+ cachedTrades = new Cache.ArrayCache(limit);
450
+ this.trades[symbol] = cachedTrades;
451
+ }
452
+ cachedTrades.append(trade);
453
+ const hash = 'trades:' + symbol;
454
+ client.resolve(cachedTrades, hash);
455
+ }
456
+ }
457
+ async watchOHLCV(symbol, timeframe = '1m', since = undefined, limit = undefined, params = {}) {
458
+ /**
459
+ * @method
460
+ * @name gate#watchOHLCV
461
+ * @description watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
462
+ * @param {string} symbol unified symbol of the market to fetch OHLCV data for
463
+ * @param {string} timeframe the length of time each candle represents
464
+ * @param {int} [since] timestamp in ms of the earliest candle to fetch
465
+ * @param {int} [limit] the maximum amount of candles to fetch
466
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
467
+ * @returns {int[][]} A list of candles ordered as timestamp, open, high, low, close, volume
468
+ */
469
+ await this.loadMarkets();
470
+ const market = this.market(symbol);
471
+ symbol = market['symbol'];
472
+ const marketId = market['id'];
473
+ const interval = this.safeString(this.timeframes, timeframe, timeframe);
474
+ const messageType = this.getTypeByMarket(market);
475
+ const channel = messageType + '.candlesticks';
476
+ const messageHash = 'candles:' + interval + ':' + market['symbol'];
477
+ const url = this.getUrlByMarket(market);
478
+ const payload = [interval, marketId];
479
+ const ohlcv = await this.subscribePublic(url, messageHash, payload, channel, params);
480
+ if (this.newUpdates) {
481
+ limit = ohlcv.getLimit(symbol, limit);
482
+ }
483
+ return this.filterBySinceLimit(ohlcv, since, limit, 0, true);
484
+ }
485
+ handleOHLCV(client, message) {
486
+ //
487
+ // {
488
+ // "time": 1606292600,
489
+ // "channel": "spot.candlesticks",
490
+ // "event": "update",
491
+ // "result": {
492
+ // "t": "1606292580", // total volume
493
+ // "v": "2362.32035", // volume
494
+ // "c": "19128.1", // close
495
+ // "h": "19128.1", // high
496
+ // "l": "19128.1", // low
497
+ // "o": "19128.1", // open
498
+ // "n": "1m_BTC_USDT" // sub
499
+ // }
500
+ // }
501
+ //
502
+ const channel = this.safeString(message, 'channel');
503
+ const channelParts = channel.split('.');
504
+ const rawMarketType = this.safeString(channelParts, 0);
505
+ const marketType = (rawMarketType === 'spot') ? 'spot' : 'contract';
506
+ let result = this.safeValue(message, 'result');
507
+ if (!Array.isArray(result)) {
508
+ result = [result];
509
+ }
510
+ const marketIds = {};
511
+ for (let i = 0; i < result.length; i++) {
512
+ const ohlcv = result[i];
513
+ const subscription = this.safeString(ohlcv, 'n', '');
514
+ const parts = subscription.split('_');
515
+ const timeframe = this.safeString(parts, 0);
516
+ const timeframeId = this.findTimeframe(timeframe);
517
+ const prefix = timeframe + '_';
518
+ const marketId = subscription.replace(prefix, '');
519
+ const symbol = this.safeSymbol(marketId, undefined, '_', marketType);
520
+ const parsed = this.parseOHLCV(ohlcv);
521
+ this.ohlcvs[symbol] = this.safeValue(this.ohlcvs, symbol, {});
522
+ let stored = this.safeValue(this.ohlcvs[symbol], timeframe);
523
+ if (stored === undefined) {
524
+ const limit = this.safeInteger(this.options, 'OHLCVLimit', 1000);
525
+ stored = new Cache.ArrayCacheByTimestamp(limit);
526
+ this.ohlcvs[symbol][timeframeId] = stored;
527
+ }
528
+ stored.append(parsed);
529
+ marketIds[symbol] = timeframe;
530
+ }
531
+ const keys = Object.keys(marketIds);
532
+ for (let i = 0; i < keys.length; i++) {
533
+ const symbol = keys[i];
534
+ const timeframe = marketIds[symbol];
535
+ const interval = this.findTimeframe(timeframe);
536
+ const hash = 'candles' + ':' + interval + ':' + symbol;
537
+ const stored = this.safeValue(this.ohlcvs[symbol], interval);
538
+ client.resolve(stored, hash);
539
+ }
540
+ }
541
+ async watchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
542
+ /**
543
+ * @method
544
+ * @name gate#watchMyTrades
545
+ * @description watches information on multiple trades made by the user
546
+ * @param {string} symbol unified market symbol of the market trades were made in
547
+ * @param {int} [since] the earliest time in ms to fetch trades for
548
+ * @param {int} [limit] the maximum number of trade structures to retrieve
549
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
550
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure
551
+ */
552
+ await this.loadMarkets();
553
+ let subType = undefined;
554
+ let type = undefined;
555
+ let marketId = '!' + 'all';
556
+ let market = undefined;
557
+ if (symbol !== undefined) {
558
+ market = this.market(symbol);
559
+ marketId = market['id'];
560
+ }
561
+ [type, params] = this.handleMarketTypeAndParams('watchMyTrades', market, params);
562
+ [subType, params] = this.handleSubTypeAndParams('watchMyTrades', market, params);
563
+ const messageType = this.getSupportedMapping(type, {
564
+ 'spot': 'spot',
565
+ 'margin': 'spot',
566
+ 'future': 'futures',
567
+ 'swap': 'futures',
568
+ 'option': 'options',
569
+ });
570
+ const channel = messageType + '.usertrades';
571
+ let messageHash = 'myTrades';
572
+ if (symbol !== undefined) {
573
+ messageHash += ':' + symbol;
574
+ }
575
+ const isInverse = (subType === 'inverse');
576
+ const url = this.getUrlByMarketType(type, isInverse);
577
+ const payload = [marketId];
578
+ // uid required for non spot markets
579
+ const requiresUid = (type !== 'spot');
580
+ const trades = await this.subscribePrivate(url, messageHash, payload, channel, params, requiresUid);
581
+ if (this.newUpdates) {
582
+ limit = trades.getLimit(symbol, limit);
583
+ }
584
+ return this.filterBySymbolSinceLimit(trades, symbol, since, limit, true);
585
+ }
586
+ handleMyTrades(client, message) {
587
+ //
588
+ // {
589
+ // "time": 1543205083,
590
+ // "channel": "futures.usertrades",
591
+ // "event": "update",
592
+ // "error": null,
593
+ // "result": [
594
+ // {
595
+ // "id": "3335259",
596
+ // "create_time": 1628736848,
597
+ // "create_time_ms": 1628736848321,
598
+ // "contract": "BTC_USD",
599
+ // "order_id": "4872460",
600
+ // "size": 1,
601
+ // "price": "40000.4",
602
+ // "role": "maker"
603
+ // }
604
+ // ]
605
+ // }
606
+ //
607
+ const result = this.safeValue(message, 'result', []);
608
+ const tradesLength = result.length;
609
+ if (tradesLength === 0) {
610
+ return;
611
+ }
612
+ let cachedTrades = this.myTrades;
613
+ if (cachedTrades === undefined) {
614
+ const limit = this.safeInteger(this.options, 'tradesLimit', 1000);
615
+ cachedTrades = new Cache.ArrayCacheBySymbolById(limit);
616
+ this.myTrades = cachedTrades;
617
+ }
618
+ const parsed = this.parseTrades(result);
619
+ const marketIds = {};
620
+ for (let i = 0; i < parsed.length; i++) {
621
+ const trade = parsed[i];
622
+ cachedTrades.append(trade);
623
+ const symbol = trade['symbol'];
624
+ marketIds[symbol] = true;
625
+ }
626
+ const keys = Object.keys(marketIds);
627
+ for (let i = 0; i < keys.length; i++) {
628
+ const market = keys[i];
629
+ const hash = 'myTrades:' + market;
630
+ client.resolve(cachedTrades, hash);
631
+ }
632
+ client.resolve(cachedTrades, 'myTrades');
633
+ }
634
+ async watchBalance(params = {}) {
635
+ /**
636
+ * @method
637
+ * @name gate#watchBalance
638
+ * @description watch balance and get the amount of funds available for trading or funds locked in orders
639
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
640
+ * @returns {object} a [balance structure]{@link https://docs.ccxt.com/#/?id=balance-structure}
641
+ */
642
+ await this.loadMarkets();
643
+ let type = undefined;
644
+ let subType = undefined;
645
+ [type, params] = this.handleMarketTypeAndParams('watchBalance', undefined, params);
646
+ [subType, params] = this.handleSubTypeAndParams('watchBalance', undefined, params);
647
+ const isInverse = (subType === 'inverse');
648
+ const url = this.getUrlByMarketType(type, isInverse);
649
+ const requiresUid = (type !== 'spot');
650
+ const channelType = this.getSupportedMapping(type, {
651
+ 'spot': 'spot',
652
+ 'margin': 'spot',
653
+ 'future': 'futures',
654
+ 'swap': 'futures',
655
+ 'option': 'options',
656
+ });
657
+ const channel = channelType + '.balances';
658
+ const messageHash = type + '.balance';
659
+ return await this.subscribePrivate(url, messageHash, undefined, channel, params, requiresUid);
660
+ }
661
+ handleBalance(client, message) {
662
+ //
663
+ // spot order fill
664
+ // {
665
+ // "time": 1653664351,
666
+ // "channel": "spot.balances",
667
+ // "event": "update",
668
+ // "result": [
669
+ // {
670
+ // "timestamp": "1653664351",
671
+ // "timestamp_ms": "1653664351017",
672
+ // "user": "10406147",
673
+ // "currency": "LTC",
674
+ // "change": "-0.0002000000000000",
675
+ // "total": "0.09986000000000000000",
676
+ // "available": "0.09986000000000000000"
677
+ // }
678
+ // ]
679
+ // }
680
+ //
681
+ // account transfer
682
+ //
683
+ // {
684
+ // "id": null,
685
+ // "time": 1653665088,
686
+ // "channel": "futures.balances",
687
+ // "event": "update",
688
+ // "error": null,
689
+ // "result": [
690
+ // {
691
+ // "balance": 25.035008537,
692
+ // "change": 25,
693
+ // "text": "-",
694
+ // "time": 1653665088,
695
+ // "time_ms": 1653665088286,
696
+ // "type": "dnw",
697
+ // "user": "10406147"
698
+ // }
699
+ // ]
700
+ // }
701
+ //
702
+ // swap order fill
703
+ // {
704
+ // "id": null,
705
+ // "time": 1653665311,
706
+ // "channel": "futures.balances",
707
+ // "event": "update",
708
+ // "error": null,
709
+ // "result": [
710
+ // {
711
+ // "balance": 20.031873037,
712
+ // "change": -0.0031355,
713
+ // "text": "LTC_USDT:165551103273",
714
+ // "time": 1653665311,
715
+ // "time_ms": 1653665311437,
716
+ // "type": "fee",
717
+ // "user": "10406147"
718
+ // }
719
+ // ]
720
+ // }
721
+ //
722
+ const result = this.safeValue(message, 'result', []);
723
+ const timestamp = this.safeInteger(message, 'time_ms');
724
+ this.balance['info'] = result;
725
+ this.balance['timestamp'] = timestamp;
726
+ this.balance['datetime'] = this.iso8601(timestamp);
727
+ for (let i = 0; i < result.length; i++) {
728
+ const rawBalance = result[i];
729
+ const account = this.account();
730
+ const currencyId = this.safeString(rawBalance, 'currency', 'USDT'); // when not present it is USDT
731
+ const code = this.safeCurrencyCode(currencyId);
732
+ account['free'] = this.safeString(rawBalance, 'available');
733
+ account['total'] = this.safeString2(rawBalance, 'total', 'balance');
734
+ this.balance[code] = account;
735
+ }
736
+ const channel = this.safeString(message, 'channel');
737
+ const parts = channel.split('.');
738
+ const rawType = this.safeString(parts, 0);
739
+ const channelType = this.getSupportedMapping(rawType, {
740
+ 'spot': 'spot',
741
+ 'futures': 'swap',
742
+ 'options': 'option',
743
+ });
744
+ const messageHash = channelType + '.balance';
745
+ this.balance = this.safeBalance(this.balance);
746
+ client.resolve(this.balance, messageHash);
747
+ }
748
+ async watchPositions(symbols = undefined, since = undefined, limit = undefined, params = {}) {
749
+ /**
750
+ * @method
751
+ * @name gate#watchPositions
752
+ * @see https://www.gate.io/docs/developers/futures/ws/en/#positions-subscription
753
+ * @see https://www.gate.io/docs/developers/delivery/ws/en/#positions-subscription
754
+ * @see https://www.gate.io/docs/developers/options/ws/en/#positions-channel
755
+ * @description watch all open positions
756
+ * @param {string[]|undefined} symbols list of unified market symbols
757
+ * @param {object} params extra parameters specific to the exchange API endpoint
758
+ * @returns {object[]} a list of [position structure]{@link https://docs.ccxt.com/en/latest/manual.html#position-structure}
759
+ */
760
+ await this.loadMarkets();
761
+ let market = undefined;
762
+ symbols = this.marketSymbols(symbols);
763
+ const payload = ['!' + 'all'];
764
+ if (!this.isEmpty(symbols)) {
765
+ market = this.getMarketFromSymbols(symbols);
766
+ }
767
+ let type = undefined;
768
+ let query = undefined;
769
+ [type, query] = this.handleMarketTypeAndParams('watchPositions', market, params);
770
+ if (type === 'spot') {
771
+ type = 'swap';
772
+ }
773
+ const typeId = this.getSupportedMapping(type, {
774
+ 'future': 'futures',
775
+ 'swap': 'futures',
776
+ 'option': 'options',
777
+ });
778
+ let messageHash = type + ':positions';
779
+ if (!this.isEmpty(symbols)) {
780
+ messageHash += '::' + symbols.join(',');
781
+ }
782
+ const channel = typeId + '.positions';
783
+ let subType = undefined;
784
+ [subType, query] = this.handleSubTypeAndParams('watchPositions', market, query);
785
+ const isInverse = (subType === 'inverse');
786
+ const url = this.getUrlByMarketType(type, isInverse);
787
+ const client = this.client(url);
788
+ this.setPositionsCache(client, type, symbols);
789
+ const fetchPositionsSnapshot = this.handleOption('watchPositions', 'fetchPositionsSnapshot', true);
790
+ const awaitPositionsSnapshot = this.safeValue('watchPositions', 'awaitPositionsSnapshot', true);
791
+ const cache = this.safeValue(this.positions, type);
792
+ if (fetchPositionsSnapshot && awaitPositionsSnapshot && cache === undefined) {
793
+ return await client.future(type + ':fetchPositionsSnapshot');
794
+ }
795
+ const positions = await this.subscribePrivate(url, messageHash, payload, channel, query, true);
796
+ if (this.newUpdates) {
797
+ return positions;
798
+ }
799
+ return this.filterBySymbolsSinceLimit(this.positions[type], symbols, since, limit, true);
800
+ }
801
+ setPositionsCache(client, type, symbols = undefined) {
802
+ if (this.positions === undefined) {
803
+ this.positions = {};
804
+ }
805
+ if (type in this.positions) {
806
+ return;
807
+ }
808
+ const fetchPositionsSnapshot = this.handleOption('watchPositions', 'fetchPositionsSnapshot', false);
809
+ if (fetchPositionsSnapshot) {
810
+ const messageHash = type + ':fetchPositionsSnapshot';
811
+ if (!(messageHash in client.futures)) {
812
+ client.future(messageHash);
813
+ this.spawn(this.loadPositionsSnapshot, client, messageHash, type);
814
+ }
815
+ }
816
+ else {
817
+ this.positions[type] = new Cache.ArrayCacheBySymbolBySide();
818
+ }
819
+ }
820
+ async loadPositionsSnapshot(client, messageHash, type) {
821
+ const positions = await this.fetchPositions(undefined, { 'type': type });
822
+ this.positions[type] = new Cache.ArrayCacheBySymbolBySide();
823
+ const cache = this.positions[type];
824
+ for (let i = 0; i < positions.length; i++) {
825
+ const position = positions[i];
826
+ cache.append(position);
827
+ }
828
+ // don't remove the future from the .futures cache
829
+ const future = client.futures[messageHash];
830
+ future.resolve(cache);
831
+ client.resolve(cache, type + ':position');
832
+ }
833
+ handlePositions(client, message) {
834
+ //
835
+ // {
836
+ // time: 1693158497,
837
+ // time_ms: 1693158497204,
838
+ // channel: 'futures.positions',
839
+ // event: 'update',
840
+ // result: [{
841
+ // contract: 'XRP_USDT',
842
+ // cross_leverage_limit: 0,
843
+ // entry_price: 0.5253,
844
+ // history_pnl: 0,
845
+ // history_point: 0,
846
+ // last_close_pnl: 0,
847
+ // leverage: 0,
848
+ // leverage_max: 50,
849
+ // liq_price: 0.0361,
850
+ // maintenance_rate: 0.01,
851
+ // margin: 4.89609962852,
852
+ // mode: 'single',
853
+ // realised_pnl: -0.0026265,
854
+ // realised_point: 0,
855
+ // risk_limit: 500000,
856
+ // size: 1,
857
+ // time: 1693158497,
858
+ // time_ms: 1693158497195,
859
+ // update_id: 1,
860
+ // user: '10444586'
861
+ // }]
862
+ // }
863
+ //
864
+ const type = this.getMarketTypeByUrl(client.url);
865
+ const data = this.safeValue(message, 'result', []);
866
+ const cache = this.positions[type];
867
+ const newPositions = [];
868
+ for (let i = 0; i < data.length; i++) {
869
+ const rawPosition = data[i];
870
+ const position = this.parsePosition(rawPosition);
871
+ newPositions.push(position);
872
+ cache.append(position);
873
+ }
874
+ const messageHashes = this.findMessageHashes(client, type + ':positions::');
875
+ for (let i = 0; i < messageHashes.length; i++) {
876
+ const messageHash = messageHashes[i];
877
+ const parts = messageHash.split('::');
878
+ const symbolsString = parts[1];
879
+ const symbols = symbolsString.split(',');
880
+ const positions = this.filterByArray(newPositions, 'symbol', symbols, false);
881
+ if (!this.isEmpty(positions)) {
882
+ client.resolve(positions, messageHash);
883
+ }
884
+ }
885
+ client.resolve(newPositions, type + ':positions');
886
+ }
887
+ async watchOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
888
+ /**
889
+ * @method
890
+ * @name gate#watchOrders
891
+ * @description watches information on multiple orders made by the user
892
+ * @param {string} symbol unified market symbol of the market orders were made in
893
+ * @param {int} [since] the earliest time in ms to fetch orders for
894
+ * @param {int} [limit] the maximum number of order structures to retrieve
895
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
896
+ * @param {string} [params.type] spot, margin, swap, future, or option. Required if listening to all symbols.
897
+ * @param {boolean} [params.isInverse] if future, listen to inverse or linear contracts
898
+ * @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure
899
+ */
900
+ await this.loadMarkets();
901
+ let market = undefined;
902
+ if (symbol !== undefined) {
903
+ market = this.market(symbol);
904
+ symbol = market['symbol'];
905
+ }
906
+ let type = undefined;
907
+ let query = undefined;
908
+ [type, query] = this.handleMarketTypeAndParams('watchOrders', market, params);
909
+ const typeId = this.getSupportedMapping(type, {
910
+ 'spot': 'spot',
911
+ 'margin': 'spot',
912
+ 'future': 'futures',
913
+ 'swap': 'futures',
914
+ 'option': 'options',
915
+ });
916
+ const channel = typeId + '.orders';
917
+ let messageHash = 'orders';
918
+ let payload = ['!' + 'all'];
919
+ if (symbol !== undefined) {
920
+ messageHash += ':' + market['id'];
921
+ payload = [market['id']];
922
+ }
923
+ let subType = undefined;
924
+ [subType, query] = this.handleSubTypeAndParams('watchOrders', market, query);
925
+ const isInverse = (subType === 'inverse');
926
+ const url = this.getUrlByMarketType(type, isInverse);
927
+ // uid required for non spot markets
928
+ const requiresUid = (type !== 'spot');
929
+ const orders = await this.subscribePrivate(url, messageHash, payload, channel, query, requiresUid);
930
+ if (this.newUpdates) {
931
+ limit = orders.getLimit(symbol, limit);
932
+ }
933
+ return this.filterBySinceLimit(orders, since, limit, 'timestamp', true);
934
+ }
935
+ handleOrder(client, message) {
936
+ //
937
+ // {
938
+ // "time": 1605175506,
939
+ // "channel": "spot.orders",
940
+ // "event": "update",
941
+ // "result": [
942
+ // {
943
+ // "id": "30784435",
944
+ // "user": 123456,
945
+ // "text": "t-abc",
946
+ // "create_time": "1605175506",
947
+ // "create_time_ms": "1605175506123",
948
+ // "update_time": "1605175506",
949
+ // "update_time_ms": "1605175506123",
950
+ // "event": "put",
951
+ // "currency_pair": "BTC_USDT",
952
+ // "type": "limit",
953
+ // "account": "spot",
954
+ // "side": "sell",
955
+ // "amount": "1",
956
+ // "price": "10001",
957
+ // "time_in_force": "gtc",
958
+ // "left": "1",
959
+ // "filled_total": "0",
960
+ // "fee": "0",
961
+ // "fee_currency": "USDT",
962
+ // "point_fee": "0",
963
+ // "gt_fee": "0",
964
+ // "gt_discount": true,
965
+ // "rebated_fee": "0",
966
+ // "rebated_fee_currency": "USDT"
967
+ // }
968
+ // ]
969
+ // }
970
+ //
971
+ const orders = this.safeValue(message, 'result', []);
972
+ const limit = this.safeInteger(this.options, 'ordersLimit', 1000);
973
+ if (this.orders === undefined) {
974
+ this.orders = new Cache.ArrayCacheBySymbolById(limit);
975
+ }
976
+ const stored = this.orders;
977
+ const marketIds = {};
978
+ const parsedOrders = this.parseOrders(orders);
979
+ for (let i = 0; i < parsedOrders.length; i++) {
980
+ const parsed = parsedOrders[i];
981
+ // inject order status
982
+ const info = this.safeValue(parsed, 'info');
983
+ const event = this.safeString(info, 'event');
984
+ if (event === 'put' || event === 'update') {
985
+ parsed['status'] = 'open';
986
+ }
987
+ else if (event === 'finish') {
988
+ const status = this.safeString(parsed, 'status');
989
+ if (status === undefined) {
990
+ const left = this.safeNumber(info, 'left');
991
+ parsed['status'] = (left === 0) ? 'closed' : 'canceled';
992
+ }
993
+ }
994
+ stored.append(parsed);
995
+ const symbol = parsed['symbol'];
996
+ const market = this.market(symbol);
997
+ marketIds[market['id']] = true;
998
+ }
999
+ const keys = Object.keys(marketIds);
1000
+ for (let i = 0; i < keys.length; i++) {
1001
+ const messageHash = 'orders:' + keys[i];
1002
+ client.resolve(this.orders, messageHash);
1003
+ }
1004
+ client.resolve(this.orders, 'orders');
1005
+ }
1006
+ handleErrorMessage(client, message) {
1007
+ // {
1008
+ // "time": 1647274664,
1009
+ // "channel": "futures.orders",
1010
+ // "event": "subscribe",
1011
+ // "error": { code: 2, message: "unknown contract BTC_USDT_20220318" },
1012
+ // }
1013
+ // {
1014
+ // "time": 1647276473,
1015
+ // "channel": "futures.orders",
1016
+ // "event": "subscribe",
1017
+ // "error": {
1018
+ // "code": 4,
1019
+ // "message": "{"label":"INVALID_KEY","message":"Invalid key provided"}\n"
1020
+ // },
1021
+ // "result": null
1022
+ // }
1023
+ const error = this.safeValue(message, 'error');
1024
+ const code = this.safeInteger(error, 'code');
1025
+ const id = this.safeString(message, 'id');
1026
+ if (id === undefined) {
1027
+ return false;
1028
+ }
1029
+ if (code !== undefined) {
1030
+ const messageHash = this.safeString(client.subscriptions, id);
1031
+ if (messageHash !== undefined) {
1032
+ try {
1033
+ this.throwExactlyMatchedException(this.exceptions['ws']['exact'], code, this.json(message));
1034
+ }
1035
+ catch (e) {
1036
+ client.reject(e, messageHash);
1037
+ if (messageHash in client.subscriptions) {
1038
+ delete client.subscriptions[messageHash];
1039
+ }
1040
+ }
1041
+ }
1042
+ delete client.subscriptions[id];
1043
+ return true;
1044
+ }
1045
+ return false;
1046
+ }
1047
+ handleBalanceSubscription(client, message, subscription = undefined) {
1048
+ this.balance = {};
1049
+ }
1050
+ handleSubscriptionStatus(client, message) {
1051
+ const channel = this.safeString(message, 'channel');
1052
+ const methods = {
1053
+ 'balance': this.handleBalanceSubscription,
1054
+ 'spot.order_book_update': this.handleOrderBookSubscription,
1055
+ 'futures.order_book_update': this.handleOrderBookSubscription,
1056
+ };
1057
+ const id = this.safeString(message, 'id');
1058
+ if (channel in methods) {
1059
+ const subscriptionHash = this.safeString(client.subscriptions, id);
1060
+ const subscription = this.safeValue(client.subscriptions, subscriptionHash);
1061
+ const method = methods[channel];
1062
+ method.call(this, client, message, subscription);
1063
+ }
1064
+ if (id in client.subscriptions) {
1065
+ delete client.subscriptions[id];
1066
+ }
1067
+ }
1068
+ handleMessage(client, message) {
1069
+ //
1070
+ // subscribe
1071
+ // {
1072
+ // "time": 1649062304,
1073
+ // "id": 1649062303,
1074
+ // "channel": "spot.candlesticks",
1075
+ // "event": "subscribe",
1076
+ // "result": { status: "success" }
1077
+ // }
1078
+ //
1079
+ // candlestick
1080
+ // {
1081
+ // "time": 1649063328,
1082
+ // "channel": "spot.candlesticks",
1083
+ // "event": "update",
1084
+ // "result": {
1085
+ // "t": "1649063280",
1086
+ // "v": "58932.23174896",
1087
+ // "c": "45966.47",
1088
+ // "h": "45997.24",
1089
+ // "l": "45966.47",
1090
+ // "o": "45975.18",
1091
+ // "n": "1m_BTC_USDT",
1092
+ // "a": "1.281699"
1093
+ // }
1094
+ // }
1095
+ //
1096
+ // orders
1097
+ // {
1098
+ // "time": 1630654851,
1099
+ // "channel": "options.orders", or futures.orders or spot.orders
1100
+ // "event": "update",
1101
+ // "result": [
1102
+ // {
1103
+ // "contract": "BTC_USDT-20211130-65000-C",
1104
+ // "create_time": 1637897000,
1105
+ // (...)
1106
+ // ]
1107
+ // }
1108
+ // orderbook
1109
+ // {
1110
+ // "time": 1649770525,
1111
+ // "channel": "spot.order_book_update",
1112
+ // "event": "update",
1113
+ // "result": {
1114
+ // "t": 1649770525653,
1115
+ // "e": "depthUpdate",
1116
+ // "E": 1649770525,
1117
+ // "s": "LTC_USDT",
1118
+ // "U": 2622525645,
1119
+ // "u": 2622525665,
1120
+ // "b": [
1121
+ // [Array], [Array],
1122
+ // [Array], [Array],
1123
+ // [Array], [Array],
1124
+ // [Array], [Array],
1125
+ // [Array], [Array],
1126
+ // [Array]
1127
+ // ],
1128
+ // "a": [
1129
+ // [Array], [Array],
1130
+ // [Array], [Array],
1131
+ // [Array], [Array],
1132
+ // [Array], [Array],
1133
+ // [Array], [Array],
1134
+ // [Array]
1135
+ // ]
1136
+ // }
1137
+ // }
1138
+ //
1139
+ // balance update
1140
+ //
1141
+ // {
1142
+ // "time": 1653664351,
1143
+ // "channel": "spot.balances",
1144
+ // "event": "update",
1145
+ // "result": [
1146
+ // {
1147
+ // "timestamp": "1653664351",
1148
+ // "timestamp_ms": "1653664351017",
1149
+ // "user": "10406147",
1150
+ // "currency": "LTC",
1151
+ // "change": "-0.0002000000000000",
1152
+ // "total": "0.09986000000000000000",
1153
+ // "available": "0.09986000000000000000"
1154
+ // }
1155
+ // ]
1156
+ // }
1157
+ //
1158
+ if (this.handleErrorMessage(client, message)) {
1159
+ return;
1160
+ }
1161
+ const event = this.safeString(message, 'event');
1162
+ if (event === 'subscribe') {
1163
+ this.handleSubscriptionStatus(client, message);
1164
+ return;
1165
+ }
1166
+ const channel = this.safeString(message, 'channel', '');
1167
+ const channelParts = channel.split('.');
1168
+ const channelType = this.safeValue(channelParts, 1);
1169
+ const v4Methods = {
1170
+ 'usertrades': this.handleMyTrades,
1171
+ 'candlesticks': this.handleOHLCV,
1172
+ 'orders': this.handleOrder,
1173
+ 'positions': this.handlePositions,
1174
+ 'tickers': this.handleTicker,
1175
+ 'book_ticker': this.handleTicker,
1176
+ 'trades': this.handleTrades,
1177
+ 'order_book_update': this.handleOrderBook,
1178
+ 'balances': this.handleBalance,
1179
+ };
1180
+ const method = this.safeValue(v4Methods, channelType);
1181
+ if (method !== undefined) {
1182
+ method.call(this, client, message);
1183
+ }
1184
+ }
1185
+ getUrlByMarket(market) {
1186
+ const baseUrl = this.urls['api'][market['type']];
1187
+ if (market['contract']) {
1188
+ return market['linear'] ? baseUrl['usdt'] : baseUrl['btc'];
1189
+ }
1190
+ else {
1191
+ return baseUrl;
1192
+ }
1193
+ }
1194
+ getTypeByMarket(market) {
1195
+ if (market['spot']) {
1196
+ return 'spot';
1197
+ }
1198
+ else if (market['option']) {
1199
+ return 'options';
1200
+ }
1201
+ else {
1202
+ return 'futures';
1203
+ }
1204
+ }
1205
+ getUrlByMarketType(type, isInverse = false) {
1206
+ const api = this.urls['api'];
1207
+ const url = api[type];
1208
+ if ((type === 'swap') || (type === 'future')) {
1209
+ return isInverse ? url['btc'] : url['usdt'];
1210
+ }
1211
+ else {
1212
+ return url;
1213
+ }
1214
+ }
1215
+ getMarketTypeByUrl(url) {
1216
+ const findBy = {
1217
+ 'op-': 'option',
1218
+ 'delivery': 'future',
1219
+ 'fx': 'swap',
1220
+ };
1221
+ const keys = Object.keys(findBy);
1222
+ for (let i = 0; i < keys.length; i++) {
1223
+ const key = keys[i];
1224
+ const value = findBy[key];
1225
+ if (url.indexOf(key) >= 0) {
1226
+ return value;
1227
+ }
1228
+ }
1229
+ return 'spot';
1230
+ }
1231
+ requestId() {
1232
+ // their support said that reqid must be an int32, not documented
1233
+ const reqid = this.sum(this.safeInteger(this.options, 'reqid', 0), 1);
1234
+ this.options['reqid'] = reqid;
1235
+ return reqid;
1236
+ }
1237
+ async subscribePublic(url, messageHash, payload, channel, params = {}, subscription = undefined) {
1238
+ const requestId = this.requestId();
1239
+ const time = this.seconds();
1240
+ const request = {
1241
+ 'id': requestId,
1242
+ 'time': time,
1243
+ 'channel': channel,
1244
+ 'event': 'subscribe',
1245
+ 'payload': payload,
1246
+ };
1247
+ if (subscription !== undefined) {
1248
+ const client = this.client(url);
1249
+ if (!(messageHash in client.subscriptions)) {
1250
+ const tempSubscriptionHash = requestId.toString();
1251
+ client.subscriptions[tempSubscriptionHash] = messageHash;
1252
+ }
1253
+ }
1254
+ const message = this.extend(request, params);
1255
+ return await this.watch(url, messageHash, message, messageHash, subscription);
1256
+ }
1257
+ async subscribePublicMultiple(url, messageHashes, payload, channel, params = {}) {
1258
+ const requestId = this.requestId();
1259
+ const time = this.seconds();
1260
+ const request = {
1261
+ 'id': requestId,
1262
+ 'time': time,
1263
+ 'channel': channel,
1264
+ 'event': 'subscribe',
1265
+ 'payload': payload,
1266
+ };
1267
+ const message = this.extend(request, params);
1268
+ return await this.watchMultiple(url, messageHashes, message, messageHashes);
1269
+ }
1270
+ async subscribePrivate(url, messageHash, payload, channel, params, requiresUid = false) {
1271
+ this.checkRequiredCredentials();
1272
+ // uid is required for some subscriptions only so it's not a part of required credentials
1273
+ if (requiresUid) {
1274
+ if (this.uid === undefined || this.uid.length === 0) {
1275
+ throw new errors.ArgumentsRequired(this.id + ' requires uid to subscribe');
1276
+ }
1277
+ const idArray = [this.uid];
1278
+ if (payload === undefined) {
1279
+ payload = idArray;
1280
+ }
1281
+ else {
1282
+ payload = this.arrayConcat(idArray, payload);
1283
+ }
1284
+ }
1285
+ const time = this.seconds();
1286
+ const event = 'subscribe';
1287
+ const signaturePayload = 'channel=' + channel + '&' + 'event=' + event + '&' + 'time=' + time.toString();
1288
+ const signature = this.hmac(this.encode(signaturePayload), this.encode(this.secret), sha512.sha512, 'hex');
1289
+ const auth = {
1290
+ 'method': 'api_key',
1291
+ 'KEY': this.apiKey,
1292
+ 'SIGN': signature,
1293
+ };
1294
+ const requestId = this.requestId();
1295
+ const request = {
1296
+ 'id': requestId,
1297
+ 'time': time,
1298
+ 'channel': channel,
1299
+ 'event': 'subscribe',
1300
+ 'auth': auth,
1301
+ };
1302
+ if (payload !== undefined) {
1303
+ request['payload'] = payload;
1304
+ }
1305
+ const client = this.client(url);
1306
+ if (!(messageHash in client.subscriptions)) {
1307
+ const tempSubscriptionHash = requestId.toString();
1308
+ // in case of authenticationError we will throw
1309
+ client.subscriptions[tempSubscriptionHash] = messageHash;
1310
+ }
1311
+ const message = this.extend(request, params);
1312
+ return await this.watch(url, messageHash, message, messageHash);
1313
+ }
1314
+ }
1315
+
1316
+ module.exports = gate;