ccxt 4.2.12 → 4.2.14

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 (81) hide show
  1. package/README.md +3 -3
  2. package/dist/ccxt.browser.js +1338 -366
  3. package/dist/ccxt.browser.min.js +7 -7
  4. package/dist/cjs/ccxt.js +1 -1
  5. package/dist/cjs/js/ccxt.js +1 -1
  6. package/dist/cjs/js/src/base/Exchange.js +148 -1
  7. package/dist/cjs/js/src/bigone.js +125 -54
  8. package/dist/cjs/js/src/binance.js +142 -27
  9. package/dist/cjs/js/src/binanceus.js +8 -0
  10. package/dist/cjs/js/src/bingx.js +110 -36
  11. package/dist/cjs/js/src/bitget.js +17 -6
  12. package/dist/cjs/js/src/bitmart.js +3 -3
  13. package/dist/cjs/js/src/bybit.js +5 -1
  14. package/dist/cjs/js/src/coinbase.js +176 -26
  15. package/dist/cjs/js/src/coinex.js +3 -0
  16. package/dist/cjs/js/src/coinlist.js +1 -1
  17. package/dist/cjs/js/src/coinone.js +1 -1
  18. package/dist/cjs/js/src/delta.js +7 -1
  19. package/dist/cjs/js/src/deribit.js +1 -1
  20. package/dist/cjs/js/src/gate.js +79 -56
  21. package/dist/cjs/js/src/gemini.js +1 -1
  22. package/dist/cjs/js/src/htx.js +151 -1
  23. package/dist/cjs/js/src/independentreserve.js +7 -5
  24. package/dist/cjs/js/src/kraken.js +22 -14
  25. package/dist/cjs/js/src/kucoin.js +5 -0
  26. package/dist/cjs/js/src/kucoinfutures.js +131 -77
  27. package/dist/cjs/js/src/lbank.js +59 -33
  28. package/dist/cjs/js/src/oceanex.js +1 -1
  29. package/dist/cjs/js/src/okx.js +11 -9
  30. package/dist/cjs/js/src/phemex.js +9 -2
  31. package/dist/cjs/js/src/pro/kraken.js +1 -1
  32. package/dist/cjs/js/src/pro/okx.js +52 -2
  33. package/dist/cjs/js/src/probit.js +4 -2
  34. package/dist/cjs/js/src/wavesexchange.js +1 -1
  35. package/dist/cjs/js/src/woo.js +56 -2
  36. package/js/ccxt.d.ts +1 -1
  37. package/js/ccxt.js +1 -1
  38. package/js/src/abstract/bigone.d.ts +1 -0
  39. package/js/src/abstract/bingx.d.ts +2 -0
  40. package/js/src/abstract/kucoin.d.ts +4 -0
  41. package/js/src/abstract/kucoinfutures.d.ts +4 -0
  42. package/js/src/abstract/okx.d.ts +1 -0
  43. package/js/src/base/Exchange.d.ts +8 -0
  44. package/js/src/base/Exchange.js +148 -1
  45. package/js/src/bigone.d.ts +2 -0
  46. package/js/src/bigone.js +125 -54
  47. package/js/src/binance.d.ts +9 -0
  48. package/js/src/binance.js +142 -27
  49. package/js/src/binanceus.js +8 -0
  50. package/js/src/bingx.js +110 -36
  51. package/js/src/bitget.js +17 -6
  52. package/js/src/bitmart.js +3 -3
  53. package/js/src/bybit.js +5 -1
  54. package/js/src/coinbase.d.ts +26 -3
  55. package/js/src/coinbase.js +176 -26
  56. package/js/src/coinex.js +3 -0
  57. package/js/src/coinlist.js +1 -1
  58. package/js/src/coinone.js +1 -1
  59. package/js/src/delta.js +7 -1
  60. package/js/src/deribit.js +1 -1
  61. package/js/src/gate.js +79 -56
  62. package/js/src/gemini.js +1 -1
  63. package/js/src/htx.d.ts +10 -0
  64. package/js/src/htx.js +151 -1
  65. package/js/src/independentreserve.js +7 -5
  66. package/js/src/kraken.js +22 -14
  67. package/js/src/kucoin.js +5 -0
  68. package/js/src/kucoinfutures.d.ts +4 -2
  69. package/js/src/kucoinfutures.js +131 -77
  70. package/js/src/lbank.js +59 -33
  71. package/js/src/oceanex.js +1 -1
  72. package/js/src/okx.js +11 -9
  73. package/js/src/phemex.js +9 -2
  74. package/js/src/pro/kraken.js +1 -1
  75. package/js/src/pro/okx.d.ts +1 -0
  76. package/js/src/pro/okx.js +52 -2
  77. package/js/src/probit.js +4 -2
  78. package/js/src/wavesexchange.js +1 -1
  79. package/js/src/woo.d.ts +2 -0
  80. package/js/src/woo.js +56 -2
  81. package/package.json +1 -1
package/js/src/htx.js CHANGED
@@ -44,13 +44,16 @@ export default class htx extends Exchange {
44
44
  'createMarketBuyOrderWithCost': true,
45
45
  'createMarketOrderWithCost': false,
46
46
  'createMarketSellOrderWithCost': false,
47
- 'createTrailingPercentOrder': true,
48
47
  'createOrder': true,
49
48
  'createOrders': true,
50
49
  'createReduceOnlyOrder': false,
51
50
  'createStopLimitOrder': true,
52
51
  'createStopMarketOrder': true,
53
52
  'createStopOrder': true,
53
+ 'createTrailingPercentOrder': true,
54
+ 'createTriggerOrder': true,
55
+ 'createTakeProfitOrder': true,
56
+ 'createStopLossOrder': true,
54
57
  'fetchAccounts': true,
55
58
  'fetchBalance': true,
56
59
  'fetchBidsAsks': undefined,
@@ -78,6 +81,7 @@ export default class htx extends Exchange {
78
81
  'fetchIsolatedBorrowRate': false,
79
82
  'fetchIsolatedBorrowRates': true,
80
83
  'fetchL3OrderBook': undefined,
84
+ 'fetchLastPrices': true,
81
85
  'fetchLedger': true,
82
86
  'fetchLedgerEntry': undefined,
83
87
  'fetchLeverage': false,
@@ -2270,6 +2274,127 @@ export default class htx extends Exchange {
2270
2274
  }
2271
2275
  return this.filterByArrayTickers(result, 'symbol', symbols);
2272
2276
  }
2277
+ async fetchLastPrices(symbols = undefined, params = {}) {
2278
+ /**
2279
+ * @method
2280
+ * @name binance#fetchLastPrices
2281
+ * @description fetches the last price for multiple markets
2282
+ * @see https://www.htx.com/en-us/opend/newApiPages/?id=8cb81024-77b5-11ed-9966-0242ac110003 linear swap & linear future
2283
+ * @see https://www.htx.com/en-us/opend/newApiPages/?id=28c2e8fc-77ae-11ed-9966-0242ac110003 inverse future
2284
+ * @see https://www.htx.com/en-us/opend/newApiPages/?id=5d517ef5-77b6-11ed-9966-0242ac110003 inverse swap
2285
+ * @param {string[]|undefined} symbols unified symbols of the markets to fetch the last prices
2286
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
2287
+ * @returns {object} a dictionary of lastprices structures
2288
+ */
2289
+ await this.loadMarkets();
2290
+ symbols = this.marketSymbols(symbols);
2291
+ const market = this.getMarketFromSymbols(symbols);
2292
+ let type = undefined;
2293
+ let subType = undefined;
2294
+ [subType, params] = this.handleSubTypeAndParams('fetchLastPrices', market, params);
2295
+ [type, params] = this.handleMarketTypeAndParams('fetchLastPrices', market, params);
2296
+ let response = undefined;
2297
+ if (((type === 'swap') || (type === 'future')) && (subType === 'linear')) {
2298
+ response = await this.contractPublicGetLinearSwapExMarketTrade(params);
2299
+ //
2300
+ // {
2301
+ // "ch": "market.*.trade.detail",
2302
+ // "status": "ok",
2303
+ // "tick": {
2304
+ // "data": [
2305
+ // {
2306
+ // "amount": "4",
2307
+ // "quantity": "40",
2308
+ // "trade_turnover": "22.176",
2309
+ // "ts": 1703697705028,
2310
+ // "id": 1000003558478170000,
2311
+ // "price": "0.5544",
2312
+ // "direction": "buy",
2313
+ // "contract_code": "MANA-USDT",
2314
+ // "business_type": "swap",
2315
+ // "trade_partition": "USDT"
2316
+ // },
2317
+ // ],
2318
+ // "id": 1703697740147,
2319
+ // "ts": 1703697740147
2320
+ // },
2321
+ // "ts": 1703697740147
2322
+ // }
2323
+ //
2324
+ }
2325
+ else if ((type === 'swap') && (subType === 'inverse')) {
2326
+ response = await this.contractPublicGetSwapExMarketTrade(params);
2327
+ //
2328
+ // {
2329
+ // "ch": "market.*.trade.detail",
2330
+ // "status": "ok",
2331
+ // "tick": {
2332
+ // "data": [
2333
+ // {
2334
+ // "amount": "6",
2335
+ // "quantity": "94.5000945000945000945000945000945000945",
2336
+ // "ts": 1703698704594,
2337
+ // "id": 1000001187811060000,
2338
+ // "price": "0.63492",
2339
+ // "direction": "buy",
2340
+ // "contract_code": "XRP-USD"
2341
+ // },
2342
+ // ],
2343
+ // "id": 1703698706589,
2344
+ // "ts": 1703698706589
2345
+ // },
2346
+ // "ts": 1703698706589
2347
+ // }
2348
+ //
2349
+ }
2350
+ else if ((type === 'future') && (subType === 'inverse')) {
2351
+ response = await this.contractPublicGetMarketTrade(params);
2352
+ //
2353
+ // {
2354
+ // "ch": "market.*.trade.detail",
2355
+ // "status": "ok",
2356
+ // "tick": {
2357
+ // "data": [
2358
+ // {
2359
+ // "amount": "20",
2360
+ // "quantity": "44.4444444444444444444444444444444444444",
2361
+ // "ts": 1686134498885,
2362
+ // "id": 2323000000174820000,
2363
+ // "price": "4.5",
2364
+ // "direction": "sell",
2365
+ // "symbol": "DORA_CW"
2366
+ // },
2367
+ // ],
2368
+ // "id": 1703698855142,
2369
+ // "ts": 1703698855142
2370
+ // },
2371
+ // "ts": 1703698855142
2372
+ // }
2373
+ //
2374
+ }
2375
+ else {
2376
+ throw new NotSupported(this.id + ' fetchLastPrices() does not support ' + type + ' markets yet');
2377
+ }
2378
+ const tick = this.safeValue(response, 'tick', {});
2379
+ const data = this.safeValue(tick, 'data', []);
2380
+ return this.parseLastPrices(data, symbols);
2381
+ }
2382
+ parseLastPrice(entry, market = undefined) {
2383
+ // example responses are documented in fetchLastPrices
2384
+ const marketId = this.safeString2(entry, 'symbol', 'contract_code');
2385
+ market = this.safeMarket(marketId, market);
2386
+ const price = this.safeNumber(entry, 'price');
2387
+ const direction = this.safeString(entry, 'direction'); // "buy" or "sell"
2388
+ // group timestamp should not be assigned to the individual trades' times
2389
+ return {
2390
+ 'symbol': market['symbol'],
2391
+ 'timestamp': undefined,
2392
+ 'datetime': undefined,
2393
+ 'price': price,
2394
+ 'side': direction,
2395
+ 'info': entry,
2396
+ };
2397
+ }
2273
2398
  async fetchOrderBook(symbol, limit = undefined, params = {}) {
2274
2399
  /**
2275
2400
  * @method
@@ -4972,6 +5097,31 @@ export default class htx extends Exchange {
4972
5097
  params['createMarketBuyOrderRequiresPrice'] = false;
4973
5098
  return await this.createOrder(symbol, 'market', 'buy', cost, undefined, params);
4974
5099
  }
5100
+ async createTrailingPercentOrder(symbol, type, side, amount, price = undefined, trailingPercent = undefined, trailingTriggerPrice = undefined, params = {}) {
5101
+ /**
5102
+ * @method
5103
+ * @name htx#createTrailingPercentOrder
5104
+ * @description create a trailing order by providing the symbol, type, side, amount, price and trailingPercent
5105
+ * @param {string} symbol unified symbol of the market to create an order in
5106
+ * @param {string} type 'market' or 'limit'
5107
+ * @param {string} side 'buy' or 'sell'
5108
+ * @param {float} amount how much you want to trade in units of the base currency, or number of contracts
5109
+ * @param {float} [price] the price for the order to be filled at, in units of the quote currency, ignored in market orders
5110
+ * @param {float} trailingPercent the percent to trail away from the current market price
5111
+ * @param {float} trailingTriggerPrice the price to activate a trailing order, default uses the price argument
5112
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
5113
+ * @returns {object} an [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
5114
+ */
5115
+ if (trailingPercent === undefined) {
5116
+ throw new ArgumentsRequired(this.id + ' createTrailingPercentOrder() requires a trailingPercent argument');
5117
+ }
5118
+ if (trailingTriggerPrice === undefined) {
5119
+ throw new ArgumentsRequired(this.id + ' createTrailingPercentOrder() requires a trailingTriggerPrice argument');
5120
+ }
5121
+ params['trailingPercent'] = trailingPercent;
5122
+ params['trailingTriggerPrice'] = trailingTriggerPrice;
5123
+ return await this.createOrder(symbol, type, side, amount, price, params);
5124
+ }
4975
5125
  async createSpotOrderRequest(symbol, type, side, amount, price = undefined, params = {}) {
4976
5126
  /**
4977
5127
  * @method
@@ -686,20 +686,22 @@ export default class independentreserve extends Exchange {
686
686
  */
687
687
  await this.loadMarkets();
688
688
  const market = this.market(symbol);
689
- const capitalizedOrderType = this.capitalize(type);
690
- const method = 'privatePostPlace' + capitalizedOrderType + 'Order';
691
- let orderType = capitalizedOrderType;
689
+ let orderType = this.capitalize(type);
692
690
  orderType += (side === 'sell') ? 'Offer' : 'Bid';
693
691
  const request = this.ordered({
694
692
  'primaryCurrencyCode': market['baseId'],
695
693
  'secondaryCurrencyCode': market['quoteId'],
696
694
  'orderType': orderType,
697
695
  });
696
+ let response = undefined;
697
+ request['volume'] = amount;
698
698
  if (type === 'limit') {
699
699
  request['price'] = price;
700
+ response = await this.privatePostPlaceLimitOrder(this.extend(request, params));
701
+ }
702
+ else {
703
+ response = await this.privatePostPlaceMarketOrder(this.extend(request, params));
700
704
  }
701
- request['volume'] = amount;
702
- const response = await this[method](this.extend(request, params));
703
705
  return this.safeOrder({
704
706
  'info': response,
705
707
  'id': response['OrderGuid'],
package/js/src/kraken.js CHANGED
@@ -41,8 +41,8 @@ export default class kraken extends Exchange {
41
41
  'createOrder': true,
42
42
  'createStopLimitOrder': true,
43
43
  'createStopMarketOrder': true,
44
- 'createTrailingAmountOrder': true,
45
44
  'createStopOrder': true,
45
+ 'createTrailingAmountOrder': true,
46
46
  'editOrder': true,
47
47
  'fetchBalance': true,
48
48
  'fetchBorrowInterest': false,
@@ -1267,12 +1267,8 @@ export default class kraken extends Exchange {
1267
1267
  request['since'] = since * 1e6;
1268
1268
  request['since'] = since.toString() + '000000'; // expected to be in nanoseconds
1269
1269
  }
1270
- // https://github.com/ccxt/ccxt/issues/5698
1271
- if (limit !== undefined && limit !== 1000) {
1272
- const fetchTradesWarning = this.safeValue(this.options, 'fetchTradesWarning', true);
1273
- if (fetchTradesWarning) {
1274
- throw new ExchangeError(this.id + ' fetchTrades() cannot serve ' + limit.toString() + " trades without breaking the pagination, see https://github.com/ccxt/ccxt/issues/5698 for more details. Set exchange.options['fetchTradesWarning'] to acknowledge this warning and silence it.");
1275
- }
1270
+ if (limit !== undefined) {
1271
+ request['count'] = limit;
1276
1272
  }
1277
1273
  const response = await this.publicGetTrades(this.extend(request, params));
1278
1274
  //
@@ -1627,27 +1623,39 @@ export default class kraken extends Exchange {
1627
1623
  const trailingAmount = this.safeString(params, 'trailingAmount');
1628
1624
  const trailingLimitAmount = this.safeString(params, 'trailingLimitAmount');
1629
1625
  const isTrailingAmountOrder = trailingAmount !== undefined;
1630
- if ((type === 'limit') && !isTrailingAmountOrder) {
1626
+ const isLimitOrder = type.endsWith('limit'); // supporting limit, stop-loss-limit, take-profit-limit, etc
1627
+ if (isLimitOrder && !isTrailingAmountOrder) {
1631
1628
  request['price'] = this.priceToPrecision(symbol, price);
1632
1629
  }
1633
- let reduceOnly = this.safeValue2(params, 'reduceOnly', 'reduce_only');
1630
+ const reduceOnly = this.safeValue2(params, 'reduceOnly', 'reduce_only');
1634
1631
  if (isStopLossOrTakeProfitTrigger) {
1635
1632
  if (isStopLossTriggerOrder) {
1636
1633
  request['price'] = this.priceToPrecision(symbol, stopLossTriggerPrice);
1637
- request['ordertype'] = 'stop-loss-limit';
1634
+ if (isLimitOrder) {
1635
+ request['ordertype'] = 'stop-loss-limit';
1636
+ }
1637
+ else {
1638
+ request['ordertype'] = 'stop-loss';
1639
+ }
1638
1640
  }
1639
1641
  else if (isTakeProfitTriggerOrder) {
1640
1642
  request['price'] = this.priceToPrecision(symbol, takeProfitTriggerPrice);
1641
- request['ordertype'] = 'take-profit-limit';
1643
+ if (isLimitOrder) {
1644
+ request['ordertype'] = 'take-profit-limit';
1645
+ }
1646
+ else {
1647
+ request['ordertype'] = 'take-profit';
1648
+ }
1649
+ }
1650
+ if (isLimitOrder) {
1651
+ request['price2'] = this.priceToPrecision(symbol, price);
1642
1652
  }
1643
- request['price2'] = this.priceToPrecision(symbol, price);
1644
- reduceOnly = true;
1645
1653
  }
1646
1654
  else if (isTrailingAmountOrder) {
1647
1655
  const trailingActivationPriceType = this.safeString(params, 'trigger', 'last');
1648
1656
  const trailingAmountString = '+' + trailingAmount;
1649
1657
  request['trigger'] = trailingActivationPriceType;
1650
- if ((type === 'limit') || (trailingLimitAmount !== undefined)) {
1658
+ if (isLimitOrder || (trailingLimitAmount !== undefined)) {
1651
1659
  const offset = this.safeString(params, 'offset', '-');
1652
1660
  const trailingLimitAmountString = offset + this.numberToString(trailingLimitAmount);
1653
1661
  request['price'] = trailingAmountString;
package/js/src/kucoin.js CHANGED
@@ -49,6 +49,7 @@ export default class kucoin extends Exchange {
49
49
  'createPostOnlyOrder': true,
50
50
  'createStopLimitOrder': true,
51
51
  'createStopMarketOrder': true,
52
+ 'createTriggerOrder': true,
52
53
  'createStopOrder': true,
53
54
  'editOrder': true,
54
55
  'fetchAccounts': true,
@@ -316,6 +317,7 @@ export default class kucoin extends Exchange {
316
317
  'premium/query': 4.5,
317
318
  'trade-statistics': 4.5,
318
319
  'funding-rate/{symbol}/current': 3,
320
+ 'contract/funding-rates': 7.5,
319
321
  'timestamp': 3,
320
322
  'status': 6,
321
323
  // ?
@@ -345,6 +347,7 @@ export default class kucoin extends Exchange {
345
347
  'openOrderStatistics': 15,
346
348
  'position': 3,
347
349
  'positions': 3,
350
+ 'margin/maxWithdrawMargin': 15,
348
351
  'contracts/risk-limit/{symbol}': 7.5,
349
352
  'funding-history': 7.5, // 5FW
350
353
  },
@@ -355,7 +358,9 @@ export default class kucoin extends Exchange {
355
358
  // futures
356
359
  'orders': 3,
357
360
  'orders/test': 3,
361
+ 'orders/multi': 4.5,
358
362
  'position/margin/auto-deposit-status': 6,
363
+ 'margin/withdrawMargin': 15,
359
364
  'position/margin/deposit-margin': 6,
360
365
  'position/risk-limit-level/change': 6,
361
366
  // ws
@@ -1,5 +1,5 @@
1
1
  import kucoin from './abstract/kucoinfutures.js';
2
- import type { Int, OrderSide, OrderType, OHLCV, Order, Trade, FundingRateHistory, FundingHistory, Balances, Str, Ticker, OrderBook, Transaction, Strings, Market, Currency } from './base/types.js';
2
+ import type { Int, OrderSide, OrderType, OHLCV, Order, Trade, FundingHistory, Balances, Str, Ticker, OrderBook, Transaction, Strings, Market, Currency, OrderRequest } from './base/types.js';
3
3
  export default class kucoinfutures extends kucoin {
4
4
  describe(): any;
5
5
  fetchStatus(params?: {}): Promise<{
@@ -28,6 +28,8 @@ export default class kucoinfutures extends kucoin {
28
28
  fetchPositions(symbols?: Strings, params?: {}): Promise<import("./base/types.js").Position[]>;
29
29
  parsePosition(position: any, market?: Market): import("./base/types.js").Position;
30
30
  createOrder(symbol: string, type: OrderType, side: OrderSide, amount: any, price?: any, params?: {}): Promise<Order>;
31
+ createOrders(orders: OrderRequest[], params?: {}): Promise<Order[]>;
32
+ createContractOrderRequest(symbol: string, type: OrderType, side: OrderSide, amount: any, price?: any, params?: {}): any;
31
33
  cancelOrder(id: string, symbol?: Str, params?: {}): Promise<any>;
32
34
  cancelAllOrders(symbol?: Str, params?: {}): Promise<any>;
33
35
  addMargin(symbol: string, amount: any, params?: {}): Promise<any>;
@@ -85,7 +87,7 @@ export default class kucoinfutures extends kucoin {
85
87
  fetchWithdrawals(code?: Str, since?: Int, limit?: Int, params?: {}): Promise<Transaction[]>;
86
88
  fetchMarketLeverageTiers(symbol: string, params?: {}): Promise<any[]>;
87
89
  parseMarketLeverageTiers(info: any, market?: Market): any[];
88
- fetchFundingRateHistory(symbol?: Str, since?: Int, limit?: Int, params?: {}): Promise<FundingRateHistory[]>;
90
+ fetchFundingRateHistory(symbol?: Str, since?: Int, limit?: Int, params?: {}): Promise<import("./base/types.js").FundingRateHistory[]>;
89
91
  parseFundingRateHistory(info: any, market?: Market): {
90
92
  info: any;
91
93
  symbol: string;
@@ -36,10 +36,14 @@ export default class kucoinfutures extends kucoin {
36
36
  'closePositions': false,
37
37
  'createDepositAddress': true,
38
38
  'createOrder': true,
39
+ 'createOrders': true,
39
40
  'createReduceOnlyOrder': true,
40
41
  'createStopLimitOrder': true,
41
42
  'createStopMarketOrder': true,
42
43
  'createStopOrder': true,
44
+ 'createTriggerOrder': true,
45
+ 'createTakeProfitOrder': true,
46
+ 'createStopLossOrder': true,
43
47
  'fetchAccounts': true,
44
48
  'fetchBalance': true,
45
49
  'fetchBorrowRateHistories': false,
@@ -54,7 +58,7 @@ export default class kucoinfutures extends kucoin {
54
58
  'fetchDepositWithdrawFees': false,
55
59
  'fetchFundingHistory': true,
56
60
  'fetchFundingRate': true,
57
- 'fetchFundingRateHistory': false,
61
+ 'fetchFundingRateHistory': true,
58
62
  'fetchIndexOHLCV': false,
59
63
  'fetchIsolatedBorrowRate': false,
60
64
  'fetchIsolatedBorrowRates': false,
@@ -1115,6 +1119,78 @@ export default class kucoinfutures extends kucoin {
1115
1119
  * @returns {object} an [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1116
1120
  */
1117
1121
  await this.loadMarkets();
1122
+ const market = this.market(symbol);
1123
+ const testOrder = this.safeValue(params, 'test', false);
1124
+ params = this.omit(params, 'test');
1125
+ const orderRequest = this.createContractOrderRequest(symbol, type, side, amount, price, params);
1126
+ let response = undefined;
1127
+ if (testOrder) {
1128
+ response = await this.futuresPrivatePostOrdersTest(orderRequest);
1129
+ }
1130
+ else {
1131
+ response = await this.futuresPrivatePostOrders(orderRequest);
1132
+ }
1133
+ //
1134
+ // {
1135
+ // "code": "200000",
1136
+ // "data": {
1137
+ // "orderId": "619717484f1d010001510cde",
1138
+ // },
1139
+ // }
1140
+ //
1141
+ const data = this.safeValue(response, 'data', {});
1142
+ return this.parseOrder(data, market);
1143
+ }
1144
+ async createOrders(orders, params = {}) {
1145
+ /**
1146
+ * @method
1147
+ * @name kucoinfutures#createOrders
1148
+ * @description create a list of trade orders
1149
+ * @see https://www.kucoin.com/docs/rest/futures-trading/orders/place-multiple-orders
1150
+ * @param {Array} orders list of orders to create, each object should contain the parameters required by createOrder, namely symbol, type, side, amount, price and params
1151
+ * @param {object} [params] extra parameters specific to the exchange API endpoint
1152
+ * @returns {object} an [order structure]{@link https://docs.ccxt.com/#/?id=order-structure}
1153
+ */
1154
+ await this.loadMarkets();
1155
+ const ordersRequests = [];
1156
+ for (let i = 0; i < orders.length; i++) {
1157
+ const rawOrder = orders[i];
1158
+ const symbol = this.safeString(rawOrder, 'symbol');
1159
+ const market = this.market(symbol);
1160
+ const type = this.safeString(rawOrder, 'type');
1161
+ const side = this.safeString(rawOrder, 'side');
1162
+ const amount = this.safeValue(rawOrder, 'amount');
1163
+ const price = this.safeValue(rawOrder, 'price');
1164
+ const orderParams = this.safeValue(rawOrder, 'params', {});
1165
+ const orderRequest = this.createContractOrderRequest(market['id'], type, side, amount, price, orderParams);
1166
+ ordersRequests.push(orderRequest);
1167
+ }
1168
+ const response = await this.futuresPrivatePostOrdersMulti(ordersRequests);
1169
+ //
1170
+ // {
1171
+ // "code": "200000",
1172
+ // "data": [
1173
+ // {
1174
+ // "orderId": "135241412609331200",
1175
+ // "clientOid": "3d8fcc13-0b13-447f-ad30-4b3441e05213",
1176
+ // "symbol": "LTCUSDTM",
1177
+ // "code": "200000",
1178
+ // "msg": "success"
1179
+ // },
1180
+ // {
1181
+ // "orderId": "135241412747743234",
1182
+ // "clientOid": "b878c7ee-ae3e-4d63-a20b-038acbb7306f",
1183
+ // "symbol": "LTCUSDTM",
1184
+ // "code": "200000",
1185
+ // "msg": "success"
1186
+ // }
1187
+ // ]
1188
+ // }
1189
+ //
1190
+ const data = this.safeValue(response, 'data', []);
1191
+ return this.parseOrders(data);
1192
+ }
1193
+ createContractOrderRequest(symbol, type, side, amount, price = undefined, params = {}) {
1118
1194
  const market = this.market(symbol);
1119
1195
  // required param, cannot be used twice
1120
1196
  const clientOrderId = this.safeString2(params, 'clientOid', 'clientOrderId', this.uuid());
@@ -1187,48 +1263,7 @@ export default class kucoinfutures extends kucoin {
1187
1263
  }
1188
1264
  }
1189
1265
  params = this.omit(params, ['timeInForce', 'stopPrice', 'triggerPrice', 'stopLossPrice', 'takeProfitPrice']); // Time in force only valid for limit orders, exchange error when gtc for market orders
1190
- let response = undefined;
1191
- const testOrder = this.safeValue(params, 'test', false);
1192
- params = this.omit(params, 'test');
1193
- if (testOrder) {
1194
- response = await this.futuresPrivatePostOrdersTest(this.extend(request, params));
1195
- }
1196
- else {
1197
- response = await this.futuresPrivatePostOrders(this.extend(request, params));
1198
- }
1199
- //
1200
- // {
1201
- // "code": "200000",
1202
- // "data": {
1203
- // "orderId": "619717484f1d010001510cde",
1204
- // },
1205
- // }
1206
- //
1207
- const data = this.safeValue(response, 'data', {});
1208
- return this.safeOrder({
1209
- 'id': this.safeString(data, 'orderId'),
1210
- 'clientOrderId': undefined,
1211
- 'timestamp': undefined,
1212
- 'datetime': undefined,
1213
- 'lastTradeTimestamp': undefined,
1214
- 'symbol': undefined,
1215
- 'type': undefined,
1216
- 'side': undefined,
1217
- 'price': undefined,
1218
- 'amount': undefined,
1219
- 'cost': undefined,
1220
- 'average': undefined,
1221
- 'filled': undefined,
1222
- 'remaining': undefined,
1223
- 'status': undefined,
1224
- 'fee': undefined,
1225
- 'trades': undefined,
1226
- 'timeInForce': undefined,
1227
- 'postOnly': undefined,
1228
- 'stopPrice': undefined,
1229
- 'triggerPrice': undefined,
1230
- 'info': response,
1231
- }, market);
1266
+ return this.extend(request, params);
1232
1267
  }
1233
1268
  async cancelOrder(id, symbol = undefined, params = {}) {
1234
1269
  /**
@@ -1701,10 +1736,26 @@ export default class kucoinfutures extends kucoin {
1701
1736
  // "reduceOnly": false
1702
1737
  // }
1703
1738
  //
1739
+ // createOrder
1740
+ //
1741
+ // {
1742
+ // "orderId": "619717484f1d010001510cde"
1743
+ // }
1744
+ //
1745
+ // createOrders
1746
+ //
1747
+ // {
1748
+ // "orderId": "80465574458560512",
1749
+ // "clientOid": "5c52e11203aa677f33e491",
1750
+ // "symbol": "ETHUSDTM",
1751
+ // "code": "200000",
1752
+ // "msg": "success"
1753
+ // }
1754
+ //
1704
1755
  const marketId = this.safeString(order, 'symbol');
1705
1756
  market = this.safeMarket(marketId, market);
1706
1757
  const symbol = market['symbol'];
1707
- const orderId = this.safeString(order, 'id');
1758
+ const orderId = this.safeString2(order, 'id', 'orderId');
1708
1759
  const type = this.safeString(order, 'type');
1709
1760
  const timestamp = this.safeInteger(order, 'createdAt');
1710
1761
  const datetime = this.iso8601(timestamp);
@@ -1731,9 +1782,12 @@ export default class kucoinfutures extends kucoin {
1731
1782
  // precision reported by their api is 8 d.p.
1732
1783
  // const average = Precise.stringDiv (cost, Precise.stringMul (filled, market['contractSize']));
1733
1784
  // bool
1734
- const isActive = this.safeValue(order, 'isActive', false);
1785
+ const isActive = this.safeValue(order, 'isActive');
1735
1786
  const cancelExist = this.safeValue(order, 'cancelExist', false);
1736
- let status = isActive ? 'open' : 'closed';
1787
+ let status = undefined;
1788
+ if (isActive !== undefined) {
1789
+ status = isActive ? 'open' : 'closed';
1790
+ }
1737
1791
  status = cancelExist ? 'canceled' : status;
1738
1792
  let fee = undefined;
1739
1793
  if (feeCost !== undefined) {
@@ -2378,62 +2432,62 @@ export default class kucoinfutures extends kucoin {
2378
2432
  /**
2379
2433
  * @method
2380
2434
  * @name kucoinfutures#fetchFundingRateHistory
2435
+ * @see https://www.kucoin.com/docs/rest/futures-trading/funding-fees/get-public-funding-history#request-url
2381
2436
  * @description fetches historical funding rate prices
2382
2437
  * @param {string} symbol unified symbol of the market to fetch the funding rate history for
2383
2438
  * @param {int} [since] not used by kucuoinfutures
2384
2439
  * @param {int} [limit] the maximum amount of [funding rate structures]{@link https://docs.ccxt.com/#/?id=funding-rate-history-structure} to fetch
2385
2440
  * @param {object} [params] extra parameters specific to the exchange API endpoint
2386
- * @param {boolean} [params.paginate] default false, when true will automatically paginate by calling this endpoint multiple times. See in the docs all the [availble parameters](https://github.com/ccxt/ccxt/wiki/Manual#pagination-params)
2441
+ * @param {int} [params.until] end time in ms
2387
2442
  * @returns {object[]} a list of [funding rate structures]{@link https://docs.ccxt.com/#/?id=funding-rate-history-structure}
2388
2443
  */
2389
2444
  if (symbol === undefined) {
2390
2445
  throw new ArgumentsRequired(this.id + ' fetchFundingRateHistory() requires a symbol argument');
2391
2446
  }
2392
2447
  await this.loadMarkets();
2393
- let paginate = false;
2394
- [paginate, params] = this.handleOptionAndParams(params, 'fetchFundingRateHistory', 'paginate');
2395
- if (paginate) {
2396
- return await this.fetchPaginatedCallDeterministic('fetchFundingRateHistory', symbol, since, limit, '8h', params);
2397
- }
2398
2448
  const market = this.market(symbol);
2399
2449
  const request = {
2400
2450
  'symbol': market['id'],
2451
+ 'from': 0,
2452
+ 'to': this.milliseconds(),
2401
2453
  };
2402
- if (limit !== undefined) {
2403
- request['maxCount'] = limit;
2454
+ const until = this.safeInteger2(params, 'until', 'till');
2455
+ params = this.omit(params, ['until', 'till']);
2456
+ if (since !== undefined) {
2457
+ request['from'] = since;
2458
+ if (until === undefined) {
2459
+ request['to'] = since + 1000 * 8 * 60 * 60 * 100;
2460
+ }
2461
+ }
2462
+ if (until !== undefined) {
2463
+ request['to'] = until;
2464
+ if (since === undefined) {
2465
+ request['to'] = until - 1000 * 8 * 60 * 60 * 100;
2466
+ }
2404
2467
  }
2405
- const response = await this.webExchangeGetContractSymbolFundingRates(this.extend(request, params));
2468
+ const response = await this.futuresPublicGetContractFundingRates(this.extend(request, params));
2406
2469
  //
2407
- // {
2408
- // "success": true,
2409
- // "code": "200",
2410
- // "msg": "success",
2411
- // "retry": false,
2412
- // "data": {
2413
- // "dataList": [
2414
- // {
2415
- // "symbol": "XBTUSDTM",
2416
- // "granularity": 28800000,
2417
- // "timePoint": 1675108800000,
2418
- // "value": 0.0001
2419
- // },
2420
- // ...
2421
- // ],
2422
- // "hasMore": true
2423
- // }
2424
- // }
2470
+ // {
2471
+ // "code": "200000",
2472
+ // "data": [
2473
+ // {
2474
+ // "symbol": "IDUSDTM",
2475
+ // "fundingRate": 2.26E-4,
2476
+ // "timepoint": 1702296000000
2477
+ // }
2478
+ // ]
2479
+ // }
2425
2480
  //
2426
2481
  const data = this.safeValue(response, 'data');
2427
- const dataList = this.safeValue(data, 'dataList');
2428
- return this.parseFundingRateHistories(dataList, market, since, limit);
2482
+ return this.parseFundingRateHistories(data, market, since, limit);
2429
2483
  }
2430
2484
  parseFundingRateHistory(info, market = undefined) {
2431
- const timestamp = this.safeInteger(info, 'timePoint');
2485
+ const timestamp = this.safeInteger(info, 'timepoint');
2432
2486
  const marketId = this.safeString(info, 'symbol');
2433
2487
  return {
2434
2488
  'info': info,
2435
2489
  'symbol': this.safeSymbol(marketId, market),
2436
- 'fundingRate': this.safeNumber(info, 'value'),
2490
+ 'fundingRate': this.safeNumber(info, 'fundingRate'),
2437
2491
  'timestamp': timestamp,
2438
2492
  'datetime': this.iso8601(timestamp),
2439
2493
  };