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/woofipro.py ADDED
@@ -0,0 +1,1183 @@
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, ArrayCacheBySymbolBySide, ArrayCacheByTimestamp
8
+ from ccxt.base.types import Balances, Int, Order, OrderBook, Position, Str, Strings, Ticker, Tickers, Trade
9
+ from ccxt.async_support.base.ws.client import Client
10
+ from typing import List
11
+ from ccxt.base.errors import AuthenticationError
12
+ from ccxt.base.errors import NotSupported
13
+ from ccxt.base.precise import Precise
14
+
15
+
16
+ class woofipro(ccxt.async_support.woofipro):
17
+
18
+ def describe(self):
19
+ return self.deep_extend(super(woofipro, self).describe(), {
20
+ 'has': {
21
+ 'ws': True,
22
+ 'watchBalance': True,
23
+ 'watchMyTrades': True,
24
+ 'watchOHLCV': True,
25
+ 'watchOrderBook': True,
26
+ 'watchOrders': True,
27
+ 'watchTicker': True,
28
+ 'watchTickers': True,
29
+ 'watchTrades': True,
30
+ 'watchPositions': True,
31
+ },
32
+ 'urls': {
33
+ 'api': {
34
+ 'ws': {
35
+ 'public': 'wss://ws-evm.orderly.org/ws/stream',
36
+ 'private': 'wss://ws-private-evm.orderly.org/v2/ws/private/stream',
37
+ },
38
+ },
39
+ 'test': {
40
+ 'ws': {
41
+ 'public': 'wss://testnet-ws-evm.orderly.org/ws/stream',
42
+ 'private': 'wss://testnet-ws-private-evm.orderly.org/v2/ws/private/stream',
43
+ },
44
+ },
45
+ },
46
+ 'requiredCredentials': {
47
+ 'apiKey': True,
48
+ 'secret': True,
49
+ 'accountId': True,
50
+ },
51
+ 'options': {
52
+ 'tradesLimit': 1000,
53
+ 'ordersLimit': 1000,
54
+ 'requestId': {},
55
+ 'watchPositions': {
56
+ 'fetchPositionsSnapshot': True, # or False
57
+ 'awaitPositionsSnapshot': True, # whether to wait for the positions snapshot before providing updates
58
+ },
59
+ },
60
+ 'streaming': {
61
+ 'ping': self.ping,
62
+ 'keepAlive': 10000,
63
+ },
64
+ 'exceptions': {
65
+ 'ws': {
66
+ 'exact': {
67
+ 'Auth is needed.': AuthenticationError,
68
+ },
69
+ },
70
+ },
71
+ })
72
+
73
+ def request_id(self, url):
74
+ options = self.safe_dict(self.options, 'requestId', {})
75
+ previousValue = self.safe_integer(options, url, 0)
76
+ newValue = self.sum(previousValue, 1)
77
+ self.options['requestId'][url] = newValue
78
+ return newValue
79
+
80
+ async def watch_public(self, messageHash, message):
81
+ # the default id
82
+ id = 'OqdphuyCtYWxwzhxyLLjOWNdFP7sQt8RPWzmb5xY'
83
+ if self.accountId is not None:
84
+ id = self.accountId
85
+ url = self.urls['api']['ws']['public'] + '/' + id
86
+ requestId = self.request_id(url)
87
+ subscribe: dict = {
88
+ 'id': requestId,
89
+ }
90
+ request = self.extend(subscribe, message)
91
+ return await self.watch(url, messageHash, request, messageHash, subscribe)
92
+
93
+ async def watch_order_book(self, symbol: str, limit: Int = None, params={}) -> OrderBook:
94
+ """
95
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/public/orderbook
96
+ watches information on open orders with bid(buy) and ask(sell) prices, volumes and other data
97
+ :param str symbol: unified symbol of the market to fetch the order book for
98
+ :param int [limit]: the maximum amount of order book entries to return.
99
+ :param dict [params]: extra parameters specific to the exchange API endpoint
100
+ :returns dict: A dictionary of `order book structures <https://docs.ccxt.com/#/?id=order-book-structure>` indexed by market symbols
101
+ """
102
+ await self.load_markets()
103
+ name = 'orderbook'
104
+ market = self.market(symbol)
105
+ topic = market['id'] + '@' + name
106
+ request: dict = {
107
+ 'event': 'subscribe',
108
+ 'topic': topic,
109
+ }
110
+ message = self.extend(request, params)
111
+ orderbook = await self.watch_public(topic, message)
112
+ return orderbook.limit()
113
+
114
+ def handle_order_book(self, client: Client, message):
115
+ #
116
+ # {
117
+ # "topic": "PERP_BTC_USDC@orderbook",
118
+ # "ts": 1650121915308,
119
+ # "data": {
120
+ # "symbol": "PERP_BTC_USDC",
121
+ # "bids": [
122
+ # [
123
+ # 0.30891,
124
+ # 2469.98
125
+ # ]
126
+ # ],
127
+ # "asks": [
128
+ # [
129
+ # 0.31075,
130
+ # 2379.63
131
+ # ]
132
+ # ]
133
+ # }
134
+ # }
135
+ #
136
+ data = self.safe_dict(message, 'data', {})
137
+ marketId = self.safe_string(data, 'symbol')
138
+ market = self.safe_market(marketId)
139
+ symbol = market['symbol']
140
+ topic = self.safe_string(message, 'topic')
141
+ if not (symbol in self.orderbooks):
142
+ self.orderbooks[symbol] = self.order_book()
143
+ orderbook = self.orderbooks[symbol]
144
+ timestamp = self.safe_integer(message, 'ts')
145
+ snapshot = self.parse_order_book(data, symbol, timestamp, 'bids', 'asks')
146
+ orderbook.reset(snapshot)
147
+ client.resolve(orderbook, topic)
148
+
149
+ async def watch_ticker(self, symbol: str, params={}) -> Ticker:
150
+ """
151
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/public/24-hour-ticker
152
+ watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
153
+ :param str symbol: unified symbol of the market to fetch the ticker for
154
+ :param dict [params]: extra parameters specific to the exchange API endpoint
155
+ :returns dict: a `ticker structure <https://docs.ccxt.com/#/?id=ticker-structure>`
156
+ """
157
+ await self.load_markets()
158
+ name = 'ticker'
159
+ market = self.market(symbol)
160
+ symbol = market['symbol']
161
+ topic = market['id'] + '@' + name
162
+ request: dict = {
163
+ 'event': 'subscribe',
164
+ 'topic': topic,
165
+ }
166
+ message = self.extend(request, params)
167
+ return await self.watch_public(topic, message)
168
+
169
+ def parse_ws_ticker(self, ticker, market=None):
170
+ #
171
+ # {
172
+ # "symbol": "PERP_BTC_USDC",
173
+ # "open": 19441.5,
174
+ # "close": 20147.07,
175
+ # "high": 20761.87,
176
+ # "low": 19320.54,
177
+ # "volume": 2481.103,
178
+ # "amount": 50037935.0286,
179
+ # "count": 3689
180
+ # }
181
+ #
182
+ return self.safe_ticker({
183
+ 'symbol': self.safe_symbol(None, market),
184
+ 'timestamp': None,
185
+ 'datetime': None,
186
+ 'high': self.safe_string(ticker, 'high'),
187
+ 'low': self.safe_string(ticker, 'low'),
188
+ 'bid': None,
189
+ 'bidVolume': None,
190
+ 'ask': None,
191
+ 'askVolume': None,
192
+ 'vwap': None,
193
+ 'open': self.safe_string(ticker, 'open'),
194
+ 'close': self.safe_string(ticker, 'close'),
195
+ 'last': None,
196
+ 'previousClose': None,
197
+ 'change': None,
198
+ 'percentage': None,
199
+ 'average': None,
200
+ 'baseVolume': self.safe_string(ticker, 'volume'),
201
+ 'quoteVolume': self.safe_string(ticker, 'amount'),
202
+ 'info': ticker,
203
+ }, market)
204
+
205
+ def handle_ticker(self, client: Client, message):
206
+ #
207
+ # {
208
+ # "topic": "PERP_BTC_USDC@ticker",
209
+ # "ts": 1657120017000,
210
+ # "data": {
211
+ # "symbol": "PERP_BTC_USDC",
212
+ # "open": 19441.5,
213
+ # "close": 20147.07,
214
+ # "high": 20761.87,
215
+ # "low": 19320.54,
216
+ # "volume": 2481.103,
217
+ # "amount": 50037935.0286,
218
+ # "count": 3689
219
+ # }
220
+ # }
221
+ #
222
+ data = self.safe_dict(message, 'data', {})
223
+ topic = self.safe_string(message, 'topic')
224
+ marketId = self.safe_string(data, 'symbol')
225
+ market = self.safe_market(marketId)
226
+ timestamp = self.safe_integer(message, 'ts')
227
+ data['date'] = timestamp
228
+ ticker = self.parse_ws_ticker(data, market)
229
+ ticker['symbol'] = market['symbol']
230
+ self.tickers[market['symbol']] = ticker
231
+ client.resolve(ticker, topic)
232
+ return message
233
+
234
+ async def watch_tickers(self, symbols: Strings = None, params={}) -> Tickers:
235
+ """
236
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/public/24-hour-tickers
237
+ watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for all markets of a specific list
238
+ :param str[] symbols: unified symbol of the market to fetch the ticker for
239
+ :param dict [params]: extra parameters specific to the exchange API endpoint
240
+ :returns dict: a `ticker structure <https://docs.ccxt.com/#/?id=ticker-structure>`
241
+ """
242
+ await self.load_markets()
243
+ symbols = self.market_symbols(symbols)
244
+ name = 'tickers'
245
+ topic = name
246
+ request: dict = {
247
+ 'event': 'subscribe',
248
+ 'topic': topic,
249
+ }
250
+ message = self.extend(request, params)
251
+ tickers = await self.watch_public(topic, message)
252
+ return self.filter_by_array(tickers, 'symbol', symbols)
253
+
254
+ def handle_tickers(self, client: Client, message):
255
+ #
256
+ # {
257
+ # "topic":"tickers",
258
+ # "ts":1618820615000,
259
+ # "data":[
260
+ # {
261
+ # "symbol":"PERP_NEAR_USDC",
262
+ # "open":16.297,
263
+ # "close":17.183,
264
+ # "high":24.707,
265
+ # "low":11.997,
266
+ # "volume":0,
267
+ # "amount":0,
268
+ # "count":0
269
+ # },
270
+ # ...
271
+ # ]
272
+ # }
273
+ #
274
+ topic = self.safe_string(message, 'topic')
275
+ data = self.safe_list(message, 'data', [])
276
+ timestamp = self.safe_integer(message, 'ts')
277
+ result = []
278
+ for i in range(0, len(data)):
279
+ marketId = self.safe_string(data[i], 'symbol')
280
+ market = self.safe_market(marketId)
281
+ ticker = self.parse_ws_ticker(self.extend(data[i], {'date': timestamp}), market)
282
+ self.tickers[market['symbol']] = ticker
283
+ result.append(ticker)
284
+ client.resolve(result, topic)
285
+
286
+ async def watch_ohlcv(self, symbol: str, timeframe='1m', since: Int = None, limit: Int = None, params={}) -> List[list]:
287
+ """
288
+ watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
289
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/public/k-line
290
+ :param str symbol: unified symbol of the market to fetch OHLCV data for
291
+ :param str timeframe: the length of time each candle represents
292
+ :param int [since]: timestamp in ms of the earliest candle to fetch
293
+ :param int [limit]: the maximum amount of candles to fetch
294
+ :param dict [params]: extra parameters specific to the exchange API endpoint
295
+ :returns int[][]: A list of candles ordered, open, high, low, close, volume
296
+ """
297
+ await self.load_markets()
298
+ if (timeframe != '1m') and (timeframe != '5m') and (timeframe != '15m') and (timeframe != '30m') and (timeframe != '1h') and (timeframe != '1d') and (timeframe != '1w') and (timeframe != '1M'):
299
+ raise NotSupported(self.id + ' watchOHLCV timeframe argument must be 1m, 5m, 15m, 30m, 1h, 1d, 1w, 1M')
300
+ market = self.market(symbol)
301
+ interval = self.safe_string(self.timeframes, timeframe, timeframe)
302
+ name = 'kline'
303
+ topic = market['id'] + '@' + name + '_' + interval
304
+ request: dict = {
305
+ 'event': 'subscribe',
306
+ 'topic': topic,
307
+ }
308
+ message = self.extend(request, params)
309
+ ohlcv = await self.watch_public(topic, message)
310
+ if self.newUpdates:
311
+ limit = ohlcv.getLimit(market['symbol'], limit)
312
+ return self.filter_by_since_limit(ohlcv, since, limit, 0, True)
313
+
314
+ def handle_ohlcv(self, client: Client, message):
315
+ #
316
+ # {
317
+ # "topic":"PERP_BTC_USDC@kline_1m",
318
+ # "ts":1618822432146,
319
+ # "data":{
320
+ # "symbol":"PERP_BTC_USDC",
321
+ # "type":"1m",
322
+ # "open":56948.97,
323
+ # "close":56891.76,
324
+ # "high":56948.97,
325
+ # "low":56889.06,
326
+ # "volume":44.00947568,
327
+ # "amount":2504584.9,
328
+ # "startTime":1618822380000,
329
+ # "endTime":1618822440000
330
+ # }
331
+ # }
332
+ #
333
+ data = self.safe_dict(message, 'data', {})
334
+ topic = self.safe_string(message, 'topic')
335
+ marketId = self.safe_string(data, 'symbol')
336
+ market = self.safe_market(marketId)
337
+ symbol = market['symbol']
338
+ interval = self.safe_string(data, 'type')
339
+ timeframe = self.find_timeframe(interval)
340
+ parsed = [
341
+ self.safe_integer(data, 'startTime'),
342
+ self.safe_number(data, 'open'),
343
+ self.safe_number(data, 'high'),
344
+ self.safe_number(data, 'low'),
345
+ self.safe_number(data, 'close'),
346
+ self.safe_number(data, 'volume'),
347
+ ]
348
+ self.ohlcvs[symbol] = self.safe_value(self.ohlcvs, symbol, {})
349
+ stored = self.safe_value(self.ohlcvs[symbol], timeframe)
350
+ if stored is None:
351
+ limit = self.safe_integer(self.options, 'OHLCVLimit', 1000)
352
+ stored = ArrayCacheByTimestamp(limit)
353
+ self.ohlcvs[symbol][timeframe] = stored
354
+ ohlcvCache = self.ohlcvs[symbol][timeframe]
355
+ ohlcvCache.append(parsed)
356
+ client.resolve(ohlcvCache, topic)
357
+
358
+ async def watch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
359
+ """
360
+ watches information on multiple trades made in a market
361
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/public/trade
362
+ :param str symbol: unified market symbol of the market trades were made in
363
+ :param int [since]: the earliest time in ms to fetch trades for
364
+ :param int [limit]: the maximum number of trade structures to retrieve
365
+ :param dict [params]: extra parameters specific to the exchange API endpoint
366
+ :returns dict[]: a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure
367
+ """
368
+ await self.load_markets()
369
+ market = self.market(symbol)
370
+ symbol = market['symbol']
371
+ topic = market['id'] + '@trade'
372
+ request: dict = {
373
+ 'event': 'subscribe',
374
+ 'topic': topic,
375
+ }
376
+ message = self.extend(request, params)
377
+ trades = await self.watch_public(topic, message)
378
+ if self.newUpdates:
379
+ limit = trades.getLimit(market['symbol'], limit)
380
+ return self.filter_by_symbol_since_limit(trades, symbol, since, limit, True)
381
+
382
+ def handle_trade(self, client: Client, message):
383
+ #
384
+ # {
385
+ # "topic":"PERP_ADA_USDC@trade",
386
+ # "ts":1618820361552,
387
+ # "data":{
388
+ # "symbol":"PERP_ADA_USDC",
389
+ # "price":1.27988,
390
+ # "size":300,
391
+ # "side":"BUY",
392
+ # }
393
+ # }
394
+ #
395
+ topic = self.safe_string(message, 'topic')
396
+ timestamp = self.safe_integer(message, 'ts')
397
+ data = self.safe_dict(message, 'data', {})
398
+ marketId = self.safe_string(data, 'symbol')
399
+ market = self.safe_market(marketId)
400
+ symbol = market['symbol']
401
+ trade = self.parse_ws_trade(self.extend(data, {'timestamp': timestamp}), market)
402
+ if not (symbol in self.trades):
403
+ limit = self.safe_integer(self.options, 'tradesLimit', 1000)
404
+ stored = ArrayCache(limit)
405
+ self.trades[symbol] = stored
406
+ trades = self.trades[symbol]
407
+ trades.append(trade)
408
+ self.trades[symbol] = trades
409
+ client.resolve(trades, topic)
410
+
411
+ def parse_ws_trade(self, trade, market=None):
412
+ #
413
+ # {
414
+ # "symbol":"PERP_ADA_USDC",
415
+ # "timestamp":1618820361552,
416
+ # "price":1.27988,
417
+ # "size":300,
418
+ # "side":"BUY",
419
+ # }
420
+ # private stream
421
+ # {
422
+ # symbol: 'PERP_XRP_USDC',
423
+ # clientOrderId: '',
424
+ # orderId: 1167632251,
425
+ # type: 'MARKET',
426
+ # side: 'BUY',
427
+ # quantity: 20,
428
+ # price: 0,
429
+ # tradeId: '1715179456664012',
430
+ # executedPrice: 0.5276,
431
+ # executedQuantity: 20,
432
+ # fee: 0.006332,
433
+ # feeAsset: 'USDC',
434
+ # totalExecutedQuantity: 20,
435
+ # avgPrice: 0.5276,
436
+ # averageExecutedPrice: 0.5276,
437
+ # status: 'FILLED',
438
+ # reason: '',
439
+ # totalFee: 0.006332,
440
+ # visible: 0,
441
+ # visibleQuantity: 0,
442
+ # timestamp: 1715179456660,
443
+ # orderTag: 'CCXT',
444
+ # createdTime: 1715179456656,
445
+ # maker: False
446
+ # }
447
+ #
448
+ marketId = self.safe_string(trade, 'symbol')
449
+ market = self.safe_market(marketId, market)
450
+ symbol = market['symbol']
451
+ price = self.safe_string_2(trade, 'executedPrice', 'price')
452
+ amount = self.safe_string_2(trade, 'executedQuantity', 'size')
453
+ cost = Precise.string_mul(price, amount)
454
+ side = self.safe_string_lower(trade, 'side')
455
+ timestamp = self.safe_integer(trade, 'timestamp')
456
+ takerOrMaker = None
457
+ maker = self.safe_bool(trade, 'maker')
458
+ if maker is not None:
459
+ takerOrMaker = 'maker' if maker else 'taker'
460
+ fee = None
461
+ feeValue = self.safe_string(trade, 'fee')
462
+ if feeValue is not None:
463
+ fee = {
464
+ 'cost': feeValue,
465
+ 'currency': self.safe_currency_code(self.safe_string(trade, 'feeAsset')),
466
+ }
467
+ return self.safe_trade({
468
+ 'id': self.safe_string(trade, 'tradeId'),
469
+ 'timestamp': timestamp,
470
+ 'datetime': self.iso8601(timestamp),
471
+ 'symbol': symbol,
472
+ 'side': side,
473
+ 'price': price,
474
+ 'amount': amount,
475
+ 'cost': cost,
476
+ 'order': self.safe_string(trade, 'orderId'),
477
+ 'takerOrMaker': takerOrMaker,
478
+ 'type': self.safe_string_lower(trade, 'type'),
479
+ 'fee': fee,
480
+ 'info': trade,
481
+ }, market)
482
+
483
+ def handle_auth(self, client: Client, message):
484
+ #
485
+ # {
486
+ # "event": "auth",
487
+ # "success": True,
488
+ # "ts": 1657463158812
489
+ # }
490
+ #
491
+ messageHash = 'authenticated'
492
+ success = self.safe_value(message, 'success')
493
+ if success:
494
+ # client.resolve(message, messageHash)
495
+ future = self.safe_value(client.futures, 'authenticated')
496
+ future.resolve(True)
497
+ else:
498
+ error = AuthenticationError(self.json(message))
499
+ client.reject(error, messageHash)
500
+ # allows further authentication attempts
501
+ if messageHash in client.subscriptions:
502
+ del client.subscriptions['authenticated']
503
+
504
+ async def authenticate(self, params={}):
505
+ self.check_required_credentials()
506
+ url = self.urls['api']['ws']['private'] + '/' + self.accountId
507
+ client = self.client(url)
508
+ messageHash = 'authenticated'
509
+ event = 'auth'
510
+ future = client.future(messageHash)
511
+ authenticated = self.safe_value(client.subscriptions, messageHash)
512
+ if authenticated is None:
513
+ ts = str(self.nonce())
514
+ auth = ts
515
+ secret = self.secret
516
+ if secret.find('ed25519:') >= 0:
517
+ parts = secret.split('ed25519:')
518
+ secret = parts[1]
519
+ signature = self.eddsa(self.encode(auth), self.base58_to_binary(secret), 'ed25519')
520
+ request: dict = {
521
+ 'event': event,
522
+ 'params': {
523
+ 'orderly_key': self.apiKey,
524
+ 'sign': signature,
525
+ 'timestamp': ts,
526
+ },
527
+ }
528
+ message = self.extend(request, params)
529
+ self.watch(url, messageHash, message, messageHash)
530
+ return await future
531
+
532
+ async def watch_private(self, messageHash, message, params={}):
533
+ await self.authenticate(params)
534
+ url = self.urls['api']['ws']['private'] + '/' + self.accountId
535
+ requestId = self.request_id(url)
536
+ subscribe: dict = {
537
+ 'id': requestId,
538
+ }
539
+ request = self.extend(subscribe, message)
540
+ return await self.watch(url, messageHash, request, messageHash, subscribe)
541
+
542
+ async def watch_private_multiple(self, messageHashes, message, params={}):
543
+ await self.authenticate(params)
544
+ url = self.urls['api']['ws']['private'] + '/' + self.accountId
545
+ requestId = self.request_id(url)
546
+ subscribe: dict = {
547
+ 'id': requestId,
548
+ }
549
+ request = self.extend(subscribe, message)
550
+ return await self.watch_multiple(url, messageHashes, request, messageHashes, subscribe)
551
+
552
+ async def watch_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
553
+ """
554
+ watches information on multiple orders made by the user
555
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/private/execution-report
556
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/private/algo-execution-report
557
+ :param str symbol: unified market symbol of the market orders were made in
558
+ :param int [since]: the earliest time in ms to fetch orders for
559
+ :param int [limit]: the maximum number of order structures to retrieve
560
+ :param dict [params]: extra parameters specific to the exchange API endpoint
561
+ :param bool [params.trigger]: True if trigger order
562
+ :returns dict[]: a list of `order structures <https://docs.ccxt.com/#/?id=order-structure>`
563
+ """
564
+ await self.load_markets()
565
+ trigger = self.safe_bool_2(params, 'stop', 'trigger', False)
566
+ topic = 'algoexecutionreport' if (trigger) else 'executionreport'
567
+ params = self.omit(params, ['stop', 'trigger'])
568
+ messageHash = topic
569
+ if symbol is not None:
570
+ market = self.market(symbol)
571
+ symbol = market['symbol']
572
+ messageHash += ':' + symbol
573
+ request: dict = {
574
+ 'event': 'subscribe',
575
+ 'topic': topic,
576
+ }
577
+ message = self.extend(request, params)
578
+ orders = await self.watch_private(messageHash, message)
579
+ if self.newUpdates:
580
+ limit = orders.getLimit(symbol, limit)
581
+ return self.filter_by_symbol_since_limit(orders, symbol, since, limit, True)
582
+
583
+ async def watch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
584
+ """
585
+ watches information on multiple trades made by the user
586
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/private/execution-report
587
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/private/algo-execution-report
588
+ :param str symbol: unified market symbol of the market orders were made in
589
+ :param int [since]: the earliest time in ms to fetch orders for
590
+ :param int [limit]: the maximum number of order structures to retrieve
591
+ :param dict [params]: extra parameters specific to the exchange API endpoint
592
+ :param bool [params.trigger]: True if trigger order
593
+ :returns dict[]: a list of `order structures <https://docs.ccxt.com/#/?id=order-structure>`
594
+ """
595
+ await self.load_markets()
596
+ trigger = self.safe_bool_2(params, 'stop', 'trigger', False)
597
+ topic = 'algoexecutionreport' if (trigger) else 'executionreport'
598
+ params = self.omit(params, 'stop')
599
+ messageHash = 'myTrades'
600
+ if symbol is not None:
601
+ market = self.market(symbol)
602
+ symbol = market['symbol']
603
+ messageHash += ':' + symbol
604
+ request: dict = {
605
+ 'event': 'subscribe',
606
+ 'topic': topic,
607
+ }
608
+ message = self.extend(request, params)
609
+ orders = await self.watch_private(messageHash, message)
610
+ if self.newUpdates:
611
+ limit = orders.getLimit(symbol, limit)
612
+ return self.filter_by_symbol_since_limit(orders, symbol, since, limit, True)
613
+
614
+ def parse_ws_order(self, order, market=None):
615
+ #
616
+ # {
617
+ # "symbol": "PERP_BTC_USDT",
618
+ # "clientOrderId": 0,
619
+ # "orderId": 52952826,
620
+ # "type": "LIMIT",
621
+ # "side": "SELL",
622
+ # "quantity": 0.01,
623
+ # "price": 22000,
624
+ # "tradeId": 0,
625
+ # "executedPrice": 0,
626
+ # "executedQuantity": 0,
627
+ # "fee": 0,
628
+ # "feeAsset": "USDT",
629
+ # "totalExecutedQuantity": 0,
630
+ # "status": "NEW",
631
+ # "reason": '',
632
+ # "orderTag": "default",
633
+ # "totalFee": 0,
634
+ # "visible": 0.01,
635
+ # "timestamp": 1657515556799,
636
+ # "reduceOnly": False,
637
+ # "maker": False
638
+ # }
639
+ # algo order
640
+ # {
641
+ # "symbol":"PERP_MATIC_USDC",
642
+ # "rootAlgoOrderId":123,
643
+ # "parentAlgoOrderId":123,
644
+ # "algoOrderId":123,
645
+ # "orderTag":"some tags",
646
+ # "algoType": "STOP",
647
+ # "clientOrderId":"client_id",
648
+ # "type":"LIMIT",
649
+ # "side":"BUY",
650
+ # "quantity":7029.0,
651
+ # "price":0.7699,
652
+ # "tradeId":0,
653
+ # "triggerTradePrice":0,
654
+ # "triggerTime":1234567,
655
+ # "triggered": False,
656
+ # "activated": False,
657
+ # "executedPrice":0.0,
658
+ # "executedQuantity":0.0,
659
+ # "fee":0.0,
660
+ # "feeAsset":"USDC",
661
+ # "totalExecutedQuantity":0.0,
662
+ # "averageExecutedQuantity":0.0,
663
+ # "avgPrice":0,
664
+ # "triggerPrice":0.0,
665
+ # "triggerPriceType":"STOP",
666
+ # "isActivated": False,
667
+ # "status":"NEW",
668
+ # "rootAlgoStatus": "FILLED",
669
+ # "algoStatus": "FILLED",
670
+ # "reason":"",
671
+ # "totalFee":0.0,
672
+ # "visible": 7029.0,
673
+ # "visibleQuantity":7029.0,
674
+ # "timestamp":1704679472448,
675
+ # "maker":false,
676
+ # "isMaker":false,
677
+ # "createdTime":1704679472448
678
+ # }
679
+ #
680
+ orderId = self.safe_string(order, 'orderId')
681
+ marketId = self.safe_string(order, 'symbol')
682
+ market = self.market(marketId)
683
+ symbol = market['symbol']
684
+ timestamp = self.safe_integer(order, 'timestamp')
685
+ fee = {
686
+ 'cost': self.safe_string(order, 'totalFee'),
687
+ 'currency': self.safe_string(order, 'feeAsset'),
688
+ }
689
+ price = self.safe_number(order, 'price')
690
+ avgPrice = self.safe_number(order, 'avgPrice')
691
+ if (price == 0) and (avgPrice is not None):
692
+ price = avgPrice
693
+ amount = self.safe_string(order, 'quantity')
694
+ side = self.safe_string_lower(order, 'side')
695
+ type = self.safe_string_lower(order, 'type')
696
+ filled = self.safe_number(order, 'totalExecutedQuantity')
697
+ totalExecQuantity = self.safe_string(order, 'totalExecutedQuantity')
698
+ remaining = amount
699
+ if Precise.string_ge(amount, totalExecQuantity):
700
+ remaining = Precise.string_sub(remaining, totalExecQuantity)
701
+ rawStatus = self.safe_string(order, 'status')
702
+ status = self.parse_order_status(rawStatus)
703
+ trades = None
704
+ clientOrderId = self.safe_string(order, 'clientOrderId')
705
+ triggerPrice = self.safe_number(order, 'triggerPrice')
706
+ return self.safe_order({
707
+ 'info': order,
708
+ 'symbol': symbol,
709
+ 'id': orderId,
710
+ 'clientOrderId': clientOrderId,
711
+ 'timestamp': timestamp,
712
+ 'datetime': self.iso8601(timestamp),
713
+ 'lastTradeTimestamp': timestamp,
714
+ 'type': type,
715
+ 'timeInForce': None,
716
+ 'postOnly': None,
717
+ 'side': side,
718
+ 'price': price,
719
+ 'stopPrice': triggerPrice,
720
+ 'triggerPrice': triggerPrice,
721
+ 'amount': amount,
722
+ 'cost': None,
723
+ 'average': None,
724
+ 'filled': filled,
725
+ 'remaining': remaining,
726
+ 'status': status,
727
+ 'fee': fee,
728
+ 'trades': trades,
729
+ })
730
+
731
+ def handle_order_update(self, client: Client, message):
732
+ #
733
+ # {
734
+ # "topic": "executionreport",
735
+ # "ts": 1657515556799,
736
+ # "data": {
737
+ # "symbol": "PERP_BTC_USDT",
738
+ # "clientOrderId": 0,
739
+ # "orderId": 52952826,
740
+ # "type": "LIMIT",
741
+ # "side": "SELL",
742
+ # "quantity": 0.01,
743
+ # "price": 22000,
744
+ # "tradeId": 0,
745
+ # "executedPrice": 0,
746
+ # "executedQuantity": 0,
747
+ # "fee": 0,
748
+ # "feeAsset": "USDT",
749
+ # "totalExecutedQuantity": 0,
750
+ # "status": "NEW",
751
+ # "reason": '',
752
+ # "orderTag": "default",
753
+ # "totalFee": 0,
754
+ # "visible": 0.01,
755
+ # "timestamp": 1657515556799,
756
+ # "maker": False
757
+ # }
758
+ # }
759
+ #
760
+ topic = self.safe_string(message, 'topic')
761
+ data = self.safe_value(message, 'data')
762
+ if isinstance(data, list):
763
+ # algoexecutionreport
764
+ for i in range(0, len(data)):
765
+ order = data[i]
766
+ tradeId = self.omit_zero(self.safe_string(data, 'tradeId'))
767
+ if tradeId is not None:
768
+ self.handle_my_trade(client, order)
769
+ self.handle_order(client, order, topic)
770
+ else:
771
+ # executionreport
772
+ tradeId = self.omit_zero(self.safe_string(data, 'tradeId'))
773
+ if tradeId is not None:
774
+ self.handle_my_trade(client, data)
775
+ self.handle_order(client, data, topic)
776
+
777
+ def handle_order(self, client: Client, message, topic):
778
+ parsed = self.parse_ws_order(message)
779
+ symbol = self.safe_string(parsed, 'symbol')
780
+ orderId = self.safe_string(parsed, 'id')
781
+ if symbol is not None:
782
+ if self.orders is None:
783
+ limit = self.safe_integer(self.options, 'ordersLimit', 1000)
784
+ self.orders = ArrayCacheBySymbolById(limit)
785
+ cachedOrders = self.orders
786
+ orders = self.safe_dict(cachedOrders.hashmap, symbol, {})
787
+ order = self.safe_dict(orders, orderId)
788
+ if order is not None:
789
+ fee = self.safe_value(order, 'fee')
790
+ if fee is not None:
791
+ parsed['fee'] = fee
792
+ fees = self.safe_list(order, 'fees')
793
+ if fees is not None:
794
+ parsed['fees'] = fees
795
+ parsed['trades'] = self.safe_list(order, 'trades')
796
+ parsed['timestamp'] = self.safe_integer(order, 'timestamp')
797
+ parsed['datetime'] = self.safe_string(order, 'datetime')
798
+ cachedOrders.append(parsed)
799
+ client.resolve(self.orders, topic)
800
+ messageHashSymbol = topic + ':' + symbol
801
+ client.resolve(self.orders, messageHashSymbol)
802
+
803
+ def handle_my_trade(self, client: Client, message):
804
+ #
805
+ # {
806
+ # symbol: 'PERP_XRP_USDC',
807
+ # clientOrderId: '',
808
+ # orderId: 1167632251,
809
+ # type: 'MARKET',
810
+ # side: 'BUY',
811
+ # quantity: 20,
812
+ # price: 0,
813
+ # tradeId: '1715179456664012',
814
+ # executedPrice: 0.5276,
815
+ # executedQuantity: 20,
816
+ # fee: 0.006332,
817
+ # feeAsset: 'USDC',
818
+ # totalExecutedQuantity: 20,
819
+ # avgPrice: 0.5276,
820
+ # averageExecutedPrice: 0.5276,
821
+ # status: 'FILLED',
822
+ # reason: '',
823
+ # totalFee: 0.006332,
824
+ # visible: 0,
825
+ # visibleQuantity: 0,
826
+ # timestamp: 1715179456660,
827
+ # orderTag: 'CCXT',
828
+ # createdTime: 1715179456656,
829
+ # maker: False
830
+ # }
831
+ #
832
+ messageHash = 'myTrades'
833
+ marketId = self.safe_string(message, 'symbol')
834
+ market = self.safe_market(marketId)
835
+ symbol = market['symbol']
836
+ trade = self.parse_ws_trade(message, market)
837
+ trades = self.myTrades
838
+ if trades is None:
839
+ limit = self.safe_integer(self.options, 'tradesLimit', 1000)
840
+ trades = ArrayCacheBySymbolById(limit)
841
+ self.myTrades = trades
842
+ trades.append(trade)
843
+ client.resolve(trades, messageHash)
844
+ symbolSpecificMessageHash = messageHash + ':' + symbol
845
+ client.resolve(trades, symbolSpecificMessageHash)
846
+
847
+ async def watch_positions(self, symbols: Strings = None, since: Int = None, limit: Int = None, params={}) -> List[Position]:
848
+ """
849
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/private/position-push
850
+ watch all open positions
851
+ :param str[]|None symbols: list of unified market symbols
852
+ :param dict params: extra parameters specific to the exchange API endpoint
853
+ :returns dict[]: a list of `position structure <https://docs.ccxt.com/en/latest/manual.html#position-structure>`
854
+ """
855
+ await self.load_markets()
856
+ messageHashes = []
857
+ symbols = self.market_symbols(symbols)
858
+ if not self.is_empty(symbols):
859
+ for i in range(0, len(symbols)):
860
+ symbol = symbols[i]
861
+ messageHashes.append('positions::' + symbol)
862
+ else:
863
+ messageHashes.append('positions')
864
+ url = self.urls['api']['ws']['private'] + '/' + self.accountId
865
+ client = self.client(url)
866
+ self.set_positions_cache(client, symbols)
867
+ fetchPositionsSnapshot = self.handle_option('watchPositions', 'fetchPositionsSnapshot', True)
868
+ awaitPositionsSnapshot = self.safe_bool('watchPositions', 'awaitPositionsSnapshot', True)
869
+ if fetchPositionsSnapshot and awaitPositionsSnapshot and self.positions is None:
870
+ snapshot = await client.future('fetchPositionsSnapshot')
871
+ return self.filter_by_symbols_since_limit(snapshot, symbols, since, limit, True)
872
+ request: dict = {
873
+ 'event': 'subscribe',
874
+ 'topic': 'position',
875
+ }
876
+ newPositions = await self.watch_private_multiple(messageHashes, request, params)
877
+ if self.newUpdates:
878
+ return newPositions
879
+ return self.filter_by_symbols_since_limit(self.positions, symbols, since, limit, True)
880
+
881
+ def set_positions_cache(self, client: Client, type, symbols: Strings = None):
882
+ fetchPositionsSnapshot = self.handle_option('watchPositions', 'fetchPositionsSnapshot', False)
883
+ if fetchPositionsSnapshot:
884
+ messageHash = 'fetchPositionsSnapshot'
885
+ if not (messageHash in client.futures):
886
+ client.future(messageHash)
887
+ self.spawn(self.load_positions_snapshot, client, messageHash)
888
+ else:
889
+ self.positions = ArrayCacheBySymbolBySide()
890
+
891
+ async def load_positions_snapshot(self, client, messageHash):
892
+ positions = await self.fetch_positions()
893
+ self.positions = ArrayCacheBySymbolBySide()
894
+ cache = self.positions
895
+ for i in range(0, len(positions)):
896
+ position = positions[i]
897
+ contracts = self.safe_string(position, 'contracts', '0')
898
+ if Precise.string_gt(contracts, '0'):
899
+ cache.append(position)
900
+ # don't remove the future from the .futures cache
901
+ future = client.futures[messageHash]
902
+ future.resolve(cache)
903
+ client.resolve(cache, 'positions')
904
+
905
+ def handle_positions(self, client, message):
906
+ #
907
+ # {
908
+ # "topic":"position",
909
+ # "ts":1705292345255,
910
+ # "data":{
911
+ # "positions":[
912
+ # {
913
+ # "symbol":"PERP_ETH_USDC",
914
+ # "positionQty":3.1408,
915
+ # "costPosition":5706.51952,
916
+ # "lastSumUnitaryFunding":0.804,
917
+ # "sumUnitaryFundingVersion":0,
918
+ # "pendingLongQty":0.0,
919
+ # "pendingShortQty":-1.0,
920
+ # "settlePrice":1816.9,
921
+ # "averageOpenPrice":1804.51490427,
922
+ # "unsettledPnl":-2.79856,
923
+ # "pnl24H":-338.90179488,
924
+ # "fee24H":4.242423,
925
+ # "markPrice":1816.2,
926
+ # "estLiqPrice":0.0,
927
+ # "version":179967,
928
+ # "imrwithOrders":0.1,
929
+ # "mmrwithOrders":0.05,
930
+ # "mmr":0.05,
931
+ # "imr":0.1,
932
+ # "timestamp":1685154032762
933
+ # }
934
+ # ]
935
+ # }
936
+ # }
937
+ #
938
+ data = self.safe_dict(message, 'data', {})
939
+ rawPositions = self.safe_list(data, 'positions', [])
940
+ if self.positions is None:
941
+ self.positions = ArrayCacheBySymbolBySide()
942
+ cache = self.positions
943
+ newPositions = []
944
+ for i in range(0, len(rawPositions)):
945
+ rawPosition = rawPositions[i]
946
+ marketId = self.safe_string(rawPosition, 'symbol')
947
+ market = self.safe_market(marketId)
948
+ position = self.parse_ws_position(rawPosition, market)
949
+ newPositions.append(position)
950
+ cache.append(position)
951
+ messageHash = 'positions::' + market['symbol']
952
+ client.resolve(position, messageHash)
953
+ client.resolve(newPositions, 'positions')
954
+
955
+ def parse_ws_position(self, position, market=None):
956
+ #
957
+ # {
958
+ # "symbol":"PERP_ETH_USDC",
959
+ # "positionQty":3.1408,
960
+ # "costPosition":5706.51952,
961
+ # "lastSumUnitaryFunding":0.804,
962
+ # "sumUnitaryFundingVersion":0,
963
+ # "pendingLongQty":0.0,
964
+ # "pendingShortQty":-1.0,
965
+ # "settlePrice":1816.9,
966
+ # "averageOpenPrice":1804.51490427,
967
+ # "unsettledPnl":-2.79856,
968
+ # "pnl24H":-338.90179488,
969
+ # "fee24H":4.242423,
970
+ # "markPrice":1816.2,
971
+ # "estLiqPrice":0.0,
972
+ # "version":179967,
973
+ # "imrwithOrders":0.1,
974
+ # "mmrwithOrders":0.05,
975
+ # "mmr":0.05,
976
+ # "imr":0.1,
977
+ # "timestamp":1685154032762
978
+ # }
979
+ #
980
+ contract = self.safe_string(position, 'symbol')
981
+ market = self.safe_market(contract, market)
982
+ size = self.safe_string(position, 'positionQty')
983
+ side: Str = None
984
+ if Precise.string_gt(size, '0'):
985
+ side = 'long'
986
+ else:
987
+ side = 'short'
988
+ contractSize = self.safe_string(market, 'contractSize')
989
+ markPrice = self.safe_string(position, 'markPrice')
990
+ timestamp = self.safe_integer(position, 'timestamp')
991
+ entryPrice = self.safe_string(position, 'averageOpenPrice')
992
+ unrealisedPnl = self.safe_string(position, 'unsettledPnl')
993
+ size = Precise.string_abs(size)
994
+ notional = Precise.string_mul(size, markPrice)
995
+ return self.safe_position({
996
+ 'info': position,
997
+ 'id': None,
998
+ 'symbol': self.safe_string(market, 'symbol'),
999
+ 'timestamp': timestamp,
1000
+ 'datetime': self.iso8601(timestamp),
1001
+ 'lastUpdateTimestamp': None,
1002
+ 'initialMargin': None,
1003
+ 'initialMarginPercentage': None,
1004
+ 'maintenanceMargin': None,
1005
+ 'maintenanceMarginPercentage': None,
1006
+ 'entryPrice': self.parse_number(entryPrice),
1007
+ 'notional': self.parse_number(notional),
1008
+ 'leverage': None,
1009
+ 'unrealizedPnl': self.parse_number(unrealisedPnl),
1010
+ 'contracts': self.parse_number(size),
1011
+ 'contractSize': self.parse_number(contractSize),
1012
+ 'marginRatio': None,
1013
+ 'liquidationPrice': self.safe_number(position, 'estLiqPrice'),
1014
+ 'markPrice': self.parse_number(markPrice),
1015
+ 'lastPrice': None,
1016
+ 'collateral': None,
1017
+ 'marginMode': 'cross',
1018
+ 'marginType': None,
1019
+ 'side': side,
1020
+ 'percentage': None,
1021
+ 'hedged': None,
1022
+ 'stopLossPrice': None,
1023
+ 'takeProfitPrice': None,
1024
+ })
1025
+
1026
+ async def watch_balance(self, params={}) -> Balances:
1027
+ """
1028
+ watch balance and get the amount of funds available for trading or funds locked in orders
1029
+ :see: https://orderly.network/docs/build-on-evm/evm-api/websocket-api/private/balance
1030
+ :param dict [params]: extra parameters specific to the exchange API endpoint
1031
+ :returns dict: a `balance structure <https://docs.ccxt.com/#/?id=balance-structure>`
1032
+ """
1033
+ await self.load_markets()
1034
+ topic = 'balance'
1035
+ messageHash = topic
1036
+ request: dict = {
1037
+ 'event': 'subscribe',
1038
+ 'topic': topic,
1039
+ }
1040
+ message = self.extend(request, params)
1041
+ return await self.watch_private(messageHash, message)
1042
+
1043
+ def handle_balance(self, client, message):
1044
+ #
1045
+ # {
1046
+ # "topic":"balance",
1047
+ # "ts":1651836695254,
1048
+ # "data":{
1049
+ # "balances":{
1050
+ # "USDC":{
1051
+ # "holding":5555815.47398272,
1052
+ # "frozen":0,
1053
+ # "interest":0,
1054
+ # "pendingShortQty":0,
1055
+ # "pendingExposure":0,
1056
+ # "pendingLongQty":0,
1057
+ # "pendingLongExposure":0,
1058
+ # "version":894,
1059
+ # "staked":51370692,
1060
+ # "unbonding":0,
1061
+ # "vault":0,
1062
+ # "averageOpenPrice":0.00000574,
1063
+ # "pnl24H":0,
1064
+ # "fee24H":0.01914,
1065
+ # "markPrice":0.31885
1066
+ # }
1067
+ # }
1068
+ # }
1069
+ # }
1070
+ #
1071
+ data = self.safe_dict(message, 'data', {})
1072
+ balances = self.safe_dict(data, 'balances', {})
1073
+ keys = list(balances.keys())
1074
+ ts = self.safe_integer(message, 'ts')
1075
+ self.balance['info'] = data
1076
+ self.balance['timestamp'] = ts
1077
+ self.balance['datetime'] = self.iso8601(ts)
1078
+ for i in range(0, len(keys)):
1079
+ key = keys[i]
1080
+ value = balances[key]
1081
+ code = self.safe_currency_code(key)
1082
+ account = self.balance[code] if (code in self.balance) else self.account()
1083
+ total = self.safe_string(value, 'holding')
1084
+ used = self.safe_string(value, 'frozen')
1085
+ account['total'] = total
1086
+ account['used'] = used
1087
+ account['free'] = Precise.string_sub(total, used)
1088
+ self.balance[code] = account
1089
+ self.balance = self.safe_balance(self.balance)
1090
+ client.resolve(self.balance, 'balance')
1091
+
1092
+ def handle_error_message(self, client: Client, message):
1093
+ #
1094
+ # {"id":"1","event":"subscribe","success":false,"ts":1710780997216,"errorMsg":"Auth is needed."}
1095
+ #
1096
+ if not ('success' in message):
1097
+ return False
1098
+ success = self.safe_bool(message, 'success')
1099
+ if success:
1100
+ return False
1101
+ errorMessage = self.safe_string(message, 'errorMsg')
1102
+ try:
1103
+ if errorMessage is not None:
1104
+ feedback = self.id + ' ' + self.json(message)
1105
+ self.throw_exactly_matched_exception(self.exceptions['exact'], errorMessage, feedback)
1106
+ return False
1107
+ except Exception as error:
1108
+ if isinstance(error, AuthenticationError):
1109
+ messageHash = 'authenticated'
1110
+ client.reject(error, messageHash)
1111
+ if messageHash in client.subscriptions:
1112
+ del client.subscriptions[messageHash]
1113
+ else:
1114
+ client.reject(error)
1115
+ return True
1116
+
1117
+ def handle_message(self, client: Client, message):
1118
+ if self.handle_error_message(client, message):
1119
+ return
1120
+ methods: dict = {
1121
+ 'ping': self.handle_ping,
1122
+ 'pong': self.handle_pong,
1123
+ 'subscribe': self.handle_subscribe,
1124
+ 'orderbook': self.handle_order_book,
1125
+ 'ticker': self.handle_ticker,
1126
+ 'tickers': self.handle_tickers,
1127
+ 'kline': self.handle_ohlcv,
1128
+ 'trade': self.handle_trade,
1129
+ 'auth': self.handle_auth,
1130
+ 'executionreport': self.handle_order_update,
1131
+ 'algoexecutionreport': self.handle_order_update,
1132
+ 'position': self.handle_positions,
1133
+ 'balance': self.handle_balance,
1134
+ }
1135
+ event = self.safe_string(message, 'event')
1136
+ method = self.safe_value(methods, event)
1137
+ if method is not None:
1138
+ method(client, message)
1139
+ return
1140
+ topic = self.safe_string(message, 'topic')
1141
+ if topic is not None:
1142
+ method = self.safe_value(methods, topic)
1143
+ if method is not None:
1144
+ method(client, message)
1145
+ return
1146
+ splitTopic = topic.split('@')
1147
+ splitLength = len(splitTopic)
1148
+ if splitLength == 2:
1149
+ name = self.safe_string(splitTopic, 1)
1150
+ method = self.safe_value(methods, name)
1151
+ if method is not None:
1152
+ method(client, message)
1153
+ return
1154
+ splitName = name.split('_')
1155
+ splitNameLength = len(splitTopic)
1156
+ if splitNameLength == 2:
1157
+ method = self.safe_value(methods, self.safe_string(splitName, 0))
1158
+ if method is not None:
1159
+ method(client, message)
1160
+
1161
+ def ping(self, client: Client):
1162
+ return {'event': 'ping'}
1163
+
1164
+ def handle_ping(self, client: Client, message):
1165
+ return {'event': 'pong'}
1166
+
1167
+ def handle_pong(self, client: Client, message):
1168
+ #
1169
+ # {event: "pong", ts: 1614667590000}
1170
+ #
1171
+ client.lastPong = self.milliseconds()
1172
+ return message
1173
+
1174
+ def handle_subscribe(self, client: Client, message):
1175
+ #
1176
+ # {
1177
+ # "id": "666888",
1178
+ # "event": "subscribe",
1179
+ # "success": True,
1180
+ # "ts": 1657117712212
1181
+ # }
1182
+ #
1183
+ return message