ccxt 4.5.9 → 4.5.11

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 (79) hide show
  1. package/README.md +5 -6
  2. package/dist/ccxt.browser.min.js +2 -2
  3. package/dist/cjs/ccxt.js +1 -6
  4. package/dist/cjs/src/base/Exchange.js +14 -2
  5. package/dist/cjs/src/bingx.js +1 -1
  6. package/dist/cjs/src/bitfinex.js +4 -2
  7. package/dist/cjs/src/bitget.js +5 -2
  8. package/dist/cjs/src/btcmarkets.js +4 -2
  9. package/dist/cjs/src/coinbase.js +1 -0
  10. package/dist/cjs/src/deribit.js +21 -19
  11. package/dist/cjs/src/kraken.js +4 -0
  12. package/dist/cjs/src/kucoin.js +1 -1
  13. package/dist/cjs/src/latoken.js +1 -0
  14. package/dist/cjs/src/mexc.js +1 -0
  15. package/dist/cjs/src/onetrading.js +2 -1
  16. package/dist/cjs/src/phemex.js +1 -0
  17. package/dist/cjs/src/pro/bitget.js +1 -0
  18. package/dist/cjs/src/pro/htx.js +22 -3
  19. package/dist/cjs/src/pro/kraken.js +282 -458
  20. package/dist/cjs/src/pro/mexc.js +15 -10
  21. package/dist/cjs/src/probit.js +1 -1
  22. package/js/ccxt.d.ts +2 -8
  23. package/js/ccxt.js +2 -6
  24. package/js/src/abstract/coinbase.d.ts +1 -0
  25. package/js/src/abstract/coinbaseadvanced.d.ts +1 -0
  26. package/js/src/abstract/phemex.d.ts +1 -0
  27. package/js/src/base/Exchange.d.ts +5 -2
  28. package/js/src/base/Exchange.js +14 -2
  29. package/js/src/bingx.js +1 -1
  30. package/js/src/bitfinex.d.ts +1 -1
  31. package/js/src/bitfinex.js +4 -2
  32. package/js/src/bitget.d.ts +1 -1
  33. package/js/src/bitget.js +5 -2
  34. package/js/src/bithumb.d.ts +1 -1
  35. package/js/src/bitmex.d.ts +1 -1
  36. package/js/src/bitopro.d.ts +1 -1
  37. package/js/src/bitso.d.ts +1 -1
  38. package/js/src/bittrade.d.ts +1 -1
  39. package/js/src/blofin.d.ts +1 -1
  40. package/js/src/btcmarkets.d.ts +1 -1
  41. package/js/src/btcmarkets.js +4 -2
  42. package/js/src/bybit.d.ts +1 -1
  43. package/js/src/coinbase.d.ts +1 -1
  44. package/js/src/coinbase.js +1 -0
  45. package/js/src/coinex.d.ts +1 -1
  46. package/js/src/cryptocom.d.ts +1 -1
  47. package/js/src/deribit.js +21 -19
  48. package/js/src/digifinex.d.ts +1 -1
  49. package/js/src/hibachi.d.ts +1 -1
  50. package/js/src/htx.d.ts +1 -1
  51. package/js/src/hyperliquid.d.ts +1 -1
  52. package/js/src/kraken.d.ts +1 -1
  53. package/js/src/kraken.js +4 -0
  54. package/js/src/kucoin.js +1 -1
  55. package/js/src/kucoinfutures.d.ts +1 -1
  56. package/js/src/latoken.js +1 -0
  57. package/js/src/mexc.d.ts +1 -1
  58. package/js/src/mexc.js +1 -0
  59. package/js/src/oceanex.d.ts +1 -1
  60. package/js/src/okx.d.ts +1 -1
  61. package/js/src/onetrading.d.ts +1 -1
  62. package/js/src/onetrading.js +2 -1
  63. package/js/src/phemex.js +1 -0
  64. package/js/src/pro/bitget.d.ts +1 -0
  65. package/js/src/pro/bitget.js +1 -0
  66. package/js/src/pro/bitvavo.d.ts +2 -2
  67. package/js/src/pro/htx.js +22 -3
  68. package/js/src/pro/kraken.d.ts +7 -8
  69. package/js/src/pro/kraken.js +282 -458
  70. package/js/src/pro/mexc.js +15 -10
  71. package/js/src/probit.js +1 -1
  72. package/js/src/timex.d.ts +1 -1
  73. package/package.json +1 -1
  74. package/js/src/abstract/okcoin.d.ts +0 -77
  75. package/js/src/abstract/okcoin.js +0 -11
  76. package/js/src/okcoin.d.ts +0 -346
  77. package/js/src/okcoin.js +0 -3214
  78. package/js/src/pro/okcoin.d.ts +0 -91
  79. package/js/src/pro/okcoin.js +0 -763
package/js/src/kucoin.js CHANGED
@@ -1609,7 +1609,7 @@ export default class kucoin extends Exchange {
1609
1609
  const networkCodeNew = this.networkIdToCode(this.safeString(chain, 'chainId'), this.safeString(currency, 'code'));
1610
1610
  resultNew['networks'][networkCodeNew] = {
1611
1611
  'withdraw': {
1612
- 'fee': this.safeNumber(chain, 'withdrawMinFee'),
1612
+ 'fee': this.safeNumber2(chain, 'withdrawalMinFee', 'withdrawMinFee'),
1613
1613
  'percentage': false,
1614
1614
  },
1615
1615
  'deposit': {
@@ -234,7 +234,7 @@ export default class kucoinfutures extends kucoin {
234
234
  * @param {string[]} [params.clientOrderIds] client order ids
235
235
  * @returns {object} an list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
236
236
  */
237
- cancelOrders(ids: any, symbol?: Str, params?: {}): Promise<Order[]>;
237
+ cancelOrders(ids: string[], symbol?: Str, params?: {}): Promise<Order[]>;
238
238
  /**
239
239
  * @method
240
240
  * @name kucoinfutures#cancelAllOrders
package/js/src/latoken.js CHANGED
@@ -1607,6 +1607,7 @@ export default class latoken extends Exchange {
1607
1607
  'TRANSACTION_STATUS_CHECKING': 'pending',
1608
1608
  'TRANSACTION_STATUS_CANCELLED': 'canceled',
1609
1609
  'TRANSACTION_STATUS_FAILED': 'failed',
1610
+ 'TRANSACTION_STATUS_REJECTED': 'rejected',
1610
1611
  };
1611
1612
  return this.safeString(statuses, status, status);
1612
1613
  }
package/js/src/mexc.d.ts CHANGED
@@ -354,7 +354,7 @@ export default class mexc extends Exchange {
354
354
  * @param {object} [params] extra parameters specific to the exchange API endpoint
355
355
  * @returns {object} an list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
356
356
  */
357
- cancelOrders(ids: any, symbol?: Str, params?: {}): Promise<Order[]>;
357
+ cancelOrders(ids: string[], symbol?: Str, params?: {}): Promise<Order[]>;
358
358
  /**
359
359
  * @method
360
360
  * @name mexc#cancelAllOrders
package/js/src/mexc.js CHANGED
@@ -3591,6 +3591,7 @@ export default class mexc extends Exchange {
3591
3591
  'timestamp': timestamp,
3592
3592
  'datetime': this.iso8601(timestamp),
3593
3593
  'lastTradeTimestamp': undefined,
3594
+ 'lastUpdateTimestamp': this.safeInteger(order, 'updateTime'),
3594
3595
  'status': this.parseOrderStatus(this.safeString2(order, 'status', 'state')),
3595
3596
  'symbol': market['symbol'],
3596
3597
  'type': this.parseOrderType(typeRaw),
@@ -199,7 +199,7 @@ export default class oceanex extends Exchange {
199
199
  * @param {object} [params] extra parameters specific to the exchange API endpoint
200
200
  * @returns {object} an list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
201
201
  */
202
- cancelOrders(ids: any, symbol?: Str, params?: {}): Promise<Order[]>;
202
+ cancelOrders(ids: string[], symbol?: Str, params?: {}): Promise<Order[]>;
203
203
  /**
204
204
  * @method
205
205
  * @name oceanex#cancelAllOrders
package/js/src/okx.d.ts CHANGED
@@ -314,7 +314,7 @@ export default class okx extends Exchange {
314
314
  * @param {boolean} [params.trailing] set to true if you want to cancel trailing orders
315
315
  * @returns {object} an list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
316
316
  */
317
- cancelOrders(ids: any, symbol?: Str, params?: {}): Promise<Order[]>;
317
+ cancelOrders(ids: string[], symbol?: Str, params?: {}): Promise<Order[]>;
318
318
  /**
319
319
  * @method
320
320
  * @name okx#cancelOrdersForSymbols
@@ -158,7 +158,7 @@ export default class onetrading extends Exchange {
158
158
  * @param {object} [params] extra parameters specific to the exchange API endpoint
159
159
  * @returns {object} an list of [order structures]{@link https://docs.ccxt.com/#/?id=order-structure}
160
160
  */
161
- cancelOrders(ids: any, symbol?: Str, params?: {}): Promise<any>;
161
+ cancelOrders(ids: string[], symbol?: Str, params?: {}): Promise<Order[]>;
162
162
  /**
163
163
  * @method
164
164
  * @name onetrading#fetchOrder
@@ -1489,7 +1489,8 @@ export default class onetrading extends Exchange {
1489
1489
  // "a10e9bd1-8f72-4cfe-9f1b-7f1c8a9bd8ee"
1490
1490
  // ]
1491
1491
  //
1492
- return response;
1492
+ const order = this.safeOrder({ 'info': response });
1493
+ return [order];
1493
1494
  }
1494
1495
  /**
1495
1496
  * @method
package/js/src/phemex.js CHANGED
@@ -193,6 +193,7 @@ export default class phemex extends Exchange {
193
193
  'accounts/accountPositions': 1,
194
194
  'g-accounts/accountPositions': 1,
195
195
  'g-accounts/positions': 25,
196
+ 'g-accounts/risk-unit': 1,
196
197
  'api-data/futures/funding-fees': 5,
197
198
  'api-data/g-futures/funding-fees': 5,
198
199
  'api-data/futures/orders': 5,
@@ -209,6 +209,7 @@ export default class bitget extends bitgetRest {
209
209
  * @name bitget#watchOrders
210
210
  * @description watches information on multiple orders made by the user
211
211
  * @see https://www.bitget.com/api-doc/spot/websocket/private/Order-Channel
212
+ * @see https://www.bitget.com/api-doc/spot/websocket/private/Plan-Order-Channel
212
213
  * @see https://www.bitget.com/api-doc/contract/websocket/private/Order-Channel
213
214
  * @see https://www.bitget.com/api-doc/contract/websocket/private/Plan-Order-Channel
214
215
  * @see https://www.bitget.com/api-doc/margin/cross/websocket/private/Cross-Orders
@@ -1499,6 +1499,7 @@ export default class bitget extends bitgetRest {
1499
1499
  * @name bitget#watchOrders
1500
1500
  * @description watches information on multiple orders made by the user
1501
1501
  * @see https://www.bitget.com/api-doc/spot/websocket/private/Order-Channel
1502
+ * @see https://www.bitget.com/api-doc/spot/websocket/private/Plan-Order-Channel
1502
1503
  * @see https://www.bitget.com/api-doc/contract/websocket/private/Order-Channel
1503
1504
  * @see https://www.bitget.com/api-doc/contract/websocket/private/Plan-Order-Channel
1504
1505
  * @see https://www.bitget.com/api-doc/margin/cross/websocket/private/Cross-Orders
@@ -1,5 +1,5 @@
1
1
  import bitvavoRest from '../bitvavo.js';
2
- import { Int, Str, OrderSide, OrderType, OrderBook, Ticker, Trade, Order, OHLCV, Balances, Num, TradingFees, Strings, Tickers, Bool } from '../base/types.js';
2
+ import { Int, Str, OrderSide, OrderType, OrderBook, Ticker, Trade, Order, OHLCV, Balances, Num, TradingFees, Strings, Tickers, Bool, Currencies } from '../base/types.js';
3
3
  import Client from '../base/ws/Client.js';
4
4
  export default class bitvavo extends bitvavoRest {
5
5
  describe(): any;
@@ -293,7 +293,7 @@ export default class bitvavo extends bitvavoRest {
293
293
  * @param {object} [params] extra parameters specific to the bitvavo api endpoint
294
294
  * @returns {object} an associative dictionary of currencies
295
295
  */
296
- fetchCurrenciesWs(params?: {}): Promise<any>;
296
+ fetchCurrenciesWs(params?: {}): Promise<Currencies>;
297
297
  handleFetchCurrencies(client: Client, message: any): void;
298
298
  handleTradingFees(client: any, message: any): void;
299
299
  /**
package/js/src/pro/htx.js CHANGED
@@ -929,24 +929,40 @@ export default class htx extends htxRest {
929
929
  //
930
930
  // spot
931
931
  //
932
+ // for new order creation
933
+ //
932
934
  // {
933
935
  // "action":"push",
934
936
  // "ch":"orders#btcusdt", // or "orders#*" for global subscriptions
935
937
  // "data": {
938
+ // "orderStatus": "submitted",
939
+ // "eventType": "creation",
940
+ // "totalTradeAmount": 0 // for "submitted" order status
941
+ // "orderCreateTime": 1645116048355, // only when `submitted` status
936
942
  // "orderSource": "spot-web",
937
- // "orderCreateTime": 1645116048355,
938
943
  // "accountId": 44234548,
939
944
  // "orderPrice": "100",
940
945
  // "orderSize": "0.05",
941
946
  // "symbol": "ethusdt",
942
947
  // "type": "buy-limit",
943
948
  // "orderId": "478861479986886",
944
- // "eventType": "creation",
945
949
  // "clientOrderId": '',
946
- // "orderStatus": "submitted"
947
950
  // }
948
951
  // }
949
952
  //
953
+ // for filled order, additional fields are present:
954
+ //
955
+ // "orderStatus": "filled",
956
+ // "eventType": "trade",
957
+ // "totalTradeAmount": "5.9892649859",
958
+ // "tradePrice": "0.676669",
959
+ // "tradeVolume": "8.8511",
960
+ // "tradeTime": 1760427775894,
961
+ // "aggressor": false,
962
+ // "execAmt": "8.8511",
963
+ // "tradeId": 100599712781,
964
+ // "remainAmt": "0",
965
+ //
950
966
  // spot wrapped trade
951
967
  //
952
968
  // {
@@ -1058,6 +1074,9 @@ export default class htx extends htxRest {
1058
1074
  'symbol': market['symbol'],
1059
1075
  'filled': this.parseNumber(filled),
1060
1076
  'remaining': this.parseNumber(remaining),
1077
+ 'price': this.safeNumber(data, 'orderPrice'),
1078
+ 'amount': this.safeNumber(data, 'orderSize'),
1079
+ 'info': data,
1061
1080
  };
1062
1081
  parsedOrder = order;
1063
1082
  }
@@ -72,7 +72,6 @@ export default class kraken extends krakenRest {
72
72
  handleTrades(client: Client, message: any): void;
73
73
  handleOHLCV(client: Client, message: any, subscription: any): void;
74
74
  requestId(): any;
75
- watchPublic(name: any, symbol: any, params?: {}): Promise<any>;
76
75
  /**
77
76
  * @method
78
77
  * @name kraken#watchTicker
@@ -153,7 +152,7 @@ export default class kraken extends krakenRest {
153
152
  * @method
154
153
  * @name kraken#watchOHLCV
155
154
  * @description watches historical candlestick data containing the open, high, low, and close price, and the volume of a market
156
- * @see https://docs.kraken.com/api/docs/websocket-v1/ohlc
155
+ * @see https://docs.kraken.com/api/docs/websocket-v2/ohlc
157
156
  * @param {string} symbol unified symbol of the market to fetch OHLCV data for
158
157
  * @param {string} timeframe the length of time each candle represents
159
158
  * @param {int} [since] timestamp in ms of the earliest candle to fetch
@@ -177,7 +176,7 @@ export default class kraken extends krakenRest {
177
176
  * @method
178
177
  * @name kraken#watchMyTrades
179
178
  * @description watches information on multiple trades made by the user
180
- * @see https://docs.kraken.com/api/docs/websocket-v1/owntrades
179
+ * @see https://docs.kraken.com/api/docs/websocket-v2/executions
181
180
  * @param {string} symbol unified market symbol of the market trades were made in
182
181
  * @param {int} [since] the earliest time in ms to fetch trades for
183
182
  * @param {int} [limit] the maximum number of trade structures to retrieve
@@ -187,25 +186,25 @@ export default class kraken extends krakenRest {
187
186
  watchMyTrades(symbol?: Str, since?: Int, limit?: Int, params?: {}): Promise<Trade[]>;
188
187
  handleMyTrades(client: Client, message: any, subscription?: any): void;
189
188
  parseWsTrade(trade: any, market?: any): {
189
+ info: any;
190
190
  id: string;
191
191
  order: string;
192
- info: any;
193
192
  timestamp: number;
194
193
  datetime: string;
195
- symbol: any;
194
+ symbol: string;
196
195
  type: string;
197
196
  side: string;
198
- takerOrMaker: any;
197
+ takerOrMaker: string;
199
198
  price: number;
200
199
  amount: number;
201
- cost: any;
200
+ cost: number;
202
201
  fee: any;
203
202
  };
204
203
  /**
205
204
  * @method
206
205
  * @name kraken#watchOrders
207
- * @see https://docs.kraken.com/api/docs/websocket-v1/openorders
208
206
  * @description watches information on multiple orders made by the user
207
+ * @see https://docs.kraken.com/api/docs/websocket-v2/executions
209
208
  * @param {string} symbol unified market symbol of the market orders were made in
210
209
  * @param {int} [since] the earliest time in ms to fetch orders for
211
210
  * @param {int} [limit] the maximum number of orde structures to retrieve