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,1933 @@
1
+ 'use strict';
2
+
3
+ var coinsph$1 = require('./abstract/coinsph.js');
4
+ var errors = require('./base/errors.js');
5
+ var number = require('./base/functions/number.js');
6
+ var Precise = require('./base/Precise.js');
7
+ var sha256 = require('./static_dependencies/noble-hashes/sha256.js');
8
+
9
+ /**
10
+ * @class coinsph
11
+ * @augments Exchange
12
+ */
13
+ class coinsph extends coinsph$1 {
14
+ describe() {
15
+ return this.deepExtend(super.describe(), {
16
+ 'id': 'coinsph',
17
+ 'name': 'Coins.ph',
18
+ 'countries': ['PH'],
19
+ 'version': 'v1',
20
+ 'rateLimit': 50,
21
+ 'certified': false,
22
+ 'pro': false,
23
+ 'has': {
24
+ 'CORS': undefined,
25
+ 'spot': true,
26
+ 'margin': false,
27
+ 'swap': false,
28
+ 'future': false,
29
+ 'option': false,
30
+ 'addMargin': false,
31
+ 'cancelAllOrders': true,
32
+ 'cancelOrder': true,
33
+ 'cancelOrders': false,
34
+ 'closeAllPositions': false,
35
+ 'closePosition': false,
36
+ 'createDepositAddress': false,
37
+ 'createMarketBuyOrderWithCost': true,
38
+ 'createMarketOrderWithCost': false,
39
+ 'createMarketSellOrderWithCost': false,
40
+ 'createOrder': true,
41
+ 'createPostOnlyOrder': false,
42
+ 'createReduceOnlyOrder': false,
43
+ 'createStopLimitOrder': true,
44
+ 'createStopMarketOrder': true,
45
+ 'createStopOrder': true,
46
+ 'deposit': true,
47
+ 'editOrder': false,
48
+ 'fetchAccounts': false,
49
+ 'fetchBalance': true,
50
+ 'fetchBidsAsks': false,
51
+ 'fetchBorrowInterest': false,
52
+ 'fetchBorrowRateHistories': false,
53
+ 'fetchBorrowRateHistory': false,
54
+ 'fetchCanceledOrders': false,
55
+ 'fetchClosedOrder': false,
56
+ 'fetchClosedOrders': true,
57
+ 'fetchCrossBorrowRate': false,
58
+ 'fetchCrossBorrowRates': false,
59
+ 'fetchCurrencies': false,
60
+ 'fetchDeposit': undefined,
61
+ 'fetchDepositAddress': true,
62
+ 'fetchDepositAddresses': false,
63
+ 'fetchDepositAddressesByNetwork': false,
64
+ 'fetchDeposits': true,
65
+ 'fetchDepositWithdrawFee': false,
66
+ 'fetchDepositWithdrawFees': false,
67
+ 'fetchFundingHistory': false,
68
+ 'fetchFundingRate': false,
69
+ 'fetchFundingRateHistory': false,
70
+ 'fetchFundingRates': false,
71
+ 'fetchIndexOHLCV': false,
72
+ 'fetchIsolatedBorrowRate': false,
73
+ 'fetchIsolatedBorrowRates': false,
74
+ 'fetchL3OrderBook': false,
75
+ 'fetchLedger': false,
76
+ 'fetchLeverage': false,
77
+ 'fetchLeverageTiers': false,
78
+ 'fetchMarketLeverageTiers': false,
79
+ 'fetchMarkets': true,
80
+ 'fetchMarkOHLCV': false,
81
+ 'fetchMyTrades': true,
82
+ 'fetchOHLCV': true,
83
+ 'fetchOpenInterestHistory': false,
84
+ 'fetchOpenOrder': undefined,
85
+ 'fetchOpenOrders': true,
86
+ 'fetchOrder': true,
87
+ 'fetchOrderBook': true,
88
+ 'fetchOrderBooks': false,
89
+ 'fetchOrders': false,
90
+ 'fetchOrderTrades': true,
91
+ 'fetchPosition': false,
92
+ 'fetchPositions': false,
93
+ 'fetchPositionsRisk': false,
94
+ 'fetchPremiumIndexOHLCV': false,
95
+ 'fetchStatus': true,
96
+ 'fetchTicker': true,
97
+ 'fetchTickers': true,
98
+ 'fetchTime': true,
99
+ 'fetchTrades': true,
100
+ 'fetchTradingFee': true,
101
+ 'fetchTradingFees': true,
102
+ 'fetchTradingLimits': false,
103
+ 'fetchTransactionFee': false,
104
+ 'fetchTransactionFees': false,
105
+ 'fetchTransactions': false,
106
+ 'fetchTransfers': false,
107
+ 'fetchWithdrawal': undefined,
108
+ 'fetchWithdrawals': true,
109
+ 'fetchWithdrawalWhitelist': false,
110
+ 'reduceMargin': false,
111
+ 'repayCrossMargin': false,
112
+ 'repayIsolatedMargin': false,
113
+ 'setLeverage': false,
114
+ 'setMargin': false,
115
+ 'setMarginMode': false,
116
+ 'setPositionMode': false,
117
+ 'signIn': false,
118
+ 'transfer': false,
119
+ 'withdraw': true,
120
+ 'ws': false,
121
+ },
122
+ 'timeframes': {
123
+ '1m': '1m',
124
+ '3m': '3m',
125
+ '5m': '5m',
126
+ '15m': '15m',
127
+ '30m': '30m',
128
+ '1h': '1h',
129
+ '2h': '2h',
130
+ '4h': '4h',
131
+ '6h': '6h',
132
+ '8h': '8h',
133
+ '12h': '12h',
134
+ '1d': '1d',
135
+ '3d': '3d',
136
+ '1w': '1w',
137
+ '1M': '1M',
138
+ },
139
+ 'urls': {
140
+ 'logo': 'https://user-images.githubusercontent.com/1294454/225719995-48ab2026-4ddb-496c-9da7-0d7566617c9b.jpg',
141
+ 'api': {
142
+ 'public': 'https://api.pro.coins.ph',
143
+ 'private': 'https://api.pro.coins.ph',
144
+ },
145
+ 'www': 'https://coins.ph/',
146
+ 'doc': [
147
+ 'https://coins-docs.github.io/rest-api',
148
+ ],
149
+ 'fees': 'https://support.coins.ph/hc/en-us/sections/4407198694681-Limits-Fees',
150
+ },
151
+ 'api': {
152
+ 'public': {
153
+ 'get': {
154
+ 'openapi/v1/ping': 1,
155
+ 'openapi/v1/time': 1,
156
+ // cost 1 if 'symbol' param defined (one market symbol) or if 'symbols' param is a list of 1-20 market symbols
157
+ // cost 20 if 'symbols' param is a list of 21-100 market symbols
158
+ // cost 40 if 'symbols' param is a list of 101 or more market symbols or if both 'symbol' and 'symbols' params are omited
159
+ 'openapi/quote/v1/ticker/24hr': { 'cost': 1, 'noSymbolAndNoSymbols': 40, 'byNumberOfSymbols': [[101, 40], [21, 20], [0, 1]] },
160
+ // cost 1 if 'symbol' param defined (one market symbol)
161
+ // cost 2 if 'symbols' param is a list of 1 or more market symbols or if both 'symbol' and 'symbols' params are omited
162
+ 'openapi/quote/v1/ticker/price': { 'cost': 1, 'noSymbol': 2 },
163
+ // cost 1 if 'symbol' param defined (one market symbol)
164
+ // cost 2 if 'symbols' param is a list of 1 or more market symbols or if both 'symbol' and 'symbols' params are omited
165
+ 'openapi/quote/v1/ticker/bookTicker': { 'cost': 1, 'noSymbol': 2 },
166
+ 'openapi/v1/exchangeInfo': 10,
167
+ // cost 1 if limit <= 100; 5 if limit > 100.
168
+ 'openapi/quote/v1/depth': { 'cost': 1, 'byLimit': [[101, 5], [0, 1]] },
169
+ 'openapi/quote/v1/klines': 1,
170
+ 'openapi/quote/v1/trades': 1,
171
+ 'openapi/v1/pairs': 1,
172
+ 'openapi/quote/v1/avgPrice': 1,
173
+ },
174
+ },
175
+ 'private': {
176
+ 'get': {
177
+ 'openapi/wallet/v1/config/getall': 10,
178
+ 'openapi/wallet/v1/deposit/address': 10,
179
+ 'openapi/wallet/v1/deposit/history': 1,
180
+ 'openapi/wallet/v1/withdraw/history': 1,
181
+ 'openapi/v1/account': 10,
182
+ // cost 3 for a single symbol; 40 when the symbol parameter is omitted
183
+ 'openapi/v1/openOrders': { 'cost': 3, 'noSymbol': 40 },
184
+ 'openapi/v1/asset/tradeFee': 1,
185
+ 'openapi/v1/order': 2,
186
+ // cost 10 with symbol, 40 when the symbol parameter is omitted;
187
+ 'openapi/v1/historyOrders': { 'cost': 10, 'noSymbol': 40 },
188
+ 'openapi/v1/myTrades': 10,
189
+ 'openapi/v1/capital/deposit/history': 1,
190
+ 'openapi/v1/capital/withdraw/history': 1,
191
+ 'openapi/v3/payment-request/get-payment-request': 1,
192
+ 'merchant-api/v1/get-invoices': 1,
193
+ 'openapi/account/v3/crypto-accounts': 1,
194
+ 'openapi/transfer/v3/transfers/{id}': 1,
195
+ },
196
+ 'post': {
197
+ 'openapi/wallet/v1/withdraw/apply': 600,
198
+ 'openapi/v1/order/test': 1,
199
+ 'openapi/v1/order': 1,
200
+ 'openapi/v1/capital/withdraw/apply': 1,
201
+ 'openapi/v1/capital/deposit/apply': 1,
202
+ 'openapi/v3/payment-request/payment-requests': 1,
203
+ 'openapi/v3/payment-request/delete-payment-request': 1,
204
+ 'openapi/v3/payment-request/payment-request-reminder': 1,
205
+ 'openapi/v1/userDataStream': 1,
206
+ 'merchant-api/v1/invoices': 1,
207
+ 'merchant-api/v1/invoices-cancel': 1,
208
+ 'openapi/convert/v1/get-supported-trading-pairs': 1,
209
+ 'openapi/convert/v1/get-quote': 1,
210
+ 'openapi/convert/v1/accpet-quote': 1,
211
+ 'openapi/fiat/v1/support-channel': 1,
212
+ 'openapi/fiat/v1/cash-out': 1,
213
+ 'openapi/fiat/v1/history': 1,
214
+ 'openapi/migration/v4/sellorder': 1,
215
+ 'openapi/migration/v4/validate-field': 1,
216
+ 'openapi/transfer/v3/transfers': 1,
217
+ },
218
+ 'delete': {
219
+ 'openapi/v1/order': 1,
220
+ 'openapi/v1/openOrders': 1,
221
+ 'openapi/v1/userDataStream': 1,
222
+ },
223
+ },
224
+ },
225
+ 'fees': {
226
+ // todo: zero fees for USDT, ETH and BTC markets till 2023-04-02
227
+ 'trading': {
228
+ 'feeSide': 'get',
229
+ 'tierBased': true,
230
+ 'percentage': true,
231
+ 'maker': this.parseNumber('0.0025'),
232
+ 'taker': this.parseNumber('0.003'),
233
+ 'tiers': {
234
+ 'taker': [
235
+ [this.parseNumber('0'), this.parseNumber('0.003')],
236
+ [this.parseNumber('500000'), this.parseNumber('0.0027')],
237
+ [this.parseNumber('1000000'), this.parseNumber('0.0024')],
238
+ [this.parseNumber('2500000'), this.parseNumber('0.002')],
239
+ [this.parseNumber('5000000'), this.parseNumber('0.0018')],
240
+ [this.parseNumber('10000000'), this.parseNumber('0.0015')],
241
+ [this.parseNumber('100000000'), this.parseNumber('0.0012')],
242
+ [this.parseNumber('500000000'), this.parseNumber('0.0009')],
243
+ [this.parseNumber('1000000000'), this.parseNumber('0.0007')],
244
+ [this.parseNumber('2500000000'), this.parseNumber('0.0005')],
245
+ ],
246
+ 'maker': [
247
+ [this.parseNumber('0'), this.parseNumber('0.0025')],
248
+ [this.parseNumber('500000'), this.parseNumber('0.0022')],
249
+ [this.parseNumber('1000000'), this.parseNumber('0.0018')],
250
+ [this.parseNumber('2500000'), this.parseNumber('0.0015')],
251
+ [this.parseNumber('5000000'), this.parseNumber('0.0012')],
252
+ [this.parseNumber('10000000'), this.parseNumber('0.001')],
253
+ [this.parseNumber('100000000'), this.parseNumber('0.0008')],
254
+ [this.parseNumber('500000000'), this.parseNumber('0.0007')],
255
+ [this.parseNumber('1000000000'), this.parseNumber('0.0006')],
256
+ [this.parseNumber('2500000000'), this.parseNumber('0.0005')],
257
+ ],
258
+ },
259
+ },
260
+ },
261
+ 'precisionMode': number.TICK_SIZE,
262
+ // exchange-specific options
263
+ 'options': {
264
+ 'createMarketBuyOrderRequiresPrice': true,
265
+ 'withdraw': {
266
+ 'warning': false,
267
+ },
268
+ 'deposit': {
269
+ 'warning': false,
270
+ },
271
+ 'createOrder': {
272
+ 'timeInForce': 'GTC',
273
+ 'newOrderRespType': {
274
+ 'market': 'FULL',
275
+ 'limit': 'FULL', // we change it from 'ACK' by default to 'FULL'
276
+ },
277
+ },
278
+ 'fetchTicker': {
279
+ 'method': 'publicGetOpenapiQuoteV1Ticker24hr', // publicGetOpenapiQuoteV1TickerPrice, publicGetOpenapiQuoteV1TickerBookTicker
280
+ },
281
+ 'fetchTickers': {
282
+ 'method': 'publicGetOpenapiQuoteV1Ticker24hr', // publicGetOpenapiQuoteV1TickerPrice, publicGetOpenapiQuoteV1TickerBookTicker
283
+ },
284
+ 'networks': {
285
+ // all networks: 'ETH', 'TRX', 'BSC', 'ARBITRUM', 'RON', 'BTC', 'XRP'
286
+ // you can call api privateGetOpenapiWalletV1ConfigGetall to check which network is supported for the currency
287
+ 'TRC20': 'TRX',
288
+ 'ERC20': 'ETH',
289
+ 'BEP20': 'BSC',
290
+ 'ARB': 'ARBITRUM',
291
+ },
292
+ },
293
+ // https://coins-docs.github.io/errors/
294
+ 'exceptions': {
295
+ 'exact': {
296
+ '-1000': errors.BadRequest,
297
+ '-1001': errors.BadRequest,
298
+ '-1002': errors.AuthenticationError,
299
+ '-1003': errors.RateLimitExceeded,
300
+ '-1004': errors.InvalidOrder,
301
+ '-1006': errors.BadResponse,
302
+ '-1007': errors.BadResponse,
303
+ '-1014': errors.InvalidOrder,
304
+ '-1015': errors.RateLimitExceeded,
305
+ '-1016': errors.NotSupported,
306
+ '-1020': errors.NotSupported,
307
+ '-1021': errors.BadRequest,
308
+ '-1022': errors.BadRequest,
309
+ '-1023': errors.AuthenticationError,
310
+ '-1024': errors.BadRequest,
311
+ '-1025': errors.BadRequest,
312
+ '-1030': errors.ExchangeError,
313
+ '-1100': errors.BadRequest,
314
+ '-1101': errors.BadRequest,
315
+ '-1102': errors.BadRequest,
316
+ '-1103': errors.BadRequest,
317
+ '-1104': errors.BadRequest,
318
+ '-1105': errors.BadRequest,
319
+ '-1106': errors.BadRequest,
320
+ '-1111': errors.BadRequest,
321
+ '-1112': errors.BadResponse,
322
+ '-1114': errors.BadRequest,
323
+ '-1115': errors.InvalidOrder,
324
+ '-1116': errors.InvalidOrder,
325
+ '-1117': errors.InvalidOrder,
326
+ '-1118': errors.InvalidOrder,
327
+ '-1119': errors.InvalidOrder,
328
+ '-1120': errors.BadRequest,
329
+ '-1121': errors.BadSymbol,
330
+ '-1122': errors.InvalidOrder,
331
+ '-1125': errors.BadRequest,
332
+ '-1127': errors.BadRequest,
333
+ '-1128': errors.BadRequest,
334
+ '-1130': errors.BadRequest,
335
+ '-1131': errors.InsufficientFunds,
336
+ '-1132': errors.InvalidOrder,
337
+ '-1133': errors.InvalidOrder,
338
+ '-1134': errors.InvalidOrder,
339
+ '-1135': errors.InvalidOrder,
340
+ '-1136': errors.InvalidOrder,
341
+ '-1137': errors.InvalidOrder,
342
+ '-1138': errors.InvalidOrder,
343
+ '-1139': errors.InvalidOrder,
344
+ '-1140': errors.InvalidOrder,
345
+ '-1141': errors.DuplicateOrderId,
346
+ '-1142': errors.InvalidOrder,
347
+ '-1143': errors.OrderNotFound,
348
+ '-1144': errors.InvalidOrder,
349
+ '-1145': errors.InvalidOrder,
350
+ '-1146': errors.InvalidOrder,
351
+ '-1147': errors.InvalidOrder,
352
+ '-1148': errors.InvalidOrder,
353
+ '-1149': errors.InvalidOrder,
354
+ '-1150': errors.InvalidOrder,
355
+ '-1151': errors.BadSymbol,
356
+ '-1152': errors.NotSupported,
357
+ '-1153': errors.AuthenticationError,
358
+ '-1154': errors.BadRequest,
359
+ '-1155': errors.BadRequest,
360
+ '-1156': errors.InvalidOrder,
361
+ '-1157': errors.BadSymbol,
362
+ '-1158': errors.InvalidOrder,
363
+ '-1159': errors.InvalidOrder,
364
+ '-1160': errors.BadRequest,
365
+ '-1161': errors.BadRequest,
366
+ '-2010': errors.InvalidOrder,
367
+ '-2013': errors.OrderNotFound,
368
+ '-2011': errors.BadRequest,
369
+ '-2014': errors.BadRequest,
370
+ '-2015': errors.AuthenticationError,
371
+ '-2016': errors.BadResponse,
372
+ '-3126': errors.InvalidOrder,
373
+ '-3127': errors.InvalidOrder,
374
+ '-4001': errors.BadRequest,
375
+ '-100011': errors.BadSymbol,
376
+ '-100012': errors.BadSymbol,
377
+ '-30008': errors.InsufficientFunds,
378
+ '-30036': errors.InsufficientFunds,
379
+ '403': errors.ExchangeNotAvailable,
380
+ },
381
+ 'broad': {
382
+ 'Unknown order sent': errors.OrderNotFound,
383
+ 'Duplicate order sent': errors.DuplicateOrderId,
384
+ 'Market is closed': errors.BadSymbol,
385
+ 'Account has insufficient balance for requested action': errors.InsufficientFunds,
386
+ 'Market orders are not supported for this symbol': errors.BadSymbol,
387
+ 'Iceberg orders are not supported for this symbol': errors.BadSymbol,
388
+ 'Stop loss orders are not supported for this symbol': errors.BadSymbol,
389
+ 'Stop loss limit orders are not supported for this symbol': errors.BadSymbol,
390
+ 'Take profit orders are not supported for this symbol': errors.BadSymbol,
391
+ 'Take profit limit orders are not supported for this symbol': errors.BadSymbol,
392
+ 'Price* QTY is zero or less': errors.BadRequest,
393
+ 'IcebergQty exceeds QTY': errors.BadRequest,
394
+ 'This action disabled is on this account': errors.PermissionDenied,
395
+ 'Unsupported order combination': errors.InvalidOrder,
396
+ 'Order would trigger immediately': errors.InvalidOrder,
397
+ 'Cancel order is invalid. Check origClOrdId and orderId': errors.InvalidOrder,
398
+ 'Order would immediately match and take': errors.OrderImmediatelyFillable,
399
+ 'PRICE_FILTER': errors.InvalidOrder,
400
+ 'LOT_SIZE': errors.InvalidOrder,
401
+ 'MIN_NOTIONAL': errors.InvalidOrder,
402
+ 'MAX_NUM_ORDERS': errors.InvalidOrder,
403
+ 'MAX_ALGO_ORDERS': errors.InvalidOrder,
404
+ 'BROKER_MAX_NUM_ORDERS': errors.InvalidOrder,
405
+ 'BROKER_MAX_ALGO_ORDERS': errors.InvalidOrder,
406
+ 'ICEBERG_PARTS': errors.BadRequest, // Iceberg order would break into too many parts; icebergQty is too small.
407
+ },
408
+ },
409
+ });
410
+ }
411
+ calculateRateLimiterCost(api, method, path, params, config = {}) {
412
+ if (('noSymbol' in config) && !('symbol' in params)) {
413
+ return config['noSymbol'];
414
+ }
415
+ else if (('noSymbolAndNoSymbols' in config) && !('symbol' in params) && !('symbols' in params)) {
416
+ return config['noSymbolAndNoSymbols'];
417
+ }
418
+ else if (('byNumberOfSymbols' in config) && ('symbols' in params)) {
419
+ const symbols = params['symbols'];
420
+ const symbolsAmount = symbols.length;
421
+ const byNumberOfSymbols = config['byNumberOfSymbols'];
422
+ for (let i = 0; i < byNumberOfSymbols.length; i++) {
423
+ const entry = byNumberOfSymbols[i];
424
+ if (symbolsAmount >= entry[0]) {
425
+ return entry[1];
426
+ }
427
+ }
428
+ }
429
+ else if (('byLimit' in config) && ('limit' in params)) {
430
+ const limit = params['limit'];
431
+ const byLimit = config['byLimit'];
432
+ for (let i = 0; i < byLimit.length; i++) {
433
+ const entry = byLimit[i];
434
+ if (limit >= entry[0]) {
435
+ return entry[1];
436
+ }
437
+ }
438
+ }
439
+ return this.safeValue(config, 'cost', 1);
440
+ }
441
+ async fetchStatus(params = {}) {
442
+ /**
443
+ * @method
444
+ * @name coinsph#fetchStatus
445
+ * @description the latest known information on the availability of the exchange API
446
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
447
+ * @returns {object} a [status structure]{@link https://docs.ccxt.com/#/?id=exchange-status-structure}
448
+ */
449
+ const response = await this.publicGetOpenapiV1Ping(params);
450
+ return {
451
+ 'status': 'ok',
452
+ 'updated': undefined,
453
+ 'eta': undefined,
454
+ 'url': undefined,
455
+ 'info': response,
456
+ };
457
+ }
458
+ async fetchTime(params = {}) {
459
+ /**
460
+ * @method
461
+ * @name coinsph#fetchTime
462
+ * @description fetches the current integer timestamp in milliseconds from the exchange server
463
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
464
+ * @returns {int} the current integer timestamp in milliseconds from the exchange server
465
+ */
466
+ const response = await this.publicGetOpenapiV1Time(params);
467
+ //
468
+ // {"serverTime":1677705408268}
469
+ //
470
+ return this.safeInteger(response, 'serverTime');
471
+ }
472
+ async fetchMarkets(params = {}) {
473
+ /**
474
+ * @method
475
+ * @name coinsph#fetchMarkets
476
+ * @description retrieves data on all markets for coinsph
477
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
478
+ * @returns {object[]} an array of objects representing market data
479
+ */
480
+ const response = await this.publicGetOpenapiV1ExchangeInfo(params);
481
+ //
482
+ // {
483
+ // "timezone": "UTC",
484
+ // "serverTime": "1677449496897",
485
+ // "exchangeFilters": [],
486
+ // "symbols": [
487
+ // {
488
+ // "symbol": "XRPPHP",
489
+ // "status": "TRADING",
490
+ // "baseAsset": "XRP",
491
+ // "baseAssetPrecision": "2",
492
+ // "quoteAsset": "PHP",
493
+ // "quoteAssetPrecision": "4",
494
+ // "orderTypes": [
495
+ // "LIMIT",
496
+ // "MARKET",
497
+ // "LIMIT_MAKER",
498
+ // "STOP_LOSS_LIMIT",
499
+ // "STOP_LOSS",
500
+ // "TAKE_PROFIT_LIMIT",
501
+ // "TAKE_PROFIT"
502
+ // ],
503
+ // "filters": [
504
+ // {
505
+ // "minPrice": "0.01",
506
+ // "maxPrice": "99999999.00000000",
507
+ // "tickSize": "0.01",
508
+ // "filterType": "PRICE_FILTER"
509
+ // },
510
+ // {
511
+ // "minQty": "0.01",
512
+ // "maxQty": "99999999999.00000000",
513
+ // "stepSize": "0.01",
514
+ // "filterType": "LOT_SIZE"
515
+ // },
516
+ // { minNotional: "50", filterType: "NOTIONAL" },
517
+ // { minNotional: "50", filterType: "MIN_NOTIONAL" },
518
+ // {
519
+ // "priceUp": "99999999",
520
+ // "priceDown": "0.01",
521
+ // "filterType": "STATIC_PRICE_RANGE"
522
+ // },
523
+ // {
524
+ // "multiplierUp": "1.1",
525
+ // "multiplierDown": "0.9",
526
+ // "filterType": "PERCENT_PRICE_INDEX"
527
+ // },
528
+ // {
529
+ // "multiplierUp": "1.1",
530
+ // "multiplierDown": "0.9",
531
+ // "filterType": "PERCENT_PRICE_ORDER_SIZE"
532
+ // },
533
+ // { maxNumOrders: "200", filterType: "MAX_NUM_ORDERS" },
534
+ // { maxNumAlgoOrders: "5", filterType: "MAX_NUM_ALGO_ORDERS" }
535
+ // ]
536
+ // },
537
+ // ]
538
+ // }
539
+ //
540
+ const markets = this.safeValue(response, 'symbols');
541
+ const result = [];
542
+ for (let i = 0; i < markets.length; i++) {
543
+ const market = markets[i];
544
+ const id = this.safeString(market, 'symbol');
545
+ const baseId = this.safeString(market, 'baseAsset');
546
+ const quoteId = this.safeString(market, 'quoteAsset');
547
+ const base = this.safeCurrencyCode(baseId);
548
+ const quote = this.safeCurrencyCode(quoteId);
549
+ const limits = this.indexBy(this.safeValue(market, 'filters'), 'filterType');
550
+ const amountLimits = this.safeValue(limits, 'LOT_SIZE', {});
551
+ const priceLimits = this.safeValue(limits, 'PRICE_FILTER', {});
552
+ const costLimits = this.safeValue(limits, 'NOTIONAL', {});
553
+ result.push({
554
+ 'id': id,
555
+ 'symbol': base + '/' + quote,
556
+ 'base': base,
557
+ 'quote': quote,
558
+ 'settle': undefined,
559
+ 'baseId': baseId,
560
+ 'quoteId': quoteId,
561
+ 'settleId': undefined,
562
+ 'type': 'spot',
563
+ 'spot': true,
564
+ 'margin': false,
565
+ 'swap': false,
566
+ 'future': false,
567
+ 'option': false,
568
+ 'active': this.safeStringLower(market, 'status') === 'trading',
569
+ 'contract': false,
570
+ 'linear': undefined,
571
+ 'inverse': undefined,
572
+ 'taker': undefined,
573
+ 'maker': undefined,
574
+ 'contractSize': undefined,
575
+ 'expiry': undefined,
576
+ 'expiryDatetime': undefined,
577
+ 'strike': undefined,
578
+ 'optionType': undefined,
579
+ 'precision': {
580
+ 'amount': this.parseNumber(this.safeString(amountLimits, 'stepSize')),
581
+ 'price': this.parseNumber(this.safeString(priceLimits, 'tickSize')),
582
+ },
583
+ 'limits': {
584
+ 'leverage': {
585
+ 'min': undefined,
586
+ 'max': undefined,
587
+ },
588
+ 'amount': {
589
+ 'min': this.parseNumber(this.safeString(amountLimits, 'minQty')),
590
+ 'max': this.parseNumber(this.safeString(amountLimits, 'maxQty')),
591
+ },
592
+ 'price': {
593
+ 'min': this.parseNumber(this.safeString(priceLimits, 'minPrice')),
594
+ 'max': this.parseNumber(this.safeString(priceLimits, 'maxPrice')),
595
+ },
596
+ 'cost': {
597
+ 'min': this.parseNumber(this.safeString(costLimits, 'minNotional')),
598
+ 'max': undefined,
599
+ },
600
+ },
601
+ 'created': undefined,
602
+ 'info': market,
603
+ });
604
+ }
605
+ this.setMarkets(result);
606
+ return result;
607
+ }
608
+ async fetchTickers(symbols = undefined, params = {}) {
609
+ /**
610
+ * @method
611
+ * @name coinsph#fetchTickers
612
+ * @description fetches price tickers for multiple markets, statistical information calculated over the past 24 hours for each market
613
+ * @param {string[]|undefined} symbols unified symbols of the markets to fetch the ticker for, all market tickers are returned if not assigned
614
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
615
+ * @returns {object} a dictionary of [ticker structures]{@link https://docs.ccxt.com/#/?id=ticker-structure}
616
+ */
617
+ await this.loadMarkets();
618
+ const request = {};
619
+ if (symbols !== undefined) {
620
+ const ids = [];
621
+ for (let i = 0; i < symbols.length; i++) {
622
+ const market = this.market(symbols[i]);
623
+ const id = market['id'];
624
+ ids.push(id);
625
+ }
626
+ request['symbols'] = ids;
627
+ }
628
+ const defaultMethod = 'publicGetOpenapiQuoteV1Ticker24hr';
629
+ const options = this.safeValue(this.options, 'fetchTickers', {});
630
+ const method = this.safeString(options, 'method', defaultMethod);
631
+ let tickers = undefined;
632
+ if (method === 'publicGetOpenapiQuoteV1TickerPrice') {
633
+ tickers = await this.publicGetOpenapiQuoteV1TickerPrice(this.extend(request, params));
634
+ }
635
+ else if (method === 'publicGetOpenapiQuoteV1TickerBookTicker') {
636
+ tickers = await this.publicGetOpenapiQuoteV1TickerBookTicker(this.extend(request, params));
637
+ }
638
+ else {
639
+ tickers = await this.publicGetOpenapiQuoteV1Ticker24hr(this.extend(request, params));
640
+ }
641
+ return this.parseTickers(tickers, symbols, params);
642
+ }
643
+ async fetchTicker(symbol, params = {}) {
644
+ /**
645
+ * @method
646
+ * @name coinsph#fetchTicker
647
+ * @description fetches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
648
+ * @param {string} symbol unified symbol of the market to fetch the ticker for
649
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
650
+ * @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
651
+ */
652
+ await this.loadMarkets();
653
+ const market = this.market(symbol);
654
+ const request = {
655
+ 'symbol': market['id'],
656
+ };
657
+ const defaultMethod = 'publicGetOpenapiQuoteV1Ticker24hr';
658
+ const options = this.safeValue(this.options, 'fetchTicker', {});
659
+ const method = this.safeString(options, 'method', defaultMethod);
660
+ let ticker = undefined;
661
+ if (method === 'publicGetOpenapiQuoteV1TickerPrice') {
662
+ ticker = await this.publicGetOpenapiQuoteV1TickerPrice(this.extend(request, params));
663
+ }
664
+ else if (method === 'publicGetOpenapiQuoteV1TickerBookTicker') {
665
+ ticker = await this.publicGetOpenapiQuoteV1TickerBookTicker(this.extend(request, params));
666
+ }
667
+ else {
668
+ ticker = await this.publicGetOpenapiQuoteV1Ticker24hr(this.extend(request, params));
669
+ }
670
+ return this.parseTicker(ticker, market);
671
+ }
672
+ parseTicker(ticker, market = undefined) {
673
+ //
674
+ // publicGetOpenapiQuoteV1Ticker24hr
675
+ // {
676
+ // "symbol": "ETHUSDT",
677
+ // "priceChange": "41.440000000000000000",
678
+ // "priceChangePercent": "0.0259",
679
+ // "weightedAvgPrice": "1631.169825783972125436",
680
+ // "prevClosePrice": "1601.520000000000000000",
681
+ // "lastPrice": "1642.96",
682
+ // "lastQty": "0.000001000000000000",
683
+ // "bidPrice": "1638.790000000000000000",
684
+ // "bidQty": "0.280075000000000000",
685
+ // "askPrice": "1647.340000000000000000",
686
+ // "askQty": "0.165183000000000000",
687
+ // "openPrice": "1601.52",
688
+ // "highPrice": "1648.28",
689
+ // "lowPrice": "1601.52",
690
+ // "volume": "0.000287",
691
+ // "quoteVolume": "0.46814574",
692
+ // "openTime": "1677417000000",
693
+ // "closeTime": "1677503415200",
694
+ // "firstId": "1364680572697591809",
695
+ // "lastId": "1365389809203560449",
696
+ // "count": "100"
697
+ // }
698
+ //
699
+ // publicGetOpenapiQuoteV1TickerPrice
700
+ // { "symbol": "ETHUSDT", "price": "1599.68" }
701
+ //
702
+ // publicGetOpenapiQuoteV1TickerBookTicker
703
+ // {
704
+ // "symbol": "ETHUSDT",
705
+ // "bidPrice": "1596.57",
706
+ // "bidQty": "0.246405",
707
+ // "askPrice": "1605.12",
708
+ // "askQty": "0.242681"
709
+ // }
710
+ //
711
+ const marketId = this.safeString(ticker, 'symbol');
712
+ market = this.safeMarket(marketId, market);
713
+ const timestamp = this.safeInteger(ticker, 'closeTime');
714
+ const bid = this.safeString(ticker, 'bidPrice');
715
+ const ask = this.safeString(ticker, 'askPrice');
716
+ const bidVolume = this.safeString(ticker, 'bidQty');
717
+ const askVolume = this.safeString(ticker, 'askQty');
718
+ const baseVolume = this.safeString(ticker, 'volume');
719
+ const quoteVolume = this.safeString(ticker, 'quoteVolume');
720
+ const open = this.safeString(ticker, 'openPrice');
721
+ const high = this.safeString(ticker, 'highPrice');
722
+ const low = this.safeString(ticker, 'lowPrice');
723
+ const prevClose = this.safeString(ticker, 'prevClosePrice');
724
+ const vwap = this.safeString(ticker, 'weightedAvgPrice');
725
+ const changeValue = this.safeString(ticker, 'priceChange');
726
+ let changePcnt = this.safeString(ticker, 'priceChangePercent');
727
+ changePcnt = Precise["default"].stringMul(changePcnt, '100');
728
+ return this.safeTicker({
729
+ 'symbol': market['symbol'],
730
+ 'timestamp': timestamp,
731
+ 'datetime': this.iso8601(timestamp),
732
+ 'open': open,
733
+ 'high': high,
734
+ 'low': low,
735
+ 'close': this.safeString2(ticker, 'lastPrice', 'price'),
736
+ 'bid': bid,
737
+ 'bidVolume': bidVolume,
738
+ 'ask': ask,
739
+ 'askVolume': askVolume,
740
+ 'vwap': vwap,
741
+ 'previousClose': prevClose,
742
+ 'change': changeValue,
743
+ 'percentage': changePcnt,
744
+ 'average': undefined,
745
+ 'baseVolume': baseVolume,
746
+ 'quoteVolume': quoteVolume,
747
+ 'info': ticker,
748
+ }, market);
749
+ }
750
+ async fetchOrderBook(symbol, limit = undefined, params = {}) {
751
+ /**
752
+ * @method
753
+ * @name coinsph#fetchOrderBook
754
+ * @description fetches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
755
+ * @param {string} symbol unified symbol of the market to fetch the order book for
756
+ * @param {int} [limit] the maximum amount of order book entries to return (default 100, max 200)
757
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
758
+ * @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
759
+ */
760
+ await this.loadMarkets();
761
+ const market = this.market(symbol);
762
+ const request = {
763
+ 'symbol': market['id'],
764
+ };
765
+ if (limit !== undefined) {
766
+ request['limit'] = limit;
767
+ }
768
+ const response = await this.publicGetOpenapiQuoteV1Depth(this.extend(request, params));
769
+ //
770
+ // {
771
+ // "lastUpdateId": "1667022157000699400",
772
+ // "bids": [
773
+ // [ '1651.810000000000000000', '0.214556000000000000' ],
774
+ // [ '1651.730000000000000000', '0.257343000000000000' ],
775
+ // ],
776
+ // "asks": [
777
+ // [ '1660.510000000000000000', '0.299092000000000000' ],
778
+ // [ '1660.600000000000000000', '0.253667000000000000' ],
779
+ // ]
780
+ // }
781
+ //
782
+ const orderbook = this.parseOrderBook(response, symbol);
783
+ orderbook['nonce'] = this.safeInteger(response, 'lastUpdateId');
784
+ return orderbook;
785
+ }
786
+ async fetchOHLCV(symbol, timeframe = '1m', since = undefined, limit = undefined, params = {}) {
787
+ /**
788
+ * @method
789
+ * @name coinsph#fetchOHLCV
790
+ * @description fetches historical candlestick data containing the open, high, low, and close price, and the volume of a market
791
+ * @param {string} symbol unified symbol of the market to fetch OHLCV data for
792
+ * @param {string} timeframe the length of time each candle represents
793
+ * @param {int} [since] timestamp in ms of the earliest candle to fetch
794
+ * @param {int} [limit] the maximum amount of candles to fetch (default 500, max 1000)
795
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
796
+ * @returns {int[][]} A list of candles ordered as timestamp, open, high, low, close, volume
797
+ */
798
+ await this.loadMarkets();
799
+ const market = this.market(symbol);
800
+ const interval = this.safeString(this.timeframes, timeframe);
801
+ const request = {
802
+ 'symbol': market['id'],
803
+ 'interval': interval,
804
+ };
805
+ if (since !== undefined) {
806
+ request['startTime'] = since;
807
+ request['limit'] = 1000;
808
+ // since work properly only when it is "younger" than last "limit" candle
809
+ if (limit !== undefined) {
810
+ const duration = this.parseTimeframe(timeframe) * 1000;
811
+ request['endTime'] = this.sum(since, duration * (limit - 1));
812
+ }
813
+ else {
814
+ request['endTime'] = this.milliseconds();
815
+ }
816
+ }
817
+ else {
818
+ if (limit !== undefined) {
819
+ request['limit'] = limit;
820
+ }
821
+ }
822
+ const response = await this.publicGetOpenapiQuoteV1Klines(this.extend(request, params));
823
+ //
824
+ // [
825
+ // [
826
+ // 1499040000000, // Open time
827
+ // "0.01634790", // Open
828
+ // "0.80000000", // High
829
+ // "0.01575800", // Low
830
+ // "0.01577100", // Close
831
+ // "148976.11427815", // Volume
832
+ // 1499644799999, // Close time
833
+ // "2434.19055334", // Quote asset volume
834
+ // 308, // Number of trades
835
+ // "1756.87402397", // Taker buy base asset volume
836
+ // "28.46694368" // Taker buy quote asset volume
837
+ // ]
838
+ // ]
839
+ //
840
+ return this.parseOHLCVs(response, market, timeframe, since, limit);
841
+ }
842
+ parseOHLCV(ohlcv, market = undefined) {
843
+ return [
844
+ this.safeInteger(ohlcv, 0),
845
+ this.safeNumber(ohlcv, 1),
846
+ this.safeNumber(ohlcv, 2),
847
+ this.safeNumber(ohlcv, 3),
848
+ this.safeNumber(ohlcv, 4),
849
+ this.safeNumber(ohlcv, 5),
850
+ ];
851
+ }
852
+ async fetchTrades(symbol, since = undefined, limit = undefined, params = {}) {
853
+ /**
854
+ * @method
855
+ * @name coinsph#fetchTrades
856
+ * @description get the list of most recent trades for a particular symbol
857
+ * @param {string} symbol unified symbol of the market to fetch trades for
858
+ * @param {int} [since] timestamp in ms of the earliest trade to fetch
859
+ * @param {int} [limit] the maximum amount of trades to fetch (default 500, max 1000)
860
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
861
+ * @returns {Trade[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
862
+ */
863
+ await this.loadMarkets();
864
+ const market = this.market(symbol);
865
+ const request = {
866
+ 'symbol': market['id'],
867
+ };
868
+ if (since !== undefined) {
869
+ // since work properly only when it is "younger" than last 'limit' trade
870
+ request['limit'] = 1000;
871
+ }
872
+ else {
873
+ if (limit !== undefined) {
874
+ request['limit'] = limit;
875
+ }
876
+ }
877
+ const response = await this.publicGetOpenapiQuoteV1Trades(this.extend(request, params));
878
+ //
879
+ // [
880
+ // {
881
+ // "price": "89685.8",
882
+ // "id": "1365561108437680129",
883
+ // "qty": "0.000004",
884
+ // "quoteQty": "0.000004000000000000",
885
+ // "time": "1677523569575",
886
+ // "isBuyerMaker": false,
887
+ // "isBestMatch": true
888
+ // },
889
+ // ]
890
+ //
891
+ return this.parseTrades(response, market, since, limit);
892
+ }
893
+ async fetchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
894
+ /**
895
+ * @method
896
+ * @name coinsph#fetchMyTrades
897
+ * @description fetch all trades made by the user
898
+ * @param {string} symbol unified market symbol
899
+ * @param {int} [since] the earliest time in ms to fetch trades for
900
+ * @param {int} [limit] the maximum number of trades structures to retrieve (default 500, max 1000)
901
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
902
+ * @returns {Trade[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure}
903
+ */
904
+ if (symbol === undefined) {
905
+ throw new errors.ArgumentsRequired(this.id + ' fetchMyTrades() requires a symbol argument');
906
+ }
907
+ await this.loadMarkets();
908
+ const market = this.market(symbol);
909
+ const request = {
910
+ 'symbol': market['id'],
911
+ };
912
+ if (since !== undefined) {
913
+ request['startTime'] = since;
914
+ // since work properly only when it is "younger" than last 'limit' trade
915
+ request['limit'] = 1000;
916
+ }
917
+ else if (limit !== undefined) {
918
+ request['limit'] = limit;
919
+ }
920
+ const response = await this.privateGetOpenapiV1MyTrades(this.extend(request, params));
921
+ return this.parseTrades(response, market, since, limit);
922
+ }
923
+ async fetchOrderTrades(id, symbol = undefined, since = undefined, limit = undefined, params = {}) {
924
+ /**
925
+ * @method
926
+ * @name coinsph#fetchOrderTrades
927
+ * @description fetch all the trades made from a single order
928
+ * @param {string} id order id
929
+ * @param {string} symbol unified market symbol
930
+ * @param {int} [since] the earliest time in ms to fetch trades for
931
+ * @param {int} [limit] the maximum number of trades to retrieve
932
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
933
+ * @returns {object[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure}
934
+ */
935
+ if (symbol === undefined) {
936
+ throw new errors.ArgumentsRequired(this.id + ' fetchOrderTrades() requires a symbol argument');
937
+ }
938
+ const request = {
939
+ 'orderId': id,
940
+ };
941
+ return await this.fetchMyTrades(symbol, since, limit, this.extend(request, params));
942
+ }
943
+ parseTrade(trade, market = undefined) {
944
+ //
945
+ // fetchTrades
946
+ // {
947
+ // "price": "89685.8",
948
+ // "id": "1365561108437680129",
949
+ // "qty": "0.000004",
950
+ // "quoteQty": "0.000004000000000000", // warning: report to exchange - this is not quote quantity, this is base quantity
951
+ // "time": "1677523569575",
952
+ // "isBuyerMaker": false,
953
+ // "isBestMatch": true
954
+ // },
955
+ //
956
+ // fetchMyTrades
957
+ // {
958
+ // "symbol": "ETHUSDT",
959
+ // "id": 1375426310524125185,
960
+ // "orderId": 1375426310415879614,
961
+ // "price": "1580.91",
962
+ // "qty": "0.01",
963
+ // "quoteQty": "15.8091",
964
+ // "commission": "0",
965
+ // "commissionAsset": "USDT",
966
+ // "time": 1678699593307,
967
+ // "isBuyer": false,
968
+ // "isMaker":false,
969
+ // "isBestMatch":false
970
+ // }
971
+ //
972
+ // createOrder
973
+ // {
974
+ // "price": "1579.51",
975
+ // "qty": "0.001899",
976
+ // "commission": "0",
977
+ // "commissionAsset": "ETH",
978
+ // "tradeId":1375445992035598337
979
+ // }
980
+ //
981
+ const marketId = this.safeString(trade, 'symbol');
982
+ market = this.safeMarket(marketId, market);
983
+ const symbol = market['symbol'];
984
+ const id = this.safeString2(trade, 'id', 'tradeId');
985
+ const orderId = this.safeString(trade, 'orderId');
986
+ const timestamp = this.safeInteger(trade, 'time');
987
+ const priceString = this.safeString(trade, 'price');
988
+ const amountString = this.safeString(trade, 'qty');
989
+ const type = undefined;
990
+ let fee = undefined;
991
+ const feeCost = this.safeString(trade, 'commission');
992
+ if (feeCost !== undefined) {
993
+ const feeCurrencyId = this.safeString(trade, 'commissionAsset');
994
+ fee = {
995
+ 'cost': feeCost,
996
+ 'currency': this.safeCurrencyCode(feeCurrencyId),
997
+ };
998
+ }
999
+ const isBuyer = this.safeString2(trade, 'isBuyer', 'isBuyerMaker', undefined);
1000
+ let side = undefined;
1001
+ if (isBuyer !== undefined) {
1002
+ side = (isBuyer === 'true') ? 'buy' : 'sell';
1003
+ }
1004
+ const isMaker = this.safeString2(trade, 'isMaker', undefined);
1005
+ let takerOrMaker = undefined;
1006
+ if (isMaker !== undefined) {
1007
+ takerOrMaker = (isMaker === 'true') ? 'maker' : 'taker';
1008
+ }
1009
+ let costString = undefined;
1010
+ if (orderId !== undefined) {
1011
+ costString = this.safeString(trade, 'quoteQty');
1012
+ }
1013
+ return this.safeTrade({
1014
+ 'id': id,
1015
+ 'order': orderId,
1016
+ 'timestamp': timestamp,
1017
+ 'datetime': this.iso8601(timestamp),
1018
+ 'symbol': symbol,
1019
+ 'type': type,
1020
+ 'side': side,
1021
+ 'takerOrMaker': takerOrMaker,
1022
+ 'price': priceString,
1023
+ 'amount': amountString,
1024
+ 'cost': costString,
1025
+ 'fee': fee,
1026
+ 'info': trade,
1027
+ }, market);
1028
+ }
1029
+ async fetchBalance(params = {}) {
1030
+ /**
1031
+ * @method
1032
+ * @name coinsph#fetchBalance
1033
+ * @description query for balance and get the amount of funds available for trading or funds locked in orders
1034
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1035
+ * @returns {object} a [balance structure]{@link https://docs.ccxt.com/#/?id=balance-structure}
1036
+ */
1037
+ await this.loadMarkets();
1038
+ const response = await this.privateGetOpenapiV1Account(params);
1039
+ //
1040
+ // {
1041
+ // "accountType": "SPOT",
1042
+ // "balances": [
1043
+ // {
1044
+ // "asset": "BTC",
1045
+ // "free": "4723846.89208129",
1046
+ // "locked": "0.00000000"
1047
+ // },
1048
+ // {
1049
+ // "asset": "LTC",
1050
+ // "free": "4763368.68006011",
1051
+ // "locked": "0.00000000"
1052
+ // }
1053
+ // ],
1054
+ // "canDeposit": true,
1055
+ // "canTrade": true,
1056
+ // "canWithdraw": true,
1057
+ // "updateTime": "1677430932528"
1058
+ // }
1059
+ //
1060
+ return this.parseBalance(response);
1061
+ }
1062
+ parseBalance(response) {
1063
+ const balances = this.safeValue(response, 'balances', []);
1064
+ const result = {
1065
+ 'info': response,
1066
+ 'timestamp': undefined,
1067
+ 'datetime': undefined,
1068
+ };
1069
+ for (let i = 0; i < balances.length; i++) {
1070
+ const balance = balances[i];
1071
+ const currencyId = this.safeString(balance, 'asset');
1072
+ const code = this.safeCurrencyCode(currencyId);
1073
+ const account = this.account();
1074
+ account['free'] = this.safeString(balance, 'free');
1075
+ account['used'] = this.safeString(balance, 'locked');
1076
+ result[code] = account;
1077
+ }
1078
+ return this.safeBalance(result);
1079
+ }
1080
+ async createOrder(symbol, type, side, amount, price = undefined, params = {}) {
1081
+ /**
1082
+ * @method
1083
+ * @name coinsph#createOrder
1084
+ * @description create a trade order
1085
+ * @see https://coins-docs.github.io/rest-api/#new-order--trade
1086
+ * @param {string} symbol unified symbol of the market to create an order in
1087
+ * @param {string} type 'market', 'limit', 'stop_loss', 'take_profit', 'stop_loss_limit', 'take_profit_limit' or 'limit_maker'
1088
+ * @param {string} side 'buy' or 'sell'
1089
+ * @param {float} amount how much of currency you want to trade in units of base currency
1090
+ * @param {float} [price] the price at which the order is to be fullfilled, in units of the quote currency, ignored in market orders
1091
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1092
+ * @param {float} [params.cost] the quote quantity that can be used as an alternative for the amount for market buy orders
1093
+ * @returns {object} an [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1094
+ */
1095
+ // todo: add test order low priority
1096
+ await this.loadMarkets();
1097
+ const market = this.market(symbol);
1098
+ let orderType = this.safeString(params, 'type', type);
1099
+ orderType = this.encodeOrderType(orderType);
1100
+ params = this.omit(params, 'type');
1101
+ const orderSide = this.encodeOrderSide(side);
1102
+ const request = {
1103
+ 'symbol': market['id'],
1104
+ 'type': orderType,
1105
+ 'side': orderSide,
1106
+ };
1107
+ const options = this.safeValue(this.options, 'createOrder', {});
1108
+ let newOrderRespType = this.safeValue(options, 'newOrderRespType', {});
1109
+ // if limit order
1110
+ if (orderType === 'LIMIT' || orderType === 'STOP_LOSS_LIMIT' || orderType === 'TAKE_PROFIT_LIMIT' || orderType === 'LIMIT_MAKER') {
1111
+ if (price === undefined) {
1112
+ throw new errors.ArgumentsRequired(this.id + ' createOrder() requires a price argument for a ' + type + ' order');
1113
+ }
1114
+ newOrderRespType = this.safeString(newOrderRespType, 'limit', 'FULL');
1115
+ request['price'] = this.priceToPrecision(symbol, price);
1116
+ request['quantity'] = this.amountToPrecision(symbol, amount);
1117
+ if (orderType !== 'LIMIT_MAKER') {
1118
+ request['timeInForce'] = this.safeString(options, 'timeInForce', 'GTC');
1119
+ }
1120
+ // if market order
1121
+ }
1122
+ else if (orderType === 'MARKET' || orderType === 'STOP_LOSS' || orderType === 'TAKE_PROFIT') {
1123
+ newOrderRespType = this.safeString(newOrderRespType, 'market', 'FULL');
1124
+ if (orderSide === 'SELL') {
1125
+ request['quantity'] = this.amountToPrecision(symbol, amount);
1126
+ }
1127
+ else if (orderSide === 'BUY') {
1128
+ let quoteAmount = undefined;
1129
+ let createMarketBuyOrderRequiresPrice = true;
1130
+ [createMarketBuyOrderRequiresPrice, params] = this.handleOptionAndParams(params, 'createOrder', 'createMarketBuyOrderRequiresPrice', true);
1131
+ const cost = this.safeNumber2(params, 'cost', 'quoteOrderQty');
1132
+ params = this.omit(params, 'cost');
1133
+ if (cost !== undefined) {
1134
+ quoteAmount = this.costToPrecision(symbol, cost);
1135
+ }
1136
+ else if (createMarketBuyOrderRequiresPrice) {
1137
+ if (price === undefined) {
1138
+ throw new errors.InvalidOrder(this.id + ' createOrder() requires the price argument for market buy orders to calculate the total cost to spend (amount * price), alternatively set the createMarketBuyOrderRequiresPrice option or param to false and pass the cost to spend in the amount argument');
1139
+ }
1140
+ else {
1141
+ const amountString = this.numberToString(amount);
1142
+ const priceString = this.numberToString(price);
1143
+ const costRequest = Precise["default"].stringMul(amountString, priceString);
1144
+ quoteAmount = this.costToPrecision(symbol, costRequest);
1145
+ }
1146
+ }
1147
+ else {
1148
+ quoteAmount = this.costToPrecision(symbol, amount);
1149
+ }
1150
+ request['quoteOrderQty'] = quoteAmount;
1151
+ }
1152
+ }
1153
+ if (orderType === 'STOP_LOSS' || orderType === 'STOP_LOSS_LIMIT' || orderType === 'TAKE_PROFIT' || orderType === 'TAKE_PROFIT_LIMIT') {
1154
+ const stopPrice = this.safeString2(params, 'triggerPrice', 'stopPrice');
1155
+ if (stopPrice === undefined) {
1156
+ throw new errors.InvalidOrder(this.id + ' createOrder () requires a triggerPrice or stopPrice param for stop_loss, take_profit, stop_loss_limit, and take_profit_limit orders');
1157
+ }
1158
+ request['stopPrice'] = this.priceToPrecision(symbol, stopPrice);
1159
+ }
1160
+ request['newOrderRespType'] = newOrderRespType;
1161
+ params = this.omit(params, 'price', 'stopPrice', 'triggerPrice', 'quantity', 'quoteOrderQty');
1162
+ const response = await this.privatePostOpenapiV1Order(this.extend(request, params));
1163
+ //
1164
+ // {
1165
+ // "symbol": "ETHUSDT",
1166
+ // "orderId": "1375407140139731486",
1167
+ // "clientOrderId": "1375407140139733169",
1168
+ // "transactTime": "1678697308023",
1169
+ // "price": "1600",
1170
+ // "origQty": "0.02",
1171
+ // "executedQty": "0.02",
1172
+ // "cummulativeQuoteQty": "31.9284",
1173
+ // "status": "FILLED",
1174
+ // "timeInForce": "GTC",
1175
+ // "type": "LIMIT",
1176
+ // "side": "BUY",
1177
+ // "stopPrice": "0",
1178
+ // "origQuoteOrderQty": "0",
1179
+ // "fills": [
1180
+ // {
1181
+ // "price": "1596.42",
1182
+ // "qty": "0.02",
1183
+ // "commission": "0",
1184
+ // "commissionAsset": "ETH",
1185
+ // "tradeId": "1375407140281532417"
1186
+ // }
1187
+ // ]
1188
+ // },
1189
+ //
1190
+ return this.parseOrder(response, market);
1191
+ }
1192
+ async fetchOrder(id, symbol = undefined, params = {}) {
1193
+ /**
1194
+ * @method
1195
+ * @name coinsph#fetchOrder
1196
+ * @description fetches information on an order made by the user
1197
+ * @param {int|string} id order id
1198
+ * @param {string} symbol not used by coinsph fetchOrder ()
1199
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1200
+ * @returns {object} An [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1201
+ */
1202
+ await this.loadMarkets();
1203
+ const request = {};
1204
+ const clientOrderId = this.safeValue2(params, 'origClientOrderId', 'clientOrderId');
1205
+ if (clientOrderId !== undefined) {
1206
+ request['origClientOrderId'] = clientOrderId;
1207
+ }
1208
+ else {
1209
+ request['orderId'] = id;
1210
+ }
1211
+ params = this.omit(params, ['clientOrderId', 'origClientOrderId']);
1212
+ const response = await this.privateGetOpenapiV1Order(this.extend(request, params));
1213
+ return this.parseOrder(response);
1214
+ }
1215
+ async fetchOpenOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
1216
+ /**
1217
+ * @method
1218
+ * @name coinsph#fetchOpenOrders
1219
+ * @description fetch all unfilled currently open orders
1220
+ * @param {string} symbol unified market symbol
1221
+ * @param {int} [since] the earliest time in ms to fetch open orders for
1222
+ * @param {int} [limit] the maximum number of open orders structures to retrieve
1223
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1224
+ * @returns {Order[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1225
+ */
1226
+ await this.loadMarkets();
1227
+ let market = undefined;
1228
+ const request = {};
1229
+ if (symbol !== undefined) {
1230
+ market = this.market(symbol);
1231
+ request['symbol'] = market['id'];
1232
+ }
1233
+ const response = await this.privateGetOpenapiV1OpenOrders(this.extend(request, params));
1234
+ return this.parseOrders(response, market, since, limit);
1235
+ }
1236
+ async fetchClosedOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
1237
+ /**
1238
+ * @method
1239
+ * @name coinsph#fetchClosedOrders
1240
+ * @description fetches information on multiple closed orders made by the user
1241
+ * @param {string} symbol unified market symbol of the market orders were made in
1242
+ * @param {int} [since] the earliest time in ms to fetch orders for
1243
+ * @param {int} [limit] the maximum number of order structures to retrieve (default 500, max 1000)
1244
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1245
+ * @returns {Order[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1246
+ */
1247
+ if (symbol === undefined) {
1248
+ throw new errors.ArgumentsRequired(this.id + ' fetchClosedOrders() requires a symbol argument');
1249
+ }
1250
+ await this.loadMarkets();
1251
+ const market = this.market(symbol);
1252
+ const request = {
1253
+ 'symbol': market['id'],
1254
+ };
1255
+ if (since !== undefined) {
1256
+ request['startTime'] = since;
1257
+ // since work properly only when it is "younger" than last 'limit' order
1258
+ request['limit'] = 1000;
1259
+ }
1260
+ else if (limit !== undefined) {
1261
+ request['limit'] = limit;
1262
+ }
1263
+ const response = await this.privateGetOpenapiV1HistoryOrders(this.extend(request, params));
1264
+ return this.parseOrders(response, market, since, limit);
1265
+ }
1266
+ async cancelOrder(id, symbol = undefined, params = {}) {
1267
+ /**
1268
+ * @method
1269
+ * @name coinsph#cancelOrder
1270
+ * @description cancels an open order
1271
+ * @param {string} id order id
1272
+ * @param {string} symbol not used by coinsph cancelOrder ()
1273
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1274
+ * @returns {object} An [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1275
+ */
1276
+ await this.loadMarkets();
1277
+ const request = {};
1278
+ const clientOrderId = this.safeValue2(params, 'origClientOrderId', 'clientOrderId');
1279
+ if (clientOrderId !== undefined) {
1280
+ request['origClientOrderId'] = clientOrderId;
1281
+ }
1282
+ else {
1283
+ request['orderId'] = id;
1284
+ }
1285
+ params = this.omit(params, ['clientOrderId', 'origClientOrderId']);
1286
+ const response = await this.privateDeleteOpenapiV1Order(this.extend(request, params));
1287
+ return this.parseOrder(response);
1288
+ }
1289
+ async cancelAllOrders(symbol = undefined, params = {}) {
1290
+ /**
1291
+ * @method
1292
+ * @name coinsph#cancelAllOrders
1293
+ * @description cancel open orders of market
1294
+ * @param {string} symbol unified market symbol
1295
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1296
+ * @returns {object[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
1297
+ */
1298
+ if (symbol === undefined) {
1299
+ throw new errors.ArgumentsRequired(this.id + ' cancelAllOrders() requires a symbol argument');
1300
+ }
1301
+ await this.loadMarkets();
1302
+ let market = undefined;
1303
+ const request = {};
1304
+ if (symbol !== undefined) {
1305
+ market = this.market(symbol);
1306
+ request['symbol'] = market['id'];
1307
+ }
1308
+ const response = await this.privateDeleteOpenapiV1OpenOrders(this.extend(request, params));
1309
+ return this.parseOrders(response, market);
1310
+ }
1311
+ parseOrder(order, market = undefined) {
1312
+ //
1313
+ // createOrder POST /openapi/v1/order
1314
+ // {
1315
+ // "symbol": "ETHUSDT",
1316
+ // "orderId": 1375445991893797391,
1317
+ // "clientOrderId": "1375445991893799115",
1318
+ // "transactTime": 1678701939513,
1319
+ // "price": "0",
1320
+ // "origQty": "0",
1321
+ // "executedQty": "0.001899",
1322
+ // "cummulativeQuoteQty": "2.99948949",
1323
+ // "status": "FILLED",
1324
+ // "timeInForce": "GTC",
1325
+ // "type": "MARKET",
1326
+ // "side": "BUY",
1327
+ // "stopPrice": "0",
1328
+ // "origQuoteOrderQty": "3",
1329
+ // "fills": [
1330
+ // {
1331
+ // "price": "1579.51",
1332
+ // "qty": "0.001899",
1333
+ // "commission": "0",
1334
+ // "commissionAsset": "ETH",
1335
+ // "tradeId":1375445992035598337
1336
+ // }
1337
+ // ]
1338
+ // }
1339
+ //
1340
+ // fetchOrder GET /openapi/v1/order
1341
+ // fetchOpenOrders GET /openapi/v1/openOrders
1342
+ // fetchClosedOrders GET /openapi/v1/historyOrders
1343
+ // cancelAllOrders DELETE /openapi/v1/openOrders
1344
+ // {
1345
+ // "symbol": "DOGEPHP",
1346
+ // "orderId":1375465375097982423,
1347
+ // "clientOrderId": "1375465375098001241",
1348
+ // "price": "0",
1349
+ // "origQty": "0",
1350
+ // "executedQty": "13",
1351
+ // "cummulativeQuoteQty": "49.621",
1352
+ // "status": "FILLED",
1353
+ // "timeInForce": "GTC",
1354
+ // "type": "MARKET",
1355
+ // "side": "BUY",
1356
+ // "stopPrice": "0",
1357
+ // "time":1678704250171,
1358
+ // "updateTime":1678704250256,
1359
+ // "isWorking":false,
1360
+ // "origQuoteOrderQty": "50"
1361
+ // }
1362
+ //
1363
+ // cancelOrder DELETE /openapi/v1/order
1364
+ // {
1365
+ // "symbol": "ETHPHP",
1366
+ // "orderId":1375609441915774332,
1367
+ // "clientOrderId": "1375609441915899557",
1368
+ // "price": "96000",
1369
+ // "origQty": "0.001",
1370
+ // "executedQty": "0",
1371
+ // "cummulativeQuoteQty": "0",
1372
+ // "status": "CANCELED",
1373
+ // "timeInForce": "GTC",
1374
+ // "type": "LIMIT",
1375
+ // "side": "SELL",
1376
+ // "stopPrice": "0",
1377
+ // "origQuoteOrderQty": "0"
1378
+ // }
1379
+ //
1380
+ const id = this.safeString(order, 'orderId');
1381
+ const marketId = this.safeString(order, 'symbol');
1382
+ market = this.safeMarket(marketId, market);
1383
+ const timestamp = this.safeInteger2(order, 'time', 'transactTime');
1384
+ const trades = this.safeValue(order, 'fills', undefined);
1385
+ let stopPrice = this.safeString(order, 'stopPrice');
1386
+ if (Precise["default"].stringEq(stopPrice, '0')) {
1387
+ stopPrice = undefined;
1388
+ }
1389
+ return this.safeOrder({
1390
+ 'id': id,
1391
+ 'clientOrderId': this.safeString(order, 'clientOrderId'),
1392
+ 'timestamp': timestamp,
1393
+ 'datetime': this.iso8601(timestamp),
1394
+ 'lastTradeTimestamp': undefined,
1395
+ 'status': this.parseOrderStatus(this.safeString(order, 'status')),
1396
+ 'symbol': market['symbol'],
1397
+ 'type': this.parseOrderType(this.safeString(order, 'type')),
1398
+ 'timeInForce': this.parseOrderTimeInForce(this.safeString(order, 'timeInForce')),
1399
+ 'side': this.parseOrderSide(this.safeString(order, 'side')),
1400
+ 'price': this.safeString(order, 'price'),
1401
+ 'stopPrice': stopPrice,
1402
+ 'triggerPrice': stopPrice,
1403
+ 'average': undefined,
1404
+ 'amount': this.safeString(order, 'origQty'),
1405
+ 'cost': this.safeString(order, 'cummulativeQuoteQty'),
1406
+ 'filled': this.safeString(order, 'executedQty'),
1407
+ 'remaining': undefined,
1408
+ 'fee': undefined,
1409
+ 'fees': undefined,
1410
+ 'trades': trades,
1411
+ 'info': order,
1412
+ }, market);
1413
+ }
1414
+ parseOrderSide(status) {
1415
+ const statuses = {
1416
+ 'BUY': 'buy',
1417
+ 'SELL': 'sell',
1418
+ };
1419
+ return this.safeString(statuses, status, status);
1420
+ }
1421
+ encodeOrderSide(status) {
1422
+ const statuses = {
1423
+ 'buy': 'BUY',
1424
+ 'sell': 'SELL',
1425
+ };
1426
+ return this.safeString(statuses, status, status);
1427
+ }
1428
+ parseOrderType(status) {
1429
+ const statuses = {
1430
+ 'MARKET': 'market',
1431
+ 'LIMIT': 'limit',
1432
+ 'LIMIT_MAKER': 'limit',
1433
+ 'STOP_LOSS': 'market',
1434
+ 'STOP_LOSS_LIMIT': 'limit',
1435
+ 'TAKE_PROFIT': 'market',
1436
+ 'TAKE_PROFIT_LIMIT': 'limit',
1437
+ };
1438
+ return this.safeString(statuses, status, status);
1439
+ }
1440
+ encodeOrderType(status) {
1441
+ const statuses = {
1442
+ 'market': 'MARKET',
1443
+ 'limit': 'LIMIT',
1444
+ 'limit_maker': 'LIMIT_MAKER',
1445
+ 'stop_loss': 'STOP_LOSS',
1446
+ 'stop_loss_limit': 'STOP_LOSS_LIMIT',
1447
+ 'take_profit': 'TAKE_PROFIT',
1448
+ 'take_profit_limit': 'TAKE_PROFIT_LIMIT',
1449
+ };
1450
+ return this.safeString(statuses, status, status);
1451
+ }
1452
+ parseOrderStatus(status) {
1453
+ const statuses = {
1454
+ 'NEW': 'open',
1455
+ 'FILLED': 'closed',
1456
+ 'CANCELED': 'canceled',
1457
+ 'PARTIALLY_FILLED': 'open',
1458
+ 'PARTIALLY_CANCELED': 'canceled',
1459
+ 'REJECTED': 'rejected',
1460
+ };
1461
+ return this.safeString(statuses, status, status);
1462
+ }
1463
+ parseOrderTimeInForce(status) {
1464
+ const statuses = {
1465
+ 'GTC': 'GTC',
1466
+ 'FOK': 'FOK',
1467
+ 'IOC': 'IOC',
1468
+ };
1469
+ return this.safeString(statuses, status, status);
1470
+ }
1471
+ async fetchTradingFee(symbol, params = {}) {
1472
+ /**
1473
+ * @method
1474
+ * @name coinsph#fetchTradingFee
1475
+ * @description fetch the trading fees for a market
1476
+ * @param {string} symbol unified market symbol
1477
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1478
+ * @returns {object} a [fee structure]{@link https://docs.ccxt.com/#/?id=fee-structure}
1479
+ */
1480
+ await this.loadMarkets();
1481
+ const market = this.market(symbol);
1482
+ const request = {
1483
+ 'symbol': market['id'],
1484
+ };
1485
+ const response = await this.privateGetOpenapiV1AssetTradeFee(this.extend(request, params));
1486
+ //
1487
+ // [
1488
+ // {
1489
+ // "symbol": "ETHUSDT",
1490
+ // "makerCommission": "0.0025",
1491
+ // "takerCommission": "0.003"
1492
+ // }
1493
+ // ]
1494
+ //
1495
+ const tradingFee = this.safeValue(response, 0, {});
1496
+ return this.parseTradingFee(tradingFee, market);
1497
+ }
1498
+ async fetchTradingFees(params = {}) {
1499
+ /**
1500
+ * @method
1501
+ * @name coinsph#fetchTradingFees
1502
+ * @description fetch the trading fees for multiple markets
1503
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1504
+ * @returns {object} a dictionary of [fee structures]{@link https://docs.ccxt.com/#/?id=fee-structure} indexed by market symbols
1505
+ */
1506
+ await this.loadMarkets();
1507
+ const response = await this.privateGetOpenapiV1AssetTradeFee(params);
1508
+ //
1509
+ // [
1510
+ // {
1511
+ // "symbol": "ETHPHP",
1512
+ // "makerCommission": "0.0025",
1513
+ // "takerCommission": "0.003"
1514
+ // },
1515
+ // {
1516
+ // "symbol": "UNIPHP",
1517
+ // "makerCommission": "0.0025",
1518
+ // "takerCommission": "0.003"
1519
+ // },
1520
+ // ]
1521
+ //
1522
+ const result = {};
1523
+ for (let i = 0; i < response.length; i++) {
1524
+ const fee = this.parseTradingFee(response[i]);
1525
+ const symbol = fee['symbol'];
1526
+ result[symbol] = fee;
1527
+ }
1528
+ return result;
1529
+ }
1530
+ parseTradingFee(fee, market = undefined) {
1531
+ //
1532
+ // {
1533
+ // "symbol": "ETHUSDT",
1534
+ // "makerCommission": "0.0025",
1535
+ // "takerCommission": "0.003"
1536
+ // }
1537
+ //
1538
+ const marketId = this.safeString(fee, 'symbol');
1539
+ market = this.safeMarket(marketId, market);
1540
+ const symbol = market['symbol'];
1541
+ return {
1542
+ 'info': fee,
1543
+ 'symbol': symbol,
1544
+ 'maker': this.safeNumber(fee, 'makerCommission'),
1545
+ 'taker': this.safeNumber(fee, 'takerCommission'),
1546
+ };
1547
+ }
1548
+ async withdraw(code, amount, address, tag = undefined, params = {}) {
1549
+ /**
1550
+ * @method
1551
+ * @name coinsph#withdraw
1552
+ * @description make a withdrawal to coins_ph account
1553
+ * @see https://coins-docs.github.io/rest-api/#withdrawuser_data
1554
+ * @param {string} code unified currency code
1555
+ * @param {float} amount the amount to withdraw
1556
+ * @param {string} address not used by coinsph withdraw ()
1557
+ * @param {string} tag
1558
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1559
+ * @returns {object} a [transaction structure]{@link https://docs.ccxt.com/#/?id=transaction-structure}
1560
+ */
1561
+ const options = this.safeValue(this.options, 'withdraw');
1562
+ const warning = this.safeValue(options, 'warning', true);
1563
+ if (warning) {
1564
+ throw new errors.InvalidAddress(this.id + " withdraw() makes a withdrawals only to coins_ph account, add .options['withdraw']['warning'] = false to make a withdrawal to your coins_ph account");
1565
+ }
1566
+ const networkCode = this.safeString(params, 'network');
1567
+ const networkId = this.networkCodeToId(networkCode, code);
1568
+ if (networkId === undefined) {
1569
+ throw new errors.BadRequest(this.id + ' withdraw() require network parameter');
1570
+ }
1571
+ await this.loadMarkets();
1572
+ const currency = this.currency(code);
1573
+ const request = {
1574
+ 'coin': currency['id'],
1575
+ 'amount': this.numberToString(amount),
1576
+ 'network': networkId,
1577
+ 'address': address,
1578
+ };
1579
+ if (tag !== undefined) {
1580
+ request['withdrawOrderId'] = tag;
1581
+ }
1582
+ params = this.omit(params, 'network');
1583
+ const response = await this.privatePostOpenapiWalletV1WithdrawApply(this.extend(request, params));
1584
+ return this.parseTransaction(response, currency);
1585
+ }
1586
+ async fetchDeposits(code = undefined, since = undefined, limit = undefined, params = {}) {
1587
+ /**
1588
+ * @method
1589
+ * @name coinsph#fetchDeposits
1590
+ * @description fetch all deposits made to an account
1591
+ * @see https://coins-docs.github.io/rest-api/#deposit-history-user_data
1592
+ * @param {string} code unified currency code
1593
+ * @param {int} [since] the earliest time in ms to fetch deposits for
1594
+ * @param {int} [limit] the maximum number of deposits structures to retrieve
1595
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1596
+ * @returns {object[]} a list of [transaction structures]{@link https://docs.ccxt.com/#/?id=transaction-structure}
1597
+ */
1598
+ // todo: returns an empty array - find out why
1599
+ await this.loadMarkets();
1600
+ let currency = undefined;
1601
+ const request = {};
1602
+ if (code !== undefined) {
1603
+ currency = this.currency(code);
1604
+ request['coin'] = currency['id'];
1605
+ }
1606
+ if (since !== undefined) {
1607
+ request['startTime'] = since;
1608
+ }
1609
+ if (limit !== undefined) {
1610
+ request['limit'] = limit;
1611
+ }
1612
+ const response = await this.privateGetOpenapiWalletV1DepositHistory(this.extend(request, params));
1613
+ //
1614
+ // [
1615
+ // {
1616
+ // "id": "d_769800519366885376",
1617
+ // "amount": "0.001",
1618
+ // "coin": "BNB",
1619
+ // "network": "BNB",
1620
+ // "status": 0,
1621
+ // "address": "bnb136ns6lfw4zs5hg4n85vdthaad7hq5m4gtkgf23",
1622
+ // "addressTag": "101764890",
1623
+ // "txId": "98A3EA560C6B3336D348B6C83F0F95ECE4F1F5919E94BD006E5BF3BF264FACFC",
1624
+ // "insertTime": 1661493146000,
1625
+ // "confirmNo": 10,
1626
+ // },
1627
+ // {
1628
+ // "id": "d_769754833590042625",
1629
+ // "amount":"0.5",
1630
+ // "coin":"IOTA",
1631
+ // "network":"IOTA",
1632
+ // "status":1,
1633
+ // "address":"SIZ9VLMHWATXKV99LH99CIGFJFUMLEHGWVZVNNZXRJJVWBPHYWPPBOSDORZ9EQSHCZAMPVAPGFYQAUUV9DROOXJLNW",
1634
+ // "addressTag":"",
1635
+ // "txId":"ESBFVQUTPIWQNJSPXFNHNYHSQNTGKRVKPRABQWTAXCDWOAKDKYWPTVG9BGXNVNKTLEJGESAVXIKIZ9999",
1636
+ // "insertTime":1599620082000,
1637
+ // "confirmNo": 20,
1638
+ // }
1639
+ // ]
1640
+ //
1641
+ return this.parseTransactions(response, currency, since, limit);
1642
+ }
1643
+ async fetchWithdrawals(code = undefined, since = undefined, limit = undefined, params = {}) {
1644
+ /**
1645
+ * @method
1646
+ * @name coinsph#fetchWithdrawals
1647
+ * @description fetch all withdrawals made from an account
1648
+ * @see https://coins-docs.github.io/rest-api/#withdraw-history-user_data
1649
+ * @param {string} code unified currency code
1650
+ * @param {int} [since] the earliest time in ms to fetch withdrawals for
1651
+ * @param {int} [limit] the maximum number of withdrawals structures to retrieve
1652
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1653
+ * @returns {object[]} a list of [transaction structures]{@link https://docs.ccxt.com/#/?id=transaction-structure}
1654
+ */
1655
+ // todo: returns an empty array - find out why
1656
+ await this.loadMarkets();
1657
+ let currency = undefined;
1658
+ const request = {};
1659
+ if (code !== undefined) {
1660
+ currency = this.currency(code);
1661
+ request['coin'] = currency['id'];
1662
+ }
1663
+ if (since !== undefined) {
1664
+ request['startTime'] = since;
1665
+ }
1666
+ if (limit !== undefined) {
1667
+ request['limit'] = limit;
1668
+ }
1669
+ const response = await this.privateGetOpenapiWalletV1WithdrawHistory(this.extend(request, params));
1670
+ //
1671
+ // [
1672
+ // {
1673
+ // "id": "459890698271244288",
1674
+ // "amount": "0.01",
1675
+ // "transactionFee": "0",
1676
+ // "coin": "ETH",
1677
+ // "status": 1,
1678
+ // "address": "0x386AE30AE2dA293987B5d51ddD03AEb70b21001F",
1679
+ // "addressTag": "",
1680
+ // "txId": "0x4ae2fed36a90aada978fc31c38488e8b60d7435cfe0b4daed842456b4771fcf7",
1681
+ // "applyTime": 1673601139000,
1682
+ // "network": "ETH",
1683
+ // "withdrawOrderId": "thomas123",
1684
+ // "info": "",
1685
+ // "confirmNo": 100
1686
+ // },
1687
+ // {
1688
+ // "id": "451899190746456064",
1689
+ // "amount": "0.00063",
1690
+ // "transactionFee": "0.00037",
1691
+ // "coin": "ETH",
1692
+ // "status": 1,
1693
+ // "address": "0x386AE30AE2dA293987B5d51ddD03AEb70b21001F",
1694
+ // "addressTag": "",
1695
+ // "txId": "0x62690ca4f9d6a8868c258e2ce613805af614d9354dda7b39779c57b2e4da0260",
1696
+ // "applyTime": 1671695815000,
1697
+ // "network": "ETH",
1698
+ // "withdrawOrderId": "",
1699
+ // "info": "",
1700
+ // "confirmNo": 100
1701
+ // }
1702
+ // ]
1703
+ //
1704
+ return this.parseTransactions(response, currency, since, limit);
1705
+ }
1706
+ parseTransaction(transaction, currency = undefined) {
1707
+ //
1708
+ // fetchDeposits
1709
+ // {
1710
+ // "coin": "PHP",
1711
+ // "address": "Internal Transfer",
1712
+ // "addressTag": "Internal Transfer",
1713
+ // "amount": "0.02",
1714
+ // "id": "31312321312312312312322",
1715
+ // "network": "Internal",
1716
+ // "transferType": "0",
1717
+ // "status": 3,
1718
+ // "confirmTimes": "",
1719
+ // "unlockConfirm": "",
1720
+ // "txId": "Internal Transfer",
1721
+ // "insertTime": 1657623798000,
1722
+ // "depositOrderId": "the deposit id which created by client"
1723
+ // }
1724
+ //
1725
+ // fetchWithdrawals
1726
+ // {
1727
+ // "coin": "BTC",
1728
+ // "address": "Internal Transfer",
1729
+ // "amount": "0.1",
1730
+ // "id": "1201515362324421632",
1731
+ // "withdrawOrderId": null,
1732
+ // "network": "Internal",
1733
+ // "transferType": "0",
1734
+ // "status": 0,
1735
+ // "transactionFee": "0",
1736
+ // "confirmNo": 0,
1737
+ // "info": "{}",
1738
+ // "txId": "Internal Transfer",
1739
+ // "applyTime": 1657967792000
1740
+ // }
1741
+ //
1742
+ // todo: this is in progress
1743
+ const id = this.safeString(transaction, 'id');
1744
+ const address = this.safeString(transaction, 'address');
1745
+ let tag = this.safeString(transaction, 'addressTag');
1746
+ if (tag !== undefined) {
1747
+ if (tag.length < 1) {
1748
+ tag = undefined;
1749
+ }
1750
+ }
1751
+ const txid = this.safeString(transaction, 'txId');
1752
+ const currencyId = this.safeString(transaction, 'coin');
1753
+ const code = this.safeCurrencyCode(currencyId, currency);
1754
+ let timestamp = undefined;
1755
+ timestamp = this.safeInteger2(transaction, 'insertTime', 'applyTime');
1756
+ const updated = undefined;
1757
+ let type = undefined;
1758
+ const withdrawOrderId = this.safeString(transaction, 'withdrawOrderId');
1759
+ const depositOrderId = this.safeString(transaction, 'depositOrderId');
1760
+ if (withdrawOrderId !== undefined) {
1761
+ type = 'withdrawal';
1762
+ }
1763
+ else if (depositOrderId !== undefined) {
1764
+ type = 'deposit';
1765
+ }
1766
+ const status = this.parseTransactionStatus(this.safeString(transaction, 'status'));
1767
+ const amount = this.safeNumber(transaction, 'amount');
1768
+ const feeCost = this.safeNumber(transaction, 'transactionFee');
1769
+ let fee = undefined;
1770
+ if (feeCost !== undefined) {
1771
+ fee = { 'currency': code, 'cost': feeCost };
1772
+ }
1773
+ const network = this.safeString(transaction, 'network');
1774
+ const internal = network === 'Internal';
1775
+ return {
1776
+ 'info': transaction,
1777
+ 'id': id,
1778
+ 'txid': txid,
1779
+ 'timestamp': timestamp,
1780
+ 'datetime': this.iso8601(timestamp),
1781
+ 'network': network,
1782
+ 'address': address,
1783
+ 'addressTo': address,
1784
+ 'addressFrom': undefined,
1785
+ 'tag': tag,
1786
+ 'tagTo': tag,
1787
+ 'tagFrom': undefined,
1788
+ 'type': type,
1789
+ 'amount': amount,
1790
+ 'currency': code,
1791
+ 'status': status,
1792
+ 'updated': updated,
1793
+ 'internal': internal,
1794
+ 'comment': undefined,
1795
+ 'fee': fee,
1796
+ };
1797
+ }
1798
+ parseTransactionStatus(status) {
1799
+ const statuses = {
1800
+ '0': 'pending',
1801
+ '1': 'ok',
1802
+ '2': 'failed',
1803
+ '3': 'pending',
1804
+ };
1805
+ return this.safeString(statuses, status, status);
1806
+ }
1807
+ async fetchDepositAddress(code, params = {}) {
1808
+ /**
1809
+ * @method
1810
+ * @name coinsph#fetchDepositAddress
1811
+ * @description fetch the deposit address for a currency associated with this account
1812
+ * @see https://coins-docs.github.io/rest-api/#deposit-address-user_data
1813
+ * @param {string} code unified currency code
1814
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1815
+ * @param {string} [params.network] network for fetch deposit address
1816
+ * @returns {object} an [address structure]{@link https://docs.ccxt.com/#/?id=address-structure}
1817
+ */
1818
+ const networkCode = this.safeString(params, 'network');
1819
+ const networkId = this.networkCodeToId(networkCode, code);
1820
+ if (networkId === undefined) {
1821
+ throw new errors.BadRequest(this.id + ' fetchDepositAddress() require network parameter');
1822
+ }
1823
+ await this.loadMarkets();
1824
+ const currency = this.currency(code);
1825
+ const request = {
1826
+ 'coin': currency['id'],
1827
+ 'network': networkId,
1828
+ };
1829
+ params = this.omit(params, 'network');
1830
+ const response = await this.privateGetOpenapiWalletV1DepositAddress(this.extend(request, params));
1831
+ //
1832
+ // {
1833
+ // "coin": "ETH",
1834
+ // "address": "0xfe98628173830bf79c59f04585ce41f7de168784",
1835
+ // "addressTag": ""
1836
+ // }
1837
+ //
1838
+ return this.parseDepositAddress(response, currency);
1839
+ }
1840
+ parseDepositAddress(depositAddress, currency = undefined) {
1841
+ //
1842
+ // {
1843
+ // "coin": "ETH",
1844
+ // "address": "0xfe98628173830bf79c59f04585ce41f7de168784",
1845
+ // "addressTag": ""
1846
+ // }
1847
+ //
1848
+ const currencyId = this.safeString(depositAddress, 'coin');
1849
+ const parsedCurrency = this.safeCurrencyCode(currencyId, currency);
1850
+ return {
1851
+ 'currency': parsedCurrency,
1852
+ 'address': this.safeString(depositAddress, 'address'),
1853
+ 'tag': this.safeString(depositAddress, 'addressTag'),
1854
+ 'network': null,
1855
+ 'info': depositAddress,
1856
+ };
1857
+ }
1858
+ urlEncodeQuery(query = {}) {
1859
+ let encodedArrayParams = '';
1860
+ const keys = Object.keys(query);
1861
+ for (let i = 0; i < keys.length; i++) {
1862
+ const key = keys[i];
1863
+ if (Array.isArray(query[key])) {
1864
+ if (i !== 0) {
1865
+ encodedArrayParams += '&';
1866
+ }
1867
+ const innerArray = query[key];
1868
+ query = this.omit(query, key);
1869
+ const encodedArrayParam = this.parseArrayParam(innerArray, key);
1870
+ encodedArrayParams += encodedArrayParam;
1871
+ }
1872
+ }
1873
+ const encodedQuery = this.urlencode(query);
1874
+ if (encodedQuery.length !== 0) {
1875
+ return encodedQuery + '&' + encodedArrayParams;
1876
+ }
1877
+ else {
1878
+ return encodedArrayParams;
1879
+ }
1880
+ }
1881
+ parseArrayParam(array, key) {
1882
+ let stringifiedArray = this.json(array);
1883
+ stringifiedArray = stringifiedArray.replace('[', '%5B');
1884
+ stringifiedArray = stringifiedArray.replace(']', '%5D');
1885
+ const urlEncodedParam = key + '=' + stringifiedArray;
1886
+ return urlEncodedParam;
1887
+ }
1888
+ sign(path, api = 'public', method = 'GET', params = {}, headers = undefined, body = undefined) {
1889
+ let url = this.urls['api'][api];
1890
+ let query = this.omit(params, this.extractParams(path));
1891
+ const endpoint = this.implodeParams(path, params);
1892
+ url = url + '/' + endpoint;
1893
+ if (api === 'private') {
1894
+ this.checkRequiredCredentials();
1895
+ query['timestamp'] = this.milliseconds();
1896
+ const recvWindow = this.safeInteger(query, 'recvWindow');
1897
+ if (recvWindow === undefined) {
1898
+ const defaultRecvWindow = this.safeInteger(this.options, 'recvWindow');
1899
+ if (defaultRecvWindow !== undefined) {
1900
+ query['recvWindow'] = defaultRecvWindow;
1901
+ }
1902
+ }
1903
+ query = this.urlEncodeQuery(query);
1904
+ const signature = this.hmac(this.encode(query), this.encode(this.secret), sha256.sha256);
1905
+ url = url + '?' + query + '&signature=' + signature;
1906
+ headers = {
1907
+ 'X-COINS-APIKEY': this.apiKey,
1908
+ };
1909
+ }
1910
+ else {
1911
+ query = this.urlEncodeQuery(query);
1912
+ if (query.length !== 0) {
1913
+ url += '?' + query;
1914
+ }
1915
+ }
1916
+ return { 'url': url, 'method': method, 'body': body, 'headers': headers };
1917
+ }
1918
+ handleErrors(code, reason, url, method, headers, body, response, requestHeaders, requestBody) {
1919
+ if (response === undefined) {
1920
+ return undefined;
1921
+ }
1922
+ const responseCode = this.safeString(response, 'code', undefined);
1923
+ if ((responseCode !== undefined) && (responseCode !== '200') && (responseCode !== '0')) {
1924
+ const feedback = this.id + ' ' + body;
1925
+ this.throwBroadlyMatchedException(this.exceptions['broad'], body, feedback);
1926
+ this.throwExactlyMatchedException(this.exceptions['exact'], responseCode, feedback);
1927
+ throw new errors.ExchangeError(feedback);
1928
+ }
1929
+ return undefined;
1930
+ }
1931
+ }
1932
+
1933
+ module.exports = coinsph;