ccxt 4.2.10 → 4.2.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (383) hide show
  1. package/README.md +5 -5
  2. package/build.sh +4 -4
  3. package/dist/ccxt.browser.js +695 -282
  4. package/dist/ccxt.browser.min.js +3 -3
  5. package/dist/cjs/_virtual/agent.js +7 -0
  6. package/dist/cjs/_virtual/parse-proxy-response.js +7 -0
  7. package/dist/cjs/_virtual/promisify.js +7 -0
  8. package/dist/cjs/ccxt.js +1 -1
  9. package/dist/cjs/js/ccxt.js +474 -0
  10. package/dist/cjs/js/src/abstract/ace.js +9 -0
  11. package/dist/cjs/js/src/abstract/alpaca.js +9 -0
  12. package/dist/cjs/js/src/abstract/ascendex.js +9 -0
  13. package/dist/cjs/js/src/abstract/bigone.js +9 -0
  14. package/dist/cjs/js/src/abstract/binance.js +9 -0
  15. package/dist/cjs/js/src/abstract/bingx.js +9 -0
  16. package/dist/cjs/js/src/abstract/bit2c.js +9 -0
  17. package/dist/cjs/js/src/abstract/bitbank.js +9 -0
  18. package/dist/cjs/js/src/abstract/bitbns.js +9 -0
  19. package/dist/cjs/js/src/abstract/bitfinex.js +9 -0
  20. package/dist/cjs/js/src/abstract/bitfinex2.js +9 -0
  21. package/dist/cjs/js/src/abstract/bitflyer.js +9 -0
  22. package/dist/cjs/js/src/abstract/bitforex.js +9 -0
  23. package/dist/cjs/js/src/abstract/bitget.js +9 -0
  24. package/dist/cjs/js/src/abstract/bithumb.js +9 -0
  25. package/dist/cjs/js/src/abstract/bitmart.js +9 -0
  26. package/dist/cjs/js/src/abstract/bitmex.js +9 -0
  27. package/dist/cjs/js/src/abstract/bitopro.js +9 -0
  28. package/dist/cjs/js/src/abstract/bitpanda.js +9 -0
  29. package/dist/cjs/js/src/abstract/bitrue.js +9 -0
  30. package/dist/cjs/js/src/abstract/bitso.js +9 -0
  31. package/dist/cjs/js/src/abstract/bitstamp.js +9 -0
  32. package/dist/cjs/js/src/abstract/bitteam.js +9 -0
  33. package/dist/cjs/js/src/abstract/bitvavo.js +9 -0
  34. package/dist/cjs/js/src/abstract/bl3p.js +9 -0
  35. package/dist/cjs/js/src/abstract/blockchaincom.js +9 -0
  36. package/dist/cjs/js/src/abstract/btcalpha.js +9 -0
  37. package/dist/cjs/js/src/abstract/btcbox.js +9 -0
  38. package/dist/cjs/js/src/abstract/btcmarkets.js +9 -0
  39. package/dist/cjs/js/src/abstract/btcturk.js +9 -0
  40. package/dist/cjs/js/src/abstract/bybit.js +9 -0
  41. package/dist/cjs/js/src/abstract/cex.js +9 -0
  42. package/dist/cjs/js/src/abstract/coinbase.js +9 -0
  43. package/dist/cjs/js/src/abstract/coinbasepro.js +9 -0
  44. package/dist/cjs/js/src/abstract/coincheck.js +9 -0
  45. package/dist/cjs/js/src/abstract/coinex.js +9 -0
  46. package/dist/cjs/js/src/abstract/coinlist.js +9 -0
  47. package/dist/cjs/js/src/abstract/coinmate.js +9 -0
  48. package/dist/cjs/js/src/abstract/coinone.js +9 -0
  49. package/dist/cjs/js/src/abstract/coinsph.js +9 -0
  50. package/dist/cjs/js/src/abstract/coinspot.js +9 -0
  51. package/dist/cjs/js/src/abstract/cryptocom.js +9 -0
  52. package/dist/cjs/js/src/abstract/currencycom.js +9 -0
  53. package/dist/cjs/js/src/abstract/delta.js +9 -0
  54. package/dist/cjs/js/src/abstract/deribit.js +9 -0
  55. package/dist/cjs/js/src/abstract/digifinex.js +9 -0
  56. package/dist/cjs/js/src/abstract/exmo.js +9 -0
  57. package/dist/cjs/js/src/abstract/gate.js +9 -0
  58. package/dist/cjs/js/src/abstract/gemini.js +9 -0
  59. package/dist/cjs/js/src/abstract/hitbtc.js +9 -0
  60. package/dist/cjs/js/src/abstract/hollaex.js +9 -0
  61. package/dist/cjs/js/src/abstract/htx.js +9 -0
  62. package/dist/cjs/js/src/abstract/huobijp.js +9 -0
  63. package/dist/cjs/js/src/abstract/idex.js +9 -0
  64. package/dist/cjs/js/src/abstract/independentreserve.js +9 -0
  65. package/dist/cjs/js/src/abstract/indodax.js +9 -0
  66. package/dist/cjs/js/src/abstract/kraken.js +9 -0
  67. package/dist/cjs/js/src/abstract/krakenfutures.js +9 -0
  68. package/dist/cjs/js/src/abstract/kucoin.js +9 -0
  69. package/dist/cjs/js/src/abstract/kucoinfutures.js +9 -0
  70. package/dist/cjs/js/src/abstract/kuna.js +9 -0
  71. package/dist/cjs/js/src/abstract/latoken.js +9 -0
  72. package/dist/cjs/js/src/abstract/lbank.js +9 -0
  73. package/dist/cjs/js/src/abstract/luno.js +9 -0
  74. package/dist/cjs/js/src/abstract/lykke.js +9 -0
  75. package/dist/cjs/js/src/abstract/mercado.js +9 -0
  76. package/dist/cjs/js/src/abstract/mexc.js +9 -0
  77. package/dist/cjs/js/src/abstract/ndax.js +9 -0
  78. package/dist/cjs/js/src/abstract/novadax.js +9 -0
  79. package/dist/cjs/js/src/abstract/oceanex.js +9 -0
  80. package/dist/cjs/js/src/abstract/okcoin.js +9 -0
  81. package/dist/cjs/js/src/abstract/okx.js +9 -0
  82. package/dist/cjs/js/src/abstract/p2b.js +9 -0
  83. package/dist/cjs/js/src/abstract/paymium.js +9 -0
  84. package/dist/cjs/js/src/abstract/phemex.js +9 -0
  85. package/dist/cjs/js/src/abstract/poloniex.js +9 -0
  86. package/dist/cjs/js/src/abstract/poloniexfutures.js +9 -0
  87. package/dist/cjs/js/src/abstract/probit.js +9 -0
  88. package/dist/cjs/js/src/abstract/timex.js +9 -0
  89. package/dist/cjs/js/src/abstract/tokocrypto.js +9 -0
  90. package/dist/cjs/js/src/abstract/upbit.js +9 -0
  91. package/dist/cjs/js/src/abstract/wavesexchange.js +9 -0
  92. package/dist/cjs/js/src/abstract/wazirx.js +9 -0
  93. package/dist/cjs/js/src/abstract/whitebit.js +9 -0
  94. package/dist/cjs/js/src/abstract/woo.js +9 -0
  95. package/dist/cjs/js/src/abstract/yobit.js +9 -0
  96. package/dist/cjs/js/src/abstract/zaif.js +9 -0
  97. package/dist/cjs/js/src/abstract/zonda.js +9 -0
  98. package/dist/cjs/js/src/ace.js +1058 -0
  99. package/dist/cjs/js/src/alpaca.js +1125 -0
  100. package/dist/cjs/js/src/ascendex.js +3360 -0
  101. package/dist/cjs/js/src/base/Exchange.js +5110 -0
  102. package/dist/cjs/js/src/base/Precise.js +263 -0
  103. package/dist/cjs/js/src/base/errors.js +299 -0
  104. package/dist/cjs/js/src/base/functions/crypto.js +78 -0
  105. package/dist/cjs/js/src/base/functions/encode.js +44 -0
  106. package/dist/cjs/js/src/base/functions/generic.js +193 -0
  107. package/dist/cjs/js/src/base/functions/misc.js +96 -0
  108. package/dist/cjs/js/src/base/functions/number.js +297 -0
  109. package/dist/cjs/js/src/base/functions/platform.js +28 -0
  110. package/dist/cjs/js/src/base/functions/rsa.js +34 -0
  111. package/dist/cjs/js/src/base/functions/string.js +48 -0
  112. package/dist/cjs/js/src/base/functions/throttle.js +66 -0
  113. package/dist/cjs/js/src/base/functions/time.js +187 -0
  114. package/dist/cjs/js/src/base/functions/totp.js +24 -0
  115. package/dist/cjs/js/src/base/functions/type.js +162 -0
  116. package/dist/cjs/js/src/base/functions.js +157 -0
  117. package/dist/cjs/js/src/base/ws/Cache.js +254 -0
  118. package/dist/cjs/js/src/base/ws/Client.js +299 -0
  119. package/dist/cjs/js/src/base/ws/Future.js +34 -0
  120. package/dist/cjs/js/src/base/ws/OrderBook.js +107 -0
  121. package/dist/cjs/js/src/base/ws/OrderBookSide.js +281 -0
  122. package/dist/cjs/js/src/base/ws/WsClient.js +69 -0
  123. package/dist/cjs/js/src/bequant.js +33 -0
  124. package/dist/cjs/js/src/bigone.js +2142 -0
  125. package/dist/cjs/js/src/binance.js +9729 -0
  126. package/dist/cjs/js/src/binancecoinm.js +45 -0
  127. package/dist/cjs/js/src/binanceus.js +84 -0
  128. package/dist/cjs/js/src/binanceusdm.js +58 -0
  129. package/dist/cjs/js/src/bingx.js +3737 -0
  130. package/dist/cjs/js/src/bit2c.js +916 -0
  131. package/dist/cjs/js/src/bitbank.js +1000 -0
  132. package/dist/cjs/js/src/bitbay.js +17 -0
  133. package/dist/cjs/js/src/bitbns.js +1220 -0
  134. package/dist/cjs/js/src/bitcoincom.js +17 -0
  135. package/dist/cjs/js/src/bitfinex.js +1670 -0
  136. package/dist/cjs/js/src/bitfinex2.js +2990 -0
  137. package/dist/cjs/js/src/bitflyer.js +1045 -0
  138. package/dist/cjs/js/src/bitforex.js +852 -0
  139. package/dist/cjs/js/src/bitget.js +8284 -0
  140. package/dist/cjs/js/src/bithumb.js +1090 -0
  141. package/dist/cjs/js/src/bitmart.js +4454 -0
  142. package/dist/cjs/js/src/bitmex.js +2884 -0
  143. package/dist/cjs/js/src/bitopro.js +1724 -0
  144. package/dist/cjs/js/src/bitpanda.js +2002 -0
  145. package/dist/cjs/js/src/bitrue.js +3253 -0
  146. package/dist/cjs/js/src/bitso.js +1753 -0
  147. package/dist/cjs/js/src/bitstamp.js +2188 -0
  148. package/dist/cjs/js/src/bitteam.js +2309 -0
  149. package/dist/cjs/js/src/bitvavo.js +1968 -0
  150. package/dist/cjs/js/src/bl3p.js +447 -0
  151. package/dist/cjs/js/src/blockchaincom.js +1160 -0
  152. package/dist/cjs/js/src/btcalpha.js +929 -0
  153. package/dist/cjs/js/src/btcbox.js +565 -0
  154. package/dist/cjs/js/src/btcmarkets.js +1237 -0
  155. package/dist/cjs/js/src/btcturk.js +929 -0
  156. package/dist/cjs/js/src/bybit.js +7646 -0
  157. package/dist/cjs/js/src/cex.js +1693 -0
  158. package/dist/cjs/js/src/coinbase.js +3274 -0
  159. package/dist/cjs/js/src/coinbasepro.js +1866 -0
  160. package/dist/cjs/js/src/coincheck.js +843 -0
  161. package/dist/cjs/js/src/coinex.js +5414 -0
  162. package/dist/cjs/js/src/coinlist.js +2329 -0
  163. package/dist/cjs/js/src/coinmate.js +989 -0
  164. package/dist/cjs/js/src/coinone.js +1185 -0
  165. package/dist/cjs/js/src/coinsph.js +1933 -0
  166. package/dist/cjs/js/src/coinspot.js +548 -0
  167. package/dist/cjs/js/src/cryptocom.js +3007 -0
  168. package/dist/cjs/js/src/currencycom.js +2015 -0
  169. package/dist/cjs/js/src/delta.js +3256 -0
  170. package/dist/cjs/js/src/deribit.js +3306 -0
  171. package/dist/cjs/js/src/digifinex.js +4307 -0
  172. package/dist/cjs/js/src/exmo.js +2645 -0
  173. package/dist/cjs/js/src/fmfwio.js +34 -0
  174. package/dist/cjs/js/src/gate.js +7054 -0
  175. package/dist/cjs/js/src/gateio.js +16 -0
  176. package/dist/cjs/js/src/gemini.js +1801 -0
  177. package/dist/cjs/js/src/hitbtc.js +3660 -0
  178. package/dist/cjs/js/src/hitbtc3.js +19 -0
  179. package/dist/cjs/js/src/hollaex.js +1882 -0
  180. package/dist/cjs/js/src/htx.js +9024 -0
  181. package/dist/cjs/js/src/huobi.js +16 -0
  182. package/dist/cjs/js/src/huobijp.js +1918 -0
  183. package/dist/cjs/js/src/idex.js +1770 -0
  184. package/dist/cjs/js/src/independentreserve.js +759 -0
  185. package/dist/cjs/js/src/indodax.js +1069 -0
  186. package/dist/cjs/js/src/kraken.js +2861 -0
  187. package/dist/cjs/js/src/krakenfutures.js +2407 -0
  188. package/dist/cjs/js/src/kucoin.js +4489 -0
  189. package/dist/cjs/js/src/kucoinfutures.js +2475 -0
  190. package/dist/cjs/js/src/kuna.js +1949 -0
  191. package/dist/cjs/js/src/latoken.js +1729 -0
  192. package/dist/cjs/js/src/lbank.js +2825 -0
  193. package/dist/cjs/js/src/luno.js +1044 -0
  194. package/dist/cjs/js/src/lykke.js +1303 -0
  195. package/dist/cjs/js/src/mercado.js +897 -0
  196. package/dist/cjs/js/src/mexc.js +5407 -0
  197. package/dist/cjs/js/src/ndax.js +2450 -0
  198. package/dist/cjs/js/src/novadax.js +1556 -0
  199. package/dist/cjs/js/src/oceanex.js +964 -0
  200. package/dist/cjs/js/src/okcoin.js +3115 -0
  201. package/dist/cjs/js/src/okx.js +7329 -0
  202. package/dist/cjs/js/src/p2b.js +1243 -0
  203. package/dist/cjs/js/src/paymium.js +597 -0
  204. package/dist/cjs/js/src/phemex.js +4715 -0
  205. package/dist/cjs/js/src/poloniex.js +2356 -0
  206. package/dist/cjs/js/src/poloniexfutures.js +1794 -0
  207. package/dist/cjs/js/src/pro/alpaca.js +714 -0
  208. package/dist/cjs/js/src/pro/ascendex.js +957 -0
  209. package/dist/cjs/js/src/pro/bequant.js +33 -0
  210. package/dist/cjs/js/src/pro/binance.js +2796 -0
  211. package/dist/cjs/js/src/pro/binancecoinm.js +23 -0
  212. package/dist/cjs/js/src/pro/binanceus.js +51 -0
  213. package/dist/cjs/js/src/pro/binanceusdm.js +32 -0
  214. package/dist/cjs/js/src/pro/bingx.js +944 -0
  215. package/dist/cjs/js/src/pro/bitcoincom.js +29 -0
  216. package/dist/cjs/js/src/pro/bitfinex.js +672 -0
  217. package/dist/cjs/js/src/pro/bitfinex2.js +1159 -0
  218. package/dist/cjs/js/src/pro/bitget.js +1733 -0
  219. package/dist/cjs/js/src/pro/bitmart.js +1486 -0
  220. package/dist/cjs/js/src/pro/bitmex.js +1576 -0
  221. package/dist/cjs/js/src/pro/bitopro.js +327 -0
  222. package/dist/cjs/js/src/pro/bitpanda.js +1341 -0
  223. package/dist/cjs/js/src/pro/bitrue.js +462 -0
  224. package/dist/cjs/js/src/pro/bitstamp.js +547 -0
  225. package/dist/cjs/js/src/pro/bitvavo.js +704 -0
  226. package/dist/cjs/js/src/pro/blockchaincom.js +794 -0
  227. package/dist/cjs/js/src/pro/bybit.js +1843 -0
  228. package/dist/cjs/js/src/pro/cex.js +1510 -0
  229. package/dist/cjs/js/src/pro/coinbase.js +561 -0
  230. package/dist/cjs/js/src/pro/coinbasepro.js +968 -0
  231. package/dist/cjs/js/src/pro/coinex.js +1095 -0
  232. package/dist/cjs/js/src/pro/cryptocom.js +1020 -0
  233. package/dist/cjs/js/src/pro/currencycom.js +563 -0
  234. package/dist/cjs/js/src/pro/deribit.js +825 -0
  235. package/dist/cjs/js/src/pro/exmo.js +658 -0
  236. package/dist/cjs/js/src/pro/gate.js +1316 -0
  237. package/dist/cjs/js/src/pro/gateio.js +16 -0
  238. package/dist/cjs/js/src/pro/gemini.js +649 -0
  239. package/dist/cjs/js/src/pro/hitbtc.js +1293 -0
  240. package/dist/cjs/js/src/pro/hollaex.js +597 -0
  241. package/dist/cjs/js/src/pro/htx.js +2383 -0
  242. package/dist/cjs/js/src/pro/huobi.js +16 -0
  243. package/dist/cjs/js/src/pro/huobijp.js +606 -0
  244. package/dist/cjs/js/src/pro/idex.js +714 -0
  245. package/dist/cjs/js/src/pro/independentreserve.js +280 -0
  246. package/dist/cjs/js/src/pro/kraken.js +1364 -0
  247. package/dist/cjs/js/src/pro/krakenfutures.js +1500 -0
  248. package/dist/cjs/js/src/pro/kucoin.js +1052 -0
  249. package/dist/cjs/js/src/pro/kucoinfutures.js +981 -0
  250. package/dist/cjs/js/src/pro/luno.js +322 -0
  251. package/dist/cjs/js/src/pro/mexc.js +1170 -0
  252. package/dist/cjs/js/src/pro/ndax.js +545 -0
  253. package/dist/cjs/js/src/pro/okcoin.js +760 -0
  254. package/dist/cjs/js/src/pro/okx.js +1558 -0
  255. package/dist/cjs/js/src/pro/phemex.js +1511 -0
  256. package/dist/cjs/js/src/pro/poloniex.js +1253 -0
  257. package/dist/cjs/js/src/pro/poloniexfutures.js +1014 -0
  258. package/dist/cjs/js/src/pro/probit.js +586 -0
  259. package/dist/cjs/js/src/pro/upbit.js +234 -0
  260. package/dist/cjs/js/src/pro/wazirx.js +776 -0
  261. package/dist/cjs/js/src/pro/whitebit.js +927 -0
  262. package/dist/cjs/js/src/pro/woo.js +769 -0
  263. package/dist/cjs/js/src/probit.js +1865 -0
  264. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +401 -0
  265. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +195 -0
  266. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +308 -0
  267. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +554 -0
  268. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
  269. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
  270. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
  271. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +16 -0
  272. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1760 -0
  273. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +52 -0
  274. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +81 -0
  275. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +376 -0
  276. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +70 -0
  277. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1580 -0
  278. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +74 -0
  279. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +24 -0
  280. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +158 -0
  281. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +429 -0
  282. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +176 -0
  283. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +324 -0
  284. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +163 -0
  285. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +245 -0
  286. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +1018 -0
  287. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +383 -0
  288. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +258 -0
  289. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +53 -0
  290. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +120 -0
  291. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +69 -0
  292. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +7 -0
  293. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +83 -0
  294. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +240 -0
  295. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +91 -0
  296. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +130 -0
  297. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +214 -0
  298. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +239 -0
  299. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +93 -0
  300. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +354 -0
  301. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +16 -0
  302. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +20 -0
  303. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +30 -0
  304. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +239 -0
  305. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +372 -0
  306. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +273 -0
  307. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +139 -0
  308. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +14 -0
  309. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +16 -0
  310. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +81 -0
  311. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +292 -0
  312. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +103 -0
  313. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +140 -0
  314. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +175 -0
  315. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
  316. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +7 -0
  317. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +383 -0
  318. package/dist/cjs/js/src/timex.js +1562 -0
  319. package/dist/cjs/js/src/tokocrypto.js +2542 -0
  320. package/dist/cjs/js/src/upbit.js +1844 -0
  321. package/dist/cjs/js/src/wavesexchange.js +2607 -0
  322. package/dist/cjs/js/src/wazirx.js +953 -0
  323. package/dist/cjs/js/src/whitebit.js +2309 -0
  324. package/dist/cjs/js/src/woo.js +2715 -0
  325. package/dist/cjs/js/src/yobit.js +1314 -0
  326. package/dist/cjs/js/src/zaif.js +736 -0
  327. package/dist/cjs/js/src/zonda.js +1883 -0
  328. package/dist/cjs/src/base/Exchange.js +11 -0
  329. package/dist/cjs/src/bingx.js +0 -10
  330. package/dist/cjs/src/bitget.js +14 -5
  331. package/dist/cjs/src/bybit.js +1 -1
  332. package/dist/cjs/src/kucoin.js +29 -5
  333. package/js/ccxt.d.ts +1 -1
  334. package/js/ccxt.js +1 -1
  335. package/js/src/abstract/bigone.d.ts +18 -0
  336. package/js/src/abstract/binance.d.ts +2 -0
  337. package/js/src/abstract/binancecoinm.d.ts +2 -0
  338. package/js/src/abstract/binanceus.d.ts +2 -0
  339. package/js/src/abstract/binanceusdm.d.ts +2 -0
  340. package/js/src/abstract/bybit.d.ts +1 -0
  341. package/js/src/abstract/gate.d.ts +11 -0
  342. package/js/src/abstract/gateio.d.ts +11 -0
  343. package/js/src/alpaca.js +18 -18
  344. package/js/src/base/Exchange.d.ts +6 -1
  345. package/js/src/base/Exchange.js +112 -12
  346. package/js/src/bigone.d.ts +1 -2
  347. package/js/src/bigone.js +340 -145
  348. package/js/src/binance.js +15 -8
  349. package/js/src/bingx.d.ts +0 -1
  350. package/js/src/bingx.js +9 -12
  351. package/js/src/bitfinex.d.ts +2 -2
  352. package/js/src/bitfinex.js +2 -3
  353. package/js/src/bitget.js +35 -13
  354. package/js/src/bitmart.d.ts +2 -2
  355. package/js/src/bitmart.js +3 -3
  356. package/js/src/bitmex.js +1 -0
  357. package/js/src/bybit.js +3 -1
  358. package/js/src/coinlist.js +2 -3
  359. package/js/src/coinsph.js +2 -3
  360. package/js/src/deribit.js +1 -0
  361. package/js/src/gate.d.ts +4 -4
  362. package/js/src/gate.js +22 -3
  363. package/js/src/hitbtc.d.ts +4 -4
  364. package/js/src/hitbtc.js +2 -3
  365. package/js/src/htx.js +4 -7
  366. package/js/src/huobijp.js +2 -3
  367. package/js/src/kraken.js +1 -0
  368. package/js/src/kucoin.js +29 -5
  369. package/js/src/mexc.js +2 -1
  370. package/js/src/okx.js +13 -3
  371. package/js/src/pro/binance.d.ts +2 -23
  372. package/js/src/pro/binance.js +58 -22
  373. package/js/src/pro/coinbase.d.ts +2 -2
  374. package/js/src/pro/coinbase.js +4 -1
  375. package/js/src/pro/coinbasepro.d.ts +2 -2
  376. package/js/src/pro/hitbtc.d.ts +2 -2
  377. package/js/src/pro/poloniex.d.ts +2 -2
  378. package/js/src/upbit.d.ts +3 -101
  379. package/js/src/upbit.js +12 -12
  380. package/js/src/woo.js +2 -0
  381. package/package.json +11 -11
  382. package/skip-tests.json +5 -0
  383. package/tests-manager.sh +2 -2
@@ -0,0 +1,981 @@
1
+ 'use strict';
2
+
3
+ var kucoinfutures$1 = require('../kucoinfutures.js');
4
+ var errors = require('../base/errors.js');
5
+ var Cache = require('../base/ws/Cache.js');
6
+
7
+ // ---------------------------------------------------------------------------
8
+ // ---------------------------------------------------------------------------
9
+ class kucoinfutures extends kucoinfutures$1 {
10
+ describe() {
11
+ return this.deepExtend(super.describe(), {
12
+ 'has': {
13
+ 'ws': true,
14
+ 'watchTicker': true,
15
+ 'watchTrades': true,
16
+ 'watchOrderBook': true,
17
+ 'watchOrders': true,
18
+ 'watchBalance': true,
19
+ 'watchPosition': true,
20
+ 'watchPositions': false,
21
+ 'watchPositionForSymbols': false,
22
+ 'watchTradesForSymbols': true,
23
+ 'watchOrderBookForSymbols': true,
24
+ },
25
+ 'options': {
26
+ 'accountsByType': {
27
+ 'swap': 'future',
28
+ 'cross': 'margin',
29
+ // 'spot': ,
30
+ // 'margin': ,
31
+ // 'main': ,
32
+ // 'funding': ,
33
+ // 'future': ,
34
+ // 'mining': ,
35
+ // 'trade': ,
36
+ // 'contract': ,
37
+ // 'pool': ,
38
+ },
39
+ 'tradesLimit': 1000,
40
+ 'watchOrderBook': {
41
+ 'snapshotDelay': 20,
42
+ 'snapshotMaxRetries': 3,
43
+ },
44
+ 'watchTicker': {
45
+ 'name': 'contractMarket/tickerV2', // market/ticker
46
+ },
47
+ 'watchPosition': {
48
+ 'fetchPositionSnapshot': true,
49
+ 'awaitPositionSnapshot': true, // whether to wait for the position snapshot before providing updates
50
+ },
51
+ },
52
+ 'streaming': {
53
+ // kucoin does not support built-in ws protocol-level ping-pong
54
+ // instead it requires a custom json-based text ping-pong
55
+ // https://docs.kucoin.com/#ping
56
+ 'ping': this.ping,
57
+ },
58
+ });
59
+ }
60
+ negotiate(privateChannel, params = {}) {
61
+ const connectId = privateChannel ? 'private' : 'public';
62
+ const urls = this.safeValue(this.options, 'urls', {});
63
+ const spawaned = this.safeValue(urls, connectId);
64
+ if (spawaned !== undefined) {
65
+ return spawaned;
66
+ }
67
+ // we store an awaitable to the url
68
+ // so that multiple calls don't asynchronously
69
+ // fetch different urls and overwrite each other
70
+ urls[connectId] = this.spawn(this.negotiateHelper, privateChannel, params);
71
+ this.options['urls'] = urls;
72
+ return urls[connectId];
73
+ }
74
+ async negotiateHelper(privateChannel, params = {}) {
75
+ let response = undefined;
76
+ const connectId = privateChannel ? 'private' : 'public';
77
+ if (privateChannel) {
78
+ response = await this.futuresPrivatePostBulletPrivate(params);
79
+ //
80
+ // {
81
+ // "code": "200000",
82
+ // "data": {
83
+ // "instanceServers": [
84
+ // {
85
+ // "pingInterval": 50000,
86
+ // "endpoint": "wss://push-private.kucoin.com/endpoint",
87
+ // "protocol": "websocket",
88
+ // "encrypt": true,
89
+ // "pingTimeout": 10000
90
+ // }
91
+ // ],
92
+ // "token": "2neAiuYvAU61ZDXANAGAsiL4-iAExhsBXZxftpOeh_55i3Ysy2q2LEsEWU64mdzUOPusi34M_wGoSf7iNyEWJ1UQy47YbpY4zVdzilNP-Bj3iXzrjjGlWtiYB9J6i9GjsxUuhPw3BlrzazF6ghq4Lzf7scStOz3KkxjwpsOBCH4=.WNQmhZQeUKIkh97KYgU0Lg=="
93
+ // }
94
+ // }
95
+ //
96
+ }
97
+ else {
98
+ response = await this.futuresPublicPostBulletPublic(params);
99
+ }
100
+ const data = this.safeValue(response, 'data', {});
101
+ const instanceServers = this.safeValue(data, 'instanceServers', []);
102
+ const firstInstanceServer = this.safeValue(instanceServers, 0);
103
+ const pingInterval = this.safeInteger(firstInstanceServer, 'pingInterval');
104
+ const endpoint = this.safeString(firstInstanceServer, 'endpoint');
105
+ const token = this.safeString(data, 'token');
106
+ const result = endpoint + '?' + this.urlencode({
107
+ 'token': token,
108
+ 'privateChannel': privateChannel,
109
+ 'connectId': connectId,
110
+ });
111
+ const client = this.client(result);
112
+ client.keepAlive = pingInterval;
113
+ return result;
114
+ }
115
+ requestId() {
116
+ const requestId = this.sum(this.safeInteger(this.options, 'requestId', 0), 1);
117
+ this.options['requestId'] = requestId;
118
+ return requestId;
119
+ }
120
+ async subscribe(url, messageHash, subscriptionHash, subscription, params = {}) {
121
+ const requestId = this.requestId().toString();
122
+ const request = {
123
+ 'id': requestId,
124
+ 'type': 'subscribe',
125
+ 'topic': subscriptionHash,
126
+ 'response': true,
127
+ };
128
+ const message = this.extend(request, params);
129
+ const subscriptionRequest = {
130
+ 'id': requestId,
131
+ };
132
+ if (subscription === undefined) {
133
+ subscription = subscriptionRequest;
134
+ }
135
+ else {
136
+ subscription = this.extend(subscriptionRequest, subscription);
137
+ }
138
+ return await this.watch(url, messageHash, message, subscriptionHash, subscription);
139
+ }
140
+ async subscribeMultiple(url, messageHashes, topic, subscriptionHashes, subscription, params = {}) {
141
+ const requestId = this.requestId().toString();
142
+ const request = {
143
+ 'id': requestId,
144
+ 'type': 'subscribe',
145
+ 'topic': topic,
146
+ 'response': true,
147
+ };
148
+ const message = this.extend(request, params);
149
+ const subscriptionRequest = {
150
+ 'id': requestId,
151
+ };
152
+ if (subscription === undefined) {
153
+ subscription = subscriptionRequest;
154
+ }
155
+ else {
156
+ subscription = this.extend(subscriptionRequest, subscription);
157
+ }
158
+ return await this.watchMultiple(url, messageHashes, message, subscriptionHashes, subscription);
159
+ }
160
+ async watchTicker(symbol, params = {}) {
161
+ /**
162
+ * @method
163
+ * @name kucoinfutures#watchTicker
164
+ * @description watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
165
+ * @see https://docs.kucoin.com/futures/#get-real-time-symbol-ticker-v2
166
+ * @param {string} symbol 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
+ const market = this.market(symbol);
172
+ symbol = market['symbol'];
173
+ const url = await this.negotiate(false);
174
+ const options = this.safeValue(this.options, 'watchTicker', {});
175
+ const channel = this.safeString(options, 'name', 'contractMarket/tickerV2');
176
+ const topic = '/' + channel + ':' + market['id'];
177
+ const messageHash = 'ticker:' + symbol;
178
+ return await this.subscribe(url, messageHash, topic, undefined, params);
179
+ }
180
+ handleTicker(client, message) {
181
+ //
182
+ // market/tickerV2
183
+ //
184
+ // {
185
+ // "type": "message",
186
+ // "topic": "/contractMarket/tickerV2:ADAUSDTM",
187
+ // "subject": "tickerV2",
188
+ // "data": {
189
+ // "symbol": "ADAUSDTM",
190
+ // "sequence": 1668007800439,
191
+ // "bestBidSize": 178,
192
+ // "bestBidPrice": "0.35959",
193
+ // "bestAskPrice": "0.35981",
194
+ // "ts": "1668141430037124460",
195
+ // "bestAskSize": 134
196
+ // }
197
+ // }
198
+ //
199
+ const data = this.safeValue(message, 'data', {});
200
+ const marketId = this.safeValue(data, 'symbol');
201
+ const market = this.safeMarket(marketId, undefined, '-');
202
+ const ticker = this.parseTicker(data, market);
203
+ this.tickers[market['symbol']] = ticker;
204
+ const messageHash = 'ticker:' + market['symbol'];
205
+ client.resolve(ticker, messageHash);
206
+ return message;
207
+ }
208
+ async watchPosition(symbol = undefined, params = {}) {
209
+ /**
210
+ * @method
211
+ * @name kucoinfutures#watchPosition
212
+ * @description watch open positions for a specific symbol
213
+ * @see https://docs.kucoin.com/futures/#position-change-events
214
+ * @param {string|undefined} symbol unified market symbol
215
+ * @param {object} params extra parameters specific to the exchange API endpoint
216
+ * @returns {object} a [position structure]{@link https://docs.ccxt.com/en/latest/manual.html#position-structure}
217
+ */
218
+ if (symbol === undefined) {
219
+ throw new errors.ArgumentsRequired(this.id + ' watchPosition() requires a symbol argument');
220
+ }
221
+ await this.loadMarkets();
222
+ const url = await this.negotiate(true);
223
+ const market = this.market(symbol);
224
+ const topic = '/contract/position:' + market['id'];
225
+ const request = {
226
+ 'privateChannel': true,
227
+ };
228
+ const messageHash = 'position:' + market['symbol'];
229
+ const client = this.client(url);
230
+ this.setPositionCache(client, symbol);
231
+ const fetchPositionSnapshot = this.handleOption('watchPosition', 'fetchPositionSnapshot', true);
232
+ const awaitPositionSnapshot = this.safeValue('watchPosition', 'awaitPositionSnapshot', true);
233
+ const currentPosition = this.getCurrentPosition(symbol);
234
+ if (fetchPositionSnapshot && awaitPositionSnapshot && currentPosition === undefined) {
235
+ const snapshot = await client.future('fetchPositionSnapshot:' + symbol);
236
+ return snapshot;
237
+ }
238
+ return await this.subscribe(url, messageHash, topic, undefined, this.extend(request, params));
239
+ }
240
+ getCurrentPosition(symbol) {
241
+ if (this.positions === undefined) {
242
+ return undefined;
243
+ }
244
+ const cache = this.positions.hashmap;
245
+ const symbolCache = this.safeValue(cache, symbol, {});
246
+ const values = Object.values(symbolCache);
247
+ return this.safeValue(values, 0);
248
+ }
249
+ setPositionCache(client, symbol) {
250
+ const fetchPositionSnapshot = this.handleOption('watchPosition', 'fetchPositionSnapshot', false);
251
+ if (fetchPositionSnapshot) {
252
+ const messageHash = 'fetchPositionSnapshot:' + symbol;
253
+ if (!(messageHash in client.futures)) {
254
+ client.future(messageHash);
255
+ this.spawn(this.loadPositionSnapshot, client, messageHash, symbol);
256
+ }
257
+ }
258
+ }
259
+ async loadPositionSnapshot(client, messageHash, symbol) {
260
+ const position = await this.fetchPosition(symbol);
261
+ this.positions = new Cache.ArrayCacheBySymbolById();
262
+ const cache = this.positions;
263
+ cache.append(position);
264
+ // don't remove the future from the .futures cache
265
+ const future = client.futures[messageHash];
266
+ future.resolve(cache);
267
+ client.resolve(position, 'position:' + symbol);
268
+ }
269
+ handlePosition(client, message) {
270
+ //
271
+ // Position Changes Caused Operations
272
+ // {
273
+ // "type": "message",
274
+ // "userId": "5c32d69203aa676ce4b543c7", // Deprecated, will detele later
275
+ // "channelType": "private",
276
+ // "topic": "/contract/position:XBTUSDM",
277
+ // "subject": "position.change",
278
+ // "data": {
279
+ // "realisedGrossPnl": 0E-8, //Accumulated realised profit and loss
280
+ // "symbol": "XBTUSDM", //Symbol
281
+ // "crossMode": false, //Cross mode or not
282
+ // "liquidationPrice": 1000000.0, //Liquidation price
283
+ // "posLoss": 0E-8, //Manually added margin amount
284
+ // "avgEntryPrice": 7508.22, //Average entry price
285
+ // "unrealisedPnl": -0.00014735, //Unrealised profit and loss
286
+ // "markPrice": 7947.83, //Mark price
287
+ // "posMargin": 0.00266779, //Position margin
288
+ // "autoDeposit": false, //Auto deposit margin or not
289
+ // "riskLimit": 100000, //Risk limit
290
+ // "unrealisedCost": 0.00266375, //Unrealised value
291
+ // "posComm": 0.00000392, //Bankruptcy cost
292
+ // "posMaint": 0.00001724, //Maintenance margin
293
+ // "posCost": 0.00266375, //Position value
294
+ // "maintMarginReq": 0.005, //Maintenance margin rate
295
+ // "bankruptPrice": 1000000.0, //Bankruptcy price
296
+ // "realisedCost": 0.00000271, //Currently accumulated realised position value
297
+ // "markValue": 0.00251640, //Mark value
298
+ // "posInit": 0.00266375, //Position margin
299
+ // "realisedPnl": -0.00000253, //Realised profit and losts
300
+ // "maintMargin": 0.00252044, //Position margin
301
+ // "realLeverage": 1.06, //Leverage of the order
302
+ // "changeReason": "positionChange", //changeReason:marginChange、positionChange、liquidation、autoAppendMarginStatusChange、adl
303
+ // "currentCost": 0.00266375, //Current position value
304
+ // "openingTimestamp": 1558433191000, //Open time
305
+ // "currentQty": -20, //Current position
306
+ // "delevPercentage": 0.52, //ADL ranking percentile
307
+ // "currentComm": 0.00000271, //Current commission
308
+ // "realisedGrossCost": 0E-8, //Accumulated reliased gross profit value
309
+ // "isOpen": true, //Opened position or not
310
+ // "posCross": 1.2E-7, //Manually added margin
311
+ // "currentTimestamp": 1558506060394, //Current timestamp
312
+ // "unrealisedRoePcnt": -0.0553, //Rate of return on investment
313
+ // "unrealisedPnlPcnt": -0.0553, //Position profit and loss ratio
314
+ // "settleCurrency": "XBT" //Currency used to clear and settle the trades
315
+ // }
316
+ // }
317
+ // Position Changes Caused by Mark Price
318
+ // {
319
+ // "userId": "5cd3f1a7b7ebc19ae9558591", // Deprecated, will detele later
320
+ // "topic": "/contract/position:XBTUSDM",
321
+ // "subject": "position.change",
322
+ // "data": {
323
+ // "markPrice": 7947.83, //Mark price
324
+ // "markValue": 0.00251640, //Mark value
325
+ // "maintMargin": 0.00252044, //Position margin
326
+ // "realLeverage": 10.06, //Leverage of the order
327
+ // "unrealisedPnl": -0.00014735, //Unrealised profit and lost
328
+ // "unrealisedRoePcnt": -0.0553, //Rate of return on investment
329
+ // "unrealisedPnlPcnt": -0.0553, //Position profit and loss ratio
330
+ // "delevPercentage": 0.52, //ADL ranking percentile
331
+ // "currentTimestamp": 1558087175068, //Current timestamp
332
+ // "settleCurrency": "XBT" //Currency used to clear and settle the trades
333
+ // }
334
+ // }
335
+ // Funding Settlement
336
+ // {
337
+ // "userId": "xbc453tg732eba53a88ggyt8c", // Deprecated, will detele later
338
+ // "topic": "/contract/position:XBTUSDM",
339
+ // "subject": "position.settlement",
340
+ // "data": {
341
+ // "fundingTime": 1551770400000, //Funding time
342
+ // "qty": 100, //Position siz
343
+ // "markPrice": 3610.85, //Settlement price
344
+ // "fundingRate": -0.002966, //Funding rate
345
+ // "fundingFee": -296, //Funding fees
346
+ // "ts": 1547697294838004923, //Current time (nanosecond)
347
+ // "settleCurrency": "XBT" //Currency used to clear and settle the trades
348
+ // }
349
+ // }
350
+ // Adjustmet result of risk limit level
351
+ // {
352
+ // "userId": "xbc453tg732eba53a88ggyt8c",
353
+ // "topic": "/contract/position:ADAUSDTM",
354
+ // "subject": "position.adjustRiskLimit",
355
+ // "data": {
356
+ // "success": true, // Successful or not
357
+ // "riskLimitLevel": 1, // Current risk limit level
358
+ // "msg": "" // Failure reason
359
+ // }
360
+ // }
361
+ //
362
+ const topic = this.safeString(message, 'topic', '');
363
+ const parts = topic.split(':');
364
+ const marketId = this.safeString(parts, 1);
365
+ const symbol = this.safeSymbol(marketId, undefined, '');
366
+ const cache = this.positions;
367
+ const currentPosition = this.getCurrentPosition(symbol);
368
+ const messageHash = 'position:' + symbol;
369
+ const data = this.safeValue(message, 'data', {});
370
+ const newPosition = this.parsePosition(data);
371
+ const keys = Object.keys(newPosition);
372
+ for (let i = 0; i < keys.length; i++) {
373
+ const key = keys[i];
374
+ if (newPosition[key] === undefined) {
375
+ delete newPosition[key];
376
+ }
377
+ }
378
+ const position = this.extend(currentPosition, newPosition);
379
+ cache.append(position);
380
+ client.resolve(position, messageHash);
381
+ }
382
+ async watchTrades(symbol, since = undefined, limit = undefined, params = {}) {
383
+ /**
384
+ * @method
385
+ * @name kucoinfutures#watchTrades
386
+ * @description get the list of most recent trades for a particular symbol
387
+ * @see https://docs.kucoin.com/futures/#execution-data
388
+ * @param {string} symbol unified symbol of the market to fetch trades for
389
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
390
+ * @param {int} [limit] the maximum amount of trades to fetch
391
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
392
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
393
+ */
394
+ return await this.watchTradesForSymbols([symbol], since, limit, params);
395
+ }
396
+ async watchTradesForSymbols(symbols, since = undefined, limit = undefined, params = {}) {
397
+ /**
398
+ * @method
399
+ * @name kucoinfutures#watchTrades
400
+ * @description get the list of most recent trades for a particular symbol
401
+ * @param {string} symbol unified symbol of the market to fetch trades for
402
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
403
+ * @param {int} [limit] the maximum amount of trades to fetch
404
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
405
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
406
+ */
407
+ const symbolsLength = symbols.length;
408
+ if (symbolsLength === 0) {
409
+ throw new errors.ArgumentsRequired(this.id + ' watchTradesForSymbols() requires a non-empty array of symbols');
410
+ }
411
+ await this.loadMarkets();
412
+ symbols = this.marketSymbols(symbols);
413
+ const url = await this.negotiate(false);
414
+ symbols = this.marketSymbols(symbols);
415
+ const marketIds = this.marketIds(symbols);
416
+ const topic = '/contractMarket/execution:' + marketIds.join(',');
417
+ const subscriptionHashes = [];
418
+ const messageHashes = [];
419
+ for (let i = 0; i < symbols.length; i++) {
420
+ const symbol = symbols[i];
421
+ const marketId = marketIds[i];
422
+ messageHashes.push('trades:' + symbol);
423
+ subscriptionHashes.push('/contractMarket/execution:' + marketId);
424
+ }
425
+ const trades = await this.subscribeMultiple(url, messageHashes, topic, subscriptionHashes, params);
426
+ if (this.newUpdates) {
427
+ const first = this.safeValue(trades, 0);
428
+ const tradeSymbol = this.safeString(first, 'symbol');
429
+ limit = trades.getLimit(tradeSymbol, limit);
430
+ }
431
+ return this.filterBySinceLimit(trades, since, limit, 'timestamp', true);
432
+ }
433
+ handleTrade(client, message) {
434
+ //
435
+ // {
436
+ // "type": "message",
437
+ // "topic": "/contractMarket/execution:ADAUSDTM",
438
+ // "subject": "match",
439
+ // "data": {
440
+ // "makerUserId": "62286a4d720edf0001e81961",
441
+ // "symbol": "ADAUSDTM",
442
+ // "sequence": 41320766,
443
+ // "side": "sell",
444
+ // "size": 2,
445
+ // "price": 0.35904,
446
+ // "takerOrderId": "636dd9da9857ba00010cfa44",
447
+ // "makerOrderId": "636dd9c8df149d0001e62bc8",
448
+ // "takerUserId": "6180be22b6ab210001fa3371",
449
+ // "tradeId": "636dd9da0000d400d477eca7",
450
+ // "ts": 1668143578987357700
451
+ // }
452
+ // }
453
+ //
454
+ const data = this.safeValue(message, 'data', {});
455
+ const trade = this.parseTrade(data);
456
+ const symbol = trade['symbol'];
457
+ let trades = this.safeValue(this.trades, symbol);
458
+ if (trades === undefined) {
459
+ const limit = this.safeInteger(this.options, 'tradesLimit', 1000);
460
+ trades = new Cache.ArrayCache(limit);
461
+ this.trades[symbol] = trades;
462
+ }
463
+ trades.append(trade);
464
+ const messageHash = 'trades:' + symbol;
465
+ client.resolve(trades, messageHash);
466
+ return message;
467
+ }
468
+ async watchOrderBook(symbol, limit = undefined, params = {}) {
469
+ /**
470
+ * @method
471
+ * @name kucoinfutures#watchOrderBook
472
+ * @description watches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
473
+ * 1. After receiving the websocket Level 2 data flow, cache the data.
474
+ * 2. Initiate a REST request to get the snapshot data of Level 2 order book.
475
+ * 3. Playback the cached Level 2 data flow.
476
+ * 4. Apply the new Level 2 data flow to the local snapshot to ensure that the sequence of the new Level 2 update lines up with the sequence of the previous Level 2 data. Discard all the message prior to that sequence, and then playback the change to snapshot.
477
+ * 5. Update the level2 full data based on sequence according to the size. If the price is 0, ignore the messages and update the sequence. If the size=0, update the sequence and remove the price of which the size is 0 out of level 2. For other cases, please update the price.
478
+ * 6. If the sequence of the newly pushed message does not line up to the sequence of the last message, you could pull through REST Level 2 message request to get the updated messages. Please note that the difference between the start and end parameters cannot exceed 500.
479
+ * @see https://docs.kucoin.com/futures/#level-2-market-data
480
+ * @param {string} symbol unified symbol of the market to fetch the order book for
481
+ * @param {int} [limit] the maximum amount of order book entries to return
482
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
483
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
484
+ */
485
+ return await this.watchOrderBookForSymbols([symbol], limit, params);
486
+ }
487
+ async watchOrderBookForSymbols(symbols, limit = undefined, params = {}) {
488
+ /**
489
+ * @method
490
+ * @name kucoinfutures#watchOrderBookForSymbols
491
+ * @description watches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
492
+ * @param {string[]} symbols unified array of symbols
493
+ * @param {int} [limit] the maximum amount of order book entries to return
494
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
495
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
496
+ */
497
+ const symbolsLength = symbols.length;
498
+ if (symbolsLength === 0) {
499
+ throw new errors.ArgumentsRequired(this.id + ' watchOrderBookForSymbols() requires a non-empty array of symbols');
500
+ }
501
+ if (limit !== undefined) {
502
+ if ((limit !== 20) && (limit !== 100)) {
503
+ throw new errors.ExchangeError(this.id + " watchOrderBook 'limit' argument must be undefined, 20 or 100");
504
+ }
505
+ }
506
+ await this.loadMarkets();
507
+ symbols = this.marketSymbols(symbols);
508
+ const marketIds = this.marketIds(symbols);
509
+ const url = await this.negotiate(false);
510
+ const topic = '/contractMarket/level2:' + marketIds.join(',');
511
+ const subscription = {
512
+ 'method': this.handleOrderBookSubscription,
513
+ 'symbols': symbols,
514
+ 'limit': limit,
515
+ };
516
+ const subscriptionHashes = [];
517
+ const messageHashes = [];
518
+ for (let i = 0; i < symbols.length; i++) {
519
+ const symbol = symbols[i];
520
+ const marketId = marketIds[i];
521
+ messageHashes.push('orderbook:' + symbol);
522
+ subscriptionHashes.push('/contractMarket/level2:' + marketId);
523
+ }
524
+ const orderbook = await this.subscribeMultiple(url, messageHashes, topic, subscriptionHashes, subscription, params);
525
+ return orderbook.limit();
526
+ }
527
+ handleDelta(orderbook, delta) {
528
+ orderbook['nonce'] = this.safeInteger(delta, 'sequence');
529
+ const timestamp = this.safeInteger(delta, 'timestamp');
530
+ orderbook['timestamp'] = timestamp;
531
+ orderbook['datetime'] = this.iso8601(timestamp);
532
+ const change = this.safeValue(delta, 'change', {});
533
+ const splitChange = change.split(',');
534
+ const price = this.safeNumber(splitChange, 0);
535
+ const side = this.safeString(splitChange, 1);
536
+ const quantity = this.safeNumber(splitChange, 2);
537
+ const type = (side === 'buy') ? 'bids' : 'asks';
538
+ const value = [price, quantity];
539
+ if (type === 'bids') {
540
+ const storedBids = orderbook['bids'];
541
+ storedBids.storeArray(value);
542
+ }
543
+ else {
544
+ const storedAsks = orderbook['asks'];
545
+ storedAsks.storeArray(value);
546
+ }
547
+ }
548
+ handleDeltas(bookside, deltas) {
549
+ for (let i = 0; i < deltas.length; i++) {
550
+ this.handleDelta(bookside, deltas[i]);
551
+ }
552
+ }
553
+ handleOrderBook(client, message) {
554
+ //
555
+ // initial snapshot is fetched with ccxt's fetchOrderBook
556
+ // the feed does not include a snapshot, just the deltas
557
+ //
558
+ // {
559
+ // "type": "message",
560
+ // "topic": "/contractMarket/level2:ADAUSDTM",
561
+ // "subject": "level2",
562
+ // "data": {
563
+ // "sequence": 1668059586457,
564
+ // "change": "0.34172,sell,456", // type, side, quantity
565
+ // "timestamp": 1668573023223
566
+ // }
567
+ // }
568
+ //
569
+ const data = this.safeValue(message, 'data');
570
+ const topic = this.safeString(message, 'topic');
571
+ const topicParts = topic.split(':');
572
+ const marketId = this.safeString(topicParts, 1);
573
+ const symbol = this.safeSymbol(marketId, undefined, '-');
574
+ const messageHash = 'orderbook:' + symbol;
575
+ const storedOrderBook = this.safeValue(this.orderbooks, symbol);
576
+ const nonce = this.safeInteger(storedOrderBook, 'nonce');
577
+ const deltaEnd = this.safeInteger(data, 'sequence');
578
+ if (nonce === undefined) {
579
+ const cacheLength = storedOrderBook.cache.length;
580
+ const topicPartsNew = topic.split(':');
581
+ const topicSymbol = this.safeString(topicPartsNew, 1);
582
+ const topicChannel = this.safeString(topicPartsNew, 0);
583
+ const subscriptions = Object.keys(client.subscriptions);
584
+ let subscription = undefined;
585
+ for (let i = 0; i < subscriptions.length; i++) {
586
+ const key = subscriptions[i];
587
+ if ((key.indexOf(topicSymbol) >= 0) && (key.indexOf(topicChannel) >= 0)) {
588
+ subscription = client.subscriptions[key];
589
+ break;
590
+ }
591
+ }
592
+ const limit = this.safeInteger(subscription, 'limit');
593
+ const snapshotDelay = this.handleOption('watchOrderBook', 'snapshotDelay', 5);
594
+ if (cacheLength === snapshotDelay) {
595
+ this.spawn(this.loadOrderBook, client, messageHash, symbol, limit);
596
+ }
597
+ storedOrderBook.cache.push(data);
598
+ return;
599
+ }
600
+ else if (nonce >= deltaEnd) {
601
+ return;
602
+ }
603
+ this.handleDelta(storedOrderBook, data);
604
+ client.resolve(storedOrderBook, messageHash);
605
+ }
606
+ getCacheIndex(orderbook, cache) {
607
+ const firstDelta = this.safeValue(cache, 0);
608
+ const nonce = this.safeInteger(orderbook, 'nonce');
609
+ const firstDeltaStart = this.safeInteger(firstDelta, 'sequence');
610
+ if (nonce < firstDeltaStart - 1) {
611
+ return -1;
612
+ }
613
+ for (let i = 0; i < cache.length; i++) {
614
+ const delta = cache[i];
615
+ const deltaStart = this.safeInteger(delta, 'sequence');
616
+ if (nonce < deltaStart - 1) {
617
+ return i;
618
+ }
619
+ }
620
+ return cache.length;
621
+ }
622
+ handleOrderBookSubscription(client, message, subscription) {
623
+ const limit = this.safeInteger(subscription, 'limit');
624
+ const symbols = this.safeValue(subscription, 'symbols');
625
+ if (symbols === undefined) {
626
+ const symbol = this.safeString(subscription, 'symbol');
627
+ this.orderbooks[symbol] = this.orderBook({}, limit);
628
+ }
629
+ else {
630
+ for (let i = 0; i < symbols.length; i++) {
631
+ const symbol = symbols[i];
632
+ this.orderbooks[symbol] = this.orderBook({}, limit);
633
+ }
634
+ }
635
+ // moved snapshot initialization to handleOrderBook to fix
636
+ // https://github.com/ccxt/ccxt/issues/6820
637
+ // the general idea is to fetch the snapshot after the first delta
638
+ // but not before, because otherwise we cannot synchronize the feed
639
+ }
640
+ handleSubscriptionStatus(client, message) {
641
+ //
642
+ // {
643
+ // "id": "1578090438322",
644
+ // "type": "ack"
645
+ // }
646
+ //
647
+ const id = this.safeString(message, 'id');
648
+ const subscriptionsById = this.indexBy(client.subscriptions, 'id');
649
+ const subscription = this.safeValue(subscriptionsById, id, {});
650
+ const method = this.safeValue(subscription, 'method');
651
+ if (method !== undefined) {
652
+ method.call(this, client, message, subscription);
653
+ }
654
+ }
655
+ handleSystemStatus(client, message) {
656
+ //
657
+ // todo: answer the question whether handleSystemStatus should be renamed
658
+ // and unified as handleStatus for any usage pattern that
659
+ // involves system status and maintenance updates
660
+ //
661
+ // {
662
+ // "id": "1578090234088", // connectId
663
+ // "type": "welcome",
664
+ // }
665
+ //
666
+ return message;
667
+ }
668
+ async watchOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
669
+ /**
670
+ * @method
671
+ * @name kucoinfutures#watchOrders
672
+ * @description watches information on multiple orders made by the user
673
+ * @see https://docs.kucoin.com/futures/#trade-orders-according-to-the-market
674
+ * @param {string} symbol unified market symbol of the market orders were made in
675
+ * @param {int} [since] the earliest time in ms to fetch orders for
676
+ * @param {int} [limit] the maximum number of order structures to retrieve
677
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
678
+ * @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
679
+ */
680
+ await this.loadMarkets();
681
+ const url = await this.negotiate(true);
682
+ const topic = '/contractMarket/tradeOrders';
683
+ const request = {
684
+ 'privateChannel': true,
685
+ };
686
+ let messageHash = 'orders';
687
+ if (symbol !== undefined) {
688
+ const market = this.market(symbol);
689
+ symbol = market['symbol'];
690
+ messageHash = messageHash + ':' + symbol;
691
+ }
692
+ const orders = await this.subscribe(url, messageHash, topic, undefined, this.extend(request, params));
693
+ if (this.newUpdates) {
694
+ limit = orders.getLimit(symbol, limit);
695
+ }
696
+ return this.filterBySymbolSinceLimit(orders, symbol, since, limit, true);
697
+ }
698
+ parseWsOrderStatus(status) {
699
+ const statuses = {
700
+ 'open': 'open',
701
+ 'filled': 'closed',
702
+ 'match': 'open',
703
+ 'update': 'open',
704
+ 'canceled': 'canceled',
705
+ };
706
+ return this.safeString(statuses, status, status);
707
+ }
708
+ parseWsOrder(order, market = undefined) {
709
+ //
710
+ // "symbol": "XCAD-USDT",
711
+ // {
712
+ // "orderType": "limit",
713
+ // "side": "buy",
714
+ // "orderId": "6249167327218b000135e749",
715
+ // "type": "canceled",
716
+ // "orderTime": 1648957043065280224,
717
+ // "size": "100.452",
718
+ // "filledSize": "0",
719
+ // "price": "2.9635",
720
+ // "clientOid": "buy-XCAD-USDT-1648957043010159",
721
+ // "remainSize": "0",
722
+ // "status": "done",
723
+ // "ts": 1648957054031001037
724
+ // }
725
+ //
726
+ const id = this.safeString(order, 'orderId');
727
+ const clientOrderId = this.safeString(order, 'clientOid');
728
+ const orderType = this.safeStringLower(order, 'orderType');
729
+ const price = this.safeString(order, 'price');
730
+ const filled = this.safeString(order, 'filledSize');
731
+ const amount = this.safeString(order, 'size');
732
+ const rawType = this.safeString(order, 'type');
733
+ const status = this.parseWsOrderStatus(rawType);
734
+ const timestamp = this.safeIntegerProduct(order, 'orderTime', 0.000001);
735
+ const marketId = this.safeString(order, 'symbol');
736
+ market = this.safeMarket(marketId, market);
737
+ const symbol = market['symbol'];
738
+ const side = this.safeStringLower(order, 'side');
739
+ return this.safeOrder({
740
+ 'info': order,
741
+ 'symbol': symbol,
742
+ 'id': id,
743
+ 'clientOrderId': clientOrderId,
744
+ 'timestamp': timestamp,
745
+ 'datetime': this.iso8601(timestamp),
746
+ 'lastTradeTimestamp': undefined,
747
+ 'type': orderType,
748
+ 'timeInForce': undefined,
749
+ 'postOnly': undefined,
750
+ 'side': side,
751
+ 'price': price,
752
+ 'stopPrice': undefined,
753
+ 'amount': amount,
754
+ 'cost': undefined,
755
+ 'average': undefined,
756
+ 'filled': filled,
757
+ 'remaining': undefined,
758
+ 'status': status,
759
+ 'fee': undefined,
760
+ 'trades': undefined,
761
+ }, market);
762
+ }
763
+ handleOrder(client, message) {
764
+ const messageHash = 'orders';
765
+ const data = this.safeValue(message, 'data');
766
+ const parsed = this.parseWsOrder(data);
767
+ const symbol = this.safeString(parsed, 'symbol');
768
+ const orderId = this.safeString(parsed, 'id');
769
+ if (symbol !== undefined) {
770
+ if (this.orders === undefined) {
771
+ const limit = this.safeInteger(this.options, 'ordersLimit', 1000);
772
+ this.orders = new Cache.ArrayCacheBySymbolById(limit);
773
+ }
774
+ const cachedOrders = this.orders;
775
+ const orders = this.safeValue(cachedOrders.hashmap, symbol, {});
776
+ const order = this.safeValue(orders, orderId);
777
+ if (order !== undefined) {
778
+ // todo add others to calculate average etc
779
+ const stopPrice = this.safeValue(order, 'stopPrice');
780
+ if (stopPrice !== undefined) {
781
+ parsed['stopPrice'] = stopPrice;
782
+ }
783
+ if (order['status'] === 'closed') {
784
+ parsed['status'] = 'closed';
785
+ }
786
+ }
787
+ cachedOrders.append(parsed);
788
+ client.resolve(this.orders, messageHash);
789
+ const symbolSpecificMessageHash = messageHash + ':' + symbol;
790
+ client.resolve(this.orders, symbolSpecificMessageHash);
791
+ }
792
+ }
793
+ async watchBalance(params = {}) {
794
+ /**
795
+ * @method
796
+ * @name kucoinfutures#watchBalance
797
+ * @description watch balance and get the amount of funds available for trading or funds locked in orders
798
+ * @see https://docs.kucoin.com/futures/#account-balance-events
799
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
800
+ * @returns {object} a [balance structure]{@link https://docs.ccxt.com/#/?id=balance-structure}
801
+ */
802
+ await this.loadMarkets();
803
+ const url = await this.negotiate(true);
804
+ const topic = '/contractAccount/wallet';
805
+ const request = {
806
+ 'privateChannel': true,
807
+ };
808
+ const subscription = {
809
+ 'method': this.handleBalanceSubscription,
810
+ };
811
+ const messageHash = 'balance';
812
+ return await this.subscribe(url, messageHash, topic, subscription, this.extend(request, params));
813
+ }
814
+ handleBalance(client, message) {
815
+ //
816
+ // {
817
+ // "id": "6375553193027a0001f6566f",
818
+ // "type": "message",
819
+ // "topic": "/contractAccount/wallet",
820
+ // "userId": "613a896885d8660006151f01",
821
+ // "channelType": "private",
822
+ // "subject": "availableBalance.change",
823
+ // "data": {
824
+ // "currency": "USDT",
825
+ // "holdBalance": "0.0000000000",
826
+ // "availableBalance": "14.0350281903",
827
+ // "timestamp": "1668633905657"
828
+ // }
829
+ // }
830
+ //
831
+ const data = this.safeValue(message, 'data', {});
832
+ this.balance['info'] = data;
833
+ const currencyId = this.safeString(data, 'currency');
834
+ const code = this.safeCurrencyCode(currencyId);
835
+ const account = this.account();
836
+ account['free'] = this.safeString(data, 'availableBalance');
837
+ account['used'] = this.safeString(data, 'holdBalance');
838
+ this.balance[code] = account;
839
+ this.balance = this.safeBalance(this.balance);
840
+ client.resolve(this.balance, 'balance');
841
+ }
842
+ handleBalanceSubscription(client, message, subscription) {
843
+ this.spawn(this.fetchBalanceSnapshot, client, message);
844
+ }
845
+ async fetchBalanceSnapshot(client, message) {
846
+ await this.loadMarkets();
847
+ this.checkRequiredCredentials();
848
+ const messageHash = 'balance';
849
+ const selectedType = this.safeString2(this.options, 'watchBalance', 'defaultType', 'swap'); // spot, margin, main, funding, future, mining, trade, contract, pool
850
+ const params = {
851
+ 'type': selectedType,
852
+ };
853
+ const snapshot = await this.fetchBalance(params);
854
+ //
855
+ // {
856
+ // "info": {
857
+ // "code": "200000",
858
+ // "data": {
859
+ // "accountEquity": 0.0350281903,
860
+ // "unrealisedPNL": 0,
861
+ // "marginBalance": 0.0350281903,
862
+ // "positionMargin": 0,
863
+ // "orderMargin": 0,
864
+ // "frozenFunds": 0,
865
+ // "availableBalance": 0.0350281903,
866
+ // "currency": "USDT"
867
+ // }
868
+ // },
869
+ // "timestamp": undefined,
870
+ // "datetime": undefined,
871
+ // "USDT": {
872
+ // "free": 0.0350281903,
873
+ // "used": 0,
874
+ // "total": 0.0350281903
875
+ // },
876
+ // "free": {
877
+ // "USDT": 0.0350281903
878
+ // },
879
+ // "used": {
880
+ // "USDT": 0
881
+ // },
882
+ // "total": {
883
+ // "USDT": 0.0350281903
884
+ // }
885
+ // }
886
+ //
887
+ const keys = Object.keys(snapshot);
888
+ for (let i = 0; i < keys.length; i++) {
889
+ const code = keys[i];
890
+ if (code !== 'free' && code !== 'used' && code !== 'total' && code !== 'timestamp' && code !== 'datetime' && code !== 'info') {
891
+ this.balance[code] = snapshot[code];
892
+ }
893
+ }
894
+ this.balance['info'] = this.safeValue(snapshot, 'info', {});
895
+ client.resolve(this.balance, messageHash);
896
+ }
897
+ handleSubject(client, message) {
898
+ //
899
+ // {
900
+ // "type": "message",
901
+ // "topic": "/contractMarket/level2:ADAUSDTM",
902
+ // "subject": "level2",
903
+ // "data": {
904
+ // "sequence": 1668059586457,
905
+ // "change": "0.34172,sell,456", // type, side, quantity
906
+ // "timestamp": 1668573023223
907
+ // }
908
+ // }
909
+ //
910
+ const subject = this.safeString(message, 'subject');
911
+ const methods = {
912
+ 'level2': this.handleOrderBook,
913
+ 'tickerV2': this.handleTicker,
914
+ 'availableBalance.change': this.handleBalance,
915
+ 'match': this.handleTrade,
916
+ 'orderChange': this.handleOrder,
917
+ 'orderUpdated': this.handleOrder,
918
+ 'position.change': this.handlePosition,
919
+ 'position.settlement': this.handlePosition,
920
+ 'position.adjustRiskLimit': this.handlePosition,
921
+ };
922
+ const method = this.safeValue(methods, subject);
923
+ if (method === undefined) {
924
+ return message;
925
+ }
926
+ else {
927
+ return method.call(this, client, message);
928
+ }
929
+ }
930
+ ping(client) {
931
+ // kucoin does not support built-in ws protocol-level ping-pong
932
+ // instead it requires a custom json-based text ping-pong
933
+ // https://docs.kucoin.com/#ping
934
+ const id = this.requestId().toString();
935
+ return {
936
+ 'id': id,
937
+ 'type': 'ping',
938
+ };
939
+ }
940
+ handlePong(client, message) {
941
+ // https://docs.kucoin.com/#ping
942
+ client.lastPong = this.milliseconds();
943
+ return message;
944
+ }
945
+ handleErrorMessage(client, message) {
946
+ //
947
+ // {
948
+ // "id": "64d8732c856851144bded10d",
949
+ // "type": "error",
950
+ // "code": 401,
951
+ // "data": "token is expired"
952
+ // }
953
+ //
954
+ const data = this.safeString(message, 'data', '');
955
+ if (data === 'token is expired') {
956
+ let type = 'public';
957
+ if (client.url.indexOf('connectId=private') >= 0) {
958
+ type = 'private';
959
+ }
960
+ this.options['urls'][type] = undefined;
961
+ }
962
+ this.handleErrors(undefined, undefined, client.url, undefined, undefined, data, message, undefined, undefined);
963
+ }
964
+ handleMessage(client, message) {
965
+ const type = this.safeString(message, 'type');
966
+ const methods = {
967
+ // 'heartbeat': this.handleHeartbeat,
968
+ 'welcome': this.handleSystemStatus,
969
+ 'ack': this.handleSubscriptionStatus,
970
+ 'message': this.handleSubject,
971
+ 'pong': this.handlePong,
972
+ 'error': this.handleErrorMessage,
973
+ };
974
+ const method = this.safeValue(methods, type);
975
+ if (method !== undefined) {
976
+ return method.call(this, client, message);
977
+ }
978
+ }
979
+ }
980
+
981
+ module.exports = kucoinfutures;