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.

Files changed (156) hide show
  1. ccxt/__init__.py +1 -1
  2. ccxt/abstract/bingx.py +2 -0
  3. ccxt/abstract/bybit.py +2 -0
  4. ccxt/ascendex.py +6 -3
  5. ccxt/async_support/__init__.py +1 -1
  6. ccxt/async_support/ascendex.py +6 -3
  7. ccxt/async_support/base/exchange.py +15 -2
  8. ccxt/async_support/bigone.py +2 -2
  9. ccxt/async_support/binance.py +88 -14
  10. ccxt/async_support/bingx.py +96 -3
  11. ccxt/async_support/bit2c.py +2 -2
  12. ccxt/async_support/bitbank.py +2 -2
  13. ccxt/async_support/bitfinex.py +2 -2
  14. ccxt/async_support/bitfinex2.py +4 -3
  15. ccxt/async_support/bitflyer.py +4 -2
  16. ccxt/async_support/bitget.py +12 -5
  17. ccxt/async_support/bitmart.py +6 -4
  18. ccxt/async_support/bitmex.py +3 -2
  19. ccxt/async_support/bitopro.py +3 -3
  20. ccxt/async_support/bitrue.py +3 -2
  21. ccxt/async_support/bitso.py +2 -2
  22. ccxt/async_support/bitstamp.py +89 -97
  23. ccxt/async_support/bitteam.py +2 -2
  24. ccxt/async_support/bitvavo.py +3 -3
  25. ccxt/async_support/bl3p.py +2 -2
  26. ccxt/async_support/blockchaincom.py +2 -2
  27. ccxt/async_support/blofin.py +4 -2
  28. ccxt/async_support/bybit.py +57 -5
  29. ccxt/async_support/cex.py +3 -3
  30. ccxt/async_support/coinbase.py +42 -22
  31. ccxt/async_support/coinbaseinternational.py +3 -2
  32. ccxt/async_support/coinbasepro.py +3 -3
  33. ccxt/async_support/coincheck.py +2 -2
  34. ccxt/async_support/coinex.py +101 -13
  35. ccxt/async_support/coinlist.py +3 -3
  36. ccxt/async_support/coinmate.py +2 -2
  37. ccxt/async_support/coinmetro.py +2 -2
  38. ccxt/async_support/coinone.py +2 -2
  39. ccxt/async_support/coinsph.py +6 -4
  40. ccxt/async_support/cryptocom.py +1 -0
  41. ccxt/async_support/currencycom.py +3 -3
  42. ccxt/async_support/delta.py +3 -2
  43. ccxt/async_support/deribit.py +3 -3
  44. ccxt/async_support/digifinex.py +7 -4
  45. ccxt/async_support/exmo.py +4 -3
  46. ccxt/async_support/gate.py +8 -4
  47. ccxt/async_support/gemini.py +13 -12
  48. ccxt/async_support/hitbtc.py +8 -5
  49. ccxt/async_support/hollaex.py +3 -3
  50. ccxt/async_support/htx.py +7 -4
  51. ccxt/async_support/huobijp.py +2 -2
  52. ccxt/async_support/hyperliquid.py +3 -2
  53. ccxt/async_support/idex.py +3 -3
  54. ccxt/async_support/independentreserve.py +2 -2
  55. ccxt/async_support/kraken.py +3 -3
  56. ccxt/async_support/kucoin.py +43 -18
  57. ccxt/async_support/kucoinfutures.py +32 -4
  58. ccxt/async_support/kuna.py +2 -2
  59. ccxt/async_support/latoken.py +7 -3
  60. ccxt/async_support/lbank.py +7 -5
  61. ccxt/async_support/luno.py +4 -2
  62. ccxt/async_support/lykke.py +2 -2
  63. ccxt/async_support/mexc.py +57 -9
  64. ccxt/async_support/ndax.py +2 -2
  65. ccxt/async_support/oceanex.py +2 -2
  66. ccxt/async_support/okcoin.py +2 -2
  67. ccxt/async_support/okx.py +149 -12
  68. ccxt/async_support/onetrading.py +3 -3
  69. ccxt/async_support/phemex.py +3 -2
  70. ccxt/async_support/poloniex.py +3 -3
  71. ccxt/async_support/probit.py +2 -2
  72. ccxt/async_support/timex.py +6 -4
  73. ccxt/async_support/upbit.py +2 -2
  74. ccxt/async_support/wazirx.py +2 -2
  75. ccxt/async_support/whitebit.py +3 -3
  76. ccxt/async_support/woo.py +4 -3
  77. ccxt/async_support/yobit.py +2 -2
  78. ccxt/base/exchange.py +65 -12
  79. ccxt/base/types.py +33 -0
  80. ccxt/bigone.py +2 -2
  81. ccxt/binance.py +88 -14
  82. ccxt/bingx.py +96 -3
  83. ccxt/bit2c.py +2 -2
  84. ccxt/bitbank.py +2 -2
  85. ccxt/bitfinex.py +2 -2
  86. ccxt/bitfinex2.py +4 -3
  87. ccxt/bitflyer.py +4 -2
  88. ccxt/bitget.py +12 -5
  89. ccxt/bitmart.py +6 -4
  90. ccxt/bitmex.py +3 -2
  91. ccxt/bitopro.py +3 -3
  92. ccxt/bitrue.py +3 -2
  93. ccxt/bitso.py +2 -2
  94. ccxt/bitstamp.py +89 -97
  95. ccxt/bitteam.py +2 -2
  96. ccxt/bitvavo.py +3 -3
  97. ccxt/bl3p.py +2 -2
  98. ccxt/blockchaincom.py +2 -2
  99. ccxt/blofin.py +4 -2
  100. ccxt/bybit.py +57 -5
  101. ccxt/cex.py +3 -3
  102. ccxt/coinbase.py +42 -22
  103. ccxt/coinbaseinternational.py +3 -2
  104. ccxt/coinbasepro.py +3 -3
  105. ccxt/coincheck.py +2 -2
  106. ccxt/coinex.py +101 -13
  107. ccxt/coinlist.py +3 -3
  108. ccxt/coinmate.py +2 -2
  109. ccxt/coinmetro.py +2 -2
  110. ccxt/coinone.py +2 -2
  111. ccxt/coinsph.py +6 -4
  112. ccxt/cryptocom.py +1 -0
  113. ccxt/currencycom.py +3 -3
  114. ccxt/delta.py +3 -2
  115. ccxt/deribit.py +3 -3
  116. ccxt/digifinex.py +7 -4
  117. ccxt/exmo.py +4 -3
  118. ccxt/gate.py +8 -4
  119. ccxt/gemini.py +13 -12
  120. ccxt/hitbtc.py +8 -5
  121. ccxt/hollaex.py +3 -3
  122. ccxt/htx.py +7 -4
  123. ccxt/huobijp.py +2 -2
  124. ccxt/hyperliquid.py +3 -2
  125. ccxt/idex.py +3 -3
  126. ccxt/independentreserve.py +2 -2
  127. ccxt/kraken.py +3 -3
  128. ccxt/kucoin.py +43 -18
  129. ccxt/kucoinfutures.py +32 -4
  130. ccxt/kuna.py +2 -2
  131. ccxt/latoken.py +7 -3
  132. ccxt/lbank.py +7 -5
  133. ccxt/luno.py +4 -2
  134. ccxt/lykke.py +2 -2
  135. ccxt/mexc.py +57 -9
  136. ccxt/ndax.py +2 -2
  137. ccxt/oceanex.py +2 -2
  138. ccxt/okcoin.py +2 -2
  139. ccxt/okx.py +149 -12
  140. ccxt/onetrading.py +3 -3
  141. ccxt/phemex.py +3 -2
  142. ccxt/poloniex.py +3 -3
  143. ccxt/pro/__init__.py +1 -1
  144. ccxt/pro/bitget.py +2 -0
  145. ccxt/pro/bitvavo.py +2 -2
  146. ccxt/probit.py +2 -2
  147. ccxt/timex.py +6 -4
  148. ccxt/upbit.py +2 -2
  149. ccxt/wazirx.py +2 -2
  150. ccxt/whitebit.py +3 -3
  151. ccxt/woo.py +4 -3
  152. ccxt/yobit.py +2 -2
  153. {ccxt-4.2.88.dist-info → ccxt-4.2.90.dist-info}/METADATA +4 -4
  154. {ccxt-4.2.88.dist-info → ccxt-4.2.90.dist-info}/RECORD +156 -156
  155. {ccxt-4.2.88.dist-info → ccxt-4.2.90.dist-info}/WHEEL +0 -0
  156. {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/#balance
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
- balance = self.privatePostBalance(params)
1207
- return self.parse_transaction_fees(balance)
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
- mainCurrencyId = None
1231
- ids = list(response.keys())
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
- currencyId = id.split('_')[0]
1235
- code = self.safe_currency_code(currencyId)
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
- if id.find('_available') >= 0:
1239
- mainCurrencyId = currencyId
1240
- result[code] = {
1241
- 'deposit': None,
1242
- 'withdraw': None,
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: Strings = None, params={}):
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.privatePostBalance(params)
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
- result = {}
1299
- ids = list(response.keys())
1300
- for i in range(0, len(ids)):
1301
- id = ids[i]
1302
- currencyId = id.split('_')[0]
1303
- code = self.safe_currency_code(currencyId)
1304
- dictValue = self.safe_number(response, id)
1305
- if codes is not None and not self.in_array(code, codes):
1306
- continue
1307
- if id.find('_available') >= 0:
1308
- result[code] = self.deposit_withdraw_fee({})
1309
- if id.find('_withdrawal_fee') >= 0:
1310
- result[code]['withdraw']['fee'] = dictValue
1311
- resultValue = self.safe_value(result, code)
1312
- if resultValue is not None:
1313
- result[code]['info'][id] = dictValue
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