ccxt-ir 4.3.46.0.3__py2.py3-none-any.whl → 4.5.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 (529) hide show
  1. ccxt/__init__.py +39 -35
  2. ccxt/abantether.py +8 -8
  3. ccxt/abstract/alpaca.py +4 -0
  4. ccxt/abstract/apex.py +31 -0
  5. ccxt/abstract/bigone.py +1 -1
  6. ccxt/abstract/binance.py +106 -48
  7. ccxt/abstract/binancecoinm.py +106 -48
  8. ccxt/abstract/binanceus.py +141 -83
  9. ccxt/abstract/binanceusdm.py +106 -48
  10. ccxt/abstract/bingx.py +50 -1
  11. ccxt/abstract/bitbank.py +5 -0
  12. ccxt/abstract/bitfinex.py +136 -65
  13. ccxt/abstract/bitflyer.py +1 -0
  14. ccxt/abstract/bitget.py +67 -0
  15. ccxt/abstract/bitmart.py +19 -1
  16. ccxt/abstract/bitopro.py +1 -0
  17. ccxt/abstract/bitrue.py +68 -68
  18. ccxt/abstract/bitstamp.py +1 -0
  19. ccxt/abstract/blofin.py +30 -0
  20. ccxt/abstract/btcbox.py +2 -0
  21. ccxt/abstract/bybit.py +28 -13
  22. ccxt/abstract/cex.py +28 -29
  23. ccxt/abstract/coinbaseexchange.py +1 -0
  24. ccxt/abstract/coinbaseinternational.py +1 -1
  25. ccxt/abstract/cryptocom.py +16 -0
  26. ccxt/abstract/cryptomus.py +20 -0
  27. ccxt/abstract/defx.py +69 -0
  28. ccxt/abstract/deribit.py +1 -0
  29. ccxt/abstract/derive.py +117 -0
  30. ccxt/abstract/digifinex.py +1 -0
  31. ccxt/abstract/ellipx.py +25 -0
  32. ccxt/abstract/foxbit.py +26 -0
  33. ccxt/abstract/gate.py +19 -0
  34. ccxt/abstract/gateio.py +19 -0
  35. ccxt/abstract/gemini.py +1 -0
  36. ccxt/abstract/hibachi.py +26 -0
  37. ccxt/abstract/hyperliquid.py +1 -1
  38. ccxt/abstract/independentreserve.py +6 -0
  39. ccxt/abstract/kraken.py +1 -0
  40. ccxt/abstract/krakenfutures.py +4 -0
  41. ccxt/abstract/kucoin.py +10 -0
  42. ccxt/abstract/kucoinfutures.py +18 -0
  43. ccxt/abstract/lbank.py +2 -1
  44. ccxt/abstract/luno.py +1 -0
  45. ccxt/abstract/mexc.py +2 -0
  46. ccxt/abstract/modetrade.py +119 -0
  47. ccxt/abstract/myokx.py +349 -0
  48. ccxt/abstract/oceanex.py +5 -0
  49. ccxt/abstract/okx.py +25 -0
  50. ccxt/abstract/okxus.py +349 -0
  51. ccxt/abstract/onetrading.py +0 -12
  52. ccxt/abstract/paradex.py +23 -0
  53. ccxt/abstract/phemex.py +2 -0
  54. ccxt/abstract/poloniex.py +36 -0
  55. ccxt/abstract/tradeogre.py +3 -1
  56. ccxt/abstract/upbit.py +51 -34
  57. ccxt/abstract/whitebit.py +16 -0
  58. ccxt/abstract/woo.py +64 -6
  59. ccxt/abstract/xt.py +10 -5
  60. ccxt/afratether.py +8 -8
  61. ccxt/alpaca.py +828 -51
  62. ccxt/apex.py +1875 -0
  63. ccxt/arzinja.py +7 -7
  64. ccxt/arzplus.py +9 -9
  65. ccxt/ascendex.py +501 -306
  66. ccxt/async_support/__init__.py +39 -35
  67. ccxt/async_support/abantether.py +8 -8
  68. ccxt/async_support/afratether.py +10 -10
  69. ccxt/async_support/alpaca.py +828 -51
  70. ccxt/async_support/apex.py +1875 -0
  71. ccxt/async_support/arzinja.py +10 -10
  72. ccxt/async_support/arzplus.py +12 -12
  73. ccxt/async_support/ascendex.py +502 -306
  74. ccxt/async_support/base/exchange.py +303 -89
  75. ccxt/async_support/base/ws/cache.py +9 -3
  76. ccxt/async_support/base/ws/client.py +173 -38
  77. ccxt/async_support/base/ws/future.py +25 -37
  78. ccxt/async_support/bequant.py +5 -3
  79. ccxt/async_support/bigone.py +279 -144
  80. ccxt/async_support/binance.py +2347 -1158
  81. ccxt/async_support/binancecoinm.py +9 -3
  82. ccxt/async_support/binanceus.py +17 -3
  83. ccxt/async_support/binanceusdm.py +9 -4
  84. ccxt/async_support/bingx.py +2962 -920
  85. ccxt/async_support/bit2c.py +147 -27
  86. ccxt/async_support/bitbank.py +151 -23
  87. ccxt/async_support/bitbns.py +104 -30
  88. ccxt/async_support/bitfinex.py +3291 -1113
  89. ccxt/async_support/bitflyer.py +202 -27
  90. ccxt/async_support/bitget.py +3683 -1538
  91. ccxt/async_support/bithumb.py +195 -38
  92. ccxt/async_support/bitimen.py +12 -12
  93. ccxt/async_support/bitir.py +38 -38
  94. ccxt/async_support/bitmart.py +1288 -350
  95. ccxt/async_support/bitmex.py +260 -75
  96. ccxt/async_support/bitopro.py +262 -62
  97. ccxt/async_support/bitpin.py +17 -16
  98. ccxt/async_support/bitrue.py +459 -290
  99. ccxt/async_support/bitso.py +199 -54
  100. ccxt/async_support/bitstamp.py +230 -96
  101. ccxt/async_support/bitteam.py +167 -25
  102. ccxt/async_support/{huobijp.py → bittrade.py} +158 -30
  103. ccxt/async_support/bitvavo.py +213 -49
  104. ccxt/async_support/blockchaincom.py +160 -46
  105. ccxt/async_support/blofin.py +502 -120
  106. ccxt/async_support/btcalpha.py +169 -31
  107. ccxt/async_support/btcbox.py +292 -23
  108. ccxt/async_support/btcmarkets.py +211 -58
  109. ccxt/async_support/btcturk.py +161 -38
  110. ccxt/async_support/bybit.py +1775 -1030
  111. ccxt/async_support/cex.py +1440 -1303
  112. ccxt/async_support/coinbase.py +724 -212
  113. ccxt/async_support/coinbaseadvanced.py +2 -1
  114. ccxt/async_support/coinbaseexchange.py +388 -89
  115. ccxt/async_support/coinbaseinternational.py +412 -57
  116. ccxt/async_support/coincatch.py +177 -78
  117. ccxt/async_support/coincheck.py +135 -19
  118. ccxt/async_support/coinex.py +606 -232
  119. ccxt/async_support/coinmate.py +189 -63
  120. ccxt/async_support/coinmetro.py +195 -54
  121. ccxt/async_support/coinone.py +158 -51
  122. ccxt/async_support/coinsph.py +336 -61
  123. ccxt/async_support/coinspot.py +151 -52
  124. ccxt/async_support/cryptocom.py +661 -111
  125. ccxt/async_support/cryptomus.py +1137 -0
  126. ccxt/async_support/defx.py +2071 -0
  127. ccxt/async_support/delta.py +299 -99
  128. ccxt/async_support/deribit.py +348 -126
  129. ccxt/async_support/derive.py +2572 -0
  130. ccxt/async_support/digifinex.py +430 -214
  131. ccxt/async_support/ellipx.py +2029 -0
  132. ccxt/async_support/eterex.py +10 -10
  133. ccxt/async_support/excoino.py +31 -31
  134. ccxt/async_support/exir.py +14 -14
  135. ccxt/async_support/exmo.py +344 -131
  136. ccxt/async_support/exnovin.py +10 -10
  137. ccxt/async_support/farhadexchange.py +12 -12
  138. ccxt/async_support/fmfwio.py +2 -1
  139. ccxt/async_support/foxbit.py +1935 -0
  140. ccxt/async_support/gate.py +1351 -529
  141. ccxt/async_support/gateio.py +2 -1
  142. ccxt/async_support/gemini.py +144 -39
  143. ccxt/async_support/hashkey.py +152 -109
  144. ccxt/async_support/hibachi.py +2080 -0
  145. ccxt/async_support/hitbtc.py +395 -167
  146. ccxt/async_support/hitobit.py +12 -12
  147. ccxt/async_support/hollaex.py +307 -119
  148. ccxt/async_support/htx.py +851 -383
  149. ccxt/async_support/huobi.py +2 -1
  150. ccxt/async_support/hyperliquid.py +1848 -536
  151. ccxt/async_support/independentreserve.py +288 -15
  152. ccxt/async_support/indodax.py +190 -33
  153. ccxt/async_support/jibitex.py +12 -12
  154. ccxt/async_support/kraken.py +795 -351
  155. ccxt/async_support/krakenfutures.py +214 -62
  156. ccxt/async_support/kucoin.py +715 -396
  157. ccxt/async_support/kucoinfutures.py +652 -89
  158. ccxt/async_support/latoken.py +217 -113
  159. ccxt/async_support/lbank.py +425 -97
  160. ccxt/async_support/luno.py +382 -35
  161. ccxt/async_support/mercado.py +113 -6
  162. ccxt/async_support/mexc.py +874 -437
  163. ccxt/async_support/modetrade.py +2818 -0
  164. ccxt/async_support/myokx.py +54 -0
  165. ccxt/async_support/ndax.py +221 -64
  166. ccxt/async_support/nobitex.py +32 -38
  167. ccxt/async_support/novadax.py +190 -34
  168. ccxt/async_support/oceanex.py +217 -28
  169. ccxt/async_support/okcoin.py +253 -145
  170. ccxt/async_support/okexchange.py +11 -11
  171. ccxt/async_support/okx.py +1088 -351
  172. ccxt/async_support/okxus.py +54 -0
  173. ccxt/async_support/ompfinex.py +32 -27
  174. ccxt/async_support/onetrading.py +213 -392
  175. ccxt/async_support/oxfun.py +245 -166
  176. ccxt/async_support/p2b.py +151 -29
  177. ccxt/async_support/paradex.py +562 -49
  178. ccxt/async_support/paymium.py +82 -19
  179. ccxt/async_support/phemex.py +713 -172
  180. ccxt/async_support/poloniex.py +1602 -283
  181. ccxt/async_support/probit.py +224 -95
  182. ccxt/async_support/ramzinex.py +34 -30
  183. ccxt/async_support/sarmayex.py +9 -9
  184. ccxt/async_support/sarrafex.py +13 -13
  185. ccxt/async_support/tabdeal.py +15 -14
  186. ccxt/async_support/tetherland.py +9 -9
  187. ccxt/async_support/timex.py +210 -51
  188. ccxt/async_support/tokocrypto.py +167 -47
  189. ccxt/async_support/tradeogre.py +266 -31
  190. ccxt/async_support/twox.py +9 -9
  191. ccxt/async_support/ubitex.py +12 -12
  192. ccxt/async_support/upbit.py +568 -165
  193. ccxt/async_support/vertex.py +160 -32
  194. ccxt/async_support/wallex.py +12 -12
  195. ccxt/async_support/wavesexchange.py +165 -30
  196. ccxt/async_support/whitebit.py +975 -127
  197. ccxt/async_support/woo.py +1918 -1016
  198. ccxt/async_support/woofipro.py +433 -141
  199. ccxt/async_support/xt.py +649 -193
  200. ccxt/async_support/yobit.py +195 -70
  201. ccxt/async_support/zaif.py +91 -15
  202. ccxt/async_support/zonda.py +151 -36
  203. ccxt/base/decimal_to_precision.py +14 -10
  204. ccxt/base/errors.py +49 -18
  205. ccxt/base/exchange.py +1556 -450
  206. ccxt/base/precise.py +10 -0
  207. ccxt/base/types.py +114 -6
  208. ccxt/bequant.py +5 -3
  209. ccxt/bigone.py +279 -144
  210. ccxt/binance.py +2347 -1158
  211. ccxt/binancecoinm.py +9 -3
  212. ccxt/binanceus.py +17 -3
  213. ccxt/binanceusdm.py +9 -4
  214. ccxt/bingx.py +2962 -920
  215. ccxt/bit2c.py +147 -27
  216. ccxt/bitbank.py +151 -23
  217. ccxt/bitbns.py +104 -30
  218. ccxt/bitfinex.py +3290 -1113
  219. ccxt/bitflyer.py +202 -27
  220. ccxt/bitget.py +3683 -1538
  221. ccxt/bithumb.py +194 -38
  222. ccxt/bitimen.py +9 -9
  223. ccxt/bitir.py +35 -35
  224. ccxt/bitmart.py +1288 -350
  225. ccxt/bitmex.py +260 -75
  226. ccxt/bitopro.py +262 -62
  227. ccxt/bitpin.py +15 -14
  228. ccxt/bitrue.py +459 -290
  229. ccxt/bitso.py +199 -54
  230. ccxt/bitstamp.py +230 -96
  231. ccxt/bitteam.py +167 -25
  232. ccxt/{huobijp.py → bittrade.py} +158 -30
  233. ccxt/bitvavo.py +213 -49
  234. ccxt/blockchaincom.py +160 -46
  235. ccxt/blofin.py +502 -120
  236. ccxt/btcalpha.py +169 -31
  237. ccxt/btcbox.py +291 -23
  238. ccxt/btcmarkets.py +211 -58
  239. ccxt/btcturk.py +161 -38
  240. ccxt/bybit.py +1775 -1030
  241. ccxt/cex.py +1439 -1303
  242. ccxt/coinbase.py +724 -212
  243. ccxt/coinbaseadvanced.py +2 -1
  244. ccxt/coinbaseexchange.py +388 -89
  245. ccxt/coinbaseinternational.py +412 -57
  246. ccxt/coincatch.py +177 -78
  247. ccxt/coincheck.py +135 -19
  248. ccxt/coinex.py +606 -232
  249. ccxt/coinmate.py +189 -63
  250. ccxt/coinmetro.py +194 -54
  251. ccxt/coinone.py +158 -51
  252. ccxt/coinsph.py +336 -61
  253. ccxt/coinspot.py +151 -52
  254. ccxt/cryptocom.py +661 -111
  255. ccxt/cryptomus.py +1137 -0
  256. ccxt/defx.py +2070 -0
  257. ccxt/delta.py +299 -99
  258. ccxt/deribit.py +348 -126
  259. ccxt/derive.py +2571 -0
  260. ccxt/digifinex.py +430 -214
  261. ccxt/ellipx.py +2029 -0
  262. ccxt/eterex.py +7 -7
  263. ccxt/excoino.py +29 -29
  264. ccxt/exir.py +11 -11
  265. ccxt/exmo.py +343 -131
  266. ccxt/exnovin.py +8 -8
  267. ccxt/farhadexchange.py +10 -10
  268. ccxt/fmfwio.py +2 -1
  269. ccxt/foxbit.py +1935 -0
  270. ccxt/gate.py +1351 -529
  271. ccxt/gateio.py +2 -1
  272. ccxt/gemini.py +144 -39
  273. ccxt/hashkey.py +152 -109
  274. ccxt/hibachi.py +2079 -0
  275. ccxt/hitbtc.py +395 -167
  276. ccxt/hitobit.py +9 -9
  277. ccxt/hollaex.py +307 -119
  278. ccxt/htx.py +851 -383
  279. ccxt/huobi.py +2 -1
  280. ccxt/hyperliquid.py +1848 -536
  281. ccxt/independentreserve.py +287 -15
  282. ccxt/indodax.py +190 -33
  283. ccxt/jibitex.py +9 -9
  284. ccxt/kraken.py +794 -351
  285. ccxt/krakenfutures.py +214 -62
  286. ccxt/kucoin.py +715 -396
  287. ccxt/kucoinfutures.py +652 -89
  288. ccxt/latoken.py +217 -113
  289. ccxt/lbank.py +425 -97
  290. ccxt/luno.py +382 -35
  291. ccxt/mercado.py +113 -6
  292. ccxt/mexc.py +873 -437
  293. ccxt/modetrade.py +2818 -0
  294. ccxt/myokx.py +54 -0
  295. ccxt/ndax.py +221 -64
  296. ccxt/nobitex.py +30 -36
  297. ccxt/novadax.py +190 -34
  298. ccxt/oceanex.py +217 -28
  299. ccxt/okcoin.py +253 -145
  300. ccxt/okexchange.py +9 -9
  301. ccxt/okx.py +1088 -351
  302. ccxt/okxus.py +54 -0
  303. ccxt/ompfinex.py +29 -24
  304. ccxt/onetrading.py +213 -392
  305. ccxt/oxfun.py +245 -166
  306. ccxt/p2b.py +151 -29
  307. ccxt/paradex.py +562 -49
  308. ccxt/paymium.py +82 -19
  309. ccxt/phemex.py +712 -172
  310. ccxt/poloniex.py +1601 -283
  311. ccxt/pro/__init__.py +76 -17
  312. ccxt/pro/alpaca.py +21 -6
  313. ccxt/pro/apex.py +984 -0
  314. ccxt/pro/ascendex.py +58 -10
  315. ccxt/pro/bequant.py +6 -1
  316. ccxt/pro/binance.py +728 -156
  317. ccxt/pro/binancecoinm.py +6 -2
  318. ccxt/pro/binanceus.py +8 -4
  319. ccxt/pro/binanceusdm.py +7 -2
  320. ccxt/pro/bingx.py +333 -142
  321. ccxt/pro/bitfinex.py +727 -262
  322. ccxt/pro/bitget.py +570 -79
  323. ccxt/pro/bithumb.py +20 -6
  324. ccxt/pro/bitmart.py +216 -87
  325. ccxt/pro/bitmex.py +47 -9
  326. ccxt/pro/bitopro.py +26 -14
  327. ccxt/pro/bitrue.py +22 -22
  328. ccxt/pro/bitstamp.py +54 -21
  329. ccxt/pro/{huobijp.py → bittrade.py} +7 -6
  330. ccxt/pro/bitvavo.py +191 -67
  331. ccxt/pro/blockchaincom.py +21 -8
  332. ccxt/pro/blofin.py +9 -1
  333. ccxt/pro/bybit.py +632 -245
  334. ccxt/pro/cex.py +59 -24
  335. ccxt/pro/coinbase.py +102 -73
  336. ccxt/pro/coinbaseadvanced.py +2 -1
  337. ccxt/pro/coinbaseexchange.py +8 -8
  338. ccxt/pro/coinbaseinternational.py +181 -25
  339. ccxt/pro/coincatch.py +6 -7
  340. ccxt/pro/coincheck.py +11 -6
  341. ccxt/pro/coinex.py +967 -665
  342. ccxt/pro/coinone.py +16 -9
  343. ccxt/pro/cryptocom.py +448 -45
  344. ccxt/pro/defx.py +831 -0
  345. ccxt/pro/deribit.py +150 -14
  346. ccxt/pro/derive.py +704 -0
  347. ccxt/pro/exmo.py +239 -6
  348. ccxt/pro/gate.py +623 -65
  349. ccxt/pro/gateio.py +2 -1
  350. ccxt/pro/gemini.py +27 -11
  351. ccxt/pro/hashkey.py +2 -2
  352. ccxt/pro/hitbtc.py +196 -91
  353. ccxt/pro/hollaex.py +23 -7
  354. ccxt/pro/htx.py +51 -14
  355. ccxt/pro/huobi.py +2 -1
  356. ccxt/pro/hyperliquid.py +591 -27
  357. ccxt/pro/independentreserve.py +9 -6
  358. ccxt/pro/kraken.py +640 -320
  359. ccxt/pro/krakenfutures.py +62 -35
  360. ccxt/pro/kucoin.py +267 -46
  361. ccxt/pro/kucoinfutures.py +165 -21
  362. ccxt/pro/lbank.py +102 -21
  363. ccxt/pro/luno.py +12 -8
  364. ccxt/pro/mexc.py +877 -111
  365. ccxt/pro/modetrade.py +1271 -0
  366. ccxt/pro/myokx.py +38 -0
  367. ccxt/pro/ndax.py +15 -2
  368. ccxt/pro/okcoin.py +23 -4
  369. ccxt/pro/okx.py +573 -98
  370. ccxt/pro/okxus.py +38 -0
  371. ccxt/pro/onetrading.py +30 -13
  372. ccxt/pro/oxfun.py +131 -27
  373. ccxt/pro/p2b.py +88 -22
  374. ccxt/pro/paradex.py +3 -3
  375. ccxt/pro/phemex.py +75 -21
  376. ccxt/pro/poloniex.py +124 -41
  377. ccxt/pro/probit.py +87 -80
  378. ccxt/pro/tradeogre.py +272 -0
  379. ccxt/pro/upbit.py +152 -12
  380. ccxt/pro/vertex.py +8 -3
  381. ccxt/pro/whitebit.py +58 -5
  382. ccxt/pro/woo.py +228 -37
  383. ccxt/pro/woofipro.py +106 -18
  384. ccxt/pro/xt.py +111 -5
  385. ccxt/probit.py +224 -95
  386. ccxt/protobuf/__init__.py +0 -0
  387. ccxt/protobuf/mexc/PrivateAccountV3Api_pb2.py +37 -0
  388. ccxt/protobuf/mexc/PrivateDealsV3Api_pb2.py +37 -0
  389. ccxt/protobuf/mexc/PrivateOrdersV3Api_pb2.py +37 -0
  390. ccxt/protobuf/mexc/PublicAggreBookTickerV3Api_pb2.py +37 -0
  391. ccxt/protobuf/mexc/PublicAggreDealsV3Api_pb2.py +39 -0
  392. ccxt/protobuf/mexc/PublicAggreDepthsV3Api_pb2.py +39 -0
  393. ccxt/protobuf/mexc/PublicBookTickerBatchV3Api_pb2.py +38 -0
  394. ccxt/protobuf/mexc/PublicBookTickerV3Api_pb2.py +37 -0
  395. ccxt/protobuf/mexc/PublicDealsV3Api_pb2.py +39 -0
  396. ccxt/protobuf/mexc/PublicIncreaseDepthsBatchV3Api_pb2.py +38 -0
  397. ccxt/protobuf/mexc/PublicIncreaseDepthsV3Api_pb2.py +39 -0
  398. ccxt/protobuf/mexc/PublicLimitDepthsV3Api_pb2.py +39 -0
  399. ccxt/protobuf/mexc/PublicMiniTickerV3Api_pb2.py +37 -0
  400. ccxt/protobuf/mexc/PublicMiniTickersV3Api_pb2.py +38 -0
  401. ccxt/protobuf/mexc/PublicSpotKlineV3Api_pb2.py +37 -0
  402. ccxt/protobuf/mexc/PushDataV3ApiWrapper_pb2.py +52 -0
  403. ccxt/protobuf/mexc/__init__.py +0 -0
  404. ccxt/ramzinex.py +32 -28
  405. ccxt/sarmayex.py +7 -7
  406. ccxt/sarrafex.py +10 -10
  407. ccxt/static_dependencies/__init__.py +1 -1
  408. ccxt/static_dependencies/lark/py.typed +0 -0
  409. ccxt/static_dependencies/marshmallow/py.typed +0 -0
  410. ccxt/static_dependencies/marshmallow_dataclass/py.typed +0 -0
  411. ccxt/static_dependencies/marshmallow_oneofschema/py.typed +0 -0
  412. ccxt/tabdeal.py +13 -12
  413. ccxt/test/tests_async.py +261 -57
  414. ccxt/test/tests_helpers.py +1 -3
  415. ccxt/test/tests_init.py +4 -3
  416. ccxt/test/tests_sync.py +261 -57
  417. ccxt/tetherland.py +7 -7
  418. ccxt/timex.py +210 -51
  419. ccxt/tokocrypto.py +167 -47
  420. ccxt/tradeogre.py +266 -31
  421. ccxt/twox.py +7 -7
  422. ccxt/ubitex.py +9 -9
  423. ccxt/upbit.py +568 -165
  424. ccxt/vertex.py +160 -32
  425. ccxt/wallex.py +9 -9
  426. ccxt/wavesexchange.py +165 -30
  427. ccxt/whitebit.py +975 -127
  428. ccxt/woo.py +1917 -1016
  429. ccxt/woofipro.py +432 -141
  430. ccxt/xt.py +649 -193
  431. ccxt/yobit.py +194 -70
  432. ccxt/zaif.py +91 -15
  433. ccxt/zonda.py +151 -36
  434. {ccxt_ir-4.3.46.0.3.dist-info → ccxt_ir-4.5.1.dist-info}/METADATA +225 -73
  435. ccxt_ir-4.5.1.dist-info/RECORD +743 -0
  436. {ccxt_ir-4.3.46.0.3.dist-info → ccxt_ir-4.5.1.dist-info}/WHEEL +1 -1
  437. ccxt/__test__.py +0 -7
  438. ccxt/abstract/ace.py +0 -15
  439. ccxt/abstract/bitbay.py +0 -53
  440. ccxt/abstract/bitcoincom.py +0 -115
  441. ccxt/abstract/bitfinex2.py +0 -139
  442. ccxt/abstract/bitpanda.py +0 -35
  443. ccxt/abstract/bl3p.py +0 -19
  444. ccxt/abstract/coinlist.py +0 -54
  445. ccxt/abstract/currencycom.py +0 -68
  446. ccxt/abstract/hitbtc3.py +0 -115
  447. ccxt/abstract/idex.py +0 -26
  448. ccxt/abstract/kuna.py +0 -182
  449. ccxt/abstract/lykke.py +0 -29
  450. ccxt/abstract/poloniexfutures.py +0 -48
  451. ccxt/abstract/wazirx.py +0 -30
  452. ccxt/ace.py +0 -1012
  453. ccxt/async_support/ace.py +0 -1012
  454. ccxt/async_support/base/ws/aiohttp_client.py +0 -125
  455. ccxt/async_support/base/ws/fast_client.py +0 -96
  456. ccxt/async_support/bitbay.py +0 -17
  457. ccxt/async_support/bitcoincom.py +0 -17
  458. ccxt/async_support/bitfinex2.py +0 -3552
  459. ccxt/async_support/bitpanda.py +0 -16
  460. ccxt/async_support/bl3p.py +0 -485
  461. ccxt/async_support/coinlist.py +0 -2243
  462. ccxt/async_support/currencycom.py +0 -1950
  463. ccxt/async_support/hitbtc3.py +0 -16
  464. ccxt/async_support/idex.py +0 -1766
  465. ccxt/async_support/kuna.py +0 -1841
  466. ccxt/async_support/lykke.py +0 -1270
  467. ccxt/async_support/poloniexfutures.py +0 -1717
  468. ccxt/async_support/wazirx.py +0 -1224
  469. ccxt/bitbay.py +0 -17
  470. ccxt/bitcoincom.py +0 -17
  471. ccxt/bitfinex2.py +0 -3552
  472. ccxt/bitpanda.py +0 -16
  473. ccxt/bl3p.py +0 -485
  474. ccxt/coinlist.py +0 -2243
  475. ccxt/currencycom.py +0 -1950
  476. ccxt/hitbtc3.py +0 -16
  477. ccxt/idex.py +0 -1766
  478. ccxt/kuna.py +0 -1841
  479. ccxt/lykke.py +0 -1270
  480. ccxt/poloniexfutures.py +0 -1717
  481. ccxt/pro/bitcoincom.py +0 -34
  482. ccxt/pro/bitfinex2.py +0 -1083
  483. ccxt/pro/bitpanda.py +0 -15
  484. ccxt/pro/currencycom.py +0 -536
  485. ccxt/pro/idex.py +0 -672
  486. ccxt/pro/poloniexfutures.py +0 -990
  487. ccxt/pro/wazirx.py +0 -749
  488. ccxt/test/base/__init__.py +0 -29
  489. ccxt/test/base/test_account.py +0 -26
  490. ccxt/test/base/test_balance.py +0 -56
  491. ccxt/test/base/test_borrow_interest.py +0 -35
  492. ccxt/test/base/test_borrow_rate.py +0 -32
  493. ccxt/test/base/test_calculate_fee.py +0 -51
  494. ccxt/test/base/test_crypto.py +0 -127
  495. ccxt/test/base/test_currency.py +0 -76
  496. ccxt/test/base/test_datetime.py +0 -109
  497. ccxt/test/base/test_decimal_to_precision.py +0 -392
  498. ccxt/test/base/test_deep_extend.py +0 -68
  499. ccxt/test/base/test_deposit_withdrawal.py +0 -50
  500. ccxt/test/base/test_exchange_datetime_functions.py +0 -76
  501. ccxt/test/base/test_funding_rate_history.py +0 -29
  502. ccxt/test/base/test_last_price.py +0 -31
  503. ccxt/test/base/test_ledger_entry.py +0 -45
  504. ccxt/test/base/test_ledger_item.py +0 -48
  505. ccxt/test/base/test_leverage_tier.py +0 -33
  506. ccxt/test/base/test_liquidation.py +0 -50
  507. ccxt/test/base/test_margin_mode.py +0 -24
  508. ccxt/test/base/test_margin_modification.py +0 -35
  509. ccxt/test/base/test_market.py +0 -193
  510. ccxt/test/base/test_number.py +0 -411
  511. ccxt/test/base/test_ohlcv.py +0 -33
  512. ccxt/test/base/test_open_interest.py +0 -32
  513. ccxt/test/base/test_order.py +0 -64
  514. ccxt/test/base/test_order_book.py +0 -69
  515. ccxt/test/base/test_position.py +0 -60
  516. ccxt/test/base/test_shared_methods.py +0 -353
  517. ccxt/test/base/test_status.py +0 -24
  518. ccxt/test/base/test_throttle.py +0 -126
  519. ccxt/test/base/test_ticker.py +0 -92
  520. ccxt/test/base/test_trade.py +0 -47
  521. ccxt/test/base/test_trading_fee.py +0 -26
  522. ccxt/test/base/test_transaction.py +0 -39
  523. ccxt/test/test_async.py +0 -1649
  524. ccxt/test/test_sync.py +0 -1648
  525. ccxt/wazirx.py +0 -1224
  526. ccxt_ir-4.3.46.0.3.dist-info/RECORD +0 -773
  527. /ccxt/abstract/{huobijp.py → bittrade.py} +0 -0
  528. {ccxt_ir-4.3.46.0.3.dist-info → ccxt_ir-4.5.1.dist-info/licenses}/LICENSE.txt +0 -0
  529. {ccxt_ir-4.3.46.0.3.dist-info → ccxt_ir-4.5.1.dist-info}/top_level.txt +0 -0
ccxt/pro/idex.py DELETED
@@ -1,672 +0,0 @@
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
- from ccxt.base.types import Int, Order, OrderBook, Str, Ticker, Trade
9
- from ccxt.async_support.base.ws.client import Client
10
- from typing import List
11
- from ccxt.base.errors import InvalidNonce
12
- from ccxt.base.precise import Precise
13
-
14
-
15
- class idex(ccxt.async_support.idex):
16
-
17
- def describe(self):
18
- return self.deep_extend(super(idex, self).describe(), {
19
- 'has': {
20
- 'ws': True,
21
- 'watchOrderBook': True,
22
- 'watchTrades': True,
23
- 'watchOHLCV': True,
24
- 'watchTicker': True,
25
- 'watchTickers': False, # for now
26
- 'watchOrders': True,
27
- 'watchTransactions': True,
28
- },
29
- 'urls': {
30
- 'test': {
31
- 'ws': 'wss://websocket-matic.idex.io/v1',
32
- },
33
- 'api': {},
34
- },
35
- 'options': {
36
- 'tradesLimit': 1000,
37
- 'ordersLimit': 1000,
38
- 'OHLCVLimit': 1000,
39
- 'watchOrderBookLimit': 1000, # default limit
40
- 'orderBookSubscriptions': {},
41
- 'token': None,
42
- 'watchOrderBook': {
43
- 'maxRetries': 3,
44
- },
45
- 'fetchOrderBookSnapshotMaxAttempts': 10,
46
- 'fetchOrderBookSnapshotMaxDelay': 10000, # raise if there are no orders in 10 seconds
47
- },
48
- })
49
-
50
- async def subscribe(self, subscribeObject, messageHash, subscription=True):
51
- url = self.urls['test']['ws']
52
- request: dict = {
53
- 'method': 'subscribe',
54
- 'subscriptions': [
55
- subscribeObject,
56
- ],
57
- }
58
- return await self.watch(url, messageHash, request, messageHash, subscription)
59
-
60
- async def subscribe_private(self, subscribeObject, messageHash):
61
- token = await self.authenticate()
62
- url = self.urls['test']['ws']
63
- request: dict = {
64
- 'method': 'subscribe',
65
- 'token': token,
66
- 'subscriptions': [
67
- subscribeObject,
68
- ],
69
- }
70
- return await self.watch(url, messageHash, request, messageHash)
71
-
72
- async def watch_ticker(self, symbol: str, params={}) -> Ticker:
73
- """
74
- watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
75
- :param str symbol: unified symbol of the market to fetch the ticker for
76
- :param dict [params]: extra parameters specific to the exchange API endpoint
77
- :returns dict: a `ticker structure <https://docs.ccxt.com/#/?id=ticker-structure>`
78
- """
79
- await self.load_markets()
80
- market = self.market(symbol)
81
- name = 'tickers'
82
- subscribeObject: dict = {
83
- 'name': name,
84
- 'markets': [market['id']],
85
- }
86
- messageHash = name + ':' + market['id']
87
- return await self.subscribe(self.extend(subscribeObject, params), messageHash)
88
-
89
- def handle_ticker(self, client: Client, message):
90
- # {type: "tickers",
91
- # "data":
92
- # {m: "DIL-ETH",
93
- # "t": 1599213946045,
94
- # "o": "0.09699020",
95
- # "h": "0.10301548",
96
- # "l": "0.09577222",
97
- # "c": "0.09907311",
98
- # "Q": "1.32723120",
99
- # "v": "297.80667468",
100
- # "q": "29.52142669",
101
- # "P": "2.14",
102
- # "n": 197,
103
- # "a": "0.09912245",
104
- # "b": "0.09686980",
105
- # "u": 5870}}
106
- type = self.safe_string(message, 'type')
107
- data = self.safe_value(message, 'data')
108
- marketId = self.safe_string(data, 'm')
109
- symbol = self.safe_symbol(marketId)
110
- messageHash = type + ':' + marketId
111
- timestamp = self.safe_integer(data, 't')
112
- close = self.safe_string(data, 'c')
113
- percentage = self.safe_string(data, 'P')
114
- change = None
115
- if (percentage is not None) and (close is not None):
116
- change = Precise.string_mul(close, percentage)
117
- ticker = self.safe_ticker({
118
- 'symbol': symbol,
119
- 'timestamp': timestamp,
120
- 'datetime': self.iso8601(timestamp),
121
- 'high': self.safe_string(data, 'h'),
122
- 'low': self.safe_string(data, 'l'),
123
- 'bid': self.safe_string(data, 'b'),
124
- 'bidVolume': None,
125
- 'ask': self.safe_string(data, 'a'),
126
- 'askVolume': None,
127
- 'vwap': None,
128
- 'open': self.safe_string(data, 'o'),
129
- 'close': close,
130
- 'last': close,
131
- 'previousClose': None,
132
- 'change': change,
133
- 'percentage': percentage,
134
- 'average': None,
135
- 'baseVolume': self.safe_string(data, 'v'),
136
- 'quoteVolume': self.safe_string(data, 'q'),
137
- 'info': message,
138
- })
139
- client.resolve(ticker, messageHash)
140
-
141
- async def watch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
142
- """
143
- get the list of most recent trades for a particular symbol
144
- :param str symbol: unified symbol of the market to fetch trades for
145
- :param int [since]: timestamp in ms of the earliest trade to fetch
146
- :param int [limit]: the maximum amount of trades to fetch
147
- :param dict [params]: extra parameters specific to the exchange API endpoint
148
- :returns dict[]: a list of `trade structures <https://docs.ccxt.com/#/?id=public-trades>`
149
- """
150
- await self.load_markets()
151
- market = self.market(symbol)
152
- symbol = market['symbol']
153
- name = 'trades'
154
- subscribeObject: dict = {
155
- 'name': name,
156
- 'markets': [market['id']],
157
- }
158
- messageHash = name + ':' + market['id']
159
- trades = await self.subscribe(subscribeObject, messageHash)
160
- if self.newUpdates:
161
- limit = trades.getLimit(symbol, limit)
162
- return self.filter_by_since_limit(trades, since, limit, 'timestamp', True)
163
-
164
- def handle_trade(self, client: Client, message):
165
- type = self.safe_string(message, 'type')
166
- data = self.safe_value(message, 'data')
167
- marketId = self.safe_string(data, 'm')
168
- messageHash = type + ':' + marketId
169
- trade = self.parse_ws_trade(data)
170
- keys = list(self.trades.keys())
171
- length = len(keys)
172
- if length == 0:
173
- limit = self.safe_integer(self.options, 'tradesLimit')
174
- self.trades = ArrayCacheBySymbolById(limit)
175
- trades = self.trades
176
- trades.append(trade)
177
- client.resolve(trades, messageHash)
178
-
179
- def parse_ws_trade(self, trade, market=None):
180
- # public trades
181
- # {m: "DIL-ETH",
182
- # "i": "897ecae6-4b75-368a-ac00-be555e6ad65f",
183
- # "p": "0.09696995",
184
- # "q": "2.00000000",
185
- # "Q": "0.19393990",
186
- # "t": 1599504616247,
187
- # "s": "buy",
188
- # "u": 6620}
189
- # private trades
190
- # {i: "ee253d78-88be-37ed-a61c-a36395c2ce48",
191
- # "p": "0.09925382",
192
- # "q": "0.15000000",
193
- # "Q": "0.01488807",
194
- # "t": 1599499129369,
195
- # "s": "sell",
196
- # "u": 6603,
197
- # "f": "0.00030000",
198
- # "a": "DIL",
199
- # "g": "0.00856110",
200
- # "l": "maker",
201
- # "S": "pending"}
202
- marketId = self.safe_string(trade, 'm')
203
- symbol = self.safe_symbol(marketId)
204
- id = self.safe_string(trade, 'i')
205
- price = self.safe_string(trade, 'p')
206
- amount = self.safe_string(trade, 'q')
207
- cost = self.safe_string(trade, 'Q')
208
- timestamp = self.safe_integer(trade, 't')
209
- side = self.safe_string(trade, 's')
210
- fee = {
211
- 'currency': self.safe_string(trade, 'a'),
212
- 'cost': self.safe_string(trade, 'f'),
213
- }
214
- takerOrMarker = self.safe_string(trade, 'l')
215
- return self.safe_trade({
216
- 'info': trade,
217
- 'timestamp': timestamp,
218
- 'datetime': self.iso8601(timestamp),
219
- 'symbol': symbol,
220
- 'id': id,
221
- 'order': None,
222
- 'type': None,
223
- 'takerOrMaker': takerOrMarker,
224
- 'side': side,
225
- 'price': price,
226
- 'amount': amount,
227
- 'cost': cost,
228
- 'fee': fee,
229
- })
230
-
231
- async def watch_ohlcv(self, symbol: str, timeframe='1m', since: Int = None, limit: Int = None, params={}) -> List[list]:
232
- """
233
- watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
234
- :param str symbol: unified symbol of the market to fetch OHLCV data for
235
- :param str timeframe: the length of time each candle represents
236
- :param int [since]: timestamp in ms of the earliest candle to fetch
237
- :param int [limit]: the maximum amount of candles to fetch
238
- :param dict [params]: extra parameters specific to the exchange API endpoint
239
- :returns int[][]: A list of candles ordered, open, high, low, close, volume
240
- """
241
- await self.load_markets()
242
- market = self.market(symbol)
243
- symbol = market['symbol']
244
- name = 'candles'
245
- interval = self.safe_string(self.timeframes, timeframe, timeframe)
246
- subscribeObject: dict = {
247
- 'name': name,
248
- 'markets': [market['id']],
249
- 'interval': interval,
250
- }
251
- messageHash = name + ':' + market['id']
252
- ohlcv = await self.subscribe(subscribeObject, messageHash)
253
- if self.newUpdates:
254
- limit = ohlcv.getLimit(symbol, limit)
255
- return self.filter_by_since_limit(ohlcv, since, limit, 0, True)
256
-
257
- def handle_ohlcv(self, client: Client, message):
258
- # {type: "candles",
259
- # "data":
260
- # {m: "DIL-ETH",
261
- # "t": 1599477340109,
262
- # "i": "1m",
263
- # "s": 1599477300000,
264
- # "e": 1599477360000,
265
- # "o": "0.09911040",
266
- # "h": "0.09911040",
267
- # "l": "0.09911040",
268
- # "c": "0.09911040",
269
- # "v": "0.15000000",
270
- # "n": 1,
271
- # "u": 6531}}
272
- type = self.safe_string(message, 'type')
273
- data = self.safe_value(message, 'data')
274
- marketId = self.safe_string(data, 'm')
275
- messageHash = type + ':' + marketId
276
- parsed = [
277
- self.safe_integer(data, 's'),
278
- self.safe_float(data, 'o'),
279
- self.safe_float(data, 'h'),
280
- self.safe_float(data, 'l'),
281
- self.safe_float(data, 'c'),
282
- self.safe_float(data, 'v'),
283
- ]
284
- symbol = self.safe_symbol(marketId)
285
- interval = self.safe_string(data, 'i')
286
- timeframe = self.find_timeframe(interval)
287
- # TODO: move to base class
288
- self.ohlcvs[symbol] = self.safe_value(self.ohlcvs, symbol, {})
289
- stored = self.safe_value(self.ohlcvs[symbol], timeframe)
290
- if stored is None:
291
- limit = self.safe_integer(self.options, 'OHLCVLimit', 1000)
292
- stored = ArrayCacheByTimestamp(limit)
293
- self.ohlcvs[symbol][timeframe] = stored
294
- stored.append(parsed)
295
- client.resolve(stored, messageHash)
296
-
297
- def handle_subscribe_message(self, client: Client, message):
298
- # {
299
- # "type": "subscriptions",
300
- # "subscriptions": [
301
- # {
302
- # "name": "l2orderbook",
303
- # "markets": [
304
- # "DIL-ETH"
305
- # ]
306
- # }
307
- # ]
308
- # }
309
- subscriptions = self.safe_value(message, 'subscriptions')
310
- for i in range(0, len(subscriptions)):
311
- subscription = subscriptions[i]
312
- name = self.safe_string(subscription, 'name')
313
- if name == 'l2orderbook':
314
- markets = self.safe_value(subscription, 'markets')
315
- for j in range(0, len(markets)):
316
- marketId = markets[j]
317
- orderBookSubscriptions = self.safe_value(self.options, 'orderBookSubscriptions', {})
318
- if not (marketId in orderBookSubscriptions):
319
- symbol = self.safe_symbol(marketId)
320
- if not (symbol in self.orderbooks):
321
- orderbook = self.counted_order_book({})
322
- # orderbook.cache = [] # cache is never used?
323
- self.orderbooks[symbol] = orderbook
324
- self.spawn(self.fetch_order_book_snapshot, client, symbol)
325
- break
326
-
327
- async def fetch_order_book_snapshot(self, client, symbol, params={}):
328
- orderbook = self.orderbooks[symbol]
329
- market = self.market(symbol)
330
- messageHash = 'l2orderbook' + ':' + market['id']
331
- subscription = client.subscriptions[messageHash]
332
- if not subscription['fetchingOrderBookSnapshot']:
333
- subscription['startTime'] = self.milliseconds()
334
- subscription['fetchingOrderBookSnapshot'] = True
335
- maxAttempts = self.safe_integer(self.options, 'fetchOrderBookSnapshotMaxAttempts', 10)
336
- maxDelay = self.safe_integer(self.options, 'fetchOrderBookSnapshotMaxDelay', 10000)
337
- try:
338
- limit = self.safe_integer(subscription, 'limit', 0)
339
- # 3. Request a level-2 order book snapshot for the market from the REST API Order Books endpoint with limit set to 0.
340
- snapshot = await self.fetch_rest_order_book_safe(symbol, limit)
341
- firstBuffered = self.safe_value(orderbook.cache, 0)
342
- firstData = self.safe_value(firstBuffered, 'data')
343
- firstNonce = self.safe_integer(firstData, 'u')
344
- length = len(orderbook.cache)
345
- lastBuffered = self.safe_value(orderbook.cache, length - 1)
346
- lastData = self.safe_value(lastBuffered, 'data')
347
- lastNonce = self.safe_integer(lastData, 'u')
348
- bothExist = (firstNonce is not None) and (lastNonce is not None)
349
- # ensure the snapshot is inside the range of our cached messages
350
- # for example if the snapshot nonce is 100
351
- # the first nonce must be less than or equal to 101 and the last nonce must be greater than 101
352
- if bothExist and (firstNonce <= snapshot['nonce'] + 1) and (lastNonce > snapshot['nonce']):
353
- orderbook.reset(snapshot)
354
- for i in range(0, len(orderbook.cache)):
355
- message = orderbook.cache[i]
356
- data = self.safe_value(message, 'data')
357
- u = self.safe_integer(data, 'u')
358
- if u > orderbook['nonce']:
359
- # 5. Discard all order book update messages with sequence numbers less than or equal to the snapshot sequence number.
360
- # 6. Apply the remaining buffered order book update messages and any incoming order book update messages to the order book snapshot.
361
- self.handle_order_book_message(client, message, orderbook)
362
- subscription['fetchingOrderBookSnapshot'] = False
363
- client.resolve(orderbook, messageHash)
364
- else:
365
- # 4. If the sequence in the order book snapshot is less than the sequence of the
366
- # first buffered order book update message, discard the order book snapshot and retry step 3.
367
- # self will continue to recurse until we have a buffered message
368
- # since updates the order book endpoint depend on order events
369
- # so it will eventually raise if there are no orders on a pair
370
- subscription['numAttempts'] = subscription['numAttempts'] + 1
371
- timeElapsed = self.milliseconds() - subscription['startTime']
372
- maxAttemptsValid = subscription['numAttempts'] < maxAttempts
373
- timeElapsedValid = timeElapsed < maxDelay
374
- if maxAttemptsValid and timeElapsedValid:
375
- self.delay(self.rateLimit, self.fetch_order_book_snapshot, client, symbol)
376
- else:
377
- endpart = ' in ' + str(maxAttempts) + ' attempts' if (not maxAttemptsValid) else ' after ' + str(maxDelay) + ' milliseconds'
378
- raise InvalidNonce(self.id + ' failed to synchronize WebSocket feed with the snapshot for symbol ' + symbol + endpart)
379
- except Exception as e:
380
- subscription['fetchingOrderBookSnapshot'] = False
381
- client.reject(e, messageHash)
382
-
383
- async def watch_order_book(self, symbol: str, limit: Int = None, params={}) -> OrderBook:
384
- """
385
- watches information on open orders with bid(buy) and ask(sell) prices, volumes and other data
386
- :param str symbol: unified symbol of the market to fetch the order book for
387
- :param int [limit]: the maximum amount of order book entries to return
388
- :param dict [params]: extra parameters specific to the exchange API endpoint
389
- :returns dict: A dictionary of `order book structures <https://docs.ccxt.com/#/?id=order-book-structure>` indexed by market symbols
390
- """
391
- await self.load_markets()
392
- market = self.market(symbol)
393
- name = 'l2orderbook'
394
- subscribeObject: dict = {
395
- 'name': name,
396
- 'markets': [market['id']],
397
- }
398
- messageHash = name + ':' + market['id']
399
- subscription: dict = {
400
- 'fetchingOrderBookSnapshot': False,
401
- 'numAttempts': 0,
402
- 'startTime': None,
403
- }
404
- if limit is None:
405
- subscription['limit'] = 1000
406
- else:
407
- subscription['limit'] = limit
408
- # 1. Connect to the WebSocket API endpoint and subscribe to the L2 Order Book for the target market.
409
- orderbook = await self.subscribe(subscribeObject, messageHash, subscription)
410
- return orderbook.limit()
411
-
412
- def handle_order_book(self, client: Client, message):
413
- data = self.safe_value(message, 'data')
414
- marketId = self.safe_string(data, 'm')
415
- symbol = self.safe_symbol(marketId)
416
- orderbook = self.orderbooks[symbol]
417
- if orderbook['nonce'] is None:
418
- # 2. Buffer the incoming order book update subscription messages.
419
- orderbook.cache.append(message)
420
- else:
421
- self.handle_order_book_message(client, message, orderbook)
422
-
423
- def handle_order_book_message(self, client: Client, message, orderbook):
424
- # {
425
- # "type": "l2orderbook",
426
- # "data": {
427
- # "m": "DIL-ETH",
428
- # "t": 1600197205037,
429
- # "u": 94116643,
430
- # "b": [
431
- # [
432
- # "0.09662187",
433
- # "0.00000000",
434
- # 0
435
- # ]
436
- # ],
437
- # "a": []
438
- # }
439
- # }
440
- type = self.safe_string(message, 'type')
441
- data = self.safe_value(message, 'data')
442
- marketId = self.safe_string(data, 'm')
443
- messageHash = type + ':' + marketId
444
- nonce = self.safe_integer(data, 'u')
445
- timestamp = self.safe_integer(data, 't')
446
- bids = self.safe_value(data, 'b')
447
- asks = self.safe_value(data, 'a')
448
- self.handle_deltas(orderbook['bids'], bids)
449
- self.handle_deltas(orderbook['asks'], asks)
450
- orderbook['nonce'] = nonce
451
- orderbook['timestamp'] = timestamp
452
- orderbook['datetime'] = self.iso8601(timestamp)
453
- client.resolve(orderbook, messageHash)
454
-
455
- def handle_delta(self, bookside, delta):
456
- price = self.safe_float(delta, 0)
457
- amount = self.safe_float(delta, 1)
458
- count = self.safe_integer(delta, 2)
459
- bookside.storeArray([price, amount, count])
460
-
461
- def handle_deltas(self, bookside, deltas):
462
- for i in range(0, len(deltas)):
463
- self.handle_delta(bookside, deltas[i])
464
-
465
- async def authenticate(self, params={}):
466
- time = self.seconds()
467
- lastAuthenticatedTime = self.safe_integer(self.options, 'lastAuthenticatedTime', 0)
468
- if time - lastAuthenticatedTime > 900:
469
- request: dict = {
470
- 'wallet': self.walletAddress,
471
- 'nonce': self.uuidv1(),
472
- }
473
- response = await self.privateGetWsToken(self.extend(request, params))
474
- self.options['lastAuthenticatedTime'] = time
475
- self.options['token'] = self.safe_string(response, 'token')
476
- return self.options['token']
477
-
478
- async def watch_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
479
- """
480
- watches information on multiple orders made by the user
481
- :param str symbol: unified market symbol of the market orders were made in
482
- :param int [since]: the earliest time in ms to fetch orders for
483
- :param int [limit]: the maximum number of order structures to retrieve
484
- :param dict [params]: extra parameters specific to the exchange API endpoint
485
- :returns dict[]: a list of `order structures <https://docs.ccxt.com/#/?id=order-structure>`
486
- """
487
- await self.load_markets()
488
- name = 'orders'
489
- subscribeObject: dict = {
490
- 'name': name,
491
- }
492
- messageHash = name
493
- if symbol is not None:
494
- symbol = self.symbol(symbol)
495
- marketId = self.market_id(symbol)
496
- subscribeObject['markets'] = [marketId]
497
- messageHash = name + ':' + marketId
498
- orders = await self.subscribe_private(subscribeObject, messageHash)
499
- if self.newUpdates:
500
- limit = orders.getLimit(symbol, limit)
501
- return self.filter_by_since_limit(orders, since, limit, 'timestamp', True)
502
-
503
- def handle_order(self, client: Client, message):
504
- # {
505
- # "type": "orders",
506
- # "data": {
507
- # "m": "DIL-ETH",
508
- # "i": "8f75dd30-f12d-11ea-b63c-df3381b4b5b4",
509
- # "w": "0x0AB991497116f7F5532a4c2f4f7B1784488628e1",
510
- # "t": 1599498857138,
511
- # "T": 1599498857092,
512
- # "x": "fill",
513
- # "X": "filled",
514
- # "u": 67695627,
515
- # "o": "limit",
516
- # "S": "buy",
517
- # "q": "0.15000000",
518
- # "z": "0.15000000",
519
- # "Z": "0.01486286",
520
- # "v": "0.09908573",
521
- # "p": "1.00000000",
522
- # "f": "gtc",
523
- # "V": "2",
524
- # "F": [
525
- # {
526
- # "i": "5cdc6d14-bc35-3279-ab5e-40d654ca1523",
527
- # "p": "0.09908577",
528
- # "q": "0.15000000",
529
- # "Q": "0.01486286",
530
- # "t": 1599498857092,
531
- # "s": "sell",
532
- # "u": 6600,
533
- # "f": "0.00030000",
534
- # "a": "DIL",
535
- # "g": "0.00856977",
536
- # "l": "maker",
537
- # "S": "pending"
538
- # }
539
- # ]
540
- # }
541
- # }
542
- type = self.safe_string(message, 'type')
543
- order = self.safe_value(message, 'data')
544
- marketId = self.safe_string(order, 'm')
545
- symbol = self.safe_symbol(marketId)
546
- timestamp = self.safe_integer(order, 't')
547
- fills = self.safe_value(order, 'F', [])
548
- trades = []
549
- for i in range(0, len(fills)):
550
- trades.append(self.parse_ws_trade(fills[i]))
551
- id = self.safe_string(order, 'i')
552
- side = self.safe_string(order, 's')
553
- orderType = self.safe_string(order, 'o')
554
- amount = self.safe_string(order, 'q')
555
- filled = self.safe_string(order, 'z')
556
- average = self.safe_string(order, 'v')
557
- price = self.safe_string(order, 'price', average) # for market orders
558
- rawStatus = self.safe_string(order, 'X')
559
- status = self.parse_order_status(rawStatus)
560
- fee = {
561
- 'currency': None,
562
- 'cost': None,
563
- }
564
- lastTrade = None
565
- for i in range(0, len(trades)):
566
- lastTrade = trades[i]
567
- fee['currency'] = lastTrade['fee']['currency']
568
- stringLastTradeFee = lastTrade['fee']['cost']
569
- fee['cost'] = Precise.string_add(fee['cost'], stringLastTradeFee)
570
- lastTradeTimestamp = self.safe_integer(lastTrade, 'timestamp')
571
- parsedOrder = self.safe_order({
572
- 'info': message,
573
- 'id': id,
574
- 'clientOrderId': None,
575
- 'timestamp': timestamp,
576
- 'datetime': self.iso8601(timestamp),
577
- 'lastTradeTimestamp': lastTradeTimestamp,
578
- 'symbol': symbol,
579
- 'type': orderType,
580
- 'side': side,
581
- 'price': self.parse_number(price),
582
- 'stopPrice': None,
583
- 'triggerPrice': None,
584
- 'amount': self.parse_number(amount),
585
- 'cost': None,
586
- 'average': self.parse_number(average),
587
- 'filled': self.parse_number(filled),
588
- 'remaining': None,
589
- 'status': status,
590
- 'fee': fee,
591
- 'trades': trades,
592
- })
593
- if self.orders is None:
594
- limit = self.safe_integer(self.options, 'ordersLimit', 1000)
595
- self.orders = ArrayCacheBySymbolById(limit)
596
- orders = self.orders
597
- orders.append(parsedOrder)
598
- symbolSpecificMessageHash = type + ':' + marketId
599
- client.resolve(orders, symbolSpecificMessageHash)
600
- client.resolve(orders, type)
601
-
602
- async def watch_transactions(self, code: Str = None, since: Int = None, limit: Int = None, params={}):
603
- await self.load_markets()
604
- name = 'balances'
605
- subscribeObject: dict = {
606
- 'name': name,
607
- }
608
- messageHash = name
609
- if code is not None:
610
- messageHash = name + ':' + code
611
- transactions = await self.subscribe_private(subscribeObject, messageHash)
612
- if self.newUpdates:
613
- limit = transactions.getLimit(code, limit)
614
- return self.filter_by_since_limit(transactions, since, limit, 'timestamp')
615
-
616
- def handle_transaction(self, client: Client, message):
617
- # Update Speed: Real time, updates on any deposit or withdrawal of the wallet
618
- # {type: "balances",
619
- # "data":
620
- # {w: "0x0AB991497116f7F5532a4c2f4f7B1784488628e1",
621
- # "a": "ETH",
622
- # "q": "0.11198667",
623
- # "f": "0.11198667",
624
- # "l": "0.00000000",
625
- # "d": "0.00"}}
626
- type = self.safe_string(message, 'type')
627
- data = self.safe_value(message, 'data')
628
- currencyId = self.safe_string(data, 'a')
629
- messageHash = type + ':' + currencyId
630
- code = self.safe_currency_code(currencyId)
631
- address = self.safe_string(data, 'w')
632
- transaction: dict = {
633
- 'info': message,
634
- 'id': None,
635
- 'currency': code,
636
- 'amount': None,
637
- 'address': address,
638
- 'addressTo': None,
639
- 'addressFrom': None,
640
- 'tag': None,
641
- 'tagTo': None,
642
- 'tagFrom': None,
643
- 'status': 'ok',
644
- 'type': None,
645
- 'updated': None,
646
- 'txid': None,
647
- 'timestamp': None,
648
- 'datetime': None,
649
- 'fee': None,
650
- }
651
- if not (code in self.transactions):
652
- limit = self.safe_integer(self.options, 'transactionsLimit', 1000)
653
- self.transactions[code] = ArrayCache(limit)
654
- transactions = self.transactions[code]
655
- transactions.append(transaction)
656
- client.resolve(transactions, messageHash)
657
- client.resolve(transactions, type)
658
-
659
- def handle_message(self, client: Client, message):
660
- type = self.safe_string(message, 'type')
661
- methods: dict = {
662
- 'tickers': self.handle_ticker,
663
- 'trades': self.handle_trade,
664
- 'subscriptions': self.handle_subscribe_message,
665
- 'candles': self.handle_ohlcv,
666
- 'l2orderbook': self.handle_order_book,
667
- 'balances': self.handle_transaction,
668
- 'orders': self.handle_order,
669
- }
670
- if type in methods:
671
- method = methods[type]
672
- method(client, message)