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,1052 @@
1
+ 'use strict';
2
+
3
+ var kucoin$1 = require('../kucoin.js');
4
+ var errors = require('../base/errors.js');
5
+ var Cache = require('../base/ws/Cache.js');
6
+
7
+ // ---------------------------------------------------------------------------
8
+ // ---------------------------------------------------------------------------
9
+ class kucoin extends kucoin$1 {
10
+ describe() {
11
+ return this.deepExtend(super.describe(), {
12
+ 'has': {
13
+ 'ws': true,
14
+ 'createOrderWs': false,
15
+ 'editOrderWs': false,
16
+ 'fetchOpenOrdersWs': false,
17
+ 'fetchOrderWs': false,
18
+ 'cancelOrderWs': false,
19
+ 'cancelOrdersWs': false,
20
+ 'cancelAllOrdersWs': false,
21
+ 'watchOrderBook': true,
22
+ 'watchOrders': true,
23
+ 'watchMyTrades': true,
24
+ 'watchTickers': true,
25
+ 'watchTicker': true,
26
+ 'watchTrades': true,
27
+ 'watchTradesForSymbols': true,
28
+ 'watchOrderBookForSymbols': true,
29
+ 'watchBalance': true,
30
+ 'watchOHLCV': true,
31
+ },
32
+ 'options': {
33
+ 'tradesLimit': 1000,
34
+ 'watchTicker': {
35
+ 'name': 'market/snapshot', // market/ticker
36
+ },
37
+ 'watchOrderBook': {
38
+ 'snapshotDelay': 5,
39
+ 'snapshotMaxRetries': 3,
40
+ },
41
+ },
42
+ 'streaming': {
43
+ // kucoin does not support built-in ws protocol-level ping-pong
44
+ // instead it requires a custom json-based text ping-pong
45
+ // https://docs.kucoin.com/#ping
46
+ 'ping': this.ping,
47
+ },
48
+ });
49
+ }
50
+ negotiate(privateChannel, params = {}) {
51
+ const connectId = privateChannel ? 'private' : 'public';
52
+ const urls = this.safeValue(this.options, 'urls', {});
53
+ const spawaned = this.safeValue(urls, connectId);
54
+ if (spawaned !== undefined) {
55
+ return spawaned;
56
+ }
57
+ // we store an awaitable to the url
58
+ // so that multiple calls don't asynchronously
59
+ // fetch different urls and overwrite each other
60
+ urls[connectId] = this.spawn(this.negotiateHelper, privateChannel, params);
61
+ this.options['urls'] = urls;
62
+ return urls[connectId];
63
+ }
64
+ async negotiateHelper(privateChannel, params = {}) {
65
+ let response = undefined;
66
+ const connectId = privateChannel ? 'private' : 'public';
67
+ if (privateChannel) {
68
+ response = await this.privatePostBulletPrivate(params);
69
+ //
70
+ // {
71
+ // "code": "200000",
72
+ // "data": {
73
+ // "instanceServers": [
74
+ // {
75
+ // "pingInterval": 50000,
76
+ // "endpoint": "wss://push-private.kucoin.com/endpoint",
77
+ // "protocol": "websocket",
78
+ // "encrypt": true,
79
+ // "pingTimeout": 10000
80
+ // }
81
+ // ],
82
+ // "token": "2neAiuYvAU61ZDXANAGAsiL4-iAExhsBXZxftpOeh_55i3Ysy2q2LEsEWU64mdzUOPusi34M_wGoSf7iNyEWJ1UQy47YbpY4zVdzilNP-Bj3iXzrjjGlWtiYB9J6i9GjsxUuhPw3BlrzazF6ghq4Lzf7scStOz3KkxjwpsOBCH4=.WNQmhZQeUKIkh97KYgU0Lg=="
83
+ // }
84
+ // }
85
+ //
86
+ }
87
+ else {
88
+ response = await this.publicPostBulletPublic(params);
89
+ }
90
+ const data = this.safeValue(response, 'data', {});
91
+ const instanceServers = this.safeValue(data, 'instanceServers', []);
92
+ const firstInstanceServer = this.safeValue(instanceServers, 0);
93
+ const pingInterval = this.safeInteger(firstInstanceServer, 'pingInterval');
94
+ const endpoint = this.safeString(firstInstanceServer, 'endpoint');
95
+ const token = this.safeString(data, 'token');
96
+ const result = endpoint + '?' + this.urlencode({
97
+ 'token': token,
98
+ 'privateChannel': privateChannel,
99
+ 'connectId': connectId,
100
+ });
101
+ const client = this.client(result);
102
+ client.keepAlive = pingInterval;
103
+ return result;
104
+ }
105
+ requestId() {
106
+ const requestId = this.sum(this.safeInteger(this.options, 'requestId', 0), 1);
107
+ this.options['requestId'] = requestId;
108
+ return requestId;
109
+ }
110
+ async subscribe(url, messageHash, subscriptionHash, params = {}, subscription = undefined) {
111
+ const requestId = this.requestId().toString();
112
+ const request = {
113
+ 'id': requestId,
114
+ 'type': 'subscribe',
115
+ 'topic': subscriptionHash,
116
+ 'response': true,
117
+ };
118
+ const message = this.extend(request, params);
119
+ const client = this.client(url);
120
+ if (!(subscriptionHash in client.subscriptions)) {
121
+ client.subscriptions[requestId] = subscriptionHash;
122
+ }
123
+ return await this.watch(url, messageHash, message, subscriptionHash, subscription);
124
+ }
125
+ async subscribeMultiple(url, messageHashes, topic, subscriptionHashes, params = {}, subscription = undefined) {
126
+ const requestId = this.requestId().toString();
127
+ const request = {
128
+ 'id': requestId,
129
+ 'type': 'subscribe',
130
+ 'topic': topic,
131
+ 'response': true,
132
+ };
133
+ const message = this.extend(request, params);
134
+ const client = this.client(url);
135
+ for (let i = 0; i < subscriptionHashes.length; i++) {
136
+ const subscriptionHash = subscriptionHashes[i];
137
+ if (!(subscriptionHash in client.subscriptions)) {
138
+ client.subscriptions[requestId] = subscriptionHash;
139
+ }
140
+ }
141
+ return await this.watchMultiple(url, messageHashes, message, subscriptionHashes, subscription);
142
+ }
143
+ async watchTicker(symbol, params = {}) {
144
+ /**
145
+ * @method
146
+ * @name kucoin#watchTicker
147
+ * @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
148
+ * @param {string} symbol unified symbol of the market to fetch the ticker for
149
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
150
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
151
+ */
152
+ await this.loadMarkets();
153
+ const market = this.market(symbol);
154
+ symbol = market['symbol'];
155
+ const url = await this.negotiate(false);
156
+ const [method, query] = this.handleOptionAndParams(params, 'watchTicker', 'method', '/market/snapshot');
157
+ const topic = method + ':' + market['id'];
158
+ const messageHash = 'ticker:' + symbol;
159
+ return await this.subscribe(url, messageHash, topic, query);
160
+ }
161
+ async watchTickers(symbols = undefined, params = {}) {
162
+ /**
163
+ * @method
164
+ * @name kucoin#watchTickers
165
+ * @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for all markets of a specific list
166
+ * @param {string[]} symbols unified symbol of the market to fetch the ticker for
167
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
168
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
169
+ */
170
+ await this.loadMarkets();
171
+ symbols = this.marketSymbols(symbols);
172
+ let messageHash = 'tickers';
173
+ if (symbols !== undefined) {
174
+ messageHash = 'tickers::' + symbols.join(',');
175
+ }
176
+ const url = await this.negotiate(false);
177
+ const topic = '/market/ticker:all';
178
+ const tickers = await this.subscribe(url, messageHash, topic, params);
179
+ if (this.newUpdates) {
180
+ return tickers;
181
+ }
182
+ return this.filterByArray(this.tickers, 'symbol', symbols);
183
+ }
184
+ handleTicker(client, message) {
185
+ //
186
+ // market/snapshot
187
+ //
188
+ // updates come in every 2 sec unless there
189
+ // were no changes since the previous update
190
+ //
191
+ // {
192
+ // "data": {
193
+ // "sequence": "1545896669291",
194
+ // "data": {
195
+ // "trading": true,
196
+ // "symbol": "KCS-BTC",
197
+ // "buy": 0.00011,
198
+ // "sell": 0.00012,
199
+ // "sort": 100,
200
+ // "volValue": 3.13851792584, // total
201
+ // "baseCurrency": "KCS",
202
+ // "market": "BTC",
203
+ // "quoteCurrency": "BTC",
204
+ // "symbolCode": "KCS-BTC",
205
+ // "datetime": 1548388122031,
206
+ // "high": 0.00013,
207
+ // "vol": 27514.34842,
208
+ // "low": 0.0001,
209
+ // "changePrice": -1.0e-5,
210
+ // "changeRate": -0.0769,
211
+ // "lastTradedPrice": 0.00012,
212
+ // "board": 0,
213
+ // "mark": 0
214
+ // }
215
+ // },
216
+ // "subject": "trade.snapshot",
217
+ // "topic": "/market/snapshot:KCS-BTC",
218
+ // "type": "message"
219
+ // }
220
+ //
221
+ // market/ticker
222
+ //
223
+ // {
224
+ // "type": "message",
225
+ // "topic": "/market/ticker:BTC-USDT",
226
+ // "subject": "trade.ticker",
227
+ // "data": {
228
+ // "bestAsk": "62163",
229
+ // "bestAskSize": "0.99011388",
230
+ // "bestBid": "62162.9",
231
+ // "bestBidSize": "0.04794181",
232
+ // "price": "62162.9",
233
+ // "sequence": "1621383371852",
234
+ // "size": "0.00832274",
235
+ // "time": 1634641987564
236
+ // }
237
+ // }
238
+ //
239
+ const topic = this.safeString(message, 'topic');
240
+ let market = undefined;
241
+ if (topic !== undefined) {
242
+ const parts = topic.split(':');
243
+ const first = this.safeString(parts, 1);
244
+ let marketId = undefined;
245
+ if (first === 'all') {
246
+ marketId = this.safeString(message, 'subject');
247
+ }
248
+ else {
249
+ marketId = first;
250
+ }
251
+ market = this.safeMarket(marketId, market, '-');
252
+ }
253
+ const data = this.safeValue(message, 'data', {});
254
+ const rawTicker = this.safeValue(data, 'data', data);
255
+ const ticker = this.parseTicker(rawTicker, market);
256
+ const symbol = ticker['symbol'];
257
+ this.tickers[symbol] = ticker;
258
+ const messageHash = 'ticker:' + symbol;
259
+ client.resolve(ticker, messageHash);
260
+ // watchTickers
261
+ client.resolve(ticker, 'tickers');
262
+ const messageHashes = this.findMessageHashes(client, 'tickers::');
263
+ for (let i = 0; i < messageHashes.length; i++) {
264
+ const currentMessageHash = messageHashes[i];
265
+ const parts = currentMessageHash.split('::');
266
+ const symbolsString = parts[1];
267
+ const symbols = symbolsString.split(',');
268
+ const tickers = this.filterByArray(this.tickers, 'symbol', symbols);
269
+ const tickersSymbols = Object.keys(tickers);
270
+ const numTickers = tickersSymbols.length;
271
+ if (numTickers > 0) {
272
+ client.resolve(tickers, currentMessageHash);
273
+ }
274
+ }
275
+ }
276
+ async watchOHLCV(symbol, timeframe = '1m', since = undefined, limit = undefined, params = {}) {
277
+ /**
278
+ * @method
279
+ * @name kucoin#watchOHLCV
280
+ * @description watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
281
+ * @param {string} symbol unified symbol of the market to fetch OHLCV data for
282
+ * @param {string} timeframe the length of time each candle represents
283
+ * @param {int} [since] timestamp in ms of the earliest candle to fetch
284
+ * @param {int} [limit] the maximum amount of candles to fetch
285
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
286
+ * @returns {int[][]} A list of candles ordered as timestamp, open, high, low, close, volume
287
+ */
288
+ await this.loadMarkets();
289
+ const url = await this.negotiate(false);
290
+ const market = this.market(symbol);
291
+ symbol = market['symbol'];
292
+ const period = this.safeString(this.timeframes, timeframe, timeframe);
293
+ const topic = '/market/candles:' + market['id'] + '_' + period;
294
+ const messageHash = 'candles:' + symbol + ':' + timeframe;
295
+ const ohlcv = await this.subscribe(url, messageHash, topic, params);
296
+ if (this.newUpdates) {
297
+ limit = ohlcv.getLimit(symbol, limit);
298
+ }
299
+ return this.filterBySinceLimit(ohlcv, since, limit, 0, true);
300
+ }
301
+ handleOHLCV(client, message) {
302
+ //
303
+ // {
304
+ // "data": {
305
+ // "symbol": "BTC-USDT",
306
+ // "candles": [
307
+ // "1624881240",
308
+ // "34138.8",
309
+ // "34121.6",
310
+ // "34138.8",
311
+ // "34097.9",
312
+ // "3.06097133",
313
+ // "104430.955068564"
314
+ // ],
315
+ // "time": 1624881284466023700
316
+ // },
317
+ // "subject": "trade.candles.update",
318
+ // "topic": "/market/candles:BTC-USDT_1min",
319
+ // "type": "message"
320
+ // }
321
+ //
322
+ const data = this.safeValue(message, 'data', {});
323
+ const marketId = this.safeString(data, 'symbol');
324
+ const candles = this.safeValue(data, 'candles', []);
325
+ const topic = this.safeString(message, 'topic');
326
+ const parts = topic.split('_');
327
+ const interval = this.safeString(parts, 1);
328
+ // use a reverse lookup in a static map instead
329
+ const timeframe = this.findTimeframe(interval);
330
+ const market = this.safeMarket(marketId);
331
+ const symbol = market['symbol'];
332
+ const messageHash = 'candles:' + symbol + ':' + timeframe;
333
+ this.ohlcvs[symbol] = this.safeValue(this.ohlcvs, symbol, {});
334
+ let stored = this.safeValue(this.ohlcvs[symbol], timeframe);
335
+ if (stored === undefined) {
336
+ const limit = this.safeInteger(this.options, 'OHLCVLimit', 1000);
337
+ stored = new Cache.ArrayCacheByTimestamp(limit);
338
+ this.ohlcvs[symbol][timeframe] = stored;
339
+ }
340
+ const ohlcv = this.parseOHLCV(candles, market);
341
+ stored.append(ohlcv);
342
+ client.resolve(stored, messageHash);
343
+ }
344
+ async watchTrades(symbol, since = undefined, limit = undefined, params = {}) {
345
+ /**
346
+ * @method
347
+ * @name kucoin#watchTrades
348
+ * @description get the list of most recent trades for a particular symbol
349
+ * @param {string} symbol unified symbol of the market to fetch trades for
350
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
351
+ * @param {int} [limit] the maximum amount of trades to fetch
352
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
353
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
354
+ */
355
+ return await this.watchTradesForSymbols([symbol], since, limit, params);
356
+ }
357
+ async watchTradesForSymbols(symbols, since = undefined, limit = undefined, params = {}) {
358
+ /**
359
+ * @method
360
+ * @name kucoin#watchTrades
361
+ * @description get the list of most recent trades for a particular symbol
362
+ * @param {string} symbol unified symbol of the market to fetch trades for
363
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
364
+ * @param {int} [limit] the maximum amount of trades to fetch
365
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
366
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
367
+ */
368
+ const symbolsLength = symbols.length;
369
+ if (symbolsLength === 0) {
370
+ throw new errors.ArgumentsRequired(this.id + ' watchTradesForSymbols() requires a non-empty array of symbols');
371
+ }
372
+ await this.loadMarkets();
373
+ symbols = this.marketSymbols(symbols);
374
+ const marketIds = this.marketIds(symbols);
375
+ const url = await this.negotiate(false);
376
+ const messageHashes = [];
377
+ const subscriptionHashes = [];
378
+ const topic = '/market/match:' + marketIds.join(',');
379
+ for (let i = 0; i < symbols.length; i++) {
380
+ const symbol = symbols[i];
381
+ messageHashes.push('trades:' + symbol);
382
+ const marketId = marketIds[i];
383
+ subscriptionHashes.push('/market/match:' + marketId);
384
+ }
385
+ const trades = await this.subscribeMultiple(url, messageHashes, topic, subscriptionHashes, params);
386
+ if (this.newUpdates) {
387
+ const first = this.safeValue(trades, 0);
388
+ const tradeSymbol = this.safeString(first, 'symbol');
389
+ limit = trades.getLimit(tradeSymbol, limit);
390
+ }
391
+ return this.filterBySinceLimit(trades, since, limit, 'timestamp', true);
392
+ }
393
+ handleTrade(client, message) {
394
+ //
395
+ // {
396
+ // "data": {
397
+ // "sequence": "1568787654360",
398
+ // "symbol": "BTC-USDT",
399
+ // "side": "buy",
400
+ // "size": "0.00536577",
401
+ // "price": "9345",
402
+ // "takerOrderId": "5e356c4a9f1a790008f8d921",
403
+ // "time": "1580559434436443257",
404
+ // "type": "match",
405
+ // "makerOrderId": "5e356bffedf0010008fa5d7f",
406
+ // "tradeId": "5e356c4aeefabd62c62a1ece"
407
+ // },
408
+ // "subject": "trade.l3match",
409
+ // "topic": "/market/match:BTC-USDT",
410
+ // "type": "message"
411
+ // }
412
+ //
413
+ const data = this.safeValue(message, 'data', {});
414
+ const trade = this.parseTrade(data);
415
+ const symbol = trade['symbol'];
416
+ const messageHash = 'trades:' + symbol;
417
+ let trades = this.safeValue(this.trades, symbol);
418
+ if (trades === undefined) {
419
+ const limit = this.safeInteger(this.options, 'tradesLimit', 1000);
420
+ trades = new Cache.ArrayCache(limit);
421
+ this.trades[symbol] = trades;
422
+ }
423
+ trades.append(trade);
424
+ client.resolve(trades, messageHash);
425
+ }
426
+ async watchOrderBook(symbol, limit = undefined, params = {}) {
427
+ /**
428
+ * @method
429
+ * @name kucoin#watchOrderBook
430
+ * @description watches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
431
+ * @param {string} symbol unified symbol of the market to fetch the order book for
432
+ * @param {int} [limit] the maximum amount of order book entries to return
433
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
434
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
435
+ */
436
+ //
437
+ // https://docs.kucoin.com/#level-2-market-data
438
+ //
439
+ // 1. After receiving the websocket Level 2 data flow, cache the data.
440
+ // 2. Initiate a REST request to get the snapshot data of Level 2 order book.
441
+ // 3. Playback the cached Level 2 data flow.
442
+ // 4. Apply the new Level 2 data flow to the local snapshot to ensure that
443
+ // the sequence of the new Level 2 update lines up with the sequence of
444
+ // the previous Level 2 data. Discard all the message prior to that
445
+ // sequence, and then playback the change to snapshot.
446
+ // 5. Update the level2 full data based on sequence according to the
447
+ // size. If the price is 0, ignore the messages and update the sequence.
448
+ // If the size=0, update the sequence and remove the price of which the
449
+ // size is 0 out of level 2. Fr other cases, please update the price.
450
+ //
451
+ return await this.watchOrderBookForSymbols([symbol], limit, params);
452
+ }
453
+ async watchOrderBookForSymbols(symbols, limit = undefined, params = {}) {
454
+ /**
455
+ * @method
456
+ * @name kucoin#watchOrderBookForSymbols
457
+ * @description watches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
458
+ * @param {string[]} symbols unified array of symbols
459
+ * @param {int} [limit] the maximum amount of order book entries to return
460
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
461
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
462
+ */
463
+ const symbolsLength = symbols.length;
464
+ if (symbolsLength === 0) {
465
+ throw new errors.ArgumentsRequired(this.id + ' watchOrderBookForSymbols() requires a non-empty array of symbols');
466
+ }
467
+ if (limit !== undefined) {
468
+ if ((limit !== 20) && (limit !== 100)) {
469
+ throw new errors.ExchangeError(this.id + " watchOrderBook 'limit' argument must be undefined, 20 or 100");
470
+ }
471
+ }
472
+ await this.loadMarkets();
473
+ symbols = this.marketSymbols(symbols);
474
+ const marketIds = this.marketIds(symbols);
475
+ const url = await this.negotiate(false);
476
+ const topic = '/market/level2:' + marketIds.join(',');
477
+ const messageHashes = [];
478
+ const subscriptionHashes = [];
479
+ for (let i = 0; i < symbols.length; i++) {
480
+ const symbol = symbols[i];
481
+ messageHashes.push('orderbook:' + symbol);
482
+ const marketId = marketIds[i];
483
+ subscriptionHashes.push('/market/level2:' + marketId);
484
+ }
485
+ const subscription = {
486
+ 'method': this.handleOrderBookSubscription,
487
+ 'symbols': symbols,
488
+ 'limit': limit,
489
+ };
490
+ const orderbook = await this.subscribeMultiple(url, messageHashes, topic, subscriptionHashes, params, subscription);
491
+ return orderbook.limit();
492
+ }
493
+ handleOrderBook(client, message) {
494
+ //
495
+ // initial snapshot is fetched with ccxt's fetchOrderBook
496
+ // the feed does not include a snapshot, just the deltas
497
+ //
498
+ // {
499
+ // "type":"message",
500
+ // "topic":"/market/level2:BTC-USDT",
501
+ // "subject":"trade.l2update",
502
+ // "data":{
503
+ // "sequenceStart":1545896669105,
504
+ // "sequenceEnd":1545896669106,
505
+ // "symbol":"BTC-USDT",
506
+ // "changes": {
507
+ // "asks": [["6","1","1545896669105"]], // price, size, sequence
508
+ // "bids": [["4","1","1545896669106"]]
509
+ // }
510
+ // }
511
+ // }
512
+ //
513
+ const data = this.safeValue(message, 'data');
514
+ const marketId = this.safeString(data, 'symbol');
515
+ const symbol = this.safeSymbol(marketId, undefined, '-');
516
+ const messageHash = 'orderbook:' + symbol;
517
+ const storedOrderBook = this.orderbooks[symbol];
518
+ const nonce = this.safeInteger(storedOrderBook, 'nonce');
519
+ const deltaEnd = this.safeInteger(data, 'sequenceEnd');
520
+ if (nonce === undefined) {
521
+ const cacheLength = storedOrderBook.cache.length;
522
+ const topic = this.safeString(message, 'topic');
523
+ const topicParts = topic.split(':');
524
+ const topicSymbol = this.safeString(topicParts, 1);
525
+ const topicChannel = this.safeString(topicParts, 0);
526
+ const subscriptions = Object.keys(client.subscriptions);
527
+ let subscription = undefined;
528
+ for (let i = 0; i < subscriptions.length; i++) {
529
+ const key = subscriptions[i];
530
+ if ((key.indexOf(topicSymbol) >= 0) && (key.indexOf(topicChannel) >= 0)) {
531
+ subscription = client.subscriptions[key];
532
+ break;
533
+ }
534
+ }
535
+ const limit = this.safeInteger(subscription, 'limit');
536
+ const snapshotDelay = this.handleOption('watchOrderBook', 'snapshotDelay', 5);
537
+ if (cacheLength === snapshotDelay) {
538
+ this.spawn(this.loadOrderBook, client, messageHash, symbol, limit);
539
+ }
540
+ storedOrderBook.cache.push(data);
541
+ return;
542
+ }
543
+ else if (nonce >= deltaEnd) {
544
+ return;
545
+ }
546
+ this.handleDelta(storedOrderBook, data);
547
+ client.resolve(storedOrderBook, messageHash);
548
+ }
549
+ getCacheIndex(orderbook, cache) {
550
+ const firstDelta = this.safeValue(cache, 0);
551
+ const nonce = this.safeInteger(orderbook, 'nonce');
552
+ const firstDeltaStart = this.safeInteger(firstDelta, 'sequenceStart');
553
+ if (nonce < firstDeltaStart - 1) {
554
+ return -1;
555
+ }
556
+ for (let i = 0; i < cache.length; i++) {
557
+ const delta = cache[i];
558
+ const deltaStart = this.safeInteger(delta, 'sequenceStart');
559
+ const deltaEnd = this.safeInteger(delta, 'sequenceEnd');
560
+ if ((nonce >= deltaStart - 1) && (nonce < deltaEnd)) {
561
+ return i;
562
+ }
563
+ }
564
+ return cache.length;
565
+ }
566
+ handleDelta(orderbook, delta) {
567
+ orderbook['nonce'] = this.safeInteger(delta, 'sequenceEnd');
568
+ const timestamp = this.safeInteger(delta, 'time');
569
+ orderbook['timestamp'] = timestamp;
570
+ orderbook['datetime'] = this.iso8601(timestamp);
571
+ const changes = this.safeValue(delta, 'changes');
572
+ const bids = this.safeValue(changes, 'bids', []);
573
+ const asks = this.safeValue(changes, 'asks', []);
574
+ const storedBids = orderbook['bids'];
575
+ const storedAsks = orderbook['asks'];
576
+ this.handleBidAsks(storedBids, bids);
577
+ this.handleBidAsks(storedAsks, asks);
578
+ }
579
+ handleBidAsks(bookSide, bidAsks) {
580
+ for (let i = 0; i < bidAsks.length; i++) {
581
+ const bidAsk = this.parseBidAsk(bidAsks[i]);
582
+ bookSide.storeArray(bidAsk);
583
+ }
584
+ }
585
+ handleOrderBookSubscription(client, message, subscription) {
586
+ const limit = this.safeInteger(subscription, 'limit');
587
+ const symbols = this.safeValue(subscription, 'symbols');
588
+ if (symbols === undefined) {
589
+ const symbol = this.safeString(subscription, 'symbol');
590
+ this.orderbooks[symbol] = this.orderBook({}, limit);
591
+ }
592
+ else {
593
+ for (let i = 0; i < symbols.length; i++) {
594
+ const symbol = symbols[i];
595
+ this.orderbooks[symbol] = this.orderBook({}, limit);
596
+ }
597
+ }
598
+ // moved snapshot initialization to handleOrderBook to fix
599
+ // https://github.com/ccxt/ccxt/issues/6820
600
+ // the general idea is to fetch the snapshot after the first delta
601
+ // but not before, because otherwise we cannot synchronize the feed
602
+ }
603
+ handleSubscriptionStatus(client, message) {
604
+ //
605
+ // {
606
+ // "id": "1578090438322",
607
+ // "type": "ack"
608
+ // }
609
+ //
610
+ const id = this.safeString(message, 'id');
611
+ const subscriptionHash = this.safeString(client.subscriptions, id);
612
+ const subscription = this.safeValue(client.subscriptions, subscriptionHash);
613
+ delete client.subscriptions[id];
614
+ const method = this.safeValue(subscription, 'method');
615
+ if (method !== undefined) {
616
+ method.call(this, client, message, subscription);
617
+ }
618
+ }
619
+ handleSystemStatus(client, message) {
620
+ //
621
+ // todo: answer the question whether handleSystemStatus should be renamed
622
+ // and unified as handleStatus for any usage pattern that
623
+ // involves system status and maintenance updates
624
+ //
625
+ // {
626
+ // "id": "1578090234088", // connectId
627
+ // "type": "welcome",
628
+ // }
629
+ //
630
+ return message;
631
+ }
632
+ async watchOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
633
+ /**
634
+ * @method
635
+ * @name kucoin#watchOrders
636
+ * @description watches information on multiple orders made by the user
637
+ * @param {string} symbol unified market symbol of the market orders were made in
638
+ * @param {int} [since] the earliest time in ms to fetch orders for
639
+ * @param {int} [limit] the maximum number of order structures to retrieve
640
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
641
+ * @param {boolean} [params.stop] trigger orders are watched if true
642
+ * @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
643
+ */
644
+ await this.loadMarkets();
645
+ const stop = this.safeValue2(params, 'stop', 'trigger');
646
+ params = this.omit(params, ['stop', 'trigger']);
647
+ const url = await this.negotiate(true);
648
+ const topic = stop ? '/spotMarket/advancedOrders' : '/spotMarket/tradeOrders';
649
+ const request = {
650
+ 'privateChannel': true,
651
+ };
652
+ let messageHash = 'orders';
653
+ if (symbol !== undefined) {
654
+ const market = this.market(symbol);
655
+ symbol = market['symbol'];
656
+ messageHash = messageHash + ':' + symbol;
657
+ }
658
+ const orders = await this.subscribe(url, messageHash, topic, this.extend(request, params));
659
+ if (this.newUpdates) {
660
+ limit = orders.getLimit(symbol, limit);
661
+ }
662
+ return this.filterBySymbolSinceLimit(orders, symbol, since, limit, true);
663
+ }
664
+ parseWsOrderStatus(status) {
665
+ const statuses = {
666
+ 'open': 'open',
667
+ 'filled': 'closed',
668
+ 'match': 'open',
669
+ 'update': 'open',
670
+ 'canceled': 'canceled',
671
+ 'cancel': 'canceled',
672
+ 'TRIGGERED': 'triggered',
673
+ };
674
+ return this.safeString(statuses, status, status);
675
+ }
676
+ parseWsOrder(order, market = undefined) {
677
+ //
678
+ // /spotMarket/tradeOrders
679
+ //
680
+ // {
681
+ // "symbol": "XCAD-USDT",
682
+ // "orderType": "limit",
683
+ // "side": "buy",
684
+ // "orderId": "6249167327218b000135e749",
685
+ // "type": "canceled",
686
+ // "orderTime": 1648957043065280224,
687
+ // "size": "100.452",
688
+ // "filledSize": "0",
689
+ // "price": "2.9635",
690
+ // "clientOid": "buy-XCAD-USDT-1648957043010159",
691
+ // "remainSize": "0",
692
+ // "status": "done",
693
+ // "ts": 1648957054031001037
694
+ // }
695
+ //
696
+ // /spotMarket/advancedOrders
697
+ //
698
+ // {
699
+ // "createdAt": 1589789942337,
700
+ // "orderId": "5ec244f6a8a75e0009958237",
701
+ // "orderPrice": "0.00062",
702
+ // "orderType": "stop",
703
+ // "side": "sell",
704
+ // "size": "1",
705
+ // "stop": "entry",
706
+ // "stopPrice": "0.00062",
707
+ // "symbol": "KCS-BTC",
708
+ // "tradeType": "TRADE",
709
+ // "triggerSuccess": true,
710
+ // "ts": 1589790121382281286,
711
+ // "type": "triggered"
712
+ // }
713
+ //
714
+ const rawType = this.safeString(order, 'type');
715
+ let status = this.parseWsOrderStatus(rawType);
716
+ const timestamp = this.safeInteger2(order, 'orderTime', 'createdAt');
717
+ const marketId = this.safeString(order, 'symbol');
718
+ market = this.safeMarket(marketId, market);
719
+ const triggerPrice = this.safeString(order, 'stopPrice');
720
+ const triggerSuccess = this.safeValue(order, 'triggerSuccess');
721
+ const triggerFail = (triggerSuccess !== true) && (triggerSuccess !== undefined); // TODO: updated to triggerSuccess === False once transpiler transpiles it correctly
722
+ if ((status === 'triggered') && triggerFail) {
723
+ status = 'canceled';
724
+ }
725
+ return this.safeOrder({
726
+ 'info': order,
727
+ 'symbol': market['symbol'],
728
+ 'id': this.safeString(order, 'orderId'),
729
+ 'clientOrderId': this.safeString(order, 'clientOid'),
730
+ 'timestamp': timestamp,
731
+ 'datetime': this.iso8601(timestamp),
732
+ 'lastTradeTimestamp': undefined,
733
+ 'type': this.safeStringLower(order, 'orderType'),
734
+ 'timeInForce': undefined,
735
+ 'postOnly': undefined,
736
+ 'side': this.safeStringLower(order, 'side'),
737
+ 'price': this.safeString2(order, 'price', 'orderPrice'),
738
+ 'stopPrice': triggerPrice,
739
+ 'triggerPrice': triggerPrice,
740
+ 'amount': this.safeString(order, 'size'),
741
+ 'cost': undefined,
742
+ 'average': undefined,
743
+ 'filled': this.safeString(order, 'filledSize'),
744
+ 'remaining': undefined,
745
+ 'status': status,
746
+ 'fee': undefined,
747
+ 'trades': undefined,
748
+ }, market);
749
+ }
750
+ handleOrder(client, message) {
751
+ //
752
+ // Trigger Orders
753
+ //
754
+ // {
755
+ // "createdAt": 1692745706437,
756
+ // "error": "Balance insufficient!", // not always there
757
+ // "orderId": "vs86kp757vlda6ni003qs70v",
758
+ // "orderPrice": "0.26",
759
+ // "orderType": "stop",
760
+ // "side": "sell",
761
+ // "size": "5",
762
+ // "stop": "loss",
763
+ // "stopPrice": "0.26",
764
+ // "symbol": "ADA-USDT",
765
+ // "tradeType": "TRADE",
766
+ // "triggerSuccess": false, // not always there
767
+ // "ts": "1692745706442929298",
768
+ // "type": "open"
769
+ // }
770
+ //
771
+ const messageHash = 'orders';
772
+ const data = this.safeValue(message, 'data');
773
+ const parsed = this.parseWsOrder(data);
774
+ const symbol = this.safeString(parsed, 'symbol');
775
+ const orderId = this.safeString(parsed, 'id');
776
+ const triggerPrice = this.safeValue(parsed, 'triggerPrice');
777
+ const isTriggerOrder = (triggerPrice !== undefined);
778
+ if (this.orders === undefined) {
779
+ const limit = this.safeInteger(this.options, 'ordersLimit', 1000);
780
+ this.orders = new Cache.ArrayCacheBySymbolById(limit);
781
+ this.triggerOrders = new Cache.ArrayCacheBySymbolById(limit);
782
+ }
783
+ const cachedOrders = isTriggerOrder ? this.triggerOrders : this.orders;
784
+ const orders = this.safeValue(cachedOrders.hashmap, symbol, {});
785
+ const order = this.safeValue(orders, orderId);
786
+ if (order !== undefined) {
787
+ // todo add others to calculate average etc
788
+ if (order['status'] === 'closed') {
789
+ parsed['status'] = 'closed';
790
+ }
791
+ }
792
+ cachedOrders.append(parsed);
793
+ client.resolve(cachedOrders, messageHash);
794
+ const symbolSpecificMessageHash = messageHash + ':' + symbol;
795
+ client.resolve(cachedOrders, symbolSpecificMessageHash);
796
+ }
797
+ async watchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
798
+ /**
799
+ * @method
800
+ * @name kucoin#watchMyTrades
801
+ * @description watches information on multiple trades made by the user
802
+ * @param {string} symbol unified market symbol of the market trades were made in
803
+ * @param {int} [since] the earliest time in ms to fetch trades for
804
+ * @param {int} [limit] the maximum number of trade structures to retrieve
805
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
806
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure
807
+ */
808
+ await this.loadMarkets();
809
+ const url = await this.negotiate(true);
810
+ const topic = '/spot/tradeFills';
811
+ const request = {
812
+ 'privateChannel': true,
813
+ };
814
+ let messageHash = 'myTrades';
815
+ if (symbol !== undefined) {
816
+ const market = this.market(symbol);
817
+ symbol = market['symbol'];
818
+ messageHash = messageHash + ':' + market['symbol'];
819
+ }
820
+ const trades = await this.subscribe(url, messageHash, topic, this.extend(request, params));
821
+ if (this.newUpdates) {
822
+ limit = trades.getLimit(symbol, limit);
823
+ }
824
+ return this.filterBySymbolSinceLimit(trades, symbol, since, limit, true);
825
+ }
826
+ handleMyTrade(client, message) {
827
+ let trades = this.myTrades;
828
+ if (trades === undefined) {
829
+ const limit = this.safeInteger(this.options, 'tradesLimit', 1000);
830
+ trades = new Cache.ArrayCacheBySymbolById(limit);
831
+ }
832
+ const data = this.safeValue(message, 'data');
833
+ const parsed = this.parseWsTrade(data);
834
+ trades.append(parsed);
835
+ const messageHash = 'myTrades';
836
+ client.resolve(trades, messageHash);
837
+ const symbolSpecificMessageHash = messageHash + ':' + parsed['symbol'];
838
+ client.resolve(trades, symbolSpecificMessageHash);
839
+ }
840
+ parseWsTrade(trade, market = undefined) {
841
+ //
842
+ // {
843
+ // "fee": 0.00262148,
844
+ // "feeCurrency": "USDT",
845
+ // "feeRate": 0.001,
846
+ // "orderId": "62417436b29df8000183df2f",
847
+ // "orderType": "market",
848
+ // "price": 131.074,
849
+ // "side": "sell",
850
+ // "size": 0.02,
851
+ // "symbol": "LTC-USDT",
852
+ // "time": "1648456758734571745",
853
+ // "tradeId": "624174362e113d2f467b3043"
854
+ // }
855
+ //
856
+ const marketId = this.safeString(trade, 'symbol');
857
+ market = this.safeMarket(marketId, market, '-');
858
+ const symbol = market['symbol'];
859
+ const type = this.safeString(trade, 'orderType');
860
+ const side = this.safeString(trade, 'side');
861
+ const tradeId = this.safeString(trade, 'tradeId');
862
+ const price = this.safeString(trade, 'price');
863
+ const amount = this.safeString(trade, 'size');
864
+ const order = this.safeString(trade, 'orderId');
865
+ const timestamp = this.safeIntegerProduct(trade, 'time', 0.000001);
866
+ const feeCurrency = market['quote'];
867
+ const feeRate = this.safeString(trade, 'feeRate');
868
+ const feeCost = this.safeString(trade, 'fee');
869
+ const fee = {
870
+ 'cost': feeCost,
871
+ 'rate': feeRate,
872
+ 'currency': feeCurrency,
873
+ };
874
+ return this.safeTrade({
875
+ 'info': trade,
876
+ 'timestamp': timestamp,
877
+ 'datetime': this.iso8601(timestamp),
878
+ 'symbol': symbol,
879
+ 'id': tradeId,
880
+ 'order': order,
881
+ 'type': type,
882
+ 'takerOrMaker': undefined,
883
+ 'side': side,
884
+ 'price': price,
885
+ 'amount': amount,
886
+ 'cost': undefined,
887
+ 'fee': fee,
888
+ }, market);
889
+ }
890
+ async watchBalance(params = {}) {
891
+ /**
892
+ * @method
893
+ * @name kucoin#watchBalance
894
+ * @description watch balance and get the amount of funds available for trading or funds locked in orders
895
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
896
+ * @returns {object} a [balance structure]{@link https://docs.ccxt.com/#/?id=balance-structure}
897
+ */
898
+ await this.loadMarkets();
899
+ const url = await this.negotiate(true);
900
+ const topic = '/account/balance';
901
+ const request = {
902
+ 'privateChannel': true,
903
+ };
904
+ const messageHash = 'balance';
905
+ return await this.subscribe(url, messageHash, topic, this.extend(request, params));
906
+ }
907
+ handleBalance(client, message) {
908
+ //
909
+ // {
910
+ // "id":"6217a451294b030001e3a26a",
911
+ // "type":"message",
912
+ // "topic":"/account/balance",
913
+ // "userId":"6217707c52f97f00012a67db",
914
+ // "channelType":"private",
915
+ // "subject":"account.balance",
916
+ // "data":{
917
+ // "accountId":"62177fe67810720001db2f18",
918
+ // "available":"89",
919
+ // "availableChange":"-30",
920
+ // "currency":"USDT",
921
+ // "hold":"0",
922
+ // "holdChange":"0",
923
+ // "relationContext":{
924
+ // },
925
+ // "relationEvent":"main.transfer",
926
+ // "relationEventId":"6217a451294b030001e3a26a",
927
+ // "time":"1645716561816",
928
+ // "total":"89"
929
+ // }
930
+ //
931
+ const data = this.safeValue(message, 'data', {});
932
+ const messageHash = 'balance';
933
+ const currencyId = this.safeString(data, 'currency');
934
+ const relationEvent = this.safeString(data, 'relationEvent');
935
+ let requestAccountType = undefined;
936
+ if (relationEvent !== undefined) {
937
+ const relationEventParts = relationEvent.split('.');
938
+ requestAccountType = this.safeString(relationEventParts, 0);
939
+ }
940
+ const selectedType = this.safeString2(this.options, 'watchBalance', 'defaultType', 'trade'); // trade, main, margin or other
941
+ const accountsByType = this.safeValue(this.options, 'accountsByType');
942
+ const uniformType = this.safeString(accountsByType, requestAccountType, 'trade');
943
+ if (!(uniformType in this.balance)) {
944
+ this.balance[uniformType] = {};
945
+ }
946
+ this.balance[uniformType]['info'] = data;
947
+ const timestamp = this.safeInteger(data, 'time');
948
+ this.balance[uniformType]['timestamp'] = timestamp;
949
+ this.balance[uniformType]['datetime'] = this.iso8601(timestamp);
950
+ const code = this.safeCurrencyCode(currencyId);
951
+ const account = this.account();
952
+ account['free'] = this.safeString(data, 'available');
953
+ account['used'] = this.safeString(data, 'hold');
954
+ account['total'] = this.safeString(data, 'total');
955
+ this.balance[uniformType][code] = account;
956
+ this.balance[uniformType] = this.safeBalance(this.balance[uniformType]);
957
+ if (uniformType === selectedType) {
958
+ client.resolve(this.balance[uniformType], messageHash);
959
+ }
960
+ }
961
+ handleSubject(client, message) {
962
+ //
963
+ // {
964
+ // "type":"message",
965
+ // "topic":"/market/level2:BTC-USDT",
966
+ // "subject":"trade.l2update",
967
+ // "data":{
968
+ // "sequenceStart":1545896669105,
969
+ // "sequenceEnd":1545896669106,
970
+ // "symbol":"BTC-USDT",
971
+ // "changes": {
972
+ // "asks": [["6","1","1545896669105"]], // price, size, sequence
973
+ // "bids": [["4","1","1545896669106"]]
974
+ // }
975
+ // }
976
+ // }
977
+ //
978
+ const topic = this.safeString(message, 'topic');
979
+ if (topic === '/market/ticker:all') {
980
+ return this.handleTicker(client, message);
981
+ }
982
+ const subject = this.safeString(message, 'subject');
983
+ const methods = {
984
+ 'trade.l2update': this.handleOrderBook,
985
+ 'trade.ticker': this.handleTicker,
986
+ 'trade.snapshot': this.handleTicker,
987
+ 'trade.l3match': this.handleTrade,
988
+ 'trade.candles.update': this.handleOHLCV,
989
+ 'account.balance': this.handleBalance,
990
+ '/spot/tradeFills': this.handleMyTrade,
991
+ 'orderChange': this.handleOrder,
992
+ 'stopOrder': this.handleOrder,
993
+ };
994
+ const method = this.safeValue(methods, subject);
995
+ if (method === undefined) {
996
+ return message;
997
+ }
998
+ else {
999
+ return method.call(this, client, message);
1000
+ }
1001
+ }
1002
+ ping(client) {
1003
+ // kucoin does not support built-in ws protocol-level ping-pong
1004
+ // instead it requires a custom json-based text ping-pong
1005
+ // https://docs.kucoin.com/#ping
1006
+ const id = this.requestId().toString();
1007
+ return {
1008
+ 'id': id,
1009
+ 'type': 'ping',
1010
+ };
1011
+ }
1012
+ handlePong(client, message) {
1013
+ client.lastPong = this.milliseconds();
1014
+ // https://docs.kucoin.com/#ping
1015
+ }
1016
+ handleErrorMessage(client, message) {
1017
+ //
1018
+ // {
1019
+ // "id": "1",
1020
+ // "type": "error",
1021
+ // "code": 415,
1022
+ // "data": "type is not supported"
1023
+ // }
1024
+ //
1025
+ const data = this.safeString(message, 'data', '');
1026
+ if (data === 'token is expired') {
1027
+ let type = 'public';
1028
+ if (client.url.indexOf('connectId=private') >= 0) {
1029
+ type = 'private';
1030
+ }
1031
+ this.options['urls'][type] = undefined;
1032
+ }
1033
+ this.handleErrors(undefined, undefined, client.url, undefined, undefined, data, message, undefined, undefined);
1034
+ }
1035
+ handleMessage(client, message) {
1036
+ const type = this.safeString(message, 'type');
1037
+ const methods = {
1038
+ // 'heartbeat': this.handleHeartbeat,
1039
+ 'welcome': this.handleSystemStatus,
1040
+ 'ack': this.handleSubscriptionStatus,
1041
+ 'message': this.handleSubject,
1042
+ 'pong': this.handlePong,
1043
+ 'error': this.handleErrorMessage,
1044
+ };
1045
+ const method = this.safeValue(methods, type);
1046
+ if (method !== undefined) {
1047
+ return method.call(this, client, message);
1048
+ }
1049
+ }
1050
+ }
1051
+
1052
+ module.exports = kucoin;