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
@@ -0,0 +1,1127 @@
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
+ from ccxt.async_support.base.exchange import Exchange
7
+ from ccxt.abstract.coinone import ImplicitAPI
8
+ import hashlib
9
+ from ccxt.base.types import Balances, Currencies, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade
10
+ from typing import List
11
+ from ccxt.base.errors import ExchangeError
12
+ from ccxt.base.errors import ArgumentsRequired
13
+ from ccxt.base.errors import BadRequest
14
+ from ccxt.base.errors import BadSymbol
15
+ from ccxt.base.errors import OrderNotFound
16
+ from ccxt.base.errors import OnMaintenance
17
+ from ccxt.base.decimal_to_precision import TICK_SIZE
18
+ from ccxt.base.precise import Precise
19
+
20
+
21
+ class coinone(Exchange, ImplicitAPI):
22
+
23
+ def describe(self):
24
+ return self.deep_extend(super(coinone, self).describe(), {
25
+ 'id': 'coinone',
26
+ 'name': 'CoinOne',
27
+ 'countries': ['KR'], # Korea
28
+ # 'enableRateLimit': False,
29
+ 'rateLimit': 667,
30
+ 'version': 'v2',
31
+ 'pro': False,
32
+ 'has': {
33
+ 'CORS': None,
34
+ 'spot': True,
35
+ 'margin': False,
36
+ 'swap': False,
37
+ 'future': False,
38
+ 'option': False,
39
+ 'addMargin': False,
40
+ 'cancelOrder': True,
41
+ 'closeAllPositions': False,
42
+ 'closePosition': False,
43
+ 'createMarketOrder': False,
44
+ 'createOrder': True,
45
+ 'createReduceOnlyOrder': False,
46
+ 'createStopLimitOrder': False,
47
+ 'createStopMarketOrder': False,
48
+ 'createStopOrder': False,
49
+ 'fetchBalance': True,
50
+ 'fetchBorrowRateHistories': False,
51
+ 'fetchBorrowRateHistory': False,
52
+ 'fetchClosedOrders': False, # the endpoint that should return closed orders actually returns trades, https://github.com/ccxt/ccxt/pull/7067
53
+ 'fetchCrossBorrowRate': False,
54
+ 'fetchCrossBorrowRates': False,
55
+ 'fetchCurrencies': True,
56
+ 'fetchDepositAddresses': True,
57
+ 'fetchFundingHistory': False,
58
+ 'fetchFundingRate': False,
59
+ 'fetchFundingRateHistory': False,
60
+ 'fetchFundingRates': False,
61
+ 'fetchIndexOHLCV': False,
62
+ 'fetchIsolatedBorrowRate': False,
63
+ 'fetchIsolatedBorrowRates': False,
64
+ 'fetchLeverage': False,
65
+ 'fetchLeverageTiers': False,
66
+ 'fetchMarginMode': False,
67
+ 'fetchMarkets': True,
68
+ 'fetchMarkOHLCV': False,
69
+ 'fetchMyTrades': True,
70
+ 'fetchOpenInterestHistory': False,
71
+ 'fetchOpenOrders': True,
72
+ 'fetchOrder': True,
73
+ 'fetchOrderBook': True,
74
+ 'fetchPosition': False,
75
+ 'fetchPositionHistory': False,
76
+ 'fetchPositionMode': False,
77
+ 'fetchPositions': False,
78
+ 'fetchPositionsForSymbol': False,
79
+ 'fetchPositionsHistory': False,
80
+ 'fetchPositionsRisk': False,
81
+ 'fetchPremiumIndexOHLCV': False,
82
+ 'fetchTicker': True,
83
+ 'fetchTickers': True,
84
+ 'fetchTrades': True,
85
+ 'reduceMargin': False,
86
+ 'setLeverage': False,
87
+ 'setMarginMode': False,
88
+ 'setPositionMode': False,
89
+ 'ws': True,
90
+ },
91
+ 'urls': {
92
+ 'logo': 'https://user-images.githubusercontent.com/1294454/38003300-adc12fba-323f-11e8-8525-725f53c4a659.jpg',
93
+ 'api': {
94
+ 'rest': 'https://api.coinone.co.kr',
95
+ 'v2Public': 'https://api.coinone.co.kr/public/v2',
96
+ 'v2Private': 'https://api.coinone.co.kr/v2',
97
+ 'v2_1Private': 'https://api.coinone.co.kr/v2.1',
98
+ },
99
+ 'www': 'https://coinone.co.kr',
100
+ 'doc': 'https://doc.coinone.co.kr',
101
+ },
102
+ 'requiredCredentials': {
103
+ 'apiKey': True,
104
+ 'secret': True,
105
+ },
106
+ 'api': {
107
+ 'public': {
108
+ 'get': [
109
+ 'orderbook',
110
+ 'ticker',
111
+ 'ticker_utc',
112
+ 'trades',
113
+ ],
114
+ },
115
+ 'v2Public': {
116
+ 'get': [
117
+ 'range_units',
118
+ 'markets/{quote_currency}',
119
+ 'markets/{quote_currency}/{target_currency}',
120
+ 'orderbook/{quote_currency}/{target_currency}',
121
+ 'trades/{quote_currency}/{target_currency}',
122
+ 'ticker_new/{quote_currency}',
123
+ 'ticker_new/{quote_currency}/{target_currency}',
124
+ 'ticker_utc_new/{quote_currency}',
125
+ 'ticker_utc_new/{quote_currency}/{target_currency}',
126
+ 'currencies',
127
+ 'currencies/{currency}',
128
+ 'chart/{quote_currency}/{target_currency}',
129
+ ],
130
+ },
131
+ 'private': {
132
+ 'post': [
133
+ 'account/deposit_address',
134
+ 'account/btc_deposit_address',
135
+ 'account/balance',
136
+ 'account/daily_balance',
137
+ 'account/user_info',
138
+ 'account/virtual_account',
139
+ 'order/cancel_all',
140
+ 'order/cancel',
141
+ 'order/limit_buy',
142
+ 'order/limit_sell',
143
+ 'order/complete_orders',
144
+ 'order/limit_orders',
145
+ 'order/order_info',
146
+ 'transaction/auth_number',
147
+ 'transaction/history',
148
+ 'transaction/krw/history',
149
+ 'transaction/btc',
150
+ 'transaction/coin',
151
+ ],
152
+ },
153
+ 'v2Private': {
154
+ 'post': [
155
+ 'account/balance',
156
+ 'account/deposit_address',
157
+ 'account/user_info',
158
+ 'account/virtual_account',
159
+ 'order/cancel',
160
+ 'order/limit_buy',
161
+ 'order/limit_sell',
162
+ 'order/limit_orders',
163
+ 'order/complete_orders',
164
+ 'order/query_order',
165
+ 'transaction/auth_number',
166
+ 'transaction/btc',
167
+ 'transaction/history',
168
+ 'transaction/krw/history',
169
+ ],
170
+ },
171
+ 'v2_1Private': {
172
+ 'post': [
173
+ 'account/balance/all',
174
+ 'account/balance',
175
+ 'account/trade_fee',
176
+ 'account/trade_fee/{quote_currency}/{target_currency}',
177
+ 'order/limit',
178
+ 'order/cancel',
179
+ 'order/cancel/all',
180
+ 'order/open_orders',
181
+ 'order/open_orders/all',
182
+ 'order/complete_orders',
183
+ 'order/complete_orders/all',
184
+ 'order/info',
185
+ 'transaction/krw/history',
186
+ 'transaction/coin/history',
187
+ 'transaction/coin/withdrawal/limit',
188
+ ],
189
+ },
190
+ },
191
+ 'fees': {
192
+ 'trading': {
193
+ 'tierBased': False,
194
+ 'percentage': True,
195
+ 'taker': 0.002,
196
+ 'maker': 0.002,
197
+ },
198
+ },
199
+ 'precisionMode': TICK_SIZE,
200
+ 'exceptions': {
201
+ '405': OnMaintenance, # {"errorCode":"405","status":"maintenance","result":"error"}
202
+ '104': OrderNotFound, # {"errorCode":"104","errorMsg":"Order id is not exist","result":"error"}
203
+ '108': BadSymbol, # {"errorCode":"108","errorMsg":"Unknown CryptoCurrency","result":"error"}
204
+ '107': BadRequest, # {"errorCode":"107","errorMsg":"Parameter error","result":"error"}
205
+ },
206
+ 'commonCurrencies': {
207
+ 'SOC': 'Soda Coin',
208
+ },
209
+ })
210
+
211
+ async def fetch_currencies(self, params={}) -> Currencies:
212
+ """
213
+ fetches all available currencies on an exchange
214
+ :see: https://docs.coinone.co.kr/reference/currencies
215
+ :param dict [params]: extra parameters specific to the exchange API endpoint
216
+ :returns dict: an associative dictionary of currencies
217
+ """
218
+ response = await self.v2PublicGetCurrencies(params)
219
+ #
220
+ # {
221
+ # "result": "success",
222
+ # "error_code": "0",
223
+ # "server_time": 1701054555578,
224
+ # "currencies": [
225
+ # {
226
+ # "name": "Polygon",
227
+ # "symbol": "MATIC",
228
+ # "deposit_status": "normal",
229
+ # "withdraw_status": "normal",
230
+ # "deposit_confirm_count": 150,
231
+ # "max_precision": 8,
232
+ # "deposit_fee": "0.0",
233
+ # "withdrawal_min_amount": "1.0",
234
+ # "withdrawal_fee": "3.0"
235
+ # }
236
+ # ]
237
+ # }
238
+ #
239
+ result: dict = {}
240
+ currencies = self.safe_value(response, 'currencies', [])
241
+ for i in range(0, len(currencies)):
242
+ entry = currencies[i]
243
+ id = self.safe_string(entry, 'symbol')
244
+ name = self.safe_string(entry, 'name')
245
+ code = self.safe_currency_code(id)
246
+ withdrawStatus = self.safe_string(entry, 'withdraw_status', '')
247
+ depositStatus = self.safe_string(entry, 'deposit_status', '')
248
+ isWithdrawEnabled = withdrawStatus == 'normal'
249
+ isDepositEnabled = depositStatus == 'normal'
250
+ result[code] = {
251
+ 'id': id,
252
+ 'code': code,
253
+ 'info': entry,
254
+ 'name': name,
255
+ 'active': isWithdrawEnabled and isDepositEnabled,
256
+ 'deposit': isDepositEnabled,
257
+ 'withdraw': isWithdrawEnabled,
258
+ 'fee': self.safe_number(entry, 'withdrawal_fee'),
259
+ 'precision': self.parse_number(self.parse_precision(self.safe_string(entry, 'max_precision'))),
260
+ 'limits': {
261
+ 'amount': {
262
+ 'min': None,
263
+ 'max': None,
264
+ },
265
+ 'withdraw': {
266
+ 'min': self.safe_number(entry, 'withdrawal_min_amount'),
267
+ 'max': None,
268
+ },
269
+ },
270
+ 'networks': {},
271
+ }
272
+ return result
273
+
274
+ async def fetch_markets(self, params={}) -> List[Market]:
275
+ """
276
+ retrieves data on all markets for coinone
277
+ :see: https://docs.coinone.co.kr/v1.0/reference/tickers
278
+ :param dict [params]: extra parameters specific to the exchange API endpoint
279
+ :returns dict[]: an array of objects representing market data
280
+ """
281
+ request: dict = {
282
+ 'quote_currency': 'KRW',
283
+ }
284
+ response = await self.v2PublicGetTickerNewQuoteCurrency(request)
285
+ #
286
+ # {
287
+ # "result": "success",
288
+ # "error_code": "0",
289
+ # "server_time": 1701067923060,
290
+ # "tickers": [
291
+ # {
292
+ # "quote_currency": "krw",
293
+ # "target_currency": "stg",
294
+ # "timestamp": 1701067920001,
295
+ # "high": "667.5",
296
+ # "low": "667.5",
297
+ # "first": "667.5",
298
+ # "last": "667.5",
299
+ # "quote_volume": "0.0",
300
+ # "target_volume": "0.0",
301
+ # "best_asks": [
302
+ # {
303
+ # "price": "777.0",
304
+ # "qty": "73.9098"
305
+ # }
306
+ # ],
307
+ # "best_bids": [
308
+ # {
309
+ # "price": "690.8",
310
+ # "qty": "40.7768"
311
+ # }
312
+ # ],
313
+ # "id": "1701067920001001"
314
+ # }
315
+ # ]
316
+ # }
317
+ #
318
+ tickers = self.safe_value(response, 'tickers', [])
319
+ result = []
320
+ for i in range(0, len(tickers)):
321
+ entry = self.safe_value(tickers, i)
322
+ id = self.safe_string(entry, 'id')
323
+ baseId = self.safe_string_upper(entry, 'target_currency')
324
+ quoteId = self.safe_string_upper(entry, 'quote_currency')
325
+ base = self.safe_currency_code(baseId)
326
+ quote = self.safe_currency_code(quoteId)
327
+ result.append({
328
+ 'id': id,
329
+ 'symbol': base + '/' + quote,
330
+ 'base': base,
331
+ 'quote': quote,
332
+ 'settle': None,
333
+ 'baseId': baseId,
334
+ 'quoteId': quoteId,
335
+ 'settleId': None,
336
+ 'type': 'spot',
337
+ 'spot': True,
338
+ 'margin': False,
339
+ 'swap': False,
340
+ 'future': False,
341
+ 'option': False,
342
+ 'active': None,
343
+ 'contract': False,
344
+ 'linear': None,
345
+ 'inverse': None,
346
+ 'contractSize': None,
347
+ 'expiry': None,
348
+ 'expiryDatetime': None,
349
+ 'strike': None,
350
+ 'optionType': None,
351
+ 'precision': {
352
+ 'amount': self.parse_number('1e-4'),
353
+ 'price': self.parse_number('1e-4'),
354
+ 'cost': self.parse_number('1e-8'),
355
+ },
356
+ 'limits': {
357
+ 'leverage': {
358
+ 'min': None,
359
+ 'max': None,
360
+ },
361
+ 'amount': {
362
+ 'min': None,
363
+ 'max': None,
364
+ },
365
+ 'price': {
366
+ 'min': None,
367
+ 'max': None,
368
+ },
369
+ 'cost': {
370
+ 'min': None,
371
+ 'max': None,
372
+ },
373
+ },
374
+ 'created': None,
375
+ 'info': entry,
376
+ })
377
+ return result
378
+
379
+ def parse_balance(self, response) -> Balances:
380
+ result: dict = {'info': response}
381
+ balances = self.omit(response, [
382
+ 'errorCode',
383
+ 'result',
384
+ 'normalWallets',
385
+ ])
386
+ currencyIds = list(balances.keys())
387
+ for i in range(0, len(currencyIds)):
388
+ currencyId = currencyIds[i]
389
+ balance = balances[currencyId]
390
+ code = self.safe_currency_code(currencyId)
391
+ account = self.account()
392
+ account['free'] = self.safe_string(balance, 'avail')
393
+ account['total'] = self.safe_string(balance, 'balance')
394
+ result[code] = account
395
+ return self.safe_balance(result)
396
+
397
+ async def fetch_balance(self, params={}) -> Balances:
398
+ """
399
+ query for balance and get the amount of funds available for trading or funds locked in orders
400
+ :see: https://docs.coinone.co.kr/v1.0/reference/v21
401
+ :param dict [params]: extra parameters specific to the exchange API endpoint
402
+ :returns dict: a `balance structure <https://docs.ccxt.com/#/?id=balance-structure>`
403
+ """
404
+ await self.load_markets()
405
+ response = await self.v2PrivatePostAccountBalance(params)
406
+ return self.parse_balance(response)
407
+
408
+ async def fetch_order_book(self, symbol: str, limit: Int = None, params={}) -> OrderBook:
409
+ """
410
+ fetches information on open orders with bid(buy) and ask(sell) prices, volumes and other data
411
+ :see: https://docs.coinone.co.kr/v1.0/reference/orderbook
412
+ :param str symbol: unified symbol of the market to fetch the order book for
413
+ :param int [limit]: the maximum amount of order book entries to return
414
+ :param dict [params]: extra parameters specific to the exchange API endpoint
415
+ :returns dict: A dictionary of `order book structures <https://docs.ccxt.com/#/?id=order-book-structure>` indexed by market symbols
416
+ """
417
+ await self.load_markets()
418
+ market = self.market(symbol)
419
+ request: dict = {
420
+ 'quote_currency': market['quote'],
421
+ 'target_currency': market['base'],
422
+ }
423
+ if limit is not None:
424
+ request['size'] = limit # only support 5, 10, 15, 16
425
+ response = await self.v2PublicGetOrderbookQuoteCurrencyTargetCurrency(self.extend(request, params))
426
+ #
427
+ # {
428
+ # "result": "success",
429
+ # "error_code": "0",
430
+ # "timestamp": 1701071108673,
431
+ # "id": "1701071108673001",
432
+ # "quote_currency": "KRW",
433
+ # "target_currency": "BTC",
434
+ # "order_book_unit": "0.0",
435
+ # "bids": [
436
+ # {
437
+ # "price": "50048000",
438
+ # "qty": "0.01080229"
439
+ # }
440
+ # ],
441
+ # "asks": [
442
+ # {
443
+ # "price": "50058000",
444
+ # "qty": "0.00272592"
445
+ # }
446
+ # ]
447
+ # }
448
+ #
449
+ timestamp = self.safe_integer(response, 'timestamp')
450
+ return self.parse_order_book(response, market['symbol'], timestamp, 'bids', 'asks', 'price', 'qty')
451
+
452
+ async def fetch_tickers(self, symbols: Strings = None, params={}) -> Tickers:
453
+ """
454
+ fetches price tickers for multiple markets, statistical information calculated over the past 24 hours for each market
455
+ :see: https://docs.coinone.co.kr/v1.0/reference/tickers
456
+ :see: https://docs.coinone.co.kr/v1.0/reference/ticker
457
+ :param str[]|None symbols: unified symbols of the markets to fetch the ticker for, all market tickers are returned if not assigned
458
+ :param dict [params]: extra parameters specific to the exchange API endpoint
459
+ :returns dict: a dictionary of `ticker structures <https://docs.ccxt.com/#/?id=ticker-structure>`
460
+ """
461
+ await self.load_markets()
462
+ symbols = self.market_symbols(symbols)
463
+ request: dict = {
464
+ 'quote_currency': 'KRW',
465
+ }
466
+ market = None
467
+ response = None
468
+ if symbols is not None:
469
+ first = self.safe_string(symbols, 0)
470
+ market = self.market(first)
471
+ request['quote_currency'] = market['quote']
472
+ request['target_currency'] = market['base']
473
+ response = await self.v2PublicGetTickerNewQuoteCurrencyTargetCurrency(self.extend(request, params))
474
+ else:
475
+ response = await self.v2PublicGetTickerNewQuoteCurrency(self.extend(request, params))
476
+ #
477
+ # {
478
+ # "result": "success",
479
+ # "error_code": "0",
480
+ # "server_time": 1701073358487,
481
+ # "tickers": [
482
+ # {
483
+ # "quote_currency": "krw",
484
+ # "target_currency": "btc",
485
+ # "timestamp": 1701073357818,
486
+ # "high": "50543000.0",
487
+ # "low": "49945000.0",
488
+ # "first": "50487000.0",
489
+ # "last": "50062000.0",
490
+ # "quote_volume": "11349804285.3859",
491
+ # "target_volume": "226.07268994",
492
+ # "best_asks": [
493
+ # {
494
+ # "price": "50081000.0",
495
+ # "qty": "0.18471358"
496
+ # }
497
+ # ],
498
+ # "best_bids": [
499
+ # {
500
+ # "price": "50062000.0",
501
+ # "qty": "0.04213455"
502
+ # }
503
+ # ],
504
+ # "id": "1701073357818001"
505
+ # }
506
+ # ]
507
+ # }
508
+ #
509
+ data = self.safe_list(response, 'tickers', [])
510
+ return self.parse_tickers(data, symbols)
511
+
512
+ async def fetch_ticker(self, symbol: str, params={}) -> Ticker:
513
+ """
514
+ fetches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
515
+ :see: https://docs.coinone.co.kr/v1.0/reference/ticker
516
+ :param str symbol: unified symbol of the market to fetch the ticker for
517
+ :param dict [params]: extra parameters specific to the exchange API endpoint
518
+ :returns dict: a `ticker structure <https://docs.ccxt.com/#/?id=ticker-structure>`
519
+ """
520
+ await self.load_markets()
521
+ market = self.market(symbol)
522
+ request: dict = {
523
+ 'quote_currency': market['quote'],
524
+ 'target_currency': market['base'],
525
+ }
526
+ response = await self.v2PublicGetTickerNewQuoteCurrencyTargetCurrency(self.extend(request, params))
527
+ #
528
+ # {
529
+ # "result": "success",
530
+ # "error_code": "0",
531
+ # "server_time": 1701073358487,
532
+ # "tickers": [
533
+ # {
534
+ # "quote_currency": "krw",
535
+ # "target_currency": "btc",
536
+ # "timestamp": 1701073357818,
537
+ # "high": "50543000.0",
538
+ # "low": "49945000.0",
539
+ # "first": "50487000.0",
540
+ # "last": "50062000.0",
541
+ # "quote_volume": "11349804285.3859",
542
+ # "target_volume": "226.07268994",
543
+ # "best_asks": [
544
+ # {
545
+ # "price": "50081000.0",
546
+ # "qty": "0.18471358"
547
+ # }
548
+ # ],
549
+ # "best_bids": [
550
+ # {
551
+ # "price": "50062000.0",
552
+ # "qty": "0.04213455"
553
+ # }
554
+ # ],
555
+ # "id": "1701073357818001"
556
+ # }
557
+ # ]
558
+ # }
559
+ #
560
+ data = self.safe_value(response, 'tickers', [])
561
+ ticker = self.safe_dict(data, 0, {})
562
+ return self.parse_ticker(ticker, market)
563
+
564
+ def parse_ticker(self, ticker: dict, market: Market = None) -> Ticker:
565
+ #
566
+ # {
567
+ # "quote_currency": "krw",
568
+ # "target_currency": "btc",
569
+ # "timestamp": 1701073357818,
570
+ # "high": "50543000.0",
571
+ # "low": "49945000.0",
572
+ # "first": "50487000.0",
573
+ # "last": "50062000.0",
574
+ # "quote_volume": "11349804285.3859",
575
+ # "target_volume": "226.07268994",
576
+ # "best_asks": [
577
+ # {
578
+ # "price": "50081000.0",
579
+ # "qty": "0.18471358"
580
+ # }
581
+ # ],
582
+ # "best_bids": [
583
+ # {
584
+ # "price": "50062000.0",
585
+ # "qty": "0.04213455"
586
+ # }
587
+ # ],
588
+ # "id": "1701073357818001"
589
+ # }
590
+ #
591
+ timestamp = self.safe_integer(ticker, 'timestamp')
592
+ last = self.safe_string(ticker, 'last')
593
+ asks = self.safe_value(ticker, 'best_asks')
594
+ bids = self.safe_value(ticker, 'best_bids')
595
+ baseId = self.safe_string(ticker, 'target_currency')
596
+ quoteId = self.safe_string(ticker, 'quote_currency')
597
+ base = self.safe_currency_code(baseId)
598
+ quote = self.safe_currency_code(quoteId)
599
+ return self.safe_ticker({
600
+ 'symbol': base + '/' + quote,
601
+ 'timestamp': timestamp,
602
+ 'datetime': self.iso8601(timestamp),
603
+ 'high': self.safe_string(ticker, 'high'),
604
+ 'low': self.safe_string(ticker, 'low'),
605
+ 'bid': self.safe_string(bids, 'price'),
606
+ 'bidVolume': self.safe_string(bids, 'qty'),
607
+ 'ask': self.safe_string(asks, 'price'),
608
+ 'askVolume': self.safe_string(asks, 'qty'),
609
+ 'vwap': None,
610
+ 'open': self.safe_string(ticker, 'first'),
611
+ 'close': last,
612
+ 'last': last,
613
+ 'previousClose': None,
614
+ 'change': None,
615
+ 'percentage': None,
616
+ 'average': None,
617
+ 'baseVolume': self.safe_string(ticker, 'target_volume'),
618
+ 'quoteVolume': self.safe_string(ticker, 'quote_volume'),
619
+ 'info': ticker,
620
+ }, market)
621
+
622
+ def parse_trade(self, trade: dict, market: Market = None) -> Trade:
623
+ #
624
+ # fetchTrades(public)
625
+ #
626
+ # {
627
+ # "id": "1701075265708001",
628
+ # "timestamp": 1701075265708,
629
+ # "price": "50020000",
630
+ # "qty": "0.00155177",
631
+ # "is_seller_maker": False
632
+ # }
633
+ #
634
+ # fetchMyTrades(private)
635
+ #
636
+ # {
637
+ # "timestamp": "1416561032",
638
+ # "price": "419000.0",
639
+ # "type": "bid",
640
+ # "qty": "0.001",
641
+ # "feeRate": "-0.0015",
642
+ # "fee": "-0.0000015",
643
+ # "orderId": "E84A1AC2-8088-4FA0-B093-A3BCDB9B3C85"
644
+ # }
645
+ #
646
+ timestamp = self.safe_integer(trade, 'timestamp')
647
+ market = self.safe_market(None, market)
648
+ isSellerMaker = self.safe_value(trade, 'is_seller_maker')
649
+ side = None
650
+ if isSellerMaker is not None:
651
+ side = 'sell' if isSellerMaker else 'buy'
652
+ priceString = self.safe_string(trade, 'price')
653
+ amountString = self.safe_string(trade, 'qty')
654
+ orderId = self.safe_string(trade, 'orderId')
655
+ feeCostString = self.safe_string(trade, 'fee')
656
+ fee = None
657
+ if feeCostString is not None:
658
+ feeCostString = Precise.string_abs(feeCostString)
659
+ feeRateString = self.safe_string(trade, 'feeRate')
660
+ feeRateString = Precise.string_abs(feeRateString)
661
+ feeCurrencyCode = market['quote'] if (side == 'sell') else market['base']
662
+ fee = {
663
+ 'cost': feeCostString,
664
+ 'currency': feeCurrencyCode,
665
+ 'rate': feeRateString,
666
+ }
667
+ return self.safe_trade({
668
+ 'id': self.safe_string(trade, 'id'),
669
+ 'info': trade,
670
+ 'timestamp': timestamp,
671
+ 'datetime': self.iso8601(timestamp),
672
+ 'order': orderId,
673
+ 'symbol': market['symbol'],
674
+ 'type': None,
675
+ 'side': side,
676
+ 'takerOrMaker': None,
677
+ 'price': priceString,
678
+ 'amount': amountString,
679
+ 'cost': None,
680
+ 'fee': fee,
681
+ }, market)
682
+
683
+ async def fetch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
684
+ """
685
+ get the list of most recent trades for a particular symbol
686
+ :see: https://docs.coinone.co.kr/v1.0/reference/recent-completed-orders
687
+ :param str symbol: unified symbol of the market to fetch trades for
688
+ :param int [since]: timestamp in ms of the earliest trade to fetch
689
+ :param int [limit]: the maximum amount of trades to fetch
690
+ :param dict [params]: extra parameters specific to the exchange API endpoint
691
+ :returns Trade[]: a list of `trade structures <https://docs.ccxt.com/#/?id=public-trades>`
692
+ """
693
+ await self.load_markets()
694
+ market = self.market(symbol)
695
+ request: dict = {
696
+ 'quote_currency': market['quote'],
697
+ 'target_currency': market['base'],
698
+ }
699
+ if limit is not None:
700
+ request['size'] = min(limit, 200)
701
+ response = await self.v2PublicGetTradesQuoteCurrencyTargetCurrency(self.extend(request, params))
702
+ #
703
+ # {
704
+ # "result": "success",
705
+ # "error_code": "0",
706
+ # "server_time": 1701075315771,
707
+ # "quote_currency": "KRW",
708
+ # "target_currency": "BTC",
709
+ # "transactions": [
710
+ # {
711
+ # "id": "1701075265708001",
712
+ # "timestamp": 1701075265708,
713
+ # "price": "50020000",
714
+ # "qty": "0.00155177",
715
+ # "is_seller_maker": False
716
+ # }
717
+ # ]
718
+ # }
719
+ #
720
+ data = self.safe_list(response, 'transactions', [])
721
+ return self.parse_trades(data, market, since, limit)
722
+
723
+ async def create_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={}):
724
+ """
725
+ create a trade order
726
+ :see: https://doc.coinone.co.kr/#tag/Order-V2/operation/v2_order_limit_buy
727
+ :see: https://doc.coinone.co.kr/#tag/Order-V2/operation/v2_order_limit_sell
728
+ :param str symbol: unified symbol of the market to create an order in
729
+ :param str type: must be 'limit'
730
+ :param str side: 'buy' or 'sell'
731
+ :param float amount: how much of currency you want to trade in units of base currency
732
+ :param float [price]: the price at which the order is to be fullfilled, in units of the quote currency, ignored in market orders
733
+ :param dict [params]: extra parameters specific to the exchange API endpoint
734
+ :returns dict: an `order structure <https://docs.ccxt.com/#/?id=order-structure>`
735
+ """
736
+ if type != 'limit':
737
+ raise ExchangeError(self.id + ' createOrder() allows limit orders only')
738
+ await self.load_markets()
739
+ market = self.market(symbol)
740
+ request: dict = {
741
+ 'price': price,
742
+ 'currency': market['id'],
743
+ 'qty': amount,
744
+ }
745
+ method = 'privatePostOrder' + self.capitalize(type) + self.capitalize(side)
746
+ response = await getattr(self, method)(self.extend(request, params))
747
+ #
748
+ # {
749
+ # "result": "success",
750
+ # "errorCode": "0",
751
+ # "orderId": "8a82c561-40b4-4cb3-9bc0-9ac9ffc1d63b"
752
+ # }
753
+ #
754
+ return self.parse_order(response, market)
755
+
756
+ async def fetch_order(self, id: str, symbol: Str = None, params={}):
757
+ """
758
+ fetches information on an order made by the user
759
+ :param str symbol: unified symbol of the market the order was made in
760
+ :param dict [params]: extra parameters specific to the exchange API endpoint
761
+ :returns dict: An `order structure <https://docs.ccxt.com/#/?id=order-structure>`
762
+ """
763
+ if symbol is None:
764
+ raise ArgumentsRequired(self.id + ' fetchOrder() requires a symbol argument')
765
+ await self.load_markets()
766
+ market = self.market(symbol)
767
+ request: dict = {
768
+ 'order_id': id,
769
+ 'currency': market['id'],
770
+ }
771
+ response = await self.v2PrivatePostOrderQueryOrder(self.extend(request, params))
772
+ #
773
+ # {
774
+ # "result": "success",
775
+ # "errorCode": "0",
776
+ # "orderId": "0e3019f2-1e4d-11e9-9ec7-00e04c3600d7",
777
+ # "baseCurrency": "KRW",
778
+ # "targetCurrency": "BTC",
779
+ # "price": "10011000.0",
780
+ # "originalQty": "3.0",
781
+ # "executedQty": "0.62",
782
+ # "canceledQty": "1.125",
783
+ # "remainQty": "1.255",
784
+ # "status": "partially_filled",
785
+ # "side": "bid",
786
+ # "orderedAt": 1499340941,
787
+ # "updatedAt": 1499341142,
788
+ # "feeRate": "0.002",
789
+ # "fee": "0.00124",
790
+ # "averageExecutedPrice": "10011000.0"
791
+ # }
792
+ #
793
+ return self.parse_order(response, market)
794
+
795
+ def parse_order_status(self, status: Str):
796
+ statuses: dict = {
797
+ 'live': 'open',
798
+ 'partially_filled': 'open',
799
+ 'partially_canceled': 'open',
800
+ 'filled': 'closed',
801
+ 'canceled': 'canceled',
802
+ }
803
+ return self.safe_string(statuses, status, status)
804
+
805
+ def parse_order(self, order: dict, market: Market = None) -> Order:
806
+ #
807
+ # createOrder
808
+ #
809
+ # {
810
+ # "result": "success",
811
+ # "errorCode": "0",
812
+ # "orderId": "8a82c561-40b4-4cb3-9bc0-9ac9ffc1d63b"
813
+ # }
814
+ #
815
+ # fetchOrder
816
+ #
817
+ # {
818
+ # "result": "success",
819
+ # "errorCode": "0",
820
+ # "orderId": "0e3019f2-1e4d-11e9-9ec7-00e04c3600d7",
821
+ # "baseCurrency": "KRW",
822
+ # "targetCurrency": "BTC",
823
+ # "price": "10011000.0",
824
+ # "originalQty": "3.0",
825
+ # "executedQty": "0.62",
826
+ # "canceledQty": "1.125",
827
+ # "remainQty": "1.255",
828
+ # "status": "partially_filled",
829
+ # "side": "bid",
830
+ # "orderedAt": 1499340941,
831
+ # "updatedAt": 1499341142,
832
+ # "feeRate": "0.002",
833
+ # "fee": "0.00124",
834
+ # "averageExecutedPrice": "10011000.0"
835
+ # }
836
+ #
837
+ # fetchOpenOrders
838
+ #
839
+ # {
840
+ # "index": "0",
841
+ # "orderId": "68665943-1eb5-4e4b-9d76-845fc54f5489",
842
+ # "timestamp": "1449037367",
843
+ # "price": "444000.0",
844
+ # "qty": "0.3456",
845
+ # "type": "ask",
846
+ # "feeRate": "-0.0015"
847
+ # }
848
+ #
849
+ id = self.safe_string(order, 'orderId')
850
+ baseId = self.safe_string(order, 'baseCurrency')
851
+ quoteId = self.safe_string(order, 'targetCurrency')
852
+ base = None
853
+ quote = None
854
+ if baseId is not None:
855
+ base = self.safe_currency_code(baseId)
856
+ if quoteId is not None:
857
+ quote = self.safe_currency_code(quoteId)
858
+ symbol = None
859
+ if (base is not None) and (quote is not None):
860
+ symbol = base + '/' + quote
861
+ market = self.safe_market(symbol, market, '/')
862
+ timestamp = self.safe_timestamp_2(order, 'timestamp', 'updatedAt')
863
+ side = self.safe_string_2(order, 'type', 'side')
864
+ if side == 'ask':
865
+ side = 'sell'
866
+ elif side == 'bid':
867
+ side = 'buy'
868
+ remainingString = self.safe_string(order, 'remainQty')
869
+ amountString = self.safe_string_2(order, 'originalQty', 'qty')
870
+ status = self.safe_string(order, 'status')
871
+ # https://github.com/ccxt/ccxt/pull/7067
872
+ if status == 'live':
873
+ if (remainingString is not None) and (amountString is not None):
874
+ isLessThan = Precise.string_lt(remainingString, amountString)
875
+ if isLessThan:
876
+ status = 'canceled'
877
+ status = self.parse_order_status(status)
878
+ fee = None
879
+ feeCostString = self.safe_string(order, 'fee')
880
+ if feeCostString is not None:
881
+ feeCurrencyCode = quote if (side == 'sell') else base
882
+ fee = {
883
+ 'cost': feeCostString,
884
+ 'rate': self.safe_string(order, 'feeRate'),
885
+ 'currency': feeCurrencyCode,
886
+ }
887
+ return self.safe_order({
888
+ 'info': order,
889
+ 'id': id,
890
+ 'clientOrderId': None,
891
+ 'timestamp': timestamp,
892
+ 'datetime': self.iso8601(timestamp),
893
+ 'lastTradeTimestamp': None,
894
+ 'symbol': symbol,
895
+ 'type': 'limit',
896
+ 'timeInForce': None,
897
+ 'postOnly': None,
898
+ 'side': side,
899
+ 'price': self.safe_string(order, 'price'),
900
+ 'stopPrice': None,
901
+ 'triggerPrice': None,
902
+ 'cost': None,
903
+ 'average': self.safe_string(order, 'averageExecutedPrice'),
904
+ 'amount': amountString,
905
+ 'filled': self.safe_string(order, 'executedQty'),
906
+ 'remaining': remainingString,
907
+ 'status': status,
908
+ 'fee': fee,
909
+ 'trades': None,
910
+ }, market)
911
+
912
+ async def fetch_open_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
913
+ """
914
+ fetch all unfilled currently open orders
915
+ :param str symbol: unified market symbol
916
+ :param int [since]: the earliest time in ms to fetch open orders for
917
+ :param int [limit]: the maximum number of open orders structures to retrieve
918
+ :param dict [params]: extra parameters specific to the exchange API endpoint
919
+ :returns Order[]: a list of `order structures <https://docs.ccxt.com/#/?id=order-structure>`
920
+ """
921
+ # The returned amount might not be same ordered amount. If an order is partially filled, the returned amount means the remaining amount.
922
+ # For the same reason, the returned amount and remaining are always same, and the returned filled and cost are always zero.
923
+ if symbol is None:
924
+ raise ExchangeError(self.id + ' fetchOpenOrders() allows fetching closed orders with a specific symbol')
925
+ await self.load_markets()
926
+ market = self.market(symbol)
927
+ request: dict = {
928
+ 'currency': market['id'],
929
+ }
930
+ response = await self.privatePostOrderLimitOrders(self.extend(request, params))
931
+ #
932
+ # {
933
+ # "result": "success",
934
+ # "errorCode": "0",
935
+ # "limitOrders": [
936
+ # {
937
+ # "index": "0",
938
+ # "orderId": "68665943-1eb5-4e4b-9d76-845fc54f5489",
939
+ # "timestamp": "1449037367",
940
+ # "price": "444000.0",
941
+ # "qty": "0.3456",
942
+ # "type": "ask",
943
+ # "feeRate": "-0.0015"
944
+ # }
945
+ # ]
946
+ # }
947
+ #
948
+ limitOrders = self.safe_list(response, 'limitOrders', [])
949
+ return self.parse_orders(limitOrders, market, since, limit)
950
+
951
+ async def fetch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
952
+ """
953
+ fetch all trades made by the user
954
+ :param str symbol: unified market symbol
955
+ :param int [since]: the earliest time in ms to fetch trades for
956
+ :param int [limit]: the maximum number of trades structures to retrieve
957
+ :param dict [params]: extra parameters specific to the exchange API endpoint
958
+ :returns Trade[]: a list of `trade structures <https://docs.ccxt.com/#/?id=trade-structure>`
959
+ """
960
+ if symbol is None:
961
+ raise ArgumentsRequired(self.id + ' fetchMyTrades() requires a symbol argument')
962
+ await self.load_markets()
963
+ market = self.market(symbol)
964
+ request: dict = {
965
+ 'currency': market['id'],
966
+ }
967
+ response = await self.v2PrivatePostOrderCompleteOrders(self.extend(request, params))
968
+ #
969
+ # despite the name of the endpoint it returns trades which may have a duplicate orderId
970
+ # https://github.com/ccxt/ccxt/pull/7067
971
+ #
972
+ # {
973
+ # "result": "success",
974
+ # "errorCode": "0",
975
+ # "completeOrders": [
976
+ # {
977
+ # "timestamp": "1416561032",
978
+ # "price": "419000.0",
979
+ # "type": "bid",
980
+ # "qty": "0.001",
981
+ # "feeRate": "-0.0015",
982
+ # "fee": "-0.0000015",
983
+ # "orderId": "E84A1AC2-8088-4FA0-B093-A3BCDB9B3C85"
984
+ # }
985
+ # ]
986
+ # }
987
+ #
988
+ completeOrders = self.safe_list(response, 'completeOrders', [])
989
+ return self.parse_trades(completeOrders, market, since, limit)
990
+
991
+ async def cancel_order(self, id: str, symbol: Str = None, params={}):
992
+ """
993
+ cancels an open order
994
+ :param str id: order id
995
+ :param str symbol: unified symbol of the market the order was made in
996
+ :param dict [params]: extra parameters specific to the exchange API endpoint
997
+ :returns dict: An `order structure <https://docs.ccxt.com/#/?id=order-structure>`
998
+ """
999
+ if symbol is None:
1000
+ # eslint-disable-next-line quotes
1001
+ raise ArgumentsRequired(self.id + " cancelOrder() requires a symbol argument. To cancel the order, pass a symbol argument and {'price': 12345, 'qty': 1.2345, 'is_ask': 0} in the params argument of cancelOrder.")
1002
+ price = self.safe_number(params, 'price')
1003
+ qty = self.safe_number(params, 'qty')
1004
+ isAsk = self.safe_integer(params, 'is_ask')
1005
+ if (price is None) or (qty is None) or (isAsk is None):
1006
+ # eslint-disable-next-line quotes
1007
+ raise ArgumentsRequired(self.id + " cancelOrder() requires {'price': 12345, 'qty': 1.2345, 'is_ask': 0} in the params argument.")
1008
+ await self.load_markets()
1009
+ request: dict = {
1010
+ 'order_id': id,
1011
+ 'price': price,
1012
+ 'qty': qty,
1013
+ 'is_ask': isAsk,
1014
+ 'currency': self.market_id(symbol),
1015
+ }
1016
+ response = await self.v2PrivatePostOrderCancel(self.extend(request, params))
1017
+ #
1018
+ # {
1019
+ # "result": "success",
1020
+ # "errorCode": "0"
1021
+ # }
1022
+ #
1023
+ return self.safe_order(response)
1024
+
1025
+ async def fetch_deposit_addresses(self, codes: Strings = None, params={}):
1026
+ """
1027
+ fetch deposit addresses for multiple currencies and chain types
1028
+ :param str[]|None codes: list of unified currency codes, default is None
1029
+ :param dict [params]: extra parameters specific to the exchange API endpoint
1030
+ :returns dict: a list of `address structures <https://docs.ccxt.com/#/?id=address-structure>`
1031
+ """
1032
+ await self.load_markets()
1033
+ response = await self.v2PrivatePostAccountDepositAddress(params)
1034
+ #
1035
+ # {
1036
+ # "result": "success",
1037
+ # "errorCode": "0",
1038
+ # "walletAddress": {
1039
+ # "matic": null,
1040
+ # "btc": "mnobqu4i6qMCJWDpf5UimRmr8JCvZ8FLcN",
1041
+ # "xrp": null,
1042
+ # "xrp_tag": "-1",
1043
+ # "kava": null,
1044
+ # "kava_memo": null,
1045
+ # }
1046
+ # }
1047
+ #
1048
+ walletAddress = self.safe_value(response, 'walletAddress', {})
1049
+ keys = list(walletAddress.keys())
1050
+ result: dict = {}
1051
+ for i in range(0, len(keys)):
1052
+ key = keys[i]
1053
+ value = walletAddress[key]
1054
+ if (not value) or (value == '-1'):
1055
+ continue
1056
+ parts = key.split('_')
1057
+ currencyId = self.safe_value(parts, 0)
1058
+ secondPart = self.safe_value(parts, 1)
1059
+ code = self.safe_currency_code(currencyId)
1060
+ depositAddress = self.safe_value(result, code)
1061
+ if depositAddress is None:
1062
+ depositAddress = {
1063
+ 'currency': code,
1064
+ 'address': None,
1065
+ 'tag': None,
1066
+ 'info': value,
1067
+ }
1068
+ address = self.safe_string(depositAddress, 'address', value)
1069
+ self.check_address(address)
1070
+ depositAddress['address'] = address
1071
+ depositAddress['info'] = address
1072
+ if (secondPart == 'tag' or secondPart == 'memo'):
1073
+ depositAddress['tag'] = value
1074
+ depositAddress['info'] = [address, value]
1075
+ result[code] = depositAddress
1076
+ return result
1077
+
1078
+ def sign(self, path, api='public', method='GET', params={}, headers=None, body=None):
1079
+ request = self.implode_params(path, params)
1080
+ query = self.omit(params, self.extract_params(path))
1081
+ url = self.urls['api']['rest'] + '/'
1082
+ if api == 'v2Public':
1083
+ url = self.urls['api']['v2Public'] + '/'
1084
+ api = 'public'
1085
+ elif api == 'v2Private':
1086
+ url = self.urls['api']['v2Private'] + '/'
1087
+ elif api == 'v2_1Private':
1088
+ url = self.urls['api']['v2_1Private'] + '/'
1089
+ if api == 'public':
1090
+ url += request
1091
+ if query:
1092
+ url += '?' + self.urlencode(query)
1093
+ else:
1094
+ self.check_required_credentials()
1095
+ url += request
1096
+ nonce = str(self.nonce())
1097
+ json = self.json(self.extend({
1098
+ 'access_token': self.apiKey,
1099
+ 'nonce': nonce,
1100
+ }, params))
1101
+ payload = self.string_to_base64(json)
1102
+ body = payload
1103
+ secret = self.secret.upper()
1104
+ signature = self.hmac(self.encode(payload), self.encode(secret), hashlib.sha512)
1105
+ headers = {
1106
+ 'Content-Type': 'application/json',
1107
+ 'X-COINONE-PAYLOAD': payload,
1108
+ 'X-COINONE-SIGNATURE': signature,
1109
+ }
1110
+ return {'url': url, 'method': method, 'body': body, 'headers': headers}
1111
+
1112
+ def handle_errors(self, code: int, reason: str, url: str, method: str, headers: dict, body: str, response, requestHeaders, requestBody):
1113
+ if response is None:
1114
+ return None
1115
+ if 'result' in response:
1116
+ result = response['result']
1117
+ if result != 'success':
1118
+ #
1119
+ # { "errorCode": "405", "status": "maintenance", "result": "error"}
1120
+ #
1121
+ errorCode = self.safe_string(response, 'errorCode')
1122
+ feedback = self.id + ' ' + body
1123
+ self.throw_exactly_matched_exception(self.exceptions, errorCode, feedback)
1124
+ raise ExchangeError(feedback)
1125
+ else:
1126
+ raise ExchangeError(self.id + ' ' + body)
1127
+ return None