ccxt 4.3.51 → 4.3.53

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 (45) hide show
  1. package/README.md +6 -5
  2. package/dist/ccxt.browser.min.js +3 -3
  3. package/dist/cjs/ccxt.js +6 -1
  4. package/dist/cjs/src/abstract/vertex.js +9 -0
  5. package/dist/cjs/src/base/Precise.js +10 -0
  6. package/dist/cjs/src/base/functions/type.js +43 -10
  7. package/dist/cjs/src/binance.js +2 -2
  8. package/dist/cjs/src/bybit.js +6 -0
  9. package/dist/cjs/src/hyperliquid.js +27 -26
  10. package/dist/cjs/src/krakenfutures.js +1 -0
  11. package/dist/cjs/src/okx.js +1 -0
  12. package/dist/cjs/src/pro/okx.js +1 -1
  13. package/dist/cjs/src/pro/probit.js +8 -3
  14. package/dist/cjs/src/pro/vertex.js +978 -0
  15. package/dist/cjs/src/probit.js +10 -5
  16. package/dist/cjs/src/static_dependencies/ethers/hash/typed-data.js +1 -1
  17. package/dist/cjs/src/vertex.js +2941 -0
  18. package/js/ccxt.d.ts +8 -2
  19. package/js/ccxt.js +6 -2
  20. package/js/src/abstract/okx.d.ts +1 -0
  21. package/js/src/abstract/vertex.d.ts +22 -0
  22. package/js/src/abstract/vertex.js +11 -0
  23. package/js/src/base/Exchange.d.ts +1 -1
  24. package/js/src/base/Precise.d.ts +2 -0
  25. package/js/src/base/Precise.js +10 -0
  26. package/js/src/base/functions/type.js +43 -10
  27. package/js/src/binance.d.ts +1 -11
  28. package/js/src/binance.js +2 -2
  29. package/js/src/bitget.d.ts +1 -1
  30. package/js/src/bitmart.d.ts +1 -1
  31. package/js/src/bybit.js +6 -0
  32. package/js/src/coinex.d.ts +1 -1
  33. package/js/src/htx.d.ts +1 -1
  34. package/js/src/hyperliquid.js +27 -26
  35. package/js/src/krakenfutures.js +1 -0
  36. package/js/src/okx.js +1 -0
  37. package/js/src/pro/okx.js +1 -1
  38. package/js/src/pro/probit.js +8 -3
  39. package/js/src/pro/vertex.d.ts +39 -0
  40. package/js/src/pro/vertex.js +979 -0
  41. package/js/src/probit.js +11 -6
  42. package/js/src/static_dependencies/ethers/hash/typed-data.js +1 -1
  43. package/js/src/vertex.d.ts +112 -0
  44. package/js/src/vertex.js +2942 -0
  45. package/package.json +1 -1
package/js/src/probit.js CHANGED
@@ -6,7 +6,7 @@
6
6
 
7
7
  // ---------------------------------------------------------------------------
8
8
  import Exchange from './abstract/probit.js';
9
- import { ExchangeError, ExchangeNotAvailable, BadResponse, BadRequest, InvalidOrder, InsufficientFunds, AuthenticationError, InvalidAddress, RateLimitExceeded, DDoSProtection, BadSymbol, ArgumentsRequired } from './base/errors.js';
9
+ import { ExchangeError, ExchangeNotAvailable, BadResponse, BadRequest, InvalidOrder, InsufficientFunds, AuthenticationError, InvalidAddress, RateLimitExceeded, DDoSProtection, BadSymbol, MarketClosed, ArgumentsRequired } from './base/errors.js';
10
10
  import { Precise } from './base/Precise.js';
11
11
  import { TRUNCATE, TICK_SIZE } from './base/functions/number.js';
12
12
  // ---------------------------------------------------------------------------
@@ -182,7 +182,7 @@ export default class probit extends Exchange {
182
182
  'RATE_LIMIT_EXCEEDED': RateLimitExceeded,
183
183
  'MARKET_UNAVAILABLE': ExchangeNotAvailable,
184
184
  'INVALID_MARKET': BadSymbol,
185
- 'MARKET_CLOSED': BadSymbol,
185
+ 'MARKET_CLOSED': MarketClosed,
186
186
  'MARKET_NOT_FOUND': BadSymbol,
187
187
  'INVALID_CURRENCY': BadRequest,
188
188
  'TOO_MANY_OPEN_ORDERS': DDoSProtection,
@@ -1839,11 +1839,16 @@ export default class probit extends Exchange {
1839
1839
  }
1840
1840
  if ('errorCode' in response) {
1841
1841
  const errorCode = this.safeString(response, 'errorCode');
1842
- const message = this.safeString(response, 'message');
1843
1842
  if (errorCode !== undefined) {
1844
- const feedback = this.id + ' ' + body;
1845
- this.throwExactlyMatchedException(this.exceptions['exact'], message, feedback);
1846
- this.throwBroadlyMatchedException(this.exceptions['exact'], errorCode, feedback);
1843
+ const errMessage = this.safeString(response, 'message', '');
1844
+ const details = this.safeValue(response, 'details');
1845
+ const feedback = this.id + ' ' + errorCode + ' ' + errMessage + ' ' + this.json(details);
1846
+ if ('exact' in this.exceptions) {
1847
+ this.throwExactlyMatchedException(this.exceptions['exact'], errorCode, feedback);
1848
+ }
1849
+ if ('broad' in this.exceptions) {
1850
+ this.throwBroadlyMatchedException(this.exceptions['broad'], errMessage, feedback);
1851
+ }
1847
1852
  throw new ExchangeError(feedback);
1848
1853
  }
1849
1854
  }
@@ -467,7 +467,7 @@ _TypedDataEncoder_types = new WeakMap(), _TypedDataEncoder_fullTypes = new WeakM
467
467
  if (__classPrivateFieldGet(this, _TypedDataEncoder_fullTypes, "f").has(subtype)) {
468
468
  result = result.map(keccak256);
469
469
  }
470
- return keccak256(concat(result));
470
+ return keccak256(getBytes(concat(result)));
471
471
  };
472
472
  }
473
473
  // Struct
@@ -0,0 +1,112 @@
1
+ import Exchange from './abstract/vertex.js';
2
+ import type { Market, Ticker, Tickers, TradingFees, Balances, Int, OrderBook, OHLCV, Str, Order, OrderType, OrderSide, Trade, Strings, Dict, Num, Currencies } from './base/types.js';
3
+ /**
4
+ * @class vertex
5
+ * @augments Exchange
6
+ */
7
+ export default class vertex extends Exchange {
8
+ describe(): any;
9
+ setSandboxMode(enabled: any): void;
10
+ convertToX18(num: any): string;
11
+ convertFromX18(num: any): string;
12
+ fetchCurrencies(params?: {}): Promise<Currencies>;
13
+ parseMarket(market: any): Market;
14
+ fetchMarkets(params?: {}): Promise<Market[]>;
15
+ fetchTime(params?: {}): Promise<number>;
16
+ fetchStatus(params?: {}): Promise<{
17
+ status: string;
18
+ updated: any;
19
+ eta: any;
20
+ url: any;
21
+ info: any;
22
+ }>;
23
+ parseTrade(trade: any, market?: Market): Trade;
24
+ fetchTrades(symbol: string, since?: Int, limit?: Int, params?: {}): Promise<Trade[]>;
25
+ fetchMyTrades(symbol?: Str, since?: Int, limit?: Int, params?: {}): Promise<Trade[]>;
26
+ fetchOrderBook(symbol: string, limit?: Int, params?: {}): Promise<OrderBook>;
27
+ fetchTradingFees(params?: {}): Promise<TradingFees>;
28
+ parseOHLCV(ohlcv: any, market?: Market): OHLCV;
29
+ fetchOHLCV(symbol: string, timeframe?: string, since?: Int, limit?: Int, params?: {}): Promise<OHLCV[]>;
30
+ parseFundingRate(ticker: any, market?: Market): {
31
+ info: any;
32
+ symbol: string;
33
+ markPrice: number;
34
+ indexPrice: number;
35
+ interestRate: any;
36
+ estimatedSettlePrice: any;
37
+ timestamp: any;
38
+ datetime: any;
39
+ fundingRate: number;
40
+ fundingTimestamp: number;
41
+ fundingDatetime: string;
42
+ nextFundingRate: any;
43
+ nextFundingTimestamp: any;
44
+ nextFundingDatetime: any;
45
+ previousFundingRate: any;
46
+ previousFundingTimestamp: any;
47
+ previousFundingDatetime: any;
48
+ };
49
+ fetchFundingRate(symbol: string, params?: {}): Promise<{
50
+ info: any;
51
+ symbol: string;
52
+ markPrice: number;
53
+ indexPrice: number;
54
+ interestRate: any;
55
+ estimatedSettlePrice: any;
56
+ timestamp: any;
57
+ datetime: any;
58
+ fundingRate: number;
59
+ fundingTimestamp: number;
60
+ fundingDatetime: string;
61
+ nextFundingRate: any;
62
+ nextFundingTimestamp: any;
63
+ nextFundingDatetime: any;
64
+ previousFundingRate: any;
65
+ previousFundingTimestamp: any;
66
+ previousFundingDatetime: any;
67
+ }>;
68
+ fetchFundingRates(symbols?: Strings, params?: {}): Promise<any>;
69
+ parseOpenInterest(interest: any, market?: Market): import("./base/types.js").OpenInterest;
70
+ fetchOpenInterest(symbol: string, params?: {}): Promise<import("./base/types.js").OpenInterest>;
71
+ parseTicker(ticker: Dict, market?: Market): Ticker;
72
+ fetchTickers(symbols?: Strings, params?: {}): Promise<Tickers>;
73
+ queryContracts(params?: {}): Promise<Currencies>;
74
+ nonce(): number;
75
+ hashMessage(message: any): string;
76
+ signHash(hash: any, privateKey: any): string;
77
+ signMessage(message: any, privateKey: any): string;
78
+ buildSig(chainId: any, messageTypes: any, message: any, verifyingContractAddress?: string): string;
79
+ buildCreateOrderSig(message: any, chainId: any, verifyingContractAddress: any): string;
80
+ buildListTriggerTxSig(message: any, chainId: any, verifyingContractAddress: any): string;
81
+ buildCancelAllOrdersSig(message: any, chainId: any, verifyingContractAddress: any): string;
82
+ buildCancelOrdersSig(message: any, chainId: any, verifyingContractAddress: any): string;
83
+ buildWithdrawSig(message: any, chainId: any, verifyingContractAddress: any): string;
84
+ convertAddressToSender(address: string): string;
85
+ getNonce(now: any, expiration: any): string;
86
+ getExpiration(now: any, timeInForce: any, postOnly: any, reduceOnly: any): string;
87
+ getAmount(amount: any, side: any): string;
88
+ createOrder(symbol: string, type: OrderType, side: OrderSide, amount: number, price?: Num, params?: {}): Promise<Order>;
89
+ editOrder(id: string, symbol: string, type: OrderType, side: OrderSide, amount?: Num, price?: Num, params?: {}): Promise<Order>;
90
+ parseOrderStatus(status: any): any;
91
+ parseOrder(order: any, market?: Market): Order;
92
+ parseTimeInForce(timeInForce: any): string;
93
+ fetchOrder(id: string, symbol?: Str, params?: {}): Promise<Order>;
94
+ fetchOpenOrders(symbol?: Str, since?: Int, limit?: Int, params?: {}): Promise<Order[]>;
95
+ fetchOrders(symbol?: Str, since?: Int, limit?: Int, params?: {}): Promise<Order[]>;
96
+ cancelAllOrders(symbol?: Str, params?: {}): Promise<any>;
97
+ cancelOrder(id: string, symbol?: Str, params?: {}): Promise<any>;
98
+ cancelOrders(ids: string[], symbol?: Str, params?: {}): Promise<any>;
99
+ fetchBalance(params?: {}): Promise<Balances>;
100
+ parsePosition(position: any, market?: Market): import("./base/types.js").Position;
101
+ fetchPositions(symbols?: Strings, params?: {}): Promise<import("./base/types.js").Position[]>;
102
+ queryNonces(): Promise<import("./base/types.js").Dictionary<any>>;
103
+ withdraw(code: string, amount: any, address: any, tag?: any, params?: {}): Promise<any>;
104
+ handlePublicAddress(methodName: string, params: Dict): any[];
105
+ handleErrors(code: any, reason: any, url: any, method: any, headers: any, body: any, response: any, requestHeaders: any, requestBody: any): any;
106
+ sign(path: any, api?: string, method?: string, params?: {}, headers?: any, body?: any): {
107
+ url: string;
108
+ method: string;
109
+ body: any;
110
+ headers: any;
111
+ };
112
+ }