ccxt-ir 4.3.46.0.1__py2.py3-none-any.whl

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 (772) hide show
  1. ccxt/__init__.py +358 -0
  2. ccxt/abantether.py +316 -0
  3. ccxt/abstract/__init__.py +0 -0
  4. ccxt/abstract/abantether.py +5 -0
  5. ccxt/abstract/ace.py +15 -0
  6. ccxt/abstract/afratether.py +6 -0
  7. ccxt/abstract/alpaca.py +70 -0
  8. ccxt/abstract/arzinja.py +5 -0
  9. ccxt/abstract/arzplus.py +7 -0
  10. ccxt/abstract/ascendex.py +77 -0
  11. ccxt/abstract/bequant.py +115 -0
  12. ccxt/abstract/bigone.py +45 -0
  13. ccxt/abstract/binance.py +712 -0
  14. ccxt/abstract/binancecoinm.py +712 -0
  15. ccxt/abstract/binanceus.py +764 -0
  16. ccxt/abstract/binanceusdm.py +712 -0
  17. ccxt/abstract/bingx.py +113 -0
  18. ccxt/abstract/bit2c.py +27 -0
  19. ccxt/abstract/bitbank.py +27 -0
  20. ccxt/abstract/bitbay.py +53 -0
  21. ccxt/abstract/bitbns.py +40 -0
  22. ccxt/abstract/bitcoincom.py +115 -0
  23. ccxt/abstract/bitfinex.py +69 -0
  24. ccxt/abstract/bitfinex2.py +139 -0
  25. ccxt/abstract/bitflyer.py +38 -0
  26. ccxt/abstract/bitget.py +508 -0
  27. ccxt/abstract/bithumb.py +32 -0
  28. ccxt/abstract/bitimen.py +7 -0
  29. ccxt/abstract/bitir.py +7 -0
  30. ccxt/abstract/bitmart.py +99 -0
  31. ccxt/abstract/bitmex.py +97 -0
  32. ccxt/abstract/bitopro.py +29 -0
  33. ccxt/abstract/bitpanda.py +35 -0
  34. ccxt/abstract/bitpin.py +7 -0
  35. ccxt/abstract/bitrue.py +72 -0
  36. ccxt/abstract/bitso.py +43 -0
  37. ccxt/abstract/bitstamp.py +258 -0
  38. ccxt/abstract/bitteam.py +29 -0
  39. ccxt/abstract/bitvavo.py +27 -0
  40. ccxt/abstract/bl3p.py +19 -0
  41. ccxt/abstract/blockchaincom.py +28 -0
  42. ccxt/abstract/blofin.py +37 -0
  43. ccxt/abstract/btcalpha.py +18 -0
  44. ccxt/abstract/btcbox.py +13 -0
  45. ccxt/abstract/btcmarkets.py +39 -0
  46. ccxt/abstract/btcturk.py +20 -0
  47. ccxt/abstract/bybit.py +298 -0
  48. ccxt/abstract/cex.py +33 -0
  49. ccxt/abstract/coinbase.py +94 -0
  50. ccxt/abstract/coinbaseadvanced.py +94 -0
  51. ccxt/abstract/coinbaseexchange.py +67 -0
  52. ccxt/abstract/coinbaseinternational.py +39 -0
  53. ccxt/abstract/coincatch.py +94 -0
  54. ccxt/abstract/coincheck.py +33 -0
  55. ccxt/abstract/coinex.py +237 -0
  56. ccxt/abstract/coinlist.py +54 -0
  57. ccxt/abstract/coinmate.py +62 -0
  58. ccxt/abstract/coinmetro.py +34 -0
  59. ccxt/abstract/coinone.py +67 -0
  60. ccxt/abstract/coinsph.py +54 -0
  61. ccxt/abstract/coinspot.py +28 -0
  62. ccxt/abstract/cryptocom.py +107 -0
  63. ccxt/abstract/currencycom.py +68 -0
  64. ccxt/abstract/delta.py +50 -0
  65. ccxt/abstract/deribit.py +125 -0
  66. ccxt/abstract/digifinex.py +91 -0
  67. ccxt/abstract/eterex.py +5 -0
  68. ccxt/abstract/excoino.py +7 -0
  69. ccxt/abstract/exir.py +8 -0
  70. ccxt/abstract/exmo.py +55 -0
  71. ccxt/abstract/exnovin.py +6 -0
  72. ccxt/abstract/farhadexchange.py +5 -0
  73. ccxt/abstract/fmfwio.py +115 -0
  74. ccxt/abstract/gate.py +265 -0
  75. ccxt/abstract/gateio.py +265 -0
  76. ccxt/abstract/gemini.py +58 -0
  77. ccxt/abstract/hashkey.py +67 -0
  78. ccxt/abstract/hitbtc.py +115 -0
  79. ccxt/abstract/hitbtc3.py +115 -0
  80. ccxt/abstract/hitobit.py +8 -0
  81. ccxt/abstract/hollaex.py +33 -0
  82. ccxt/abstract/htx.py +548 -0
  83. ccxt/abstract/huobi.py +548 -0
  84. ccxt/abstract/huobijp.py +114 -0
  85. ccxt/abstract/hyperliquid.py +6 -0
  86. ccxt/abstract/idex.py +26 -0
  87. ccxt/abstract/independentreserve.py +37 -0
  88. ccxt/abstract/indodax.py +26 -0
  89. ccxt/abstract/jibitex.py +7 -0
  90. ccxt/abstract/kraken.py +57 -0
  91. ccxt/abstract/krakenfutures.py +38 -0
  92. ccxt/abstract/kucoin.py +214 -0
  93. ccxt/abstract/kucoinfutures.py +233 -0
  94. ccxt/abstract/kuna.py +182 -0
  95. ccxt/abstract/latoken.py +56 -0
  96. ccxt/abstract/lbank.py +61 -0
  97. ccxt/abstract/luno.py +37 -0
  98. ccxt/abstract/lykke.py +29 -0
  99. ccxt/abstract/mercado.py +25 -0
  100. ccxt/abstract/mexc.py +178 -0
  101. ccxt/abstract/ndax.py +97 -0
  102. ccxt/abstract/nobitex.py +7 -0
  103. ccxt/abstract/novadax.py +29 -0
  104. ccxt/abstract/oceanex.py +22 -0
  105. ccxt/abstract/okcoin.py +74 -0
  106. ccxt/abstract/okexchange.py +8 -0
  107. ccxt/abstract/okx.py +324 -0
  108. ccxt/abstract/ompfinex.py +7 -0
  109. ccxt/abstract/onetrading.py +35 -0
  110. ccxt/abstract/oxfun.py +34 -0
  111. ccxt/abstract/p2b.py +22 -0
  112. ccxt/abstract/paradex.py +40 -0
  113. ccxt/abstract/paymium.py +28 -0
  114. ccxt/abstract/phemex.py +115 -0
  115. ccxt/abstract/poloniex.py +69 -0
  116. ccxt/abstract/poloniexfutures.py +48 -0
  117. ccxt/abstract/probit.py +23 -0
  118. ccxt/abstract/ramzinex.py +7 -0
  119. ccxt/abstract/sarmayex.py +5 -0
  120. ccxt/abstract/sarrafex.py +7 -0
  121. ccxt/abstract/tabdeal.py +7 -0
  122. ccxt/abstract/tetherland.py +5 -0
  123. ccxt/abstract/timex.py +62 -0
  124. ccxt/abstract/tokocrypto.py +37 -0
  125. ccxt/abstract/tradeogre.py +16 -0
  126. ccxt/abstract/twox.py +5 -0
  127. ccxt/abstract/ubitex.py +7 -0
  128. ccxt/abstract/upbit.py +38 -0
  129. ccxt/abstract/vertex.py +19 -0
  130. ccxt/abstract/wallex.py +8 -0
  131. ccxt/abstract/wavesexchange.py +154 -0
  132. ccxt/abstract/wazirx.py +30 -0
  133. ccxt/abstract/whitebit.py +98 -0
  134. ccxt/abstract/woo.py +83 -0
  135. ccxt/abstract/woofipro.py +119 -0
  136. ccxt/abstract/xt.py +152 -0
  137. ccxt/abstract/yobit.py +16 -0
  138. ccxt/abstract/zaif.py +38 -0
  139. ccxt/abstract/zonda.py +53 -0
  140. ccxt/ace.py +1012 -0
  141. ccxt/afratether.py +293 -0
  142. ccxt/alpaca.py +1083 -0
  143. ccxt/arzinja.py +285 -0
  144. ccxt/arzplus.py +412 -0
  145. ccxt/ascendex.py +3330 -0
  146. ccxt/async_support/__init__.py +337 -0
  147. ccxt/async_support/abantether.py +316 -0
  148. ccxt/async_support/ace.py +1012 -0
  149. ccxt/async_support/afratether.py +293 -0
  150. ccxt/async_support/alpaca.py +1083 -0
  151. ccxt/async_support/arzinja.py +285 -0
  152. ccxt/async_support/arzplus.py +412 -0
  153. ccxt/async_support/ascendex.py +3330 -0
  154. ccxt/async_support/base/__init__.py +1 -0
  155. ccxt/async_support/base/exchange.py +1966 -0
  156. ccxt/async_support/base/throttler.py +50 -0
  157. ccxt/async_support/base/ws/__init__.py +38 -0
  158. ccxt/async_support/base/ws/aiohttp_client.py +125 -0
  159. ccxt/async_support/base/ws/cache.py +212 -0
  160. ccxt/async_support/base/ws/client.py +193 -0
  161. ccxt/async_support/base/ws/fast_client.py +96 -0
  162. ccxt/async_support/base/ws/functions.py +59 -0
  163. ccxt/async_support/base/ws/future.py +58 -0
  164. ccxt/async_support/base/ws/order_book.py +78 -0
  165. ccxt/async_support/base/ws/order_book_side.py +174 -0
  166. ccxt/async_support/bequant.py +33 -0
  167. ccxt/async_support/bigone.py +2113 -0
  168. ccxt/async_support/binance.py +12234 -0
  169. ccxt/async_support/binancecoinm.py +45 -0
  170. ccxt/async_support/binanceus.py +211 -0
  171. ccxt/async_support/binanceusdm.py +58 -0
  172. ccxt/async_support/bingx.py +4325 -0
  173. ccxt/async_support/bit2c.py +866 -0
  174. ccxt/async_support/bitbank.py +1001 -0
  175. ccxt/async_support/bitbay.py +17 -0
  176. ccxt/async_support/bitbns.py +1154 -0
  177. ccxt/async_support/bitcoincom.py +17 -0
  178. ccxt/async_support/bitfinex.py +1617 -0
  179. ccxt/async_support/bitfinex2.py +3552 -0
  180. ccxt/async_support/bitflyer.py +995 -0
  181. ccxt/async_support/bitget.py +8273 -0
  182. ccxt/async_support/bithumb.py +1061 -0
  183. ccxt/async_support/bitimen.py +401 -0
  184. ccxt/async_support/bitir.py +490 -0
  185. ccxt/async_support/bitmart.py +4415 -0
  186. ccxt/async_support/bitmex.py +2756 -0
  187. ccxt/async_support/bitopro.py +1630 -0
  188. ccxt/async_support/bitpanda.py +16 -0
  189. ccxt/async_support/bitpin.py +454 -0
  190. ccxt/async_support/bitrue.py +3027 -0
  191. ccxt/async_support/bitso.py +1670 -0
  192. ccxt/async_support/bitstamp.py +2203 -0
  193. ccxt/async_support/bitteam.py +2239 -0
  194. ccxt/async_support/bitvavo.py +1968 -0
  195. ccxt/async_support/bl3p.py +485 -0
  196. ccxt/async_support/blockchaincom.py +1104 -0
  197. ccxt/async_support/blofin.py +2066 -0
  198. ccxt/async_support/btcalpha.py +891 -0
  199. ccxt/async_support/btcbox.py +544 -0
  200. ccxt/async_support/btcmarkets.py +1221 -0
  201. ccxt/async_support/btcturk.py +911 -0
  202. ccxt/async_support/bybit.py +8159 -0
  203. ccxt/async_support/cex.py +1605 -0
  204. ccxt/async_support/coinbase.py +4475 -0
  205. ccxt/async_support/coinbaseadvanced.py +17 -0
  206. ccxt/async_support/coinbaseexchange.py +1734 -0
  207. ccxt/async_support/coinbaseinternational.py +1899 -0
  208. ccxt/async_support/coincatch.py +5069 -0
  209. ccxt/async_support/coincheck.py +815 -0
  210. ccxt/async_support/coinex.py +5526 -0
  211. ccxt/async_support/coinlist.py +2243 -0
  212. ccxt/async_support/coinmate.py +1067 -0
  213. ccxt/async_support/coinmetro.py +1797 -0
  214. ccxt/async_support/coinone.py +1127 -0
  215. ccxt/async_support/coinsph.py +1850 -0
  216. ccxt/async_support/coinspot.py +534 -0
  217. ccxt/async_support/cryptocom.py +2822 -0
  218. ccxt/async_support/currencycom.py +1950 -0
  219. ccxt/async_support/delta.py +3376 -0
  220. ccxt/async_support/deribit.py +3437 -0
  221. ccxt/async_support/digifinex.py +3960 -0
  222. ccxt/async_support/eterex.py +286 -0
  223. ccxt/async_support/excoino.py +399 -0
  224. ccxt/async_support/exir.py +375 -0
  225. ccxt/async_support/exmo.py +2462 -0
  226. ccxt/async_support/exnovin.py +360 -0
  227. ccxt/async_support/farhadexchange.py +266 -0
  228. ccxt/async_support/fmfwio.py +34 -0
  229. ccxt/async_support/gate.py +6976 -0
  230. ccxt/async_support/gateio.py +16 -0
  231. ccxt/async_support/gemini.py +1825 -0
  232. ccxt/async_support/hashkey.py +4150 -0
  233. ccxt/async_support/hitbtc.py +3423 -0
  234. ccxt/async_support/hitbtc3.py +16 -0
  235. ccxt/async_support/hitobit.py +391 -0
  236. ccxt/async_support/hollaex.py +1813 -0
  237. ccxt/async_support/htx.py +8506 -0
  238. ccxt/async_support/huobi.py +16 -0
  239. ccxt/async_support/huobijp.py +1801 -0
  240. ccxt/async_support/hyperliquid.py +2431 -0
  241. ccxt/async_support/idex.py +1766 -0
  242. ccxt/async_support/independentreserve.py +784 -0
  243. ccxt/async_support/indodax.py +1247 -0
  244. ccxt/async_support/jibitex.py +395 -0
  245. ccxt/async_support/kraken.py +2894 -0
  246. ccxt/async_support/krakenfutures.py +2601 -0
  247. ccxt/async_support/kucoin.py +4602 -0
  248. ccxt/async_support/kucoinfutures.py +2698 -0
  249. ccxt/async_support/kuna.py +1841 -0
  250. ccxt/async_support/latoken.py +1664 -0
  251. ccxt/async_support/lbank.py +2683 -0
  252. ccxt/async_support/luno.py +1067 -0
  253. ccxt/async_support/lykke.py +1270 -0
  254. ccxt/async_support/mercado.py +842 -0
  255. ccxt/async_support/mexc.py +5369 -0
  256. ccxt/async_support/ndax.py +2354 -0
  257. ccxt/async_support/nobitex.py +419 -0
  258. ccxt/async_support/novadax.py +1484 -0
  259. ccxt/async_support/oceanex.py +903 -0
  260. ccxt/async_support/okcoin.py +2936 -0
  261. ccxt/async_support/okexchange.py +349 -0
  262. ccxt/async_support/okx.py +7827 -0
  263. ccxt/async_support/ompfinex.py +472 -0
  264. ccxt/async_support/onetrading.py +1911 -0
  265. ccxt/async_support/oxfun.py +2773 -0
  266. ccxt/async_support/p2b.py +1194 -0
  267. ccxt/async_support/paradex.py +2015 -0
  268. ccxt/async_support/paymium.py +564 -0
  269. ccxt/async_support/phemex.py +4473 -0
  270. ccxt/async_support/poloniex.py +2232 -0
  271. ccxt/async_support/poloniexfutures.py +1717 -0
  272. ccxt/async_support/probit.py +1734 -0
  273. ccxt/async_support/ramzinex.py +476 -0
  274. ccxt/async_support/sarmayex.py +357 -0
  275. ccxt/async_support/sarrafex.py +478 -0
  276. ccxt/async_support/tabdeal.py +364 -0
  277. ccxt/async_support/tetherland.py +349 -0
  278. ccxt/async_support/timex.py +1593 -0
  279. ccxt/async_support/tokocrypto.py +2405 -0
  280. ccxt/async_support/tradeogre.py +608 -0
  281. ccxt/async_support/twox.py +326 -0
  282. ccxt/async_support/ubitex.py +409 -0
  283. ccxt/async_support/upbit.py +1833 -0
  284. ccxt/async_support/vertex.py +2922 -0
  285. ccxt/async_support/wallex.py +445 -0
  286. ccxt/async_support/wavesexchange.py +2473 -0
  287. ccxt/async_support/wazirx.py +1224 -0
  288. ccxt/async_support/whitebit.py +2469 -0
  289. ccxt/async_support/woo.py +3114 -0
  290. ccxt/async_support/woofipro.py +2533 -0
  291. ccxt/async_support/xt.py +4454 -0
  292. ccxt/async_support/yobit.py +1283 -0
  293. ccxt/async_support/zaif.py +725 -0
  294. ccxt/async_support/zonda.py +1828 -0
  295. ccxt/base/__init__.py +27 -0
  296. ccxt/base/decimal_to_precision.py +174 -0
  297. ccxt/base/errors.py +242 -0
  298. ccxt/base/exchange.py +5941 -0
  299. ccxt/base/precise.py +287 -0
  300. ccxt/base/types.py +502 -0
  301. ccxt/bequant.py +33 -0
  302. ccxt/bigone.py +2112 -0
  303. ccxt/binance.py +12233 -0
  304. ccxt/binancecoinm.py +45 -0
  305. ccxt/binanceus.py +211 -0
  306. ccxt/binanceusdm.py +58 -0
  307. ccxt/bingx.py +4324 -0
  308. ccxt/bit2c.py +866 -0
  309. ccxt/bitbank.py +1001 -0
  310. ccxt/bitbay.py +17 -0
  311. ccxt/bitbns.py +1154 -0
  312. ccxt/bitcoincom.py +17 -0
  313. ccxt/bitfinex.py +1617 -0
  314. ccxt/bitfinex2.py +3552 -0
  315. ccxt/bitflyer.py +995 -0
  316. ccxt/bitget.py +8272 -0
  317. ccxt/bithumb.py +1061 -0
  318. ccxt/bitimen.py +401 -0
  319. ccxt/bitir.py +490 -0
  320. ccxt/bitmart.py +4415 -0
  321. ccxt/bitmex.py +2756 -0
  322. ccxt/bitopro.py +1630 -0
  323. ccxt/bitpanda.py +16 -0
  324. ccxt/bitpin.py +454 -0
  325. ccxt/bitrue.py +3026 -0
  326. ccxt/bitso.py +1670 -0
  327. ccxt/bitstamp.py +2203 -0
  328. ccxt/bitteam.py +2239 -0
  329. ccxt/bitvavo.py +1968 -0
  330. ccxt/bl3p.py +485 -0
  331. ccxt/blockchaincom.py +1104 -0
  332. ccxt/blofin.py +2066 -0
  333. ccxt/btcalpha.py +891 -0
  334. ccxt/btcbox.py +544 -0
  335. ccxt/btcmarkets.py +1221 -0
  336. ccxt/btcturk.py +911 -0
  337. ccxt/bybit.py +8158 -0
  338. ccxt/cex.py +1605 -0
  339. ccxt/coinbase.py +4474 -0
  340. ccxt/coinbaseadvanced.py +17 -0
  341. ccxt/coinbaseexchange.py +1734 -0
  342. ccxt/coinbaseinternational.py +1899 -0
  343. ccxt/coincatch.py +5069 -0
  344. ccxt/coincheck.py +815 -0
  345. ccxt/coinex.py +5525 -0
  346. ccxt/coinlist.py +2243 -0
  347. ccxt/coinmate.py +1067 -0
  348. ccxt/coinmetro.py +1797 -0
  349. ccxt/coinone.py +1127 -0
  350. ccxt/coinsph.py +1850 -0
  351. ccxt/coinspot.py +534 -0
  352. ccxt/cryptocom.py +2822 -0
  353. ccxt/currencycom.py +1950 -0
  354. ccxt/delta.py +3376 -0
  355. ccxt/deribit.py +3437 -0
  356. ccxt/digifinex.py +3959 -0
  357. ccxt/eterex.py +286 -0
  358. ccxt/excoino.py +399 -0
  359. ccxt/exir.py +375 -0
  360. ccxt/exmo.py +2462 -0
  361. ccxt/exnovin.py +360 -0
  362. ccxt/farhadexchange.py +266 -0
  363. ccxt/fmfwio.py +34 -0
  364. ccxt/gate.py +6975 -0
  365. ccxt/gateio.py +16 -0
  366. ccxt/gemini.py +1824 -0
  367. ccxt/hashkey.py +4150 -0
  368. ccxt/hitbtc.py +3423 -0
  369. ccxt/hitbtc3.py +16 -0
  370. ccxt/hitobit.py +391 -0
  371. ccxt/hollaex.py +1813 -0
  372. ccxt/htx.py +8505 -0
  373. ccxt/huobi.py +16 -0
  374. ccxt/huobijp.py +1801 -0
  375. ccxt/hyperliquid.py +2430 -0
  376. ccxt/idex.py +1766 -0
  377. ccxt/independentreserve.py +784 -0
  378. ccxt/indodax.py +1247 -0
  379. ccxt/jibitex.py +395 -0
  380. ccxt/kraken.py +2894 -0
  381. ccxt/krakenfutures.py +2601 -0
  382. ccxt/kucoin.py +4601 -0
  383. ccxt/kucoinfutures.py +2698 -0
  384. ccxt/kuna.py +1841 -0
  385. ccxt/latoken.py +1664 -0
  386. ccxt/lbank.py +2682 -0
  387. ccxt/luno.py +1067 -0
  388. ccxt/lykke.py +1270 -0
  389. ccxt/mercado.py +842 -0
  390. ccxt/mexc.py +5369 -0
  391. ccxt/ndax.py +2354 -0
  392. ccxt/nobitex.py +419 -0
  393. ccxt/novadax.py +1484 -0
  394. ccxt/oceanex.py +903 -0
  395. ccxt/okcoin.py +2936 -0
  396. ccxt/okexchange.py +349 -0
  397. ccxt/okx.py +7826 -0
  398. ccxt/ompfinex.py +472 -0
  399. ccxt/onetrading.py +1911 -0
  400. ccxt/oxfun.py +2772 -0
  401. ccxt/p2b.py +1194 -0
  402. ccxt/paradex.py +2015 -0
  403. ccxt/paymium.py +564 -0
  404. ccxt/phemex.py +4473 -0
  405. ccxt/poloniex.py +2232 -0
  406. ccxt/poloniexfutures.py +1717 -0
  407. ccxt/pro/__init__.py +149 -0
  408. ccxt/pro/alpaca.py +685 -0
  409. ccxt/pro/ascendex.py +916 -0
  410. ccxt/pro/bequant.py +38 -0
  411. ccxt/pro/binance.py +3488 -0
  412. ccxt/pro/binancecoinm.py +28 -0
  413. ccxt/pro/binanceus.py +48 -0
  414. ccxt/pro/binanceusdm.py +31 -0
  415. ccxt/pro/bingx.py +1264 -0
  416. ccxt/pro/bitcoincom.py +34 -0
  417. ccxt/pro/bitfinex.py +621 -0
  418. ccxt/pro/bitfinex2.py +1083 -0
  419. ccxt/pro/bitget.py +1692 -0
  420. ccxt/pro/bithumb.py +368 -0
  421. ccxt/pro/bitmart.py +1449 -0
  422. ccxt/pro/bitmex.py +1656 -0
  423. ccxt/pro/bitopro.py +445 -0
  424. ccxt/pro/bitpanda.py +15 -0
  425. ccxt/pro/bitrue.py +447 -0
  426. ccxt/pro/bitstamp.py +522 -0
  427. ccxt/pro/bitvavo.py +1270 -0
  428. ccxt/pro/blockchaincom.py +738 -0
  429. ccxt/pro/blofin.py +692 -0
  430. ccxt/pro/bybit.py +2000 -0
  431. ccxt/pro/cex.py +1440 -0
  432. ccxt/pro/coinbase.py +678 -0
  433. ccxt/pro/coinbaseadvanced.py +16 -0
  434. ccxt/pro/coinbaseexchange.py +895 -0
  435. ccxt/pro/coinbaseinternational.py +620 -0
  436. ccxt/pro/coincatch.py +1464 -0
  437. ccxt/pro/coincheck.py +199 -0
  438. ccxt/pro/coinex.py +1061 -0
  439. ccxt/pro/coinone.py +395 -0
  440. ccxt/pro/cryptocom.py +947 -0
  441. ccxt/pro/currencycom.py +536 -0
  442. ccxt/pro/deribit.py +892 -0
  443. ccxt/pro/exmo.py +629 -0
  444. ccxt/pro/gate.py +1416 -0
  445. ccxt/pro/gateio.py +15 -0
  446. ccxt/pro/gemini.py +865 -0
  447. ccxt/pro/hashkey.py +802 -0
  448. ccxt/pro/hitbtc.py +1216 -0
  449. ccxt/pro/hollaex.py +563 -0
  450. ccxt/pro/htx.py +2215 -0
  451. ccxt/pro/huobi.py +15 -0
  452. ccxt/pro/huobijp.py +570 -0
  453. ccxt/pro/hyperliquid.py +525 -0
  454. ccxt/pro/idex.py +672 -0
  455. ccxt/pro/independentreserve.py +270 -0
  456. ccxt/pro/kraken.py +1356 -0
  457. ccxt/pro/krakenfutures.py +1492 -0
  458. ccxt/pro/kucoin.py +1133 -0
  459. ccxt/pro/kucoinfutures.py +1081 -0
  460. ccxt/pro/lbank.py +843 -0
  461. ccxt/pro/luno.py +303 -0
  462. ccxt/pro/mexc.py +1122 -0
  463. ccxt/pro/ndax.py +506 -0
  464. ccxt/pro/okcoin.py +698 -0
  465. ccxt/pro/okx.py +1851 -0
  466. ccxt/pro/onetrading.py +1275 -0
  467. ccxt/pro/oxfun.py +950 -0
  468. ccxt/pro/p2b.py +419 -0
  469. ccxt/pro/paradex.py +352 -0
  470. ccxt/pro/phemex.py +1441 -0
  471. ccxt/pro/poloniex.py +1166 -0
  472. ccxt/pro/poloniexfutures.py +990 -0
  473. ccxt/pro/probit.py +551 -0
  474. ccxt/pro/upbit.py +520 -0
  475. ccxt/pro/vertex.py +943 -0
  476. ccxt/pro/wazirx.py +749 -0
  477. ccxt/pro/whitebit.py +864 -0
  478. ccxt/pro/woo.py +1078 -0
  479. ccxt/pro/woofipro.py +1183 -0
  480. ccxt/pro/xt.py +1067 -0
  481. ccxt/probit.py +1734 -0
  482. ccxt/ramzinex.py +476 -0
  483. ccxt/sarmayex.py +357 -0
  484. ccxt/sarrafex.py +478 -0
  485. ccxt/static_dependencies/__init__.py +1 -0
  486. ccxt/static_dependencies/ecdsa/__init__.py +14 -0
  487. ccxt/static_dependencies/ecdsa/_version.py +520 -0
  488. ccxt/static_dependencies/ecdsa/curves.py +56 -0
  489. ccxt/static_dependencies/ecdsa/der.py +221 -0
  490. ccxt/static_dependencies/ecdsa/ecdsa.py +310 -0
  491. ccxt/static_dependencies/ecdsa/ellipticcurve.py +197 -0
  492. ccxt/static_dependencies/ecdsa/keys.py +332 -0
  493. ccxt/static_dependencies/ecdsa/numbertheory.py +531 -0
  494. ccxt/static_dependencies/ecdsa/rfc6979.py +100 -0
  495. ccxt/static_dependencies/ecdsa/util.py +266 -0
  496. ccxt/static_dependencies/ethereum/__init__.py +7 -0
  497. ccxt/static_dependencies/ethereum/abi/__init__.py +16 -0
  498. ccxt/static_dependencies/ethereum/abi/abi.py +19 -0
  499. ccxt/static_dependencies/ethereum/abi/base.py +152 -0
  500. ccxt/static_dependencies/ethereum/abi/codec.py +217 -0
  501. ccxt/static_dependencies/ethereum/abi/constants.py +3 -0
  502. ccxt/static_dependencies/ethereum/abi/decoding.py +565 -0
  503. ccxt/static_dependencies/ethereum/abi/encoding.py +720 -0
  504. ccxt/static_dependencies/ethereum/abi/exceptions.py +139 -0
  505. ccxt/static_dependencies/ethereum/abi/grammar.py +443 -0
  506. ccxt/static_dependencies/ethereum/abi/packed.py +13 -0
  507. ccxt/static_dependencies/ethereum/abi/py.typed +0 -0
  508. ccxt/static_dependencies/ethereum/abi/registry.py +643 -0
  509. ccxt/static_dependencies/ethereum/abi/tools/__init__.py +3 -0
  510. ccxt/static_dependencies/ethereum/abi/tools/_strategies.py +230 -0
  511. ccxt/static_dependencies/ethereum/abi/utils/__init__.py +0 -0
  512. ccxt/static_dependencies/ethereum/abi/utils/numeric.py +83 -0
  513. ccxt/static_dependencies/ethereum/abi/utils/padding.py +27 -0
  514. ccxt/static_dependencies/ethereum/abi/utils/string.py +19 -0
  515. ccxt/static_dependencies/ethereum/account/__init__.py +3 -0
  516. ccxt/static_dependencies/ethereum/account/encode_typed_data/__init__.py +4 -0
  517. ccxt/static_dependencies/ethereum/account/encode_typed_data/encoding_and_hashing.py +239 -0
  518. ccxt/static_dependencies/ethereum/account/encode_typed_data/helpers.py +40 -0
  519. ccxt/static_dependencies/ethereum/account/messages.py +263 -0
  520. ccxt/static_dependencies/ethereum/account/py.typed +0 -0
  521. ccxt/static_dependencies/ethereum/hexbytes/__init__.py +5 -0
  522. ccxt/static_dependencies/ethereum/hexbytes/_utils.py +54 -0
  523. ccxt/static_dependencies/ethereum/hexbytes/main.py +65 -0
  524. ccxt/static_dependencies/ethereum/hexbytes/py.typed +0 -0
  525. ccxt/static_dependencies/ethereum/typing/__init__.py +63 -0
  526. ccxt/static_dependencies/ethereum/typing/abi.py +6 -0
  527. ccxt/static_dependencies/ethereum/typing/bls.py +7 -0
  528. ccxt/static_dependencies/ethereum/typing/discovery.py +5 -0
  529. ccxt/static_dependencies/ethereum/typing/encoding.py +7 -0
  530. ccxt/static_dependencies/ethereum/typing/enums.py +17 -0
  531. ccxt/static_dependencies/ethereum/typing/ethpm.py +9 -0
  532. ccxt/static_dependencies/ethereum/typing/evm.py +20 -0
  533. ccxt/static_dependencies/ethereum/typing/networks.py +1122 -0
  534. ccxt/static_dependencies/ethereum/typing/py.typed +0 -0
  535. ccxt/static_dependencies/ethereum/utils/__init__.py +115 -0
  536. ccxt/static_dependencies/ethereum/utils/abi.py +72 -0
  537. ccxt/static_dependencies/ethereum/utils/address.py +171 -0
  538. ccxt/static_dependencies/ethereum/utils/applicators.py +151 -0
  539. ccxt/static_dependencies/ethereum/utils/conversions.py +190 -0
  540. ccxt/static_dependencies/ethereum/utils/currency.py +107 -0
  541. ccxt/static_dependencies/ethereum/utils/curried/__init__.py +269 -0
  542. ccxt/static_dependencies/ethereum/utils/debug.py +20 -0
  543. ccxt/static_dependencies/ethereum/utils/decorators.py +132 -0
  544. ccxt/static_dependencies/ethereum/utils/encoding.py +6 -0
  545. ccxt/static_dependencies/ethereum/utils/exceptions.py +4 -0
  546. ccxt/static_dependencies/ethereum/utils/functional.py +75 -0
  547. ccxt/static_dependencies/ethereum/utils/hexadecimal.py +74 -0
  548. ccxt/static_dependencies/ethereum/utils/humanize.py +188 -0
  549. ccxt/static_dependencies/ethereum/utils/logging.py +159 -0
  550. ccxt/static_dependencies/ethereum/utils/module_loading.py +31 -0
  551. ccxt/static_dependencies/ethereum/utils/numeric.py +43 -0
  552. ccxt/static_dependencies/ethereum/utils/py.typed +0 -0
  553. ccxt/static_dependencies/ethereum/utils/toolz.py +76 -0
  554. ccxt/static_dependencies/ethereum/utils/types.py +54 -0
  555. ccxt/static_dependencies/ethereum/utils/typing/__init__.py +18 -0
  556. ccxt/static_dependencies/ethereum/utils/typing/misc.py +14 -0
  557. ccxt/static_dependencies/ethereum/utils/units.py +31 -0
  558. ccxt/static_dependencies/keccak/__init__.py +3 -0
  559. ccxt/static_dependencies/keccak/keccak.py +197 -0
  560. ccxt/static_dependencies/lark/__init__.py +38 -0
  561. ccxt/static_dependencies/lark/__pyinstaller/__init__.py +6 -0
  562. ccxt/static_dependencies/lark/__pyinstaller/hook-lark.py +14 -0
  563. ccxt/static_dependencies/lark/ast_utils.py +59 -0
  564. ccxt/static_dependencies/lark/common.py +86 -0
  565. ccxt/static_dependencies/lark/exceptions.py +292 -0
  566. ccxt/static_dependencies/lark/grammar.py +130 -0
  567. ccxt/static_dependencies/lark/grammars/__init__.py +0 -0
  568. ccxt/static_dependencies/lark/indenter.py +143 -0
  569. ccxt/static_dependencies/lark/lark.py +658 -0
  570. ccxt/static_dependencies/lark/lexer.py +678 -0
  571. ccxt/static_dependencies/lark/load_grammar.py +1428 -0
  572. ccxt/static_dependencies/lark/parse_tree_builder.py +391 -0
  573. ccxt/static_dependencies/lark/parser_frontends.py +257 -0
  574. ccxt/static_dependencies/lark/parsers/__init__.py +0 -0
  575. ccxt/static_dependencies/lark/parsers/cyk.py +340 -0
  576. ccxt/static_dependencies/lark/parsers/earley.py +314 -0
  577. ccxt/static_dependencies/lark/parsers/earley_common.py +42 -0
  578. ccxt/static_dependencies/lark/parsers/earley_forest.py +801 -0
  579. ccxt/static_dependencies/lark/parsers/grammar_analysis.py +203 -0
  580. ccxt/static_dependencies/lark/parsers/lalr_analysis.py +332 -0
  581. ccxt/static_dependencies/lark/parsers/lalr_interactive_parser.py +158 -0
  582. ccxt/static_dependencies/lark/parsers/lalr_parser.py +122 -0
  583. ccxt/static_dependencies/lark/parsers/lalr_parser_state.py +110 -0
  584. ccxt/static_dependencies/lark/parsers/xearley.py +165 -0
  585. ccxt/static_dependencies/lark/reconstruct.py +107 -0
  586. ccxt/static_dependencies/lark/tools/__init__.py +70 -0
  587. ccxt/static_dependencies/lark/tools/nearley.py +202 -0
  588. ccxt/static_dependencies/lark/tools/serialize.py +32 -0
  589. ccxt/static_dependencies/lark/tools/standalone.py +196 -0
  590. ccxt/static_dependencies/lark/tree.py +267 -0
  591. ccxt/static_dependencies/lark/tree_matcher.py +186 -0
  592. ccxt/static_dependencies/lark/tree_templates.py +180 -0
  593. ccxt/static_dependencies/lark/utils.py +343 -0
  594. ccxt/static_dependencies/lark/visitors.py +596 -0
  595. ccxt/static_dependencies/marshmallow/__init__.py +81 -0
  596. ccxt/static_dependencies/marshmallow/base.py +65 -0
  597. ccxt/static_dependencies/marshmallow/class_registry.py +94 -0
  598. ccxt/static_dependencies/marshmallow/decorators.py +231 -0
  599. ccxt/static_dependencies/marshmallow/error_store.py +60 -0
  600. ccxt/static_dependencies/marshmallow/exceptions.py +71 -0
  601. ccxt/static_dependencies/marshmallow/fields.py +2114 -0
  602. ccxt/static_dependencies/marshmallow/orderedset.py +89 -0
  603. ccxt/static_dependencies/marshmallow/schema.py +1228 -0
  604. ccxt/static_dependencies/marshmallow/types.py +12 -0
  605. ccxt/static_dependencies/marshmallow/utils.py +378 -0
  606. ccxt/static_dependencies/marshmallow/validate.py +678 -0
  607. ccxt/static_dependencies/marshmallow/warnings.py +2 -0
  608. ccxt/static_dependencies/marshmallow_dataclass/__init__.py +1047 -0
  609. ccxt/static_dependencies/marshmallow_dataclass/collection_field.py +51 -0
  610. ccxt/static_dependencies/marshmallow_dataclass/lazy_class_attribute.py +45 -0
  611. ccxt/static_dependencies/marshmallow_dataclass/mypy.py +71 -0
  612. ccxt/static_dependencies/marshmallow_dataclass/typing.py +14 -0
  613. ccxt/static_dependencies/marshmallow_dataclass/union_field.py +82 -0
  614. ccxt/static_dependencies/marshmallow_oneofschema/__init__.py +1 -0
  615. ccxt/static_dependencies/marshmallow_oneofschema/one_of_schema.py +193 -0
  616. ccxt/static_dependencies/msgpack/__init__.py +55 -0
  617. ccxt/static_dependencies/msgpack/exceptions.py +48 -0
  618. ccxt/static_dependencies/msgpack/ext.py +168 -0
  619. ccxt/static_dependencies/msgpack/fallback.py +951 -0
  620. ccxt/static_dependencies/parsimonious/__init__.py +10 -0
  621. ccxt/static_dependencies/parsimonious/exceptions.py +105 -0
  622. ccxt/static_dependencies/parsimonious/expressions.py +479 -0
  623. ccxt/static_dependencies/parsimonious/grammar.py +487 -0
  624. ccxt/static_dependencies/parsimonious/nodes.py +325 -0
  625. ccxt/static_dependencies/parsimonious/utils.py +40 -0
  626. ccxt/static_dependencies/starknet/__init__.py +0 -0
  627. ccxt/static_dependencies/starknet/cairo/__init__.py +0 -0
  628. ccxt/static_dependencies/starknet/cairo/data_types.py +123 -0
  629. ccxt/static_dependencies/starknet/cairo/deprecated_parse/__init__.py +0 -0
  630. ccxt/static_dependencies/starknet/cairo/deprecated_parse/cairo_types.py +77 -0
  631. ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser.py +46 -0
  632. ccxt/static_dependencies/starknet/cairo/deprecated_parse/parser_transformer.py +138 -0
  633. ccxt/static_dependencies/starknet/cairo/felt.py +64 -0
  634. ccxt/static_dependencies/starknet/cairo/type_parser.py +121 -0
  635. ccxt/static_dependencies/starknet/cairo/v1/__init__.py +0 -0
  636. ccxt/static_dependencies/starknet/cairo/v1/type_parser.py +59 -0
  637. ccxt/static_dependencies/starknet/cairo/v2/__init__.py +0 -0
  638. ccxt/static_dependencies/starknet/cairo/v2/type_parser.py +77 -0
  639. ccxt/static_dependencies/starknet/ccxt_utils.py +7 -0
  640. ccxt/static_dependencies/starknet/common.py +15 -0
  641. ccxt/static_dependencies/starknet/constants.py +39 -0
  642. ccxt/static_dependencies/starknet/hash/__init__.py +0 -0
  643. ccxt/static_dependencies/starknet/hash/address.py +79 -0
  644. ccxt/static_dependencies/starknet/hash/compiled_class_hash_objects.py +111 -0
  645. ccxt/static_dependencies/starknet/hash/selector.py +16 -0
  646. ccxt/static_dependencies/starknet/hash/storage.py +12 -0
  647. ccxt/static_dependencies/starknet/hash/utils.py +78 -0
  648. ccxt/static_dependencies/starknet/models/__init__.py +0 -0
  649. ccxt/static_dependencies/starknet/models/typed_data.py +45 -0
  650. ccxt/static_dependencies/starknet/serialization/__init__.py +24 -0
  651. ccxt/static_dependencies/starknet/serialization/_calldata_reader.py +40 -0
  652. ccxt/static_dependencies/starknet/serialization/_context.py +142 -0
  653. ccxt/static_dependencies/starknet/serialization/data_serializers/__init__.py +10 -0
  654. ccxt/static_dependencies/starknet/serialization/data_serializers/_common.py +82 -0
  655. ccxt/static_dependencies/starknet/serialization/data_serializers/array_serializer.py +43 -0
  656. ccxt/static_dependencies/starknet/serialization/data_serializers/bool_serializer.py +37 -0
  657. ccxt/static_dependencies/starknet/serialization/data_serializers/byte_array_serializer.py +66 -0
  658. ccxt/static_dependencies/starknet/serialization/data_serializers/cairo_data_serializer.py +71 -0
  659. ccxt/static_dependencies/starknet/serialization/data_serializers/enum_serializer.py +71 -0
  660. ccxt/static_dependencies/starknet/serialization/data_serializers/felt_serializer.py +50 -0
  661. ccxt/static_dependencies/starknet/serialization/data_serializers/named_tuple_serializer.py +58 -0
  662. ccxt/static_dependencies/starknet/serialization/data_serializers/option_serializer.py +43 -0
  663. ccxt/static_dependencies/starknet/serialization/data_serializers/output_serializer.py +40 -0
  664. ccxt/static_dependencies/starknet/serialization/data_serializers/payload_serializer.py +72 -0
  665. ccxt/static_dependencies/starknet/serialization/data_serializers/struct_serializer.py +36 -0
  666. ccxt/static_dependencies/starknet/serialization/data_serializers/tuple_serializer.py +36 -0
  667. ccxt/static_dependencies/starknet/serialization/data_serializers/uint256_serializer.py +76 -0
  668. ccxt/static_dependencies/starknet/serialization/data_serializers/uint_serializer.py +100 -0
  669. ccxt/static_dependencies/starknet/serialization/data_serializers/unit_serializer.py +32 -0
  670. ccxt/static_dependencies/starknet/serialization/errors.py +10 -0
  671. ccxt/static_dependencies/starknet/serialization/factory.py +229 -0
  672. ccxt/static_dependencies/starknet/serialization/function_serialization_adapter.py +110 -0
  673. ccxt/static_dependencies/starknet/serialization/tuple_dataclass.py +59 -0
  674. ccxt/static_dependencies/starknet/utils/__init__.py +0 -0
  675. ccxt/static_dependencies/starknet/utils/constructor_args_translator.py +86 -0
  676. ccxt/static_dependencies/starknet/utils/iterable.py +13 -0
  677. ccxt/static_dependencies/starknet/utils/schema.py +13 -0
  678. ccxt/static_dependencies/starknet/utils/typed_data.py +182 -0
  679. ccxt/static_dependencies/starkware/__init__.py +0 -0
  680. ccxt/static_dependencies/starkware/crypto/__init__.py +0 -0
  681. ccxt/static_dependencies/starkware/crypto/fast_pedersen_hash.py +50 -0
  682. ccxt/static_dependencies/starkware/crypto/math_utils.py +78 -0
  683. ccxt/static_dependencies/starkware/crypto/signature.py +2344 -0
  684. ccxt/static_dependencies/starkware/crypto/utils.py +63 -0
  685. ccxt/static_dependencies/sympy/__init__.py +0 -0
  686. ccxt/static_dependencies/sympy/core/__init__.py +0 -0
  687. ccxt/static_dependencies/sympy/core/intfunc.py +35 -0
  688. ccxt/static_dependencies/sympy/external/__init__.py +0 -0
  689. ccxt/static_dependencies/sympy/external/gmpy.py +345 -0
  690. ccxt/static_dependencies/sympy/external/importtools.py +187 -0
  691. ccxt/static_dependencies/sympy/external/ntheory.py +637 -0
  692. ccxt/static_dependencies/sympy/external/pythonmpq.py +341 -0
  693. ccxt/static_dependencies/toolz/__init__.py +26 -0
  694. ccxt/static_dependencies/toolz/_signatures.py +784 -0
  695. ccxt/static_dependencies/toolz/_version.py +520 -0
  696. ccxt/static_dependencies/toolz/compatibility.py +30 -0
  697. ccxt/static_dependencies/toolz/curried/__init__.py +101 -0
  698. ccxt/static_dependencies/toolz/curried/exceptions.py +22 -0
  699. ccxt/static_dependencies/toolz/curried/operator.py +22 -0
  700. ccxt/static_dependencies/toolz/dicttoolz.py +339 -0
  701. ccxt/static_dependencies/toolz/functoolz.py +1049 -0
  702. ccxt/static_dependencies/toolz/itertoolz.py +1057 -0
  703. ccxt/static_dependencies/toolz/recipes.py +46 -0
  704. ccxt/static_dependencies/toolz/utils.py +9 -0
  705. ccxt/static_dependencies/typing_inspect/__init__.py +0 -0
  706. ccxt/static_dependencies/typing_inspect/typing_inspect.py +851 -0
  707. ccxt/tabdeal.py +364 -0
  708. ccxt/test/__init__.py +3 -0
  709. ccxt/test/base/__init__.py +29 -0
  710. ccxt/test/base/test_account.py +26 -0
  711. ccxt/test/base/test_balance.py +56 -0
  712. ccxt/test/base/test_borrow_interest.py +35 -0
  713. ccxt/test/base/test_borrow_rate.py +32 -0
  714. ccxt/test/base/test_calculate_fee.py +51 -0
  715. ccxt/test/base/test_crypto.py +127 -0
  716. ccxt/test/base/test_currency.py +76 -0
  717. ccxt/test/base/test_datetime.py +109 -0
  718. ccxt/test/base/test_decimal_to_precision.py +392 -0
  719. ccxt/test/base/test_deep_extend.py +68 -0
  720. ccxt/test/base/test_deposit_withdrawal.py +50 -0
  721. ccxt/test/base/test_exchange_datetime_functions.py +76 -0
  722. ccxt/test/base/test_funding_rate_history.py +29 -0
  723. ccxt/test/base/test_last_price.py +31 -0
  724. ccxt/test/base/test_ledger_entry.py +45 -0
  725. ccxt/test/base/test_ledger_item.py +48 -0
  726. ccxt/test/base/test_leverage_tier.py +33 -0
  727. ccxt/test/base/test_liquidation.py +50 -0
  728. ccxt/test/base/test_margin_mode.py +24 -0
  729. ccxt/test/base/test_margin_modification.py +35 -0
  730. ccxt/test/base/test_market.py +193 -0
  731. ccxt/test/base/test_number.py +411 -0
  732. ccxt/test/base/test_ohlcv.py +33 -0
  733. ccxt/test/base/test_open_interest.py +32 -0
  734. ccxt/test/base/test_order.py +64 -0
  735. ccxt/test/base/test_order_book.py +69 -0
  736. ccxt/test/base/test_position.py +60 -0
  737. ccxt/test/base/test_shared_methods.py +353 -0
  738. ccxt/test/base/test_status.py +24 -0
  739. ccxt/test/base/test_throttle.py +126 -0
  740. ccxt/test/base/test_ticker.py +92 -0
  741. ccxt/test/base/test_trade.py +47 -0
  742. ccxt/test/base/test_trading_fee.py +26 -0
  743. ccxt/test/base/test_transaction.py +39 -0
  744. ccxt/test/test_async.py +1649 -0
  745. ccxt/test/test_sync.py +1648 -0
  746. ccxt/test/tests_async.py +1558 -0
  747. ccxt/test/tests_helpers.py +287 -0
  748. ccxt/test/tests_init.py +39 -0
  749. ccxt/test/tests_sync.py +1555 -0
  750. ccxt/tetherland.py +349 -0
  751. ccxt/timex.py +1593 -0
  752. ccxt/tokocrypto.py +2405 -0
  753. ccxt/tradeogre.py +608 -0
  754. ccxt/twox.py +326 -0
  755. ccxt/ubitex.py +409 -0
  756. ccxt/upbit.py +1833 -0
  757. ccxt/vertex.py +2922 -0
  758. ccxt/wallex.py +445 -0
  759. ccxt/wavesexchange.py +2472 -0
  760. ccxt/wazirx.py +1224 -0
  761. ccxt/whitebit.py +2469 -0
  762. ccxt/woo.py +3114 -0
  763. ccxt/woofipro.py +2533 -0
  764. ccxt/xt.py +4453 -0
  765. ccxt/yobit.py +1283 -0
  766. ccxt/zaif.py +725 -0
  767. ccxt/zonda.py +1828 -0
  768. ccxt_ir-4.3.46.0.1.dist-info/LICENSE.txt +21 -0
  769. ccxt_ir-4.3.46.0.1.dist-info/METADATA +655 -0
  770. ccxt_ir-4.3.46.0.1.dist-info/RECORD +772 -0
  771. ccxt_ir-4.3.46.0.1.dist-info/WHEEL +6 -0
  772. ccxt_ir-4.3.46.0.1.dist-info/top_level.txt +1 -0
ccxt/pro/mexc.py ADDED
@@ -0,0 +1,1122 @@
1
+ # -*- coding: utf-8 -*-
2
+
3
+ # PLEASE DO NOT EDIT THIS FILE, IT IS GENERATED AND WILL BE OVERWRITTEN:
4
+ # https://github.com/ccxt/ccxt/blob/master/CONTRIBUTING.md#how-to-contribute-code
5
+
6
+ import ccxt.async_support
7
+ from ccxt.async_support.base.ws.cache import ArrayCache, ArrayCacheBySymbolById, ArrayCacheByTimestamp
8
+ import hashlib
9
+ from ccxt.base.types import Balances, Int, Order, OrderBook, Str, Ticker, Trade
10
+ from ccxt.async_support.base.ws.client import Client
11
+ from typing import List
12
+ from ccxt.base.errors import AuthenticationError
13
+
14
+
15
+ class mexc(ccxt.async_support.mexc):
16
+
17
+ def describe(self):
18
+ return self.deep_extend(super(mexc, self).describe(), {
19
+ 'has': {
20
+ 'ws': True,
21
+ 'cancelAllOrdersWs': False,
22
+ 'cancelOrdersWs': False,
23
+ 'cancelOrderWs': False,
24
+ 'createOrderWs': False,
25
+ 'editOrderWs': False,
26
+ 'fetchBalanceWs': False,
27
+ 'fetchOpenOrdersWs': False,
28
+ 'fetchOrderWs': False,
29
+ 'fetchTradesWs': False,
30
+ 'watchBalance': True,
31
+ 'watchMyTrades': True,
32
+ 'watchOHLCV': True,
33
+ 'watchOrderBook': True,
34
+ 'watchOrders': True,
35
+ 'watchTicker': True,
36
+ 'watchTickers': False,
37
+ 'watchTrades': True,
38
+ },
39
+ 'urls': {
40
+ 'api': {
41
+ 'ws': {
42
+ 'spot': 'wss://wbs.mexc.com/ws',
43
+ 'swap': 'wss://contract.mexc.com/edge',
44
+ },
45
+ },
46
+ },
47
+ 'options': {
48
+ 'listenKeyRefreshRate': 1200000,
49
+ # TODO add reset connection after #16754 is merged
50
+ 'timeframes': {
51
+ '1m': 'Min1',
52
+ '5m': 'Min5',
53
+ '15m': 'Min15',
54
+ '30m': 'Min30',
55
+ '1h': 'Min60',
56
+ '4h': 'Hour4',
57
+ '8h': 'Hour8',
58
+ '1d': 'Day1',
59
+ '1w': 'Week1',
60
+ '1M': 'Month1',
61
+ },
62
+ 'watchOrderBook': {
63
+ 'snapshotDelay': 25,
64
+ 'snapshotMaxRetries': 3,
65
+ },
66
+ 'listenKey': None,
67
+ },
68
+ 'streaming': {
69
+ 'ping': self.ping,
70
+ 'keepAlive': 8000,
71
+ },
72
+ 'exceptions': {
73
+ },
74
+ })
75
+
76
+ async def watch_ticker(self, symbol: str, params={}) -> Ticker:
77
+ """
78
+ watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
79
+ :param str symbol: unified symbol of the market to fetch the ticker for
80
+ :param dict [params]: extra parameters specific to the exchange API endpoint
81
+ :returns dict: a `ticker structure <https://docs.ccxt.com/#/?id=ticker-structure>`
82
+ """
83
+ await self.load_markets()
84
+ market = self.market(symbol)
85
+ messageHash = 'ticker:' + market['symbol']
86
+ if market['spot']:
87
+ channel = 'spot@public.bookTicker.v3.api@' + market['id']
88
+ return await self.watch_spot_public(channel, messageHash, params)
89
+ else:
90
+ channel = 'sub.ticker'
91
+ requestParams: dict = {
92
+ 'symbol': market['id'],
93
+ }
94
+ return await self.watch_swap_public(channel, messageHash, requestParams, params)
95
+
96
+ def handle_ticker(self, client: Client, message):
97
+ #
98
+ # {
99
+ # "c": "spot@public.bookTicker.v3.api@BTCUSDT",
100
+ # "d": {
101
+ # "A": "4.70432",
102
+ # "B": "6.714863",
103
+ # "a": "20744.54",
104
+ # "b": "20744.17"
105
+ # },
106
+ # "s": "BTCUSDT",
107
+ # "t": 1678643605721
108
+ # }
109
+ #
110
+ rawTicker = self.safe_value_2(message, 'd', 'data')
111
+ marketId = self.safe_string_2(message, 's', 'symbol')
112
+ timestamp = self.safe_integer(message, 't')
113
+ market = self.safe_market(marketId)
114
+ symbol = market['symbol']
115
+ ticker = None
116
+ if market['spot']:
117
+ ticker = self.parse_ws_ticker(rawTicker, market)
118
+ ticker['timestamp'] = timestamp
119
+ ticker['datetime'] = self.iso8601(timestamp)
120
+ else:
121
+ ticker = self.parse_ticker(rawTicker, market)
122
+ self.tickers[symbol] = ticker
123
+ messageHash = 'ticker:' + symbol
124
+ client.resolve(ticker, messageHash)
125
+
126
+ def parse_ws_ticker(self, ticker, market=None):
127
+ #
128
+ # spot
129
+ # {
130
+ # "A": "4.70432",
131
+ # "B": "6.714863",
132
+ # "a": "20744.54",
133
+ # "b": "20744.17"
134
+ # }
135
+ #
136
+ return self.safe_ticker({
137
+ 'symbol': self.safe_symbol(None, market),
138
+ 'timestamp': None,
139
+ 'datetime': None,
140
+ 'open': None,
141
+ 'high': None,
142
+ 'low': None,
143
+ 'close': None,
144
+ 'bid': self.safe_number(ticker, 'b'),
145
+ 'bidVolume': self.safe_number(ticker, 'B'),
146
+ 'ask': self.safe_number(ticker, 'a'),
147
+ 'askVolume': self.safe_number(ticker, 'A'),
148
+ 'vwap': None,
149
+ 'previousClose': None,
150
+ 'change': None,
151
+ 'percentage': None,
152
+ 'average': None,
153
+ 'baseVolume': None,
154
+ 'quoteVolume': None,
155
+ 'info': ticker,
156
+ }, market)
157
+
158
+ async def watch_spot_public(self, channel, messageHash, params={}):
159
+ url = self.urls['api']['ws']['spot']
160
+ request: dict = {
161
+ 'method': 'SUBSCRIPTION',
162
+ 'params': [channel],
163
+ }
164
+ return await self.watch(url, messageHash, self.extend(request, params), channel)
165
+
166
+ async def watch_spot_private(self, channel, messageHash, params={}):
167
+ self.check_required_credentials()
168
+ listenKey = await self.authenticate(channel)
169
+ url = self.urls['api']['ws']['spot'] + '?listenKey=' + listenKey
170
+ request: dict = {
171
+ 'method': 'SUBSCRIPTION',
172
+ 'params': [channel],
173
+ }
174
+ return await self.watch(url, messageHash, self.extend(request, params), channel)
175
+
176
+ async def watch_swap_public(self, channel, messageHash, requestParams, params={}):
177
+ url = self.urls['api']['ws']['swap']
178
+ request: dict = {
179
+ 'method': channel,
180
+ 'param': requestParams,
181
+ }
182
+ message = self.extend(request, params)
183
+ return await self.watch(url, messageHash, message, messageHash)
184
+
185
+ async def watch_swap_private(self, messageHash, params={}):
186
+ self.check_required_credentials()
187
+ channel = 'login'
188
+ url = self.urls['api']['ws']['swap']
189
+ timestamp = str(self.milliseconds())
190
+ payload = self.apiKey + timestamp
191
+ signature = self.hmac(self.encode(payload), self.encode(self.secret), hashlib.sha256)
192
+ request: dict = {
193
+ 'method': channel,
194
+ 'param': {
195
+ 'apiKey': self.apiKey,
196
+ 'signature': signature,
197
+ 'reqTime': timestamp,
198
+ },
199
+ }
200
+ message = self.extend(request, params)
201
+ return await self.watch(url, messageHash, message, channel)
202
+
203
+ async def watch_ohlcv(self, symbol: str, timeframe='1m', since: Int = None, limit: Int = None, params={}) -> List[list]:
204
+ """
205
+ :see: https://mxcdevelop.github.io/apidocs/spot_v3_en/#kline-streams
206
+ watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
207
+ :param str symbol: unified symbol of the market to fetch OHLCV data for
208
+ :param str timeframe: the length of time each candle represents
209
+ :param int [since]: timestamp in ms of the earliest candle to fetch
210
+ :param int [limit]: the maximum amount of candles to fetch
211
+ :param dict [params]: extra parameters specific to the exchange API endpoint
212
+ :returns int[][]: A list of candles ordered, open, high, low, close, volume
213
+ """
214
+ await self.load_markets()
215
+ market = self.market(symbol)
216
+ symbol = market['symbol']
217
+ timeframes = self.safe_value(self.options, 'timeframes', {})
218
+ timeframeId = self.safe_string(timeframes, timeframe)
219
+ messageHash = 'candles:' + symbol + ':' + timeframe
220
+ ohlcv = None
221
+ if market['spot']:
222
+ channel = 'spot@public.kline.v3.api@' + market['id'] + '@' + timeframeId
223
+ ohlcv = await self.watch_spot_public(channel, messageHash, params)
224
+ else:
225
+ channel = 'sub.kline'
226
+ requestParams: dict = {
227
+ 'symbol': market['id'],
228
+ 'interval': timeframeId,
229
+ }
230
+ ohlcv = await self.watch_swap_public(channel, messageHash, requestParams, params)
231
+ if self.newUpdates:
232
+ limit = ohlcv.getLimit(symbol, limit)
233
+ return self.filter_by_since_limit(ohlcv, since, limit, 0, True)
234
+
235
+ def handle_ohlcv(self, client: Client, message):
236
+ #
237
+ # spot
238
+ #
239
+ # {
240
+ # "d": {
241
+ # "e": "spot@public.kline.v3.api",
242
+ # "k": {
243
+ # "t": 1678642261,
244
+ # "o": 20626.94,
245
+ # "c": 20599.69,
246
+ # "h": 20626.94,
247
+ # "l": 20597.06,
248
+ # "v": 27.678686,
249
+ # "a": 570332.77,
250
+ # "T": 1678642320,
251
+ # "i": "Min1"
252
+ # }
253
+ # },
254
+ # "c": "spot@public.kline.v3.api@BTCUSDT@Min1",
255
+ # "t": 1678642276459,
256
+ # "s": "BTCUSDT"
257
+ # }
258
+ #
259
+ # swap
260
+ #
261
+ # {
262
+ # "channel": "push.kline",
263
+ # "data": {
264
+ # "a": 325653.3287,
265
+ # "c": 38839,
266
+ # "h": 38909.5,
267
+ # "interval": "Min1",
268
+ # "l": 38833,
269
+ # "o": 38901.5,
270
+ # "q": 83808,
271
+ # "rc": 38839,
272
+ # "rh": 38909.5,
273
+ # "rl": 38833,
274
+ # "ro": 38909.5,
275
+ # "symbol": "BTC_USDT",
276
+ # "t": 1651230660
277
+ # },
278
+ # "symbol": "BTC_USDT",
279
+ # "ts": 1651230713067
280
+ # }
281
+ #
282
+ d = self.safe_value_2(message, 'd', 'data', {})
283
+ rawOhlcv = self.safe_value(d, 'k', d)
284
+ timeframeId = self.safe_string_2(rawOhlcv, 'i', 'interval')
285
+ timeframes = self.safe_value(self.options, 'timeframes', {})
286
+ timeframe = self.find_timeframe(timeframeId, timeframes)
287
+ marketId = self.safe_string_2(message, 's', 'symbol')
288
+ market = self.safe_market(marketId)
289
+ symbol = market['symbol']
290
+ messageHash = 'candles:' + symbol + ':' + timeframe
291
+ parsed = self.parse_ws_ohlcv(rawOhlcv, market)
292
+ self.ohlcvs[symbol] = self.safe_value(self.ohlcvs, symbol, {})
293
+ stored = self.safe_value(self.ohlcvs[symbol], timeframe)
294
+ if stored is None:
295
+ limit = self.safe_integer(self.options, 'OHLCVLimit', 1000)
296
+ stored = ArrayCacheByTimestamp(limit)
297
+ self.ohlcvs[symbol][timeframe] = stored
298
+ stored.append(parsed)
299
+ client.resolve(stored, messageHash)
300
+
301
+ def parse_ws_ohlcv(self, ohlcv, market=None) -> list:
302
+ #
303
+ # spot
304
+ #
305
+ # {
306
+ # "t": 1678642260,
307
+ # "o": 20626.94,
308
+ # "c": 20599.69,
309
+ # "h": 20626.94,
310
+ # "l": 20597.06,
311
+ # "v": 27.678686,
312
+ # "a": 570332.77,
313
+ # "T": 1678642320,
314
+ # "i": "Min1"
315
+ # }
316
+ #
317
+ # swap
318
+ # {
319
+ # "symbol": "BTC_USDT",
320
+ # "interval": "Min1",
321
+ # "t": 1680055080,
322
+ # "o": 27301.9,
323
+ # "c": 27301.8,
324
+ # "h": 27301.9,
325
+ # "l": 27301.8,
326
+ # "a": 8.19054,
327
+ # "q": 3,
328
+ # "ro": 27301.8,
329
+ # "rc": 27301.8,
330
+ # "rh": 27301.8,
331
+ # "rl": 27301.8
332
+ # }
333
+ #
334
+ return [
335
+ self.safe_timestamp(ohlcv, 't'),
336
+ self.safe_number(ohlcv, 'o'),
337
+ self.safe_number(ohlcv, 'h'),
338
+ self.safe_number(ohlcv, 'l'),
339
+ self.safe_number(ohlcv, 'c'),
340
+ self.safe_number_2(ohlcv, 'v', 'q'),
341
+ ]
342
+
343
+ async def watch_order_book(self, symbol: str, limit: Int = None, params={}) -> OrderBook:
344
+ """
345
+ :see: https://mxcdevelop.github.io/apidocs/spot_v3_en/#diff-depth-stream
346
+ watches information on open orders with bid(buy) and ask(sell) prices, volumes and other data
347
+ :param str symbol: unified symbol of the market to fetch the order book for
348
+ :param int [limit]: the maximum amount of order book entries to return
349
+ :param dict [params]: extra parameters specific to the exchange API endpoint
350
+ :returns dict: A dictionary of `order book structures <https://docs.ccxt.com/#/?id=order-book-structure>` indexed by market symbols
351
+ """
352
+ await self.load_markets()
353
+ market = self.market(symbol)
354
+ symbol = market['symbol']
355
+ messageHash = 'orderbook:' + symbol
356
+ orderbook = None
357
+ if market['spot']:
358
+ channel = 'spot@public.increase.depth.v3.api@' + market['id']
359
+ orderbook = await self.watch_spot_public(channel, messageHash, params)
360
+ else:
361
+ channel = 'sub.depth'
362
+ requestParams: dict = {
363
+ 'symbol': market['id'],
364
+ }
365
+ orderbook = await self.watch_swap_public(channel, messageHash, requestParams, params)
366
+ return orderbook.limit()
367
+
368
+ def handle_order_book_subscription(self, client: Client, message):
369
+ # spot
370
+ # {id: 0, code: 0, msg: "spot@public.increase.depth.v3.api@BTCUSDT"}
371
+ #
372
+ msg = self.safe_string(message, 'msg')
373
+ parts = msg.split('@')
374
+ marketId = self.safe_string(parts, 2)
375
+ symbol = self.safe_symbol(marketId)
376
+ self.orderbooks[symbol] = self.order_book({})
377
+
378
+ def get_cache_index(self, orderbook, cache):
379
+ # return the first index of the cache that can be applied to the orderbook or -1 if not possible
380
+ nonce = self.safe_integer(orderbook, 'nonce')
381
+ firstDelta = self.safe_value(cache, 0)
382
+ firstDeltaNonce = self.safe_integer_2(firstDelta, 'r', 'version')
383
+ if nonce < firstDeltaNonce - 1:
384
+ return -1
385
+ for i in range(0, len(cache)):
386
+ delta = cache[i]
387
+ deltaNonce = self.safe_integer_2(delta, 'r', 'version')
388
+ if deltaNonce >= nonce:
389
+ return i
390
+ return len(cache)
391
+
392
+ def handle_order_book(self, client: Client, message):
393
+ #
394
+ # spot
395
+ # {
396
+ # "c": "spot@public.increase.depth.v3.api@BTCUSDT",
397
+ # "d": {
398
+ # "asks": [{
399
+ # "p": "20290.89",
400
+ # "v": "0.000000"
401
+ # }],
402
+ # "e": "spot@public.increase.depth.v3.api",
403
+ # "r": "3407459756"
404
+ # },
405
+ # "s": "BTCUSDT",
406
+ # "t": 1661932660144
407
+ # }
408
+ #
409
+ #
410
+ #
411
+ # swap
412
+ # {
413
+ # "channel":"push.depth",
414
+ # "data":{
415
+ # "asks":[
416
+ # [
417
+ # 39146.5,
418
+ # 11264,
419
+ # 1
420
+ # ]
421
+ # ],
422
+ # "bids":[
423
+ # [
424
+ # 39144,
425
+ # 35460,
426
+ # 1
427
+ # ]
428
+ # ],
429
+ # "end":4895965272,
430
+ # "begin":4895965271
431
+ # },
432
+ # "symbol":"BTC_USDT",
433
+ # "ts":1651239652372
434
+ # }
435
+ #
436
+ data = self.safe_value_2(message, 'd', 'data')
437
+ marketId = self.safe_string_2(message, 's', 'symbol')
438
+ symbol = self.safe_symbol(marketId)
439
+ messageHash = 'orderbook:' + symbol
440
+ subscription = self.safe_value(client.subscriptions, messageHash)
441
+ limit = self.safe_integer(subscription, 'limit')
442
+ if subscription is True:
443
+ # we set client.subscriptions[messageHash] to 1
444
+ # once we have received the first delta and initialized the orderbook
445
+ client.subscriptions[messageHash] = 1
446
+ self.orderbooks[symbol] = self.counted_order_book({})
447
+ storedOrderBook = self.orderbooks[symbol]
448
+ nonce = self.safe_integer(storedOrderBook, 'nonce')
449
+ if nonce is None:
450
+ cacheLength = len(storedOrderBook.cache)
451
+ snapshotDelay = self.handle_option('watchOrderBook', 'snapshotDelay', 25)
452
+ if cacheLength == snapshotDelay:
453
+ self.spawn(self.load_order_book, client, messageHash, symbol, limit, {})
454
+ storedOrderBook.cache.append(data)
455
+ return
456
+ try:
457
+ self.handle_delta(storedOrderBook, data)
458
+ timestamp = self.safe_integer_2(message, 't', 'ts')
459
+ storedOrderBook['timestamp'] = timestamp
460
+ storedOrderBook['datetime'] = self.iso8601(timestamp)
461
+ except Exception as e:
462
+ del client.subscriptions[messageHash]
463
+ client.reject(e, messageHash)
464
+ client.resolve(storedOrderBook, messageHash)
465
+
466
+ def handle_bookside_delta(self, bookside, bidasks):
467
+ #
468
+ # [{
469
+ # "p": "20290.89",
470
+ # "v": "0.000000"
471
+ # }]
472
+ #
473
+ for i in range(0, len(bidasks)):
474
+ bidask = bidasks[i]
475
+ if isinstance(bidask, list):
476
+ bookside.storeArray(bidask)
477
+ else:
478
+ price = self.safe_float(bidask, 'p')
479
+ amount = self.safe_float(bidask, 'v')
480
+ bookside.store(price, amount)
481
+
482
+ def handle_delta(self, orderbook, delta):
483
+ existingNonce = self.safe_integer(orderbook, 'nonce')
484
+ deltaNonce = self.safe_integer_2(delta, 'r', 'version')
485
+ if deltaNonce < existingNonce:
486
+ # even when doing < comparison, self happens: https://app.travis-ci.com/github/ccxt/ccxt/builds/269234741#L1809
487
+ # so, we just skip old updates
488
+ return
489
+ orderbook['nonce'] = deltaNonce
490
+ asks = self.safe_list(delta, 'asks', [])
491
+ bids = self.safe_list(delta, 'bids', [])
492
+ asksOrderSide = orderbook['asks']
493
+ bidsOrderSide = orderbook['bids']
494
+ self.handle_bookside_delta(asksOrderSide, asks)
495
+ self.handle_bookside_delta(bidsOrderSide, bids)
496
+
497
+ async def watch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
498
+ """
499
+ :see: https://mxcdevelop.github.io/apidocs/spot_v3_en/#trade-streams
500
+ get the list of most recent trades for a particular symbol
501
+ :param str symbol: unified symbol of the market to fetch trades for
502
+ :param int [since]: timestamp in ms of the earliest trade to fetch
503
+ :param int [limit]: the maximum amount of trades to fetch
504
+ :param dict [params]: extra parameters specific to the exchange API endpoint
505
+ :returns dict[]: a list of `trade structures <https://docs.ccxt.com/#/?id=public-trades>`
506
+ """
507
+ await self.load_markets()
508
+ market = self.market(symbol)
509
+ symbol = market['symbol']
510
+ messageHash = 'trades:' + symbol
511
+ trades = None
512
+ if market['spot']:
513
+ channel = 'spot@public.deals.v3.api@' + market['id']
514
+ trades = await self.watch_spot_public(channel, messageHash, params)
515
+ else:
516
+ channel = 'sub.deal'
517
+ requestParams: dict = {
518
+ 'symbol': market['id'],
519
+ }
520
+ trades = await self.watch_swap_public(channel, messageHash, requestParams, params)
521
+ if self.newUpdates:
522
+ limit = trades.getLimit(symbol, limit)
523
+ return self.filter_by_since_limit(trades, since, limit, 'timestamp', True)
524
+
525
+ def handle_trades(self, client: Client, message):
526
+ #
527
+ # {
528
+ # "c": "spot@public.deals.v3.api@BTCUSDT",
529
+ # "d": {
530
+ # "deals": [{
531
+ # "p": "20382.70",
532
+ # "v": "0.043800",
533
+ # "S": 1,
534
+ # "t": 1678593222456,
535
+ # },],
536
+ # "e": "spot@public.deals.v3.api",
537
+ # },
538
+ # "s": "BTCUSDT",
539
+ # "t": 1678593222460,
540
+ # }
541
+ #
542
+ # swap
543
+ # {
544
+ # "symbol": "BTC_USDT",
545
+ # "data": {
546
+ # "p": 27307.3,
547
+ # "v": 5,
548
+ # "T": 2,
549
+ # "O": 3,
550
+ # "M": 1,
551
+ # "t": 1680055941870
552
+ # },
553
+ # "channel": "push.deal",
554
+ # "ts": 1680055941870
555
+ # }
556
+ #
557
+ marketId = self.safe_string_2(message, 's', 'symbol')
558
+ market = self.safe_market(marketId)
559
+ symbol = market['symbol']
560
+ messageHash = 'trades:' + symbol
561
+ stored = self.safe_value(self.trades, symbol)
562
+ if stored is None:
563
+ limit = self.safe_integer(self.options, 'tradesLimit', 1000)
564
+ stored = ArrayCache(limit)
565
+ self.trades[symbol] = stored
566
+ d = self.safe_value_2(message, 'd', 'data')
567
+ trades = self.safe_value(d, 'deals', [d])
568
+ for j in range(0, len(trades)):
569
+ parsedTrade = None
570
+ if market['spot']:
571
+ parsedTrade = self.parse_ws_trade(trades[j], market)
572
+ else:
573
+ parsedTrade = self.parse_trade(trades[j], market)
574
+ stored.append(parsedTrade)
575
+ client.resolve(stored, messageHash)
576
+
577
+ async def watch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
578
+ """
579
+ :see: https://mxcdevelop.github.io/apidocs/spot_v3_en/#spot-account-deals
580
+ watches information on multiple trades made by the user
581
+ :param str symbol: unified market symbol of the market trades were made in
582
+ :param int [since]: the earliest time in ms to fetch trades for
583
+ :param int [limit]: the maximum number of trade structures to retrieve
584
+ :param dict [params]: extra parameters specific to the exchange API endpoint
585
+ :returns dict[]: a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure
586
+ """
587
+ await self.load_markets()
588
+ messageHash = 'myTrades'
589
+ market = None
590
+ if symbol is not None:
591
+ market = self.market(symbol)
592
+ symbol = market['symbol']
593
+ messageHash = messageHash + ':' + symbol
594
+ type = None
595
+ type, params = self.handle_market_type_and_params('watchMyTrades', market, params)
596
+ trades = None
597
+ if type == 'spot':
598
+ channel = 'spot@private.deals.v3.api'
599
+ trades = await self.watch_spot_private(channel, messageHash, params)
600
+ else:
601
+ trades = await self.watch_swap_private(messageHash, params)
602
+ if self.newUpdates:
603
+ limit = trades.getLimit(symbol, limit)
604
+ return self.filter_by_symbol_since_limit(trades, symbol, since, limit, True)
605
+
606
+ def handle_my_trade(self, client: Client, message, subscription=None):
607
+ #
608
+ # {
609
+ # "c": "spot@private.deals.v3.api",
610
+ # "d": {
611
+ # "p": "22339.99",
612
+ # "v": "0.000235",
613
+ # "S": 1,
614
+ # "T": 1678670940695,
615
+ # "t": "9f6a47fb926442e496c5c4c104076ae3",
616
+ # "c": '',
617
+ # "i": "e2b9835d1b6745f8a10ab74a81a16d50",
618
+ # "m": 0,
619
+ # "st": 0
620
+ # },
621
+ # "s": "BTCUSDT",
622
+ # "t": 1678670940700
623
+ # }
624
+ #
625
+ messageHash = 'myTrades'
626
+ data = self.safe_value_2(message, 'd', 'data')
627
+ futuresMarketId = self.safe_string(data, 'symbol')
628
+ marketId = self.safe_string(message, 's', futuresMarketId)
629
+ market = self.safe_market(marketId)
630
+ symbol = market['symbol']
631
+ trade = None
632
+ if market['spot']:
633
+ trade = self.parse_ws_trade(data, market)
634
+ else:
635
+ trade = self.parse_trade(data, market)
636
+ trades = self.myTrades
637
+ if trades is None:
638
+ limit = self.safe_integer(self.options, 'tradesLimit', 1000)
639
+ trades = ArrayCacheBySymbolById(limit)
640
+ self.myTrades = trades
641
+ trades.append(trade)
642
+ client.resolve(trades, messageHash)
643
+ symbolSpecificMessageHash = messageHash + ':' + symbol
644
+ client.resolve(trades, symbolSpecificMessageHash)
645
+
646
+ def parse_ws_trade(self, trade, market=None):
647
+ #
648
+ # public trade
649
+ # {
650
+ # "p": "20382.70",
651
+ # "v": "0.043800",
652
+ # "S": 1,
653
+ # "t": 1678593222456,
654
+ # }
655
+ # private trade
656
+ # {
657
+ # "S": 1,
658
+ # "T": 1661938980268,
659
+ # "c": "",
660
+ # "i": "c079b0fcb80a46e8b128b281ce4e4f38",
661
+ # "m": 1,
662
+ # "p": "1.008",
663
+ # "st": 0,
664
+ # "t": "4079b1522a0b40e7919f609e1ea38d44",
665
+ # "v": "5"
666
+ # }
667
+ #
668
+ #
669
+ # d: {
670
+ # p: '1.0005',
671
+ # v: '5.71',
672
+ # a: '5.712855',
673
+ # S: 1,
674
+ # T: 1714325698237,
675
+ # t: 'edafcd9fdc2f426e82443d114691f724',
676
+ # c: '',
677
+ # i: 'C02__413321238354677760043',
678
+ # m: 0,
679
+ # st: 0,
680
+ # n: '0.005712855',
681
+ # N: 'USDT'
682
+ # }
683
+ timestamp = self.safe_integer(trade, 'T')
684
+ tradeId = self.safe_string(trade, 't')
685
+ if timestamp is None:
686
+ timestamp = self.safe_integer(trade, 't')
687
+ tradeId = None
688
+ priceString = self.safe_string(trade, 'p')
689
+ amountString = self.safe_string(trade, 'v')
690
+ rawSide = self.safe_string(trade, 'S')
691
+ side = 'buy' if (rawSide == '1') else 'sell'
692
+ isMaker = self.safe_integer(trade, 'm')
693
+ feeAmount = self.safe_number(trade, 'n')
694
+ feeCurrencyId = self.safe_string(trade, 'N')
695
+ return self.safe_trade({
696
+ 'info': trade,
697
+ 'id': tradeId,
698
+ 'order': self.safe_string(trade, 'i'),
699
+ 'timestamp': timestamp,
700
+ 'datetime': self.iso8601(timestamp),
701
+ 'symbol': self.safe_symbol(None, market),
702
+ 'type': None,
703
+ 'side': side,
704
+ 'takerOrMaker': 'maker' if (isMaker) else 'taker',
705
+ 'price': priceString,
706
+ 'amount': amountString,
707
+ 'cost': None,
708
+ 'fee': {
709
+ 'cost': feeAmount,
710
+ 'currency': self.safe_currency_code(feeCurrencyId),
711
+ },
712
+ }, market)
713
+
714
+ async def watch_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
715
+ """
716
+ :see: https://mxcdevelop.github.io/apidocs/spot_v3_en/#spot-account-orders
717
+ :see: https://mxcdevelop.github.io/apidocs/spot_v3_en/#margin-account-orders
718
+ watches information on multiple orders made by the user
719
+ :param str symbol: unified market symbol of the market orders were made in
720
+ :param int [since]: the earliest time in ms to fetch orders for
721
+ :param int [limit]: the maximum number of order structures to retrieve
722
+ :param dict [params]: extra parameters specific to the exchange API endpoint
723
+ :param str|None params['type']: the type of orders to retrieve, can be 'spot' or 'margin'
724
+ :returns dict[]: a list of `order structures <https://docs.ccxt.com/#/?id=order-structure>`
725
+ """
726
+ await self.load_markets()
727
+ params = self.omit(params, 'type')
728
+ messageHash = 'orders'
729
+ market = None
730
+ if symbol is not None:
731
+ market = self.market(symbol)
732
+ symbol = market['symbol']
733
+ messageHash = messageHash + ':' + symbol
734
+ type = None
735
+ type, params = self.handle_market_type_and_params('watchOrders', market, params)
736
+ orders = None
737
+ if type == 'spot':
738
+ channel = type + '@private.orders.v3.api'
739
+ orders = await self.watch_spot_private(channel, messageHash, params)
740
+ else:
741
+ orders = await self.watch_swap_private(messageHash, params)
742
+ if self.newUpdates:
743
+ limit = orders.getLimit(symbol, limit)
744
+ return self.filter_by_symbol_since_limit(orders, symbol, since, limit, True)
745
+
746
+ def handle_order(self, client: Client, message):
747
+ #
748
+ # spot
749
+ # {
750
+ # "c": "spot@private.orders.v3.api",
751
+ # "d": {
752
+ # "A":8.0,
753
+ # "O":1661938138000,
754
+ # "S":1,
755
+ # "V":10,
756
+ # "a":8,
757
+ # "c":"",
758
+ # "i":"e03a5c7441e44ed899466a7140b71391",
759
+ # "m":0,
760
+ # "o":1,
761
+ # "p":0.8,
762
+ # "s":1,
763
+ # "v":10,
764
+ # "ap":0,
765
+ # "cv":0,
766
+ # "ca":0
767
+ # },
768
+ # "s": "MXUSDT",
769
+ # "t": 1661938138193
770
+ # }
771
+ # spot - stop
772
+ # {
773
+ # "c": "spot@private.orders.v3.api",
774
+ # "d": {
775
+ # "N":"USDT",
776
+ # "O":1661938853715,
777
+ # "P":0.9,
778
+ # "S":1,
779
+ # "T":"LE",
780
+ # "i":"f6d82e5f41d745f59fe9d3cafffd80b5",
781
+ # "o":100,
782
+ # "p":1.01,
783
+ # "s":"NEW",
784
+ # "v":6
785
+ # },
786
+ # "s": "MXUSDT",
787
+ # "t": 1661938853727
788
+ # }
789
+ # margin
790
+ # {
791
+ # "c": "margin@private.orders.v3.api",
792
+ # "d":{
793
+ # "O":1661938138000,
794
+ # "p":"0.8",
795
+ # "a":"8",
796
+ # "v":"10",
797
+ # "da":"0",
798
+ # "dv":"0",
799
+ # "A":"8.0",
800
+ # "V":"10",
801
+ # "n": "0",
802
+ # "N": "USDT",
803
+ # "S":1,
804
+ # "o":1,
805
+ # "s":1,
806
+ # "i":"e03a5c7441e44ed899466a7140b71391",
807
+ # },
808
+ # "s": "MXUSDT",
809
+ # "t":1661938138193
810
+ # }
811
+ #
812
+ messageHash = 'orders'
813
+ data = self.safe_value_2(message, 'd', 'data')
814
+ futuresMarketId = self.safe_string(data, 'symbol')
815
+ marketId = self.safe_string(message, 's', futuresMarketId)
816
+ market = self.safe_market(marketId)
817
+ symbol = market['symbol']
818
+ parsed = None
819
+ if market['spot']:
820
+ parsed = self.parse_ws_order(data, market)
821
+ else:
822
+ parsed = self.parse_order(data, market)
823
+ orders = self.orders
824
+ if orders is None:
825
+ limit = self.safe_integer(self.options, 'ordersLimit', 1000)
826
+ orders = ArrayCacheBySymbolById(limit)
827
+ self.orders = orders
828
+ orders.append(parsed)
829
+ client.resolve(orders, messageHash)
830
+ symbolSpecificMessageHash = messageHash + ':' + symbol
831
+ client.resolve(orders, symbolSpecificMessageHash)
832
+
833
+ def parse_ws_order(self, order, market=None):
834
+ #
835
+ # spot
836
+ # {
837
+ # "A":8.0,
838
+ # "O":1661938138000,
839
+ # "S":1,
840
+ # "V":10,
841
+ # "a":8,
842
+ # "c":"",
843
+ # "i":"e03a5c7441e44ed899466a7140b71391",
844
+ # "m":0,
845
+ # "o":1,
846
+ # "p":0.8,
847
+ # "s":1,
848
+ # "v":10,
849
+ # "ap":0,
850
+ # "cv":0,
851
+ # "ca":0
852
+ # }
853
+ # spot - stop
854
+ # {
855
+ # "N":"USDT",
856
+ # "O":1661938853715,
857
+ # "P":0.9,
858
+ # "S":1,
859
+ # "T":"LE",
860
+ # "i":"f6d82e5f41d745f59fe9d3cafffd80b5",
861
+ # "o":100,
862
+ # "p":1.01,
863
+ # "s":"NEW",
864
+ # "v":6
865
+ # }
866
+ # margin
867
+ # {
868
+ # "O":1661938138000,
869
+ # "p":"0.8",
870
+ # "a":"8",
871
+ # "v":"10",
872
+ # "da":"0",
873
+ # "dv":"0",
874
+ # "A":"8.0",
875
+ # "V":"10",
876
+ # "n": "0",
877
+ # "N": "USDT",
878
+ # "S":1,
879
+ # "o":1,
880
+ # "s":1,
881
+ # "i":"e03a5c7441e44ed899466a7140b71391",
882
+ # }
883
+ #
884
+ timestamp = self.safe_integer(order, 'O')
885
+ side = self.safe_string(order, 'S')
886
+ status = self.safe_string(order, 's')
887
+ type = self.safe_string(order, 'o')
888
+ fee = None
889
+ feeCurrency = self.safe_string(order, 'N')
890
+ if feeCurrency is not None:
891
+ fee = {
892
+ 'currency': feeCurrency,
893
+ 'cost': None,
894
+ }
895
+ return self.safe_order({
896
+ 'id': self.safe_string(order, 'i'),
897
+ 'clientOrderId': self.safe_string(order, 'c'),
898
+ 'timestamp': timestamp,
899
+ 'datetime': self.iso8601(timestamp),
900
+ 'lastTradeTimestamp': None,
901
+ 'status': self.parse_ws_order_status(status, market),
902
+ 'symbol': self.safe_symbol(None, market),
903
+ 'type': self.parse_ws_order_type(type),
904
+ 'timeInForce': self.parse_ws_time_in_force(type),
905
+ 'side': 'buy' if (side == '1') else 'sell',
906
+ 'price': self.safe_string(order, 'p'),
907
+ 'stopPrice': None,
908
+ 'triggerPrice': self.safe_number(order, 'P'),
909
+ 'average': self.safe_string(order, 'ap'),
910
+ 'amount': self.safe_string(order, 'v'),
911
+ 'cost': self.safe_string(order, 'a'),
912
+ 'filled': self.safe_string(order, 'cv'),
913
+ 'remaining': self.safe_string(order, 'V'),
914
+ 'fee': fee,
915
+ 'trades': None,
916
+ 'info': order,
917
+ }, market)
918
+
919
+ def parse_ws_order_status(self, status, market=None):
920
+ statuses: dict = {
921
+ '1': 'open', # new order
922
+ '2': 'closed', # filled
923
+ '3': 'open', # partially filled
924
+ '4': 'canceled', # canceled
925
+ '5': 'open', # order partially filled
926
+ '6': 'closed', # partially filled then canceled
927
+ 'NEW': 'open',
928
+ 'CANCELED': 'canceled',
929
+ 'EXECUTED': 'closed',
930
+ 'FAILED': 'rejected',
931
+ }
932
+ return self.safe_string(statuses, status, status)
933
+
934
+ def parse_ws_order_type(self, type):
935
+ types: dict = {
936
+ '1': 'limit', # LIMIT_ORDER
937
+ '2': None, # POST_ONLY
938
+ '3': None, # IMMEDIATE_OR_CANCEL
939
+ '4': None, # FILL_OR_KILL
940
+ '5': 'market', # MARKET_ORDER
941
+ '100': 'limit', # STOP_LIMIT
942
+ }
943
+ return self.safe_string(types, type)
944
+
945
+ def parse_ws_time_in_force(self, timeInForce):
946
+ timeInForceIds: dict = {
947
+ '1': 'GTC', # LIMIT_ORDER
948
+ '2': 'PO', # POST_ONLY
949
+ '3': 'IOC', # IMMEDIATE_OR_CANCEL
950
+ '4': 'FOK', # FILL_OR_KILL
951
+ '5': 'GTC', # MARKET_ORDER
952
+ '100': 'GTC', # STOP_LIMIT
953
+ }
954
+ return self.safe_string(timeInForceIds, timeInForce)
955
+
956
+ async def watch_balance(self, params={}) -> Balances:
957
+ """
958
+ :see: https://mxcdevelop.github.io/apidocs/spot_v3_en/#spot-account-upadte
959
+ watch balance and get the amount of funds available for trading or funds locked in orders
960
+ :param dict [params]: extra parameters specific to the exchange API endpoint
961
+ :returns dict: a `balance structure <https://docs.ccxt.com/#/?id=balance-structure>`
962
+ """
963
+ await self.load_markets()
964
+ type = None
965
+ type, params = self.handle_market_type_and_params('watchBalance', None, params)
966
+ messageHash = 'balance:' + type
967
+ if type == 'spot':
968
+ channel = 'spot@private.account.v3.api'
969
+ return await self.watch_spot_private(channel, messageHash, params)
970
+ else:
971
+ return await self.watch_swap_private(messageHash, params)
972
+
973
+ def handle_balance(self, client: Client, message):
974
+ #
975
+ # spot
976
+ # {
977
+ # "c": "spot@private.account.v3.api",
978
+ # "d": {
979
+ # "a": "USDT",
980
+ # "c": 1678185928428,
981
+ # "f": "302.185113007893322435",
982
+ # "fd": "-4.990689704",
983
+ # "l": "4.990689704",
984
+ # "ld": "4.990689704",
985
+ # "o": "ENTRUST_PLACE"
986
+ # },
987
+ # "t": 1678185928435
988
+ # }
989
+ #
990
+ #
991
+ # swap balance
992
+ #
993
+ # {
994
+ # "channel": "push.personal.asset",
995
+ # "data": {
996
+ # "availableBalance": 67.2426683348,
997
+ # "bonus": 0,
998
+ # "currency": "USDT",
999
+ # "frozenBalance": 0,
1000
+ # "positionMargin": 1.36945756
1001
+ # },
1002
+ # "ts": 1680059188190
1003
+ # }
1004
+ #
1005
+ c = self.safe_string(message, 'c')
1006
+ type = 'swap' if (c is None) else 'spot'
1007
+ messageHash = 'balance:' + type
1008
+ data = self.safe_value_2(message, 'd', 'data')
1009
+ futuresTimestamp = self.safe_integer(message, 'ts')
1010
+ timestamp = self.safe_integer(data, 'c', futuresTimestamp)
1011
+ if not (type in self.balance):
1012
+ self.balance[type] = {}
1013
+ self.balance[type]['info'] = data
1014
+ self.balance[type]['timestamp'] = timestamp
1015
+ self.balance[type]['datetime'] = self.iso8601(timestamp)
1016
+ currencyId = self.safe_string_2(data, 'a', 'currency')
1017
+ code = self.safe_currency_code(currencyId)
1018
+ account = self.account()
1019
+ account['free'] = self.safe_string_2(data, 'f', 'availableBalance')
1020
+ account['used'] = self.safe_string_2(data, 'l', 'frozenBalance')
1021
+ self.balance[type][code] = account
1022
+ self.balance[type] = self.safe_balance(self.balance[type])
1023
+ client.resolve(self.balance[type], messageHash)
1024
+
1025
+ async def authenticate(self, subscriptionHash, params={}):
1026
+ # we only need one listenKey since ccxt shares connections
1027
+ listenKey = self.safe_string(self.options, 'listenKey')
1028
+ if listenKey is not None:
1029
+ return listenKey
1030
+ response = await self.spotPrivatePostUserDataStream(params)
1031
+ #
1032
+ # {
1033
+ # "listenKey": "pqia91ma19a5s61cv6a81va65sdf19v8a65a1a5s61cv6a81va65sdf19v8a65a1"
1034
+ # }
1035
+ #
1036
+ listenKey = self.safe_string(response, 'listenKey')
1037
+ self.options['listenKey'] = listenKey
1038
+ listenKeyRefreshRate = self.safe_integer(self.options, 'listenKeyRefreshRate', 1200000)
1039
+ self.delay(listenKeyRefreshRate, self.keep_alive_listen_key, listenKey, params)
1040
+ return listenKey
1041
+
1042
+ async def keep_alive_listen_key(self, listenKey, params={}):
1043
+ if listenKey is None:
1044
+ return
1045
+ request: dict = {
1046
+ 'listenKey': listenKey,
1047
+ }
1048
+ try:
1049
+ await self.spotPrivatePutUserDataStream(self.extend(request, params))
1050
+ listenKeyRefreshRate = self.safe_integer(self.options, 'listenKeyRefreshRate', 1200000)
1051
+ self.delay(listenKeyRefreshRate, self.keep_alive_listen_key, listenKey, params)
1052
+ except Exception as error:
1053
+ url = self.urls['api']['ws']['spot'] + '?listenKey=' + listenKey
1054
+ client = self.client(url)
1055
+ self.options['listenKey'] = None
1056
+ client.reject(error)
1057
+ del self.clients[url]
1058
+
1059
+ def handle_pong(self, client: Client, message):
1060
+ client.lastPong = self.milliseconds()
1061
+ return message
1062
+
1063
+ def handle_subscription_status(self, client: Client, message):
1064
+ #
1065
+ # {
1066
+ # "id": 0,
1067
+ # "code": 0,
1068
+ # "msg": "spot@public.increase.depth.v3.api@BTCUSDT"
1069
+ # }
1070
+ #
1071
+ msg = self.safe_string(message, 'msg')
1072
+ if msg == 'PONG':
1073
+ self.handle_pong(client, message)
1074
+ elif msg.find('@') > -1:
1075
+ parts = msg.split('@')
1076
+ channel = self.safe_string(parts, 1)
1077
+ methods: dict = {
1078
+ 'public.increase.depth.v3.api': self.handle_order_book_subscription,
1079
+ }
1080
+ method = self.safe_value(methods, channel)
1081
+ if method is not None:
1082
+ method(client, message)
1083
+
1084
+ def handle_message(self, client: Client, message):
1085
+ if isinstance(message, str):
1086
+ if message == 'Invalid listen key':
1087
+ error = AuthenticationError(self.id + ' invalid listen key')
1088
+ client.reject(error)
1089
+ return
1090
+ if 'msg' in message:
1091
+ self.handle_subscription_status(client, message)
1092
+ return
1093
+ c = self.safe_string(message, 'c')
1094
+ channel = None
1095
+ if c is None:
1096
+ channel = self.safe_string(message, 'channel')
1097
+ else:
1098
+ parts = c.split('@')
1099
+ channel = self.safe_string(parts, 1)
1100
+ methods: dict = {
1101
+ 'public.deals.v3.api': self.handle_trades,
1102
+ 'push.deal': self.handle_trades,
1103
+ 'public.kline.v3.api': self.handle_ohlcv,
1104
+ 'push.kline': self.handle_ohlcv,
1105
+ 'public.bookTicker.v3.api': self.handle_ticker,
1106
+ 'push.ticker': self.handle_ticker,
1107
+ 'public.increase.depth.v3.api': self.handle_order_book,
1108
+ 'push.depth': self.handle_order_book,
1109
+ 'private.orders.v3.api': self.handle_order,
1110
+ 'push.personal.order': self.handle_order,
1111
+ 'private.account.v3.api': self.handle_balance,
1112
+ 'push.personal.asset': self.handle_balance,
1113
+ 'private.deals.v3.api': self.handle_my_trade,
1114
+ 'push.personal.order.deal': self.handle_my_trade,
1115
+ 'pong': self.handle_pong,
1116
+ }
1117
+ if channel in methods:
1118
+ method = methods[channel]
1119
+ method(client, message)
1120
+
1121
+ def ping(self, client):
1122
+ return {'method': 'ping'}