ccxt 4.2.11 → 4.2.12
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.
- package/README.md +5 -5
- package/build.sh +2 -2
- package/dist/ccxt.browser.js +640 -261
- package/dist/ccxt.browser.min.js +3 -3
- package/dist/cjs/_virtual/agent.js +7 -0
- package/dist/cjs/_virtual/parse-proxy-response.js +7 -0
- package/dist/cjs/_virtual/promisify.js +7 -0
- package/dist/cjs/ccxt.js +1 -1
- package/dist/cjs/js/ccxt.js +474 -0
- package/dist/cjs/js/src/abstract/ace.js +9 -0
- package/dist/cjs/js/src/abstract/alpaca.js +9 -0
- package/dist/cjs/js/src/abstract/ascendex.js +9 -0
- package/dist/cjs/js/src/abstract/bigone.js +9 -0
- package/dist/cjs/js/src/abstract/binance.js +9 -0
- package/dist/cjs/js/src/abstract/bingx.js +9 -0
- package/dist/cjs/js/src/abstract/bit2c.js +9 -0
- package/dist/cjs/js/src/abstract/bitbank.js +9 -0
- package/dist/cjs/js/src/abstract/bitbns.js +9 -0
- package/dist/cjs/js/src/abstract/bitfinex.js +9 -0
- package/dist/cjs/js/src/abstract/bitfinex2.js +9 -0
- package/dist/cjs/js/src/abstract/bitflyer.js +9 -0
- package/dist/cjs/js/src/abstract/bitforex.js +9 -0
- package/dist/cjs/js/src/abstract/bitget.js +9 -0
- package/dist/cjs/js/src/abstract/bithumb.js +9 -0
- package/dist/cjs/js/src/abstract/bitmart.js +9 -0
- package/dist/cjs/js/src/abstract/bitmex.js +9 -0
- package/dist/cjs/js/src/abstract/bitopro.js +9 -0
- package/dist/cjs/js/src/abstract/bitpanda.js +9 -0
- package/dist/cjs/js/src/abstract/bitrue.js +9 -0
- package/dist/cjs/js/src/abstract/bitso.js +9 -0
- package/dist/cjs/js/src/abstract/bitstamp.js +9 -0
- package/dist/cjs/js/src/abstract/bitteam.js +9 -0
- package/dist/cjs/js/src/abstract/bitvavo.js +9 -0
- package/dist/cjs/js/src/abstract/bl3p.js +9 -0
- package/dist/cjs/js/src/abstract/blockchaincom.js +9 -0
- package/dist/cjs/js/src/abstract/btcalpha.js +9 -0
- package/dist/cjs/js/src/abstract/btcbox.js +9 -0
- package/dist/cjs/js/src/abstract/btcmarkets.js +9 -0
- package/dist/cjs/js/src/abstract/btcturk.js +9 -0
- package/dist/cjs/js/src/abstract/bybit.js +9 -0
- package/dist/cjs/js/src/abstract/cex.js +9 -0
- package/dist/cjs/js/src/abstract/coinbase.js +9 -0
- package/dist/cjs/js/src/abstract/coinbasepro.js +9 -0
- package/dist/cjs/js/src/abstract/coincheck.js +9 -0
- package/dist/cjs/js/src/abstract/coinex.js +9 -0
- package/dist/cjs/js/src/abstract/coinlist.js +9 -0
- package/dist/cjs/js/src/abstract/coinmate.js +9 -0
- package/dist/cjs/js/src/abstract/coinone.js +9 -0
- package/dist/cjs/js/src/abstract/coinsph.js +9 -0
- package/dist/cjs/js/src/abstract/coinspot.js +9 -0
- package/dist/cjs/js/src/abstract/cryptocom.js +9 -0
- package/dist/cjs/js/src/abstract/currencycom.js +9 -0
- package/dist/cjs/js/src/abstract/delta.js +9 -0
- package/dist/cjs/js/src/abstract/deribit.js +9 -0
- package/dist/cjs/js/src/abstract/digifinex.js +9 -0
- package/dist/cjs/js/src/abstract/exmo.js +9 -0
- package/dist/cjs/js/src/abstract/gate.js +9 -0
- package/dist/cjs/js/src/abstract/gemini.js +9 -0
- package/dist/cjs/js/src/abstract/hitbtc.js +9 -0
- package/dist/cjs/js/src/abstract/hollaex.js +9 -0
- package/dist/cjs/js/src/abstract/htx.js +9 -0
- package/dist/cjs/js/src/abstract/huobijp.js +9 -0
- package/dist/cjs/js/src/abstract/idex.js +9 -0
- package/dist/cjs/js/src/abstract/independentreserve.js +9 -0
- package/dist/cjs/js/src/abstract/indodax.js +9 -0
- package/dist/cjs/js/src/abstract/kraken.js +9 -0
- package/dist/cjs/js/src/abstract/krakenfutures.js +9 -0
- package/dist/cjs/js/src/abstract/kucoin.js +9 -0
- package/dist/cjs/js/src/abstract/kucoinfutures.js +9 -0
- package/dist/cjs/js/src/abstract/kuna.js +9 -0
- package/dist/cjs/js/src/abstract/latoken.js +9 -0
- package/dist/cjs/js/src/abstract/lbank.js +9 -0
- package/dist/cjs/js/src/abstract/luno.js +9 -0
- package/dist/cjs/js/src/abstract/lykke.js +9 -0
- package/dist/cjs/js/src/abstract/mercado.js +9 -0
- package/dist/cjs/js/src/abstract/mexc.js +9 -0
- package/dist/cjs/js/src/abstract/ndax.js +9 -0
- package/dist/cjs/js/src/abstract/novadax.js +9 -0
- package/dist/cjs/js/src/abstract/oceanex.js +9 -0
- package/dist/cjs/js/src/abstract/okcoin.js +9 -0
- package/dist/cjs/js/src/abstract/okx.js +9 -0
- package/dist/cjs/js/src/abstract/p2b.js +9 -0
- package/dist/cjs/js/src/abstract/paymium.js +9 -0
- package/dist/cjs/js/src/abstract/phemex.js +9 -0
- package/dist/cjs/js/src/abstract/poloniex.js +9 -0
- package/dist/cjs/js/src/abstract/poloniexfutures.js +9 -0
- package/dist/cjs/js/src/abstract/probit.js +9 -0
- package/dist/cjs/js/src/abstract/timex.js +9 -0
- package/dist/cjs/js/src/abstract/tokocrypto.js +9 -0
- package/dist/cjs/js/src/abstract/upbit.js +9 -0
- package/dist/cjs/js/src/abstract/wavesexchange.js +9 -0
- package/dist/cjs/js/src/abstract/wazirx.js +9 -0
- package/dist/cjs/js/src/abstract/whitebit.js +9 -0
- package/dist/cjs/js/src/abstract/woo.js +9 -0
- package/dist/cjs/js/src/abstract/yobit.js +9 -0
- package/dist/cjs/js/src/abstract/zaif.js +9 -0
- package/dist/cjs/js/src/abstract/zonda.js +9 -0
- package/dist/cjs/js/src/ace.js +1058 -0
- package/dist/cjs/js/src/alpaca.js +1125 -0
- package/dist/cjs/js/src/ascendex.js +3360 -0
- package/dist/cjs/js/src/base/Exchange.js +5110 -0
- package/dist/cjs/js/src/base/Precise.js +263 -0
- package/dist/cjs/js/src/base/errors.js +299 -0
- package/dist/cjs/js/src/base/functions/crypto.js +78 -0
- package/dist/cjs/js/src/base/functions/encode.js +44 -0
- package/dist/cjs/js/src/base/functions/generic.js +193 -0
- package/dist/cjs/js/src/base/functions/misc.js +96 -0
- package/dist/cjs/js/src/base/functions/number.js +297 -0
- package/dist/cjs/js/src/base/functions/platform.js +28 -0
- package/dist/cjs/js/src/base/functions/rsa.js +34 -0
- package/dist/cjs/js/src/base/functions/string.js +48 -0
- package/dist/cjs/js/src/base/functions/throttle.js +66 -0
- package/dist/cjs/js/src/base/functions/time.js +187 -0
- package/dist/cjs/js/src/base/functions/totp.js +24 -0
- package/dist/cjs/js/src/base/functions/type.js +162 -0
- package/dist/cjs/js/src/base/functions.js +157 -0
- package/dist/cjs/js/src/base/ws/Cache.js +254 -0
- package/dist/cjs/js/src/base/ws/Client.js +299 -0
- package/dist/cjs/js/src/base/ws/Future.js +34 -0
- package/dist/cjs/js/src/base/ws/OrderBook.js +107 -0
- package/dist/cjs/js/src/base/ws/OrderBookSide.js +281 -0
- package/dist/cjs/js/src/base/ws/WsClient.js +69 -0
- package/dist/cjs/js/src/bequant.js +33 -0
- package/dist/cjs/js/src/bigone.js +2142 -0
- package/dist/cjs/js/src/binance.js +9729 -0
- package/dist/cjs/js/src/binancecoinm.js +45 -0
- package/dist/cjs/js/src/binanceus.js +84 -0
- package/dist/cjs/js/src/binanceusdm.js +58 -0
- package/dist/cjs/js/src/bingx.js +3737 -0
- package/dist/cjs/js/src/bit2c.js +916 -0
- package/dist/cjs/js/src/bitbank.js +1000 -0
- package/dist/cjs/js/src/bitbay.js +17 -0
- package/dist/cjs/js/src/bitbns.js +1220 -0
- package/dist/cjs/js/src/bitcoincom.js +17 -0
- package/dist/cjs/js/src/bitfinex.js +1670 -0
- package/dist/cjs/js/src/bitfinex2.js +2990 -0
- package/dist/cjs/js/src/bitflyer.js +1045 -0
- package/dist/cjs/js/src/bitforex.js +852 -0
- package/dist/cjs/js/src/bitget.js +8284 -0
- package/dist/cjs/js/src/bithumb.js +1090 -0
- package/dist/cjs/js/src/bitmart.js +4454 -0
- package/dist/cjs/js/src/bitmex.js +2884 -0
- package/dist/cjs/js/src/bitopro.js +1724 -0
- package/dist/cjs/js/src/bitpanda.js +2002 -0
- package/dist/cjs/js/src/bitrue.js +3253 -0
- package/dist/cjs/js/src/bitso.js +1753 -0
- package/dist/cjs/js/src/bitstamp.js +2188 -0
- package/dist/cjs/js/src/bitteam.js +2309 -0
- package/dist/cjs/js/src/bitvavo.js +1968 -0
- package/dist/cjs/js/src/bl3p.js +447 -0
- package/dist/cjs/js/src/blockchaincom.js +1160 -0
- package/dist/cjs/js/src/btcalpha.js +929 -0
- package/dist/cjs/js/src/btcbox.js +565 -0
- package/dist/cjs/js/src/btcmarkets.js +1237 -0
- package/dist/cjs/js/src/btcturk.js +929 -0
- package/dist/cjs/js/src/bybit.js +7646 -0
- package/dist/cjs/js/src/cex.js +1693 -0
- package/dist/cjs/js/src/coinbase.js +3274 -0
- package/dist/cjs/js/src/coinbasepro.js +1866 -0
- package/dist/cjs/js/src/coincheck.js +843 -0
- package/dist/cjs/js/src/coinex.js +5414 -0
- package/dist/cjs/js/src/coinlist.js +2329 -0
- package/dist/cjs/js/src/coinmate.js +989 -0
- package/dist/cjs/js/src/coinone.js +1185 -0
- package/dist/cjs/js/src/coinsph.js +1933 -0
- package/dist/cjs/js/src/coinspot.js +548 -0
- package/dist/cjs/js/src/cryptocom.js +3007 -0
- package/dist/cjs/js/src/currencycom.js +2015 -0
- package/dist/cjs/js/src/delta.js +3256 -0
- package/dist/cjs/js/src/deribit.js +3306 -0
- package/dist/cjs/js/src/digifinex.js +4307 -0
- package/dist/cjs/js/src/exmo.js +2645 -0
- package/dist/cjs/js/src/fmfwio.js +34 -0
- package/dist/cjs/js/src/gate.js +7054 -0
- package/dist/cjs/js/src/gateio.js +16 -0
- package/dist/cjs/js/src/gemini.js +1801 -0
- package/dist/cjs/js/src/hitbtc.js +3660 -0
- package/dist/cjs/js/src/hitbtc3.js +19 -0
- package/dist/cjs/js/src/hollaex.js +1882 -0
- package/dist/cjs/js/src/htx.js +9024 -0
- package/dist/cjs/js/src/huobi.js +16 -0
- package/dist/cjs/js/src/huobijp.js +1918 -0
- package/dist/cjs/js/src/idex.js +1770 -0
- package/dist/cjs/js/src/independentreserve.js +759 -0
- package/dist/cjs/js/src/indodax.js +1069 -0
- package/dist/cjs/js/src/kraken.js +2861 -0
- package/dist/cjs/js/src/krakenfutures.js +2407 -0
- package/dist/cjs/js/src/kucoin.js +4489 -0
- package/dist/cjs/js/src/kucoinfutures.js +2475 -0
- package/dist/cjs/js/src/kuna.js +1949 -0
- package/dist/cjs/js/src/latoken.js +1729 -0
- package/dist/cjs/js/src/lbank.js +2825 -0
- package/dist/cjs/js/src/luno.js +1044 -0
- package/dist/cjs/js/src/lykke.js +1303 -0
- package/dist/cjs/js/src/mercado.js +897 -0
- package/dist/cjs/js/src/mexc.js +5407 -0
- package/dist/cjs/js/src/ndax.js +2450 -0
- package/dist/cjs/js/src/novadax.js +1556 -0
- package/dist/cjs/js/src/oceanex.js +964 -0
- package/dist/cjs/js/src/okcoin.js +3115 -0
- package/dist/cjs/js/src/okx.js +7329 -0
- package/dist/cjs/js/src/p2b.js +1243 -0
- package/dist/cjs/js/src/paymium.js +597 -0
- package/dist/cjs/js/src/phemex.js +4715 -0
- package/dist/cjs/js/src/poloniex.js +2356 -0
- package/dist/cjs/js/src/poloniexfutures.js +1794 -0
- package/dist/cjs/js/src/pro/alpaca.js +714 -0
- package/dist/cjs/js/src/pro/ascendex.js +957 -0
- package/dist/cjs/js/src/pro/bequant.js +33 -0
- package/dist/cjs/js/src/pro/binance.js +2796 -0
- package/dist/cjs/js/src/pro/binancecoinm.js +23 -0
- package/dist/cjs/js/src/pro/binanceus.js +51 -0
- package/dist/cjs/js/src/pro/binanceusdm.js +32 -0
- package/dist/cjs/js/src/pro/bingx.js +944 -0
- package/dist/cjs/js/src/pro/bitcoincom.js +29 -0
- package/dist/cjs/js/src/pro/bitfinex.js +672 -0
- package/dist/cjs/js/src/pro/bitfinex2.js +1159 -0
- package/dist/cjs/js/src/pro/bitget.js +1733 -0
- package/dist/cjs/js/src/pro/bitmart.js +1486 -0
- package/dist/cjs/js/src/pro/bitmex.js +1576 -0
- package/dist/cjs/js/src/pro/bitopro.js +327 -0
- package/dist/cjs/js/src/pro/bitpanda.js +1341 -0
- package/dist/cjs/js/src/pro/bitrue.js +462 -0
- package/dist/cjs/js/src/pro/bitstamp.js +547 -0
- package/dist/cjs/js/src/pro/bitvavo.js +704 -0
- package/dist/cjs/js/src/pro/blockchaincom.js +794 -0
- package/dist/cjs/js/src/pro/bybit.js +1843 -0
- package/dist/cjs/js/src/pro/cex.js +1510 -0
- package/dist/cjs/js/src/pro/coinbase.js +561 -0
- package/dist/cjs/js/src/pro/coinbasepro.js +968 -0
- package/dist/cjs/js/src/pro/coinex.js +1095 -0
- package/dist/cjs/js/src/pro/cryptocom.js +1020 -0
- package/dist/cjs/js/src/pro/currencycom.js +563 -0
- package/dist/cjs/js/src/pro/deribit.js +825 -0
- package/dist/cjs/js/src/pro/exmo.js +658 -0
- package/dist/cjs/js/src/pro/gate.js +1316 -0
- package/dist/cjs/js/src/pro/gateio.js +16 -0
- package/dist/cjs/js/src/pro/gemini.js +649 -0
- package/dist/cjs/js/src/pro/hitbtc.js +1293 -0
- package/dist/cjs/js/src/pro/hollaex.js +597 -0
- package/dist/cjs/js/src/pro/htx.js +2383 -0
- package/dist/cjs/js/src/pro/huobi.js +16 -0
- package/dist/cjs/js/src/pro/huobijp.js +606 -0
- package/dist/cjs/js/src/pro/idex.js +714 -0
- package/dist/cjs/js/src/pro/independentreserve.js +280 -0
- package/dist/cjs/js/src/pro/kraken.js +1364 -0
- package/dist/cjs/js/src/pro/krakenfutures.js +1500 -0
- package/dist/cjs/js/src/pro/kucoin.js +1052 -0
- package/dist/cjs/js/src/pro/kucoinfutures.js +981 -0
- package/dist/cjs/js/src/pro/luno.js +322 -0
- package/dist/cjs/js/src/pro/mexc.js +1170 -0
- package/dist/cjs/js/src/pro/ndax.js +545 -0
- package/dist/cjs/js/src/pro/okcoin.js +760 -0
- package/dist/cjs/js/src/pro/okx.js +1558 -0
- package/dist/cjs/js/src/pro/phemex.js +1511 -0
- package/dist/cjs/js/src/pro/poloniex.js +1253 -0
- package/dist/cjs/js/src/pro/poloniexfutures.js +1014 -0
- package/dist/cjs/js/src/pro/probit.js +586 -0
- package/dist/cjs/js/src/pro/upbit.js +234 -0
- package/dist/cjs/js/src/pro/wazirx.js +776 -0
- package/dist/cjs/js/src/pro/whitebit.js +927 -0
- package/dist/cjs/js/src/pro/woo.js +769 -0
- package/dist/cjs/js/src/probit.js +1865 -0
- package/dist/cjs/js/src/static_dependencies/fflake/browser.js +401 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncrypt.js +195 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/JSEncryptRSAKey.js +308 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/asn1.js +554 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/base64.js +94 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/hex.js +70 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/asn1js/int10.js +91 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/base64.js +16 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/jsbn.js +1760 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/prng4.js +52 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rng.js +81 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/rsa.js +376 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsbn/util.js +70 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/asn1-1.0.js +1580 -0
- package/dist/cjs/js/src/static_dependencies/jsencrypt/lib/jsrsasign/yahoo.js +74 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/_shortw_utils.js +24 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/curve.js +158 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/edwards.js +429 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/hash-to-curve.js +176 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/modular.js +324 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/montgomery.js +163 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/utils.js +245 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/abstract/weierstrass.js +1018 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/ed25519.js +383 -0
- package/dist/cjs/js/src/static_dependencies/noble-curves/secp256k1.js +258 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_assert.js +53 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_sha2.js +120 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/_u64.js +69 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/crypto.js +7 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/hmac.js +83 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/md5.js +240 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha1.js +91 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha256.js +130 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha3.js +214 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/sha512.js +239 -0
- package/dist/cjs/js/src/static_dependencies/noble-hashes/utils.js +93 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/body.js +354 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/abort-error.js +16 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/base.js +20 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/errors/fetch-error.js +30 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/headers.js +239 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/index.js +372 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/request.js +273 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/response.js +139 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/get-search.js +14 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is-redirect.js +16 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/is.js +81 -0
- package/dist/cjs/js/src/static_dependencies/node-fetch/utils/referrer.js +292 -0
- package/dist/cjs/js/src/static_dependencies/proxies/agent-base/index.js +103 -0
- package/dist/cjs/js/src/static_dependencies/proxies/http-proxy-agent/index.js +140 -0
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/index.js +175 -0
- package/dist/cjs/js/src/static_dependencies/proxies/https-proxy-agent/parse-proxy-response.js +95 -0
- package/dist/cjs/js/src/static_dependencies/qs/index.cjs.js +7 -0
- package/dist/cjs/js/src/static_dependencies/scure-base/index.js +383 -0
- package/dist/cjs/js/src/timex.js +1562 -0
- package/dist/cjs/js/src/tokocrypto.js +2542 -0
- package/dist/cjs/js/src/upbit.js +1844 -0
- package/dist/cjs/js/src/wavesexchange.js +2607 -0
- package/dist/cjs/js/src/wazirx.js +953 -0
- package/dist/cjs/js/src/whitebit.js +2309 -0
- package/dist/cjs/js/src/woo.js +2715 -0
- package/dist/cjs/js/src/yobit.js +1314 -0
- package/dist/cjs/js/src/zaif.js +736 -0
- package/dist/cjs/js/src/zonda.js +1883 -0
- package/js/ccxt.d.ts +1 -1
- package/js/ccxt.js +1 -1
- package/js/src/abstract/bigone.d.ts +18 -0
- package/js/src/abstract/binance.d.ts +2 -0
- package/js/src/abstract/binancecoinm.d.ts +2 -0
- package/js/src/abstract/binanceus.d.ts +2 -0
- package/js/src/abstract/binanceusdm.d.ts +2 -0
- package/js/src/abstract/bybit.d.ts +1 -0
- package/js/src/abstract/gate.d.ts +11 -0
- package/js/src/abstract/gateio.d.ts +11 -0
- package/js/src/alpaca.js +18 -18
- package/js/src/base/Exchange.d.ts +5 -1
- package/js/src/base/Exchange.js +101 -12
- package/js/src/bigone.d.ts +1 -2
- package/js/src/bigone.js +340 -145
- package/js/src/binance.js +15 -8
- package/js/src/bingx.js +9 -2
- package/js/src/bitfinex.d.ts +2 -2
- package/js/src/bitfinex.js +2 -3
- package/js/src/bitget.js +21 -8
- package/js/src/bitmart.d.ts +2 -2
- package/js/src/bitmart.js +3 -3
- package/js/src/bitmex.js +1 -0
- package/js/src/bybit.js +2 -0
- package/js/src/coinlist.js +2 -3
- package/js/src/coinsph.js +2 -3
- package/js/src/deribit.js +1 -0
- package/js/src/gate.d.ts +4 -4
- package/js/src/gate.js +22 -3
- package/js/src/hitbtc.d.ts +4 -4
- package/js/src/hitbtc.js +2 -3
- package/js/src/htx.js +4 -7
- package/js/src/huobijp.js +2 -3
- package/js/src/kraken.js +1 -0
- package/js/src/mexc.js +2 -1
- package/js/src/okx.js +13 -3
- package/js/src/pro/binance.d.ts +2 -23
- package/js/src/pro/binance.js +58 -22
- package/js/src/pro/coinbase.d.ts +2 -2
- package/js/src/pro/coinbase.js +4 -1
- package/js/src/pro/coinbasepro.d.ts +2 -2
- package/js/src/pro/hitbtc.d.ts +2 -2
- package/js/src/pro/poloniex.d.ts +2 -2
- package/js/src/upbit.d.ts +3 -101
- package/js/src/upbit.js +12 -12
- package/js/src/woo.js +2 -0
- package/package.json +1 -1
- package/skip-tests.json +5 -0
|
@@ -0,0 +1,843 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var coincheck$1 = require('./abstract/coincheck.js');
|
|
4
|
+
var errors = require('./base/errors.js');
|
|
5
|
+
var number = require('./base/functions/number.js');
|
|
6
|
+
var sha256 = require('./static_dependencies/noble-hashes/sha256.js');
|
|
7
|
+
|
|
8
|
+
// ---------------------------------------------------------------------------
|
|
9
|
+
// ---------------------------------------------------------------------------
|
|
10
|
+
/**
|
|
11
|
+
* @class coincheck
|
|
12
|
+
* @augments Exchange
|
|
13
|
+
*/
|
|
14
|
+
class coincheck extends coincheck$1 {
|
|
15
|
+
describe() {
|
|
16
|
+
return this.deepExtend(super.describe(), {
|
|
17
|
+
'id': 'coincheck',
|
|
18
|
+
'name': 'coincheck',
|
|
19
|
+
'countries': ['JP', 'ID'],
|
|
20
|
+
'rateLimit': 1500,
|
|
21
|
+
'has': {
|
|
22
|
+
'CORS': undefined,
|
|
23
|
+
'spot': true,
|
|
24
|
+
'margin': false,
|
|
25
|
+
'swap': false,
|
|
26
|
+
'future': false,
|
|
27
|
+
'option': false,
|
|
28
|
+
'addMargin': false,
|
|
29
|
+
'cancelOrder': true,
|
|
30
|
+
'closeAllPositions': false,
|
|
31
|
+
'closePosition': false,
|
|
32
|
+
'createOrder': true,
|
|
33
|
+
'createReduceOnlyOrder': false,
|
|
34
|
+
'fetchBalance': true,
|
|
35
|
+
'fetchBorrowRateHistories': false,
|
|
36
|
+
'fetchBorrowRateHistory': false,
|
|
37
|
+
'fetchCrossBorrowRate': false,
|
|
38
|
+
'fetchCrossBorrowRates': false,
|
|
39
|
+
'fetchDeposits': true,
|
|
40
|
+
'fetchFundingHistory': false,
|
|
41
|
+
'fetchFundingRate': false,
|
|
42
|
+
'fetchFundingRateHistory': false,
|
|
43
|
+
'fetchFundingRates': false,
|
|
44
|
+
'fetchIndexOHLCV': false,
|
|
45
|
+
'fetchIsolatedBorrowRate': false,
|
|
46
|
+
'fetchIsolatedBorrowRates': false,
|
|
47
|
+
'fetchLeverage': false,
|
|
48
|
+
'fetchMarginMode': false,
|
|
49
|
+
'fetchMarkOHLCV': false,
|
|
50
|
+
'fetchMyTrades': true,
|
|
51
|
+
'fetchOpenInterestHistory': false,
|
|
52
|
+
'fetchOpenOrders': true,
|
|
53
|
+
'fetchOrderBook': true,
|
|
54
|
+
'fetchPosition': false,
|
|
55
|
+
'fetchPositionMode': false,
|
|
56
|
+
'fetchPositions': false,
|
|
57
|
+
'fetchPositionsRisk': false,
|
|
58
|
+
'fetchPremiumIndexOHLCV': false,
|
|
59
|
+
'fetchTicker': true,
|
|
60
|
+
'fetchTrades': true,
|
|
61
|
+
'fetchTradingFee': false,
|
|
62
|
+
'fetchTradingFees': true,
|
|
63
|
+
'fetchWithdrawals': true,
|
|
64
|
+
'reduceMargin': false,
|
|
65
|
+
'setLeverage': false,
|
|
66
|
+
'setMarginMode': false,
|
|
67
|
+
'setPositionMode': false,
|
|
68
|
+
},
|
|
69
|
+
'urls': {
|
|
70
|
+
'logo': 'https://user-images.githubusercontent.com/51840849/87182088-1d6d6380-c2ec-11ea-9c64-8ab9f9b289f5.jpg',
|
|
71
|
+
'api': {
|
|
72
|
+
'rest': 'https://coincheck.com/api',
|
|
73
|
+
},
|
|
74
|
+
'www': 'https://coincheck.com',
|
|
75
|
+
'doc': 'https://coincheck.com/documents/exchange/api',
|
|
76
|
+
'fees': [
|
|
77
|
+
'https://coincheck.com/exchange/fee',
|
|
78
|
+
'https://coincheck.com/info/fee',
|
|
79
|
+
],
|
|
80
|
+
},
|
|
81
|
+
'api': {
|
|
82
|
+
'public': {
|
|
83
|
+
'get': [
|
|
84
|
+
'exchange/orders/rate',
|
|
85
|
+
'order_books',
|
|
86
|
+
'rate/{pair}',
|
|
87
|
+
'ticker',
|
|
88
|
+
'trades',
|
|
89
|
+
],
|
|
90
|
+
},
|
|
91
|
+
'private': {
|
|
92
|
+
'get': [
|
|
93
|
+
'accounts',
|
|
94
|
+
'accounts/balance',
|
|
95
|
+
'accounts/leverage_balance',
|
|
96
|
+
'bank_accounts',
|
|
97
|
+
'deposit_money',
|
|
98
|
+
'exchange/orders/opens',
|
|
99
|
+
'exchange/orders/transactions',
|
|
100
|
+
'exchange/orders/transactions_pagination',
|
|
101
|
+
'exchange/leverage/positions',
|
|
102
|
+
'lending/borrows/matches',
|
|
103
|
+
'send_money',
|
|
104
|
+
'withdraws',
|
|
105
|
+
],
|
|
106
|
+
'post': [
|
|
107
|
+
'bank_accounts',
|
|
108
|
+
'deposit_money/{id}/fast',
|
|
109
|
+
'exchange/orders',
|
|
110
|
+
'exchange/transfers/to_leverage',
|
|
111
|
+
'exchange/transfers/from_leverage',
|
|
112
|
+
'lending/borrows',
|
|
113
|
+
'lending/borrows/{id}/repay',
|
|
114
|
+
'send_money',
|
|
115
|
+
'withdraws',
|
|
116
|
+
],
|
|
117
|
+
'delete': [
|
|
118
|
+
'bank_accounts/{id}',
|
|
119
|
+
'exchange/orders/{id}',
|
|
120
|
+
'withdraws/{id}',
|
|
121
|
+
],
|
|
122
|
+
},
|
|
123
|
+
},
|
|
124
|
+
'markets': {
|
|
125
|
+
'BTC/JPY': this.safeMarketStructure({ 'id': 'btc_jpy', 'symbol': 'BTC/JPY', 'base': 'BTC', 'quote': 'JPY', 'baseId': 'btc', 'quoteId': 'jpy', 'type': 'spot', 'spot': true }),
|
|
126
|
+
// 'ETH/JPY': { 'id': 'eth_jpy', 'symbol': 'ETH/JPY', 'base': 'ETH', 'quote': 'JPY', 'baseId': 'eth', 'quoteId': 'jpy' },
|
|
127
|
+
'ETC/JPY': this.safeMarketStructure({ 'id': 'etc_jpy', 'symbol': 'ETC/JPY', 'base': 'ETC', 'quote': 'JPY', 'baseId': 'etc', 'quoteId': 'jpy', 'type': 'spot', 'spot': true }),
|
|
128
|
+
// 'DAO/JPY': { 'id': 'dao_jpy', 'symbol': 'DAO/JPY', 'base': 'DAO', 'quote': 'JPY', 'baseId': 'dao', 'quoteId': 'jpy' },
|
|
129
|
+
// 'LSK/JPY': { 'id': 'lsk_jpy', 'symbol': 'LSK/JPY', 'base': 'LSK', 'quote': 'JPY', 'baseId': 'lsk', 'quoteId': 'jpy' },
|
|
130
|
+
'FCT/JPY': this.safeMarketStructure({ 'id': 'fct_jpy', 'symbol': 'FCT/JPY', 'base': 'FCT', 'quote': 'JPY', 'baseId': 'fct', 'quoteId': 'jpy', 'type': 'spot', 'spot': true }),
|
|
131
|
+
'MONA/JPY': this.safeMarketStructure({ 'id': 'mona_jpy', 'symbol': 'MONA/JPY', 'base': 'MONA', 'quote': 'JPY', 'baseId': 'mona', 'quoteId': 'jpy', 'type': 'spot', 'spot': true }),
|
|
132
|
+
// 'XMR/JPY': { 'id': 'xmr_jpy', 'symbol': 'XMR/JPY', 'base': 'XMR', 'quote': 'JPY', 'baseId': 'xmr', 'quoteId': 'jpy' },
|
|
133
|
+
// 'REP/JPY': { 'id': 'rep_jpy', 'symbol': 'REP/JPY', 'base': 'REP', 'quote': 'JPY', 'baseId': 'rep', 'quoteId': 'jpy' },
|
|
134
|
+
// 'XRP/JPY': { 'id': 'xrp_jpy', 'symbol': 'XRP/JPY', 'base': 'XRP', 'quote': 'JPY', 'baseId': 'xrp', 'quoteId': 'jpy' },
|
|
135
|
+
// 'ZEC/JPY': { 'id': 'zec_jpy', 'symbol': 'ZEC/JPY', 'base': 'ZEC', 'quote': 'JPY', 'baseId': 'zec', 'quoteId': 'jpy' },
|
|
136
|
+
// 'XEM/JPY': { 'id': 'xem_jpy', 'symbol': 'XEM/JPY', 'base': 'XEM', 'quote': 'JPY', 'baseId': 'xem', 'quoteId': 'jpy' },
|
|
137
|
+
// 'LTC/JPY': { 'id': 'ltc_jpy', 'symbol': 'LTC/JPY', 'base': 'LTC', 'quote': 'JPY', 'baseId': 'ltc', 'quoteId': 'jpy' },
|
|
138
|
+
// 'DASH/JPY': { 'id': 'dash_jpy', 'symbol': 'DASH/JPY', 'base': 'DASH', 'quote': 'JPY', 'baseId': 'dash', 'quoteId': 'jpy' },
|
|
139
|
+
// 'ETH/BTC': { 'id': 'eth_btc', 'symbol': 'ETH/BTC', 'base': 'ETH', 'quote': 'BTC', 'baseId': 'eth', 'quoteId': 'btc' },
|
|
140
|
+
'ETC/BTC': this.safeMarketStructure({ 'id': 'etc_btc', 'symbol': 'ETC/BTC', 'base': 'ETC', 'quote': 'BTC', 'baseId': 'etc', 'quoteId': 'btc', 'type': 'spot', 'spot': true }),
|
|
141
|
+
// 'LSK/BTC': { 'id': 'lsk_btc', 'symbol': 'LSK/BTC', 'base': 'LSK', 'quote': 'BTC', 'baseId': 'lsk', 'quoteId': 'btc' },
|
|
142
|
+
// 'FCT/BTC': { 'id': 'fct_btc', 'symbol': 'FCT/BTC', 'base': 'FCT', 'quote': 'BTC', 'baseId': 'fct', 'quoteId': 'btc' },
|
|
143
|
+
// 'XMR/BTC': { 'id': 'xmr_btc', 'symbol': 'XMR/BTC', 'base': 'XMR', 'quote': 'BTC', 'baseId': 'xmr', 'quoteId': 'btc' },
|
|
144
|
+
// 'REP/BTC': { 'id': 'rep_btc', 'symbol': 'REP/BTC', 'base': 'REP', 'quote': 'BTC', 'baseId': 'rep', 'quoteId': 'btc' },
|
|
145
|
+
// 'XRP/BTC': { 'id': 'xrp_btc', 'symbol': 'XRP/BTC', 'base': 'XRP', 'quote': 'BTC', 'baseId': 'xrp', 'quoteId': 'btc' },
|
|
146
|
+
// 'ZEC/BTC': { 'id': 'zec_btc', 'symbol': 'ZEC/BTC', 'base': 'ZEC', 'quote': 'BTC', 'baseId': 'zec', 'quoteId': 'btc' },
|
|
147
|
+
// 'XEM/BTC': { 'id': 'xem_btc', 'symbol': 'XEM/BTC', 'base': 'XEM', 'quote': 'BTC', 'baseId': 'xem', 'quoteId': 'btc' },
|
|
148
|
+
// 'LTC/BTC': { 'id': 'ltc_btc', 'symbol': 'LTC/BTC', 'base': 'LTC', 'quote': 'BTC', 'baseId': 'ltc', 'quoteId': 'btc' },
|
|
149
|
+
// 'DASH/BTC': { 'id': 'dash_btc', 'symbol': 'DASH/BTC', 'base': 'DASH', 'quote': 'BTC', 'baseId': 'dash', 'quoteId': 'btc' },
|
|
150
|
+
},
|
|
151
|
+
'fees': {
|
|
152
|
+
'trading': {
|
|
153
|
+
'tierBased': false,
|
|
154
|
+
'percentage': true,
|
|
155
|
+
'maker': this.parseNumber('0'),
|
|
156
|
+
'taker': this.parseNumber('0'),
|
|
157
|
+
},
|
|
158
|
+
},
|
|
159
|
+
'precisionMode': number.TICK_SIZE,
|
|
160
|
+
'exceptions': {
|
|
161
|
+
'exact': {
|
|
162
|
+
'disabled API Key': errors.AuthenticationError,
|
|
163
|
+
'invalid authentication': errors.AuthenticationError, // {"success":false,"error":"invalid authentication"}
|
|
164
|
+
},
|
|
165
|
+
'broad': {},
|
|
166
|
+
},
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
parseBalance(response) {
|
|
170
|
+
const result = { 'info': response };
|
|
171
|
+
const codes = Object.keys(this.currencies);
|
|
172
|
+
for (let i = 0; i < codes.length; i++) {
|
|
173
|
+
const code = codes[i];
|
|
174
|
+
const currency = this.currency(code);
|
|
175
|
+
const currencyId = currency['id'];
|
|
176
|
+
if (currencyId in response) {
|
|
177
|
+
const account = this.account();
|
|
178
|
+
const reserved = currencyId + '_reserved';
|
|
179
|
+
account['free'] = this.safeString(response, currencyId);
|
|
180
|
+
account['used'] = this.safeString(response, reserved);
|
|
181
|
+
result[code] = account;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
return this.safeBalance(result);
|
|
185
|
+
}
|
|
186
|
+
async fetchBalance(params = {}) {
|
|
187
|
+
/**
|
|
188
|
+
* @method
|
|
189
|
+
* @name coincheck#fetchBalance
|
|
190
|
+
* @description query for balance and get the amount of funds available for trading or funds locked in orders
|
|
191
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
192
|
+
* @returns {object} a [balance structure]{@link https://docs.ccxt.com/#/?id=balance-structure}
|
|
193
|
+
*/
|
|
194
|
+
await this.loadMarkets();
|
|
195
|
+
const response = await this.privateGetAccountsBalance(params);
|
|
196
|
+
return this.parseBalance(response);
|
|
197
|
+
}
|
|
198
|
+
async fetchOpenOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
|
|
199
|
+
/**
|
|
200
|
+
* @method
|
|
201
|
+
* @name coincheck#fetchOpenOrders
|
|
202
|
+
* @description fetch all unfilled currently open orders
|
|
203
|
+
* @param {string} symbol unified market symbol
|
|
204
|
+
* @param {int} [since] the earliest time in ms to fetch open orders for
|
|
205
|
+
* @param {int} [limit] the maximum number of open orders structures to retrieve
|
|
206
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
207
|
+
* @returns {Order[]} a list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
|
|
208
|
+
*/
|
|
209
|
+
await this.loadMarkets();
|
|
210
|
+
// Only BTC/JPY is meaningful
|
|
211
|
+
let market = undefined;
|
|
212
|
+
if (symbol !== undefined) {
|
|
213
|
+
market = this.market(symbol);
|
|
214
|
+
}
|
|
215
|
+
const response = await this.privateGetExchangeOrdersOpens(params);
|
|
216
|
+
const rawOrders = this.safeValue(response, 'orders', []);
|
|
217
|
+
const parsedOrders = this.parseOrders(rawOrders, market, since, limit);
|
|
218
|
+
const result = [];
|
|
219
|
+
for (let i = 0; i < parsedOrders.length; i++) {
|
|
220
|
+
result.push(this.extend(parsedOrders[i], { 'status': 'open' }));
|
|
221
|
+
}
|
|
222
|
+
return result;
|
|
223
|
+
}
|
|
224
|
+
parseOrder(order, market = undefined) {
|
|
225
|
+
//
|
|
226
|
+
// fetchOpenOrders
|
|
227
|
+
//
|
|
228
|
+
// { id: 202835,
|
|
229
|
+
// "order_type": "buy",
|
|
230
|
+
// "rate": 26890,
|
|
231
|
+
// "pair": "btc_jpy",
|
|
232
|
+
// "pending_amount": "0.5527",
|
|
233
|
+
// "pending_market_buy_amount": null,
|
|
234
|
+
// "stop_loss_rate": null,
|
|
235
|
+
// "created_at": "2015-01-10T05:55:38.000Z" }
|
|
236
|
+
//
|
|
237
|
+
// todo: add formats for fetchOrder, fetchClosedOrders here
|
|
238
|
+
//
|
|
239
|
+
const id = this.safeString(order, 'id');
|
|
240
|
+
const side = this.safeString(order, 'order_type');
|
|
241
|
+
const timestamp = this.parse8601(this.safeString(order, 'created_at'));
|
|
242
|
+
const amount = this.safeString(order, 'pending_amount');
|
|
243
|
+
const remaining = this.safeString(order, 'pending_amount');
|
|
244
|
+
const price = this.safeString(order, 'rate');
|
|
245
|
+
const status = undefined;
|
|
246
|
+
const marketId = this.safeString(order, 'pair');
|
|
247
|
+
const symbol = this.safeSymbol(marketId, market, '_');
|
|
248
|
+
return this.safeOrder({
|
|
249
|
+
'id': id,
|
|
250
|
+
'clientOrderId': undefined,
|
|
251
|
+
'timestamp': timestamp,
|
|
252
|
+
'datetime': this.iso8601(timestamp),
|
|
253
|
+
'lastTradeTimestamp': undefined,
|
|
254
|
+
'amount': amount,
|
|
255
|
+
'remaining': remaining,
|
|
256
|
+
'filled': undefined,
|
|
257
|
+
'side': side,
|
|
258
|
+
'type': undefined,
|
|
259
|
+
'timeInForce': undefined,
|
|
260
|
+
'postOnly': undefined,
|
|
261
|
+
'status': status,
|
|
262
|
+
'symbol': symbol,
|
|
263
|
+
'price': price,
|
|
264
|
+
'stopPrice': undefined,
|
|
265
|
+
'triggerPrice': undefined,
|
|
266
|
+
'cost': undefined,
|
|
267
|
+
'fee': undefined,
|
|
268
|
+
'info': order,
|
|
269
|
+
'average': undefined,
|
|
270
|
+
'trades': undefined,
|
|
271
|
+
}, market);
|
|
272
|
+
}
|
|
273
|
+
async fetchOrderBook(symbol, limit = undefined, params = {}) {
|
|
274
|
+
/**
|
|
275
|
+
* @method
|
|
276
|
+
* @name coincheck#fetchOrderBook
|
|
277
|
+
* @description fetches information on open orders with bid (buy) and ask (sell) prices, volumes and other data
|
|
278
|
+
* @param {string} symbol unified symbol of the market to fetch the order book for
|
|
279
|
+
* @param {int} [limit] the maximum amount of order book entries to return
|
|
280
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
281
|
+
* @returns {object} A dictionary of [order book structures]{@link https://docs.ccxt.com/#/?id=order-book-structure} indexed by market symbols
|
|
282
|
+
*/
|
|
283
|
+
await this.loadMarkets();
|
|
284
|
+
const market = this.market(symbol);
|
|
285
|
+
const request = {
|
|
286
|
+
'pair': market['id'],
|
|
287
|
+
};
|
|
288
|
+
const response = await this.publicGetOrderBooks(this.extend(request, params));
|
|
289
|
+
return this.parseOrderBook(response, market['symbol']);
|
|
290
|
+
}
|
|
291
|
+
parseTicker(ticker, market = undefined) {
|
|
292
|
+
//
|
|
293
|
+
// {
|
|
294
|
+
// "last":4192632.0,
|
|
295
|
+
// "bid":4192496.0,
|
|
296
|
+
// "ask":4193749.0,
|
|
297
|
+
// "high":4332000.0,
|
|
298
|
+
// "low":4101047.0,
|
|
299
|
+
// "volume":2313.43191762,
|
|
300
|
+
// "timestamp":1643374115
|
|
301
|
+
// }
|
|
302
|
+
//
|
|
303
|
+
const symbol = this.safeSymbol(undefined, market);
|
|
304
|
+
const timestamp = this.safeTimestamp(ticker, 'timestamp');
|
|
305
|
+
const last = this.safeString(ticker, 'last');
|
|
306
|
+
return this.safeTicker({
|
|
307
|
+
'symbol': symbol,
|
|
308
|
+
'timestamp': timestamp,
|
|
309
|
+
'datetime': this.iso8601(timestamp),
|
|
310
|
+
'high': this.safeString(ticker, 'high'),
|
|
311
|
+
'low': this.safeString(ticker, 'low'),
|
|
312
|
+
'bid': this.safeString(ticker, 'bid'),
|
|
313
|
+
'bidVolume': undefined,
|
|
314
|
+
'ask': this.safeString(ticker, 'ask'),
|
|
315
|
+
'askVolume': undefined,
|
|
316
|
+
'vwap': undefined,
|
|
317
|
+
'open': undefined,
|
|
318
|
+
'close': last,
|
|
319
|
+
'last': last,
|
|
320
|
+
'previousClose': undefined,
|
|
321
|
+
'change': undefined,
|
|
322
|
+
'percentage': undefined,
|
|
323
|
+
'average': undefined,
|
|
324
|
+
'baseVolume': this.safeString(ticker, 'volume'),
|
|
325
|
+
'quoteVolume': undefined,
|
|
326
|
+
'info': ticker,
|
|
327
|
+
}, market);
|
|
328
|
+
}
|
|
329
|
+
async fetchTicker(symbol, params = {}) {
|
|
330
|
+
/**
|
|
331
|
+
* @method
|
|
332
|
+
* @name coincheck#fetchTicker
|
|
333
|
+
* @description fetches a price ticker, a statistical calculation with the information calculated over the past 24 hours for a specific market
|
|
334
|
+
* @param {string} symbol unified symbol of the market to fetch the ticker for
|
|
335
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
336
|
+
* @returns {object} a [ticker structure]{@link https://docs.ccxt.com/#/?id=ticker-structure}
|
|
337
|
+
*/
|
|
338
|
+
if (symbol !== 'BTC/JPY') {
|
|
339
|
+
throw new errors.BadSymbol(this.id + ' fetchTicker() supports BTC/JPY only');
|
|
340
|
+
}
|
|
341
|
+
await this.loadMarkets();
|
|
342
|
+
const market = this.market(symbol);
|
|
343
|
+
const request = {
|
|
344
|
+
'pair': market['id'],
|
|
345
|
+
};
|
|
346
|
+
const ticker = await this.publicGetTicker(this.extend(request, params));
|
|
347
|
+
//
|
|
348
|
+
// {
|
|
349
|
+
// "last":4192632.0,
|
|
350
|
+
// "bid":4192496.0,
|
|
351
|
+
// "ask":4193749.0,
|
|
352
|
+
// "high":4332000.0,
|
|
353
|
+
// "low":4101047.0,
|
|
354
|
+
// "volume":2313.43191762,
|
|
355
|
+
// "timestamp":1643374115
|
|
356
|
+
// }
|
|
357
|
+
//
|
|
358
|
+
return this.parseTicker(ticker, market);
|
|
359
|
+
}
|
|
360
|
+
parseTrade(trade, market = undefined) {
|
|
361
|
+
//
|
|
362
|
+
// fetchTrades (public)
|
|
363
|
+
//
|
|
364
|
+
// {
|
|
365
|
+
// "id": "206849494",
|
|
366
|
+
// "amount": "0.01",
|
|
367
|
+
// "rate": "5598346.0",
|
|
368
|
+
// "pair": "btc_jpy",
|
|
369
|
+
// "order_type": "sell",
|
|
370
|
+
// "created_at": "2021-12-08T14:10:33.000Z"
|
|
371
|
+
// }
|
|
372
|
+
//
|
|
373
|
+
// fetchMyTrades (private) - example from docs
|
|
374
|
+
//
|
|
375
|
+
// {
|
|
376
|
+
// "id": 38,
|
|
377
|
+
// "order_id": 49,
|
|
378
|
+
// "created_at": "2015-11-18T07:02:21.000Z",
|
|
379
|
+
// "funds": {
|
|
380
|
+
// "btc": "0.1",
|
|
381
|
+
// "jpy": "-4096.135"
|
|
382
|
+
// },
|
|
383
|
+
// "pair": "btc_jpy",
|
|
384
|
+
// "rate": "40900.0",
|
|
385
|
+
// "fee_currency": "JPY",
|
|
386
|
+
// "fee": "6.135",
|
|
387
|
+
// "liquidity": "T",
|
|
388
|
+
// "side": "buy"
|
|
389
|
+
// }
|
|
390
|
+
//
|
|
391
|
+
const timestamp = this.parse8601(this.safeString(trade, 'created_at'));
|
|
392
|
+
const id = this.safeString(trade, 'id');
|
|
393
|
+
const priceString = this.safeString(trade, 'rate');
|
|
394
|
+
const marketId = this.safeString(trade, 'pair');
|
|
395
|
+
market = this.safeMarket(marketId, market, '_');
|
|
396
|
+
const baseId = market['baseId'];
|
|
397
|
+
const quoteId = market['quoteId'];
|
|
398
|
+
const symbol = market['symbol'];
|
|
399
|
+
let takerOrMaker = undefined;
|
|
400
|
+
let amountString = undefined;
|
|
401
|
+
let costString = undefined;
|
|
402
|
+
let side = undefined;
|
|
403
|
+
let fee = undefined;
|
|
404
|
+
let orderId = undefined;
|
|
405
|
+
if ('liquidity' in trade) {
|
|
406
|
+
if (this.safeString(trade, 'liquidity') === 'T') {
|
|
407
|
+
takerOrMaker = 'taker';
|
|
408
|
+
}
|
|
409
|
+
else if (this.safeString(trade, 'liquidity') === 'M') {
|
|
410
|
+
takerOrMaker = 'maker';
|
|
411
|
+
}
|
|
412
|
+
const funds = this.safeValue(trade, 'funds', {});
|
|
413
|
+
amountString = this.safeString(funds, baseId);
|
|
414
|
+
costString = this.safeString(funds, quoteId);
|
|
415
|
+
fee = {
|
|
416
|
+
'currency': this.safeString(trade, 'fee_currency'),
|
|
417
|
+
'cost': this.safeString(trade, 'fee'),
|
|
418
|
+
};
|
|
419
|
+
side = this.safeString(trade, 'side');
|
|
420
|
+
orderId = this.safeString(trade, 'order_id');
|
|
421
|
+
}
|
|
422
|
+
else {
|
|
423
|
+
amountString = this.safeString(trade, 'amount');
|
|
424
|
+
side = this.safeString(trade, 'order_type');
|
|
425
|
+
}
|
|
426
|
+
return this.safeTrade({
|
|
427
|
+
'id': id,
|
|
428
|
+
'info': trade,
|
|
429
|
+
'datetime': this.iso8601(timestamp),
|
|
430
|
+
'timestamp': timestamp,
|
|
431
|
+
'symbol': symbol,
|
|
432
|
+
'type': undefined,
|
|
433
|
+
'side': side,
|
|
434
|
+
'order': orderId,
|
|
435
|
+
'takerOrMaker': takerOrMaker,
|
|
436
|
+
'price': priceString,
|
|
437
|
+
'amount': amountString,
|
|
438
|
+
'cost': costString,
|
|
439
|
+
'fee': fee,
|
|
440
|
+
}, market);
|
|
441
|
+
}
|
|
442
|
+
async fetchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
|
|
443
|
+
/**
|
|
444
|
+
* @method
|
|
445
|
+
* @name coincheck#fetchMyTrades
|
|
446
|
+
* @description fetch all trades made by the user
|
|
447
|
+
* @param {string} symbol unified market symbol
|
|
448
|
+
* @param {int} [since] the earliest time in ms to fetch trades for
|
|
449
|
+
* @param {int} [limit] the maximum number of trades structures to retrieve
|
|
450
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
451
|
+
* @returns {Trade[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=trade-structure}
|
|
452
|
+
*/
|
|
453
|
+
await this.loadMarkets();
|
|
454
|
+
const market = this.market(symbol);
|
|
455
|
+
const request = {};
|
|
456
|
+
if (limit !== undefined) {
|
|
457
|
+
request['limit'] = limit;
|
|
458
|
+
}
|
|
459
|
+
const response = await this.privateGetExchangeOrdersTransactionsPagination(this.extend(request, params));
|
|
460
|
+
//
|
|
461
|
+
// {
|
|
462
|
+
// "success": true,
|
|
463
|
+
// "data": [
|
|
464
|
+
// {
|
|
465
|
+
// "id": 38,
|
|
466
|
+
// "order_id": 49,
|
|
467
|
+
// "created_at": "2015-11-18T07:02:21.000Z",
|
|
468
|
+
// "funds": {
|
|
469
|
+
// "btc": "0.1",
|
|
470
|
+
// "jpy": "-4096.135"
|
|
471
|
+
// },
|
|
472
|
+
// "pair": "btc_jpy",
|
|
473
|
+
// "rate": "40900.0",
|
|
474
|
+
// "fee_currency": "JPY",
|
|
475
|
+
// "fee": "6.135",
|
|
476
|
+
// "liquidity": "T",
|
|
477
|
+
// "side": "buy"
|
|
478
|
+
// },
|
|
479
|
+
// ]
|
|
480
|
+
// }
|
|
481
|
+
//
|
|
482
|
+
const transactions = this.safeValue(response, 'data', []);
|
|
483
|
+
return this.parseTrades(transactions, market, since, limit);
|
|
484
|
+
}
|
|
485
|
+
async fetchTrades(symbol, since = undefined, limit = undefined, params = {}) {
|
|
486
|
+
/**
|
|
487
|
+
* @method
|
|
488
|
+
* @name coincheck#fetchTrades
|
|
489
|
+
* @description get the list of most recent trades for a particular symbol
|
|
490
|
+
* @param {string} symbol unified symbol of the market to fetch trades for
|
|
491
|
+
* @param {int} [since] timestamp in ms of the earliest trade to fetch
|
|
492
|
+
* @param {int} [limit] the maximum amount of trades to fetch
|
|
493
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
494
|
+
* @returns {Trade[]} a list of [trade structures]{@link https://docs.ccxt.com/#/?id=public-trades}
|
|
495
|
+
*/
|
|
496
|
+
await this.loadMarkets();
|
|
497
|
+
const market = this.market(symbol);
|
|
498
|
+
const request = {
|
|
499
|
+
'pair': market['id'],
|
|
500
|
+
};
|
|
501
|
+
if (limit !== undefined) {
|
|
502
|
+
request['limit'] = limit;
|
|
503
|
+
}
|
|
504
|
+
const response = await this.publicGetTrades(this.extend(request, params));
|
|
505
|
+
//
|
|
506
|
+
// {
|
|
507
|
+
// "id": "206849494",
|
|
508
|
+
// "amount": "0.01",
|
|
509
|
+
// "rate": "5598346.0",
|
|
510
|
+
// "pair": "btc_jpy",
|
|
511
|
+
// "order_type": "sell",
|
|
512
|
+
// "created_at": "2021-12-08T14:10:33.000Z"
|
|
513
|
+
// }
|
|
514
|
+
//
|
|
515
|
+
const data = this.safeValue(response, 'data', []);
|
|
516
|
+
return this.parseTrades(data, market, since, limit);
|
|
517
|
+
}
|
|
518
|
+
async fetchTradingFees(params = {}) {
|
|
519
|
+
/**
|
|
520
|
+
* @method
|
|
521
|
+
* @name coincheck#fetchTradingFees
|
|
522
|
+
* @description fetch the trading fees for multiple markets
|
|
523
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
524
|
+
* @returns {object} a dictionary of [fee structures]{@link https://docs.ccxt.com/#/?id=fee-structure} indexed by market symbols
|
|
525
|
+
*/
|
|
526
|
+
await this.loadMarkets();
|
|
527
|
+
const response = await this.privateGetAccounts(params);
|
|
528
|
+
//
|
|
529
|
+
// {
|
|
530
|
+
// "success": true,
|
|
531
|
+
// "id": "7487995",
|
|
532
|
+
// "email": "some@email.com",
|
|
533
|
+
// "identity_status": "identity_pending",
|
|
534
|
+
// "bitcoin_address": null,
|
|
535
|
+
// "lending_leverage": "4",
|
|
536
|
+
// "taker_fee": "0.0",
|
|
537
|
+
// "maker_fee": "0.0",
|
|
538
|
+
// "exchange_fees": {
|
|
539
|
+
// "btc_jpy": { taker_fee: '0.0', maker_fee: "0.0" },
|
|
540
|
+
// "etc_jpy": { taker_fee: '0.0', maker_fee: "0.0" },
|
|
541
|
+
// "fct_jpy": { taker_fee: '0.0', maker_fee: "0.0" },
|
|
542
|
+
// "mona_jpy": { taker_fee: '0.0', maker_fee: "0.0" },
|
|
543
|
+
// "plt_jpy": { taker_fee: '0.0', maker_fee: "0.0" }
|
|
544
|
+
// }
|
|
545
|
+
// }
|
|
546
|
+
//
|
|
547
|
+
const fees = this.safeValue(response, 'exchange_fees', {});
|
|
548
|
+
const result = {};
|
|
549
|
+
for (let i = 0; i < this.symbols.length; i++) {
|
|
550
|
+
const symbol = this.symbols[i];
|
|
551
|
+
const market = this.market(symbol);
|
|
552
|
+
const fee = this.safeValue(fees, market['id'], {});
|
|
553
|
+
result[symbol] = {
|
|
554
|
+
'info': fee,
|
|
555
|
+
'symbol': symbol,
|
|
556
|
+
'maker': this.safeNumber(fee, 'maker_fee'),
|
|
557
|
+
'taker': this.safeNumber(fee, 'taker_fee'),
|
|
558
|
+
'percentage': true,
|
|
559
|
+
'tierBased': false,
|
|
560
|
+
};
|
|
561
|
+
}
|
|
562
|
+
return result;
|
|
563
|
+
}
|
|
564
|
+
async createOrder(symbol, type, side, amount, price = undefined, params = {}) {
|
|
565
|
+
/**
|
|
566
|
+
* @method
|
|
567
|
+
* @name coincheck#createOrder
|
|
568
|
+
* @description create a trade order
|
|
569
|
+
* @param {string} symbol unified symbol of the market to create an order in
|
|
570
|
+
* @param {string} type 'market' or 'limit'
|
|
571
|
+
* @param {string} side 'buy' or 'sell'
|
|
572
|
+
* @param {float} amount how much of currency you want to trade in units of base currency
|
|
573
|
+
* @param {float} [price] the price at which the order is to be fullfilled, in units of the quote currency, ignored in market orders
|
|
574
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
575
|
+
* @returns {object} an [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
|
|
576
|
+
*/
|
|
577
|
+
await this.loadMarkets();
|
|
578
|
+
const market = this.market(symbol);
|
|
579
|
+
const request = {
|
|
580
|
+
'pair': market['id'],
|
|
581
|
+
};
|
|
582
|
+
if (type === 'market') {
|
|
583
|
+
const order_type = type + '_' + side;
|
|
584
|
+
request['order_type'] = order_type;
|
|
585
|
+
const prefix = (side === 'buy') ? (order_type + '_') : '';
|
|
586
|
+
request[prefix + 'amount'] = amount;
|
|
587
|
+
}
|
|
588
|
+
else {
|
|
589
|
+
request['order_type'] = side;
|
|
590
|
+
request['rate'] = price;
|
|
591
|
+
request['amount'] = amount;
|
|
592
|
+
}
|
|
593
|
+
const response = await this.privatePostExchangeOrders(this.extend(request, params));
|
|
594
|
+
const id = this.safeString(response, 'id');
|
|
595
|
+
return this.safeOrder({
|
|
596
|
+
'id': id,
|
|
597
|
+
'info': response,
|
|
598
|
+
}, market);
|
|
599
|
+
}
|
|
600
|
+
async cancelOrder(id, symbol = undefined, params = {}) {
|
|
601
|
+
/**
|
|
602
|
+
* @method
|
|
603
|
+
* @name coincheck#cancelOrder
|
|
604
|
+
* @description cancels an open order
|
|
605
|
+
* @param {string} id order id
|
|
606
|
+
* @param {string} symbol not used by coincheck cancelOrder ()
|
|
607
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
608
|
+
* @returns {object} An [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
|
|
609
|
+
*/
|
|
610
|
+
const request = {
|
|
611
|
+
'id': id,
|
|
612
|
+
};
|
|
613
|
+
return await this.privateDeleteExchangeOrdersId(this.extend(request, params));
|
|
614
|
+
}
|
|
615
|
+
async fetchDeposits(code = undefined, since = undefined, limit = undefined, params = {}) {
|
|
616
|
+
/**
|
|
617
|
+
* @method
|
|
618
|
+
* @name coincheck#fetchDeposits
|
|
619
|
+
* @description fetch all deposits made to an account
|
|
620
|
+
* @param {string} code unified currency code
|
|
621
|
+
* @param {int} [since] the earliest time in ms to fetch deposits for
|
|
622
|
+
* @param {int} [limit] the maximum number of deposits structures to retrieve
|
|
623
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
624
|
+
* @returns {object[]} a list of [transaction structures]{@link https://docs.ccxt.com/#/?id=transaction-structure}
|
|
625
|
+
*/
|
|
626
|
+
await this.loadMarkets();
|
|
627
|
+
let currency = undefined;
|
|
628
|
+
const request = {};
|
|
629
|
+
if (code !== undefined) {
|
|
630
|
+
currency = this.currency(code);
|
|
631
|
+
request['currency'] = currency['id'];
|
|
632
|
+
}
|
|
633
|
+
if (limit !== undefined) {
|
|
634
|
+
request['limit'] = limit;
|
|
635
|
+
}
|
|
636
|
+
const response = await this.privateGetDepositMoney(this.extend(request, params));
|
|
637
|
+
// {
|
|
638
|
+
// "success": true,
|
|
639
|
+
// "deposits": [
|
|
640
|
+
// {
|
|
641
|
+
// "id": 2,
|
|
642
|
+
// "amount": "0.05",
|
|
643
|
+
// "currency": "BTC",
|
|
644
|
+
// "address": "13PhzoK8me3u5nHzzFD85qT9RqEWR9M4Ty",
|
|
645
|
+
// "status": "confirmed",
|
|
646
|
+
// "confirmed_at": "2015-06-13T08:29:18.000Z",
|
|
647
|
+
// "created_at": "2015-06-13T08:22:18.000Z"
|
|
648
|
+
// },
|
|
649
|
+
// {
|
|
650
|
+
// "id": 1,
|
|
651
|
+
// "amount": "0.01",
|
|
652
|
+
// "currency": "BTC",
|
|
653
|
+
// "address": "13PhzoK8me3u5nHzzFD85qT9RqEWR9M4Ty",
|
|
654
|
+
// "status": "received",
|
|
655
|
+
// "confirmed_at": "2015-06-13T08:21:18.000Z",
|
|
656
|
+
// "created_at": "2015-06-13T08:21:18.000Z"
|
|
657
|
+
// }
|
|
658
|
+
// ]
|
|
659
|
+
// }
|
|
660
|
+
const data = this.safeValue(response, 'deposits', []);
|
|
661
|
+
return this.parseTransactions(data, currency, since, limit, { 'type': 'deposit' });
|
|
662
|
+
}
|
|
663
|
+
async fetchWithdrawals(code = undefined, since = undefined, limit = undefined, params = {}) {
|
|
664
|
+
/**
|
|
665
|
+
* @method
|
|
666
|
+
* @name coincheck#fetchWithdrawals
|
|
667
|
+
* @description fetch all withdrawals made from an account
|
|
668
|
+
* @param {string} code unified currency code
|
|
669
|
+
* @param {int} [since] the earliest time in ms to fetch withdrawals for
|
|
670
|
+
* @param {int} [limit] the maximum number of withdrawals structures to retrieve
|
|
671
|
+
* @param {object} [params] extra parameters specific to the exchange API endpoint
|
|
672
|
+
* @returns {object[]} a list of [transaction structures]{@link https://docs.ccxt.com/#/?id=transaction-structure}
|
|
673
|
+
*/
|
|
674
|
+
await this.loadMarkets();
|
|
675
|
+
let currency = undefined;
|
|
676
|
+
if (code !== undefined) {
|
|
677
|
+
currency = this.currency(code);
|
|
678
|
+
}
|
|
679
|
+
const request = {};
|
|
680
|
+
if (limit !== undefined) {
|
|
681
|
+
request['limit'] = limit;
|
|
682
|
+
}
|
|
683
|
+
const response = await this.privateGetWithdraws(this.extend(request, params));
|
|
684
|
+
// {
|
|
685
|
+
// "success": true,
|
|
686
|
+
// "pagination": {
|
|
687
|
+
// "limit": 25,
|
|
688
|
+
// "order": "desc",
|
|
689
|
+
// "starting_after": null,
|
|
690
|
+
// "ending_before": null
|
|
691
|
+
// },
|
|
692
|
+
// "data": [
|
|
693
|
+
// {
|
|
694
|
+
// "id": 398,
|
|
695
|
+
// "status": "finished",
|
|
696
|
+
// "amount": "242742.0",
|
|
697
|
+
// "currency": "JPY",
|
|
698
|
+
// "created_at": "2014-12-04T15:00:00.000Z",
|
|
699
|
+
// "bank_account_id": 243,
|
|
700
|
+
// "fee": "400.0",
|
|
701
|
+
// "is_fast": true
|
|
702
|
+
// }
|
|
703
|
+
// ]
|
|
704
|
+
// }
|
|
705
|
+
const data = this.safeValue(response, 'data', []);
|
|
706
|
+
return this.parseTransactions(data, currency, since, limit, { 'type': 'withdrawal' });
|
|
707
|
+
}
|
|
708
|
+
parseTransactionStatus(status) {
|
|
709
|
+
const statuses = {
|
|
710
|
+
// withdrawals
|
|
711
|
+
'pending': 'pending',
|
|
712
|
+
'processing': 'pending',
|
|
713
|
+
'finished': 'ok',
|
|
714
|
+
'canceled': 'canceled',
|
|
715
|
+
// deposits
|
|
716
|
+
'confirmed': 'pending',
|
|
717
|
+
'received': 'ok',
|
|
718
|
+
};
|
|
719
|
+
return this.safeString(statuses, status, status);
|
|
720
|
+
}
|
|
721
|
+
parseTransaction(transaction, currency = undefined) {
|
|
722
|
+
//
|
|
723
|
+
// fetchDeposits
|
|
724
|
+
//
|
|
725
|
+
// {
|
|
726
|
+
// "id": 2,
|
|
727
|
+
// "amount": "0.05",
|
|
728
|
+
// "currency": "BTC",
|
|
729
|
+
// "address": "13PhzoK8me3u5nHzzFD85qT9RqEWR9M4Ty",
|
|
730
|
+
// "status": "confirmed",
|
|
731
|
+
// "confirmed_at": "2015-06-13T08:29:18.000Z",
|
|
732
|
+
// "created_at": "2015-06-13T08:22:18.000Z"
|
|
733
|
+
// }
|
|
734
|
+
//
|
|
735
|
+
// fetchWithdrawals
|
|
736
|
+
//
|
|
737
|
+
// {
|
|
738
|
+
// "id": 398,
|
|
739
|
+
// "status": "finished",
|
|
740
|
+
// "amount": "242742.0",
|
|
741
|
+
// "currency": "JPY",
|
|
742
|
+
// "created_at": "2014-12-04T15:00:00.000Z",
|
|
743
|
+
// "bank_account_id": 243,
|
|
744
|
+
// "fee": "400.0",
|
|
745
|
+
// "is_fast": true
|
|
746
|
+
// }
|
|
747
|
+
//
|
|
748
|
+
const id = this.safeString(transaction, 'id');
|
|
749
|
+
const timestamp = this.parse8601(this.safeString(transaction, 'created_at'));
|
|
750
|
+
const address = this.safeString(transaction, 'address');
|
|
751
|
+
const amount = this.safeNumber(transaction, 'amount');
|
|
752
|
+
const currencyId = this.safeString(transaction, 'currency');
|
|
753
|
+
const code = this.safeCurrencyCode(currencyId, currency);
|
|
754
|
+
const status = this.parseTransactionStatus(this.safeString(transaction, 'status'));
|
|
755
|
+
const updated = this.parse8601(this.safeString(transaction, 'confirmed_at'));
|
|
756
|
+
let fee = undefined;
|
|
757
|
+
const feeCost = this.safeNumber(transaction, 'fee');
|
|
758
|
+
if (feeCost !== undefined) {
|
|
759
|
+
fee = {
|
|
760
|
+
'cost': feeCost,
|
|
761
|
+
'currency': code,
|
|
762
|
+
};
|
|
763
|
+
}
|
|
764
|
+
return {
|
|
765
|
+
'info': transaction,
|
|
766
|
+
'id': id,
|
|
767
|
+
'txid': undefined,
|
|
768
|
+
'timestamp': timestamp,
|
|
769
|
+
'datetime': this.iso8601(timestamp),
|
|
770
|
+
'network': undefined,
|
|
771
|
+
'address': address,
|
|
772
|
+
'addressTo': address,
|
|
773
|
+
'addressFrom': undefined,
|
|
774
|
+
'tag': undefined,
|
|
775
|
+
'tagTo': undefined,
|
|
776
|
+
'tagFrom': undefined,
|
|
777
|
+
'type': undefined,
|
|
778
|
+
'amount': amount,
|
|
779
|
+
'currency': code,
|
|
780
|
+
'status': status,
|
|
781
|
+
'updated': updated,
|
|
782
|
+
'comment': undefined,
|
|
783
|
+
'internal': undefined,
|
|
784
|
+
'fee': fee,
|
|
785
|
+
};
|
|
786
|
+
}
|
|
787
|
+
nonce() {
|
|
788
|
+
return this.milliseconds();
|
|
789
|
+
}
|
|
790
|
+
sign(path, api = 'public', method = 'GET', params = {}, headers = undefined, body = undefined) {
|
|
791
|
+
let url = this.urls['api']['rest'] + '/' + this.implodeParams(path, params);
|
|
792
|
+
const query = this.omit(params, this.extractParams(path));
|
|
793
|
+
if (api === 'public') {
|
|
794
|
+
if (Object.keys(query).length) {
|
|
795
|
+
url += '?' + this.urlencode(query);
|
|
796
|
+
}
|
|
797
|
+
}
|
|
798
|
+
else {
|
|
799
|
+
this.checkRequiredCredentials();
|
|
800
|
+
const nonce = this.nonce().toString();
|
|
801
|
+
let queryString = '';
|
|
802
|
+
if (method === 'GET') {
|
|
803
|
+
if (Object.keys(query).length) {
|
|
804
|
+
url += '?' + this.urlencode(this.keysort(query));
|
|
805
|
+
}
|
|
806
|
+
}
|
|
807
|
+
else {
|
|
808
|
+
if (Object.keys(query).length) {
|
|
809
|
+
body = this.urlencode(this.keysort(query));
|
|
810
|
+
queryString = body;
|
|
811
|
+
}
|
|
812
|
+
}
|
|
813
|
+
const auth = nonce + url + queryString;
|
|
814
|
+
headers = {
|
|
815
|
+
'Content-Type': 'application/x-www-form-urlencoded',
|
|
816
|
+
'ACCESS-KEY': this.apiKey,
|
|
817
|
+
'ACCESS-NONCE': nonce,
|
|
818
|
+
'ACCESS-SIGNATURE': this.hmac(this.encode(auth), this.encode(this.secret), sha256.sha256),
|
|
819
|
+
};
|
|
820
|
+
}
|
|
821
|
+
return { 'url': url, 'method': method, 'body': body, 'headers': headers };
|
|
822
|
+
}
|
|
823
|
+
handleErrors(httpCode, reason, url, method, headers, body, response, requestHeaders, requestBody) {
|
|
824
|
+
if (response === undefined) {
|
|
825
|
+
return undefined;
|
|
826
|
+
}
|
|
827
|
+
//
|
|
828
|
+
// {"success":false,"error":"disabled API Key"}'
|
|
829
|
+
// {"success":false,"error":"invalid authentication"}
|
|
830
|
+
//
|
|
831
|
+
const success = this.safeValue(response, 'success', true);
|
|
832
|
+
if (!success) {
|
|
833
|
+
const error = this.safeString(response, 'error');
|
|
834
|
+
const feedback = this.id + ' ' + this.json(response);
|
|
835
|
+
this.throwExactlyMatchedException(this.exceptions['exact'], error, feedback);
|
|
836
|
+
this.throwBroadlyMatchedException(this.exceptions['broad'], body, feedback);
|
|
837
|
+
throw new errors.ExchangeError(this.id + ' ' + this.json(response));
|
|
838
|
+
}
|
|
839
|
+
return undefined;
|
|
840
|
+
}
|
|
841
|
+
}
|
|
842
|
+
|
|
843
|
+
module.exports = coincheck;
|