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/phemex.py ADDED
@@ -0,0 +1,1441 @@
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
+ from ccxt.base.precise import Precise
14
+
15
+
16
+ class phemex(ccxt.async_support.phemex):
17
+
18
+ def describe(self):
19
+ return self.deep_extend(super(phemex, self).describe(), {
20
+ 'has': {
21
+ 'ws': True,
22
+ 'watchTicker': True,
23
+ 'watchTickers': False, # for now
24
+ 'watchTrades': True,
25
+ 'watchMyTrades': True,
26
+ 'watchOrders': True,
27
+ 'watchOrderBook': True,
28
+ 'watchOHLCV': True,
29
+ 'watchPositions': None, # TODO
30
+ # mutli-endpoints are not supported: https://github.com/ccxt/ccxt/pull/21490
31
+ 'watchOrderBookForSymbols': False,
32
+ 'watchTradesForSymbols': False,
33
+ 'watchOHLCVForSymbols': False,
34
+ },
35
+ 'urls': {
36
+ 'test': {
37
+ 'ws': 'wss://testnet-api.phemex.com/ws',
38
+ },
39
+ 'api': {
40
+ 'ws': 'wss://ws.phemex.com',
41
+ },
42
+ },
43
+ 'options': {
44
+ 'tradesLimit': 1000,
45
+ 'OHLCVLimit': 1000,
46
+ },
47
+ 'streaming': {
48
+ 'keepAlive': 10000,
49
+ },
50
+ })
51
+
52
+ def from_en(self, en, scale):
53
+ if en is None:
54
+ return None
55
+ precise = Precise(en)
56
+ precise.decimals = self.sum(precise.decimals, scale)
57
+ precise.reduce()
58
+ return str(precise)
59
+
60
+ def from_ep(self, ep, market=None):
61
+ if (ep is None) or (market is None):
62
+ return ep
63
+ return self.from_en(ep, self.safe_integer(market, 'priceScale'))
64
+
65
+ def from_ev(self, ev, market=None):
66
+ if (ev is None) or (market is None):
67
+ return ev
68
+ return self.from_en(ev, self.safe_integer(market, 'valueScale'))
69
+
70
+ def from_er(self, er, market=None):
71
+ if (er is None) or (market is None):
72
+ return er
73
+ return self.from_en(er, self.safe_integer(market, 'ratioScale'))
74
+
75
+ def request_id(self):
76
+ requestId = self.sum(self.safe_integer(self.options, 'requestId', 0), 1)
77
+ self.options['requestId'] = requestId
78
+ return requestId
79
+
80
+ def parse_swap_ticker(self, ticker, market=None):
81
+ #
82
+ # {
83
+ # "close": 442800,
84
+ # "fundingRate": 10000,
85
+ # "high": 445400,
86
+ # "indexPrice": 442621,
87
+ # "low": 428400,
88
+ # "markPrice": 442659,
89
+ # "open": 432200,
90
+ # "openInterest": 744183,
91
+ # "predFundingRate": 10000,
92
+ # "symbol": "LTCUSD",
93
+ # "turnover": 8133238294,
94
+ # "volume": 934292
95
+ # }
96
+ #
97
+ marketId = self.safe_string(ticker, 'symbol')
98
+ market = self.safe_market(marketId, market)
99
+ symbol = market['symbol']
100
+ timestamp = self.safe_integer_product(ticker, 'timestamp', 0.000001)
101
+ lastString = self.from_ep(self.safe_string(ticker, 'close'), market)
102
+ last = self.parse_number(lastString)
103
+ quoteVolume = self.parse_number(self.from_ev(self.safe_string(ticker, 'turnover'), market))
104
+ baseVolume = self.parse_number(self.from_ev(self.safe_string(ticker, 'volume'), market))
105
+ change = None
106
+ percentage = None
107
+ average = None
108
+ openString = self.omit_zero(self.from_ep(self.safe_string(ticker, 'open'), market))
109
+ open = self.parse_number(openString)
110
+ if (openString is not None) and (lastString is not None):
111
+ change = self.parse_number(Precise.string_sub(lastString, openString))
112
+ average = self.parse_number(Precise.string_div(Precise.string_add(lastString, openString), '2'))
113
+ percentage = self.parse_number(Precise.string_mul(Precise.string_sub(Precise.string_div(lastString, openString), '1'), '100'))
114
+ result: dict = {
115
+ 'symbol': symbol,
116
+ 'timestamp': timestamp,
117
+ 'datetime': self.iso8601(timestamp),
118
+ 'high': self.parse_number(self.from_ep(self.safe_string(ticker, 'high'), market)),
119
+ 'low': self.parse_number(self.from_ep(self.safe_string(ticker, 'low'), market)),
120
+ 'bid': None,
121
+ 'bidVolume': None,
122
+ 'ask': None,
123
+ 'askVolume': None,
124
+ 'vwap': None,
125
+ 'open': open,
126
+ 'close': last,
127
+ 'last': last,
128
+ 'previousClose': None, # previous day close
129
+ 'change': change,
130
+ 'percentage': percentage,
131
+ 'average': average,
132
+ 'baseVolume': baseVolume,
133
+ 'quoteVolume': quoteVolume,
134
+ 'info': ticker,
135
+ }
136
+ return result
137
+
138
+ def parse_perpetual_ticker(self, ticker, market=None):
139
+ #
140
+ # [
141
+ # "STXUSDT",
142
+ # "0.64649",
143
+ # "0.8628",
144
+ # "0.61215",
145
+ # "0.71737",
146
+ # "4519387",
147
+ # "3210827.98166",
148
+ # "697635",
149
+ # "0.71720205",
150
+ # "0.71720205",
151
+ # "0.0001",
152
+ # "0.0001",
153
+ # ]
154
+ #
155
+ marketId = self.safe_string(ticker, 0)
156
+ market = self.safe_market(marketId, market)
157
+ symbol = market['symbol']
158
+ lastString = self.from_ep(self.safe_string(ticker, 4), market)
159
+ last = self.parse_number(lastString)
160
+ quoteVolume = self.parse_number(self.from_ev(self.safe_string(ticker, 6), market))
161
+ baseVolume = self.parse_number(self.from_ev(self.safe_string(ticker, 5), market))
162
+ change = None
163
+ percentage = None
164
+ average = None
165
+ openString = self.omit_zero(self.from_ep(self.safe_string(ticker, 1), market))
166
+ open = self.parse_number(openString)
167
+ if (openString is not None) and (lastString is not None):
168
+ change = self.parse_number(Precise.string_sub(lastString, openString))
169
+ average = self.parse_number(Precise.string_div(Precise.string_add(lastString, openString), '2'))
170
+ percentage = self.parse_number(Precise.string_mul(Precise.string_sub(Precise.string_div(lastString, openString), '1'), '100'))
171
+ result: dict = {
172
+ 'symbol': symbol,
173
+ 'timestamp': None,
174
+ 'datetime': None,
175
+ 'high': self.parse_number(self.from_ep(self.safe_string(ticker, 2), market)),
176
+ 'low': self.parse_number(self.from_ep(self.safe_string(ticker, 3), market)),
177
+ 'bid': None,
178
+ 'bidVolume': None,
179
+ 'ask': None,
180
+ 'askVolume': None,
181
+ 'vwap': None,
182
+ 'open': open,
183
+ 'close': last,
184
+ 'last': last,
185
+ 'previousClose': None, # previous day close
186
+ 'change': change,
187
+ 'percentage': percentage,
188
+ 'average': average,
189
+ 'baseVolume': baseVolume,
190
+ 'quoteVolume': quoteVolume,
191
+ 'info': ticker,
192
+ }
193
+ return result
194
+
195
+ def handle_ticker(self, client: Client, message):
196
+ #
197
+ # {
198
+ # "spot_market24h": {
199
+ # "askEp": 958148000000,
200
+ # "bidEp": 957884000000,
201
+ # "highEp": 962000000000,
202
+ # "lastEp": 958220000000,
203
+ # "lowEp": 928049000000,
204
+ # "openEp": 935597000000,
205
+ # "symbol": "sBTCUSDT",
206
+ # "turnoverEv": 146074214388978,
207
+ # "volumeEv": 15492228900
208
+ # },
209
+ # "timestamp": 1592847265888272100
210
+ # }
211
+ #
212
+ # swap
213
+ #
214
+ # {
215
+ # "market24h": {
216
+ # "close": 442800,
217
+ # "fundingRate": 10000,
218
+ # "high": 445400,
219
+ # "indexPrice": 442621,
220
+ # "low": 428400,
221
+ # "markPrice": 442659,
222
+ # "open": 432200,
223
+ # "openInterest": 744183,
224
+ # "predFundingRate": 10000,
225
+ # "symbol": "LTCUSD",
226
+ # "turnover": 8133238294,
227
+ # "volume": 934292
228
+ # },
229
+ # "timestamp": 1592845585373374500
230
+ # }
231
+ #
232
+ # perpetual
233
+ #
234
+ # {
235
+ # "data": [
236
+ # [
237
+ # "STXUSDT",
238
+ # "0.64649",
239
+ # "0.8628",
240
+ # "0.61215",
241
+ # "0.71737",
242
+ # "4519387",
243
+ # "3210827.98166",
244
+ # "697635",
245
+ # "0.71720205",
246
+ # "0.71720205",
247
+ # "0.0001",
248
+ # "0.0001",
249
+ # ],
250
+ # ...
251
+ # ],
252
+ # "fields": [
253
+ # "symbol",
254
+ # "openRp",
255
+ # "highRp",
256
+ # "lowRp",
257
+ # "lastRp",
258
+ # "volumeRq",
259
+ # "turnoverRv",
260
+ # "openInterestRv",
261
+ # "indexRp",
262
+ # "markRp",
263
+ # "fundingRateRr",
264
+ # "predFundingRateRr",
265
+ # ],
266
+ # "method": "perp_market24h_pack_p.update",
267
+ # "timestamp": "1677094918686806209",
268
+ # "type": "snapshot",
269
+ # }
270
+ #
271
+ tickers = []
272
+ if 'market24h' in message:
273
+ ticker = self.safe_value(message, 'market24h')
274
+ tickers.append(self.parse_swap_ticker(ticker))
275
+ elif 'spot_market24h' in message:
276
+ ticker = self.safe_value(message, 'spot_market24h')
277
+ tickers.append(self.parse_ticker(ticker))
278
+ elif 'data' in message:
279
+ data = self.safe_value(message, 'data', [])
280
+ for i in range(0, len(data)):
281
+ tickers.append(self.parse_perpetual_ticker(data[i]))
282
+ for i in range(0, len(tickers)):
283
+ ticker = tickers[i]
284
+ symbol = ticker['symbol']
285
+ messageHash = 'ticker:' + symbol
286
+ timestamp = self.safe_integer_product(message, 'timestamp', 0.000001)
287
+ ticker['timestamp'] = timestamp
288
+ ticker['datetime'] = self.iso8601(timestamp)
289
+ self.tickers[symbol] = ticker
290
+ client.resolve(ticker, messageHash)
291
+
292
+ async def watch_balance(self, params={}) -> Balances:
293
+ """
294
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Hedged-Perpetual-API.md#subscribe-account-order-position-aop
295
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Contract-API-en.md#subscribe-account-order-position-aop
296
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Spot-API-en.md#subscribe-wallet-order-messages
297
+ watch balance and get the amount of funds available for trading or funds locked in orders
298
+ :param dict [params]: extra parameters specific to the exchange API endpoint
299
+ :param str [params.settle]: set to USDT to use hedged perpetual api
300
+ :returns dict: a `balance structure <https://docs.ccxt.com/#/?id=balance-structure>`
301
+ """
302
+ await self.load_markets()
303
+ type = None
304
+ type, params = self.handle_market_type_and_params('watchBalance', None, params)
305
+ usePerpetualApi = self.safe_string(params, 'settle') == 'USDT'
306
+ messageHash = ':balance'
307
+ messageHash = 'perpetual' + messageHash if usePerpetualApi else type + messageHash
308
+ return await self.subscribe_private(type, messageHash, params)
309
+
310
+ def handle_balance(self, type, client, message):
311
+ # spot
312
+ # [
313
+ # {
314
+ # "balanceEv": 0,
315
+ # "currency": "BTC",
316
+ # "lastUpdateTimeNs": "1650442638722099092",
317
+ # "lockedTradingBalanceEv": 0,
318
+ # "lockedWithdrawEv": 0,
319
+ # "userID": 2647224
320
+ # },
321
+ # {
322
+ # "balanceEv": 1154232337,
323
+ # "currency": "USDT",
324
+ # "lastUpdateTimeNs": "1650442617610017597",
325
+ # "lockedTradingBalanceEv": 0,
326
+ # "lockedWithdrawEv": 0,
327
+ # "userID": 2647224
328
+ # }
329
+ # ]
330
+ # swap
331
+ # [
332
+ # {
333
+ # "accountBalanceEv": 0,
334
+ # "accountID": 26472240001,
335
+ # "bonusBalanceEv": 0,
336
+ # "currency": "BTC",
337
+ # "totalUsedBalanceEv": 0,
338
+ # "userID": 2647224
339
+ # }
340
+ # ]
341
+ # perpetual
342
+ # [
343
+ # {
344
+ # "accountBalanceRv": "1508.452588802237",
345
+ # "accountID": 9328670003,
346
+ # "bonusBalanceRv": "0",
347
+ # "currency": "USDT",
348
+ # "totalUsedBalanceRv": "343.132599666883",
349
+ # "userID": 932867
350
+ # }
351
+ # ]
352
+ #
353
+ self.balance['info'] = message
354
+ for i in range(0, len(message)):
355
+ balance = message[i]
356
+ currencyId = self.safe_string(balance, 'currency')
357
+ code = self.safe_currency_code(currencyId)
358
+ currency = self.safe_value(self.currencies, code, {})
359
+ scale = self.safe_integer(currency, 'valueScale', 8)
360
+ account = self.account()
361
+ used = self.safe_string(balance, 'totalUsedBalanceRv')
362
+ if used is None:
363
+ usedEv = self.safe_string(balance, 'totalUsedBalanceEv')
364
+ if usedEv is None:
365
+ lockedTradingBalanceEv = self.safe_string(balance, 'lockedTradingBalanceEv')
366
+ lockedWithdrawEv = self.safe_string_2(balance, 'lockedWithdrawEv', 'lockedWithdrawRv')
367
+ usedEv = Precise.string_add(lockedTradingBalanceEv, lockedWithdrawEv)
368
+ used = self.from_en(usedEv, scale)
369
+ total = self.safe_string(balance, 'accountBalanceRv')
370
+ if total is None:
371
+ totalEv = self.safe_string_2(balance, 'accountBalanceEv', 'balanceEv')
372
+ total = self.from_en(totalEv, scale)
373
+ account['used'] = used
374
+ account['total'] = total
375
+ self.balance[code] = account
376
+ self.balance = self.safe_balance(self.balance)
377
+ messageHash = type + ':balance'
378
+ client.resolve(self.balance, messageHash)
379
+
380
+ def handle_trades(self, client: Client, message):
381
+ #
382
+ # {
383
+ # "sequence": 1795484727,
384
+ # "symbol": "sBTCUSDT",
385
+ # "trades": [
386
+ # [1592891002064516600, "Buy", 964020000000, 1431000],
387
+ # [1592890978987934500, "Sell", 963704000000, 1401800],
388
+ # [1592890972918701800, "Buy", 963938000000, 2018600],
389
+ # ],
390
+ # "type": "snapshot"
391
+ # }
392
+ # perpetual
393
+ # {
394
+ # "sequence": 1230197759,
395
+ # "symbol": "BTCUSDT",
396
+ # "trades_p": [
397
+ # [
398
+ # 1677094244729433000,
399
+ # "Buy",
400
+ # "23800.4",
401
+ # "2.455",
402
+ # ],
403
+ # ],
404
+ # "type": "snapshot",
405
+ # }
406
+ #
407
+ name = 'trade'
408
+ marketId = self.safe_string(message, 'symbol')
409
+ market = self.safe_market(marketId)
410
+ symbol = market['symbol']
411
+ messageHash = name + ':' + symbol
412
+ stored = self.safe_value(self.trades, symbol)
413
+ if stored is None:
414
+ limit = self.safe_integer(self.options, 'tradesLimit', 1000)
415
+ stored = ArrayCache(limit)
416
+ self.trades[symbol] = stored
417
+ trades = self.safe_value_2(message, 'trades', 'trades_p', [])
418
+ parsed = self.parse_trades(trades, market)
419
+ for i in range(0, len(parsed)):
420
+ stored.append(parsed[i])
421
+ client.resolve(stored, messageHash)
422
+
423
+ def handle_ohlcv(self, client: Client, message):
424
+ #
425
+ # {
426
+ # "kline": [
427
+ # [1592905200, 60, 960688000000, 960709000000, 960709000000, 960400000000, 960400000000, 848100, 8146756046],
428
+ # [1592905140, 60, 960718000000, 960716000000, 960717000000, 960560000000, 960688000000, 4284900, 41163743512],
429
+ # [1592905080, 60, 960513000000, 960684000000, 960718000000, 960684000000, 960718000000, 4880500, 46887494349],
430
+ # ],
431
+ # "sequence": 1804401474,
432
+ # "symbol": "sBTCUSDT",
433
+ # "type": "snapshot"
434
+ # }
435
+ # perpetual
436
+ # {
437
+ # "kline_p": [
438
+ # [
439
+ # 1677094560,
440
+ # 60,
441
+ # "23746.2",
442
+ # "23746.1",
443
+ # "23757.6",
444
+ # "23736.9",
445
+ # "23754.8",
446
+ # "34.273",
447
+ # "813910.208",
448
+ # ],
449
+ # ],
450
+ # "sequence": 1230786017,
451
+ # "symbol": "BTCUSDT",
452
+ # "type": "incremental",
453
+ # }
454
+ #
455
+ marketId = self.safe_string(message, 'symbol')
456
+ market = self.safe_market(marketId)
457
+ symbol = market['symbol']
458
+ candles = self.safe_value_2(message, 'kline', 'kline_p', [])
459
+ first = self.safe_value(candles, 0, [])
460
+ interval = self.safe_string(first, 1)
461
+ timeframe = self.find_timeframe(interval)
462
+ if timeframe is not None:
463
+ messageHash = 'kline:' + timeframe + ':' + symbol
464
+ ohlcvs = self.parse_ohlcvs(candles, market)
465
+ self.ohlcvs[symbol] = self.safe_value(self.ohlcvs, symbol, {})
466
+ stored = self.safe_value(self.ohlcvs[symbol], timeframe)
467
+ if stored is None:
468
+ limit = self.safe_integer(self.options, 'OHLCVLimit', 1000)
469
+ stored = ArrayCacheByTimestamp(limit)
470
+ self.ohlcvs[symbol][timeframe] = stored
471
+ for i in range(0, len(ohlcvs)):
472
+ candle = ohlcvs[i]
473
+ stored.append(candle)
474
+ client.resolve(stored, messageHash)
475
+
476
+ async def watch_ticker(self, symbol: str, params={}) -> Ticker:
477
+ """
478
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Hedged-Perpetual-API.md#subscribe-24-hours-ticker
479
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Contract-API-en.md#subscribe-24-hours-ticker
480
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Spot-API-en.md#subscribe-24-hours-ticker
481
+ watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
482
+ :param str symbol: unified symbol of the market to fetch the ticker for
483
+ :param dict [params]: extra parameters specific to the exchange API endpoint
484
+ :returns dict: a `ticker structure <https://docs.ccxt.com/#/?id=ticker-structure>`
485
+ """
486
+ await self.load_markets()
487
+ market = self.market(symbol)
488
+ symbol = market['symbol']
489
+ isSwap = market['swap']
490
+ settleIsUSDT = market['settle'] == 'USDT'
491
+ name = 'spot_market24h'
492
+ if isSwap:
493
+ name = 'perp_market24h_pack_p' if settleIsUSDT else 'market24h'
494
+ url = self.urls['api']['ws']
495
+ requestId = self.request_id()
496
+ subscriptionHash = name + '.subscribe'
497
+ messageHash = 'ticker:' + symbol
498
+ subscribe: dict = {
499
+ 'method': subscriptionHash,
500
+ 'id': requestId,
501
+ 'params': [],
502
+ }
503
+ request = self.deep_extend(subscribe, params)
504
+ return await self.watch(url, messageHash, request, subscriptionHash)
505
+
506
+ async def watch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
507
+ """
508
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Hedged-Perpetual-API.md#subscribe-trade
509
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Contract-API-en.md#subscribe-trade
510
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Spot-API-en.md#subscribe-trade
511
+ get the list of most recent trades for a particular symbol
512
+ :param str symbol: unified symbol of the market to fetch trades for
513
+ :param int [since]: timestamp in ms of the earliest trade to fetch
514
+ :param int [limit]: the maximum amount of trades to fetch
515
+ :param dict [params]: extra parameters specific to the exchange API endpoint
516
+ :returns dict[]: a list of `trade structures <https://docs.ccxt.com/#/?id=public-trades>`
517
+ """
518
+ await self.load_markets()
519
+ market = self.market(symbol)
520
+ symbol = market['symbol']
521
+ url = self.urls['api']['ws']
522
+ requestId = self.request_id()
523
+ isSwap = market['swap']
524
+ settleIsUSDT = market['settle'] == 'USDT'
525
+ name = 'trade_p' if (isSwap and settleIsUSDT) else 'trade'
526
+ messageHash = 'trade:' + symbol
527
+ method = name + '.subscribe'
528
+ subscribe: dict = {
529
+ 'method': method,
530
+ 'id': requestId,
531
+ 'params': [
532
+ market['id'],
533
+ ],
534
+ }
535
+ request = self.deep_extend(subscribe, params)
536
+ trades = await self.watch(url, messageHash, request, messageHash)
537
+ if self.newUpdates:
538
+ limit = trades.getLimit(symbol, limit)
539
+ return self.filter_by_since_limit(trades, since, limit, 'timestamp', True)
540
+
541
+ async def watch_order_book(self, symbol: str, limit: Int = None, params={}) -> OrderBook:
542
+ """
543
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Spot-API-en.md#subscribe-orderbook
544
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Hedged-Perpetual-API.md#subscribe-orderbook-for-new-model
545
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Contract-API-en.md#subscribe-30-levels-orderbook
546
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Contract-API-en.md#subscribe-full-orderbook
547
+ watches information on open orders with bid(buy) and ask(sell) prices, volumes and other data
548
+ :param str symbol: unified symbol of the market to fetch the order book for
549
+ :param int [limit]: the maximum amount of order book entries to return
550
+ :param dict [params]: extra parameters specific to the exchange API endpoint
551
+ :returns dict: A dictionary of `order book structures <https://docs.ccxt.com/#/?id=order-book-structure>` indexed by market symbols
552
+ """
553
+ await self.load_markets()
554
+ market = self.market(symbol)
555
+ symbol = market['symbol']
556
+ url = self.urls['api']['ws']
557
+ requestId = self.request_id()
558
+ isSwap = market['swap']
559
+ settleIsUSDT = market['settle'] == 'USDT'
560
+ name = 'orderbook_p' if (isSwap and settleIsUSDT) else 'orderbook'
561
+ messageHash = 'orderbook:' + symbol
562
+ method = name + '.subscribe'
563
+ subscribe: dict = {
564
+ 'method': method,
565
+ 'id': requestId,
566
+ 'params': [
567
+ market['id'],
568
+ ],
569
+ }
570
+ request = self.deep_extend(subscribe, params)
571
+ orderbook = await self.watch(url, messageHash, request, messageHash)
572
+ return orderbook.limit()
573
+
574
+ async def watch_ohlcv(self, symbol: str, timeframe='1m', since: Int = None, limit: Int = None, params={}) -> List[list]:
575
+ """
576
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Hedged-Perpetual-API.md#subscribe-kline
577
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Contract-API-en.md#subscribe-kline
578
+ :see: https://github.com/phemex/phemex-api-docs/blob/master/Public-Spot-API-en.md#subscribe-kline
579
+ watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
580
+ :param str symbol: unified symbol of the market to fetch OHLCV data for
581
+ :param str timeframe: the length of time each candle represents
582
+ :param int [since]: timestamp in ms of the earliest candle to fetch
583
+ :param int [limit]: the maximum amount of candles to fetch
584
+ :param dict [params]: extra parameters specific to the exchange API endpoint
585
+ :returns int[][]: A list of candles ordered, open, high, low, close, volume
586
+ """
587
+ await self.load_markets()
588
+ market = self.market(symbol)
589
+ symbol = market['symbol']
590
+ url = self.urls['api']['ws']
591
+ requestId = self.request_id()
592
+ isSwap = market['swap']
593
+ settleIsUSDT = market['settle'] == 'USDT'
594
+ name = 'kline_p' if (isSwap and settleIsUSDT) else 'kline'
595
+ messageHash = 'kline:' + timeframe + ':' + symbol
596
+ method = name + '.subscribe'
597
+ subscribe: dict = {
598
+ 'method': method,
599
+ 'id': requestId,
600
+ 'params': [
601
+ market['id'],
602
+ self.safe_integer(self.timeframes, timeframe),
603
+ ],
604
+ }
605
+ request = self.deep_extend(subscribe, params)
606
+ ohlcv = await self.watch(url, messageHash, request, messageHash)
607
+ if self.newUpdates:
608
+ limit = ohlcv.getLimit(symbol, limit)
609
+ return self.filter_by_since_limit(ohlcv, since, limit, 0, True)
610
+
611
+ def custom_handle_delta(self, bookside, delta, market=None):
612
+ bidAsk = self.custom_parse_bid_ask(delta, 0, 1, market)
613
+ bookside.storeArray(bidAsk)
614
+
615
+ def custom_handle_deltas(self, bookside, deltas, market=None):
616
+ for i in range(0, len(deltas)):
617
+ self.custom_handle_delta(bookside, deltas[i], market)
618
+
619
+ def handle_order_book(self, client: Client, message):
620
+ #
621
+ # {
622
+ # "book": {
623
+ # "asks": [
624
+ # [960316000000, 6993800],
625
+ # [960318000000, 13183000],
626
+ # [960319000000, 9170200],
627
+ # ],
628
+ # "bids": [
629
+ # [959941000000, 8385300],
630
+ # [959939000000, 10296600],
631
+ # [959930000000, 3672400],
632
+ # ]
633
+ # },
634
+ # "depth": 30,
635
+ # "sequence": 1805784701,
636
+ # "symbol": "sBTCUSDT",
637
+ # "timestamp": 1592908460404461600,
638
+ # "type": "snapshot"
639
+ # }
640
+ # perpetual
641
+ # {
642
+ # "depth": 30,
643
+ # "orderbook_p": {
644
+ # "asks": [
645
+ # [
646
+ # "23788.5",
647
+ # "0.13",
648
+ # ],
649
+ # ],
650
+ # "bids": [
651
+ # [
652
+ # "23787.8",
653
+ # "1.836",
654
+ # ],
655
+ # ],
656
+ # },
657
+ # "sequence": 1230347368,
658
+ # "symbol": "BTCUSDT",
659
+ # "timestamp": "1677093457306978852",
660
+ # "type": "snapshot",
661
+ # }
662
+ #
663
+ marketId = self.safe_string(message, 'symbol')
664
+ market = self.safe_market(marketId)
665
+ symbol = market['symbol']
666
+ type = self.safe_string(message, 'type')
667
+ depth = self.safe_integer(message, 'depth')
668
+ name = 'orderbook'
669
+ messageHash = name + ':' + symbol
670
+ nonce = self.safe_integer(message, 'sequence')
671
+ timestamp = self.safe_integer_product(message, 'timestamp', 0.000001)
672
+ if type == 'snapshot':
673
+ book = self.safe_value_2(message, 'book', 'orderbook_p', {})
674
+ snapshot = self.custom_parse_order_book(book, symbol, timestamp, 'bids', 'asks', 0, 1, market)
675
+ snapshot['nonce'] = nonce
676
+ orderbook = self.order_book(snapshot, depth)
677
+ self.orderbooks[symbol] = orderbook
678
+ client.resolve(orderbook, messageHash)
679
+ else:
680
+ if symbol in self.orderbooks:
681
+ orderbook = self.orderbooks[symbol]
682
+ changes = self.safe_dict_2(message, 'book', 'orderbook_p', {})
683
+ asks = self.safe_list(changes, 'asks', [])
684
+ bids = self.safe_list(changes, 'bids', [])
685
+ self.custom_handle_deltas(orderbook['asks'], asks, market)
686
+ self.custom_handle_deltas(orderbook['bids'], bids, market)
687
+ orderbook['nonce'] = nonce
688
+ orderbook['timestamp'] = timestamp
689
+ orderbook['datetime'] = self.iso8601(timestamp)
690
+ self.orderbooks[symbol] = orderbook
691
+ client.resolve(orderbook, messageHash)
692
+
693
+ async def watch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
694
+ """
695
+ watches information on multiple trades made by the user
696
+ :param str symbol: unified market symbol of the market trades were made in
697
+ :param int [since]: the earliest time in ms to fetch trades for
698
+ :param int [limit]: the maximum number of trade structures to retrieve
699
+ :param dict [params]: extra parameters specific to the exchange API endpoint
700
+ :returns dict[]: a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure
701
+ """
702
+ await self.load_markets()
703
+ market = None
704
+ type = None
705
+ messageHash = 'trades:'
706
+ if symbol is not None:
707
+ market = self.market(symbol)
708
+ symbol = market['symbol']
709
+ messageHash = messageHash + market['symbol']
710
+ if market['settle'] == 'USDT':
711
+ params = self.extend(params)
712
+ params['settle'] = 'USDT'
713
+ type, params = self.handle_market_type_and_params('watchMyTrades', market, params)
714
+ if symbol is None:
715
+ settle = self.safe_string(params, 'settle')
716
+ messageHash = (messageHash + 'perpetual') if (settle == 'USDT') else (messageHash + type)
717
+ trades = await self.subscribe_private(type, messageHash, params)
718
+ if self.newUpdates:
719
+ limit = trades.getLimit(symbol, limit)
720
+ return self.filter_by_symbol_since_limit(trades, symbol, since, limit, True)
721
+
722
+ def handle_my_trades(self, client: Client, message):
723
+ #
724
+ # swap
725
+ # [
726
+ # {
727
+ # "avgPriceEp":4138763000000,
728
+ # "baseCurrency":"BTC",
729
+ # "baseQtyEv":0,
730
+ # "clOrdID":"7956e0be-e8be-93a0-2887-ca504d85cda2",
731
+ # "execBaseQtyEv":30100,
732
+ # "execFeeEv":31,
733
+ # "execID":"d3b10cfa-84e3-5752-828e-78a79617e598",
734
+ # "execPriceEp":4138763000000,
735
+ # "execQuoteQtyEv":1245767663,
736
+ # "feeCurrency":"BTC",
737
+ # "lastLiquidityInd":"RemovedLiquidity",
738
+ # "ordType":"Market",
739
+ # "orderID":"34a4b1a8-ac3a-4580-b3e6-a6d039f27195",
740
+ # "priceEp":4549022000000,
741
+ # "qtyType":"ByQuote",
742
+ # "quoteCurrency":"USDT",
743
+ # "quoteQtyEv":1248000000,
744
+ # "side":"Buy",
745
+ # "symbol":"sBTCUSDT",
746
+ # "tradeType":"Trade",
747
+ # "transactTimeNs":"1650442617609928764",
748
+ # "userID":2647224
749
+ # }
750
+ # ]
751
+ # perpetual
752
+ # [
753
+ # {
754
+ # "accountID": 9328670003,
755
+ # "action": "New",
756
+ # "actionBy": "ByUser",
757
+ # "actionTimeNs": 1666858780876924611,
758
+ # "addedSeq": 77751555,
759
+ # "apRp": "0",
760
+ # "bonusChangedAmountRv": "0",
761
+ # "bpRp": "0",
762
+ # "clOrdID": "c0327a7d-9064-62a9-28f6-2db9aaaa04e0",
763
+ # "closedPnlRv": "0",
764
+ # "closedSize": "0",
765
+ # "code": 0,
766
+ # "cumFeeRv": "0",
767
+ # "cumQty": "0",
768
+ # "cumValueRv": "0",
769
+ # "curAccBalanceRv": "1508.489893982237",
770
+ # "curAssignedPosBalanceRv": "24.62786650928",
771
+ # "curBonusBalanceRv": "0",
772
+ # "curLeverageRr": "-10",
773
+ # "curPosSide": "Buy",
774
+ # "curPosSize": "0.043",
775
+ # "curPosTerm": 1,
776
+ # "curPosValueRv": "894.0689",
777
+ # "curRiskLimitRv": "1000000",
778
+ # "currency": "USDT",
779
+ # "cxlRejReason": 0,
780
+ # "displayQty": "0.003",
781
+ # "execFeeRv": "0",
782
+ # "execID": "00000000-0000-0000-0000-000000000000",
783
+ # "execPriceRp": "20723.7",
784
+ # "execQty": "0",
785
+ # "execSeq": 77751555,
786
+ # "execStatus": "New",
787
+ # "execValueRv": "0",
788
+ # "feeRateRr": "0",
789
+ # "leavesQty": "0.003",
790
+ # "leavesValueRv": "63.4503",
791
+ # "message": "No error",
792
+ # "ordStatus": "New",
793
+ # "ordType": "Market",
794
+ # "orderID": "fa64c6f2-47a4-4929-aab4-b7fa9bbc4323",
795
+ # "orderQty": "0.003",
796
+ # "pegOffsetValueRp": "0",
797
+ # "posSide": "Long",
798
+ # "priceRp": "21150.1",
799
+ # "relatedPosTerm": 1,
800
+ # "relatedReqNum": 11,
801
+ # "side": "Buy",
802
+ # "slTrigger": "ByMarkPrice",
803
+ # "stopLossRp": "0",
804
+ # "stopPxRp": "0",
805
+ # "symbol": "BTCUSDT",
806
+ # "takeProfitRp": "0",
807
+ # "timeInForce": "ImmediateOrCancel",
808
+ # "tpTrigger": "ByLastPrice",
809
+ # "tradeType": "Amend",
810
+ # "transactTimeNs": 1666858780881545305,
811
+ # "userID": 932867
812
+ # },
813
+ # ...
814
+ # ]
815
+ #
816
+ channel = 'trades'
817
+ tradesLength = len(message)
818
+ if tradesLength == 0:
819
+ return
820
+ cachedTrades = self.myTrades
821
+ if cachedTrades is None:
822
+ limit = self.safe_integer(self.options, 'tradesLimit', 1000)
823
+ cachedTrades = ArrayCacheBySymbolById(limit)
824
+ marketIds: dict = {}
825
+ type = None
826
+ for i in range(0, len(message)):
827
+ rawTrade = message[i]
828
+ marketId = self.safe_string(rawTrade, 'symbol')
829
+ market = self.safe_market(marketId)
830
+ parsed = self.parse_trade(rawTrade)
831
+ cachedTrades.append(parsed)
832
+ symbol = parsed['symbol']
833
+ if type is None:
834
+ type = 'perpetual' if (market['settle'] == 'USDT') else market['type']
835
+ marketIds[symbol] = True
836
+ keys = list(marketIds.keys())
837
+ for i in range(0, len(keys)):
838
+ market = keys[i]
839
+ hash = channel + ':' + market
840
+ client.resolve(cachedTrades, hash)
841
+ # generic subscription
842
+ messageHash = channel + ':' + type
843
+ client.resolve(cachedTrades, messageHash)
844
+
845
+ async def watch_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
846
+ """
847
+ watches information on multiple orders made by the user
848
+ :param str symbol: unified market symbol of the market orders were made in
849
+ :param int [since]: the earliest time in ms to fetch orders for
850
+ :param int [limit]: the maximum number of order structures to retrieve
851
+ :param dict [params]: extra parameters specific to the exchange API endpoint
852
+ :returns dict[]: a list of `order structures <https://docs.ccxt.com/#/?id=order-structure>`
853
+ """
854
+ await self.load_markets()
855
+ messageHash = 'orders:'
856
+ market = None
857
+ type = None
858
+ if symbol is not None:
859
+ market = self.market(symbol)
860
+ symbol = market['symbol']
861
+ messageHash = messageHash + market['symbol']
862
+ if market['settle'] == 'USDT':
863
+ params = self.extend(params)
864
+ params['settle'] = 'USDT'
865
+ type, params = self.handle_market_type_and_params('watchOrders', market, params)
866
+ isUSDTSettled = self.safe_string(params, 'settle') == 'USDT'
867
+ if symbol is None:
868
+ messageHash = (messageHash + 'perpetual') if (isUSDTSettled) else (messageHash + type)
869
+ orders = await self.subscribe_private(type, messageHash, params)
870
+ if self.newUpdates:
871
+ limit = orders.getLimit(symbol, limit)
872
+ return self.filter_by_symbol_since_limit(orders, symbol, since, limit, True)
873
+
874
+ def handle_orders(self, client: Client, message):
875
+ # spot update
876
+ # {
877
+ # "closed":[
878
+ # {
879
+ # "action":"New",
880
+ # "avgPriceEp":4138763000000,
881
+ # "baseCurrency":"BTC",
882
+ # "baseQtyEv":0,
883
+ # "bizError":0,
884
+ # "clOrdID":"7956e0be-e8be-93a0-2887-ca504d85cda2",
885
+ # "createTimeNs":"1650442617606017583",
886
+ # "cumBaseQtyEv":30100,
887
+ # "cumFeeEv":31,
888
+ # "cumQuoteQtyEv":1245767663,
889
+ # "cxlRejReason":0,
890
+ # "feeCurrency":"BTC",
891
+ # "leavesBaseQtyEv":0,
892
+ # "leavesQuoteQtyEv":0,
893
+ # "ordStatus":"Filled",
894
+ # "ordType":"Market",
895
+ # "orderID":"34a4b1a8-ac3a-4580-b3e6-a6d039f27195",
896
+ # "pegOffsetValueEp":0,
897
+ # "priceEp":4549022000000,
898
+ # "qtyType":"ByQuote",
899
+ # "quoteCurrency":"USDT",
900
+ # "quoteQtyEv":1248000000,
901
+ # "side":"Buy",
902
+ # "stopPxEp":0,
903
+ # "symbol":"sBTCUSDT",
904
+ # "timeInForce":"ImmediateOrCancel",
905
+ # "tradeType":"Trade",
906
+ # "transactTimeNs":"1650442617609928764",
907
+ # "triggerTimeNs":0,
908
+ # "userID":2647224
909
+ # }
910
+ # ],
911
+ # "fills":[
912
+ # {
913
+ # "avgPriceEp":4138763000000,
914
+ # "baseCurrency":"BTC",
915
+ # "baseQtyEv":0,
916
+ # "clOrdID":"7956e0be-e8be-93a0-2887-ca504d85cda2",
917
+ # "execBaseQtyEv":30100,
918
+ # "execFeeEv":31,
919
+ # "execID":"d3b10cfa-84e3-5752-828e-78a79617e598",
920
+ # "execPriceEp":4138763000000,
921
+ # "execQuoteQtyEv":1245767663,
922
+ # "feeCurrency":"BTC",
923
+ # "lastLiquidityInd":"RemovedLiquidity",
924
+ # "ordType":"Market",
925
+ # "orderID":"34a4b1a8-ac3a-4580-b3e6-a6d039f27195",
926
+ # "priceEp":4549022000000,
927
+ # "qtyType":"ByQuote",
928
+ # "quoteCurrency":"USDT",
929
+ # "quoteQtyEv":1248000000,
930
+ # "side":"Buy",
931
+ # "symbol":"sBTCUSDT",
932
+ # "tradeType":"Trade",
933
+ # "transactTimeNs":"1650442617609928764",
934
+ # "userID":2647224
935
+ # }
936
+ # ],
937
+ # "open":[
938
+ # {
939
+ # "action":"New",
940
+ # "avgPriceEp":0,
941
+ # "baseCurrency":"LTC",
942
+ # "baseQtyEv":0,
943
+ # "bizError":0,
944
+ # "clOrdID":"2c0e5eb5-efb7-60d3-2e5f-df175df412ef",
945
+ # "createTimeNs":"1650446670073853755",
946
+ # "cumBaseQtyEv":0,
947
+ # "cumFeeEv":0,
948
+ # "cumQuoteQtyEv":0,
949
+ # "cxlRejReason":0,
950
+ # "feeCurrency":"LTC",
951
+ # "leavesBaseQtyEv":0,
952
+ # "leavesQuoteQtyEv":1000000000,
953
+ # "ordStatus":"New",
954
+ # "ordType":"Limit",
955
+ # "orderID":"d2aad92f-50f5-441a-957b-8184b146e3fb",
956
+ # "pegOffsetValueEp":0,
957
+ # "priceEp":5000000000,
958
+ # "qtyType":"ByQuote",
959
+ # "quoteCurrency":"USDT",
960
+ # "quoteQtyEv":1000000000,
961
+ # "side":"Buy",
962
+ # }
963
+ # ]
964
+ # },
965
+ # perpetual
966
+ # [
967
+ # {
968
+ # "accountID": 40183400003,
969
+ # "action": "New",
970
+ # "actionBy": "ByUser",
971
+ # "actionTimeNs": "1674110665380190869",
972
+ # "addedSeq": 678760103,
973
+ # "apRp": "0",
974
+ # "bonusChangedAmountRv": "0",
975
+ # "bpRp": "0",
976
+ # "clOrdID": '',
977
+ # "cl_req_code": 0,
978
+ # "closedPnlRv": "0",
979
+ # "closedSize": "0",
980
+ # "code": 0,
981
+ # "cumFeeRv": "0",
982
+ # "cumQty": "0.001",
983
+ # "cumValueRv": "20.849",
984
+ # "curAccBalanceRv": "19.9874906",
985
+ # "curAssignedPosBalanceRv": "0",
986
+ # "curBonusBalanceRv": "0",
987
+ # "curLeverageRr": "-10",
988
+ # "curPosSide": "Buy",
989
+ # "curPosSize": "0.001",
990
+ # "curPosTerm": 1,
991
+ # "curPosValueRv": "20.849",
992
+ # "curRiskLimitRv": "1000000",
993
+ # "currency": "USDT",
994
+ # "cxlRejReason": 0,
995
+ # "displayQty": "0.001",
996
+ # "execFeeRv": "0.0125094",
997
+ # "execID": "b88d2950-04a2-52d8-8927-346059900242",
998
+ # "execPriceRp": "20849",
999
+ # "execQty": "0.001",
1000
+ # "execSeq": 678760103,
1001
+ # "execStatus": "TakerFill",
1002
+ # "execValueRv": "20.849",
1003
+ # "feeRateRr": "0.0006",
1004
+ # "lastLiquidityInd": "RemovedLiquidity",
1005
+ # "leavesQty": "0",
1006
+ # "leavesValueRv": "0",
1007
+ # "message": "No error",
1008
+ # "ordStatus": "Filled",
1009
+ # "ordType": "Market",
1010
+ # "orderID": "79620ed2-54c6-4645-a35c-7057e687c576",
1011
+ # "orderQty": "0.001",
1012
+ # "pegOffsetProportionRr": "0",
1013
+ # "pegOffsetValueRp": "0",
1014
+ # "posSide": "Long",
1015
+ # "priceRp": "21476.3",
1016
+ # "relatedPosTerm": 1,
1017
+ # "relatedReqNum": 4,
1018
+ # "side": "Buy",
1019
+ # "slTrigger": "ByMarkPrice",
1020
+ # "stopLossRp": "0",
1021
+ # "stopPxRp": "0",
1022
+ # "symbol": "BTCUSDT",
1023
+ # "takeProfitRp": "0",
1024
+ # "timeInForce": "ImmediateOrCancel",
1025
+ # "tpTrigger": "ByLastPrice",
1026
+ # "tradeType": "Trade",
1027
+ # "transactTimeNs": "1674110665387882268",
1028
+ # "userID": 4018340
1029
+ # },
1030
+ # ...
1031
+ # ]
1032
+ #
1033
+ trades = []
1034
+ parsedOrders = []
1035
+ if ('closed' in message) or ('fills' in message) or ('open' in message):
1036
+ closed = self.safe_value(message, 'closed', [])
1037
+ open = self.safe_value(message, 'open', [])
1038
+ orders = self.array_concat(open, closed)
1039
+ ordersLength = len(orders)
1040
+ if ordersLength == 0:
1041
+ return
1042
+ trades = self.safe_value(message, 'fills', [])
1043
+ for i in range(0, len(orders)):
1044
+ rawOrder = orders[i]
1045
+ parsedOrder = self.parse_order(rawOrder)
1046
+ parsedOrders.append(parsedOrder)
1047
+ else:
1048
+ for i in range(0, len(message)):
1049
+ update = message[i]
1050
+ action = self.safe_string(update, 'action')
1051
+ if (action is not None) and (action != 'Cancel'):
1052
+ # order + trade info together
1053
+ trades.append(update)
1054
+ parsedOrder = self.parse_ws_swap_order(update)
1055
+ parsedOrders.append(parsedOrder)
1056
+ self.handle_my_trades(client, trades)
1057
+ limit = self.safe_integer(self.options, 'ordersLimit', 1000)
1058
+ marketIds: dict = {}
1059
+ if self.orders is None:
1060
+ self.orders = ArrayCacheBySymbolById(limit)
1061
+ type = None
1062
+ stored = self.orders
1063
+ for i in range(0, len(parsedOrders)):
1064
+ parsed = parsedOrders[i]
1065
+ stored.append(parsed)
1066
+ symbol = parsed['symbol']
1067
+ market = self.market(symbol)
1068
+ if type is None:
1069
+ isUsdt = market['settle'] == 'USDT'
1070
+ type = 'perpetual' if isUsdt else market['type']
1071
+ marketIds[symbol] = True
1072
+ keys = list(marketIds.keys())
1073
+ for i in range(0, len(keys)):
1074
+ currentMessageHash = 'orders' + ':' + keys[i]
1075
+ client.resolve(self.orders, currentMessageHash)
1076
+ # resolve generic subscription(spot or swap)
1077
+ messageHash = 'orders:' + type
1078
+ client.resolve(self.orders, messageHash)
1079
+
1080
+ def parse_ws_swap_order(self, order, market=None):
1081
+ #
1082
+ # swap
1083
+ # {
1084
+ # "accountID":26472240002,
1085
+ # "action":"Cancel",
1086
+ # "actionBy":"ByUser",
1087
+ # "actionTimeNs":"1650450096104760797",
1088
+ # "addedSeq":26975849309,
1089
+ # "bonusChangedAmountEv":0,
1090
+ # "clOrdID":"d9675963-5e4e-6fc8-898a-ec8b934c1c61",
1091
+ # "closedPnlEv":0,
1092
+ # "closedSize":0,
1093
+ # "code":0,
1094
+ # "cumQty":0,
1095
+ # "cumValueEv":0,
1096
+ # "curAccBalanceEv":400079,
1097
+ # "curAssignedPosBalanceEv":0,
1098
+ # "curBonusBalanceEv":0,
1099
+ # "curLeverageEr":0,
1100
+ # "curPosSide":"None",
1101
+ # "curPosSize":0,
1102
+ # "curPosTerm":1,
1103
+ # "curPosValueEv":0,
1104
+ # "curRiskLimitEv":5000000000,
1105
+ # "currency":"USD",
1106
+ # "cxlRejReason":0,
1107
+ # "displayQty":0,
1108
+ # "execFeeEv":0,
1109
+ # "execID":"00000000-0000-0000-0000-000000000000",
1110
+ # "execPriceEp":0,
1111
+ # "execQty":1,
1112
+ # "execSeq":26975862338,
1113
+ # "execStatus":"Canceled",
1114
+ # "execValueEv":0,
1115
+ # "feeRateEr":0,
1116
+ # "leavesQty":0,
1117
+ # "leavesValueEv":0,
1118
+ # "message":"No error",
1119
+ # "ordStatus":"Canceled",
1120
+ # "ordType":"Limit",
1121
+ # "orderID":"8141deb9-8f94-48f6-9421-a4e3a791537b",
1122
+ # "orderQty":1,
1123
+ # "pegOffsetValueEp":0,
1124
+ # "priceEp":9521,
1125
+ # "relatedPosTerm":1,
1126
+ # "relatedReqNum":4,
1127
+ # "side":"Buy",
1128
+ # "slTrigger":"ByMarkPrice",
1129
+ # "stopLossEp":0,
1130
+ # "stopPxEp":0,
1131
+ # "symbol":"ADAUSD",
1132
+ # "takeProfitEp":0,
1133
+ # "timeInForce":"GoodTillCancel",
1134
+ # "tpTrigger":"ByLastPrice",
1135
+ # "transactTimeNs":"1650450096108143014",
1136
+ # "userID":2647224
1137
+ # }
1138
+ # perpetual
1139
+ # {
1140
+ # "accountID": 40183400003,
1141
+ # "action": "New",
1142
+ # "actionBy": "ByUser",
1143
+ # "actionTimeNs": "1674110665380190869",
1144
+ # "addedSeq": 678760103,
1145
+ # "apRp": "0",
1146
+ # "bonusChangedAmountRv": "0",
1147
+ # "bpRp": "0",
1148
+ # "clOrdID": '',
1149
+ # "cl_req_code": 0,
1150
+ # "closedPnlRv": "0",
1151
+ # "closedSize": "0",
1152
+ # "code": 0,
1153
+ # "cumFeeRv": "0",
1154
+ # "cumQty": "0.001",
1155
+ # "cumValueRv": "20.849",
1156
+ # "curAccBalanceRv": "19.9874906",
1157
+ # "curAssignedPosBalanceRv": "0",
1158
+ # "curBonusBalanceRv": "0",
1159
+ # "curLeverageRr": "-10",
1160
+ # "curPosSide": "Buy",
1161
+ # "curPosSize": "0.001",
1162
+ # "curPosTerm": 1,
1163
+ # "curPosValueRv": "20.849",
1164
+ # "curRiskLimitRv": "1000000",
1165
+ # "currency": "USDT",
1166
+ # "cxlRejReason": 0,
1167
+ # "displayQty": "0.001",
1168
+ # "execFeeRv": "0.0125094",
1169
+ # "execID": "b88d2950-04a2-52d8-8927-346059900242",
1170
+ # "execPriceRp": "20849",
1171
+ # "execQty": "0.001",
1172
+ # "execSeq": 678760103,
1173
+ # "execStatus": "TakerFill",
1174
+ # "execValueRv": "20.849",
1175
+ # "feeRateRr": "0.0006",
1176
+ # "lastLiquidityInd": "RemovedLiquidity",
1177
+ # "leavesQty": "0",
1178
+ # "leavesValueRv": "0",
1179
+ # "message": "No error",
1180
+ # "ordStatus": "Filled",
1181
+ # "ordType": "Market",
1182
+ # "orderID": "79620ed2-54c6-4645-a35c-7057e687c576",
1183
+ # "orderQty": "0.001",
1184
+ # "pegOffsetProportionRr": "0",
1185
+ # "pegOffsetValueRp": "0",
1186
+ # "posSide": "Long",
1187
+ # "priceRp": "21476.3",
1188
+ # "relatedPosTerm": 1,
1189
+ # "relatedReqNum": 4,
1190
+ # "side": "Buy",
1191
+ # "slTrigger": "ByMarkPrice",
1192
+ # "stopLossRp": "0",
1193
+ # "stopPxRp": "0",
1194
+ # "symbol": "BTCUSDT",
1195
+ # "takeProfitRp": "0",
1196
+ # "timeInForce": "ImmediateOrCancel",
1197
+ # "tpTrigger": "ByLastPrice",
1198
+ # "tradeType": "Trade",
1199
+ # "transactTimeNs": "1674110665387882268",
1200
+ # "userID": 4018340
1201
+ # }
1202
+ #
1203
+ id = self.safe_string(order, 'orderID')
1204
+ clientOrderId = self.safe_string(order, 'clOrdID')
1205
+ if (clientOrderId is not None) and (len(clientOrderId) < 1):
1206
+ clientOrderId = None
1207
+ marketId = self.safe_string(order, 'symbol')
1208
+ market = self.safe_market(marketId, market)
1209
+ symbol = market['symbol']
1210
+ status = self.parse_order_status(self.safe_string(order, 'ordStatus'))
1211
+ side = self.safe_string_lower(order, 'side')
1212
+ type = self.parseOrderType(self.safe_string(order, 'ordType'))
1213
+ price = self.safe_string(order, 'priceRp', self.from_ep(self.safe_string(order, 'priceEp'), market))
1214
+ amount = self.safe_string(order, 'orderQty')
1215
+ filled = self.safe_string(order, 'cumQty')
1216
+ remaining = self.safe_string(order, 'leavesQty')
1217
+ timestamp = self.safe_integer_product(order, 'actionTimeNs', 0.000001)
1218
+ cost = self.safe_string(order, 'cumValueRv', self.from_ev(self.safe_string(order, 'cumValueEv'), market))
1219
+ lastTradeTimestamp = self.safe_integer_product(order, 'transactTimeNs', 0.000001)
1220
+ if lastTradeTimestamp == 0:
1221
+ lastTradeTimestamp = None
1222
+ timeInForce = self.parse_time_in_force(self.safe_string(order, 'timeInForce'))
1223
+ stopPrice = self.safe_string(order, 'stopPx')
1224
+ postOnly = (timeInForce == 'PO')
1225
+ return self.safe_order({
1226
+ 'info': order,
1227
+ 'id': id,
1228
+ 'clientOrderId': clientOrderId,
1229
+ 'datetime': self.iso8601(timestamp),
1230
+ 'timestamp': timestamp,
1231
+ 'lastTradeTimestamp': lastTradeTimestamp,
1232
+ 'symbol': symbol,
1233
+ 'type': type,
1234
+ 'timeInForce': timeInForce,
1235
+ 'postOnly': postOnly,
1236
+ 'side': side,
1237
+ 'price': price,
1238
+ 'stopPrice': stopPrice,
1239
+ 'triggerPrice': stopPrice,
1240
+ 'amount': amount,
1241
+ 'filled': filled,
1242
+ 'remaining': remaining,
1243
+ 'cost': cost,
1244
+ 'average': None,
1245
+ 'status': status,
1246
+ 'fee': None,
1247
+ 'trades': None,
1248
+ }, market)
1249
+
1250
+ def handle_message(self, client: Client, message):
1251
+ # private spot update
1252
+ # {
1253
+ # "orders": {closed: [], fills: [], open: []},
1254
+ # "sequence": 40435835,
1255
+ # "timestamp": "1650443245600839241",
1256
+ # "type": "snapshot",
1257
+ # "wallets": [
1258
+ # {
1259
+ # "balanceEv": 0,
1260
+ # "currency": "BTC",
1261
+ # "lastUpdateTimeNs": "1650442638722099092",
1262
+ # "lockedTradingBalanceEv": 0,
1263
+ # "lockedWithdrawEv": 0,
1264
+ # "userID": 2647224
1265
+ # },
1266
+ # {
1267
+ # "balanceEv": 1154232337,
1268
+ # "currency": "USDT",
1269
+ # "lastUpdateTimeNs": "1650442617610017597",
1270
+ # "lockedTradingBalanceEv": 0,
1271
+ # "lockedWithdrawEv": 0,
1272
+ # "userID": 2647224
1273
+ # }
1274
+ # ]
1275
+ # }
1276
+ # private swap update
1277
+ # {
1278
+ # "sequence": 83839628,
1279
+ # "timestamp": "1650382581827447829",
1280
+ # "type": "snapshot",
1281
+ # "accounts": [
1282
+ # {
1283
+ # "accountBalanceEv": 0,
1284
+ # "accountID": 26472240001,
1285
+ # "bonusBalanceEv": 0,
1286
+ # "currency": "BTC",
1287
+ # "totalUsedBalanceEv": 0,
1288
+ # "userID": 2647224
1289
+ # }
1290
+ # ],
1291
+ # "orders": [],
1292
+ # "positions": [
1293
+ # {
1294
+ # "accountID": 26472240001,
1295
+ # "assignedPosBalanceEv": 0,
1296
+ # "avgEntryPriceEp": 0,
1297
+ # "bankruptCommEv": 0,
1298
+ # "bankruptPriceEp": 0,
1299
+ # "buyLeavesQty": 0,
1300
+ # "buyLeavesValueEv": 0,
1301
+ # "buyValueToCostEr": 1150750,
1302
+ # "createdAtNs": 0,
1303
+ # "crossSharedBalanceEv": 0,
1304
+ # "cumClosedPnlEv": 0,
1305
+ # "cumFundingFeeEv": 0,
1306
+ # "cumTransactFeeEv": 0,
1307
+ # "curTermRealisedPnlEv": 0,
1308
+ # "currency": "BTC",
1309
+ # "dataVer": 2,
1310
+ # "deleveragePercentileEr": 0,
1311
+ # "displayLeverageEr": 10000000000,
1312
+ # "estimatedOrdLossEv": 0,
1313
+ # "execSeq": 0,
1314
+ # "freeCostEv": 0,
1315
+ # "freeQty": 0,
1316
+ # "initMarginReqEr": 1000000,
1317
+ # "lastFundingTime": "1640601827712091793",
1318
+ # "lastTermEndTime": 0,
1319
+ # "leverageEr": 0,
1320
+ # "liquidationPriceEp": 0,
1321
+ # "maintMarginReqEr": 500000,
1322
+ # "makerFeeRateEr": 0,
1323
+ # "markPriceEp": 507806777,
1324
+ # "orderCostEv": 0,
1325
+ # "posCostEv": 0,
1326
+ # "positionMarginEv": 0,
1327
+ # "positionStatus": "Normal",
1328
+ # "riskLimitEv": 10000000000,
1329
+ # "sellLeavesQty": 0,
1330
+ # "sellLeavesValueEv": 0,
1331
+ # "sellValueToCostEr": 1149250,
1332
+ # "side": "None",
1333
+ # "size": 0,
1334
+ # "symbol": "BTCUSD",
1335
+ # "takerFeeRateEr": 0,
1336
+ # "term": 1,
1337
+ # "transactTimeNs": 0,
1338
+ # "unrealisedPnlEv": 0,
1339
+ # "updatedAtNs": 0,
1340
+ # "usedBalanceEv": 0,
1341
+ # "userID": 2647224,
1342
+ # "valueEv": 0
1343
+ # }
1344
+ # ]
1345
+ # }
1346
+ id = self.safe_string(message, 'id')
1347
+ if id in client.subscriptions:
1348
+ method = client.subscriptions[id]
1349
+ del client.subscriptions[id]
1350
+ if method is not True:
1351
+ method(client, message)
1352
+ return
1353
+ methodName = self.safe_string(message, 'method', '')
1354
+ if ('market24h' in message) or ('spot_market24h' in message) or (methodName.find('perp_market24h_pack_p') >= 0):
1355
+ self.handle_ticker(client, message)
1356
+ return
1357
+ elif ('trades' in message) or ('trades_p' in message):
1358
+ self.handle_trades(client, message)
1359
+ return
1360
+ elif ('kline' in message) or ('kline_p' in message):
1361
+ self.handle_ohlcv(client, message)
1362
+ return
1363
+ elif ('book' in message) or ('orderbook_p' in message):
1364
+ self.handle_order_book(client, message)
1365
+ return
1366
+ if ('orders' in message) or ('orders_p' in message):
1367
+ orders = self.safe_value_2(message, 'orders', 'orders_p', {})
1368
+ self.handle_orders(client, orders)
1369
+ if ('accounts' in message) or ('accounts_p' in message) or ('wallets' in message):
1370
+ type = 'swap' if ('accounts' in message) else 'spot'
1371
+ if 'accounts_p' in message:
1372
+ type = 'perpetual'
1373
+ accounts = self.safe_value_n(message, ['accounts', 'accounts_p', 'wallets'], [])
1374
+ self.handle_balance(type, client, accounts)
1375
+
1376
+ def handle_authenticate(self, client: Client, message):
1377
+ #
1378
+ # {
1379
+ # "error": null,
1380
+ # "id": 1234,
1381
+ # "result": {
1382
+ # "status": "success"
1383
+ # }
1384
+ # }
1385
+ #
1386
+ result = self.safe_value(message, 'result')
1387
+ status = self.safe_string(result, 'status')
1388
+ messageHash = 'authenticated'
1389
+ if status == 'success':
1390
+ client.resolve(message, messageHash)
1391
+ else:
1392
+ error = AuthenticationError(self.id + ' ' + self.json(message))
1393
+ client.reject(error, messageHash)
1394
+ if messageHash in client.subscriptions:
1395
+ del client.subscriptions[messageHash]
1396
+
1397
+ async def subscribe_private(self, type, messageHash, params={}):
1398
+ await self.load_markets()
1399
+ await self.authenticate()
1400
+ url = self.urls['api']['ws']
1401
+ requestId = self.seconds()
1402
+ settleIsUSDT = (self.safe_value(params, 'settle', '') == 'USDT')
1403
+ params = self.omit(params, 'settle')
1404
+ channel = 'aop.subscribe'
1405
+ if type == 'spot':
1406
+ channel = 'wo.subscribe'
1407
+ if settleIsUSDT:
1408
+ channel = 'aop_p.subscribe'
1409
+ request = {
1410
+ 'id': requestId,
1411
+ 'method': channel,
1412
+ 'params': [],
1413
+ }
1414
+ request = self.extend(request, params)
1415
+ return await self.watch(url, messageHash, request, channel)
1416
+
1417
+ async def authenticate(self, params={}):
1418
+ self.check_required_credentials()
1419
+ url = self.urls['api']['ws']
1420
+ client = self.client(url)
1421
+ requestId = self.request_id()
1422
+ messageHash = 'authenticated'
1423
+ future = self.safe_value(client.subscriptions, messageHash)
1424
+ if future is None:
1425
+ expiryDelta = self.safe_integer(self.options, 'expires', 120)
1426
+ expiration = self.seconds() + expiryDelta
1427
+ payload = self.apiKey + str(expiration)
1428
+ signature = self.hmac(self.encode(payload), self.encode(self.secret), hashlib.sha256)
1429
+ method = 'user.auth'
1430
+ request: dict = {
1431
+ 'method': method,
1432
+ 'params': ['API', self.apiKey, signature, expiration],
1433
+ 'id': requestId,
1434
+ }
1435
+ subscriptionHash = str(requestId)
1436
+ message = self.extend(request, params)
1437
+ if not (messageHash in client.subscriptions):
1438
+ client.subscriptions[subscriptionHash] = self.handle_authenticate
1439
+ future = await self.watch(url, messageHash, message, messageHash)
1440
+ client.subscriptions[messageHash] = future
1441
+ return future