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
@@ -8,7 +8,7 @@ from ccxt.abstract.bitget import ImplicitAPI
8
8
  import asyncio
9
9
  import hashlib
10
10
  import json
11
- from ccxt.base.types import Balances, Currency, FundingHistory, Int, Liquidation, Leverage, MarginMode, MarginModification, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
11
+ from ccxt.base.types import Balances, Currencies, Currency, FundingHistory, Int, Liquidation, Leverage, MarginMode, MarginModification, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, Trade, TradingFeeInterface, TradingFees, Transaction, TransferEntry
12
12
  from typing import List
13
13
  from ccxt.base.errors import ExchangeError
14
14
  from ccxt.base.errors import PermissionDenied
@@ -106,6 +106,7 @@ class bitget(Exchange, ImplicitAPI):
106
106
  'fetchLeverage': True,
107
107
  'fetchLeverageTiers': False,
108
108
  'fetchLiquidations': False,
109
+ 'fetchMarginAdjustmentHistory': False,
109
110
  'fetchMarginMode': True,
110
111
  'fetchMarketLeverageTiers': True,
111
112
  'fetchMarkets': True,
@@ -1814,7 +1815,7 @@ class bitget(Exchange, ImplicitAPI):
1814
1815
  data = self.safe_value(response, 'data', [])
1815
1816
  return self.parse_markets(data)
1816
1817
 
1817
- async def fetch_currencies(self, params={}):
1818
+ async def fetch_currencies(self, params={}) -> Currencies:
1818
1819
  """
1819
1820
  fetches all available currencies on an exchange
1820
1821
  :see: https://www.bitget.com/api-doc/spot/market/Get-Coin-List
@@ -2558,7 +2559,10 @@ class bitget(Exchange, ImplicitAPI):
2558
2559
  #
2559
2560
  marketId = self.safe_string(ticker, 'symbol')
2560
2561
  close = self.safe_string(ticker, 'lastPr')
2561
- timestamp = self.safe_integer(ticker, 'ts')
2562
+ timestampString = self.omit_zero(self.safe_string(ticker, 'ts')) # exchange sometimes provided 0
2563
+ timestamp = None
2564
+ if timestampString is not None:
2565
+ timestamp = self.parse_to_int(timestampString)
2562
2566
  change = self.safe_string(ticker, 'change24h')
2563
2567
  open24 = self.safe_string(ticker, 'open24')
2564
2568
  open = self.safe_string(ticker, 'open')
@@ -3005,7 +3009,7 @@ class bitget(Exchange, ImplicitAPI):
3005
3009
  data = self.safe_list(response, 'data', [])
3006
3010
  return self.parse_trades(data, market, since, limit)
3007
3011
 
3008
- async def fetch_trading_fee(self, symbol: str, params={}):
3012
+ async def fetch_trading_fee(self, symbol: str, params={}) -> TradingFeeInterface:
3009
3013
  """
3010
3014
  fetch the trading fees for a market
3011
3015
  :see: https://www.bitget.com/api-doc/common/public/Get-Trade-Rate
@@ -3043,7 +3047,7 @@ class bitget(Exchange, ImplicitAPI):
3043
3047
  data = self.safe_value(response, 'data', {})
3044
3048
  return self.parse_trading_fee(data, market)
3045
3049
 
3046
- async def fetch_trading_fees(self, params={}):
3050
+ async def fetch_trading_fees(self, params={}) -> TradingFees:
3047
3051
  """
3048
3052
  fetch the trading fees for multiple markets
3049
3053
  :see: https://www.bitget.com/api-doc/spot/market/Get-Symbols
@@ -3163,6 +3167,8 @@ class bitget(Exchange, ImplicitAPI):
3163
3167
  'symbol': self.safe_symbol(marketId, market),
3164
3168
  'maker': self.safe_number(data, 'makerFeeRate'),
3165
3169
  'taker': self.safe_number(data, 'takerFeeRate'),
3170
+ 'percentage': None,
3171
+ 'tierBased': None,
3166
3172
  }
3167
3173
 
3168
3174
  def parse_ohlcv(self, ohlcv, market: Market = None) -> list:
@@ -6481,6 +6487,7 @@ class bitget(Exchange, ImplicitAPI):
6481
6487
  'info': data,
6482
6488
  'symbol': market['symbol'],
6483
6489
  'type': None,
6490
+ 'marginMode': 'isolated',
6484
6491
  'amount': None,
6485
6492
  'total': None,
6486
6493
  'code': market['settle'],
@@ -6,7 +6,7 @@
6
6
  from ccxt.async_support.base.exchange import Exchange
7
7
  from ccxt.abstract.bitmart 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, Transaction, TransferEntry
10
10
  from typing import List
11
11
  from ccxt.base.errors import ExchangeError
12
12
  from ccxt.base.errors import PermissionDenied
@@ -985,7 +985,7 @@ class bitmart(Exchange, ImplicitAPI):
985
985
  contract = await self.fetch_contract_markets(params)
986
986
  return self.array_concat(spot, contract)
987
987
 
988
- async def fetch_currencies(self, params={}):
988
+ async def fetch_currencies(self, params={}) -> Currencies:
989
989
  """
990
990
  fetches all available currencies on an exchange
991
991
  :param dict [params]: extra parameters specific to the exchange API endpoint
@@ -1999,7 +1999,7 @@ class bitmart(Exchange, ImplicitAPI):
1999
1999
  #
2000
2000
  return self.custom_parse_balance(response, marketType)
2001
2001
 
2002
- def parse_trading_fee(self, fee, market: Market = None):
2002
+ def parse_trading_fee(self, fee, market: Market = None) -> TradingFeeInterface:
2003
2003
  #
2004
2004
  # {
2005
2005
  # "symbol": "ETH_USDT",
@@ -2014,9 +2014,11 @@ class bitmart(Exchange, ImplicitAPI):
2014
2014
  'symbol': symbol,
2015
2015
  'maker': self.safe_number(fee, 'maker_fee_rate'),
2016
2016
  'taker': self.safe_number(fee, 'taker_fee_rate'),
2017
+ 'percentage': None,
2018
+ 'tierBased': None,
2017
2019
  }
2018
2020
 
2019
- async def fetch_trading_fee(self, symbol: str, params={}):
2021
+ async def fetch_trading_fee(self, symbol: str, params={}) -> TradingFeeInterface:
2020
2022
  """
2021
2023
  fetch the trading fees for a market
2022
2024
  :param str symbol: unified market symbol
@@ -6,7 +6,7 @@
6
6
  from ccxt.async_support.base.exchange import Exchange
7
7
  from ccxt.abstract.bitmex import ImplicitAPI
8
8
  import hashlib
9
- from ccxt.base.types import Balances, Currency, Int, Leverage, Leverages, Market, MarketType, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction
9
+ from ccxt.base.types import Balances, Currencies, Currency, Int, Leverage, Leverages, Market, MarketType, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction
10
10
  from typing import List
11
11
  from ccxt.base.errors import ExchangeError
12
12
  from ccxt.base.errors import PermissionDenied
@@ -75,6 +75,7 @@ class bitmex(Exchange, ImplicitAPI):
75
75
  'fetchLeverages': True,
76
76
  'fetchLeverageTiers': False,
77
77
  'fetchLiquidations': True,
78
+ 'fetchMarginAdjustmentHistory': False,
78
79
  'fetchMarketLeverageTiers': False,
79
80
  'fetchMarkets': True,
80
81
  'fetchMarkOHLCV': False,
@@ -290,7 +291,7 @@ class bitmex(Exchange, ImplicitAPI):
290
291
  },
291
292
  })
292
293
 
293
- async def fetch_currencies(self, params={}):
294
+ async def fetch_currencies(self, params={}) -> Currencies:
294
295
  """
295
296
  fetches all available currencies on an exchange
296
297
  :see: https://www.bitmex.com/api/explorer/#not /Wallet/Wallet_getAssetsConfig
@@ -7,7 +7,7 @@ from ccxt.async_support.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
- async def fetch_currencies(self, params={}):
223
+ async 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
- async def fetch_trading_fees(self, params={}):
620
+ async 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
@@ -8,7 +8,7 @@ from ccxt.abstract.bitrue import ImplicitAPI
8
8
  import asyncio
9
9
  import hashlib
10
10
  import json
11
- from ccxt.base.types import Balances, Currency, Int, MarginModification, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
11
+ from ccxt.base.types import Balances, Currencies, Currency, Int, MarginModification, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
12
12
  from typing import List
13
13
  from ccxt.base.errors import ExchangeError
14
14
  from ccxt.base.errors import PermissionDenied
@@ -593,7 +593,7 @@ class bitrue(Exchange, ImplicitAPI):
593
593
  }
594
594
  return self.safe_string_2(networksById, networkId, uppercaseNetworkId, networkId)
595
595
 
596
- async def fetch_currencies(self, params={}):
596
+ async def fetch_currencies(self, params={}) -> Currencies:
597
597
  """
598
598
  fetches all available currencies on an exchange
599
599
  :param dict [params]: extra parameters specific to the exchange API endpoint
@@ -2853,6 +2853,7 @@ class bitrue(Exchange, ImplicitAPI):
2853
2853
  'info': data,
2854
2854
  'symbol': market['symbol'],
2855
2855
  'type': None,
2856
+ 'marginMode': 'isolated',
2856
2857
  'amount': None,
2857
2858
  'total': None,
2858
2859
  'code': None,
@@ -6,7 +6,7 @@
6
6
  from ccxt.async_support.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 = await self.publicGetTrades(self.extend(request, params))
815
815
  return self.parse_trades(response['payload'], market, since, limit)
816
816
 
817
- async def fetch_trading_fees(self, params={}):
817
+ async 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
@@ -6,7 +6,7 @@
6
6
  from ccxt.async_support.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
- async def fetch_currencies(self, params={}):
634
+ async 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
- async def fetch_trading_fee(self, symbol: str, params={}):
1144
+ async 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
- async def fetch_trading_fees(self, params={}):
1197
+ async 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
  await self.load_markets()
1206
- balance = await self.privatePostBalance(params)
1207
- return self.parse_transaction_fees(balance)
1232
+ response = await 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
- async def fetch_deposit_withdraw_fees(self, codes: Strings = None, params={}):
1262
+ async 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
  await self.load_markets()
1260
- response = await 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 = await 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
  async def create_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={}):
@@ -5,7 +5,7 @@
5
5
 
6
6
  from ccxt.async_support.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
- async def fetch_currencies(self, params={}):
418
+ async 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
@@ -6,7 +6,7 @@
6
6
  from ccxt.async_support.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
- async def fetch_currencies(self, params={}):
417
+ async 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
- async def fetch_trading_fees(self, params={}):
808
+ async 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
@@ -6,7 +6,7 @@
6
6
  from ccxt.async_support.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
- async def fetch_trading_fees(self, params={}):
314
+ async 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
@@ -5,7 +5,7 @@
5
5
 
6
6
  from ccxt.async_support.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
- async def fetch_trading_fees(self, params={}):
620
+ async 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
@@ -6,7 +6,7 @@
6
6
  from ccxt.async_support.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
  async def fetch_balance(self, params={}) -> Balances: