ccxt 4.2.88__py2.py3-none-any.whl → 4.2.90__py2.py3-none-any.whl
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.
Potentially problematic release.
This version of ccxt might be problematic. Click here for more details.
- ccxt/__init__.py +1 -1
- ccxt/abstract/bingx.py +2 -0
- ccxt/abstract/bybit.py +2 -0
- ccxt/ascendex.py +6 -3
- ccxt/async_support/__init__.py +1 -1
- ccxt/async_support/ascendex.py +6 -3
- ccxt/async_support/base/exchange.py +15 -2
- ccxt/async_support/bigone.py +2 -2
- ccxt/async_support/binance.py +88 -14
- ccxt/async_support/bingx.py +96 -3
- ccxt/async_support/bit2c.py +2 -2
- ccxt/async_support/bitbank.py +2 -2
- ccxt/async_support/bitfinex.py +2 -2
- ccxt/async_support/bitfinex2.py +4 -3
- ccxt/async_support/bitflyer.py +4 -2
- ccxt/async_support/bitget.py +12 -5
- ccxt/async_support/bitmart.py +6 -4
- ccxt/async_support/bitmex.py +3 -2
- ccxt/async_support/bitopro.py +3 -3
- ccxt/async_support/bitrue.py +3 -2
- ccxt/async_support/bitso.py +2 -2
- ccxt/async_support/bitstamp.py +89 -97
- ccxt/async_support/bitteam.py +2 -2
- ccxt/async_support/bitvavo.py +3 -3
- ccxt/async_support/bl3p.py +2 -2
- ccxt/async_support/blockchaincom.py +2 -2
- ccxt/async_support/blofin.py +4 -2
- ccxt/async_support/bybit.py +57 -5
- ccxt/async_support/cex.py +3 -3
- ccxt/async_support/coinbase.py +42 -22
- ccxt/async_support/coinbaseinternational.py +3 -2
- ccxt/async_support/coinbasepro.py +3 -3
- ccxt/async_support/coincheck.py +2 -2
- ccxt/async_support/coinex.py +101 -13
- ccxt/async_support/coinlist.py +3 -3
- ccxt/async_support/coinmate.py +2 -2
- ccxt/async_support/coinmetro.py +2 -2
- ccxt/async_support/coinone.py +2 -2
- ccxt/async_support/coinsph.py +6 -4
- ccxt/async_support/cryptocom.py +1 -0
- ccxt/async_support/currencycom.py +3 -3
- ccxt/async_support/delta.py +3 -2
- ccxt/async_support/deribit.py +3 -3
- ccxt/async_support/digifinex.py +7 -4
- ccxt/async_support/exmo.py +4 -3
- ccxt/async_support/gate.py +8 -4
- ccxt/async_support/gemini.py +13 -12
- ccxt/async_support/hitbtc.py +8 -5
- ccxt/async_support/hollaex.py +3 -3
- ccxt/async_support/htx.py +7 -4
- ccxt/async_support/huobijp.py +2 -2
- ccxt/async_support/hyperliquid.py +3 -2
- ccxt/async_support/idex.py +3 -3
- ccxt/async_support/independentreserve.py +2 -2
- ccxt/async_support/kraken.py +3 -3
- ccxt/async_support/kucoin.py +43 -18
- ccxt/async_support/kucoinfutures.py +32 -4
- ccxt/async_support/kuna.py +2 -2
- ccxt/async_support/latoken.py +7 -3
- ccxt/async_support/lbank.py +7 -5
- ccxt/async_support/luno.py +4 -2
- ccxt/async_support/lykke.py +2 -2
- ccxt/async_support/mexc.py +57 -9
- ccxt/async_support/ndax.py +2 -2
- ccxt/async_support/oceanex.py +2 -2
- ccxt/async_support/okcoin.py +2 -2
- ccxt/async_support/okx.py +149 -12
- ccxt/async_support/onetrading.py +3 -3
- ccxt/async_support/phemex.py +3 -2
- ccxt/async_support/poloniex.py +3 -3
- ccxt/async_support/probit.py +2 -2
- ccxt/async_support/timex.py +6 -4
- ccxt/async_support/upbit.py +2 -2
- ccxt/async_support/wazirx.py +2 -2
- ccxt/async_support/whitebit.py +3 -3
- ccxt/async_support/woo.py +4 -3
- ccxt/async_support/yobit.py +2 -2
- ccxt/base/exchange.py +65 -12
- ccxt/base/types.py +33 -0
- ccxt/bigone.py +2 -2
- ccxt/binance.py +88 -14
- ccxt/bingx.py +96 -3
- ccxt/bit2c.py +2 -2
- ccxt/bitbank.py +2 -2
- ccxt/bitfinex.py +2 -2
- ccxt/bitfinex2.py +4 -3
- ccxt/bitflyer.py +4 -2
- ccxt/bitget.py +12 -5
- ccxt/bitmart.py +6 -4
- ccxt/bitmex.py +3 -2
- ccxt/bitopro.py +3 -3
- ccxt/bitrue.py +3 -2
- ccxt/bitso.py +2 -2
- ccxt/bitstamp.py +89 -97
- ccxt/bitteam.py +2 -2
- ccxt/bitvavo.py +3 -3
- ccxt/bl3p.py +2 -2
- ccxt/blockchaincom.py +2 -2
- ccxt/blofin.py +4 -2
- ccxt/bybit.py +57 -5
- ccxt/cex.py +3 -3
- ccxt/coinbase.py +42 -22
- ccxt/coinbaseinternational.py +3 -2
- ccxt/coinbasepro.py +3 -3
- ccxt/coincheck.py +2 -2
- ccxt/coinex.py +101 -13
- ccxt/coinlist.py +3 -3
- ccxt/coinmate.py +2 -2
- ccxt/coinmetro.py +2 -2
- ccxt/coinone.py +2 -2
- ccxt/coinsph.py +6 -4
- ccxt/cryptocom.py +1 -0
- ccxt/currencycom.py +3 -3
- ccxt/delta.py +3 -2
- ccxt/deribit.py +3 -3
- ccxt/digifinex.py +7 -4
- ccxt/exmo.py +4 -3
- ccxt/gate.py +8 -4
- ccxt/gemini.py +13 -12
- ccxt/hitbtc.py +8 -5
- ccxt/hollaex.py +3 -3
- ccxt/htx.py +7 -4
- ccxt/huobijp.py +2 -2
- ccxt/hyperliquid.py +3 -2
- ccxt/idex.py +3 -3
- ccxt/independentreserve.py +2 -2
- ccxt/kraken.py +3 -3
- ccxt/kucoin.py +43 -18
- ccxt/kucoinfutures.py +32 -4
- ccxt/kuna.py +2 -2
- ccxt/latoken.py +7 -3
- ccxt/lbank.py +7 -5
- ccxt/luno.py +4 -2
- ccxt/lykke.py +2 -2
- ccxt/mexc.py +57 -9
- ccxt/ndax.py +2 -2
- ccxt/oceanex.py +2 -2
- ccxt/okcoin.py +2 -2
- ccxt/okx.py +149 -12
- ccxt/onetrading.py +3 -3
- ccxt/phemex.py +3 -2
- ccxt/poloniex.py +3 -3
- ccxt/pro/__init__.py +1 -1
- ccxt/pro/bitget.py +2 -0
- ccxt/pro/bitvavo.py +2 -2
- ccxt/probit.py +2 -2
- ccxt/timex.py +6 -4
- ccxt/upbit.py +2 -2
- ccxt/wazirx.py +2 -2
- ccxt/whitebit.py +3 -3
- ccxt/woo.py +4 -3
- ccxt/yobit.py +2 -2
- {ccxt-4.2.88.dist-info → ccxt-4.2.90.dist-info}/METADATA +4 -4
- {ccxt-4.2.88.dist-info → ccxt-4.2.90.dist-info}/RECORD +156 -156
- {ccxt-4.2.88.dist-info → ccxt-4.2.90.dist-info}/WHEEL +0 -0
- {ccxt-4.2.88.dist-info → ccxt-4.2.90.dist-info}/top_level.txt +0 -0
ccxt/bitopro.py
CHANGED
@@ -7,7 +7,7 @@ from ccxt.base.exchange import Exchange
|
|
7
7
|
from ccxt.abstract.bitopro import ImplicitAPI
|
8
8
|
import hashlib
|
9
9
|
import math
|
10
|
-
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction
|
10
|
+
from ccxt.base.types import Balances, Currencies, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFees, Transaction
|
11
11
|
from typing import List
|
12
12
|
from ccxt.base.errors import ExchangeError
|
13
13
|
from ccxt.base.errors import ArgumentsRequired
|
@@ -220,7 +220,7 @@ class bitopro(Exchange, ImplicitAPI):
|
|
220
220
|
},
|
221
221
|
})
|
222
222
|
|
223
|
-
def fetch_currencies(self, params={}):
|
223
|
+
def fetch_currencies(self, params={}) -> Currencies:
|
224
224
|
"""
|
225
225
|
fetches all available currencies on an exchange
|
226
226
|
:see: https://github.com/bitoex/bitopro-offical-api-docs/blob/master/api/v3/public/get_currency_info.md
|
@@ -617,7 +617,7 @@ class bitopro(Exchange, ImplicitAPI):
|
|
617
617
|
#
|
618
618
|
return self.parse_trades(trades, market, since, limit)
|
619
619
|
|
620
|
-
def fetch_trading_fees(self, params={}):
|
620
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
621
621
|
"""
|
622
622
|
fetch the trading fees for multiple markets
|
623
623
|
:see: https://github.com/bitoex/bitopro-offical-api-docs/blob/master/api/v3/public/get_limitations_and_fees.md
|
ccxt/bitrue.py
CHANGED
@@ -7,7 +7,7 @@ from ccxt.base.exchange import Exchange
|
|
7
7
|
from ccxt.abstract.bitrue import ImplicitAPI
|
8
8
|
import hashlib
|
9
9
|
import json
|
10
|
-
from ccxt.base.types import Balances, Currency, Int, MarginModification, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
|
10
|
+
from ccxt.base.types import Balances, Currencies, Currency, Int, MarginModification, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
|
11
11
|
from typing import List
|
12
12
|
from ccxt.base.errors import ExchangeError
|
13
13
|
from ccxt.base.errors import PermissionDenied
|
@@ -592,7 +592,7 @@ class bitrue(Exchange, ImplicitAPI):
|
|
592
592
|
}
|
593
593
|
return self.safe_string_2(networksById, networkId, uppercaseNetworkId, networkId)
|
594
594
|
|
595
|
-
def fetch_currencies(self, params={}):
|
595
|
+
def fetch_currencies(self, params={}) -> Currencies:
|
596
596
|
"""
|
597
597
|
fetches all available currencies on an exchange
|
598
598
|
:param dict [params]: extra parameters specific to the exchange API endpoint
|
@@ -2852,6 +2852,7 @@ class bitrue(Exchange, ImplicitAPI):
|
|
2852
2852
|
'info': data,
|
2853
2853
|
'symbol': market['symbol'],
|
2854
2854
|
'type': None,
|
2855
|
+
'marginMode': 'isolated',
|
2855
2856
|
'amount': None,
|
2856
2857
|
'total': None,
|
2857
2858
|
'code': None,
|
ccxt/bitso.py
CHANGED
@@ -6,7 +6,7 @@
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.bitso import ImplicitAPI
|
8
8
|
import hashlib
|
9
|
-
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Trade, Transaction
|
9
|
+
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Trade, TradingFees, Transaction
|
10
10
|
from typing import List
|
11
11
|
from ccxt.base.errors import ExchangeError
|
12
12
|
from ccxt.base.errors import ArgumentsRequired
|
@@ -814,7 +814,7 @@ class bitso(Exchange, ImplicitAPI):
|
|
814
814
|
response = self.publicGetTrades(self.extend(request, params))
|
815
815
|
return self.parse_trades(response['payload'], market, since, limit)
|
816
816
|
|
817
|
-
def fetch_trading_fees(self, params={}):
|
817
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
818
818
|
"""
|
819
819
|
fetch the trading fees for multiple markets
|
820
820
|
:see: https://docs.bitso.com/bitso-api/docs/list-fees
|
ccxt/bitstamp.py
CHANGED
@@ -6,7 +6,7 @@
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.bitstamp import ImplicitAPI
|
8
8
|
import hashlib
|
9
|
-
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
|
9
|
+
from ccxt.base.types import Balances, Currencies, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFeeInterface, TradingFees, Transaction, TransferEntry
|
10
10
|
from typing import List
|
11
11
|
from ccxt.base.errors import ExchangeError
|
12
12
|
from ccxt.base.errors import PermissionDenied
|
@@ -441,6 +441,30 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
441
441
|
'commonCurrencies': {
|
442
442
|
'UST': 'USTC',
|
443
443
|
},
|
444
|
+
# exchange-specific options
|
445
|
+
'options': {
|
446
|
+
'networksById': {
|
447
|
+
'bitcoin-cash': 'BCH',
|
448
|
+
'bitcoin': 'BTC',
|
449
|
+
'ethereum': 'ERC20',
|
450
|
+
'litecoin': 'LTC',
|
451
|
+
'stellar': 'XLM',
|
452
|
+
'xrpl': 'XRP',
|
453
|
+
'tron': 'TRC20',
|
454
|
+
'algorand': 'ALGO',
|
455
|
+
'flare': 'FLR',
|
456
|
+
'hedera': 'HBAR',
|
457
|
+
'cardana': 'ADA',
|
458
|
+
'songbird': 'FLR',
|
459
|
+
'avalanche-c-chain': 'AVAX',
|
460
|
+
'solana': 'SOL',
|
461
|
+
'polkadot': 'DOT',
|
462
|
+
'near': 'NEAR',
|
463
|
+
'doge': 'DOGE',
|
464
|
+
'sui': 'SUI',
|
465
|
+
'casper': 'CSRP',
|
466
|
+
},
|
467
|
+
},
|
444
468
|
'exceptions': {
|
445
469
|
'exact': {
|
446
470
|
'No permission found': PermissionDenied,
|
@@ -607,7 +631,7 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
607
631
|
})
|
608
632
|
return self.safe_value(self.options['fetchMarkets'], 'response')
|
609
633
|
|
610
|
-
def fetch_currencies(self, params={}):
|
634
|
+
def fetch_currencies(self, params={}) -> Currencies:
|
611
635
|
"""
|
612
636
|
fetches all available currencies on an exchange
|
613
637
|
:see: https://www.bitstamp.net/api/#tag/Market-info/operation/GetTradingPairsInfo
|
@@ -1117,7 +1141,7 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
1117
1141
|
#
|
1118
1142
|
return self.parse_balance(response)
|
1119
1143
|
|
1120
|
-
def fetch_trading_fee(self, symbol: str, params={}):
|
1144
|
+
def fetch_trading_fee(self, symbol: str, params={}) -> TradingFeeInterface:
|
1121
1145
|
"""
|
1122
1146
|
fetch the trading fees for a market
|
1123
1147
|
:see: https://www.bitstamp.net/api/#tag/Fees/operation/GetTradingFeesForCurrency
|
@@ -1149,7 +1173,7 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
1149
1173
|
tradingFee = self.safe_dict(tradingFeesByMarketId, market['id'])
|
1150
1174
|
return self.parse_trading_fee(tradingFee, market)
|
1151
1175
|
|
1152
|
-
def parse_trading_fee(self, fee, market: Market = None):
|
1176
|
+
def parse_trading_fee(self, fee, market: Market = None) -> TradingFeeInterface:
|
1153
1177
|
marketId = self.safe_string(fee, 'market')
|
1154
1178
|
fees = self.safe_dict(fee, 'fees', {})
|
1155
1179
|
return {
|
@@ -1157,6 +1181,8 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
1157
1181
|
'symbol': self.safe_symbol(marketId, market),
|
1158
1182
|
'maker': self.safe_number(fees, 'maker'),
|
1159
1183
|
'taker': self.safe_number(fees, 'taker'),
|
1184
|
+
'percentage': None,
|
1185
|
+
'tierBased': None,
|
1160
1186
|
}
|
1161
1187
|
|
1162
1188
|
def parse_trading_fees(self, fees):
|
@@ -1168,7 +1194,7 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
1168
1194
|
result[symbol] = fee
|
1169
1195
|
return result
|
1170
1196
|
|
1171
|
-
def fetch_trading_fees(self, params={}):
|
1197
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
1172
1198
|
"""
|
1173
1199
|
fetch the trading fees for multiple markets
|
1174
1200
|
:see: https://www.bitstamp.net/api/#tag/Fees/operation/GetAllTradingFees
|
@@ -1197,58 +1223,43 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
1197
1223
|
"""
|
1198
1224
|
* @deprecated
|
1199
1225
|
please use fetchDepositWithdrawFees instead
|
1200
|
-
:see: https://www.bitstamp.net/api/#
|
1226
|
+
:see: https://www.bitstamp.net/api/#tag/Fees
|
1201
1227
|
:param str[]|None codes: list of unified currency codes
|
1202
1228
|
:param dict [params]: extra parameters specific to the exchange API endpoint
|
1203
1229
|
:returns dict[]: a list of `fee structures <https://docs.ccxt.com/#/?id=fee-structure>`
|
1204
1230
|
"""
|
1205
1231
|
self.load_markets()
|
1206
|
-
|
1207
|
-
|
1232
|
+
response = self.privatePostFeesWithdrawal(params)
|
1233
|
+
#
|
1234
|
+
# [
|
1235
|
+
# {
|
1236
|
+
# "currency": "btc",
|
1237
|
+
# "fee": "0.00015000",
|
1238
|
+
# "network": "bitcoin"
|
1239
|
+
# }
|
1240
|
+
# ...
|
1241
|
+
# ]
|
1242
|
+
#
|
1243
|
+
return self.parse_transaction_fees(response)
|
1208
1244
|
|
1209
1245
|
def parse_transaction_fees(self, response, codes=None):
|
1210
|
-
#
|
1211
|
-
# {
|
1212
|
-
# "yfi_available": "0.00000000",
|
1213
|
-
# "yfi_balance": "0.00000000",
|
1214
|
-
# "yfi_reserved": "0.00000000",
|
1215
|
-
# "yfi_withdrawal_fee": "0.00070000",
|
1216
|
-
# "yfieur_fee": "0.000",
|
1217
|
-
# "yfiusd_fee": "0.000",
|
1218
|
-
# "zrx_available": "0.00000000",
|
1219
|
-
# "zrx_balance": "0.00000000",
|
1220
|
-
# "zrx_reserved": "0.00000000",
|
1221
|
-
# "zrx_withdrawal_fee": "12.00000000",
|
1222
|
-
# "zrxeur_fee": "0.000",
|
1223
|
-
# "zrxusd_fee": "0.000",
|
1224
|
-
# ...
|
1225
|
-
# }
|
1226
|
-
#
|
1227
|
-
if codes is None:
|
1228
|
-
codes = list(self.currencies.keys())
|
1229
1246
|
result = {}
|
1230
|
-
|
1231
|
-
ids = list(
|
1247
|
+
currencies = self.index_by(response, 'currency')
|
1248
|
+
ids = list(currencies.keys())
|
1232
1249
|
for i in range(0, len(ids)):
|
1233
1250
|
id = ids[i]
|
1234
|
-
|
1235
|
-
code = self.safe_currency_code(
|
1236
|
-
if codes is not None and not self.in_array(code, codes):
|
1251
|
+
fees = self.safe_value(response, i, {})
|
1252
|
+
code = self.safe_currency_code(id)
|
1253
|
+
if (codes is not None) and not self.in_array(code, codes):
|
1237
1254
|
continue
|
1238
|
-
|
1239
|
-
|
1240
|
-
|
1241
|
-
|
1242
|
-
|
1243
|
-
'info': {},
|
1244
|
-
}
|
1245
|
-
if currencyId == mainCurrencyId:
|
1246
|
-
result[code]['info'][id] = self.safe_number(response, id)
|
1247
|
-
if id.find('_withdrawal_fee') >= 0:
|
1248
|
-
result[code]['withdraw'] = self.safe_number(response, id)
|
1255
|
+
result[code] = {
|
1256
|
+
'withdraw_fee': self.safe_number(fees, 'fee'),
|
1257
|
+
'deposit': {},
|
1258
|
+
'info': self.safe_dict(currencies, id),
|
1259
|
+
}
|
1249
1260
|
return result
|
1250
1261
|
|
1251
|
-
def fetch_deposit_withdraw_fees(self, codes
|
1262
|
+
def fetch_deposit_withdraw_fees(self, codes=None, params={}):
|
1252
1263
|
"""
|
1253
1264
|
fetch deposit and withdraw fees
|
1254
1265
|
:see: https://www.bitstamp.net/api/#tag/Fees/operation/GetAllWithdrawalFees
|
@@ -1257,60 +1268,41 @@ class bitstamp(Exchange, ImplicitAPI):
|
|
1257
1268
|
:returns dict[]: a list of `fee structures <https://docs.ccxt.com/#/?id=fee-structure>`
|
1258
1269
|
"""
|
1259
1270
|
self.load_markets()
|
1260
|
-
response = self.
|
1261
|
-
#
|
1262
|
-
# {
|
1263
|
-
# "yfi_available": "0.00000000",
|
1264
|
-
# "yfi_balance": "0.00000000",
|
1265
|
-
# "yfi_reserved": "0.00000000",
|
1266
|
-
# "yfi_withdrawal_fee": "0.00070000",
|
1267
|
-
# "yfieur_fee": "0.000",
|
1268
|
-
# "yfiusd_fee": "0.000",
|
1269
|
-
# "zrx_available": "0.00000000",
|
1270
|
-
# "zrx_balance": "0.00000000",
|
1271
|
-
# "zrx_reserved": "0.00000000",
|
1272
|
-
# "zrx_withdrawal_fee": "12.00000000",
|
1273
|
-
# "zrxeur_fee": "0.000",
|
1274
|
-
# "zrxusd_fee": "0.000",
|
1275
|
-
# ...
|
1276
|
-
# }
|
1277
|
-
#
|
1278
|
-
return self.parse_deposit_withdraw_fees(response, codes)
|
1279
|
-
|
1280
|
-
def parse_deposit_withdraw_fees(self, response, codes=None, currencyIdKey=None):
|
1281
|
-
#
|
1282
|
-
# {
|
1283
|
-
# "yfi_available": "0.00000000",
|
1284
|
-
# "yfi_balance": "0.00000000",
|
1285
|
-
# "yfi_reserved": "0.00000000",
|
1286
|
-
# "yfi_withdrawal_fee": "0.00070000",
|
1287
|
-
# "yfieur_fee": "0.000",
|
1288
|
-
# "yfiusd_fee": "0.000",
|
1289
|
-
# "zrx_available": "0.00000000",
|
1290
|
-
# "zrx_balance": "0.00000000",
|
1291
|
-
# "zrx_reserved": "0.00000000",
|
1292
|
-
# "zrx_withdrawal_fee": "12.00000000",
|
1293
|
-
# "zrxeur_fee": "0.000",
|
1294
|
-
# "zrxusd_fee": "0.000",
|
1295
|
-
# ...
|
1296
|
-
# }
|
1271
|
+
response = self.privatePostFeesWithdrawal(params)
|
1297
1272
|
#
|
1298
|
-
|
1299
|
-
|
1300
|
-
|
1301
|
-
|
1302
|
-
|
1303
|
-
|
1304
|
-
|
1305
|
-
|
1306
|
-
|
1307
|
-
|
1308
|
-
|
1309
|
-
|
1310
|
-
|
1311
|
-
|
1312
|
-
|
1313
|
-
|
1273
|
+
# [
|
1274
|
+
# {
|
1275
|
+
# "currency": "btc",
|
1276
|
+
# "fee": "0.00015000",
|
1277
|
+
# "network": "bitcoin"
|
1278
|
+
# }
|
1279
|
+
# ...
|
1280
|
+
# ]
|
1281
|
+
#
|
1282
|
+
responseByCurrencyId = self.group_by(response, 'currency')
|
1283
|
+
return self.parse_deposit_withdraw_fees(responseByCurrencyId, codes)
|
1284
|
+
|
1285
|
+
def parse_deposit_withdraw_fee(self, fee, currency=None):
|
1286
|
+
result = self.deposit_withdraw_fee(fee)
|
1287
|
+
for j in range(0, len(fee)):
|
1288
|
+
networkEntry = fee[j]
|
1289
|
+
networkId = self.safe_string(networkEntry, 'network')
|
1290
|
+
networkCode = self.network_id_to_code(networkId)
|
1291
|
+
withdrawFee = self.safe_number(networkEntry, 'fee')
|
1292
|
+
result['withdraw'] = {
|
1293
|
+
'fee': withdrawFee,
|
1294
|
+
'percentage': None,
|
1295
|
+
}
|
1296
|
+
result['networks'][networkCode] = {
|
1297
|
+
'withdraw': {
|
1298
|
+
'fee': withdrawFee,
|
1299
|
+
'percentage': None,
|
1300
|
+
},
|
1301
|
+
'deposit': {
|
1302
|
+
'fee': None,
|
1303
|
+
'percentage': None,
|
1304
|
+
},
|
1305
|
+
}
|
1314
1306
|
return result
|
1315
1307
|
|
1316
1308
|
def create_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={}):
|
ccxt/bitteam.py
CHANGED
@@ -5,7 +5,7 @@
|
|
5
5
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.bitteam import ImplicitAPI
|
8
|
-
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction
|
8
|
+
from ccxt.base.types import Balances, Currencies, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction
|
9
9
|
from typing import List
|
10
10
|
from ccxt.base.errors import ExchangeError
|
11
11
|
from ccxt.base.errors import ArgumentsRequired
|
@@ -415,7 +415,7 @@ class bitteam(Exchange, ImplicitAPI):
|
|
415
415
|
'info': market,
|
416
416
|
})
|
417
417
|
|
418
|
-
def fetch_currencies(self, params={}):
|
418
|
+
def fetch_currencies(self, params={}) -> Currencies:
|
419
419
|
"""
|
420
420
|
fetches all available currencies on an exchange
|
421
421
|
:see: https://bit.team/trade/api/documentation#/PUBLIC/getTradeApiCurrencies
|
ccxt/bitvavo.py
CHANGED
@@ -6,7 +6,7 @@
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.bitvavo import ImplicitAPI
|
8
8
|
import hashlib
|
9
|
-
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction
|
9
|
+
from ccxt.base.types import Balances, Currencies, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFees, Transaction
|
10
10
|
from typing import List
|
11
11
|
from ccxt.base.errors import ExchangeError
|
12
12
|
from ccxt.base.errors import PermissionDenied
|
@@ -414,7 +414,7 @@ class bitvavo(Exchange, ImplicitAPI):
|
|
414
414
|
}))
|
415
415
|
return result
|
416
416
|
|
417
|
-
def fetch_currencies(self, params={}):
|
417
|
+
def fetch_currencies(self, params={}) -> Currencies:
|
418
418
|
"""
|
419
419
|
:see: https://docs.bitvavo.com/#tag/General/paths/~1assets/get
|
420
420
|
fetches all available currencies on an exchange
|
@@ -805,7 +805,7 @@ class bitvavo(Exchange, ImplicitAPI):
|
|
805
805
|
'fee': fee,
|
806
806
|
}, market)
|
807
807
|
|
808
|
-
def fetch_trading_fees(self, params={}):
|
808
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
809
809
|
"""
|
810
810
|
:see: https://docs.bitvavo.com/#tag/Account/paths/~1account/get
|
811
811
|
fetch the trading fees for multiple markets
|
ccxt/bl3p.py
CHANGED
@@ -6,7 +6,7 @@
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.bl3p import ImplicitAPI
|
8
8
|
import hashlib
|
9
|
-
from ccxt.base.types import Balances, Currency, IndexType, Int, Market, Num, OrderBook, OrderSide, OrderType, Str, Ticker, Trade
|
9
|
+
from ccxt.base.types import Balances, Currency, IndexType, Int, Market, Num, OrderBook, OrderSide, OrderType, Str, Ticker, Trade, TradingFees
|
10
10
|
from typing import List
|
11
11
|
from ccxt.base.decimal_to_precision import TICK_SIZE
|
12
12
|
from ccxt.base.precise import Precise
|
@@ -311,7 +311,7 @@ class bl3p(Exchange, ImplicitAPI):
|
|
311
311
|
result = self.parse_trades(response['data']['trades'], market, since, limit)
|
312
312
|
return result
|
313
313
|
|
314
|
-
def fetch_trading_fees(self, params={}):
|
314
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
315
315
|
"""
|
316
316
|
fetch the trading fees for multiple markets
|
317
317
|
:see: https://github.com/BitonicNL/bl3p-api/blob/master/docs/authenticated_api/http.md#35---get-account-info--balance
|
ccxt/blockchaincom.py
CHANGED
@@ -5,7 +5,7 @@
|
|
5
5
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.blockchaincom import ImplicitAPI
|
8
|
-
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction
|
8
|
+
from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFees, Transaction
|
9
9
|
from typing import List
|
10
10
|
from ccxt.base.errors import ExchangeError
|
11
11
|
from ccxt.base.errors import ArgumentsRequired
|
@@ -617,7 +617,7 @@ class blockchaincom(Exchange, ImplicitAPI):
|
|
617
617
|
'info': response,
|
618
618
|
}
|
619
619
|
|
620
|
-
def fetch_trading_fees(self, params={}):
|
620
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
621
621
|
"""
|
622
622
|
fetch the trading fees for multiple markets
|
623
623
|
:see: https://api.blockchain.com/v3/#/trading/getFees
|
ccxt/blofin.py
CHANGED
@@ -6,7 +6,7 @@
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.blofin import ImplicitAPI
|
8
8
|
import hashlib
|
9
|
-
from ccxt.base.types import Balances, Currency, Int, Leverage, Leverages, MarginMode, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
|
9
|
+
from ccxt.base.types import Balances, Currency, Int, Leverage, Leverages, MarginMode, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, Trade, TradingFeeInterface, Transaction, TransferEntry
|
10
10
|
from typing import List
|
11
11
|
from ccxt.base.errors import ExchangeError
|
12
12
|
from ccxt.base.errors import ArgumentsRequired
|
@@ -906,13 +906,15 @@ class blofin(Exchange, ImplicitAPI):
|
|
906
906
|
result[code] = account
|
907
907
|
return self.safe_balance(result)
|
908
908
|
|
909
|
-
def parse_trading_fee(self, fee, market: Market = None):
|
909
|
+
def parse_trading_fee(self, fee, market: Market = None) -> TradingFeeInterface:
|
910
910
|
return {
|
911
911
|
'info': fee,
|
912
912
|
'symbol': self.safe_symbol(None, market),
|
913
913
|
# blofin returns the fees values opposed to other exchanges, so the sign needs to be flipped
|
914
914
|
'maker': self.parse_number(Precise.string_neg(self.safe_string_2(fee, 'maker', 'makerU'))),
|
915
915
|
'taker': self.parse_number(Precise.string_neg(self.safe_string_2(fee, 'taker', 'takerU'))),
|
916
|
+
'percentage': None,
|
917
|
+
'tierBased': None,
|
916
918
|
}
|
917
919
|
|
918
920
|
def fetch_balance(self, params={}) -> Balances:
|
ccxt/bybit.py
CHANGED
@@ -6,7 +6,7 @@
|
|
6
6
|
from ccxt.base.exchange import Exchange
|
7
7
|
from ccxt.abstract.bybit import ImplicitAPI
|
8
8
|
import hashlib
|
9
|
-
from ccxt.base.types import Balances, Currency, Greeks, Int, Leverage, Market, MarketInterface, Num, Option, OptionChain, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
|
9
|
+
from ccxt.base.types import Balances, Currencies, Currency, Greeks, Int, Leverage, Market, MarketInterface, Num, Option, OptionChain, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFeeInterface, TradingFees, Transaction, TransferEntry
|
10
10
|
from typing import List
|
11
11
|
from ccxt.base.errors import ExchangeError
|
12
12
|
from ccxt.base.errors import PermissionDenied
|
@@ -95,6 +95,7 @@ class bybit(Exchange, ImplicitAPI):
|
|
95
95
|
'fetchLedger': True,
|
96
96
|
'fetchLeverage': True,
|
97
97
|
'fetchLeverageTiers': True,
|
98
|
+
'fetchMarginAdjustmentHistory': False,
|
98
99
|
'fetchMarketLeverageTiers': True,
|
99
100
|
'fetchMarkets': True,
|
100
101
|
'fetchMarkOHLCV': True,
|
@@ -165,6 +166,13 @@ class bybit(Exchange, ImplicitAPI):
|
|
165
166
|
'public': 'https://api.{hostname}',
|
166
167
|
'private': 'https://api.{hostname}',
|
167
168
|
},
|
169
|
+
'demotrading': {
|
170
|
+
'spot': 'https://api-demo.{hostname}',
|
171
|
+
'futures': 'https://api-demo.{hostname}',
|
172
|
+
'v2': 'https://api-demo.{hostname}',
|
173
|
+
'public': 'https://api-demo.{hostname}',
|
174
|
+
'private': 'https://api-demo.{hostname}',
|
175
|
+
},
|
168
176
|
'www': 'https://www.bybit.com',
|
169
177
|
'doc': [
|
170
178
|
'https://bybit-exchange.github.io/docs/inverse/',
|
@@ -353,6 +361,7 @@ class bybit(Exchange, ImplicitAPI):
|
|
353
361
|
'v5/user/get-member-type': 5,
|
354
362
|
'v5/user/aff-customer-info': 5,
|
355
363
|
'v5/user/del-submember': 5,
|
364
|
+
'v5/user/submembers': 5,
|
356
365
|
# spot leverage token
|
357
366
|
'v5/spot-lever-token/order-record': 1, # 50/s => cost = 50 / 50 = 1
|
358
367
|
# spot margin trade
|
@@ -513,6 +522,8 @@ class bybit(Exchange, ImplicitAPI):
|
|
513
522
|
'v5/lending/redeem-cancel': 5,
|
514
523
|
'v5/account/set-collateral-switch': 5,
|
515
524
|
'v5/account/set-collateral-switch-batch': 5,
|
525
|
+
# demo trading
|
526
|
+
'v5/account/demo-apply-money': 5,
|
516
527
|
},
|
517
528
|
},
|
518
529
|
},
|
@@ -979,6 +990,8 @@ class bybit(Exchange, ImplicitAPI):
|
|
979
990
|
},
|
980
991
|
'precisionMode': TICK_SIZE,
|
981
992
|
'options': {
|
993
|
+
'sandboxMode': False,
|
994
|
+
'enableDemoTrading': False,
|
982
995
|
'fetchMarkets': ['spot', 'linear', 'inverse', 'option'],
|
983
996
|
'createOrder': {
|
984
997
|
'method': 'privatePostV5OrderCreate', # 'privatePostV5PositionTradingStop'
|
@@ -1062,6 +1075,32 @@ class bybit(Exchange, ImplicitAPI):
|
|
1062
1075
|
},
|
1063
1076
|
})
|
1064
1077
|
|
1078
|
+
def set_sandbox_mode(self, enable: bool):
|
1079
|
+
"""
|
1080
|
+
enables or disables sandbox mode
|
1081
|
+
:param boolean [enable]: True if demo trading should be enabled, False otherwise
|
1082
|
+
"""
|
1083
|
+
super(bybit, self).set_sandbox_mode(enable)
|
1084
|
+
self.options['sandboxMode'] = enable
|
1085
|
+
|
1086
|
+
def enable_demo_trading(self, enable: bool):
|
1087
|
+
"""
|
1088
|
+
enables or disables demo trading mode
|
1089
|
+
:see: https://bybit-exchange.github.io/docs/v5/demo
|
1090
|
+
:param boolean [enable]: True if demo trading should be enabled, False otherwise
|
1091
|
+
"""
|
1092
|
+
if self.options['sandboxMode']:
|
1093
|
+
raise NotSupported(self.id + ' demo trading does not support in sandbox environment')
|
1094
|
+
# enable demo trading in bybit, see: https://bybit-exchange.github.io/docs/v5/demo
|
1095
|
+
if enable:
|
1096
|
+
self.urls['apiBackupDemoTrading'] = self.urls['api']
|
1097
|
+
self.urls['api'] = self.urls['demotrading']
|
1098
|
+
elif 'apiBackupDemoTrading' in self.urls:
|
1099
|
+
self.urls['api'] = self.urls['apiBackupDemoTrading']
|
1100
|
+
newUrls = self.omit(self.urls, 'apiBackupDemoTrading')
|
1101
|
+
self.urls = newUrls
|
1102
|
+
self.options['enableDemoTrading'] = enable
|
1103
|
+
|
1065
1104
|
def nonce(self):
|
1066
1105
|
return self.milliseconds() - self.options['timeDifference']
|
1067
1106
|
|
@@ -1077,12 +1116,21 @@ class bybit(Exchange, ImplicitAPI):
|
|
1077
1116
|
return data
|
1078
1117
|
|
1079
1118
|
def is_unified_enabled(self, params={}):
|
1119
|
+
"""
|
1120
|
+
returns [enableUnifiedMargin, enableUnifiedAccount] so the user can check if unified account is enabled
|
1121
|
+
"""
|
1080
1122
|
# The API key of user id must own one of permissions will be allowed to call following API endpoints.
|
1081
1123
|
# SUB UID: "Account Transfer"
|
1082
1124
|
# MASTER UID: "Account Transfer", "Subaccount Transfer", "Withdrawal"
|
1083
1125
|
enableUnifiedMargin = self.safe_value(self.options, 'enableUnifiedMargin')
|
1084
1126
|
enableUnifiedAccount = self.safe_value(self.options, 'enableUnifiedAccount')
|
1085
1127
|
if enableUnifiedMargin is None or enableUnifiedAccount is None:
|
1128
|
+
if self.options['enableDemoTrading']:
|
1129
|
+
# info endpoint is not available in demo trading
|
1130
|
+
# so we're assuming UTA is enabled
|
1131
|
+
self.options['enableUnifiedMargin'] = False
|
1132
|
+
self.options['enableUnifiedAccount'] = True
|
1133
|
+
return [self.options['enableUnifiedMargin'], self.options['enableUnifiedAccount']]
|
1086
1134
|
response = self.privateGetV5UserQueryApi(params)
|
1087
1135
|
#
|
1088
1136
|
# {
|
@@ -1233,7 +1281,7 @@ class bybit(Exchange, ImplicitAPI):
|
|
1233
1281
|
#
|
1234
1282
|
return self.safe_integer(response, 'time')
|
1235
1283
|
|
1236
|
-
def fetch_currencies(self, params={}):
|
1284
|
+
def fetch_currencies(self, params={}) -> Currencies:
|
1237
1285
|
"""
|
1238
1286
|
fetches all available currencies on an exchange
|
1239
1287
|
:see: https://bybit-exchange.github.io/docs/v5/asset/coin-info
|
@@ -1242,6 +1290,8 @@ class bybit(Exchange, ImplicitAPI):
|
|
1242
1290
|
"""
|
1243
1291
|
if not self.check_required_credentials(False):
|
1244
1292
|
return None
|
1293
|
+
if self.options['enableDemoTrading']:
|
1294
|
+
return None
|
1245
1295
|
response = self.privateGetV5AssetCoinQueryInfo(params)
|
1246
1296
|
#
|
1247
1297
|
# {
|
@@ -6736,7 +6786,7 @@ class bybit(Exchange, ImplicitAPI):
|
|
6736
6786
|
request['symbol'] = market['id']
|
6737
6787
|
return self.fetch_derivatives_market_leverage_tiers(symbol, params)
|
6738
6788
|
|
6739
|
-
def parse_trading_fee(self, fee, market: Market = None):
|
6789
|
+
def parse_trading_fee(self, fee, market: Market = None) -> TradingFeeInterface:
|
6740
6790
|
#
|
6741
6791
|
# {
|
6742
6792
|
# "symbol": "ETHUSDT",
|
@@ -6752,9 +6802,11 @@ class bybit(Exchange, ImplicitAPI):
|
|
6752
6802
|
'symbol': symbol,
|
6753
6803
|
'maker': self.safe_number(fee, 'makerFeeRate'),
|
6754
6804
|
'taker': self.safe_number(fee, 'takerFeeRate'),
|
6805
|
+
'percentage': None,
|
6806
|
+
'tierBased': None,
|
6755
6807
|
}
|
6756
6808
|
|
6757
|
-
def fetch_trading_fee(self, symbol: str, params={}):
|
6809
|
+
def fetch_trading_fee(self, symbol: str, params={}) -> TradingFeeInterface:
|
6758
6810
|
"""
|
6759
6811
|
fetch the trading fees for a market
|
6760
6812
|
:see: https://bybit-exchange.github.io/docs/v5/account/fee-rate
|
@@ -6800,7 +6852,7 @@ class bybit(Exchange, ImplicitAPI):
|
|
6800
6852
|
first = self.safe_value(fees, 0, {})
|
6801
6853
|
return self.parse_trading_fee(first, market)
|
6802
6854
|
|
6803
|
-
def fetch_trading_fees(self, params={}):
|
6855
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
6804
6856
|
"""
|
6805
6857
|
fetch the trading fees for multiple markets
|
6806
6858
|
:see: https://bybit-exchange.github.io/docs/v5/account/fee-rate
|
ccxt/cex.py
CHANGED
@@ -7,7 +7,7 @@ from ccxt.base.exchange import Exchange
|
|
7
7
|
from ccxt.abstract.cex import ImplicitAPI
|
8
8
|
import hashlib
|
9
9
|
import json
|
10
|
-
from ccxt.base.types import Balances, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade
|
10
|
+
from ccxt.base.types import Balances, Currencies, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFees
|
11
11
|
from typing import List
|
12
12
|
from ccxt.base.errors import ExchangeError
|
13
13
|
from ccxt.base.errors import ArgumentsRequired
|
@@ -237,7 +237,7 @@ class cex(Exchange, ImplicitAPI):
|
|
237
237
|
})
|
238
238
|
return self.safe_value(self.options['fetchCurrencies'], 'response')
|
239
239
|
|
240
|
-
def fetch_currencies(self, params={}):
|
240
|
+
def fetch_currencies(self, params={}) -> Currencies:
|
241
241
|
"""
|
242
242
|
fetches all available currencies on an exchange
|
243
243
|
:param dict [params]: extra parameters specific to the exchange API endpoint
|
@@ -681,7 +681,7 @@ class cex(Exchange, ImplicitAPI):
|
|
681
681
|
response = self.publicGetTradeHistoryPair(self.extend(request, params))
|
682
682
|
return self.parse_trades(response, market, since, limit)
|
683
683
|
|
684
|
-
def fetch_trading_fees(self, params={}):
|
684
|
+
def fetch_trading_fees(self, params={}) -> TradingFees:
|
685
685
|
"""
|
686
686
|
:see: https://docs.cex.io/#get-my-fee
|
687
687
|
fetch the trading fees for multiple markets
|