ccxt 4.2.73 → 4.2.74

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 (267) hide show
  1. package/README.md +5 -5
  2. package/build.sh +1 -1
  3. package/dist/ccxt.browser.js +181 -100
  4. package/dist/ccxt.browser.min.js +2 -2
  5. package/dist/cjs/ccxt.js +1 -1
  6. package/dist/cjs/src/base/Exchange.js +1 -1
  7. package/dist/cjs/src/bitget.js +62 -50
  8. package/dist/cjs/src/bybit.js +90 -30
  9. package/dist/cjs/src/coinbaseinternational.js +1 -1
  10. package/dist/cjs/src/htx.js +16 -9
  11. package/dist/cjs/src/hyperliquid.js +2 -1
  12. package/dist/cjs/src/pro/krakenfutures.js +8 -7
  13. package/examples/README.md +308 -0
  14. package/examples/ccxt.pro/html/watchTicker.html +51 -0
  15. package/examples/ccxt.pro/js/binance-fetch-balance-snapshot-watch-balance-updates.js +55 -0
  16. package/examples/ccxt.pro/js/binance-https-proxy.js +48 -0
  17. package/examples/ccxt.pro/js/binance-watch-ohlcv-many-symbols-continuously.js +38 -0
  18. package/examples/ccxt.pro/js/binance-watch-ohlcv-many-symbols.js +64 -0
  19. package/examples/ccxt.pro/js/binance-watch-ticker-many-symbols.js +62 -0
  20. package/examples/ccxt.pro/js/build-ohlcv-many-symbols.js +68 -0
  21. package/examples/ccxt.pro/js/calculate-ohlcvs-from-trades-warmup.js +82 -0
  22. package/examples/ccxt.pro/js/calculate-ohlcvs-from-trades.js +59 -0
  23. package/examples/ccxt.pro/js/exchange-capabitities.js +72 -0
  24. package/examples/ccxt.pro/js/exchange-close.js +46 -0
  25. package/examples/ccxt.pro/js/gateio-swap-watch-many-orderbooks.js +30 -0
  26. package/examples/ccxt.pro/js/gateio-watch-balance.js +23 -0
  27. package/examples/ccxt.pro/js/gateio-watch-order-book.js +71 -0
  28. package/examples/ccxt.pro/js/graceful-shutdown.js +43 -0
  29. package/examples/ccxt.pro/js/many-exchanges-many-streams.js +37 -0
  30. package/examples/ccxt.pro/js/okex-create-futures-order.js +48 -0
  31. package/examples/ccxt.pro/js/okex-watch-balance-and-create-order.js +54 -0
  32. package/examples/ccxt.pro/js/okx-watch-tickers.js +31 -0
  33. package/examples/ccxt.pro/js/one-exchange-many-different-streams.js +46 -0
  34. package/examples/ccxt.pro/js/one-exchange-many-streams-2.js +26 -0
  35. package/examples/ccxt.pro/js/one-exchange-many-streams.js +28 -0
  36. package/examples/ccxt.pro/js/socks-binance-watch-orderbook.js +30 -0
  37. package/examples/ccxt.pro/js/watch-fetch-many-exchanges-many-ordersbooks.js +40 -0
  38. package/examples/ccxt.pro/js/watch-many-exchanges-many-ordersbooks.js +38 -0
  39. package/examples/ccxt.pro/js/watch-many-exchanges-many-symbols.js +40 -0
  40. package/examples/ccxt.pro/js/watch-many-orderbooks.js +27 -0
  41. package/examples/ccxt.pro/js/watch-new-trades-only.js +43 -0
  42. package/examples/ccxt.pro/js/watch-new-trades.js +42 -0
  43. package/examples/ccxt.pro/js/watch-trades-many-symbols.js +29 -0
  44. package/examples/ccxt.pro/js/watch-vs-fetch.js +29 -0
  45. package/examples/cs/Examples.sln +22 -0
  46. package/examples/cs/c#.csproj +19 -0
  47. package/examples/html/basic-cors-proxy.html +46 -0
  48. package/examples/html/basic-inheritance.html +47 -0
  49. package/examples/html/basic-poller.html +52 -0
  50. package/examples/html/basic-rate-limiting.html +49 -0
  51. package/examples/html/basic.html +43 -0
  52. package/examples/html/binance-cors-proxy.html +28 -0
  53. package/examples/html/bitmex-browser-cors-proxy.js +7 -0
  54. package/examples/html/bitmex-cors.html +46 -0
  55. package/examples/html/tradingview-charts.html +61 -0
  56. package/examples/html/webworker/index.html +97 -0
  57. package/examples/html/webworker/worker.js +43 -0
  58. package/examples/js/README.md +15 -0
  59. package/examples/js/advanced-error-handling.js +39 -0
  60. package/examples/js/aggregate-orderbook.js +54 -0
  61. package/examples/js/arbitrage-pairs.js +130 -0
  62. package/examples/js/basic-chart.js +29 -0
  63. package/examples/js/basic-orderbook-polling.js +13 -0
  64. package/examples/js/bcc-vs-bch.js +115 -0
  65. package/examples/js/binance-fetch-all-deposits.js +45 -0
  66. package/examples/js/binance-fetch-ohlcv-many-symbols-async-await.js +34 -0
  67. package/examples/js/binance-fetch-ohlcv-many-symbols-promise-then-callbacks.js +33 -0
  68. package/examples/js/binance-fetchTicker-delivery-vs-future.js +31 -0
  69. package/examples/js/binance-futures-transfer-from-sub-account-to-master.js +41 -0
  70. package/examples/js/binance-margin-stop-order.js +39 -0
  71. package/examples/js/binance-server-time.js +34 -0
  72. package/examples/js/binance-universal-transfer.js +16 -0
  73. package/examples/js/bitfinex-fetch-trades.js +35 -0
  74. package/examples/js/bitfinex2-fetch-trades.js +35 -0
  75. package/examples/js/bitmex-browser-cors-proxy.js +7 -0
  76. package/examples/js/bitpanda-fetchMyTrades-reduce.js +36 -0
  77. package/examples/js/bitrue-fetch-balance.js +28 -0
  78. package/examples/js/bitstamp-private-api.js +115 -0
  79. package/examples/js/bitstamp-public-api.js +39 -0
  80. package/examples/js/bittrex-balance.js +50 -0
  81. package/examples/js/bittrex-fetch-closed-orders-history.js +69 -0
  82. package/examples/js/blockchaincom-withdrawal.js +59 -0
  83. package/examples/js/build-ohlcv-bars.js +48 -0
  84. package/examples/js/builtin-rate-limiting-rest-poller.js +25 -0
  85. package/examples/js/bybit-trailing.js +62 -0
  86. package/examples/js/bybit-updated.cjs +154 -0
  87. package/examples/js/cli.js +405 -0
  88. package/examples/js/coinbase-fetch-all-balances.js +36 -0
  89. package/examples/js/coinex-fetch-all-deposit-addresses-using-fetchDepositAddress.js +47 -0
  90. package/examples/js/coinex-futures.js +75 -0
  91. package/examples/js/coinone-fetch-tickers.js +54 -0
  92. package/examples/js/coinone-markets.js +16 -0
  93. package/examples/js/compare-two-exchanges-capabilities.js +36 -0
  94. package/examples/js/cors-proxy.js +5 -0
  95. package/examples/js/create-order-handle-errors.js +55 -0
  96. package/examples/js/create-order-position-with-takeprofit-stoploss.js +71 -0
  97. package/examples/js/create-order-with-retry.js +65 -0
  98. package/examples/js/create-order-ws-example.js +25 -0
  99. package/examples/js/create-orders-example.js +17 -0
  100. package/examples/js/create-trailing-amount-order.js +36 -0
  101. package/examples/js/create-trailing-percent-order.js +36 -0
  102. package/examples/js/credentials.json +5 -0
  103. package/examples/js/custom-proxy-agent-for-js.js +10 -0
  104. package/examples/js/custom-proxy-url.js +23 -0
  105. package/examples/js/delta-maintenance-margin-rate-max-leverage.js +60 -0
  106. package/examples/js/env-variables.js +26 -0
  107. package/examples/js/error-handling.js +89 -0
  108. package/examples/js/exchange-capabilities.js +135 -0
  109. package/examples/js/exchanges-by-volume.js +60 -0
  110. package/examples/js/exchanges.js +40 -0
  111. package/examples/js/fetch-all-balances.js +219 -0
  112. package/examples/js/fetch-all-tickers-to-files-2.js +53 -0
  113. package/examples/js/fetch-all-tickers-to-files.js +77 -0
  114. package/examples/js/fetch-balance.js +28 -0
  115. package/examples/js/fetch-create-deposit-address.js +101 -0
  116. package/examples/js/fetch-from-many-exchanges-simultaneously.js +21 -0
  117. package/examples/js/fetch-funding-rate-history.js +25 -0
  118. package/examples/js/fetch-futures/prettier.config.js +5 -0
  119. package/examples/js/fetch-futures/src/index.js +25 -0
  120. package/examples/js/fetch-ohlcv-from-to-mark-index-premium.js +72 -0
  121. package/examples/js/fetch-ohlcv-many-exchanges-continuosly.js +39 -0
  122. package/examples/js/fetch-ohlcv.js +16 -0
  123. package/examples/js/fetch-okex-futures.js +22 -0
  124. package/examples/js/fetch-orders.js +27 -0
  125. package/examples/js/fetch-ticker-from-multiple-exchanges.js +35 -0
  126. package/examples/js/fetch-ticker-where-available.js +75 -0
  127. package/examples/js/fetch-tickers/build/index.js +19 -0
  128. package/examples/js/fetch-tickers/prettier.config.js +5 -0
  129. package/examples/js/fetch-tickers/src/index.js +17 -0
  130. package/examples/js/gateio-create-batch-order.js +43 -0
  131. package/examples/js/gateio-futures.js +49 -0
  132. package/examples/js/gateio-open-close-contract.js +49 -0
  133. package/examples/js/gateio-swaps.js +74 -0
  134. package/examples/js/gdax-fetch-trades-pagination.js +29 -0
  135. package/examples/js/hitbtc2-withdraw.js +61 -0
  136. package/examples/js/how-to-import-one-exchange-esm.js +10 -0
  137. package/examples/js/huobi-futures.js +71 -0
  138. package/examples/js/huobi-open-close-contract.js +63 -0
  139. package/examples/js/huobi-swaps.js +70 -0
  140. package/examples/js/huobipro-market-buy-sell-fetch-trading-limits.js +98 -0
  141. package/examples/js/hybridCJSExample.cjs +19 -0
  142. package/examples/js/hybridESMExample.js +19 -0
  143. package/examples/js/idex-fetch-balance.js +13 -0
  144. package/examples/js/instantiate-all-at-once.js +46 -0
  145. package/examples/js/instantiate-all-from-json.js +31 -0
  146. package/examples/js/kraken-create-and-close-position.js +54 -0
  147. package/examples/js/kraken-fetch-order-trades.js +33 -0
  148. package/examples/js/kraken-margin-trading.js +89 -0
  149. package/examples/js/kucoin-rate-limit.js +38 -0
  150. package/examples/js/latoken-example.js +108 -0
  151. package/examples/js/live-orderbook.js +106 -0
  152. package/examples/js/live-ticker.js +80 -0
  153. package/examples/js/live-tickers.js +74 -0
  154. package/examples/js/load-all-contracts.js +41 -0
  155. package/examples/js/load-all-symbols-at-once.js +69 -0
  156. package/examples/js/load-all-tickers-at-once.js +91 -0
  157. package/examples/js/load-markets-to-files.js +57 -0
  158. package/examples/js/looping-over-all-symbols-of-specific-exchanges.js +61 -0
  159. package/examples/js/looping-over-specific-symbols-of-all-exchanges.js +91 -0
  160. package/examples/js/margin-loan-borrow-buy-sell-repay.js +70 -0
  161. package/examples/js/market-status-and-currency-status.js +29 -0
  162. package/examples/js/ohlcv-console-chart.js +29 -0
  163. package/examples/js/okex-fetch-closed-orders-archive.js +31 -0
  164. package/examples/js/okex-transfer.js +51 -0
  165. package/examples/js/okx-poll-fetch-my-trades.js +37 -0
  166. package/examples/js/okx-poll-rate-limit.js +48 -0
  167. package/examples/js/order-book-extra-level-depth-param.js +20 -0
  168. package/examples/js/phemex-create-order-position-with-takeprofit-stoploss.js +49 -0
  169. package/examples/js/poll-ohlcv.js +43 -0
  170. package/examples/js/poloniex-fetch-order-books.js +35 -0
  171. package/examples/js/poloniex-limits-amount-min.js +62 -0
  172. package/examples/js/proxy-round-robin.js +98 -0
  173. package/examples/js/proxy-usage.js +32 -0
  174. package/examples/js/sample-local-proxy-server-with-cors.js +12 -0
  175. package/examples/js/search-all-exchanges.js +159 -0
  176. package/examples/js/shared-load-markets.js +80 -0
  177. package/examples/js/sort-swap-markets-by-hourly-price-change.js +55 -0
  178. package/examples/js/symbols.js +110 -0
  179. package/examples/js/theocean.js +41 -0
  180. package/examples/js/tickers.js +106 -0
  181. package/examples/js/validate-paginated-data.js +61 -0
  182. package/examples/js/watch-OHLCV-For-Symbols.js +15 -0
  183. package/examples/js/watch-OHLCV.js +12 -0
  184. package/examples/js/watch-OrderBook-For-Symbols.js +11 -0
  185. package/examples/js/watch-Trades-For-Symbols.js +11 -0
  186. package/examples/js/watch-tickers.js +11 -0
  187. package/examples/js/watchOHLCVForSymbols.js +15 -0
  188. package/examples/js/watchOrderBookForSymbols.js +11 -0
  189. package/examples/js/watchPositions-many-exchanges-continuosly.d.ts +2 -0
  190. package/examples/js/watchPositions-many-exchanges-continuosly.d.ts.map +1 -0
  191. package/examples/js/watchPositions-many-exchanges-continuosly.js +49 -0
  192. package/examples/js/watchPositions.d.ts +2 -0
  193. package/examples/js/watchPositions.d.ts.map +1 -0
  194. package/examples/js/watchPositions.js +13 -0
  195. package/examples/js/watchPositionsForSymbols.d.ts +2 -0
  196. package/examples/js/watchPositionsForSymbols.d.ts.map +1 -0
  197. package/examples/js/watchPositionsForSymbols.js +14 -0
  198. package/examples/js/watchTradesForSymbols.js +11 -0
  199. package/examples/js/withdraw-from-one-exchange-to-another.js +50 -0
  200. package/examples/php/README.md +7 -0
  201. package/examples/py/README.md +15 -0
  202. package/examples/py/playing_with_ccxt_example.ipynb +222 -0
  203. package/examples/ts/.eslintrc +111 -0
  204. package/examples/ts/build-ohlcv-bars.ts +53 -0
  205. package/examples/ts/cli.ts +397 -0
  206. package/examples/ts/compare-two-exchanges-capabilities.ts +36 -0
  207. package/examples/ts/create-order-position-with-takeprofit-stoploss.ts +89 -0
  208. package/examples/ts/create-order-ws-example.ts +33 -0
  209. package/examples/ts/create-orders-example.ts +21 -0
  210. package/examples/ts/create-trailing-amount-order.ts +37 -0
  211. package/examples/ts/create-trailing-percent-order.ts +37 -0
  212. package/examples/ts/custom-proxy-agent-for-js.ts +14 -0
  213. package/examples/ts/fetch-futures/package-lock.json +116 -0
  214. package/examples/ts/fetch-futures/package.json +34 -0
  215. package/examples/ts/fetch-futures/prettier.config.js +4 -0
  216. package/examples/ts/fetch-futures/src/index.ts +28 -0
  217. package/examples/ts/fetch-futures/tsconfig.json +28 -0
  218. package/examples/ts/fetch-ohlcv-many-exchanges-continuosly.ts +44 -0
  219. package/examples/ts/fetch-ohlcv.ts +17 -0
  220. package/examples/ts/fetch-tickers/package-lock.json +116 -0
  221. package/examples/ts/fetch-tickers/package.json +34 -0
  222. package/examples/ts/fetch-tickers/prettier.config.js +4 -0
  223. package/examples/ts/fetch-tickers/src/index.ts +21 -0
  224. package/examples/ts/fetch-tickers/tsconfig.json +28 -0
  225. package/examples/ts/how-to-import-one-exchange-esm.ts +11 -0
  226. package/examples/ts/kraken-create-and-close-position.ts +69 -0
  227. package/examples/ts/margin-loan-borrow-buy-sell-repay.ts +72 -0
  228. package/examples/ts/nextjs-page-router/.eslintrc.json +3 -0
  229. package/examples/ts/nextjs-page-router/README.md +43 -0
  230. package/examples/ts/nextjs-page-router/next.config.js +6 -0
  231. package/examples/ts/nextjs-page-router/package-lock.json +7425 -0
  232. package/examples/ts/nextjs-page-router/package.json +28 -0
  233. package/examples/ts/nextjs-page-router/postcss.config.js +6 -0
  234. package/examples/ts/nextjs-page-router/public/favicon.ico +0 -0
  235. package/examples/ts/nextjs-page-router/src/pages/_app.tsx +6 -0
  236. package/examples/ts/nextjs-page-router/src/pages/_document.tsx +13 -0
  237. package/examples/ts/nextjs-page-router/src/pages/balance.tsx +46 -0
  238. package/examples/ts/nextjs-page-router/src/pages/index.tsx +8 -0
  239. package/examples/ts/nextjs-page-router/src/pages/tickers.tsx +61 -0
  240. package/examples/ts/nextjs-page-router/src/styles/globals.css +27 -0
  241. package/examples/ts/nextjs-page-router/tailwind.config.ts +20 -0
  242. package/examples/ts/nextjs-page-router/tsconfig.json +22 -0
  243. package/examples/ts/phemex-create-order-position-with-takeprofit-stoploss.ts +62 -0
  244. package/examples/ts/proxy-usage.ts +41 -0
  245. package/examples/ts/sample-local-proxy-server-with-cors.ts +15 -0
  246. package/examples/ts/watch-OHLCV-For-Symbols.ts +17 -0
  247. package/examples/ts/watch-OHLCV.ts +14 -0
  248. package/examples/ts/watch-OrderBook-For-Symbols.ts +13 -0
  249. package/examples/ts/watch-Trades-For-Symbols.ts +13 -0
  250. package/examples/ts/watch-tickers.ts +13 -0
  251. package/examples/ts/watchPositions-many-exchanges-continuosly.ts +53 -0
  252. package/examples/ts/watchPositions.ts +15 -0
  253. package/examples/ts/watchPositionsForSymbols.ts +16 -0
  254. package/examples/tsconfig.json +27 -0
  255. package/js/ccxt.d.ts +1 -1
  256. package/js/ccxt.js +1 -1
  257. package/js/src/base/Exchange.d.ts +2 -2
  258. package/js/src/base/Exchange.js +1 -1
  259. package/js/src/bitget.js +62 -50
  260. package/js/src/bybit.d.ts +3 -1
  261. package/js/src/bybit.js +90 -30
  262. package/js/src/coinbaseinternational.js +1 -1
  263. package/js/src/htx.js +16 -9
  264. package/js/src/hyperliquid.js +2 -1
  265. package/js/src/pro/krakenfutures.js +8 -7
  266. package/package.json +4 -1
  267. package/skip-tests.json +214 -424
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+
3
+ const ccxt = require ('../../ccxt')
4
+
5
+ const exchange = new ccxt.binance ();
6
+
7
+ const symbols = [ 'BTC/USDT', 'ETH/USDT', 'ADA/USDT'];
8
+ // start from i.e. 01 february 2022
9
+ // you can use milliseconds integer or also parse uniform datetime string, i.e. exchange.parse8601 ('2020-02-01T00:00:00Z')
10
+ const fromTimestamp = 1643659200000;
11
+ const tillTimestamp = exchange.milliseconds ();
12
+ const timeframe = '1h';
13
+ const itemsLimit = 1000;
14
+ const fetchMethod = 'fetchOHLCV'; // if using swap exchanges, you can also use fetchMarkOHLCV, fetchIndexOHLCV, fetchPremiumIndexOHLCV
15
+
16
+ async function myDataFetch (symbol) {
17
+
18
+ await exchange.loadMarkets ();
19
+
20
+ // get the duration of one timeframe period in milliseconds
21
+ const duration = exchange.parseTimeframe (timeframe) * 1000;
22
+ console.log ('Fetching', symbol, timeframe, 'candles', 'from', exchange.iso8601 (fromTimestamp), 'to', exchange.iso8601 (tillTimestamp), '...');
23
+
24
+ let result = [];
25
+ let since = fromTimestamp;
26
+ do {
27
+
28
+ try {
29
+
30
+ const candles = await exchange[fetchMethod] (symbol, timeframe, since, itemsLimit);
31
+
32
+ const message = '[' + symbol + '] Fetched ' + candles.length + ' ' + timeframe + ' candles since ' + exchange.iso8601 (since);
33
+
34
+ if (candles.length) {
35
+
36
+ const first = candles[0];
37
+ const last = candles[candles.length - 1];
38
+ console.log ( message, ' | first', exchange.iso8601 (first[0]), ' | last', exchange.iso8601 (last[0]) );
39
+
40
+ // store your candles to a database or to a file here
41
+ // ...
42
+ result = result.concat (candles);
43
+ since = last[0] + duration // next start from last candle timestamp + duration
44
+
45
+ } else {
46
+ console.log ( message, ' | moving into next period');
47
+ since = since + duration * itemsLimit; // next start from the current period's end
48
+ }
49
+
50
+ } catch (e) {
51
+
52
+ console.log (symbol, e.constructor.name, e.message, ' Taking small pause...');
53
+ await exchange.sleep (2000);
54
+ // retry on next iteration
55
+ }
56
+
57
+ } while (since + duration <= tillTimestamp)
58
+
59
+ console.log (symbol + ' completed !');
60
+ return result;
61
+ }
62
+
63
+
64
+
65
+ async function checkAllSymbols() {
66
+ // download in parallel
67
+ await Promise.all (symbols.map (symbol => myDataFetch (symbol)));
68
+ // you can also do one by one (but that is not much optimal)
69
+ //for (const symbol of symbols) {
70
+ // const data = await myDataFetch (symbol);
71
+ }
72
+ checkAllSymbols();
@@ -0,0 +1,39 @@
1
+ import ccxt from '../../js/ccxt.js';
2
+ // AUTO-TRANSPILE //
3
+ // fetch and handle constinuosly
4
+ async function fetchOHLCVContinuously(exchange, symbol) {
5
+ while (true) {
6
+ try {
7
+ const ohlcv = await exchange.fetchOHLCV(symbol);
8
+ const ohlcvLength = ohlcv.length;
9
+ console.log('Fetched ', exchange.id, ' - ', symbol, ' candles. last candle: ', ohlcv[ohlcvLength - 1]);
10
+ }
11
+ catch (e) {
12
+ console.log(e);
13
+ break;
14
+ }
15
+ }
16
+ }
17
+ // start exchanges and fetch OHLCV loop
18
+ async function startExchange(exchangeName, symbols) {
19
+ const ex = new ccxt[exchangeName]({});
20
+ const promises = [];
21
+ for (let i = 0; i < symbols.length; i++) {
22
+ const symbol = symbols[i];
23
+ promises.push(fetchOHLCVContinuously(ex, symbol));
24
+ }
25
+ await Promise.all(promises);
26
+ await ex.close();
27
+ }
28
+ // main function
29
+ async function example() {
30
+ const exchanges = ['binance', 'okx', 'kraken'];
31
+ const symbols = ['BTC/USDT', 'ETH/USDT'];
32
+ const promises = [];
33
+ for (let i = 0; i < exchanges.length; i++) {
34
+ const exchangeName = exchanges[i];
35
+ promises.push(startExchange(exchangeName, symbols));
36
+ }
37
+ await Promise.all(promises);
38
+ }
39
+ await example();
@@ -0,0 +1,16 @@
1
+ import ccxt from '../../js/ccxt.js';
2
+ // AUTO-TRANSPILE //
3
+ async function example() {
4
+ const myex = new ccxt.okx({});
5
+ const fromTimestamp = myex.milliseconds() - 86400 * 1000; // last 24 hrs
6
+ const ohlcv = await myex.fetchOHLCV('BTC/USDT', '1m', fromTimestamp, 3, { 'whatever': 123 });
7
+ const length = ohlcv.length;
8
+ if (length > 0) {
9
+ const lastPrice = ohlcv[length - 1][4];
10
+ console.log('Fetched ', length, ' candles for ', myex.id, ': last close ', lastPrice);
11
+ }
12
+ else {
13
+ console.log('No candles have been fetched');
14
+ }
15
+ }
16
+ await example();
@@ -0,0 +1,22 @@
1
+
2
+
3
+ import ccxt from '../../js/ccxt.js';
4
+
5
+ async function test () {
6
+
7
+ const exchange = new ccxt.okex ()
8
+ await exchange.loadMarkets ()
9
+
10
+ for (let symbol in exchange.markets) {
11
+
12
+ const market = exchange.markets[symbol]
13
+
14
+ if (market['future']) {
15
+ console.log ('----------------------------------------------------')
16
+ console.log (symbol, await exchange.fetchTicker (symbol))
17
+ await ccxt.sleep (exchange.rateLimit)
18
+ }
19
+ }
20
+ }
21
+
22
+ test ()
@@ -0,0 +1,27 @@
1
+
2
+
3
+ import ccxt from '../../js/ccxt.js';
4
+ import asTable from 'as-table';
5
+ import log from 'ololog';
6
+ import ansicolor from 'ansicolor';
7
+
8
+
9
+ ansicolor.nice
10
+
11
+ const exchange = new ccxt.bittrex ({
12
+ apiKey: "YOUR_API_KEY",
13
+ secret: "YOUR_SECRET",
14
+ })
15
+
16
+ async function test () {
17
+
18
+ const orders = await exchange.fetchOrders ()
19
+
20
+ log (asTable (orders.map (order => ccxt.omit (order, [ 'timestamp', 'info' ]))))
21
+
22
+ const order = await exchange.fetchOrder (orders[0]['id'])
23
+
24
+ log (order)
25
+ }
26
+
27
+ test ()
@@ -0,0 +1,35 @@
1
+
2
+
3
+ import ccxt from '../../js/ccxt.js';
4
+ (async () => {
5
+
6
+ const exchanges = [
7
+ 'bittrex',
8
+ 'poloniex',
9
+ ]
10
+
11
+ const symbol = 'BTC/USDT'
12
+ const tickers = {}
13
+
14
+ await Promise.all (exchanges.map (exchangeId =>
15
+
16
+ new Promise (async (resolve, reject) => {
17
+
18
+ const exchange = new ccxt[exchangeId] ()
19
+
20
+ while (true) {
21
+
22
+ const ticker = await exchange.fetchTicker (symbol)
23
+ tickers[exchangeId] = ticker
24
+
25
+ Object.keys (tickers).map (exchangeId => {
26
+ const ticker = tickers[exchangeId]
27
+ console.log (ticker['datetime'], exchangeId, ticker['bid'], ticker['ask'])
28
+ })
29
+ }
30
+
31
+ })
32
+
33
+ ))
34
+
35
+ }) ()
@@ -0,0 +1,75 @@
1
+
2
+
3
+ import ccxt from '../../js/ccxt.js';
4
+ import asTable from 'as-table';
5
+ import log from 'ololog';
6
+ import ansicolor from 'ansicolor';
7
+
8
+
9
+ ansicolor.nice
10
+
11
+ let printUsage = function () {
12
+ log ('Usage: node', process.argv[1], 'symbol'.green)
13
+ }
14
+
15
+ ;(async function main () {
16
+
17
+ if (process.argv.length > 2) {
18
+
19
+ let symbol = process.argv[2].toUpperCase ()
20
+
21
+ for (let i = 0; i < ccxt.exchanges.length; i++) {
22
+
23
+ let id = ccxt.exchanges[i]
24
+
25
+ const exchange = new ccxt[id] ()
26
+ if (exchange.has.fetchTicker) {
27
+
28
+ try {
29
+
30
+ await exchange.loadMarkets ()
31
+
32
+ if (exchange.symbols.includes (symbol)) {
33
+
34
+ log (id.green)
35
+
36
+ const ticker = await exchange.fetchTicker (symbol)
37
+
38
+ log.dim (ticker)
39
+
40
+ if (ticker['baseVolume'] && ticker['quoteVolume']) {
41
+
42
+ if (ticker['bid'] > 1) {
43
+
44
+ if (ticker['baseVolume'] > ticker['quoteVolume'])
45
+ log (id.bright, 'baseVolume > quoteVolume ← !'.bright)
46
+
47
+ } else {
48
+
49
+ if (ticker['baseVolume'] < ticker['quoteVolume'])
50
+ log (id.bright, 'baseVolume < quoteVolume ← !'.bright)
51
+
52
+ }
53
+
54
+ }
55
+
56
+ } else {
57
+
58
+ log (id.yellow)
59
+ }
60
+
61
+ } catch (e) {
62
+
63
+ log.error (id.red, e.toString ().red)
64
+ }
65
+ }
66
+ }
67
+
68
+ } else {
69
+
70
+ printUsage ()
71
+ }
72
+
73
+ process.exit ()
74
+
75
+ }) ()
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ // Example code in typescript
3
+ // Based on /examples/js/fetch-from-many-exchanges-simultaneously.js
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ const ccxt = require("ccxt");
6
+ const log = require('ololog');
7
+ const symbol = 'BTC/USD';
8
+ const exchanges = ['coinbasepro', 'gemini', 'kraken'];
9
+ const fetchTickers = async (symbol) => {
10
+ const result = await Promise.all(exchanges.map(async (id) => {
11
+ const CCXT = ccxt; // Hack!
12
+ const exchange = new CCXT[id]({ 'enableRateLimit': true });
13
+ const ticker = await exchange.fetchTicker(symbol);
14
+ const exchangeExtended = exchange.extend({ 'exchange': id }, ticker);
15
+ return exchangeExtended;
16
+ }));
17
+ log(result);
18
+ };
19
+ fetchTickers(symbol);
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ module.exports = {
3
+ singleQuote: true,
4
+ trailingComma: 'es5',
5
+ };
@@ -0,0 +1,17 @@
1
+ // Example code in typescript
2
+ // Based on /examples/js/fetch-from-many-exchanges-simultaneously.js
3
+ import * as ccxt from 'ccxt';
4
+ const log = require('ololog');
5
+ const symbol = 'BTC/USD';
6
+ const exchanges = ['coinbasepro', 'gemini', 'kraken'];
7
+ const fetchTickers = async (symbol) => {
8
+ const result = await Promise.all(exchanges.map(async (id) => {
9
+ const CCXT = ccxt; // Hack!
10
+ const exchange = new CCXT[id]({ 'enableRateLimit': true });
11
+ const ticker = await exchange.fetchTicker(symbol);
12
+ const exchangeExtended = exchange.extend({ 'exchange': id }, ticker);
13
+ return exchangeExtended;
14
+ }));
15
+ log(result);
16
+ };
17
+ fetchTickers(symbol);
@@ -0,0 +1,43 @@
1
+ const ccxt = require ('../../ccxt');
2
+
3
+ console.log ('CCXT Version:', ccxt.version);
4
+
5
+ async function main () {
6
+
7
+ const exchange = new ccxt.gateio ({
8
+ 'apiKey': 'YOUR_API_KEY',
9
+ 'secret': 'YOUR_API_SECRET',
10
+ });
11
+ await exchange.loadMarkets ();
12
+
13
+ const ada = exchange.market ('ADA/USDT');
14
+ const xrp = exchange.market ('XRP/USDT');
15
+
16
+ const orders = await exchange.privateSpotPostBatchOrders (
17
+ [
18
+ {
19
+ text: "t-123456",
20
+ currency_pair: ada['id'],
21
+ type: "limit",
22
+ account: "spot",
23
+ side: "buy",
24
+ amount: "3",
25
+ price: "0.4",
26
+ },
27
+ {
28
+ text: "t-123456",
29
+ currency_pair: xrp['id'],
30
+ type: "limit",
31
+ account: "spot",
32
+ side: "buy",
33
+ amount: "3",
34
+ price: "0.47",
35
+ },
36
+ ]
37
+ );
38
+
39
+ console.log (orders);
40
+
41
+ };
42
+
43
+ main ();
@@ -0,0 +1,49 @@
1
+ import ccxt from '../../js/ccxt.js';
2
+
3
+
4
+ const exchange = new ccxt.gateio ({
5
+ 'apiKey': 'YOUR_API_KEY',
6
+ 'secret': 'YOUR_SECRET_KEY',
7
+ 'options': {
8
+ 'defaultType': 'future',
9
+ },
10
+ })
11
+
12
+ ;(async () => {
13
+ // exchange.setSandboxMode (true)
14
+
15
+ const markets = await exchange.loadMarkets ()
16
+
17
+ // exchange.verbose = true // uncomment for debugging purposes if necessary
18
+
19
+ // Example 1: Creating a future (market) order
20
+ try {
21
+
22
+ // find a future
23
+ const futures = []
24
+ for (const [key, market] of Object.entries(markets)) {
25
+ if (market['future']) {
26
+ futures.push(market);
27
+ }
28
+ }
29
+ if (futures.length > 0) {
30
+ const market = futures[0];
31
+ const symbol = market['symbol'] // example: BTC/USDT:USDT-220318
32
+ const type = 'market'
33
+ const side = 'buy'
34
+ const amount = 1
35
+
36
+ // placing an order
37
+ const order = await exchange.createOrder (symbol, type, side, amount)
38
+ console.log (order)
39
+
40
+ // fetching open orders
41
+ const openOrders = await exchange.fetchOpenOrders(symbol)
42
+ console.log(openOrders)
43
+ }
44
+
45
+ } catch (e) {
46
+ console.log (e.constructor.name, e.message)
47
+ }
48
+
49
+ }) ()
@@ -0,0 +1,49 @@
1
+ const ccxt = require ('../../ccxt');
2
+
3
+
4
+ const exchange = new ccxt.gateio ({
5
+ 'apiKey': 'YOUR_API_KEY',
6
+ 'secret': 'YOUR_SECRET',
7
+ 'options': {
8
+ 'defaultType': 'swap',
9
+ 'marginMode': 'cross'
10
+ },
11
+ })
12
+
13
+
14
+ ;(async () => {
15
+
16
+ // exchange.setSandboxMode (true)
17
+
18
+ const markets = await exchange.loadMarkets ()
19
+
20
+ // exchange.verbose = true // uncomment for debugging purposes if necessary
21
+
22
+ // Example: creating and closing a contract
23
+ let symbol = 'LTC/USDT:USDT'
24
+ let type = 'market'
25
+ let side = 'buy'
26
+ let amount = 1
27
+ let price = undefined
28
+
29
+ try {
30
+ // fetching current balance
31
+ const balance = await exchange.fetchBalance()
32
+ console.log(balance)
33
+
34
+ // placing an order / opening contract position
35
+ const order = await exchange.createOrder (symbol, type, side, amount, price)
36
+ console.log (order)
37
+
38
+ // closing it by issuing an oposite contract
39
+ // and therefore close our previous position
40
+ side = 'sell'
41
+ type = 'market'
42
+ reduce_only = true
43
+ params = {'reduce_only': reduce_only}
44
+ const opositeOrder = await exchange.createOrder (symbol, type, side, amount, price, params)
45
+ console.log (opositeOrder)
46
+ } catch (e) {
47
+ console.log (e.constructor.name, e.message)
48
+ }
49
+ }) ()
@@ -0,0 +1,74 @@
1
+ import ccxt from '../../js/ccxt.js';
2
+
3
+ const exchange = new ccxt.gateio ({
4
+ 'apiKey': 'YOUR_API_KEY',
5
+ 'secret': 'YOUR_SECRET_KEY',
6
+ 'options': {
7
+ 'defaultType': 'swap',
8
+ },
9
+ })
10
+
11
+ ;(async () => {
12
+ // exchange.setSandboxMode (true)
13
+
14
+ const markets = await exchange.loadMarkets ()
15
+
16
+ exchange.verbose = true // uncomment for debugging purposes if necessary
17
+
18
+ // Example 1: Creating and canceling a linear swap (limit) order
19
+ try {
20
+ const symbol = 'LTC/USDT:USDT'
21
+ const type = 'limit'
22
+ const side = 'buy'
23
+ const amount = 1
24
+ const price = 55
25
+
26
+ // placing an order
27
+ const order = await exchange.createOrder (symbol, type, side, amount, price)
28
+ console.log (order)
29
+
30
+ // fetching open orders
31
+ const openOrders = await exchange.fetchOpenOrders(symbol)
32
+ console.log(openOrders)
33
+
34
+ // canceling an order
35
+ const cancel = await exchange.cancelOrder (order['id'], symbol)
36
+ console.log (cancel)
37
+ } catch (e) {
38
+ console.log (e.constructor.name, e.message)
39
+ }
40
+
41
+ // Example 2: Creating and canceling a linear swap (stop-limit) order with leverage
42
+ try {
43
+ const symbol = 'LTC/USDT:USDT'
44
+ const type = 'limit'
45
+ const side = 'buy'
46
+ const amount = 1
47
+ const price = 55
48
+
49
+ const stopPrice = 130
50
+ const params = {
51
+ 'stopPrice': stopPrice,
52
+ }
53
+ //set leverage
54
+ const leverage = await exchange.setLeverage(3, symbol);
55
+ console.log(leverage)
56
+
57
+ // placing an order
58
+ const order = await exchange.createOrder (symbol, type, side, amount, price, params)
59
+ console.log (order)
60
+
61
+ // canceling an order
62
+ const cancelParams = {
63
+ isStop: true,
64
+ };
65
+ const cancel = await exchange.cancelOrder (order['id'], symbol, cancelParams)
66
+ console.log (cancel)
67
+
68
+ //reset leverage
69
+ exchange.setLeverage(1, symbol);
70
+ } catch (e) {
71
+ console.log (e.constructor.name, e.message)
72
+ }
73
+
74
+ }) ()
@@ -0,0 +1,29 @@
1
+ import ccxt from '../../js/ccxt.js';
2
+ import ololog from 'ololog';
3
+
4
+ const { noLocate } = ololog;
5
+ const log = noLocate;
6
+
7
+ const exchange = new ccxt.coinbasepro ()
8
+
9
+ ;(async () => {
10
+
11
+ const symbol = 'ETH/BTC'
12
+ const params = {}
13
+ await exchange.loadMarkets ()
14
+ while (true) {
15
+ const trades = await exchange.fetchTrades (symbol, undefined, undefined, params)
16
+ if (trades.length) {
17
+ const firstTrade = trades[0]
18
+ const lastTrade = trades[trades.length - 1]
19
+ log.yellow ('Fetched', trades.length, symbol, 'trades from', firstTrade['datetime'], 'to', lastTrade['datetime'])
20
+ if ('Cb-After' in exchange.last_response_headers) {
21
+ params['after'] = exchange.last_response_headers['Cb-After'];
22
+ }
23
+ } else {
24
+ log.green ('Done.')
25
+ break;
26
+ }
27
+ }
28
+
29
+ }) ()
@@ -0,0 +1,61 @@
1
+
2
+
3
+ import ccxt from '../../js/ccxt.js';
4
+ import asTable from 'as-table';
5
+ import ololog from 'ololog';
6
+ const log = ololog.configure ({ locate: false })
7
+
8
+ require ('ansicolor').nice
9
+
10
+ const getPositiveAccounts = function (balance) {
11
+ const result = {}
12
+ Object.keys (balance)
13
+ .filter (currency => balance[currency] && (balance[currency] > 0))
14
+ .forEach (currency => {
15
+ result[currency] = balance[currency]
16
+ })
17
+ return result
18
+ }
19
+
20
+ ;(async () => {
21
+
22
+ // instantiate the exchange
23
+ let exchange = new ccxt.hitbtc2 ({
24
+ "apiKey": "YOUR_API_KEY",
25
+ "secret": "YOUR_SECRET",
26
+ })
27
+
28
+ try {
29
+
30
+ let tradingBalance = await exchange.fetchBalance ()
31
+ let accountBalance = await exchange.fetchBalance ({ type: 'account' })
32
+
33
+ log.cyan ('Trading balance:', getPositiveAccounts (tradingBalance.total))
34
+ log.magenta ('Account balance:', getPositiveAccounts (accountBalance.total))
35
+
36
+ // withdraw
37
+ let withdraw = await exchange.withdraw ('ETH', 0.01, '0x811DCfeb6dC0b9ed825808B6B060Ca469b83fB81')
38
+
39
+ // output the result
40
+ log (exchange.name.green, 'withdraw', withdraw)
41
+
42
+ } catch (e) {
43
+
44
+ if (e instanceof ccxt.DDoSProtection || e.message.includes ('ECONNRESET')) {
45
+ log.bright.yellow ('[DDoS Protection] ' + e.message)
46
+ } else if (e instanceof ccxt.RequestTimeout) {
47
+ log.bright.yellow ('[Request Timeout] ' + e.message)
48
+ } else if (e instanceof ccxt.AuthenticationError) {
49
+ log.bright.yellow ('[Authentication Error] ' + e.message)
50
+ } else if (e instanceof ccxt.ExchangeNotAvailable) {
51
+ log.bright.yellow ('[Exchange Not Available Error] ' + e.message)
52
+ } else if (e instanceof ccxt.ExchangeError) {
53
+ log.bright.yellow ('[Exchange Error] ' + e.message)
54
+ } else if (e instanceof ccxt.NetworkError) {
55
+ log.bright.yellow ('[Network Error] ' + e.message)
56
+ } else {
57
+ throw e
58
+ }
59
+ }
60
+
61
+ }) ()
@@ -0,0 +1,10 @@
1
+ import { binance } from '../../js/ccxt.js';
2
+ async function example() {
3
+ const exchange = new binance({});
4
+ const ob = await exchange.fetchOrderBook('BTC/USDT', 3);
5
+ const asks = ob['asks'];
6
+ const bids = ob['bids'];
7
+ console.log(asks);
8
+ console.log(bids);
9
+ }
10
+ example();