ccxt 4.2.84 → 4.2.85

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 (164) hide show
  1. package/README.md +3 -3
  2. package/build.sh +1 -1
  3. package/dist/ccxt.browser.js +867 -904
  4. package/dist/ccxt.browser.min.js +4 -4
  5. package/dist/cjs/ccxt.js +1 -1
  6. package/dist/cjs/src/ace.js +5 -5
  7. package/dist/cjs/src/ascendex.js +8 -8
  8. package/dist/cjs/src/base/Exchange.js +76 -14
  9. package/dist/cjs/src/bigone.js +12 -12
  10. package/dist/cjs/src/binance.js +23 -35
  11. package/dist/cjs/src/bingx.js +13 -9
  12. package/dist/cjs/src/bit2c.js +1 -1
  13. package/dist/cjs/src/bitbank.js +8 -8
  14. package/dist/cjs/src/bitbns.js +5 -5
  15. package/dist/cjs/src/bitfinex.js +1 -1
  16. package/dist/cjs/src/bitfinex2.js +1 -1
  17. package/dist/cjs/src/bitget.js +30 -24
  18. package/dist/cjs/src/bithumb.js +5 -5
  19. package/dist/cjs/src/bitmart.js +16 -16
  20. package/dist/cjs/src/bitopro.js +1 -1
  21. package/dist/cjs/src/bitrue.js +4 -4
  22. package/dist/cjs/src/bitso.js +5 -5
  23. package/dist/cjs/src/bitstamp.js +1 -1
  24. package/dist/cjs/src/bitteam.js +8 -8
  25. package/dist/cjs/src/bl3p.js +1 -1
  26. package/dist/cjs/src/btcturk.js +6 -6
  27. package/dist/cjs/src/bybit.js +31 -95
  28. package/dist/cjs/src/coincheck.js +4 -4
  29. package/dist/cjs/src/coinex.js +11 -11
  30. package/dist/cjs/src/coinlist.js +7 -7
  31. package/dist/cjs/src/coinmate.js +4 -4
  32. package/dist/cjs/src/coinmetro.js +3 -3
  33. package/dist/cjs/src/coinone.js +5 -5
  34. package/dist/cjs/src/coinspot.js +2 -2
  35. package/dist/cjs/src/cryptocom.js +17 -17
  36. package/dist/cjs/src/currencycom.js +1 -1
  37. package/dist/cjs/src/delta.js +0 -8
  38. package/dist/cjs/src/deribit.js +16 -92
  39. package/dist/cjs/src/digifinex.js +8 -8
  40. package/dist/cjs/src/exmo.js +8 -8
  41. package/dist/cjs/src/gate.js +0 -8
  42. package/dist/cjs/src/hitbtc.js +5 -4
  43. package/dist/cjs/src/hollaex.js +7 -7
  44. package/dist/cjs/src/htx.js +7 -7
  45. package/dist/cjs/src/huobijp.js +3 -3
  46. package/dist/cjs/src/idex.js +2 -2
  47. package/dist/cjs/src/independentreserve.js +2 -2
  48. package/dist/cjs/src/indodax.js +2 -2
  49. package/dist/cjs/src/kraken.js +8 -8
  50. package/dist/cjs/src/krakenfutures.js +6 -6
  51. package/dist/cjs/src/kucoin.js +5 -1
  52. package/dist/cjs/src/kucoinfutures.js +8 -8
  53. package/dist/cjs/src/kuna.js +16 -16
  54. package/dist/cjs/src/latoken.js +2 -2
  55. package/dist/cjs/src/lbank.js +10 -10
  56. package/dist/cjs/src/luno.js +4 -4
  57. package/dist/cjs/src/mercado.js +5 -5
  58. package/dist/cjs/src/mexc.js +6 -6
  59. package/dist/cjs/src/ndax.js +1 -1
  60. package/dist/cjs/src/novadax.js +9 -9
  61. package/dist/cjs/src/oceanex.js +7 -7
  62. package/dist/cjs/src/okcoin.js +13 -13
  63. package/dist/cjs/src/okx.js +23 -31
  64. package/dist/cjs/src/onetrading.js +4 -4
  65. package/dist/cjs/src/p2b.js +7 -7
  66. package/dist/cjs/src/phemex.js +12 -12
  67. package/dist/cjs/src/poloniexfutures.js +5 -5
  68. package/dist/cjs/src/pro/binance.js +167 -121
  69. package/dist/cjs/src/pro/kucoin.js +6 -7
  70. package/dist/cjs/src/pro/okx.js +19 -2
  71. package/dist/cjs/src/probit.js +11 -11
  72. package/dist/cjs/src/timex.js +7 -7
  73. package/dist/cjs/src/tokocrypto.js +9 -9
  74. package/dist/cjs/src/wavesexchange.js +3 -3
  75. package/dist/cjs/src/whitebit.js +5 -5
  76. package/dist/cjs/src/woo.js +1 -1
  77. package/dist/cjs/src/zaif.js +1 -1
  78. package/dist/cjs/src/zonda.js +7 -7
  79. package/examples/js/cli.js +0 -1
  80. package/examples/ts/cli.ts +0 -1
  81. package/js/ccxt.d.ts +1 -1
  82. package/js/ccxt.js +1 -1
  83. package/js/src/ace.js +5 -5
  84. package/js/src/ascendex.js +8 -8
  85. package/js/src/base/Exchange.d.ts +4 -3
  86. package/js/src/base/Exchange.js +76 -14
  87. package/js/src/bigone.js +12 -12
  88. package/js/src/binance.d.ts +0 -1
  89. package/js/src/binance.js +23 -35
  90. package/js/src/bingx.js +13 -9
  91. package/js/src/bit2c.js +1 -1
  92. package/js/src/bitbank.js +8 -8
  93. package/js/src/bitbns.js +5 -5
  94. package/js/src/bitfinex.js +1 -1
  95. package/js/src/bitfinex2.js +1 -1
  96. package/js/src/bitget.js +30 -24
  97. package/js/src/bithumb.js +5 -5
  98. package/js/src/bitmart.js +16 -16
  99. package/js/src/bitopro.js +1 -1
  100. package/js/src/bitrue.js +4 -4
  101. package/js/src/bitso.js +5 -5
  102. package/js/src/bitstamp.js +1 -1
  103. package/js/src/bitteam.js +8 -8
  104. package/js/src/bl3p.js +1 -1
  105. package/js/src/btcturk.js +6 -6
  106. package/js/src/bybit.d.ts +0 -3
  107. package/js/src/bybit.js +31 -95
  108. package/js/src/coincheck.js +4 -4
  109. package/js/src/coinex.js +11 -11
  110. package/js/src/coinlist.js +7 -7
  111. package/js/src/coinmate.js +4 -4
  112. package/js/src/coinmetro.js +3 -3
  113. package/js/src/coinone.js +5 -5
  114. package/js/src/coinspot.js +2 -2
  115. package/js/src/cryptocom.js +17 -17
  116. package/js/src/currencycom.js +1 -1
  117. package/js/src/delta.d.ts +0 -1
  118. package/js/src/delta.js +0 -8
  119. package/js/src/deribit.d.ts +0 -3
  120. package/js/src/deribit.js +16 -92
  121. package/js/src/digifinex.js +8 -8
  122. package/js/src/exmo.js +8 -8
  123. package/js/src/gate.d.ts +0 -1
  124. package/js/src/gate.js +0 -8
  125. package/js/src/hitbtc.js +5 -4
  126. package/js/src/hollaex.js +7 -7
  127. package/js/src/htx.js +7 -7
  128. package/js/src/huobijp.js +3 -3
  129. package/js/src/idex.js +2 -2
  130. package/js/src/independentreserve.js +2 -2
  131. package/js/src/indodax.js +2 -2
  132. package/js/src/kraken.js +8 -8
  133. package/js/src/krakenfutures.js +6 -6
  134. package/js/src/kucoin.js +5 -1
  135. package/js/src/kucoinfutures.js +8 -8
  136. package/js/src/kuna.js +16 -16
  137. package/js/src/latoken.js +2 -2
  138. package/js/src/lbank.js +10 -10
  139. package/js/src/luno.js +4 -4
  140. package/js/src/mercado.js +5 -5
  141. package/js/src/mexc.js +6 -6
  142. package/js/src/ndax.js +1 -1
  143. package/js/src/novadax.js +9 -9
  144. package/js/src/oceanex.js +7 -7
  145. package/js/src/okcoin.js +13 -13
  146. package/js/src/okx.d.ts +0 -1
  147. package/js/src/okx.js +23 -31
  148. package/js/src/onetrading.js +4 -4
  149. package/js/src/p2b.js +7 -7
  150. package/js/src/phemex.js +12 -12
  151. package/js/src/poloniexfutures.js +5 -5
  152. package/js/src/pro/binance.d.ts +5 -1
  153. package/js/src/pro/binance.js +168 -122
  154. package/js/src/pro/kucoin.js +6 -7
  155. package/js/src/pro/okx.js +19 -2
  156. package/js/src/probit.js +11 -11
  157. package/js/src/timex.js +7 -7
  158. package/js/src/tokocrypto.js +9 -9
  159. package/js/src/wavesexchange.js +3 -3
  160. package/js/src/whitebit.js +5 -5
  161. package/js/src/woo.js +1 -1
  162. package/js/src/zaif.js +1 -1
  163. package/js/src/zonda.js +7 -7
  164. package/package.json +1 -1
@@ -621,7 +621,7 @@ class probit extends probit$1 {
621
621
  // ]
622
622
  // }
623
623
  //
624
- const data = this.safeValue(response, 'data', []);
624
+ const data = this.safeList(response, 'data', []);
625
625
  return this.parseTickers(data, symbols);
626
626
  }
627
627
  async fetchTicker(symbol, params = {}) {
@@ -757,7 +757,7 @@ class probit extends probit$1 {
757
757
  // ]
758
758
  // }
759
759
  //
760
- const data = this.safeValue(response, 'data', []);
760
+ const data = this.safeList(response, 'data', []);
761
761
  return this.parseTrades(data, market, since, limit);
762
762
  }
763
763
  async fetchTrades(symbol, since = undefined, limit = undefined, params = {}) {
@@ -811,7 +811,7 @@ class probit extends probit$1 {
811
811
  // ]
812
812
  // }
813
813
  //
814
- const data = this.safeValue(response, 'data', []);
814
+ const data = this.safeList(response, 'data', []);
815
815
  return this.parseTrades(data, market, since, limit);
816
816
  }
817
817
  parseTrade(trade, market = undefined) {
@@ -999,7 +999,7 @@ class probit extends probit$1 {
999
999
  // ]
1000
1000
  // }
1001
1001
  //
1002
- const data = this.safeValue(response, 'data', []);
1002
+ const data = this.safeList(response, 'data', []);
1003
1003
  return this.parseOHLCVs(data, market, timeframe, since, limit);
1004
1004
  }
1005
1005
  parseOHLCV(ohlcv, market = undefined) {
@@ -1046,7 +1046,7 @@ class probit extends probit$1 {
1046
1046
  request['market_id'] = market['id'];
1047
1047
  }
1048
1048
  const response = await this.privateGetOpenOrder(this.extend(request, params));
1049
- const data = this.safeValue(response, 'data');
1049
+ const data = this.safeList(response, 'data');
1050
1050
  return this.parseOrders(data, market, since, limit);
1051
1051
  }
1052
1052
  async fetchClosedOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1079,7 +1079,7 @@ class probit extends probit$1 {
1079
1079
  request['limit'] = limit;
1080
1080
  }
1081
1081
  const response = await this.privateGetOrderHistory(this.extend(request, params));
1082
- const data = this.safeValue(response, 'data');
1082
+ const data = this.safeList(response, 'data');
1083
1083
  return this.parseOrders(data, market, since, limit);
1084
1084
  }
1085
1085
  async fetchOrder(id, symbol = undefined, params = {}) {
@@ -1110,7 +1110,7 @@ class probit extends probit$1 {
1110
1110
  const query = this.omit(params, ['clientOrderId', 'client_order_id']);
1111
1111
  const response = await this.privateGetOrder(this.extend(request, query));
1112
1112
  const data = this.safeValue(response, 'data', []);
1113
- const order = this.safeValue(data, 0);
1113
+ const order = this.safeDict(data, 0);
1114
1114
  return this.parseOrder(order, market);
1115
1115
  }
1116
1116
  parseOrderStatus(status) {
@@ -1309,7 +1309,7 @@ class probit extends probit$1 {
1309
1309
  'order_id': id,
1310
1310
  };
1311
1311
  const response = await this.privatePostCancelOrder(this.extend(request, params));
1312
- const data = this.safeValue(response, 'data');
1312
+ const data = this.safeDict(response, 'data');
1313
1313
  return this.parseOrder(data);
1314
1314
  }
1315
1315
  parseDepositAddress(depositAddress, currency = undefined) {
@@ -1403,7 +1403,7 @@ class probit extends probit$1 {
1403
1403
  request['currency_id'] = codes.join(',');
1404
1404
  }
1405
1405
  const response = await this.privateGetDepositAddress(this.extend(request, params));
1406
- const data = this.safeValue(response, 'data', []);
1406
+ const data = this.safeList(response, 'data', []);
1407
1407
  return this.parseDepositAddresses(data, codes);
1408
1408
  }
1409
1409
  async withdraw(code, amount, address, tag = undefined, params = {}) {
@@ -1450,7 +1450,7 @@ class probit extends probit$1 {
1450
1450
  params = this.omit(params, 'network');
1451
1451
  }
1452
1452
  const response = await this.privatePostWithdrawal(this.extend(request, params));
1453
- const data = this.safeValue(response, 'data');
1453
+ const data = this.safeDict(response, 'data');
1454
1454
  return this.parseTransaction(data, currency);
1455
1455
  }
1456
1456
  async fetchDeposits(code = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1700,7 +1700,7 @@ class probit extends probit$1 {
1700
1700
  // ]
1701
1701
  // }
1702
1702
  //
1703
- const data = this.safeValue(response, 'data');
1703
+ const data = this.safeList(response, 'data');
1704
1704
  return this.parseDepositWithdrawFees(data, codes, 'id');
1705
1705
  }
1706
1706
  parseDepositWithdrawFee(fee, currency = undefined) {
@@ -546,7 +546,7 @@ class timex extends timex$1 {
546
546
  // }
547
547
  // ]
548
548
  //
549
- const ticker = this.safeValue(response, 0);
549
+ const ticker = this.safeDict(response, 0);
550
550
  return this.parseTicker(ticker, market);
551
551
  }
552
552
  async fetchOrderBook(symbol, limit = undefined, params = {}) {
@@ -807,7 +807,7 @@ class timex extends timex$1 {
807
807
  // }
808
808
  //
809
809
  const orders = this.safeValue(response, 'orders', []);
810
- const order = this.safeValue(orders, 0, {});
810
+ const order = this.safeDict(orders, 0, {});
811
811
  return this.parseOrder(order, market);
812
812
  }
813
813
  async editOrder(id, symbol, type, side, amount = undefined, price = undefined, params = {}) {
@@ -858,7 +858,7 @@ class timex extends timex$1 {
858
858
  }
859
859
  const orders = this.safeValue(response, 'changedOrders', []);
860
860
  const firstOrder = this.safeValue(orders, 0, {});
861
- const order = this.safeValue(firstOrder, 'newOrder', {});
861
+ const order = this.safeDict(firstOrder, 'newOrder', {});
862
862
  return this.parseOrder(order, market);
863
863
  }
864
864
  async cancelOrder(id, symbol = undefined, params = {}) {
@@ -966,7 +966,7 @@ class timex extends timex$1 {
966
966
  // }
967
967
  //
968
968
  const order = this.safeValue(response, 'order', {});
969
- const trades = this.safeValue(response, 'trades', []);
969
+ const trades = this.safeList(response, 'trades', []);
970
970
  return this.parseOrder(this.extend(order, { 'trades': trades }));
971
971
  }
972
972
  async fetchOpenOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1021,7 +1021,7 @@ class timex extends timex$1 {
1021
1021
  // ]
1022
1022
  // }
1023
1023
  //
1024
- const orders = this.safeValue(response, 'orders', []);
1024
+ const orders = this.safeList(response, 'orders', []);
1025
1025
  return this.parseOrders(orders, market, since, limit);
1026
1026
  }
1027
1027
  async fetchClosedOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1081,7 +1081,7 @@ class timex extends timex$1 {
1081
1081
  // ]
1082
1082
  // }
1083
1083
  //
1084
- const orders = this.safeValue(response, 'orders', []);
1084
+ const orders = this.safeList(response, 'orders', []);
1085
1085
  return this.parseOrders(orders, market, since, limit);
1086
1086
  }
1087
1087
  async fetchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1144,7 +1144,7 @@ class timex extends timex$1 {
1144
1144
  // ]
1145
1145
  // }
1146
1146
  //
1147
- const trades = this.safeValue(response, 'trades', []);
1147
+ const trades = this.safeList(response, 'trades', []);
1148
1148
  return this.parseTrades(trades, market, since, limit);
1149
1149
  }
1150
1150
  parseTradingFee(fee, market = undefined) {
@@ -1217,7 +1217,7 @@ class tokocrypto extends tokocrypto$1 {
1217
1217
  };
1218
1218
  const response = await this.binanceGetTicker24hr(this.extend(request, params));
1219
1219
  if (Array.isArray(response)) {
1220
- const firstTicker = this.safeValue(response, 0, {});
1220
+ const firstTicker = this.safeDict(response, 0, {});
1221
1221
  return this.parseTicker(firstTicker, market);
1222
1222
  }
1223
1223
  return this.parseTicker(response, market);
@@ -1336,7 +1336,7 @@ class tokocrypto extends tokocrypto$1 {
1336
1336
  // [1591478640000,"0.02500800","0.02501100","0.02500300","0.02500800","154.14200000",1591478699999,"3.85405839",97,"5.32300000","0.13312641","0"],
1337
1337
  // ]
1338
1338
  //
1339
- const data = this.safeValue(response, 'data', response);
1339
+ const data = this.safeList(response, 'data', response);
1340
1340
  return this.parseOHLCVs(data, market, timeframe, since, limit);
1341
1341
  }
1342
1342
  async fetchBalance(params = {}) {
@@ -1777,7 +1777,7 @@ class tokocrypto extends tokocrypto$1 {
1777
1777
  // "timestamp": 1662710994975
1778
1778
  // }
1779
1779
  //
1780
- const rawOrder = this.safeValue(response, 'data', {});
1780
+ const rawOrder = this.safeDict(response, 'data', {});
1781
1781
  return this.parseOrder(rawOrder, market);
1782
1782
  }
1783
1783
  async fetchOrder(id, symbol = undefined, params = {}) {
@@ -1826,7 +1826,7 @@ class tokocrypto extends tokocrypto$1 {
1826
1826
  //
1827
1827
  const data = this.safeValue(response, 'data', {});
1828
1828
  const list = this.safeValue(data, 'list', []);
1829
- const rawOrder = this.safeValue(list, 0, {});
1829
+ const rawOrder = this.safeDict(list, 0, {});
1830
1830
  return this.parseOrder(rawOrder);
1831
1831
  }
1832
1832
  async fetchOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1897,7 +1897,7 @@ class tokocrypto extends tokocrypto$1 {
1897
1897
  // }
1898
1898
  //
1899
1899
  const data = this.safeValue(response, 'data', {});
1900
- const orders = this.safeValue(data, 'list', []);
1900
+ const orders = this.safeList(data, 'list', []);
1901
1901
  return this.parseOrders(orders, market, since, limit);
1902
1902
  }
1903
1903
  async fetchOpenOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1972,7 +1972,7 @@ class tokocrypto extends tokocrypto$1 {
1972
1972
  // "timestamp": 1662710683634
1973
1973
  // }
1974
1974
  //
1975
- const rawOrder = this.safeValue(response, 'data', {});
1975
+ const rawOrder = this.safeDict(response, 'data', {});
1976
1976
  return this.parseOrder(rawOrder);
1977
1977
  }
1978
1978
  async fetchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -2033,7 +2033,7 @@ class tokocrypto extends tokocrypto$1 {
2033
2033
  // }
2034
2034
  //
2035
2035
  const data = this.safeValue(response, 'data', {});
2036
- const trades = this.safeValue(data, 'list', []);
2036
+ const trades = this.safeList(data, 'list', []);
2037
2037
  return this.parseTrades(trades, market, since, limit);
2038
2038
  }
2039
2039
  async fetchDepositAddress(code, params = {}) {
@@ -2150,7 +2150,7 @@ class tokocrypto extends tokocrypto$1 {
2150
2150
  // }
2151
2151
  //
2152
2152
  const data = this.safeValue(response, 'data', {});
2153
- const deposits = this.safeValue(data, 'list', []);
2153
+ const deposits = this.safeList(data, 'list', []);
2154
2154
  return this.parseTransactions(deposits, currency, since, limit);
2155
2155
  }
2156
2156
  async fetchWithdrawals(code = undefined, since = undefined, limit = undefined, params = {}) {
@@ -2207,7 +2207,7 @@ class tokocrypto extends tokocrypto$1 {
2207
2207
  // }
2208
2208
  //
2209
2209
  const data = this.safeValue(response, 'data', {});
2210
- const withdrawals = this.safeValue(data, 'list', []);
2210
+ const withdrawals = this.safeList(data, 'list', []);
2211
2211
  return this.parseTransactions(withdrawals, currency, since, limit);
2212
2212
  }
2213
2213
  parseTransactionStatusByType(status, type = undefined) {
@@ -887,7 +887,7 @@ class wavesexchange extends wavesexchange$1 {
887
887
  //
888
888
  const data = this.safeValue(response, 'data', []);
889
889
  const ticker = this.safeValue(data, 0, {});
890
- const dataTicker = this.safeValue(ticker, 'data', {});
890
+ const dataTicker = this.safeDict(ticker, 'data', {});
891
891
  return this.parseTicker(dataTicker, market);
892
892
  }
893
893
  async fetchTickers(symbols = undefined, params = {}) {
@@ -1459,12 +1459,12 @@ class wavesexchange extends wavesexchange$1 {
1459
1459
  //
1460
1460
  if (isMarketOrder) {
1461
1461
  const response = await this.matcherPostMatcherOrderbookMarket(body);
1462
- const value = this.safeValue(response, 'message');
1462
+ const value = this.safeDict(response, 'message');
1463
1463
  return this.parseOrder(value, market);
1464
1464
  }
1465
1465
  else {
1466
1466
  const response = await this.matcherPostMatcherOrderbook(body);
1467
- const value = this.safeValue(response, 'message');
1467
+ const value = this.safeDict(response, 'message');
1468
1468
  return this.parseOrder(value, market);
1469
1469
  }
1470
1470
  }
@@ -738,7 +738,7 @@ class whitebit extends whitebit$1 {
738
738
  // },
739
739
  // }
740
740
  //
741
- const ticker = this.safeValue(response, 'result', {});
741
+ const ticker = this.safeDict(response, 'result', {});
742
742
  return this.parseTicker(ticker, market);
743
743
  }
744
744
  parseTicker(ticker, market = undefined) {
@@ -1100,7 +1100,7 @@ class whitebit extends whitebit$1 {
1100
1100
  // ]
1101
1101
  // }
1102
1102
  //
1103
- const result = this.safeValue(response, 'result', []);
1103
+ const result = this.safeList(response, 'result', []);
1104
1104
  return this.parseOHLCVs(result, market, timeframe, since, limit);
1105
1105
  }
1106
1106
  parseOHLCV(ohlcv, market = undefined) {
@@ -1606,7 +1606,7 @@ class whitebit extends whitebit$1 {
1606
1606
  // "limit": 100
1607
1607
  // }
1608
1608
  //
1609
- const data = this.safeValue(response, 'records', []);
1609
+ const data = this.safeList(response, 'records', []);
1610
1610
  return this.parseTrades(data, market);
1611
1611
  }
1612
1612
  async fetchDepositAddress(code, params = {}) {
@@ -1947,7 +1947,7 @@ class whitebit extends whitebit$1 {
1947
1947
  // }
1948
1948
  //
1949
1949
  const records = this.safeValue(response, 'records', []);
1950
- const first = this.safeValue(records, 0, {});
1950
+ const first = this.safeDict(records, 0, {});
1951
1951
  return this.parseTransaction(first, currency);
1952
1952
  }
1953
1953
  async fetchDeposits(code = undefined, since = undefined, limit = undefined, params = {}) {
@@ -2014,7 +2014,7 @@ class whitebit extends whitebit$1 {
2014
2014
  // "total": 300 // total number of transactions, use this for calculating ‘limit’ and ‘offset'
2015
2015
  // }
2016
2016
  //
2017
- const records = this.safeValue(response, 'records', []);
2017
+ const records = this.safeList(response, 'records', []);
2018
2018
  return this.parseTransactions(records, currency, since, limit);
2019
2019
  }
2020
2020
  async fetchBorrowInterest(code = undefined, symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1349,7 +1349,7 @@ class woo extends woo$1 {
1349
1349
  // ]
1350
1350
  // }
1351
1351
  //
1352
- const orders = this.safeValue(response, 'data', response);
1352
+ const orders = this.safeDict(response, 'data', response);
1353
1353
  return this.parseOrder(orders, market);
1354
1354
  }
1355
1355
  async fetchOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -625,7 +625,7 @@ class zaif extends zaif$1 {
625
625
  // }
626
626
  // }
627
627
  //
628
- const returnData = this.safeValue(result, 'return');
628
+ const returnData = this.safeDict(result, 'return');
629
629
  return this.parseTransaction(returnData, currency);
630
630
  }
631
631
  parseTransaction(transaction, currency = undefined) {
@@ -412,7 +412,7 @@ class zonda extends zonda$1 {
412
412
  await this.loadMarkets();
413
413
  const request = {};
414
414
  const response = await this.v1_01PrivateGetTradingOffer(this.extend(request, params));
415
- const items = this.safeValue(response, 'items', []);
415
+ const items = this.safeList(response, 'items', []);
416
416
  return this.parseOrders(items, undefined, since, limit, { 'status': 'open' });
417
417
  }
418
418
  parseOrder(order, market = undefined) {
@@ -799,7 +799,7 @@ class zonda extends zonda$1 {
799
799
  else {
800
800
  throw new errors.BadRequest(this.id + ' fetchTickers params["method"] must be "v1_01PublicGetTradingTicker" or "v1_01PublicGetTradingStats"');
801
801
  }
802
- const items = this.safeValue(response, 'items');
802
+ const items = this.safeDict(response, 'items');
803
803
  return this.parseTickers(items, symbols);
804
804
  }
805
805
  async fetchLedger(code = undefined, since = undefined, limit = undefined, params = {}) {
@@ -1222,7 +1222,7 @@ class zonda extends zonda$1 {
1222
1222
  // ]
1223
1223
  // }
1224
1224
  //
1225
- const items = this.safeValue(response, 'items', []);
1225
+ const items = this.safeList(response, 'items', []);
1226
1226
  return this.parseOHLCVs(items, market, timeframe, since, limit);
1227
1227
  }
1228
1228
  parseTrade(trade, market = undefined) {
@@ -1327,7 +1327,7 @@ class zonda extends zonda$1 {
1327
1327
  request['limit'] = limit; // default - 10, max - 300
1328
1328
  }
1329
1329
  const response = await this.v1_01PublicGetTradingTransactionsSymbol(this.extend(request, params));
1330
- const items = this.safeValue(response, 'items');
1330
+ const items = this.safeList(response, 'items');
1331
1331
  return this.parseTrades(items, market, since, limit);
1332
1332
  }
1333
1333
  async createOrder(symbol, type, side, amount, price = undefined, params = {}) {
@@ -1552,7 +1552,7 @@ class zonda extends zonda$1 {
1552
1552
  // }
1553
1553
  //
1554
1554
  const data = this.safeValue(response, 'data');
1555
- const first = this.safeValue(data, 0);
1555
+ const first = this.safeDict(data, 0);
1556
1556
  return this.parseDepositAddress(first, currency);
1557
1557
  }
1558
1558
  async fetchDepositAddresses(codes = undefined, params = {}) {
@@ -1580,7 +1580,7 @@ class zonda extends zonda$1 {
1580
1580
  // ]
1581
1581
  // }
1582
1582
  //
1583
- const data = this.safeValue(response, 'data');
1583
+ const data = this.safeList(response, 'data');
1584
1584
  return this.parseDepositAddresses(data, codes);
1585
1585
  }
1586
1586
  async transfer(code, amount, fromAccount, toAccount, params = {}) {
@@ -1737,7 +1737,7 @@ class zonda extends zonda$1 {
1737
1737
  // }
1738
1738
  // }
1739
1739
  //
1740
- const data = this.safeValue(response, 'data');
1740
+ const data = this.safeDict(response, 'data');
1741
1741
  return this.parseTransaction(data, currency);
1742
1742
  }
1743
1743
  parseTransaction(transaction, currency = undefined) {
@@ -321,7 +321,6 @@ async function run () {
321
321
  headers,
322
322
  body,
323
323
  })
324
- process.exit ()
325
324
  }
326
325
  }
327
326
 
@@ -313,7 +313,6 @@ async function run () {
313
313
  headers,
314
314
  body,
315
315
  })
316
- process.exit ()
317
316
  }
318
317
  }
319
318
 
package/js/ccxt.d.ts CHANGED
@@ -4,7 +4,7 @@ import * as functions from './src/base/functions.js';
4
4
  import * as errors from './src/base/errors.js';
5
5
  import type { Market, Trade, Fee, Ticker, OrderBook, Order, Transaction, Tickers, Currency, Balance, DepositAddress, WithdrawalResponse, DepositAddressResponse, OHLCV, Balances, PartialBalances, Dictionary, MinMax, Position, FundingRateHistory, Liquidation, FundingHistory, MarginMode, Greeks, Leverage, Leverages, Option, OptionChain } from './src/base/types.js';
6
6
  import { BaseError, ExchangeError, PermissionDenied, AccountNotEnabled, AccountSuspended, ArgumentsRequired, BadRequest, BadSymbol, MarginModeAlreadySet, BadResponse, NullResponse, InsufficientFunds, InvalidAddress, InvalidOrder, OrderNotFound, OrderNotCached, CancelPending, OrderImmediatelyFillable, OrderNotFillable, DuplicateOrderId, NotSupported, NetworkError, DDoSProtection, RateLimitExceeded, ExchangeNotAvailable, OnMaintenance, InvalidNonce, RequestTimeout, AuthenticationError, AddressPending, NoChange } from './src/base/errors.js';
7
- declare const version = "4.2.83";
7
+ declare const version = "4.2.84";
8
8
  import ace from './src/ace.js';
9
9
  import alpaca from './src/alpaca.js';
10
10
  import ascendex from './src/ascendex.js';
package/js/ccxt.js CHANGED
@@ -38,7 +38,7 @@ import * as errors from './src/base/errors.js';
38
38
  import { BaseError, ExchangeError, PermissionDenied, AccountNotEnabled, AccountSuspended, ArgumentsRequired, BadRequest, BadSymbol, MarginModeAlreadySet, BadResponse, NullResponse, InsufficientFunds, InvalidAddress, InvalidOrder, OrderNotFound, OrderNotCached, CancelPending, OrderImmediatelyFillable, OrderNotFillable, DuplicateOrderId, NotSupported, NetworkError, DDoSProtection, RateLimitExceeded, ExchangeNotAvailable, OnMaintenance, InvalidNonce, RequestTimeout, AuthenticationError, AddressPending, NoChange } from './src/base/errors.js';
39
39
  //-----------------------------------------------------------------------------
40
40
  // this is updated by vss.js when building
41
- const version = '4.2.84';
41
+ const version = '4.2.85';
42
42
  Exchange.ccxtVersion = version;
43
43
  //-----------------------------------------------------------------------------
44
44
  import ace from './src/ace.js';
package/js/src/ace.js CHANGED
@@ -401,7 +401,7 @@ export default class ace extends Exchange {
401
401
  // "status": 200
402
402
  // }
403
403
  //
404
- const orderBook = this.safeValue(response, 'attachment');
404
+ const orderBook = this.safeDict(response, 'attachment');
405
405
  return this.parseOrderBook(orderBook, market['symbol'], undefined, 'bids', 'asks');
406
406
  }
407
407
  parseOHLCV(ohlcv, market = undefined) {
@@ -623,7 +623,7 @@ export default class ace extends Exchange {
623
623
  // "status": 200
624
624
  // }
625
625
  //
626
- const data = this.safeValue(response, 'attachment');
626
+ const data = this.safeDict(response, 'attachment');
627
627
  return this.parseOrder(data, market);
628
628
  }
629
629
  async cancelOrder(id, symbol = undefined, params = {}) {
@@ -689,7 +689,7 @@ export default class ace extends Exchange {
689
689
  // "status": 200
690
690
  // }
691
691
  //
692
- const data = this.safeValue(response, 'attachment');
692
+ const data = this.safeDict(response, 'attachment');
693
693
  return this.parseOrder(data, undefined);
694
694
  }
695
695
  async fetchOpenOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -882,7 +882,7 @@ export default class ace extends Exchange {
882
882
  // }
883
883
  //
884
884
  const data = this.safeValue(response, 'attachment');
885
- const trades = this.safeValue(data, 'trades', []);
885
+ const trades = this.safeList(data, 'trades', []);
886
886
  return this.parseTrades(trades, market, since, limit);
887
887
  }
888
888
  async fetchMyTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -941,7 +941,7 @@ export default class ace extends Exchange {
941
941
  // "status": 200
942
942
  // }
943
943
  //
944
- const trades = this.safeValue(response, 'attachment', []);
944
+ const trades = this.safeList(response, 'attachment', []);
945
945
  return this.parseTrades(trades, market, since, limit);
946
946
  }
947
947
  parseBalance(response) {
@@ -1034,7 +1034,7 @@ export default class ascendex extends Exchange {
1034
1034
  // }
1035
1035
  // }
1036
1036
  //
1037
- const data = this.safeValue(response, 'data', {});
1037
+ const data = this.safeDict(response, 'data', {});
1038
1038
  return this.parseTicker(data, market);
1039
1039
  }
1040
1040
  async fetchTickers(symbols = undefined, params = {}) {
@@ -1173,7 +1173,7 @@ export default class ascendex extends Exchange {
1173
1173
  // ]
1174
1174
  // }
1175
1175
  //
1176
- const data = this.safeValue(response, 'data', []);
1176
+ const data = this.safeList(response, 'data', []);
1177
1177
  return this.parseOHLCVs(data, market, timeframe, since, limit);
1178
1178
  }
1179
1179
  parseTrade(trade, market = undefined) {
@@ -1246,7 +1246,7 @@ export default class ascendex extends Exchange {
1246
1246
  // }
1247
1247
  //
1248
1248
  const records = this.safeValue(response, 'data', []);
1249
- const trades = this.safeValue(records, 'data', []);
1249
+ const trades = this.safeList(records, 'data', []);
1250
1250
  return this.parseTrades(trades, market, since, limit);
1251
1251
  }
1252
1252
  parseOrderStatus(status) {
@@ -1774,7 +1774,7 @@ export default class ascendex extends Exchange {
1774
1774
  // }
1775
1775
  //
1776
1776
  const data = this.safeValue(response, 'data', {});
1777
- const info = this.safeValue(data, 'info', []);
1777
+ const info = this.safeList(data, 'info', []);
1778
1778
  return this.parseOrders(info, market);
1779
1779
  }
1780
1780
  async fetchOrder(id, symbol = undefined, params = {}) {
@@ -1882,7 +1882,7 @@ export default class ascendex extends Exchange {
1882
1882
  // }
1883
1883
  // }
1884
1884
  //
1885
- const data = this.safeValue(response, 'data', {});
1885
+ const data = this.safeDict(response, 'data', {});
1886
1886
  return this.parseOrder(data, market);
1887
1887
  }
1888
1888
  async fetchOpenOrders(symbol = undefined, since = undefined, limit = undefined, params = {}) {
@@ -2572,7 +2572,7 @@ export default class ascendex extends Exchange {
2572
2572
  // }
2573
2573
  //
2574
2574
  const data = this.safeValue(response, 'data', {});
2575
- const transactions = this.safeValue(data, 'data', []);
2575
+ const transactions = this.safeList(data, 'data', []);
2576
2576
  return this.parseTransactions(transactions, currency, since, limit);
2577
2577
  }
2578
2578
  parseTransactionStatus(status) {
@@ -3131,7 +3131,7 @@ export default class ascendex extends Exchange {
3131
3131
  */
3132
3132
  await this.loadMarkets();
3133
3133
  const response = await this.v2PublicGetAssets(params);
3134
- const data = this.safeValue(response, 'data');
3134
+ const data = this.safeList(response, 'data');
3135
3135
  return this.parseDepositWithdrawFees(data, codes, 'assetCode');
3136
3136
  }
3137
3137
  async transfer(code, amount, fromAccount, toAccount, params = {}) {
@@ -3257,7 +3257,7 @@ export default class ascendex extends Exchange {
3257
3257
  // }
3258
3258
  //
3259
3259
  const data = this.safeValue(response, 'data', {});
3260
- const rows = this.safeValue(data, 'data', []);
3260
+ const rows = this.safeList(data, 'data', []);
3261
3261
  return this.parseIncomes(rows, market, since, limit);
3262
3262
  }
3263
3263
  parseIncome(income, market = undefined) {
@@ -844,8 +844,6 @@ export default class Exchange {
844
844
  fetchUsedBalance(params?: {}): Promise<Balance>;
845
845
  fetchTotalBalance(params?: {}): Promise<Balance>;
846
846
  fetchStatus(params?: {}): Promise<any>;
847
- fetchFundingFee(code: string, params?: {}): Promise<{}>;
848
- fetchFundingFees(codes?: string[], params?: {}): Promise<{}>;
849
847
  fetchTransactionFee(code: string, params?: {}): Promise<{}>;
850
848
  fetchTransactionFees(codes?: string[], params?: {}): Promise<{}>;
851
849
  fetchDepositWithdrawFees(codes?: string[], params?: {}): Promise<Dictionary<DepositWithdrawFeeNetwork>>;
@@ -868,7 +866,7 @@ export default class Exchange {
868
866
  watchTicker(symbol: string, params?: {}): Promise<Ticker>;
869
867
  fetchTickers(symbols?: string[], params?: {}): Promise<Tickers>;
870
868
  fetchOrderBooks(symbols?: string[], limit?: Int, params?: {}): Promise<Dictionary<OrderBook>>;
871
- watchBidsAsks(symbols?: string[], params?: {}): Promise<Tickers>;
869
+ watchBidsAsks(symbols?: Strings, params?: {}): Promise<Tickers>;
872
870
  watchTickers(symbols?: string[], params?: {}): Promise<Tickers>;
873
871
  fetchOrder(id: string, symbol?: Str, params?: {}): Promise<Order>;
874
872
  fetchOrderWs(id: string, symbol?: Str, params?: {}): Promise<Order>;
@@ -1013,5 +1011,8 @@ export default class Exchange {
1013
1011
  parseMarginMode(marginMode: any, market?: Market): MarginMode;
1014
1012
  parseLeverages(response: object[], symbols?: string[], symbolKey?: Str, marketType?: MarketType): Leverages;
1015
1013
  parseLeverage(leverage: any, market?: Market): Leverage;
1014
+ convertExpireDate(date: string): string;
1015
+ convertExpireDateToMarketIdDate(date: string): string;
1016
+ convertMarketIdExpireDate(date: string): string;
1016
1017
  }
1017
1018
  export { Exchange, };