ccxt 4.1.13 → 4.1.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.
- package/CHANGELOG.md +219 -0
- package/CONTRIBUTING.md +1 -0
- package/README.md +3 -3
- package/dist/ccxt.browser.js +296 -106
- package/dist/ccxt.browser.min.js +3 -3
- package/dist/cjs/ccxt.js +1 -1
- package/dist/cjs/src/ascendex.js +1 -0
- package/dist/cjs/src/binance.js +6 -2
- package/dist/cjs/src/bingx.js +4 -2
- package/dist/cjs/src/bitget.js +192 -1
- package/dist/cjs/src/bitmart.js +2 -0
- package/dist/cjs/src/bittrex.js +6 -0
- package/dist/cjs/src/cex.js +1 -0
- package/dist/cjs/src/coinbase.js +1 -0
- package/dist/cjs/src/coinbasepro.js +1 -0
- package/dist/cjs/src/coinex.js +2 -0
- package/dist/cjs/src/coinfalcon.js +1 -0
- package/dist/cjs/src/coinmate.js +1 -0
- package/dist/cjs/src/coinone.js +2 -1
- package/dist/cjs/src/cryptocom.js +25 -87
- package/dist/cjs/src/currencycom.js +1 -0
- package/dist/cjs/src/delta.js +1 -0
- package/dist/cjs/src/deribit.js +1 -0
- package/dist/cjs/src/digifinex.js +1 -0
- package/dist/cjs/src/exmo.js +1 -0
- package/dist/cjs/src/gate.js +3 -0
- package/dist/cjs/src/gemini.js +1 -0
- package/dist/cjs/src/hitbtc.js +1 -0
- package/dist/cjs/src/hollaex.js +1 -0
- package/dist/cjs/src/huobijp.js +1 -0
- package/dist/cjs/src/idex.js +1 -0
- package/dist/cjs/src/independentreserve.js +1 -0
- package/dist/cjs/src/indodax.js +1 -0
- package/dist/cjs/src/kraken.js +9 -0
- package/dist/cjs/src/krakenfutures.js +1 -0
- package/dist/cjs/src/latoken.js +1 -0
- package/dist/cjs/src/poloniex.js +1 -0
- package/dist/cjs/src/poloniexfutures.js +8 -2
- package/dist/cjs/src/pro/krakenfutures.js +14 -10
- package/dist/cjs/src/woo.js +1 -0
- package/js/ccxt.d.ts +1 -1
- package/js/ccxt.js +1 -1
- package/js/src/abstract/binance.d.ts +4 -0
- package/js/src/abstract/binancecoinm.d.ts +4 -0
- package/js/src/abstract/binanceus.d.ts +4 -0
- package/js/src/abstract/binanceusdm.d.ts +4 -0
- package/js/src/abstract/kraken.d.ts +8 -0
- package/js/src/abstract/poloniexfutures.d.ts +6 -1
- package/js/src/ascendex.js +1 -0
- package/js/src/binance.js +6 -2
- package/js/src/bingx.js +4 -2
- package/js/src/bitget.d.ts +28 -0
- package/js/src/bitget.js +192 -1
- package/js/src/bitmart.js +2 -0
- package/js/src/bittrex.d.ts +2 -2
- package/js/src/bittrex.js +6 -0
- package/js/src/cex.js +1 -0
- package/js/src/coinbase.js +1 -0
- package/js/src/coinbasepro.js +1 -0
- package/js/src/coinex.js +2 -0
- package/js/src/coinfalcon.js +1 -0
- package/js/src/coinmate.js +1 -0
- package/js/src/coinone.js +2 -1
- package/js/src/cryptocom.d.ts +0 -2
- package/js/src/cryptocom.js +25 -87
- package/js/src/currencycom.js +1 -0
- package/js/src/delta.js +1 -0
- package/js/src/deribit.js +1 -0
- package/js/src/digifinex.js +1 -0
- package/js/src/exmo.js +1 -0
- package/js/src/gate.d.ts +1 -0
- package/js/src/gate.js +3 -0
- package/js/src/gemini.d.ts +1 -0
- package/js/src/gemini.js +1 -0
- package/js/src/hitbtc.js +1 -0
- package/js/src/hollaex.js +1 -0
- package/js/src/huobijp.js +1 -0
- package/js/src/idex.js +1 -0
- package/js/src/independentreserve.js +1 -0
- package/js/src/indodax.js +1 -0
- package/js/src/kraken.js +9 -0
- package/js/src/krakenfutures.js +1 -0
- package/js/src/latoken.js +1 -0
- package/js/src/poloniex.js +1 -0
- package/js/src/poloniexfutures.js +8 -2
- package/js/src/pro/krakenfutures.js +14 -10
- package/js/src/woo.js +1 -0
- package/package.json +1 -1
- package/skip-tests.json +33 -7
package/js/src/huobijp.js
CHANGED
package/js/src/idex.js
CHANGED
package/js/src/indodax.js
CHANGED
package/js/src/kraken.js
CHANGED
|
@@ -156,6 +156,7 @@ export default class kraken extends Exchange {
|
|
|
156
156
|
'Depth': 1,
|
|
157
157
|
'OHLC': 1,
|
|
158
158
|
'Spread': 1,
|
|
159
|
+
'SystemStatus': 1,
|
|
159
160
|
'Ticker': 1,
|
|
160
161
|
'Time': 1,
|
|
161
162
|
'Trades': 1,
|
|
@@ -168,6 +169,7 @@ export default class kraken extends Exchange {
|
|
|
168
169
|
'AddExport': 3,
|
|
169
170
|
'Balance': 3,
|
|
170
171
|
'CancelAll': 3,
|
|
172
|
+
'CancelAllOrdersAfter': 3,
|
|
171
173
|
'CancelOrder': 0,
|
|
172
174
|
'CancelOrderBatch': 0,
|
|
173
175
|
'ClosedOrders': 6,
|
|
@@ -203,6 +205,13 @@ export default class kraken extends Exchange {
|
|
|
203
205
|
// sub accounts
|
|
204
206
|
'CreateSubaccount': 3,
|
|
205
207
|
'AccountTransfer': 3,
|
|
208
|
+
// earn
|
|
209
|
+
'Earn/Allocate': 3,
|
|
210
|
+
'Earn/Deallocate': 3,
|
|
211
|
+
'Earn/AllocateStatus': 3,
|
|
212
|
+
'Earn/DeallocateStatus': 3,
|
|
213
|
+
'Earn/Strategies': 3,
|
|
214
|
+
'Earn/Allocations': 3,
|
|
206
215
|
},
|
|
207
216
|
},
|
|
208
217
|
},
|
package/js/src/krakenfutures.js
CHANGED
package/js/src/latoken.js
CHANGED
package/js/src/poloniex.js
CHANGED
|
@@ -105,22 +105,27 @@ export default class poloniexfutures extends Exchange {
|
|
|
105
105
|
'get': {
|
|
106
106
|
'account-overview': 1,
|
|
107
107
|
'transaction-history': 1,
|
|
108
|
+
'maxActiveOrders': 1,
|
|
109
|
+
'maxRiskLimit': 1,
|
|
110
|
+
'userFeeRate': 1,
|
|
111
|
+
'marginType/query': 1,
|
|
108
112
|
'orders': 1,
|
|
109
113
|
'stopOrders': 1,
|
|
110
114
|
'recentDoneOrders': 1,
|
|
111
115
|
'orders/{order-id}': 1,
|
|
116
|
+
'clientOrderId/{clientOid}': 1,
|
|
112
117
|
'fills': 1,
|
|
113
118
|
'openOrderStatistics': 1,
|
|
114
119
|
'position': 1.5,
|
|
115
120
|
'positions': 1.5,
|
|
116
121
|
'funding-history': 1,
|
|
117
|
-
'marginType/query': 1,
|
|
118
122
|
},
|
|
119
123
|
'post': {
|
|
120
124
|
'orders': 1.5,
|
|
121
125
|
'batchOrders': 1.5,
|
|
122
126
|
'position/margin/auto-deposit-status': 1.5,
|
|
123
127
|
'position/margin/deposit-margin': 1.5,
|
|
128
|
+
'position/margin/withdraw-margin': 1.5,
|
|
124
129
|
'bullet-private': 1,
|
|
125
130
|
'marginType/change': 1,
|
|
126
131
|
},
|
|
@@ -337,6 +342,7 @@ export default class poloniexfutures extends Exchange {
|
|
|
337
342
|
'max': undefined,
|
|
338
343
|
},
|
|
339
344
|
},
|
|
345
|
+
'created': this.safeInteger(market, 'firstOpenDate'),
|
|
340
346
|
'info': market,
|
|
341
347
|
});
|
|
342
348
|
}
|
|
@@ -1261,7 +1267,7 @@ export default class poloniexfutures extends Exchange {
|
|
|
1261
1267
|
}
|
|
1262
1268
|
const request = {};
|
|
1263
1269
|
if (!stop) {
|
|
1264
|
-
request['status'] = status === 'open' ? 'active' : 'done';
|
|
1270
|
+
request['status'] = (status === 'open') ? 'active' : 'done';
|
|
1265
1271
|
}
|
|
1266
1272
|
else if (status !== 'open') {
|
|
1267
1273
|
throw new BadRequest(this.id + ' fetchOrdersByStatus() can only fetch untriggered stop orders');
|
|
@@ -102,6 +102,9 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
102
102
|
};
|
|
103
103
|
const marketIds = [];
|
|
104
104
|
let messageHash = name;
|
|
105
|
+
if (symbols === undefined) {
|
|
106
|
+
symbols = [];
|
|
107
|
+
}
|
|
105
108
|
for (let i = 0; i < symbols.length; i++) {
|
|
106
109
|
const symbol = symbols[i];
|
|
107
110
|
marketIds.push(this.marketId(symbol));
|
|
@@ -167,6 +170,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
167
170
|
const method = this.safeString(this.options, 'watchTickerMethod', 'ticker'); // or ticker_lite
|
|
168
171
|
const name = this.safeString2(params, 'method', 'watchTickerMethod', method);
|
|
169
172
|
params = this.omit(params, ['watchTickerMethod', 'method']);
|
|
173
|
+
symbols = this.marketSymbols(symbols, undefined, false);
|
|
170
174
|
return await this.subscribePublic(name, symbols, params);
|
|
171
175
|
}
|
|
172
176
|
async watchTrades(symbol = undefined, since = undefined, limit = undefined, params = {}) {
|
|
@@ -318,7 +322,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
318
322
|
// }
|
|
319
323
|
//
|
|
320
324
|
const channel = this.safeString(message, 'feed');
|
|
321
|
-
const marketId = this.
|
|
325
|
+
const marketId = this.safeString(message, 'product_id');
|
|
322
326
|
if (marketId !== undefined) {
|
|
323
327
|
const market = this.market(marketId);
|
|
324
328
|
const symbol = market['symbol'];
|
|
@@ -359,7 +363,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
359
363
|
// "price": 34893
|
|
360
364
|
// }
|
|
361
365
|
//
|
|
362
|
-
const marketId = this.
|
|
366
|
+
const marketId = this.safeString(trade, 'product_id');
|
|
363
367
|
market = this.safeMarket(marketId, market);
|
|
364
368
|
const timestamp = this.safeInteger(trade, 'time');
|
|
365
369
|
return this.safeTrade({
|
|
@@ -412,7 +416,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
412
416
|
// }
|
|
413
417
|
//
|
|
414
418
|
const timestamp = this.safeInteger(trade, 'tradeTime');
|
|
415
|
-
const marketId = this.
|
|
419
|
+
const marketId = this.safeString(trade, 'symbol');
|
|
416
420
|
return this.safeTrade({
|
|
417
421
|
'info': trade,
|
|
418
422
|
'id': this.safeString(trade, 'tradeId'),
|
|
@@ -491,7 +495,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
491
495
|
}
|
|
492
496
|
const order = this.safeValue(message, 'order');
|
|
493
497
|
if (order !== undefined) {
|
|
494
|
-
const marketId = this.
|
|
498
|
+
const marketId = this.safeString(order, 'instrument');
|
|
495
499
|
const messageHash = 'orders';
|
|
496
500
|
const symbol = this.safeSymbol(marketId);
|
|
497
501
|
const orderId = this.safeString(order, 'order_id');
|
|
@@ -684,7 +688,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
684
688
|
status = 'cancelled';
|
|
685
689
|
}
|
|
686
690
|
}
|
|
687
|
-
const marketId = this.
|
|
691
|
+
const marketId = this.safeString(unparsedOrder, 'instrument');
|
|
688
692
|
const timestamp = this.safeString(unparsedOrder, 'time');
|
|
689
693
|
const direction = this.safeInteger(unparsedOrder, 'direction');
|
|
690
694
|
return this.safeOrder({
|
|
@@ -765,7 +769,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
765
769
|
// "volumeQuote": 6899673.0
|
|
766
770
|
// }
|
|
767
771
|
//
|
|
768
|
-
const marketId = this.
|
|
772
|
+
const marketId = this.safeString(message, 'product_id');
|
|
769
773
|
const feed = this.safeString(message, 'feed');
|
|
770
774
|
if (marketId !== undefined) {
|
|
771
775
|
const ticker = this.parseWsTicker(message);
|
|
@@ -826,7 +830,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
826
830
|
// "volumeQuote": 6899673.0
|
|
827
831
|
// }
|
|
828
832
|
//
|
|
829
|
-
const marketId = this.
|
|
833
|
+
const marketId = this.safeString(ticker, 'product_id');
|
|
830
834
|
market = this.safeMarket(marketId, market);
|
|
831
835
|
const symbol = market['symbol'];
|
|
832
836
|
const timestamp = this.parse8601(this.safeString(ticker, 'lastTime'));
|
|
@@ -884,7 +888,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
884
888
|
// ]
|
|
885
889
|
// }
|
|
886
890
|
//
|
|
887
|
-
const marketId = this.
|
|
891
|
+
const marketId = this.safeString(message, 'product_id');
|
|
888
892
|
const market = this.safeMarket(marketId);
|
|
889
893
|
const symbol = market['symbol'];
|
|
890
894
|
const messageHash = 'book:' + symbol;
|
|
@@ -924,7 +928,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
924
928
|
// "timestamp": 1612269953629
|
|
925
929
|
// }
|
|
926
930
|
//
|
|
927
|
-
const marketId = this.
|
|
931
|
+
const marketId = this.safeString(message, 'product_id');
|
|
928
932
|
const market = this.safeMarket(marketId);
|
|
929
933
|
const symbol = market['symbol'];
|
|
930
934
|
const messageHash = 'book:' + symbol;
|
|
@@ -1228,7 +1232,7 @@ export default class krakenfutures extends krakenfuturesRest {
|
|
|
1228
1232
|
// }
|
|
1229
1233
|
//
|
|
1230
1234
|
const timestamp = this.safeInteger(trade, 'time');
|
|
1231
|
-
const marketId = this.
|
|
1235
|
+
const marketId = this.safeString(trade, 'instrument');
|
|
1232
1236
|
market = this.safeMarket(marketId, market);
|
|
1233
1237
|
const isBuy = this.safeValue(trade, 'buy');
|
|
1234
1238
|
const feeCurrencyId = this.safeString(trade, 'fee_currency');
|
package/js/src/woo.js
CHANGED
package/package.json
CHANGED
package/skip-tests.json
CHANGED
|
@@ -660,8 +660,37 @@
|
|
|
660
660
|
"active":"is undefined",
|
|
661
661
|
"currencyIdAndCode": "from travis location (USA) these webapi endpoints cant be loaded"
|
|
662
662
|
},
|
|
663
|
-
"fetchTickers":
|
|
664
|
-
|
|
663
|
+
"fetchTickers": {
|
|
664
|
+
"timestamp": "timestamp might be of 1970-01-01T00:00:00.000Z",
|
|
665
|
+
"quoteVolume": "can't be infered"
|
|
666
|
+
},
|
|
667
|
+
"fetchTicker": {
|
|
668
|
+
"timestamp": "timestamp might be of 1970-01-01T00:00:00.000Z",
|
|
669
|
+
"quoteVolume": "can't be infered"
|
|
670
|
+
|
|
671
|
+
},
|
|
672
|
+
"fetchPositions": {
|
|
673
|
+
"entryPrice": "entryPrice is not provided",
|
|
674
|
+
"markPrice": "undefined",
|
|
675
|
+
"notional": "undefined",
|
|
676
|
+
"leverage": "undefined",
|
|
677
|
+
"liquidationPrice": "undefined",
|
|
678
|
+
"marginMode": "undefined",
|
|
679
|
+
"percentage": "undefined",
|
|
680
|
+
"marginRatio": "undefined",
|
|
681
|
+
"stopLossPrice": "undefined",
|
|
682
|
+
"takeProfitPrice": "undefined",
|
|
683
|
+
"maintenanceMargin": "undefined",
|
|
684
|
+
"initialMarginPercentage": "undefined",
|
|
685
|
+
"maintenanceMarginPercentage": "undefined",
|
|
686
|
+
"hedged": "undefined",
|
|
687
|
+
"side": "undefined",
|
|
688
|
+
"contracts": "undefined"
|
|
689
|
+
},
|
|
690
|
+
"fetchAccounts": {
|
|
691
|
+
"type": "type is not provided",
|
|
692
|
+
"code": "not provided"
|
|
693
|
+
}
|
|
665
694
|
}
|
|
666
695
|
},
|
|
667
696
|
"currencycom": {
|
|
@@ -1256,12 +1285,9 @@
|
|
|
1256
1285
|
},
|
|
1257
1286
|
"krakenfutures": {
|
|
1258
1287
|
"skip": "continious timeouts https://app.travis-ci.com/github/ccxt/ccxt/builds/265225134#L2431",
|
|
1288
|
+
"skipWs": true,
|
|
1259
1289
|
"skipMethods": {
|
|
1260
|
-
"loadMarkets":
|
|
1261
|
-
"type":"unexpected market type",
|
|
1262
|
-
"limits": "messed",
|
|
1263
|
-
"active":"is undefined"
|
|
1264
|
-
},
|
|
1290
|
+
"loadMarkets": "skip loadMarkets",
|
|
1265
1291
|
"fetchCurrencies": {
|
|
1266
1292
|
"withdraw": "undefined",
|
|
1267
1293
|
"deposit": "undefined"
|