ccxt 4.2.11 → 4.2.13

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 (392) hide show
  1. package/README.md +5 -5
  2. package/build.sh +2 -2
  3. package/dist/ccxt.browser.js +1347 -490
  4. package/dist/ccxt.browser.min.js +3 -3
  5. package/dist/cjs/_virtual/agent.js +7 -0
  6. package/dist/cjs/_virtual/parse-proxy-response.js +7 -0
  7. package/dist/cjs/_virtual/promisify.js +7 -0
  8. package/dist/cjs/ccxt.js +1 -1
  9. package/dist/cjs/js/ccxt.js +474 -0
  10. package/dist/cjs/js/src/abstract/ace.js +9 -0
  11. package/dist/cjs/js/src/abstract/alpaca.js +9 -0
  12. package/dist/cjs/js/src/abstract/ascendex.js +9 -0
  13. package/dist/cjs/js/src/abstract/bigone.js +9 -0
  14. package/dist/cjs/js/src/abstract/binance.js +9 -0
  15. package/dist/cjs/js/src/abstract/bingx.js +9 -0
  16. package/dist/cjs/js/src/abstract/bit2c.js +9 -0
  17. package/dist/cjs/js/src/abstract/bitbank.js +9 -0
  18. package/dist/cjs/js/src/abstract/bitbns.js +9 -0
  19. package/dist/cjs/js/src/abstract/bitfinex.js +9 -0
  20. package/dist/cjs/js/src/abstract/bitfinex2.js +9 -0
  21. package/dist/cjs/js/src/abstract/bitflyer.js +9 -0
  22. package/dist/cjs/js/src/abstract/bitforex.js +9 -0
  23. package/dist/cjs/js/src/abstract/bitget.js +9 -0
  24. package/dist/cjs/js/src/abstract/bithumb.js +9 -0
  25. package/dist/cjs/js/src/abstract/bitmart.js +9 -0
  26. package/dist/cjs/js/src/abstract/bitmex.js +9 -0
  27. package/dist/cjs/js/src/abstract/bitopro.js +9 -0
  28. package/dist/cjs/js/src/abstract/bitpanda.js +9 -0
  29. package/dist/cjs/js/src/abstract/bitrue.js +9 -0
  30. package/dist/cjs/js/src/abstract/bitso.js +9 -0
  31. package/dist/cjs/js/src/abstract/bitstamp.js +9 -0
  32. package/dist/cjs/js/src/abstract/bitteam.js +9 -0
  33. package/dist/cjs/js/src/abstract/bitvavo.js +9 -0
  34. package/dist/cjs/js/src/abstract/bl3p.js +9 -0
  35. package/dist/cjs/js/src/abstract/blockchaincom.js +9 -0
  36. package/dist/cjs/js/src/abstract/btcalpha.js +9 -0
  37. package/dist/cjs/js/src/abstract/btcbox.js +9 -0
  38. package/dist/cjs/js/src/abstract/btcmarkets.js +9 -0
  39. package/dist/cjs/js/src/abstract/btcturk.js +9 -0
  40. package/dist/cjs/js/src/abstract/bybit.js +9 -0
  41. package/dist/cjs/js/src/abstract/cex.js +9 -0
  42. package/dist/cjs/js/src/abstract/coinbase.js +9 -0
  43. package/dist/cjs/js/src/abstract/coinbasepro.js +9 -0
  44. package/dist/cjs/js/src/abstract/coincheck.js +9 -0
  45. package/dist/cjs/js/src/abstract/coinex.js +9 -0
  46. package/dist/cjs/js/src/abstract/coinlist.js +9 -0
  47. package/dist/cjs/js/src/abstract/coinmate.js +9 -0
  48. package/dist/cjs/js/src/abstract/coinone.js +9 -0
  49. package/dist/cjs/js/src/abstract/coinsph.js +9 -0
  50. package/dist/cjs/js/src/abstract/coinspot.js +9 -0
  51. package/dist/cjs/js/src/abstract/cryptocom.js +9 -0
  52. package/dist/cjs/js/src/abstract/currencycom.js +9 -0
  53. package/dist/cjs/js/src/abstract/delta.js +9 -0
  54. package/dist/cjs/js/src/abstract/deribit.js +9 -0
  55. package/dist/cjs/js/src/abstract/digifinex.js +9 -0
  56. package/dist/cjs/js/src/abstract/exmo.js +9 -0
  57. package/dist/cjs/js/src/abstract/gate.js +9 -0
  58. package/dist/cjs/js/src/abstract/gemini.js +9 -0
  59. package/dist/cjs/js/src/abstract/hitbtc.js +9 -0
  60. package/dist/cjs/js/src/abstract/hollaex.js +9 -0
  61. package/dist/cjs/js/src/abstract/htx.js +9 -0
  62. package/dist/cjs/js/src/abstract/huobijp.js +9 -0
  63. package/dist/cjs/js/src/abstract/idex.js +9 -0
  64. package/dist/cjs/js/src/abstract/independentreserve.js +9 -0
  65. package/dist/cjs/js/src/abstract/indodax.js +9 -0
  66. package/dist/cjs/js/src/abstract/kraken.js +9 -0
  67. package/dist/cjs/js/src/abstract/krakenfutures.js +9 -0
  68. package/dist/cjs/js/src/abstract/kucoin.js +9 -0
  69. package/dist/cjs/js/src/abstract/kucoinfutures.js +9 -0
  70. package/dist/cjs/js/src/abstract/kuna.js +9 -0
  71. package/dist/cjs/js/src/abstract/latoken.js +9 -0
  72. package/dist/cjs/js/src/abstract/lbank.js +9 -0
  73. package/dist/cjs/js/src/abstract/luno.js +9 -0
  74. package/dist/cjs/js/src/abstract/lykke.js +9 -0
  75. package/dist/cjs/js/src/abstract/mercado.js +9 -0
  76. package/dist/cjs/js/src/abstract/mexc.js +9 -0
  77. package/dist/cjs/js/src/abstract/ndax.js +9 -0
  78. package/dist/cjs/js/src/abstract/novadax.js +9 -0
  79. package/dist/cjs/js/src/abstract/oceanex.js +9 -0
  80. package/dist/cjs/js/src/abstract/okcoin.js +9 -0
  81. package/dist/cjs/js/src/abstract/okx.js +9 -0
  82. package/dist/cjs/js/src/abstract/p2b.js +9 -0
  83. package/dist/cjs/js/src/abstract/paymium.js +9 -0
  84. package/dist/cjs/js/src/abstract/phemex.js +9 -0
  85. package/dist/cjs/js/src/abstract/poloniex.js +9 -0
  86. package/dist/cjs/js/src/abstract/poloniexfutures.js +9 -0
  87. package/dist/cjs/js/src/abstract/probit.js +9 -0
  88. package/dist/cjs/js/src/abstract/timex.js +9 -0
  89. package/dist/cjs/js/src/abstract/tokocrypto.js +9 -0
  90. package/dist/cjs/js/src/abstract/upbit.js +9 -0
  91. package/dist/cjs/js/src/abstract/wavesexchange.js +9 -0
  92. package/dist/cjs/js/src/abstract/wazirx.js +9 -0
  93. package/dist/cjs/js/src/abstract/whitebit.js +9 -0
  94. package/dist/cjs/js/src/abstract/woo.js +9 -0
  95. package/dist/cjs/js/src/abstract/yobit.js +9 -0
  96. package/dist/cjs/js/src/abstract/zaif.js +9 -0
  97. package/dist/cjs/js/src/abstract/zonda.js +9 -0
  98. package/dist/cjs/js/src/ace.js +1058 -0
  99. package/dist/cjs/js/src/alpaca.js +1125 -0
  100. package/dist/cjs/js/src/ascendex.js +3360 -0
  101. package/dist/cjs/js/src/base/Exchange.js +5110 -0
  102. package/dist/cjs/js/src/base/Precise.js +263 -0
  103. package/dist/cjs/js/src/base/errors.js +299 -0
  104. package/dist/cjs/js/src/base/functions/crypto.js +78 -0
  105. package/dist/cjs/js/src/base/functions/encode.js +44 -0
  106. package/dist/cjs/js/src/base/functions/generic.js +193 -0
  107. package/dist/cjs/js/src/base/functions/misc.js +96 -0
  108. package/dist/cjs/js/src/base/functions/number.js +297 -0
  109. package/dist/cjs/js/src/base/functions/platform.js +28 -0
  110. package/dist/cjs/js/src/base/functions/rsa.js +34 -0
  111. package/dist/cjs/js/src/base/functions/string.js +48 -0
  112. package/dist/cjs/js/src/base/functions/throttle.js +66 -0
  113. package/dist/cjs/js/src/base/functions/time.js +187 -0
  114. package/dist/cjs/js/src/base/functions/totp.js +24 -0
  115. package/dist/cjs/js/src/base/functions/type.js +162 -0
  116. package/dist/cjs/js/src/base/functions.js +157 -0
  117. package/dist/cjs/js/src/base/ws/Cache.js +254 -0
  118. package/dist/cjs/js/src/base/ws/Client.js +299 -0
  119. package/dist/cjs/js/src/base/ws/Future.js +34 -0
  120. package/dist/cjs/js/src/base/ws/OrderBook.js +107 -0
  121. package/dist/cjs/js/src/base/ws/OrderBookSide.js +281 -0
  122. package/dist/cjs/js/src/base/ws/WsClient.js +69 -0
  123. package/dist/cjs/js/src/bequant.js +33 -0
  124. package/dist/cjs/js/src/bigone.js +2209 -0
  125. package/dist/cjs/js/src/binance.js +9736 -0
  126. package/dist/cjs/js/src/binancecoinm.js +45 -0
  127. package/dist/cjs/js/src/binanceus.js +84 -0
  128. package/dist/cjs/js/src/binanceusdm.js +58 -0
  129. package/dist/cjs/js/src/bingx.js +3807 -0
  130. package/dist/cjs/js/src/bit2c.js +916 -0
  131. package/dist/cjs/js/src/bitbank.js +1000 -0
  132. package/dist/cjs/js/src/bitbay.js +17 -0
  133. package/dist/cjs/js/src/bitbns.js +1220 -0
  134. package/dist/cjs/js/src/bitcoincom.js +17 -0
  135. package/dist/cjs/js/src/bitfinex.js +1670 -0
  136. package/dist/cjs/js/src/bitfinex2.js +2990 -0
  137. package/dist/cjs/js/src/bitflyer.js +1045 -0
  138. package/dist/cjs/js/src/bitforex.js +852 -0
  139. package/dist/cjs/js/src/bitget.js +8291 -0
  140. package/dist/cjs/js/src/bithumb.js +1090 -0
  141. package/dist/cjs/js/src/bitmart.js +4454 -0
  142. package/dist/cjs/js/src/bitmex.js +2884 -0
  143. package/dist/cjs/js/src/bitopro.js +1724 -0
  144. package/dist/cjs/js/src/bitpanda.js +2002 -0
  145. package/dist/cjs/js/src/bitrue.js +3253 -0
  146. package/dist/cjs/js/src/bitso.js +1753 -0
  147. package/dist/cjs/js/src/bitstamp.js +2188 -0
  148. package/dist/cjs/js/src/bitteam.js +2309 -0
  149. package/dist/cjs/js/src/bitvavo.js +1968 -0
  150. package/dist/cjs/js/src/bl3p.js +447 -0
  151. package/dist/cjs/js/src/blockchaincom.js +1160 -0
  152. package/dist/cjs/js/src/btcalpha.js +929 -0
  153. package/dist/cjs/js/src/btcbox.js +565 -0
  154. package/dist/cjs/js/src/btcmarkets.js +1237 -0
  155. package/dist/cjs/js/src/btcturk.js +929 -0
  156. package/dist/cjs/js/src/bybit.js +7646 -0
  157. package/dist/cjs/js/src/cex.js +1693 -0
  158. package/dist/cjs/js/src/coinbase.js +3424 -0
  159. package/dist/cjs/js/src/coinbasepro.js +1866 -0
  160. package/dist/cjs/js/src/coincheck.js +843 -0
  161. package/dist/cjs/js/src/coinex.js +5414 -0
  162. package/dist/cjs/js/src/coinlist.js +2329 -0
  163. package/dist/cjs/js/src/coinmate.js +989 -0
  164. package/dist/cjs/js/src/coinone.js +1185 -0
  165. package/dist/cjs/js/src/coinsph.js +1933 -0
  166. package/dist/cjs/js/src/coinspot.js +548 -0
  167. package/dist/cjs/js/src/cryptocom.js +3007 -0
  168. package/dist/cjs/js/src/currencycom.js +2015 -0
  169. package/dist/cjs/js/src/delta.js +3256 -0
  170. package/dist/cjs/js/src/deribit.js +3306 -0
  171. package/dist/cjs/js/src/digifinex.js +4307 -0
  172. package/dist/cjs/js/src/exmo.js +2645 -0
  173. package/dist/cjs/js/src/fmfwio.js +34 -0
  174. package/dist/cjs/js/src/gate.js +7072 -0
  175. package/dist/cjs/js/src/gateio.js +16 -0
  176. package/dist/cjs/js/src/gemini.js +1801 -0
  177. package/dist/cjs/js/src/hitbtc.js +3660 -0
  178. package/dist/cjs/js/src/hitbtc3.js +19 -0
  179. package/dist/cjs/js/src/hollaex.js +1882 -0
  180. package/dist/cjs/js/src/htx.js +9049 -0
  181. package/dist/cjs/js/src/huobi.js +16 -0
  182. package/dist/cjs/js/src/huobijp.js +1918 -0
  183. package/dist/cjs/js/src/idex.js +1770 -0
  184. package/dist/cjs/js/src/independentreserve.js +761 -0
  185. package/dist/cjs/js/src/indodax.js +1069 -0
  186. package/dist/cjs/js/src/kraken.js +2857 -0
  187. package/dist/cjs/js/src/krakenfutures.js +2407 -0
  188. package/dist/cjs/js/src/kucoin.js +4489 -0
  189. package/dist/cjs/js/src/kucoinfutures.js +2475 -0
  190. package/dist/cjs/js/src/kuna.js +1949 -0
  191. package/dist/cjs/js/src/latoken.js +1729 -0
  192. package/dist/cjs/js/src/lbank.js +2851 -0
  193. package/dist/cjs/js/src/luno.js +1044 -0
  194. package/dist/cjs/js/src/lykke.js +1303 -0
  195. package/dist/cjs/js/src/mercado.js +897 -0
  196. package/dist/cjs/js/src/mexc.js +5407 -0
  197. package/dist/cjs/js/src/ndax.js +2450 -0
  198. package/dist/cjs/js/src/novadax.js +1556 -0
  199. package/dist/cjs/js/src/oceanex.js +964 -0
  200. package/dist/cjs/js/src/okcoin.js +3115 -0
  201. package/dist/cjs/js/src/okx.js +7330 -0
  202. package/dist/cjs/js/src/p2b.js +1243 -0
  203. package/dist/cjs/js/src/paymium.js +597 -0
  204. package/dist/cjs/js/src/phemex.js +4722 -0
  205. package/dist/cjs/js/src/poloniex.js +2356 -0
  206. package/dist/cjs/js/src/poloniexfutures.js +1794 -0
  207. package/dist/cjs/js/src/pro/alpaca.js +714 -0
  208. package/dist/cjs/js/src/pro/ascendex.js +957 -0
  209. package/dist/cjs/js/src/pro/bequant.js +33 -0
  210. package/dist/cjs/js/src/pro/binance.js +2796 -0
  211. package/dist/cjs/js/src/pro/binancecoinm.js +23 -0
  212. package/dist/cjs/js/src/pro/binanceus.js +51 -0
  213. package/dist/cjs/js/src/pro/binanceusdm.js +32 -0
  214. package/dist/cjs/js/src/pro/bingx.js +944 -0
  215. package/dist/cjs/js/src/pro/bitcoincom.js +29 -0
  216. package/dist/cjs/js/src/pro/bitfinex.js +672 -0
  217. package/dist/cjs/js/src/pro/bitfinex2.js +1159 -0
  218. package/dist/cjs/js/src/pro/bitget.js +1733 -0
  219. package/dist/cjs/js/src/pro/bitmart.js +1486 -0
  220. package/dist/cjs/js/src/pro/bitmex.js +1576 -0
  221. package/dist/cjs/js/src/pro/bitopro.js +327 -0
  222. package/dist/cjs/js/src/pro/bitpanda.js +1341 -0
  223. package/dist/cjs/js/src/pro/bitrue.js +462 -0
  224. package/dist/cjs/js/src/pro/bitstamp.js +547 -0
  225. package/dist/cjs/js/src/pro/bitvavo.js +704 -0
  226. package/dist/cjs/js/src/pro/blockchaincom.js +794 -0
  227. package/dist/cjs/js/src/pro/bybit.js +1843 -0
  228. package/dist/cjs/js/src/pro/cex.js +1510 -0
  229. package/dist/cjs/js/src/pro/coinbase.js +561 -0
  230. package/dist/cjs/js/src/pro/coinbasepro.js +968 -0
  231. package/dist/cjs/js/src/pro/coinex.js +1095 -0
  232. package/dist/cjs/js/src/pro/cryptocom.js +1020 -0
  233. package/dist/cjs/js/src/pro/currencycom.js +563 -0
  234. package/dist/cjs/js/src/pro/deribit.js +825 -0
  235. package/dist/cjs/js/src/pro/exmo.js +658 -0
  236. package/dist/cjs/js/src/pro/gate.js +1316 -0
  237. package/dist/cjs/js/src/pro/gateio.js +16 -0
  238. package/dist/cjs/js/src/pro/gemini.js +649 -0
  239. package/dist/cjs/js/src/pro/hitbtc.js +1293 -0
  240. package/dist/cjs/js/src/pro/hollaex.js +597 -0
  241. package/dist/cjs/js/src/pro/htx.js +2383 -0
  242. package/dist/cjs/js/src/pro/huobi.js +16 -0
  243. package/dist/cjs/js/src/pro/huobijp.js +606 -0
  244. package/dist/cjs/js/src/pro/idex.js +714 -0
  245. package/dist/cjs/js/src/pro/independentreserve.js +280 -0
  246. package/dist/cjs/js/src/pro/kraken.js +1364 -0
  247. package/dist/cjs/js/src/pro/krakenfutures.js +1500 -0
  248. package/dist/cjs/js/src/pro/kucoin.js +1052 -0
  249. package/dist/cjs/js/src/pro/kucoinfutures.js +981 -0
  250. package/dist/cjs/js/src/pro/luno.js +322 -0
  251. package/dist/cjs/js/src/pro/mexc.js +1170 -0
  252. package/dist/cjs/js/src/pro/ndax.js +545 -0
  253. package/dist/cjs/js/src/pro/okcoin.js +760 -0
  254. package/dist/cjs/js/src/pro/okx.js +1608 -0
  255. package/dist/cjs/js/src/pro/phemex.js +1511 -0
  256. package/dist/cjs/js/src/pro/poloniex.js +1253 -0
  257. package/dist/cjs/js/src/pro/poloniexfutures.js +1014 -0
  258. package/dist/cjs/js/src/pro/probit.js +586 -0
  259. package/dist/cjs/js/src/pro/upbit.js +234 -0
  260. package/dist/cjs/js/src/pro/wazirx.js +776 -0
  261. package/dist/cjs/js/src/pro/whitebit.js +927 -0
  262. package/dist/cjs/js/src/pro/woo.js +769 -0
  263. package/dist/cjs/js/src/probit.js +1867 -0
  264. package/dist/cjs/js/src/static_dependencies/fflake/browser.js +401 -0
  265. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +195 -0
  266. package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +308 -0
  267. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +554 -0
  268. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
  269. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
  270. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
  271. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +16 -0
  272. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1760 -0
  273. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +52 -0
  274. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +81 -0
  275. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +376 -0
  276. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +70 -0
  277. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1580 -0
  278. package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +74 -0
  279. package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +24 -0
  280. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +158 -0
  281. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +429 -0
  282. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +176 -0
  283. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +324 -0
  284. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +163 -0
  285. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +245 -0
  286. package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +1018 -0
  287. package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +383 -0
  288. package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +258 -0
  289. package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +53 -0
  290. package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +120 -0
  291. package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +69 -0
  292. package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +7 -0
  293. package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +83 -0
  294. package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +240 -0
  295. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +91 -0
  296. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +130 -0
  297. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +214 -0
  298. package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +239 -0
  299. package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +93 -0
  300. package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +354 -0
  301. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +16 -0
  302. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +20 -0
  303. package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +30 -0
  304. package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +239 -0
  305. package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +372 -0
  306. package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +273 -0
  307. package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +139 -0
  308. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +14 -0
  309. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +16 -0
  310. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +81 -0
  311. package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +292 -0
  312. package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +103 -0
  313. package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +140 -0
  314. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +175 -0
  315. package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
  316. package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +7 -0
  317. package/dist/cjs/js/src/static_dependencies/scure-base/index.js +383 -0
  318. package/dist/cjs/js/src/timex.js +1562 -0
  319. package/dist/cjs/js/src/tokocrypto.js +2542 -0
  320. package/dist/cjs/js/src/upbit.js +1844 -0
  321. package/dist/cjs/js/src/wavesexchange.js +2607 -0
  322. package/dist/cjs/js/src/wazirx.js +953 -0
  323. package/dist/cjs/js/src/whitebit.js +2309 -0
  324. package/dist/cjs/js/src/woo.js +2765 -0
  325. package/dist/cjs/js/src/yobit.js +1314 -0
  326. package/dist/cjs/js/src/zaif.js +736 -0
  327. package/dist/cjs/js/src/zonda.js +1883 -0
  328. package/js/ccxt.d.ts +1 -1
  329. package/js/ccxt.js +1 -1
  330. package/js/src/abstract/bigone.d.ts +18 -0
  331. package/js/src/abstract/binance.d.ts +2 -0
  332. package/js/src/abstract/binancecoinm.d.ts +2 -0
  333. package/js/src/abstract/binanceus.d.ts +2 -0
  334. package/js/src/abstract/binanceusdm.d.ts +2 -0
  335. package/js/src/abstract/bingx.d.ts +2 -0
  336. package/js/src/abstract/bybit.d.ts +1 -0
  337. package/js/src/abstract/gate.d.ts +11 -0
  338. package/js/src/abstract/gateio.d.ts +11 -0
  339. package/js/src/abstract/okx.d.ts +1 -0
  340. package/js/src/alpaca.js +18 -18
  341. package/js/src/base/Exchange.d.ts +5 -1
  342. package/js/src/base/Exchange.js +101 -12
  343. package/js/src/bigone.d.ts +3 -2
  344. package/js/src/bigone.js +429 -167
  345. package/js/src/binance.js +48 -34
  346. package/js/src/bingx.js +115 -38
  347. package/js/src/bitfinex.d.ts +2 -2
  348. package/js/src/bitfinex.js +2 -3
  349. package/js/src/bitget.js +33 -13
  350. package/js/src/bitmart.d.ts +2 -2
  351. package/js/src/bitmart.js +5 -5
  352. package/js/src/bitmex.js +1 -0
  353. package/js/src/bybit.js +2 -0
  354. package/js/src/coinbase.d.ts +26 -3
  355. package/js/src/coinbase.js +176 -26
  356. package/js/src/coinlist.js +3 -4
  357. package/js/src/coinone.js +1 -1
  358. package/js/src/coinsph.js +2 -3
  359. package/js/src/deribit.js +1 -0
  360. package/js/src/gate.d.ts +4 -4
  361. package/js/src/gate.js +96 -59
  362. package/js/src/gemini.js +1 -1
  363. package/js/src/hitbtc.d.ts +4 -4
  364. package/js/src/hitbtc.js +2 -3
  365. package/js/src/htx.d.ts +1 -0
  366. package/js/src/htx.js +29 -7
  367. package/js/src/huobijp.js +2 -3
  368. package/js/src/independentreserve.js +7 -5
  369. package/js/src/kraken.js +3 -6
  370. package/js/src/lbank.js +59 -33
  371. package/js/src/mexc.js +2 -1
  372. package/js/src/oceanex.js +1 -1
  373. package/js/src/okx.js +14 -3
  374. package/js/src/phemex.js +9 -2
  375. package/js/src/pro/binance.d.ts +2 -23
  376. package/js/src/pro/binance.js +58 -22
  377. package/js/src/pro/coinbase.d.ts +2 -2
  378. package/js/src/pro/coinbase.js +4 -1
  379. package/js/src/pro/coinbasepro.d.ts +2 -2
  380. package/js/src/pro/hitbtc.d.ts +2 -2
  381. package/js/src/pro/kraken.js +1 -1
  382. package/js/src/pro/okx.d.ts +1 -0
  383. package/js/src/pro/okx.js +52 -2
  384. package/js/src/pro/poloniex.d.ts +2 -2
  385. package/js/src/probit.js +4 -2
  386. package/js/src/upbit.d.ts +3 -101
  387. package/js/src/upbit.js +12 -12
  388. package/js/src/wavesexchange.js +1 -1
  389. package/js/src/woo.d.ts +2 -0
  390. package/js/src/woo.js +52 -0
  391. package/package.json +1 -1
  392. package/skip-tests.json +5 -0
@@ -0,0 +1,2002 @@
1
+ 'use strict';
2
+
3
+ var bitpanda$1 = require('./abstract/bitpanda.js');
4
+ var errors = require('./base/errors.js');
5
+ var Precise = require('./base/Precise.js');
6
+ var number = require('./base/functions/number.js');
7
+
8
+ // ---------------------------------------------------------------------------
9
+ // ---------------------------------------------------------------------------
10
+ /**
11
+ * @class bitpanda
12
+ * @augments Exchange
13
+ */
14
+ class bitpanda extends bitpanda$1 {
15
+ describe() {
16
+ return this.deepExtend(super.describe(), {
17
+ 'id': 'bitpanda',
18
+ 'name': 'Bitpanda Pro',
19
+ 'countries': ['AT'],
20
+ 'rateLimit': 300,
21
+ 'version': 'v1',
22
+ 'pro': true,
23
+ // new metainfo interface
24
+ 'has': {
25
+ 'CORS': undefined,
26
+ 'spot': true,
27
+ 'margin': false,
28
+ 'swap': false,
29
+ 'future': false,
30
+ 'option': false,
31
+ 'addMargin': false,
32
+ 'cancelAllOrders': true,
33
+ 'cancelOrder': true,
34
+ 'cancelOrders': true,
35
+ 'closeAllPositions': false,
36
+ 'closePosition': false,
37
+ 'createDepositAddress': true,
38
+ 'createOrder': true,
39
+ 'createReduceOnlyOrder': false,
40
+ 'createStopLimitOrder': true,
41
+ 'createStopMarketOrder': false,
42
+ 'createStopOrder': true,
43
+ 'fetchAccounts': false,
44
+ 'fetchBalance': true,
45
+ 'fetchBorrowRateHistories': false,
46
+ 'fetchBorrowRateHistory': false,
47
+ 'fetchClosedOrders': true,
48
+ 'fetchCrossBorrowRate': false,
49
+ 'fetchCrossBorrowRates': false,
50
+ 'fetchCurrencies': true,
51
+ 'fetchDeposit': false,
52
+ 'fetchDepositAddress': true,
53
+ 'fetchDepositAddresses': false,
54
+ 'fetchDeposits': true,
55
+ 'fetchDepositsWithdrawals': false,
56
+ 'fetchFundingHistory': false,
57
+ 'fetchFundingRate': false,
58
+ 'fetchFundingRateHistory': false,
59
+ 'fetchFundingRates': false,
60
+ 'fetchIndexOHLCV': false,
61
+ 'fetchIsolatedBorrowRate': false,
62
+ 'fetchIsolatedBorrowRates': false,
63
+ 'fetchLedger': false,
64
+ 'fetchLeverage': false,
65
+ 'fetchMarginMode': false,
66
+ 'fetchMarkets': true,
67
+ 'fetchMarkOHLCV': false,
68
+ 'fetchMyTrades': true,
69
+ 'fetchOHLCV': true,
70
+ 'fetchOpenInterestHistory': false,
71
+ 'fetchOpenOrders': true,
72
+ 'fetchOrder': true,
73
+ 'fetchOrderBook': true,
74
+ 'fetchOrders': false,
75
+ 'fetchOrderTrades': true,
76
+ 'fetchPosition': false,
77
+ 'fetchPositionMode': false,
78
+ 'fetchPositions': false,
79
+ 'fetchPositionsRisk': false,
80
+ 'fetchPremiumIndexOHLCV': false,
81
+ 'fetchTicker': true,
82
+ 'fetchTickers': true,
83
+ 'fetchTime': true,
84
+ 'fetchTrades': true,
85
+ 'fetchTradingFee': false,
86
+ 'fetchTradingFees': true,
87
+ 'fetchTransactionFee': false,
88
+ 'fetchTransactionFees': false,
89
+ 'fetchTransactions': false,
90
+ 'fetchTransfer': false,
91
+ 'fetchTransfers': false,
92
+ 'fetchWithdrawal': false,
93
+ 'fetchWithdrawals': true,
94
+ 'reduceMargin': false,
95
+ 'setLeverage': false,
96
+ 'setMargin': false,
97
+ 'setMarginMode': false,
98
+ 'setPositionMode': false,
99
+ 'transfer': false,
100
+ 'withdraw': true,
101
+ },
102
+ 'timeframes': {
103
+ '1m': '1/MINUTES',
104
+ '5m': '5/MINUTES',
105
+ '15m': '15/MINUTES',
106
+ '30m': '30/MINUTES',
107
+ '1h': '1/HOURS',
108
+ '4h': '4/HOURS',
109
+ '1d': '1/DAYS',
110
+ '1w': '1/WEEKS',
111
+ '1M': '1/MONTHS',
112
+ },
113
+ 'urls': {
114
+ 'logo': 'https://user-images.githubusercontent.com/51840849/87591171-9a377d80-c6f0-11ea-94ac-97a126eac3bc.jpg',
115
+ 'api': {
116
+ 'public': 'https://api.exchange.bitpanda.com/public',
117
+ 'private': 'https://api.exchange.bitpanda.com/public',
118
+ },
119
+ 'www': 'https://www.bitpanda.com/en/pro',
120
+ 'doc': [
121
+ 'https://developers.bitpanda.com/exchange/',
122
+ ],
123
+ 'fees': 'https://www.bitpanda.com/en/pro/fees',
124
+ },
125
+ 'api': {
126
+ 'public': {
127
+ 'get': [
128
+ 'currencies',
129
+ 'candlesticks/{instrument_code}',
130
+ 'fees',
131
+ 'instruments',
132
+ 'order-book/{instrument_code}',
133
+ 'market-ticker',
134
+ 'market-ticker/{instrument_code}',
135
+ 'price-ticks/{instrument_code}',
136
+ 'time',
137
+ ],
138
+ },
139
+ 'private': {
140
+ 'get': [
141
+ 'account/balances',
142
+ 'account/deposit/crypto/{currency_code}',
143
+ 'account/deposit/fiat/EUR',
144
+ 'account/deposits',
145
+ 'account/deposits/bitpanda',
146
+ 'account/withdrawals',
147
+ 'account/withdrawals/bitpanda',
148
+ 'account/fees',
149
+ 'account/orders',
150
+ 'account/orders/{order_id}',
151
+ 'account/orders/{order_id}/trades',
152
+ 'account/trades',
153
+ 'account/trades/{trade_id}',
154
+ 'account/trading-volume',
155
+ ],
156
+ 'post': [
157
+ 'account/deposit/crypto',
158
+ 'account/withdraw/crypto',
159
+ 'account/withdraw/fiat',
160
+ 'account/fees',
161
+ 'account/orders',
162
+ ],
163
+ 'delete': [
164
+ 'account/orders',
165
+ 'account/orders/{order_id}',
166
+ 'account/orders/client/{client_id}',
167
+ ],
168
+ },
169
+ },
170
+ 'fees': {
171
+ 'trading': {
172
+ 'tierBased': true,
173
+ 'percentage': true,
174
+ 'taker': this.parseNumber('0.0015'),
175
+ 'maker': this.parseNumber('0.001'),
176
+ 'tiers': [
177
+ // volume in BTC
178
+ {
179
+ 'taker': [
180
+ [this.parseNumber('0'), this.parseNumber('0.0015')],
181
+ [this.parseNumber('100'), this.parseNumber('0.0013')],
182
+ [this.parseNumber('250'), this.parseNumber('0.0013')],
183
+ [this.parseNumber('1000'), this.parseNumber('0.001')],
184
+ [this.parseNumber('5000'), this.parseNumber('0.0009')],
185
+ [this.parseNumber('10000'), this.parseNumber('0.00075')],
186
+ [this.parseNumber('20000'), this.parseNumber('0.00065')],
187
+ ],
188
+ 'maker': [
189
+ [this.parseNumber('0'), this.parseNumber('0.001')],
190
+ [this.parseNumber('100'), this.parseNumber('0.001')],
191
+ [this.parseNumber('250'), this.parseNumber('0.0009')],
192
+ [this.parseNumber('1000'), this.parseNumber('0.00075')],
193
+ [this.parseNumber('5000'), this.parseNumber('0.0006')],
194
+ [this.parseNumber('10000'), this.parseNumber('0.0005')],
195
+ [this.parseNumber('20000'), this.parseNumber('0.0005')],
196
+ ],
197
+ },
198
+ ],
199
+ },
200
+ },
201
+ 'requiredCredentials': {
202
+ 'apiKey': true,
203
+ 'secret': false,
204
+ },
205
+ 'precisionMode': number.TICK_SIZE,
206
+ 'exceptions': {
207
+ 'exact': {
208
+ 'INVALID_CLIENT_UUID': errors.InvalidOrder,
209
+ 'ORDER_NOT_FOUND': errors.OrderNotFound,
210
+ 'ONLY_ONE_ERC20_ADDRESS_ALLOWED': errors.InvalidAddress,
211
+ 'DEPOSIT_ADDRESS_NOT_USED': errors.InvalidAddress,
212
+ 'INVALID_CREDENTIALS': errors.AuthenticationError,
213
+ 'MISSING_CREDENTIALS': errors.AuthenticationError,
214
+ 'INVALID_APIKEY': errors.AuthenticationError,
215
+ 'INVALID_SCOPES': errors.AuthenticationError,
216
+ 'INVALID_SUBJECT': errors.AuthenticationError,
217
+ 'INVALID_ISSUER': errors.AuthenticationError,
218
+ 'INVALID_AUDIENCE': errors.AuthenticationError,
219
+ 'INVALID_DEVICE_ID': errors.AuthenticationError,
220
+ 'INVALID_IP_RESTRICTION': errors.AuthenticationError,
221
+ 'APIKEY_REVOKED': errors.AuthenticationError,
222
+ 'APIKEY_EXPIRED': errors.AuthenticationError,
223
+ 'SYNCHRONIZER_TOKEN_MISMATCH': errors.AuthenticationError,
224
+ 'SESSION_EXPIRED': errors.AuthenticationError,
225
+ 'INTERNAL_ERROR': errors.AuthenticationError,
226
+ 'CLIENT_IP_BLOCKED': errors.PermissionDenied,
227
+ 'MISSING_PERMISSION': errors.PermissionDenied,
228
+ 'ILLEGAL_CHARS': errors.BadRequest,
229
+ 'UNSUPPORTED_MEDIA_TYPE': errors.BadRequest,
230
+ 'ACCOUNT_HISTORY_TIME_RANGE_TOO_BIG': errors.BadRequest,
231
+ 'CANDLESTICKS_TIME_RANGE_TOO_BIG': errors.BadRequest,
232
+ 'INVALID_INSTRUMENT_CODE': errors.BadRequest,
233
+ 'INVALID_ORDER_TYPE': errors.BadRequest,
234
+ 'INVALID_UNIT': errors.BadRequest,
235
+ 'INVALID_PERIOD': errors.BadRequest,
236
+ 'INVALID_TIME': errors.BadRequest,
237
+ 'INVALID_DATE': errors.BadRequest,
238
+ 'INVALID_CURRENCY': errors.BadRequest,
239
+ 'INVALID_AMOUNT': errors.BadRequest,
240
+ 'INVALID_PRICE': errors.BadRequest,
241
+ 'INVALID_LIMIT': errors.BadRequest,
242
+ 'INVALID_QUERY': errors.BadRequest,
243
+ 'INVALID_CURSOR': errors.BadRequest,
244
+ 'INVALID_ACCOUNT_ID': errors.BadRequest,
245
+ 'INVALID_SIDE': errors.InvalidOrder,
246
+ 'INVALID_ACCOUNT_HISTORY_FROM_TIME': errors.BadRequest,
247
+ 'INVALID_ACCOUNT_HISTORY_MAX_PAGE_SIZE': errors.BadRequest,
248
+ 'INVALID_ACCOUNT_HISTORY_TIME_PERIOD': errors.BadRequest,
249
+ 'INVALID_ACCOUNT_HISTORY_TO_TIME': errors.BadRequest,
250
+ 'INVALID_CANDLESTICKS_GRANULARITY': errors.BadRequest,
251
+ 'INVALID_CANDLESTICKS_UNIT': errors.BadRequest,
252
+ 'INVALID_ORDER_BOOK_DEPTH': errors.BadRequest,
253
+ 'INVALID_ORDER_BOOK_LEVEL': errors.BadRequest,
254
+ 'INVALID_PAGE_CURSOR': errors.BadRequest,
255
+ 'INVALID_TIME_RANGE': errors.BadRequest,
256
+ 'INVALID_TRADE_ID': errors.BadRequest,
257
+ 'INVALID_UI_ACCOUNT_SETTINGS': errors.BadRequest,
258
+ 'NEGATIVE_AMOUNT': errors.InvalidOrder,
259
+ 'NEGATIVE_PRICE': errors.InvalidOrder,
260
+ 'MIN_SIZE_NOT_SATISFIED': errors.InvalidOrder,
261
+ 'BAD_AMOUNT_PRECISION': errors.InvalidOrder,
262
+ 'BAD_PRICE_PRECISION': errors.InvalidOrder,
263
+ 'BAD_TRIGGER_PRICE_PRECISION': errors.InvalidOrder,
264
+ 'MAX_OPEN_ORDERS_EXCEEDED': errors.BadRequest,
265
+ 'MISSING_PRICE': errors.InvalidOrder,
266
+ 'MISSING_ORDER_TYPE': errors.InvalidOrder,
267
+ 'MISSING_SIDE': errors.InvalidOrder,
268
+ 'MISSING_CANDLESTICKS_PERIOD_PARAM': errors.ArgumentsRequired,
269
+ 'MISSING_CANDLESTICKS_UNIT_PARAM': errors.ArgumentsRequired,
270
+ 'MISSING_FROM_PARAM': errors.ArgumentsRequired,
271
+ 'MISSING_INSTRUMENT_CODE': errors.ArgumentsRequired,
272
+ 'MISSING_ORDER_ID': errors.InvalidOrder,
273
+ 'MISSING_TO_PARAM': errors.ArgumentsRequired,
274
+ 'MISSING_TRADE_ID': errors.ArgumentsRequired,
275
+ 'INVALID_ORDER_ID': errors.OrderNotFound,
276
+ 'NOT_FOUND': errors.OrderNotFound,
277
+ 'INSUFFICIENT_LIQUIDITY': errors.InsufficientFunds,
278
+ 'INSUFFICIENT_FUNDS': errors.InsufficientFunds,
279
+ 'NO_TRADING': errors.ExchangeNotAvailable,
280
+ 'SERVICE_UNAVAILABLE': errors.ExchangeNotAvailable,
281
+ 'GATEWAY_TIMEOUT': errors.ExchangeNotAvailable,
282
+ 'RATELIMIT': errors.DDoSProtection,
283
+ 'CF_RATELIMIT': errors.DDoSProtection,
284
+ 'INTERNAL_SERVER_ERROR': errors.ExchangeError,
285
+ },
286
+ 'broad': {},
287
+ },
288
+ 'commonCurrencies': {
289
+ 'MIOTA': 'IOTA', // https://github.com/ccxt/ccxt/issues/7487
290
+ },
291
+ // exchange-specific options
292
+ 'options': {
293
+ 'fetchTradingFees': {
294
+ 'method': 'fetchPrivateTradingFees', // or 'fetchPublicTradingFees'
295
+ },
296
+ 'fiat': ['EUR', 'CHF'],
297
+ },
298
+ });
299
+ }
300
+ async fetchTime(params = {}) {
301
+ /**
302
+ * @method
303
+ * @name bitpanda#fetchTime
304
+ * @description fetches the current integer timestamp in milliseconds from the exchange server
305
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
306
+ * @returns {int} the current integer timestamp in milliseconds from the exchange server
307
+ */
308
+ const response = await this.publicGetTime(params);
309
+ //
310
+ // {
311
+ // "iso": "2020-07-10T05:17:26.716Z",
312
+ // "epoch_millis": 1594358246716,
313
+ // }
314
+ //
315
+ return this.safeInteger(response, 'epoch_millis');
316
+ }
317
+ async fetchCurrencies(params = {}) {
318
+ /**
319
+ * @method
320
+ * @name bitpanda#fetchCurrencies
321
+ * @description fetches all available currencies on an exchange
322
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
323
+ * @returns {object} an associative dictionary of currencies
324
+ */
325
+ const response = await this.publicGetCurrencies(params);
326
+ //
327
+ // [
328
+ // {
329
+ // "code":"BEST",
330
+ // "precision":8
331
+ // }
332
+ // ]
333
+ //
334
+ const result = {};
335
+ for (let i = 0; i < response.length; i++) {
336
+ const currency = response[i];
337
+ const id = this.safeString(currency, 'code');
338
+ const code = this.safeCurrencyCode(id);
339
+ result[code] = {
340
+ 'id': id,
341
+ 'code': code,
342
+ 'name': undefined,
343
+ 'info': currency,
344
+ 'active': undefined,
345
+ 'fee': undefined,
346
+ 'precision': this.parseNumber(this.parsePrecision(this.safeString(currency, 'precision'))),
347
+ 'withdraw': undefined,
348
+ 'deposit': undefined,
349
+ 'limits': {
350
+ 'amount': { 'min': undefined, 'max': undefined },
351
+ 'withdraw': { 'min': undefined, 'max': undefined },
352
+ },
353
+ 'networks': {},
354
+ };
355
+ }
356
+ return result;
357
+ }
358
+ async fetchMarkets(params = {}) {
359
+ /**
360
+ * @method
361
+ * @name bitpanda#fetchMarkets
362
+ * @description retrieves data on all markets for bitpanda
363
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
364
+ * @returns {object[]} an array of objects representing market data
365
+ */
366
+ const response = await this.publicGetInstruments(params);
367
+ //
368
+ // [
369
+ // {
370
+ // "state": "ACTIVE",
371
+ // "base": { code: "ETH", precision: 8 },
372
+ // "quote": { code: "CHF", precision: 2 },
373
+ // "amount_precision": 4,
374
+ // "market_precision": 2,
375
+ // "min_size": "10.0"
376
+ // }
377
+ // ]
378
+ //
379
+ return this.parseMarkets(response);
380
+ }
381
+ parseMarket(market) {
382
+ const baseAsset = this.safeValue(market, 'base', {});
383
+ const quoteAsset = this.safeValue(market, 'quote', {});
384
+ const baseId = this.safeString(baseAsset, 'code');
385
+ const quoteId = this.safeString(quoteAsset, 'code');
386
+ const id = baseId + '_' + quoteId;
387
+ const base = this.safeCurrencyCode(baseId);
388
+ const quote = this.safeCurrencyCode(quoteId);
389
+ const state = this.safeString(market, 'state');
390
+ return {
391
+ 'id': id,
392
+ 'symbol': base + '/' + quote,
393
+ 'base': base,
394
+ 'quote': quote,
395
+ 'settle': undefined,
396
+ 'baseId': baseId,
397
+ 'quoteId': quoteId,
398
+ 'settleId': undefined,
399
+ 'type': 'spot',
400
+ 'spot': true,
401
+ 'margin': false,
402
+ 'swap': false,
403
+ 'future': false,
404
+ 'option': false,
405
+ 'active': (state === 'ACTIVE'),
406
+ 'contract': false,
407
+ 'linear': undefined,
408
+ 'inverse': undefined,
409
+ 'contractSize': undefined,
410
+ 'expiry': undefined,
411
+ 'expiryDatetime': undefined,
412
+ 'strike': undefined,
413
+ 'optionType': undefined,
414
+ 'precision': {
415
+ 'amount': this.parseNumber(this.parsePrecision(this.safeString(market, 'amount_precision'))),
416
+ 'price': this.parseNumber(this.parsePrecision(this.safeString(market, 'market_precision'))),
417
+ },
418
+ 'limits': {
419
+ 'leverage': {
420
+ 'min': undefined,
421
+ 'max': undefined,
422
+ },
423
+ 'amount': {
424
+ 'min': undefined,
425
+ 'max': undefined,
426
+ },
427
+ 'price': {
428
+ 'min': undefined,
429
+ 'max': undefined,
430
+ },
431
+ 'cost': {
432
+ 'min': this.safeNumber(market, 'min_size'),
433
+ 'max': undefined,
434
+ },
435
+ },
436
+ 'created': undefined,
437
+ 'info': market,
438
+ };
439
+ }
440
+ async fetchTradingFees(params = {}) {
441
+ /**
442
+ * @method
443
+ * @name bitpanda#fetchTradingFees
444
+ * @description fetch the trading fees for multiple markets
445
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
446
+ * @returns {object} a dictionary of [fee structures]{@link https://docs.ccxt.com/#/?id=fee-structure} indexed by market symbols
447
+ */
448
+ let method = this.safeString(params, 'method');
449
+ params = this.omit(params, 'method');
450
+ if (method === undefined) {
451
+ const options = this.safeValue(this.options, 'fetchTradingFees', {});
452
+ method = this.safeString(options, 'method', 'fetchPrivateTradingFees');
453
+ }
454
+ return await this[method](params);
455
+ }
456
+ async fetchPublicTradingFees(params = {}) {
457
+ await this.loadMarkets();
458
+ const response = await this.publicGetFees(params);
459
+ //
460
+ // [
461
+ // {
462
+ // "fee_group_id":"default",
463
+ // "display_text":"The standard fee plan.",
464
+ // "fee_tiers":[
465
+ // {"volume":"0.0","fee_group_id":"default","maker_fee":"0.1","taker_fee":"0.15"},
466
+ // {"volume":"100.0","fee_group_id":"default","maker_fee":"0.1","taker_fee":"0.13"},
467
+ // {"volume":"250.0","fee_group_id":"default","maker_fee":"0.09","taker_fee":"0.13"},
468
+ // {"volume":"1000.0","fee_group_id":"default","maker_fee":"0.075","taker_fee":"0.1"},
469
+ // {"volume":"5000.0","fee_group_id":"default","maker_fee":"0.06","taker_fee":"0.09"},
470
+ // {"volume":"10000.0","fee_group_id":"default","maker_fee":"0.05","taker_fee":"0.075"},
471
+ // {"volume":"20000.0","fee_group_id":"default","maker_fee":"0.05","taker_fee":"0.065"}
472
+ // ],
473
+ // "fee_discount_rate":"25.0",
474
+ // "minimum_price_value":"0.12"
475
+ // }
476
+ // ]
477
+ //
478
+ const first = this.safeValue(response, 0, {});
479
+ const feeTiers = this.safeValue(first, 'fee_tiers');
480
+ const tiers = this.parseFeeTiers(feeTiers);
481
+ const firstTier = this.safeValue(feeTiers, 0, {});
482
+ const result = {};
483
+ for (let i = 0; i < this.symbols.length; i++) {
484
+ const symbol = this.symbols[i];
485
+ result[symbol] = {
486
+ 'info': first,
487
+ 'symbol': symbol,
488
+ 'maker': this.safeNumber(firstTier, 'maker_fee'),
489
+ 'taker': this.safeNumber(firstTier, 'taker_fee'),
490
+ 'percentage': true,
491
+ 'tierBased': true,
492
+ 'tiers': tiers,
493
+ };
494
+ }
495
+ return result;
496
+ }
497
+ async fetchPrivateTradingFees(params = {}) {
498
+ await this.loadMarkets();
499
+ const response = await this.privateGetAccountFees(params);
500
+ //
501
+ // {
502
+ // "account_id": "ed524d00-820a-11e9-8f1e-69602df16d85",
503
+ // "running_trading_volume": "0.0",
504
+ // "fee_group_id": "default",
505
+ // "collect_fees_in_best": false,
506
+ // "fee_discount_rate": "25.0",
507
+ // "minimum_price_value": "0.12",
508
+ // "fee_tiers": [
509
+ // { "volume": "0.0", "fee_group_id": "default", "maker_fee": "0.1", "taker_fee": "0.1" },
510
+ // { "volume": "100.0", "fee_group_id": "default", "maker_fee": "0.09", "taker_fee": "0.1" },
511
+ // { "volume": "250.0", "fee_group_id": "default", "maker_fee": "0.08", "taker_fee": "0.1" },
512
+ // { "volume": "1000.0", "fee_group_id": "default", "maker_fee": "0.07", "taker_fee": "0.09" },
513
+ // { "volume": "5000.0", "fee_group_id": "default", "maker_fee": "0.06", "taker_fee": "0.08" },
514
+ // { "volume": "10000.0", "fee_group_id": "default", "maker_fee": "0.05", "taker_fee": "0.07" },
515
+ // { "volume": "20000.0", "fee_group_id": "default", "maker_fee": "0.05", "taker_fee": "0.06" },
516
+ // { "volume": "50000.0", "fee_group_id": "default", "maker_fee": "0.05", "taker_fee": "0.05" }
517
+ // ],
518
+ // "active_fee_tier": { "volume": "0.0", "fee_group_id": "default", "maker_fee": "0.1", "taker_fee": "0.1" }
519
+ // }
520
+ //
521
+ const activeFeeTier = this.safeValue(response, 'active_fee_tier', {});
522
+ let makerFee = this.safeString(activeFeeTier, 'maker_fee');
523
+ let takerFee = this.safeString(activeFeeTier, 'taker_fee');
524
+ makerFee = Precise["default"].stringDiv(makerFee, '100');
525
+ takerFee = Precise["default"].stringDiv(takerFee, '100');
526
+ const feeTiers = this.safeValue(response, 'fee_tiers');
527
+ const result = {};
528
+ const tiers = this.parseFeeTiers(feeTiers);
529
+ for (let i = 0; i < this.symbols.length; i++) {
530
+ const symbol = this.symbols[i];
531
+ result[symbol] = {
532
+ 'info': response,
533
+ 'symbol': symbol,
534
+ 'maker': this.parseNumber(makerFee),
535
+ 'taker': this.parseNumber(takerFee),
536
+ 'percentage': true,
537
+ 'tierBased': true,
538
+ 'tiers': tiers,
539
+ };
540
+ }
541
+ return result;
542
+ }
543
+ parseFeeTiers(feeTiers, market = undefined) {
544
+ const takerFees = [];
545
+ const makerFees = [];
546
+ for (let i = 0; i < feeTiers.length; i++) {
547
+ const tier = feeTiers[i];
548
+ const volume = this.safeNumber(tier, 'volume');
549
+ let taker = this.safeString(tier, 'taker_fee');
550
+ let maker = this.safeString(tier, 'maker_fee');
551
+ maker = Precise["default"].stringDiv(maker, '100');
552
+ taker = Precise["default"].stringDiv(taker, '100');
553
+ makerFees.push([volume, this.parseNumber(maker)]);
554
+ takerFees.push([volume, this.parseNumber(taker)]);
555
+ }
556
+ return {
557
+ 'maker': makerFees,
558
+ 'taker': takerFees,
559
+ };
560
+ }
561
+ parseTicker(ticker, market = undefined) {
562
+ //
563
+ // fetchTicker, fetchTickers
564
+ //
565
+ // {
566
+ // "instrument_code":"BTC_EUR",
567
+ // "sequence":602562,
568
+ // "time":"2020-07-10T06:27:34.951Z",
569
+ // "state":"ACTIVE",
570
+ // "is_frozen":0,
571
+ // "quote_volume":"1695555.1783768",
572
+ // "base_volume":"205.67436",
573
+ // "last_price":"8143.91",
574
+ // "best_bid":"8143.71",
575
+ // "best_ask":"8156.9",
576
+ // "price_change":"-147.47",
577
+ // "price_change_percentage":"-1.78",
578
+ // "high":"8337.45",
579
+ // "low":"8110.0"
580
+ // }
581
+ //
582
+ const timestamp = this.parse8601(this.safeString(ticker, 'time'));
583
+ const marketId = this.safeString(ticker, 'instrument_code');
584
+ const symbol = this.safeSymbol(marketId, market, '_');
585
+ const last = this.safeString(ticker, 'last_price');
586
+ const percentage = this.safeString(ticker, 'price_change_percentage');
587
+ const change = this.safeString(ticker, 'price_change');
588
+ const baseVolume = this.safeString(ticker, 'base_volume');
589
+ const quoteVolume = this.safeString(ticker, 'quote_volume');
590
+ return this.safeTicker({
591
+ 'symbol': symbol,
592
+ 'timestamp': timestamp,
593
+ 'datetime': this.iso8601(timestamp),
594
+ 'high': this.safeString(ticker, 'high'),
595
+ 'low': this.safeString(ticker, 'low'),
596
+ 'bid': this.safeString(ticker, 'best_bid'),
597
+ 'bidVolume': undefined,
598
+ 'ask': this.safeString(ticker, 'best_ask'),
599
+ 'askVolume': undefined,
600
+ 'vwap': undefined,
601
+ 'open': undefined,
602
+ 'close': last,
603
+ 'last': last,
604
+ 'previousClose': undefined,
605
+ 'change': change,
606
+ 'percentage': percentage,
607
+ 'average': undefined,
608
+ 'baseVolume': baseVolume,
609
+ 'quoteVolume': quoteVolume,
610
+ 'info': ticker,
611
+ }, market);
612
+ }
613
+ async fetchTicker(symbol, params = {}) {
614
+ /**
615
+ * @method
616
+ * @name bitpanda#fetchTicker
617
+ * @description fetches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
618
+ * @param {string} symbol unified symbol of the market to fetch the ticker for
619
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
620
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
621
+ */
622
+ await this.loadMarkets();
623
+ const market = this.market(symbol);
624
+ const request = {
625
+ 'instrument_code': market['id'],
626
+ };
627
+ const response = await this.publicGetMarketTickerInstrumentCode(this.extend(request, params));
628
+ //
629
+ // {
630
+ // "instrument_code":"BTC_EUR",
631
+ // "sequence":602562,
632
+ // "time":"2020-07-10T06:27:34.951Z",
633
+ // "state":"ACTIVE",
634
+ // "is_frozen":0,
635
+ // "quote_volume":"1695555.1783768",
636
+ // "base_volume":"205.67436",
637
+ // "last_price":"8143.91",
638
+ // "best_bid":"8143.71",
639
+ // "best_ask":"8156.9",
640
+ // "price_change":"-147.47",
641
+ // "price_change_percentage":"-1.78",
642
+ // "high":"8337.45",
643
+ // "low":"8110.0"
644
+ // }
645
+ //
646
+ return this.parseTicker(response, market);
647
+ }
648
+ async fetchTickers(symbols = undefined, params = {}) {
649
+ /**
650
+ * @method
651
+ * @name bitpanda#fetchTickers
652
+ * @description fetches price tickers for multiple markets, statistical information calculated over the past 24 hours for each market
653
+ * @param {string[]|undefined} symbols unified symbols of the markets to fetch the ticker for, all market tickers are returned if not assigned
654
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
655
+ * @returns {object} a dictionary of [ticker structures]{@link https://docs.ccxt.com/#/?id=ticker-structure}
656
+ */
657
+ await this.loadMarkets();
658
+ symbols = this.marketSymbols(symbols);
659
+ const response = await this.publicGetMarketTicker(params);
660
+ //
661
+ // [
662
+ // {
663
+ // "instrument_code":"BTC_EUR",
664
+ // "sequence":602562,
665
+ // "time":"2020-07-10T06:27:34.951Z",
666
+ // "state":"ACTIVE",
667
+ // "is_frozen":0,
668
+ // "quote_volume":"1695555.1783768",
669
+ // "base_volume":"205.67436",
670
+ // "last_price":"8143.91",
671
+ // "best_bid":"8143.71",
672
+ // "best_ask":"8156.9",
673
+ // "price_change":"-147.47",
674
+ // "price_change_percentage":"-1.78",
675
+ // "high":"8337.45",
676
+ // "low":"8110.0"
677
+ // }
678
+ // ]
679
+ //
680
+ const result = {};
681
+ for (let i = 0; i < response.length; i++) {
682
+ const ticker = this.parseTicker(response[i]);
683
+ const symbol = ticker['symbol'];
684
+ result[symbol] = ticker;
685
+ }
686
+ return this.filterByArrayTickers(result, 'symbol', symbols);
687
+ }
688
+ async fetchOrderBook(symbol, limit = undefined, params = {}) {
689
+ /**
690
+ * @method
691
+ * @name bitpanda#fetchOrderBook
692
+ * @description fetches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
693
+ * @param {string} symbol unified symbol of the market to fetch the order book for
694
+ * @param {int} [limit] the maximum amount of order book entries to return
695
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
696
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
697
+ */
698
+ await this.loadMarkets();
699
+ const market = this.market(symbol);
700
+ const request = {
701
+ 'instrument_code': market['id'],
702
+ // level 1 means only the best bid and ask
703
+ // level 2 is a compiled order book up to market precision
704
+ // level 3 is a full orderbook
705
+ // if you wish to get regular updates about orderbooks please use the Websocket channel
706
+ // heavy usage of this endpoint may result in limited access according to rate limits rules
707
+ // 'level': 3, // default
708
+ };
709
+ if (limit !== undefined) {
710
+ request['depth'] = limit;
711
+ }
712
+ const response = await this.publicGetOrderBookInstrumentCode(this.extend(request, params));
713
+ //
714
+ // level 1
715
+ //
716
+ // {
717
+ // "instrument_code":"BTC_EUR",
718
+ // "time":"2020-07-10T07:39:06.343Z",
719
+ // "asks":{
720
+ // "value":{
721
+ // "price":"8145.29",
722
+ // "amount":"0.96538",
723
+ // "number_of_orders":1
724
+ // }
725
+ // },
726
+ // "bids":{
727
+ // "value":{
728
+ // "price":"8134.0",
729
+ // "amount":"1.5978",
730
+ // "number_of_orders":5
731
+ // }
732
+ // }
733
+ // }
734
+ //
735
+ // level 2
736
+ //
737
+ // {
738
+ // "instrument_code":"BTC_EUR","time":"2020-07-10T07:36:43.538Z",
739
+ // "asks":[
740
+ // {"price":"8146.59","amount":"0.89691","number_of_orders":1},
741
+ // {"price":"8146.89","amount":"1.92062","number_of_orders":1},
742
+ // {"price":"8169.5","amount":"0.0663","number_of_orders":1},
743
+ // ],
744
+ // "bids":[
745
+ // {"price":"8143.49","amount":"0.01329","number_of_orders":1},
746
+ // {"price":"8137.01","amount":"5.34748","number_of_orders":1},
747
+ // {"price":"8137.0","amount":"2.0","number_of_orders":1},
748
+ // ]
749
+ // }
750
+ //
751
+ // level 3
752
+ //
753
+ // {
754
+ // "instrument_code":"BTC_EUR",
755
+ // "time":"2020-07-10T07:32:31.525Z",
756
+ // "bids":[
757
+ // {"price":"8146.79","amount":"0.01537","order_id":"5d717da1-a8f4-422d-afcc-03cb6ab66825"},
758
+ // {"price":"8139.32","amount":"3.66009","order_id":"d0715c68-f28d-4cf1-a450-d56cf650e11c"},
759
+ // {"price":"8137.51","amount":"2.61049","order_id":"085fd6f4-e835-4ca5-9449-a8f165772e60"},
760
+ // ],
761
+ // "asks":[
762
+ // {"price":"8153.49","amount":"0.93384","order_id":"755d3aa3-42b5-46fa-903d-98f42e9ae6c4"},
763
+ // {"price":"8153.79","amount":"1.80456","order_id":"62034cf3-b70d-45ff-b285-ba6307941e7c"},
764
+ // {"price":"8167.9","amount":"0.0018","order_id":"036354e0-71cd-492f-94f2-01f7d4b66422"},
765
+ // ]
766
+ // }
767
+ //
768
+ const timestamp = this.parse8601(this.safeString(response, 'time'));
769
+ return this.parseOrderBook(response, market['symbol'], timestamp, 'bids', 'asks', 'price', 'amount');
770
+ }
771
+ parseOHLCV(ohlcv, market = undefined) {
772
+ //
773
+ // {
774
+ // "instrument_code":"BTC_EUR",
775
+ // "granularity":{"unit":"HOURS","period":1},
776
+ // "high":"9252.65",
777
+ // "low":"9115.27",
778
+ // "open":"9250.0",
779
+ // "close":"9132.35",
780
+ // "total_amount":"33.85924",
781
+ // "volume":"311958.9635744",
782
+ // "time":"2020-05-08T22:59:59.999Z",
783
+ // "last_sequence":461123
784
+ // }
785
+ //
786
+ const granularity = this.safeValue(ohlcv, 'granularity');
787
+ const unit = this.safeString(granularity, 'unit');
788
+ const period = this.safeString(granularity, 'period');
789
+ const units = {
790
+ 'MINUTES': 'm',
791
+ 'HOURS': 'h',
792
+ 'DAYS': 'd',
793
+ 'WEEKS': 'w',
794
+ 'MONTHS': 'M',
795
+ };
796
+ const lowercaseUnit = this.safeString(units, unit);
797
+ const timeframe = period + lowercaseUnit;
798
+ const durationInSeconds = this.parseTimeframe(timeframe);
799
+ const duration = durationInSeconds * 1000;
800
+ const timestamp = this.parse8601(this.safeString(ohlcv, 'time'));
801
+ const alignedTimestamp = duration * this.parseToInt(timestamp / duration);
802
+ const options = this.safeValue(this.options, 'fetchOHLCV', {});
803
+ const volumeField = this.safeString(options, 'volume', 'total_amount');
804
+ return [
805
+ alignedTimestamp,
806
+ this.safeNumber(ohlcv, 'open'),
807
+ this.safeNumber(ohlcv, 'high'),
808
+ this.safeNumber(ohlcv, 'low'),
809
+ this.safeNumber(ohlcv, 'close'),
810
+ this.safeNumber(ohlcv, volumeField),
811
+ ];
812
+ }
813
+ async fetchOHLCV(symbol, timeframe = '1m', since = undefined, limit = undefined, params = {}) {
814
+ /**
815
+ * @method
816
+ * @name bitpanda#fetchOHLCV
817
+ * @description fetches historical candlestick data containing the open, high, low, and close price, and the volume of a market
818
+ * @param {string} symbol unified symbol of the market to fetch OHLCV data for
819
+ * @param {string} timeframe the length of time each candle represents
820
+ * @param {int} [since] timestamp in ms of the earliest candle to fetch
821
+ * @param {int} [limit] the maximum amount of candles to fetch
822
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
823
+ * @returns {int[][]} A list of candles ordered as timestamp, open, high, low, close, volume
824
+ */
825
+ await this.loadMarkets();
826
+ const market = this.market(symbol);
827
+ const periodUnit = this.safeString(this.timeframes, timeframe);
828
+ const [period, unit] = periodUnit.split('/');
829
+ const durationInSeconds = this.parseTimeframe(timeframe);
830
+ const duration = durationInSeconds * 1000;
831
+ if (limit === undefined) {
832
+ limit = 1500;
833
+ }
834
+ const request = {
835
+ 'instrument_code': market['id'],
836
+ // 'from': this.iso8601 (since),
837
+ // 'to': this.iso8601 (this.milliseconds ()),
838
+ 'period': period,
839
+ 'unit': unit,
840
+ };
841
+ if (since === undefined) {
842
+ const now = this.milliseconds();
843
+ request['to'] = this.iso8601(now);
844
+ request['from'] = this.iso8601(now - limit * duration);
845
+ }
846
+ else {
847
+ request['from'] = this.iso8601(since);
848
+ request['to'] = this.iso8601(this.sum(since, limit * duration));
849
+ }
850
+ const response = await this.publicGetCandlesticksInstrumentCode(this.extend(request, params));
851
+ //
852
+ // [
853
+ // {"instrument_code":"BTC_EUR","granularity":{"unit":"HOURS","period":1},"high":"9252.65","low":"9115.27","open":"9250.0","close":"9132.35","total_amount":"33.85924","volume":"311958.9635744","time":"2020-05-08T22:59:59.999Z","last_sequence":461123},
854
+ // {"instrument_code":"BTC_EUR","granularity":{"unit":"HOURS","period":1},"high":"9162.49","low":"9040.0","open":"9132.53","close":"9083.69","total_amount":"26.19685","volume":"238553.7812365","time":"2020-05-08T23:59:59.999Z","last_sequence":461376},
855
+ // {"instrument_code":"BTC_EUR","granularity":{"unit":"HOURS","period":1},"high":"9135.7","low":"9002.59","open":"9055.45","close":"9133.98","total_amount":"26.21919","volume":"238278.8724959","time":"2020-05-09T00:59:59.999Z","last_sequence":461521},
856
+ // ]
857
+ //
858
+ return this.parseOHLCVs(response, market, timeframe, since, limit);
859
+ }
860
+ parseTrade(trade, market = undefined) {
861
+ //
862
+ // fetchTrades (public)
863
+ //
864
+ // {
865
+ // "instrument_code":"BTC_EUR",
866
+ // "price":"8137.28",
867
+ // "amount":"0.22269",
868
+ // "taker_side":"BUY",
869
+ // "volume":"1812.0908832",
870
+ // "time":"2020-07-10T14:44:32.299Z",
871
+ // "trade_timestamp":1594392272299,
872
+ // "sequence":603047
873
+ // }
874
+ //
875
+ // fetchMyTrades, fetchOrder, fetchOpenOrders, fetchClosedOrders trades (private)
876
+ //
877
+ // {
878
+ // "fee": {
879
+ // "fee_amount": "0.0014",
880
+ // "fee_currency": "BTC",
881
+ // "fee_percentage": "0.1",
882
+ // "fee_group_id": "default",
883
+ // "fee_type": "TAKER",
884
+ // "running_trading_volume": "0.0"
885
+ // },
886
+ // "trade": {
887
+ // "trade_id": "fdff2bcc-37d6-4a2d-92a5-46e09c868664",
888
+ // "order_id": "36bb2437-7402-4794-bf26-4bdf03526439",
889
+ // "account_id": "a4c699f6-338d-4a26-941f-8f9853bfc4b9",
890
+ // "amount": "1.4",
891
+ // "side": "BUY",
892
+ // "instrument_code": "BTC_EUR",
893
+ // "price": "7341.4",
894
+ // "time": "2019-09-27T15:05:32.564Z",
895
+ // "sequence": 48670
896
+ // }
897
+ // }
898
+ //
899
+ const feeInfo = this.safeValue(trade, 'fee', {});
900
+ trade = this.safeValue(trade, 'trade', trade);
901
+ let timestamp = this.safeInteger(trade, 'trade_timestamp');
902
+ if (timestamp === undefined) {
903
+ timestamp = this.parse8601(this.safeString(trade, 'time'));
904
+ }
905
+ const side = this.safeStringLower2(trade, 'side', 'taker_side');
906
+ const priceString = this.safeString(trade, 'price');
907
+ const amountString = this.safeString(trade, 'amount');
908
+ const costString = this.safeString(trade, 'volume');
909
+ const marketId = this.safeString(trade, 'instrument_code');
910
+ const symbol = this.safeSymbol(marketId, market, '_');
911
+ const feeCostString = this.safeString(feeInfo, 'fee_amount');
912
+ let takerOrMaker = undefined;
913
+ let fee = undefined;
914
+ if (feeCostString !== undefined) {
915
+ const feeCurrencyId = this.safeString(feeInfo, 'fee_currency');
916
+ const feeCurrencyCode = this.safeCurrencyCode(feeCurrencyId);
917
+ const feeRateString = this.safeString(feeInfo, 'fee_percentage');
918
+ fee = {
919
+ 'cost': feeCostString,
920
+ 'currency': feeCurrencyCode,
921
+ 'rate': feeRateString,
922
+ };
923
+ takerOrMaker = this.safeStringLower(feeInfo, 'fee_type');
924
+ }
925
+ return this.safeTrade({
926
+ 'id': this.safeString2(trade, 'trade_id', 'sequence'),
927
+ 'order': this.safeString(trade, 'order_id'),
928
+ 'timestamp': timestamp,
929
+ 'datetime': this.iso8601(timestamp),
930
+ 'symbol': symbol,
931
+ 'type': undefined,
932
+ 'side': side,
933
+ 'price': priceString,
934
+ 'amount': amountString,
935
+ 'cost': costString,
936
+ 'takerOrMaker': takerOrMaker,
937
+ 'fee': fee,
938
+ 'info': trade,
939
+ }, market);
940
+ }
941
+ async fetchTrades(symbol, since = undefined, limit = undefined, params = {}) {
942
+ /**
943
+ * @method
944
+ * @name bitpanda#fetchTrades
945
+ * @description get the list of most recent trades for a particular symbol
946
+ * @param {string} symbol unified symbol of the market to fetch trades for
947
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
948
+ * @param {int} [limit] the maximum amount of trades to fetch
949
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
950
+ * @returns {Trade[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
951
+ */
952
+ await this.loadMarkets();
953
+ const market = this.market(symbol);
954
+ const request = {
955
+ 'instrument_code': market['id'],
956
+ // 'from': this.iso8601 (since),
957
+ // 'to': this.iso8601 (this.milliseconds ()),
958
+ };
959
+ if (since !== undefined) {
960
+ // returns price ticks for a specific market with an interval of maximum of 4 hours
961
+ // sorted by latest first
962
+ request['from'] = this.iso8601(since);
963
+ request['to'] = this.iso8601(this.sum(since, 14400000));
964
+ }
965
+ const response = await this.publicGetPriceTicksInstrumentCode(this.extend(request, params));
966
+ //
967
+ // [
968
+ // {
969
+ // "instrument_code":"BTC_EUR",
970
+ // "price":"8137.28",
971
+ // "amount":"0.22269",
972
+ // "taker_side":"BUY",
973
+ // "volume":"1812.0908832",
974
+ // "time":"2020-07-10T14:44:32.299Z",
975
+ // "trade_timestamp":1594392272299,
976
+ // "sequence":603047
977
+ // }
978
+ // ]
979
+ //
980
+ return this.parseTrades(response, market, since, limit);
981
+ }
982
+ parseBalance(response) {
983
+ const balances = this.safeValue(response, 'balances', []);
984
+ const result = { 'info': response };
985
+ for (let i = 0; i < balances.length; i++) {
986
+ const balance = balances[i];
987
+ const currencyId = this.safeString(balance, 'currency_code');
988
+ const code = this.safeCurrencyCode(currencyId);
989
+ const account = this.account();
990
+ account['free'] = this.safeString(balance, 'available');
991
+ account['used'] = this.safeString(balance, 'locked');
992
+ result[code] = account;
993
+ }
994
+ return this.safeBalance(result);
995
+ }
996
+ async fetchBalance(params = {}) {
997
+ /**
998
+ * @method
999
+ * @name bitpanda#fetchBalance
1000
+ * @description query for balance and get the amount of funds available for trading or funds locked in orders
1001
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1002
+ * @returns {object} a [balance structure]{@link https://docs.ccxt.com/#/?id=balance-structure}
1003
+ */
1004
+ await this.loadMarkets();
1005
+ const response = await this.privateGetAccountBalances(params);
1006
+ //
1007
+ // {
1008
+ // "account_id":"4b95934f-55f1-460c-a525-bd5afc0cf071",
1009
+ // "balances":[
1010
+ // {
1011
+ // "account_id":"4b95934f-55f1-460c-a525-bd5afc0cf071",
1012
+ // "currency_code":"BTC",
1013
+ // "change":"10.0",
1014
+ // "available":"10.0",
1015
+ // "locked":"0.0",
1016
+ // "sequence":142135994,
1017
+ // "time":"2020-07-01T10:57:32.959Z"
1018
+ // }
1019
+ // ]
1020
+ // }
1021
+ //
1022
+ return this.parseBalance(response);
1023
+ }
1024
+ parseDepositAddress(depositAddress, currency = undefined) {
1025
+ let code = undefined;
1026
+ if (currency !== undefined) {
1027
+ code = currency['code'];
1028
+ }
1029
+ const address = this.safeString(depositAddress, 'address');
1030
+ const tag = this.safeString(depositAddress, 'destination_tag');
1031
+ this.checkAddress(address);
1032
+ return {
1033
+ 'currency': code,
1034
+ 'address': address,
1035
+ 'tag': tag,
1036
+ 'network': undefined,
1037
+ 'info': depositAddress,
1038
+ };
1039
+ }
1040
+ async createDepositAddress(code, params = {}) {
1041
+ /**
1042
+ * @method
1043
+ * @name bitpanda#createDepositAddress
1044
+ * @description create a currency deposit address
1045
+ * @param {string} code unified currency code of the currency for the deposit address
1046
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1047
+ * @returns {object} an [address structure]{@link https://docs.ccxt.com/#/?id=address-structure}
1048
+ */
1049
+ await this.loadMarkets();
1050
+ const currency = this.currency(code);
1051
+ const request = {
1052
+ 'currency': currency['id'],
1053
+ };
1054
+ const response = await this.privatePostAccountDepositCrypto(this.extend(request, params));
1055
+ //
1056
+ // {
1057
+ // "address":"rBnNhk95FrdNisZtXcStzriFS8vEzz53DM",
1058
+ // "destination_tag":"865690307",
1059
+ // "enabled":true,
1060
+ // "is_smart_contract":false
1061
+ // }
1062
+ //
1063
+ return this.parseDepositAddress(response, currency);
1064
+ }
1065
+ async fetchDepositAddress(code, params = {}) {
1066
+ /**
1067
+ * @method
1068
+ * @name bitpanda#fetchDepositAddress
1069
+ * @description fetch the deposit address for a currency associated with this account
1070
+ * @param {string} code unified currency code
1071
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1072
+ * @returns {object} an [address structure]{@link https://docs.ccxt.com/#/?id=address-structure}
1073
+ */
1074
+ await this.loadMarkets();
1075
+ const currency = this.currency(code);
1076
+ const request = {
1077
+ 'currency_code': currency['id'],
1078
+ };
1079
+ const response = await this.privateGetAccountDepositCryptoCurrencyCode(this.extend(request, params));
1080
+ //
1081
+ // {
1082
+ // "address":"rBnNhk95FrdNisZtXcStzriFS8vEzz53DM",
1083
+ // "destination_tag":"865690307",
1084
+ // "enabled":true,
1085
+ // "is_smart_contract":false,
1086
+ // "can_create_more":false
1087
+ // }
1088
+ //
1089
+ return this.parseDepositAddress(response, currency);
1090
+ }
1091
+ async fetchDeposits(code = undefined, since = undefined, limit = undefined, params = {}) {
1092
+ /**
1093
+ * @method
1094
+ * @name bitpanda#fetchDeposits
1095
+ * @description fetch all deposits made to an account
1096
+ * @param {string} code unified currency code
1097
+ * @param {int} [since] the earliest time in ms to fetch deposits for
1098
+ * @param {int} [limit] the maximum number of deposits structures to retrieve
1099
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1100
+ * @returns {object[]} a list of [transaction structures]{@link https://docs.ccxt.com/#/?id=transaction-structure}
1101
+ */
1102
+ await this.loadMarkets();
1103
+ const request = {
1104
+ // 'cursor': 'string', // pointer specifying the position from which the next pages should be returned
1105
+ };
1106
+ let currency = undefined;
1107
+ if (code !== undefined) {
1108
+ currency = this.currency(code);
1109
+ request['currency_code'] = currency['id'];
1110
+ }
1111
+ if (limit !== undefined) {
1112
+ request['max_page_size'] = limit;
1113
+ }
1114
+ if (since !== undefined) {
1115
+ const to = this.safeString(params, 'to');
1116
+ if (to === undefined) {
1117
+ throw new errors.ArgumentsRequired(this.id + ' fetchDeposits() requires a "to" iso8601 string param with the since argument is specified');
1118
+ }
1119
+ request['from'] = this.iso8601(since);
1120
+ }
1121
+ const response = await this.privateGetAccountDeposits(this.extend(request, params));
1122
+ //
1123
+ // {
1124
+ // "deposit_history": [
1125
+ // {
1126
+ // "transaction_id": "e5342efcd-d5b7-4a56-8e12-b69ffd68c5ef",
1127
+ // "account_id": "c2d0076a-c20d-41f8-9e9a-1a1d028b2b58",
1128
+ // "amount": "100",
1129
+ // "type": "CRYPTO",
1130
+ // "funds_source": "INTERNAL",
1131
+ // "time": "2020-04-22T09:57:47Z",
1132
+ // "currency": "BTC",
1133
+ // "fee_amount": "0.0",
1134
+ // "fee_currency": "BTC"
1135
+ // },
1136
+ // {
1137
+ // "transaction_id": "79793d00-2899-4a4d-95b7-73ae6b31384f",
1138
+ // "account_id": "c2d0076a-c20d-41f8-9e9a-1a1d028b2b58",
1139
+ // "time": "2020-05-05T11:22:07.925Z",
1140
+ // "currency": "EUR",
1141
+ // "funds_source": "EXTERNAL",
1142
+ // "type": "FIAT",
1143
+ // "amount": "50.0",
1144
+ // "fee_amount": "0.01",
1145
+ // "fee_currency": "EUR"
1146
+ // }
1147
+ // ],
1148
+ // "max_page_size": 2,
1149
+ // "cursor": "eyJhY2NvdW50X2lkIjp7InMiOiJlMzY5YWM4MC00NTc3LTExZTktYWUwOC05YmVkYzQ3OTBiODQiLCJzcyI6W10sIm5zIjpbXSwiYnMiOltdLCJtIjp7fSwibCI6W119LCJpdGVtX2tleSI6eyJzIjoiV0lUSERSQVdBTDo6MmFlMjYwY2ItOTk3MC00YmNiLTgxNmEtZGY4MDVmY2VhZTY1Iiwic3MiOltdLCJucyI6W10sImJzIjpbXSwibSI6e30sImwiOltdfSwiZ2xvYmFsX3dpdGhkcmF3YWxfaW5kZXhfaGFzaF9rZXkiOnsicyI6ImUzNjlhYzgwLTQ1NzctMTFlOS1hZTA4LTliZWRjNDc5MGI4NCIsInNzIjpbXSwibnMiOltdLCJicyI6W10sIm0iOnt9LCJsIjpbXX0sInRpbWVzdGFtcCI6eyJuIjoiMTU4ODA1ODc2Nzk0OCIsInNzIjpbXSwibnMiOltdLCJicyI6W10sIm0iOnt9LCJsIjpbXX19"
1150
+ // }
1151
+ //
1152
+ const depositHistory = this.safeValue(response, 'deposit_history', []);
1153
+ return this.parseTransactions(depositHistory, currency, since, limit, { 'type': 'deposit' });
1154
+ }
1155
+ async fetchWithdrawals(code = undefined, since = undefined, limit = undefined, params = {}) {
1156
+ /**
1157
+ * @method
1158
+ * @name bitpanda#fetchWithdrawals
1159
+ * @description fetch all withdrawals made from an account
1160
+ * @param {string} code unified currency code
1161
+ * @param {int} [since] the earliest time in ms to fetch withdrawals for
1162
+ * @param {int} [limit] the maximum number of withdrawals structures to retrieve
1163
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1164
+ * @returns {object[]} a list of [transaction structures]{@link https://docs.ccxt.com/#/?id=transaction-structure}
1165
+ */
1166
+ await this.loadMarkets();
1167
+ const request = {
1168
+ // 'cursor': 'string', // pointer specifying the position from which the next pages should be returned
1169
+ };
1170
+ let currency = undefined;
1171
+ if (code !== undefined) {
1172
+ currency = this.currency(code);
1173
+ request['currency_code'] = currency['id'];
1174
+ }
1175
+ if (limit !== undefined) {
1176
+ request['max_page_size'] = limit;
1177
+ }
1178
+ if (since !== undefined) {
1179
+ const to = this.safeString(params, 'to');
1180
+ if (to === undefined) {
1181
+ throw new errors.ArgumentsRequired(this.id + ' fetchWithdrawals() requires a "to" iso8601 string param with the since argument is specified');
1182
+ }
1183
+ request['from'] = this.iso8601(since);
1184
+ }
1185
+ const response = await this.privateGetAccountWithdrawals(this.extend(request, params));
1186
+ //
1187
+ // {
1188
+ // "withdrawal_history": [
1189
+ // {
1190
+ // "account_id": "e369ac80-4577-11e9-ae08-9bedc4790b84",
1191
+ // "amount": "0.1",
1192
+ // "currency": "BTC",
1193
+ // "fee_amount": "0.00002",
1194
+ // "fee_currency": "BTC",
1195
+ // "funds_source": "EXTERNAL",
1196
+ // "related_transaction_id": "e298341a-3855-405e-bce3-92db368a3157",
1197
+ // "time": "2020-05-05T11:11:32.110Z",
1198
+ // "transaction_id": "6693ff40-bb10-4dcf-ada7-3b287727c882",
1199
+ // "type": "CRYPTO"
1200
+ // },
1201
+ // {
1202
+ // "account_id": "e369ac80-4577-11e9-ae08-9bedc4790b84",
1203
+ // "amount": "0.1",
1204
+ // "currency": "BTC",
1205
+ // "fee_amount": "0.0",
1206
+ // "fee_currency": "BTC",
1207
+ // "funds_source": "INTERNAL",
1208
+ // "time": "2020-05-05T10:29:53.464Z",
1209
+ // "transaction_id": "ec9703b1-954b-4f76-adea-faac66eabc0b",
1210
+ // "type": "CRYPTO"
1211
+ // }
1212
+ // ],
1213
+ // "cursor": "eyJhY2NvdW50X2lkIjp7InMiOiJlMzY5YWM4MC00NTc3LTExZTktYWUwOC05YmVkYzQ3OTBiODQiLCJzcyI6W10sIm5zIjpbXSwiYnMiOltdLCJtIjp7fSwibCI6W119LCJpdGVtX2tleSI6eyJzIjoiV0lUSERSQVdBTDo6ZWM5NzAzYjEtOTU0Yi00Zjc2LWFkZWEtZmFhYzY2ZWFiYzBiIiwic3MiOltdLCJucyI6W10sImJzIjpbXSwibSI6e30sImwiOltdfSwiZ2xvYmFsX3dpdGhkcmF3YWxfaW5kZXhfaGFzaF9rZXkiOnsicyI6ImUzNjlhYzgwLTQ1NzctMTFlOS1hZTA4LTliZWRjNDc5MGI4NCIsInNzIjpbXSwibnMiOltdLCJicyI6W10sIm0iOnt9LCJsIjpbXX0sInRpbWVzdGFtcCI6eyJuIjoiMTU4ODY3NDU5MzQ2NCIsInNzIjpbXSwibnMiOltdLCJicyI6W10sIm0iOnt9LCJsIjpbXX19",
1214
+ // "max_page_size": 2
1215
+ // }
1216
+ //
1217
+ const withdrawalHistory = this.safeValue(response, 'withdrawal_history', []);
1218
+ return this.parseTransactions(withdrawalHistory, currency, since, limit, { 'type': 'withdrawal' });
1219
+ }
1220
+ async withdraw(code, amount, address, tag = undefined, params = {}) {
1221
+ /**
1222
+ * @method
1223
+ * @name bitpanda#withdraw
1224
+ * @description make a withdrawal
1225
+ * @param {string} code unified currency code
1226
+ * @param {float} amount the amount to withdraw
1227
+ * @param {string} address the address to withdraw to
1228
+ * @param {string} tag
1229
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1230
+ * @returns {object} a [transaction structure]{@link https://docs.ccxt.com/#/?id=transaction-structure}
1231
+ */
1232
+ [tag, params] = this.handleWithdrawTagAndParams(tag, params);
1233
+ this.checkAddress(address);
1234
+ await this.loadMarkets();
1235
+ const currency = this.currency(code);
1236
+ const request = {
1237
+ 'currency': code,
1238
+ 'amount': this.currencyToPrecision(code, amount),
1239
+ // 'payout_account_id': '66756a10-3e86-48f4-9678-b634c4b135b2', // fiat only
1240
+ // 'recipient': { // crypto only
1241
+ // 'address': address,
1242
+ // // 'destination_tag': '',
1243
+ // },
1244
+ };
1245
+ const options = this.safeValue(this.options, 'fiat', []);
1246
+ const isFiat = this.inArray(code, options);
1247
+ const method = isFiat ? 'privatePostAccountWithdrawFiat' : 'privatePostAccountWithdrawCrypto';
1248
+ if (isFiat) {
1249
+ const payoutAccountId = this.safeString(params, 'payout_account_id');
1250
+ if (payoutAccountId === undefined) {
1251
+ throw new errors.ArgumentsRequired(this.id + ' withdraw() requires a payout_account_id param for fiat ' + code + ' withdrawals');
1252
+ }
1253
+ }
1254
+ else {
1255
+ const recipient = { 'address': address };
1256
+ if (tag !== undefined) {
1257
+ recipient['destination_tag'] = tag;
1258
+ }
1259
+ request['recipient'] = recipient;
1260
+ }
1261
+ const response = await this[method](this.extend(request, params));
1262
+ //
1263
+ // crypto
1264
+ //
1265
+ // {
1266
+ // "amount": "1234.5678",
1267
+ // "fee": "1234.5678",
1268
+ // "recipient": "3NacQ7rzZdhfyAtfJ5a11k8jFPdcMP2Bq7",
1269
+ // "destination_tag": "",
1270
+ // "transaction_id": "d0f8529f-f832-4e6a-9dc5-b8d5797badb2"
1271
+ // }
1272
+ //
1273
+ // fiat
1274
+ //
1275
+ // {
1276
+ // "transaction_id": "54236cd0-4413-11e9-93fb-5fea7e5b5df6"
1277
+ // }
1278
+ //
1279
+ return this.parseTransaction(response, currency);
1280
+ }
1281
+ parseTransaction(transaction, currency = undefined) {
1282
+ //
1283
+ // fetchDeposits, fetchWithdrawals
1284
+ //
1285
+ // {
1286
+ // "transaction_id": "C2b42efcd-d5b7-4a56-8e12-b69ffd68c5ef",
1287
+ // "type": "FIAT",
1288
+ // "account_id": "c2d0076a-c20d-41f8-9e9a-1a1d028b2b58",
1289
+ // "amount": "1234.5678",
1290
+ // "time": "2019-08-24T14:15:22Z",
1291
+ // "funds_source": "INTERNAL",
1292
+ // "currency": "BTC",
1293
+ // "fee_amount": "1234.5678",
1294
+ // "fee_currency": "BTC",
1295
+ // "blockchain_transaction_id": "f4184fc596403b9d638783cf57adfe4c75c605f6356fbc91338530e9831e9e16",
1296
+ // "related_transaction_id": "e298341a-3855-405e-bce3-92db368a3157"
1297
+ // }
1298
+ //
1299
+ // withdraw
1300
+ //
1301
+ //
1302
+ // crypto
1303
+ //
1304
+ // {
1305
+ // "amount": "1234.5678",
1306
+ // "fee": "1234.5678",
1307
+ // "recipient": "3NacQ7rzZdhfyAtfJ5a11k8jFPdcMP2Bq7",
1308
+ // "destination_tag": "",
1309
+ // "transaction_id": "d0f8529f-f832-4e6a-9dc5-b8d5797badb2"
1310
+ // }
1311
+ //
1312
+ // fiat
1313
+ //
1314
+ // {
1315
+ // "transaction_id": "54236cd0-4413-11e9-93fb-5fea7e5b5df6"
1316
+ // }
1317
+ //
1318
+ const id = this.safeString(transaction, 'transaction_id');
1319
+ const amount = this.safeNumber(transaction, 'amount');
1320
+ const timestamp = this.parse8601(this.safeString(transaction, 'time'));
1321
+ const currencyId = this.safeString(transaction, 'currency');
1322
+ currency = this.safeCurrency(currencyId, currency);
1323
+ const status = 'ok'; // the exchange returns cleared transactions only
1324
+ const feeCost = this.safeNumber2(transaction, 'fee_amount', 'fee');
1325
+ let fee = undefined;
1326
+ const addressTo = this.safeString(transaction, 'recipient');
1327
+ const tagTo = this.safeString(transaction, 'destination_tag');
1328
+ if (feeCost !== undefined) {
1329
+ const feeCurrencyId = this.safeString(transaction, 'fee_currency', currencyId);
1330
+ const feeCurrencyCode = this.safeCurrencyCode(feeCurrencyId);
1331
+ fee = {
1332
+ 'cost': feeCost,
1333
+ 'currency': feeCurrencyCode,
1334
+ };
1335
+ }
1336
+ return {
1337
+ 'info': transaction,
1338
+ 'id': id,
1339
+ 'currency': currency['code'],
1340
+ 'amount': amount,
1341
+ 'network': undefined,
1342
+ 'address': addressTo,
1343
+ 'addressFrom': undefined,
1344
+ 'addressTo': addressTo,
1345
+ 'tag': tagTo,
1346
+ 'tagFrom': undefined,
1347
+ 'tagTo': tagTo,
1348
+ 'status': status,
1349
+ 'type': undefined,
1350
+ 'updated': undefined,
1351
+ 'txid': this.safeString(transaction, 'blockchain_transaction_id'),
1352
+ 'comment': undefined,
1353
+ 'internal': undefined,
1354
+ 'timestamp': timestamp,
1355
+ 'datetime': this.iso8601(timestamp),
1356
+ 'fee': fee,
1357
+ };
1358
+ }
1359
+ parseOrderStatus(status) {
1360
+ const statuses = {
1361
+ 'FILLED': 'open',
1362
+ 'FILLED_FULLY': 'closed',
1363
+ 'FILLED_CLOSED': 'canceled',
1364
+ 'FILLED_REJECTED': 'rejected',
1365
+ 'OPEN': 'open',
1366
+ 'REJECTED': 'rejected',
1367
+ 'CLOSED': 'canceled',
1368
+ 'FAILED': 'failed',
1369
+ 'STOP_TRIGGERED': 'triggered',
1370
+ };
1371
+ return this.safeString(statuses, status, status);
1372
+ }
1373
+ parseOrder(order, market = undefined) {
1374
+ //
1375
+ // createOrder
1376
+ //
1377
+ // {
1378
+ // "order_id": "d5492c24-2995-4c18-993a-5b8bf8fffc0d",
1379
+ // "client_id": "d75fb03b-b599-49e9-b926-3f0b6d103206",
1380
+ // "account_id": "a4c699f6-338d-4a26-941f-8f9853bfc4b9",
1381
+ // "instrument_code": "BTC_EUR",
1382
+ // "time": "2019-08-01T08:00:44.026Z",
1383
+ // "side": "BUY",
1384
+ // "price": "5000",
1385
+ // "amount": "1",
1386
+ // "filled_amount": "0.5",
1387
+ // "type": "LIMIT",
1388
+ // "time_in_force": "GOOD_TILL_CANCELLED"
1389
+ // }
1390
+ //
1391
+ // fetchOrder, fetchOpenOrders, fetchClosedOrders
1392
+ //
1393
+ // {
1394
+ // "order": {
1395
+ // "order_id": "66756a10-3e86-48f4-9678-b634c4b135b2",
1396
+ // "account_id": "1eb2ad5d-55f1-40b5-bc92-7dc05869e905",
1397
+ // "instrument_code": "BTC_EUR",
1398
+ // "amount": "1234.5678",
1399
+ // "filled_amount": "1234.5678",
1400
+ // "side": "BUY",
1401
+ // "type": "LIMIT",
1402
+ // "status": "OPEN",
1403
+ // "sequence": 123456789,
1404
+ // "price": "1234.5678",
1405
+ // "average_price": "1234.5678",
1406
+ // "reason": "INSUFFICIENT_FUNDS",
1407
+ // "time": "2019-08-24T14:15:22Z",
1408
+ // "time_in_force": "GOOD_TILL_CANCELLED",
1409
+ // "time_last_updated": "2019-08-24T14:15:22Z",
1410
+ // "expire_after": "2019-08-24T14:15:22Z",
1411
+ // "is_post_only": false,
1412
+ // "time_triggered": "2019-08-24T14:15:22Z",
1413
+ // "trigger_price": "1234.5678"
1414
+ // },
1415
+ // "trades": [
1416
+ // {
1417
+ // "fee": {
1418
+ // "fee_amount": "0.0014",
1419
+ // "fee_currency": "BTC",
1420
+ // "fee_percentage": "0.1",
1421
+ // "fee_group_id": "default",
1422
+ // "fee_type": "TAKER",
1423
+ // "running_trading_volume": "0.0"
1424
+ // },
1425
+ // "trade": {
1426
+ // "trade_id": "fdff2bcc-37d6-4a2d-92a5-46e09c868664",
1427
+ // "order_id": "36bb2437-7402-4794-bf26-4bdf03526439",
1428
+ // "account_id": "a4c699f6-338d-4a26-941f-8f9853bfc4b9",
1429
+ // "amount": "1.4",
1430
+ // "side": "BUY",
1431
+ // "instrument_code": "BTC_EUR",
1432
+ // "price": "7341.4",
1433
+ // "time": "2019-09-27T15:05:32.564Z",
1434
+ // "sequence": 48670
1435
+ // }
1436
+ // }
1437
+ // ]
1438
+ // }
1439
+ //
1440
+ const rawOrder = this.safeValue(order, 'order', order);
1441
+ const id = this.safeString(rawOrder, 'order_id');
1442
+ const clientOrderId = this.safeString(rawOrder, 'client_id');
1443
+ const timestamp = this.parse8601(this.safeString(rawOrder, 'time'));
1444
+ const rawStatus = this.parseOrderStatus(this.safeString(rawOrder, 'status'));
1445
+ const status = this.parseOrderStatus(rawStatus);
1446
+ const marketId = this.safeString(rawOrder, 'instrument_code');
1447
+ const symbol = this.safeSymbol(marketId, market, '_');
1448
+ const price = this.safeString(rawOrder, 'price');
1449
+ const amount = this.safeString(rawOrder, 'amount');
1450
+ const filled = this.safeString(rawOrder, 'filled_amount');
1451
+ const side = this.safeStringLower(rawOrder, 'side');
1452
+ const type = this.safeStringLower(rawOrder, 'type');
1453
+ const timeInForce = this.parseTimeInForce(this.safeString(rawOrder, 'time_in_force'));
1454
+ const stopPrice = this.safeNumber(rawOrder, 'trigger_price');
1455
+ const postOnly = this.safeValue(rawOrder, 'is_post_only');
1456
+ const rawTrades = this.safeValue(order, 'trades', []);
1457
+ return this.safeOrder({
1458
+ 'id': id,
1459
+ 'clientOrderId': clientOrderId,
1460
+ 'info': order,
1461
+ 'timestamp': timestamp,
1462
+ 'datetime': this.iso8601(timestamp),
1463
+ 'lastTradeTimestamp': undefined,
1464
+ 'symbol': symbol,
1465
+ 'type': type,
1466
+ 'timeInForce': timeInForce,
1467
+ 'postOnly': postOnly,
1468
+ 'side': side,
1469
+ 'price': price,
1470
+ 'stopPrice': stopPrice,
1471
+ 'triggerPrice': stopPrice,
1472
+ 'amount': amount,
1473
+ 'cost': undefined,
1474
+ 'average': undefined,
1475
+ 'filled': filled,
1476
+ 'remaining': undefined,
1477
+ 'status': status,
1478
+ // 'fee': undefined,
1479
+ 'trades': rawTrades,
1480
+ }, market);
1481
+ }
1482
+ parseTimeInForce(timeInForce) {
1483
+ const timeInForces = {
1484
+ 'GOOD_TILL_CANCELLED': 'GTC',
1485
+ 'GOOD_TILL_TIME': 'GTT',
1486
+ 'IMMEDIATE_OR_CANCELLED': 'IOC',
1487
+ 'FILL_OR_KILL': 'FOK',
1488
+ };
1489
+ return this.safeString(timeInForces, timeInForce, timeInForce);
1490
+ }
1491
+ async createOrder(symbol, type, side, amount, price = undefined, params = {}) {
1492
+ /**
1493
+ * @method
1494
+ * @name bitpanda#createOrder
1495
+ * @description create a trade order
1496
+ * @see https://docs.onetrading.com/#create-order
1497
+ * @param {string} symbol unified symbol of the market to create an order in
1498
+ * @param {string} type 'market' or 'limit'
1499
+ * @param {string} side 'buy' or 'sell'
1500
+ * @param {float} amount how much of currency you want to trade in units of base currency
1501
+ * @param {float} [price] the price at which the order is to be fullfilled, in units of the quote currency, ignored in market orders
1502
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1503
+ * @param {float} [params.triggerPrice] bitpanda only does stop limit orders and does not do stop market
1504
+ * @returns {object} an [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1505
+ */
1506
+ await this.loadMarkets();
1507
+ const market = this.market(symbol);
1508
+ const uppercaseType = type.toUpperCase();
1509
+ const request = {
1510
+ 'instrument_code': market['id'],
1511
+ 'type': uppercaseType,
1512
+ 'side': side.toUpperCase(),
1513
+ 'amount': this.amountToPrecision(symbol, amount),
1514
+ // "price": "1234.5678", // required for LIMIT and STOP orders
1515
+ // "client_id": "d75fb03b-b599-49e9-b926-3f0b6d103206", // optional
1516
+ // "time_in_force": "GOOD_TILL_CANCELLED", // limit orders only, GOOD_TILL_CANCELLED, GOOD_TILL_TIME, IMMEDIATE_OR_CANCELLED and FILL_OR_KILL
1517
+ // "expire_after": "2020-07-02T19:40:13Z", // required for GOOD_TILL_TIME
1518
+ // "is_post_only": false, // limit orders only, optional
1519
+ // "trigger_price": "1234.5678" // required for stop orders
1520
+ };
1521
+ let priceIsRequired = false;
1522
+ if (uppercaseType === 'LIMIT' || uppercaseType === 'STOP') {
1523
+ priceIsRequired = true;
1524
+ }
1525
+ const triggerPrice = this.safeNumberN(params, ['triggerPrice', 'trigger_price', 'stopPrice']);
1526
+ if (triggerPrice !== undefined) {
1527
+ if (uppercaseType === 'MARKET') {
1528
+ throw new errors.BadRequest(this.id + ' createOrder() cannot place stop market orders, only stop limit');
1529
+ }
1530
+ request['trigger_price'] = this.priceToPrecision(symbol, triggerPrice);
1531
+ request['type'] = 'STOP';
1532
+ params = this.omit(params, ['triggerPrice', 'trigger_price', 'stopPrice']);
1533
+ }
1534
+ else if (uppercaseType === 'STOP') {
1535
+ throw new errors.ArgumentsRequired(this.id + ' createOrder() requires a triggerPrice param for ' + type + ' orders');
1536
+ }
1537
+ if (priceIsRequired) {
1538
+ request['price'] = this.priceToPrecision(symbol, price);
1539
+ }
1540
+ const clientOrderId = this.safeString2(params, 'clientOrderId', 'client_id');
1541
+ if (clientOrderId !== undefined) {
1542
+ request['client_id'] = clientOrderId;
1543
+ params = this.omit(params, ['clientOrderId', 'client_id']);
1544
+ }
1545
+ const response = await this.privatePostAccountOrders(this.extend(request, params));
1546
+ //
1547
+ // {
1548
+ // "order_id": "d5492c24-2995-4c18-993a-5b8bf8fffc0d",
1549
+ // "client_id": "d75fb03b-b599-49e9-b926-3f0b6d103206",
1550
+ // "account_id": "a4c699f6-338d-4a26-941f-8f9853bfc4b9",
1551
+ // "instrument_code": "BTC_EUR",
1552
+ // "time": "2019-08-01T08:00:44.026Z",
1553
+ // "side": "BUY",
1554
+ // "price": "5000",
1555
+ // "amount": "1",
1556
+ // "filled_amount": "0.5",
1557
+ // "type": "LIMIT",
1558
+ // "time_in_force": "GOOD_TILL_CANCELLED"
1559
+ // }
1560
+ //
1561
+ return this.parseOrder(response, market);
1562
+ }
1563
+ async cancelOrder(id, symbol = undefined, params = {}) {
1564
+ /**
1565
+ * @method
1566
+ * @name bitpanda#cancelOrder
1567
+ * @description cancels an open order
1568
+ * @param {string} id order id
1569
+ * @param {string} symbol not used by bitmex cancelOrder ()
1570
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1571
+ * @returns {object} An [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1572
+ */
1573
+ await this.loadMarkets();
1574
+ const clientOrderId = this.safeString2(params, 'clientOrderId', 'client_id');
1575
+ params = this.omit(params, ['clientOrderId', 'client_id']);
1576
+ let method = 'privateDeleteAccountOrdersOrderId';
1577
+ const request = {};
1578
+ if (clientOrderId !== undefined) {
1579
+ method = 'privateDeleteAccountOrdersClientClientId';
1580
+ request['client_id'] = clientOrderId;
1581
+ }
1582
+ else {
1583
+ request['order_id'] = id;
1584
+ }
1585
+ const response = await this[method](this.extend(request, params));
1586
+ //
1587
+ // responds with an empty body
1588
+ //
1589
+ return response;
1590
+ }
1591
+ async cancelAllOrders(symbol = undefined, params = {}) {
1592
+ /**
1593
+ * @method
1594
+ * @name bitpanda#cancelAllOrders
1595
+ * @description cancel all open orders
1596
+ * @param {string} symbol unified market symbol, only orders in the market of this symbol are cancelled when symbol is not undefined
1597
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1598
+ * @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1599
+ */
1600
+ await this.loadMarkets();
1601
+ const request = {};
1602
+ if (symbol !== undefined) {
1603
+ const market = this.market(symbol);
1604
+ request['instrument_code'] = market['id'];
1605
+ }
1606
+ const response = await this.privateDeleteAccountOrders(this.extend(request, params));
1607
+ //
1608
+ // [
1609
+ // "a10e9bd1-8f72-4cfe-9f1b-7f1c8a9bd8ee"
1610
+ // ]
1611
+ //
1612
+ return response;
1613
+ }
1614
+ async cancelOrders(ids, symbol = undefined, params = {}) {
1615
+ /**
1616
+ * @method
1617
+ * @name bitpanda#cancelOrders
1618
+ * @description cancel multiple orders
1619
+ * @param {string[]} ids order ids
1620
+ * @param {string} symbol unified market symbol, default is undefined
1621
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1622
+ * @returns {object} an list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1623
+ */
1624
+ await this.loadMarkets();
1625
+ const request = {
1626
+ 'ids': ids.join(','),
1627
+ };
1628
+ const response = await this.privateDeleteAccountOrders(this.extend(request, params));
1629
+ //
1630
+ // [
1631
+ // "a10e9bd1-8f72-4cfe-9f1b-7f1c8a9bd8ee"
1632
+ // ]
1633
+ //
1634
+ return response;
1635
+ }
1636
+ async fetchOrder(id, symbol = undefined, params = {}) {
1637
+ /**
1638
+ * @method
1639
+ * @name bitpanda#fetchOrder
1640
+ * @description fetches information on an order made by the user
1641
+ * @param {string} symbol not used by bitpanda fetchOrder
1642
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1643
+ * @returns {object} An [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1644
+ */
1645
+ await this.loadMarkets();
1646
+ const request = {
1647
+ 'order_id': id,
1648
+ };
1649
+ const response = await this.privateGetAccountOrdersOrderId(this.extend(request, params));
1650
+ //
1651
+ // {
1652
+ // "order": {
1653
+ // "order_id": "36bb2437-7402-4794-bf26-4bdf03526439",
1654
+ // "account_id": "a4c699f6-338d-4a26-941f-8f9853bfc4b9",
1655
+ // "time_last_updated": "2019-09-27T15:05:35.096Z",
1656
+ // "sequence": 48782,
1657
+ // "price": "7349.2",
1658
+ // "filled_amount": "100.0",
1659
+ // "status": "FILLED_FULLY",
1660
+ // "amount": "100.0",
1661
+ // "instrument_code": "BTC_EUR",
1662
+ // "side": "BUY",
1663
+ // "time": "2019-09-27T15:05:32.063Z",
1664
+ // "type": "MARKET"
1665
+ // },
1666
+ // "trades": [
1667
+ // {
1668
+ // "fee": {
1669
+ // "fee_amount": "0.0014",
1670
+ // "fee_currency": "BTC",
1671
+ // "fee_percentage": "0.1",
1672
+ // "fee_group_id": "default",
1673
+ // "fee_type": "TAKER",
1674
+ // "running_trading_volume": "0.0"
1675
+ // },
1676
+ // "trade": {
1677
+ // "trade_id": "fdff2bcc-37d6-4a2d-92a5-46e09c868664",
1678
+ // "order_id": "36bb2437-7402-4794-bf26-4bdf03526439",
1679
+ // "account_id": "a4c699f6-338d-4a26-941f-8f9853bfc4b9",
1680
+ // "amount": "1.4",
1681
+ // "side": "BUY",
1682
+ // "instrument_code": "BTC_EUR",
1683
+ // "price": "7341.4",
1684
+ // "time": "2019-09-27T15:05:32.564Z",
1685
+ // "sequence": 48670
1686
+ // }
1687
+ // }
1688
+ // ]
1689
+ // }
1690
+ //
1691
+ return this.parseOrder(response);
1692
+ }
1693
+ async fetchOpenOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
1694
+ /**
1695
+ * @method
1696
+ * @name bitpanda#fetchOpenOrders
1697
+ * @description fetch all unfilled currently open orders
1698
+ * @param {string} symbol unified market symbol
1699
+ * @param {int} [since] the earliest time in ms to fetch open orders for
1700
+ * @param {int} [limit] the maximum number of open orders structures to retrieve
1701
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1702
+ * @returns {Order[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1703
+ */
1704
+ await this.loadMarkets();
1705
+ const request = {
1706
+ // 'from': this.iso8601 (since),
1707
+ // 'to': this.iso8601 (this.milliseconds ()), // max range is 100 days
1708
+ // 'instrument_code': market['id'],
1709
+ // 'with_cancelled_and_rejected': false, // default is false, orders which have been cancelled by the user before being filled or rejected by the system as invalid, additionally, all inactive filled orders which would return with "with_just_filled_inactive"
1710
+ // 'with_just_filled_inactive': false, // orders which have been filled and are no longer open, use of "with_cancelled_and_rejected" extends "with_just_filled_inactive" and in case both are specified the latter is ignored
1711
+ // 'with_just_orders': false, // do not return any trades corresponsing to the orders, it may be significanly faster and should be used if user is not interesting in trade information
1712
+ // 'max_page_size': 100,
1713
+ // 'cursor': 'string', // pointer specifying the position from which the next pages should be returned
1714
+ };
1715
+ let market = undefined;
1716
+ if (symbol !== undefined) {
1717
+ market = this.market(symbol);
1718
+ request['instrument_code'] = market['id'];
1719
+ }
1720
+ if (since !== undefined) {
1721
+ const to = this.safeString(params, 'to');
1722
+ if (to === undefined) {
1723
+ throw new errors.ArgumentsRequired(this.id + ' fetchOpenOrders() requires a "to" iso8601 string param with the since argument is specified, max range is 100 days');
1724
+ }
1725
+ request['from'] = this.iso8601(since);
1726
+ }
1727
+ if (limit !== undefined) {
1728
+ request['max_page_size'] = limit;
1729
+ }
1730
+ const response = await this.privateGetAccountOrders(this.extend(request, params));
1731
+ //
1732
+ // {
1733
+ // "order_history": [
1734
+ // {
1735
+ // "order": {
1736
+ // "trigger_price": "12089.88",
1737
+ // "order_id": "d453ca12-c650-46dd-9dee-66910d96bfc0",
1738
+ // "account_id": "ef3a5f4c-cfcd-415e-ba89-5a9abf47b28a",
1739
+ // "instrument_code": "BTC_USDT",
1740
+ // "time": "2019-08-23T10:02:31.663Z",
1741
+ // "side": "SELL",
1742
+ // "price": "10159.76",
1743
+ // "average_price": "10159.76",
1744
+ // "amount": "0.2",
1745
+ // "filled_amount": "0.2",
1746
+ // "type": "STOP",
1747
+ // "sequence": 8,
1748
+ // "status": "FILLED_FULLY"
1749
+ // },
1750
+ // "trades": [
1751
+ // {
1752
+ // "fee": {
1753
+ // "fee_amount": "0.4188869",
1754
+ // "fee_currency": "USDT",
1755
+ // "fee_percentage": "0.1",
1756
+ // "fee_group_id": "default",
1757
+ // "fee_type": "TAKER",
1758
+ // "running_trading_volume": "0.0"
1759
+ // },
1760
+ // "trade": {
1761
+ // "trade_id": "ec82896f-fd1b-4cbb-89df-a9da85ccbb4b",
1762
+ // "order_id": "d453ca12-c650-46dd-9dee-66910d96bfc0",
1763
+ // "account_id": "ef3a5f4c-cfcd-415e-ba89-5a9abf47b28a",
1764
+ // "amount": "0.2",
1765
+ // "side": "SELL",
1766
+ // "instrument_code": "BTC_USDT",
1767
+ // "price": "10159.76",
1768
+ // "time": "2019-08-23T10:02:32.663Z",
1769
+ // "sequence": 9
1770
+ // }
1771
+ // }
1772
+ // ]
1773
+ // },
1774
+ // {
1775
+ // "order": {
1776
+ // "order_id": "5151a99e-f414-418f-8cf1-2568d0a63ea5",
1777
+ // "account_id": "ef3a5f4c-cfcd-415e-ba89-5a9abf47b28a",
1778
+ // "instrument_code": "BTC_USDT",
1779
+ // "time": "2019-08-23T10:01:36.773Z",
1780
+ // "side": "SELL",
1781
+ // "price": "12289.88",
1782
+ // "amount": "0.5",
1783
+ // "filled_amount": "0.0",
1784
+ // "type": "LIMIT",
1785
+ // "sequence": 7,
1786
+ // "status": "OPEN"
1787
+ // },
1788
+ // "trades": []
1789
+ // },
1790
+ // {
1791
+ // "order": {
1792
+ // "order_id": "ac80d857-75e1-4733-9070-fd4288395fdc",
1793
+ // "account_id": "ef3a5f4c-cfcd-415e-ba89-5a9abf47b28a",
1794
+ // "instrument_code": "BTC_USDT",
1795
+ // "time": "2019-08-23T10:01:25.031Z",
1796
+ // "side": "SELL",
1797
+ // "price": "11089.88",
1798
+ // "amount": "0.1",
1799
+ // "filled_amount": "0.0",
1800
+ // "type": "LIMIT",
1801
+ // "sequence": 6,
1802
+ // "status": "OPEN"
1803
+ // },
1804
+ // "trades": []
1805
+ // }
1806
+ // ],
1807
+ // "max_page_size": 100
1808
+ // }
1809
+ //
1810
+ const orderHistory = this.safeValue(response, 'order_history', []);
1811
+ return this.parseOrders(orderHistory, market, since, limit);
1812
+ }
1813
+ async fetchClosedOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
1814
+ /**
1815
+ * @method
1816
+ * @name bitpanda#fetchClosedOrders
1817
+ * @description fetches information on multiple closed orders made by the user
1818
+ * @param {string} symbol unified market symbol of the market orders were made in
1819
+ * @param {int} [since] the earliest time in ms to fetch orders for
1820
+ * @param {int} [limit] the maximum number of order structures to retrieve
1821
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1822
+ * @returns {Order[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1823
+ */
1824
+ const request = {
1825
+ 'with_cancelled_and_rejected': true, // default is false, orders which have been cancelled by the user before being filled or rejected by the system as invalid, additionally, all inactive filled orders which would return with "with_just_filled_inactive"
1826
+ };
1827
+ return await this.fetchOpenOrders(symbol, since, limit, this.extend(request, params));
1828
+ }
1829
+ async fetchOrderTrades(id, symbol = undefined, since = undefined, limit = undefined, params = {}) {
1830
+ /**
1831
+ * @method
1832
+ * @name bitpanda#fetchOrderTrades
1833
+ * @description fetch all the trades made from a single order
1834
+ * @param {string} id order id
1835
+ * @param {string} symbol unified market symbol
1836
+ * @param {int} [since] the earliest time in ms to fetch trades for
1837
+ * @param {int} [limit] the maximum number of trades to retrieve
1838
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1839
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure}
1840
+ */
1841
+ await this.loadMarkets();
1842
+ const request = {
1843
+ 'order_id': id,
1844
+ // 'max_page_size': 100,
1845
+ // 'cursor': 'string', // pointer specifying the position from which the next pages should be returned
1846
+ };
1847
+ if (limit !== undefined) {
1848
+ request['max_page_size'] = limit;
1849
+ }
1850
+ const response = await this.privateGetAccountOrdersOrderIdTrades(this.extend(request, params));
1851
+ //
1852
+ // {
1853
+ // "trade_history": [
1854
+ // {
1855
+ // "trade": {
1856
+ // "trade_id": "2b42efcd-d5b7-4a56-8e12-b69ffd68c5ef",
1857
+ // "order_id": "66756a10-3e86-48f4-9678-b634c4b135b2",
1858
+ // "account_id": "c2d0076a-c20d-41f8-9e9a-1a1d028b2b58",
1859
+ // "amount": "1234.5678",
1860
+ // "side": "BUY",
1861
+ // "instrument_code": "BTC_EUR",
1862
+ // "price": "1234.5678",
1863
+ // "time": "2019-08-24T14:15:22Z",
1864
+ // "price_tick_sequence": 0,
1865
+ // "sequence": 123456789
1866
+ // },
1867
+ // "fee": {
1868
+ // "fee_amount": "1234.5678",
1869
+ // "fee_percentage": "1234.5678",
1870
+ // "fee_group_id": "default",
1871
+ // "running_trading_volume": "1234.5678",
1872
+ // "fee_currency": "BTC",
1873
+ // "fee_type": "TAKER"
1874
+ // }
1875
+ // }
1876
+ // ],
1877
+ // "max_page_size": 0,
1878
+ // "cursor": "string"
1879
+ // }
1880
+ //
1881
+ const tradeHistory = this.safeValue(response, 'trade_history', []);
1882
+ let market = undefined;
1883
+ if (symbol !== undefined) {
1884
+ market = this.market(symbol);
1885
+ }
1886
+ return this.parseTrades(tradeHistory, market, since, limit);
1887
+ }
1888
+ async fetchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
1889
+ /**
1890
+ * @method
1891
+ * @name bitpanda#fetchMyTrades
1892
+ * @description fetch all trades made by the user
1893
+ * @param {string} symbol unified market symbol
1894
+ * @param {int} [since] the earliest time in ms to fetch trades for
1895
+ * @param {int} [limit] the maximum number of trades structures to retrieve
1896
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1897
+ * @returns {Trade[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure}
1898
+ */
1899
+ await this.loadMarkets();
1900
+ const request = {
1901
+ // 'from': this.iso8601 (since),
1902
+ // 'to': this.iso8601 (this.milliseconds ()), // max range is 100 days
1903
+ // 'instrument_code': market['id'],
1904
+ // 'max_page_size': 100,
1905
+ // 'cursor': 'string', // pointer specifying the position from which the next pages should be returned
1906
+ };
1907
+ let market = undefined;
1908
+ if (symbol !== undefined) {
1909
+ market = this.market(symbol);
1910
+ request['instrument_code'] = market['id'];
1911
+ }
1912
+ if (since !== undefined) {
1913
+ const to = this.safeString(params, 'to');
1914
+ if (to === undefined) {
1915
+ throw new errors.ArgumentsRequired(this.id + ' fetchMyTrades() requires a "to" iso8601 string param with the since argument is specified, max range is 100 days');
1916
+ }
1917
+ request['from'] = this.iso8601(since);
1918
+ }
1919
+ if (limit !== undefined) {
1920
+ request['max_page_size'] = limit;
1921
+ }
1922
+ const response = await this.privateGetAccountTrades(this.extend(request, params));
1923
+ //
1924
+ // {
1925
+ // "trade_history": [
1926
+ // {
1927
+ // "trade": {
1928
+ // "trade_id": "2b42efcd-d5b7-4a56-8e12-b69ffd68c5ef",
1929
+ // "order_id": "66756a10-3e86-48f4-9678-b634c4b135b2",
1930
+ // "account_id": "c2d0076a-c20d-41f8-9e9a-1a1d028b2b58",
1931
+ // "amount": "1234.5678",
1932
+ // "side": "BUY",
1933
+ // "instrument_code": "BTC_EUR",
1934
+ // "price": "1234.5678",
1935
+ // "time": "2019-08-24T14:15:22Z",
1936
+ // "price_tick_sequence": 0,
1937
+ // "sequence": 123456789
1938
+ // },
1939
+ // "fee": {
1940
+ // "fee_amount": "1234.5678",
1941
+ // "fee_percentage": "1234.5678",
1942
+ // "fee_group_id": "default",
1943
+ // "running_trading_volume": "1234.5678",
1944
+ // "fee_currency": "BTC",
1945
+ // "fee_type": "TAKER"
1946
+ // }
1947
+ // }
1948
+ // ],
1949
+ // "max_page_size": 0,
1950
+ // "cursor": "string"
1951
+ // }
1952
+ //
1953
+ const tradeHistory = this.safeValue(response, 'trade_history', []);
1954
+ return this.parseTrades(tradeHistory, market, since, limit);
1955
+ }
1956
+ sign(path, api = 'public', method = 'GET', params = {}, headers = undefined, body = undefined) {
1957
+ let url = this.urls['api'][api] + '/' + this.version + '/' + this.implodeParams(path, params);
1958
+ const query = this.omit(params, this.extractParams(path));
1959
+ if (api === 'public') {
1960
+ if (Object.keys(query).length) {
1961
+ url += '?' + this.urlencode(query);
1962
+ }
1963
+ }
1964
+ else if (api === 'private') {
1965
+ this.checkRequiredCredentials();
1966
+ headers = {
1967
+ 'Accept': 'application/json',
1968
+ 'Authorization': 'Bearer ' + this.apiKey,
1969
+ };
1970
+ if (method === 'POST') {
1971
+ body = this.json(query);
1972
+ headers['Content-Type'] = 'application/json';
1973
+ }
1974
+ else {
1975
+ if (Object.keys(query).length) {
1976
+ url += '?' + this.urlencode(query);
1977
+ }
1978
+ }
1979
+ }
1980
+ return { 'url': url, 'method': method, 'body': body, 'headers': headers };
1981
+ }
1982
+ handleErrors(code, reason, url, method, headers, body, response, requestHeaders, requestBody) {
1983
+ if (response === undefined) {
1984
+ return undefined;
1985
+ }
1986
+ //
1987
+ // {"error":"MISSING_FROM_PARAM"}
1988
+ // {"error":"MISSING_TO_PARAM"}
1989
+ // {"error":"CANDLESTICKS_TIME_RANGE_TOO_BIG"}
1990
+ //
1991
+ const message = this.safeString(response, 'error');
1992
+ if (message !== undefined) {
1993
+ const feedback = this.id + ' ' + body;
1994
+ this.throwExactlyMatchedException(this.exceptions['exact'], message, feedback);
1995
+ this.throwBroadlyMatchedException(this.exceptions['broad'], message, feedback);
1996
+ throw new errors.ExchangeError(feedback); // unknown message
1997
+ }
1998
+ return undefined;
1999
+ }
2000
+ }
2001
+
2002
+ module.exports = bitpanda;