ccxt 4.2.83__py2.py3-none-any.whl → 4.2.85__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.
Files changed (152) hide show
  1. ccxt/__init__.py +1 -1
  2. ccxt/abstract/bybit.py +1 -1
  3. ccxt/ace.py +5 -5
  4. ccxt/ascendex.py +8 -8
  5. ccxt/async_support/__init__.py +1 -1
  6. ccxt/async_support/ace.py +5 -5
  7. ccxt/async_support/ascendex.py +8 -8
  8. ccxt/async_support/base/exchange.py +3 -27
  9. ccxt/async_support/bigone.py +12 -12
  10. ccxt/async_support/binance.py +20 -32
  11. ccxt/async_support/bingx.py +12 -9
  12. ccxt/async_support/bit2c.py +1 -1
  13. ccxt/async_support/bitbank.py +8 -8
  14. ccxt/async_support/bitbns.py +5 -5
  15. ccxt/async_support/bitfinex.py +1 -1
  16. ccxt/async_support/bitfinex2.py +1 -1
  17. ccxt/async_support/bitget.py +39 -28
  18. ccxt/async_support/bithumb.py +5 -5
  19. ccxt/async_support/bitmart.py +16 -16
  20. ccxt/async_support/bitopro.py +1 -1
  21. ccxt/async_support/bitrue.py +4 -4
  22. ccxt/async_support/bitso.py +5 -5
  23. ccxt/async_support/bitstamp.py +1 -1
  24. ccxt/async_support/bitteam.py +8 -8
  25. ccxt/async_support/bl3p.py +1 -1
  26. ccxt/async_support/btcturk.py +6 -6
  27. ccxt/async_support/bybit.py +34 -87
  28. ccxt/async_support/coincheck.py +4 -4
  29. ccxt/async_support/coinex.py +12 -13
  30. ccxt/async_support/coinlist.py +7 -7
  31. ccxt/async_support/coinmate.py +4 -4
  32. ccxt/async_support/coinmetro.py +3 -3
  33. ccxt/async_support/coinone.py +5 -5
  34. ccxt/async_support/coinspot.py +2 -2
  35. ccxt/async_support/cryptocom.py +17 -17
  36. ccxt/async_support/currencycom.py +1 -1
  37. ccxt/async_support/delta.py +0 -8
  38. ccxt/async_support/deribit.py +16 -80
  39. ccxt/async_support/digifinex.py +8 -8
  40. ccxt/async_support/exmo.py +8 -8
  41. ccxt/async_support/gate.py +0 -8
  42. ccxt/async_support/hitbtc.py +5 -4
  43. ccxt/async_support/hollaex.py +7 -7
  44. ccxt/async_support/htx.py +12 -34
  45. ccxt/async_support/huobijp.py +3 -3
  46. ccxt/async_support/idex.py +2 -2
  47. ccxt/async_support/independentreserve.py +2 -2
  48. ccxt/async_support/indodax.py +2 -2
  49. ccxt/async_support/kraken.py +8 -8
  50. ccxt/async_support/krakenfutures.py +6 -6
  51. ccxt/async_support/kucoin.py +14 -2
  52. ccxt/async_support/kucoinfutures.py +8 -8
  53. ccxt/async_support/kuna.py +16 -16
  54. ccxt/async_support/latoken.py +2 -2
  55. ccxt/async_support/lbank.py +10 -10
  56. ccxt/async_support/luno.py +4 -4
  57. ccxt/async_support/mercado.py +5 -5
  58. ccxt/async_support/mexc.py +6 -6
  59. ccxt/async_support/ndax.py +1 -1
  60. ccxt/async_support/novadax.py +9 -9
  61. ccxt/async_support/oceanex.py +7 -7
  62. ccxt/async_support/okcoin.py +13 -13
  63. ccxt/async_support/okx.py +23 -31
  64. ccxt/async_support/onetrading.py +4 -4
  65. ccxt/async_support/p2b.py +7 -7
  66. ccxt/async_support/phemex.py +12 -12
  67. ccxt/async_support/poloniexfutures.py +5 -5
  68. ccxt/async_support/probit.py +11 -11
  69. ccxt/async_support/timex.py +7 -7
  70. ccxt/async_support/tokocrypto.py +9 -9
  71. ccxt/async_support/wavesexchange.py +3 -3
  72. ccxt/async_support/whitebit.py +5 -5
  73. ccxt/async_support/woo.py +1 -1
  74. ccxt/async_support/zaif.py +1 -1
  75. ccxt/async_support/zonda.py +7 -7
  76. ccxt/base/exchange.py +66 -23
  77. ccxt/bigone.py +12 -12
  78. ccxt/binance.py +20 -32
  79. ccxt/bingx.py +12 -9
  80. ccxt/bit2c.py +1 -1
  81. ccxt/bitbank.py +8 -8
  82. ccxt/bitbns.py +5 -5
  83. ccxt/bitfinex.py +1 -1
  84. ccxt/bitfinex2.py +1 -1
  85. ccxt/bitget.py +39 -28
  86. ccxt/bithumb.py +5 -5
  87. ccxt/bitmart.py +16 -16
  88. ccxt/bitopro.py +1 -1
  89. ccxt/bitrue.py +4 -4
  90. ccxt/bitso.py +5 -5
  91. ccxt/bitstamp.py +1 -1
  92. ccxt/bitteam.py +8 -8
  93. ccxt/bl3p.py +1 -1
  94. ccxt/btcturk.py +6 -6
  95. ccxt/bybit.py +34 -87
  96. ccxt/coincheck.py +4 -4
  97. ccxt/coinex.py +12 -13
  98. ccxt/coinlist.py +7 -7
  99. ccxt/coinmate.py +4 -4
  100. ccxt/coinmetro.py +3 -3
  101. ccxt/coinone.py +5 -5
  102. ccxt/coinspot.py +2 -2
  103. ccxt/cryptocom.py +17 -17
  104. ccxt/currencycom.py +1 -1
  105. ccxt/delta.py +0 -8
  106. ccxt/deribit.py +16 -80
  107. ccxt/digifinex.py +8 -8
  108. ccxt/exmo.py +8 -8
  109. ccxt/gate.py +0 -8
  110. ccxt/hitbtc.py +5 -4
  111. ccxt/hollaex.py +7 -7
  112. ccxt/htx.py +12 -34
  113. ccxt/huobijp.py +3 -3
  114. ccxt/idex.py +2 -2
  115. ccxt/independentreserve.py +2 -2
  116. ccxt/indodax.py +2 -2
  117. ccxt/kraken.py +8 -8
  118. ccxt/krakenfutures.py +6 -6
  119. ccxt/kucoin.py +14 -2
  120. ccxt/kucoinfutures.py +8 -8
  121. ccxt/kuna.py +16 -16
  122. ccxt/latoken.py +2 -2
  123. ccxt/lbank.py +10 -10
  124. ccxt/luno.py +4 -4
  125. ccxt/mercado.py +5 -5
  126. ccxt/mexc.py +6 -6
  127. ccxt/ndax.py +1 -1
  128. ccxt/novadax.py +9 -9
  129. ccxt/oceanex.py +7 -7
  130. ccxt/okcoin.py +13 -13
  131. ccxt/okx.py +23 -31
  132. ccxt/onetrading.py +4 -4
  133. ccxt/p2b.py +7 -7
  134. ccxt/phemex.py +12 -12
  135. ccxt/poloniexfutures.py +5 -5
  136. ccxt/pro/__init__.py +1 -1
  137. ccxt/pro/binance.py +150 -112
  138. ccxt/pro/kucoin.py +6 -7
  139. ccxt/pro/okx.py +12 -1
  140. ccxt/probit.py +11 -11
  141. ccxt/test/base/test_market.py +3 -0
  142. ccxt/timex.py +7 -7
  143. ccxt/tokocrypto.py +9 -9
  144. ccxt/wavesexchange.py +3 -3
  145. ccxt/whitebit.py +5 -5
  146. ccxt/woo.py +1 -1
  147. ccxt/zaif.py +1 -1
  148. ccxt/zonda.py +7 -7
  149. {ccxt-4.2.83.dist-info → ccxt-4.2.85.dist-info}/METADATA +4 -4
  150. {ccxt-4.2.83.dist-info → ccxt-4.2.85.dist-info}/RECORD +152 -152
  151. {ccxt-4.2.83.dist-info → ccxt-4.2.85.dist-info}/WHEEL +0 -0
  152. {ccxt-4.2.83.dist-info → ccxt-4.2.85.dist-info}/top_level.txt +0 -0
ccxt/bitbank.py CHANGED
@@ -302,7 +302,7 @@ class bitbank(Exchange, ImplicitAPI):
302
302
  'pair': market['id'],
303
303
  }
304
304
  response = self.publicGetPairTicker(self.extend(request, params))
305
- data = self.safe_value(response, 'data', {})
305
+ data = self.safe_dict(response, 'data', {})
306
306
  return self.parse_ticker(data, market)
307
307
 
308
308
  def fetch_order_book(self, symbol: str, limit: Int = None, params={}) -> OrderBook:
@@ -385,7 +385,7 @@ class bitbank(Exchange, ImplicitAPI):
385
385
  }
386
386
  response = self.publicGetPairTransactions(self.extend(request, params))
387
387
  data = self.safe_value(response, 'data', {})
388
- trades = self.safe_value(data, 'transactions', [])
388
+ trades = self.safe_list(data, 'transactions', [])
389
389
  return self.parse_trades(trades, market, since, limit)
390
390
 
391
391
  def fetch_trading_fees(self, params={}):
@@ -508,7 +508,7 @@ class bitbank(Exchange, ImplicitAPI):
508
508
  data = self.safe_value(response, 'data', {})
509
509
  candlestick = self.safe_value(data, 'candlestick', [])
510
510
  first = self.safe_value(candlestick, 0, {})
511
- ohlcv = self.safe_value(first, 'ohlcv', [])
511
+ ohlcv = self.safe_list(first, 'ohlcv', [])
512
512
  return self.parse_ohlcvs(ohlcv, market, timeframe, since, limit)
513
513
 
514
514
  def parse_balance(self, response) -> Balances:
@@ -645,7 +645,7 @@ class bitbank(Exchange, ImplicitAPI):
645
645
  if type == 'limit':
646
646
  request['price'] = self.price_to_precision(symbol, price)
647
647
  response = self.privatePostUserSpotOrder(self.extend(request, params))
648
- data = self.safe_value(response, 'data')
648
+ data = self.safe_dict(response, 'data')
649
649
  return self.parse_order(data, market)
650
650
 
651
651
  def cancel_order(self, id: str, symbol: Str = None, params={}):
@@ -682,7 +682,7 @@ class bitbank(Exchange, ImplicitAPI):
682
682
  'pair': market['id'],
683
683
  }
684
684
  response = self.privateGetUserSpotOrder(self.extend(request, params))
685
- data = self.safe_value(response, 'data')
685
+ data = self.safe_dict(response, 'data')
686
686
  return self.parse_order(data, market)
687
687
 
688
688
  def fetch_open_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
@@ -706,7 +706,7 @@ class bitbank(Exchange, ImplicitAPI):
706
706
  request['since'] = self.parse_to_int(since / 1000)
707
707
  response = self.privateGetUserSpotActiveOrders(self.extend(request, params))
708
708
  data = self.safe_value(response, 'data', {})
709
- orders = self.safe_value(data, 'orders', [])
709
+ orders = self.safe_list(data, 'orders', [])
710
710
  return self.parse_orders(orders, market, since, limit)
711
711
 
712
712
  def fetch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
@@ -731,7 +731,7 @@ class bitbank(Exchange, ImplicitAPI):
731
731
  request['since'] = self.parse_to_int(since / 1000)
732
732
  response = self.privateGetUserSpotTradeHistory(self.extend(request, params))
733
733
  data = self.safe_value(response, 'data', {})
734
- trades = self.safe_value(data, 'trades', [])
734
+ trades = self.safe_list(data, 'trades', [])
735
735
  return self.parse_trades(trades, market, since, limit)
736
736
 
737
737
  def fetch_deposit_address(self, code: str, params={}):
@@ -799,7 +799,7 @@ class bitbank(Exchange, ImplicitAPI):
799
799
  # }
800
800
  # }
801
801
  #
802
- data = self.safe_value(response, 'data', {})
802
+ data = self.safe_dict(response, 'data', {})
803
803
  return self.parse_transaction(data, currency)
804
804
 
805
805
  def parse_transaction(self, transaction, currency: Currency = None) -> Transaction:
ccxt/bitbns.py CHANGED
@@ -696,7 +696,7 @@ class bitbns(Exchange, ImplicitAPI):
696
696
  # }
697
697
  #
698
698
  data = self.safe_value(response, 'data', [])
699
- first = self.safe_value(data, 0)
699
+ first = self.safe_dict(data, 0)
700
700
  return self.parse_order(first, market)
701
701
 
702
702
  def fetch_open_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
@@ -744,7 +744,7 @@ class bitbns(Exchange, ImplicitAPI):
744
744
  # "code":200
745
745
  # }
746
746
  #
747
- data = self.safe_value(response, 'data', [])
747
+ data = self.safe_list(response, 'data', [])
748
748
  return self.parse_orders(data, market, since, limit)
749
749
 
750
750
  def parse_trade(self, trade, market: Market = None) -> Trade:
@@ -884,7 +884,7 @@ class bitbns(Exchange, ImplicitAPI):
884
884
  # "code": 200
885
885
  # }
886
886
  #
887
- data = self.safe_value(response, 'data', [])
887
+ data = self.safe_list(response, 'data', [])
888
888
  return self.parse_trades(data, market, since, limit)
889
889
 
890
890
  def fetch_trades(self, symbol: str, since: Int = None, limit: Int = None, params={}) -> List[Trade]:
@@ -955,7 +955,7 @@ class bitbns(Exchange, ImplicitAPI):
955
955
  # "code":200
956
956
  # }
957
957
  #
958
- data = self.safe_value(response, 'data', [])
958
+ data = self.safe_list(response, 'data', [])
959
959
  return self.parse_transactions(data, currency, since, limit)
960
960
 
961
961
  def fetch_withdrawals(self, code: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Transaction]:
@@ -979,7 +979,7 @@ class bitbns(Exchange, ImplicitAPI):
979
979
  #
980
980
  # ...
981
981
  #
982
- data = self.safe_value(response, 'data', [])
982
+ data = self.safe_list(response, 'data', [])
983
983
  return self.parse_transactions(data, currency, since, limit)
984
984
 
985
985
  def parse_transaction_status_by_type(self, status, type=None):
ccxt/bitfinex.py CHANGED
@@ -460,7 +460,7 @@ class bitfinex(Exchange, ImplicitAPI):
460
460
  # }
461
461
  # }
462
462
  #
463
- withdraw = self.safe_value(response, 'withdraw')
463
+ withdraw = self.safe_list(response, 'withdraw')
464
464
  return self.parse_deposit_withdraw_fees(withdraw, codes)
465
465
 
466
466
  def parse_deposit_withdraw_fee(self, fee, currency: Currency = None):
ccxt/bitfinex2.py CHANGED
@@ -1712,7 +1712,7 @@ class bitfinex2(Exchange, ImplicitAPI):
1712
1712
  'all': 1,
1713
1713
  }
1714
1714
  response = self.privatePostAuthWOrderCancelMulti(self.extend(request, params))
1715
- orders = self.safe_value(response, 4, [])
1715
+ orders = self.safe_list(response, 4, [])
1716
1716
  return self.parse_orders(orders)
1717
1717
 
1718
1718
  def cancel_order(self, id: str, symbol: Str = None, params={}):
ccxt/bitget.py CHANGED
@@ -2148,7 +2148,7 @@ class bitget(Exchange, ImplicitAPI):
2148
2148
  # ]
2149
2149
  # }
2150
2150
  #
2151
- rawTransactions = self.safe_value(response, 'data', [])
2151
+ rawTransactions = self.safe_list(response, 'data', [])
2152
2152
  return self.parse_transactions(rawTransactions, currency, since, limit)
2153
2153
 
2154
2154
  def withdraw(self, code: str, amount: float, address, tag=None, params={}):
@@ -2285,7 +2285,7 @@ class bitget(Exchange, ImplicitAPI):
2285
2285
  # ]
2286
2286
  # }
2287
2287
  #
2288
- rawTransactions = self.safe_value(response, 'data', [])
2288
+ rawTransactions = self.safe_list(response, 'data', [])
2289
2289
  return self.parse_transactions(rawTransactions, currency, since, limit)
2290
2290
 
2291
2291
  def parse_transaction(self, transaction, currency: Currency = None) -> Transaction:
@@ -2408,7 +2408,7 @@ class bitget(Exchange, ImplicitAPI):
2408
2408
  # }
2409
2409
  # }
2410
2410
  #
2411
- data = self.safe_value(response, 'data', {})
2411
+ data = self.safe_dict(response, 'data', {})
2412
2412
  return self.parse_deposit_address(data, currency)
2413
2413
 
2414
2414
  def parse_deposit_address(self, depositAddress, currency: Currency = None):
@@ -2681,7 +2681,7 @@ class bitget(Exchange, ImplicitAPI):
2681
2681
  # ]
2682
2682
  # }
2683
2683
  #
2684
- data = self.safe_value(response, 'data', [])
2684
+ data = self.safe_list(response, 'data', [])
2685
2685
  return self.parse_ticker(data[0], market)
2686
2686
 
2687
2687
  def fetch_tickers(self, symbols: Strings = None, params={}) -> Tickers:
@@ -2691,6 +2691,7 @@ class bitget(Exchange, ImplicitAPI):
2691
2691
  :see: https://www.bitget.com/api-doc/contract/market/Get-All-Symbol-Ticker
2692
2692
  :param str[]|None symbols: unified symbols of the markets to fetch the ticker for, all market tickers are returned if not assigned
2693
2693
  :param dict [params]: extra parameters specific to the exchange API endpoint
2694
+ :param str [params.subType]: *contract only* 'linear', 'inverse'
2694
2695
  :param str [params.productType]: *contract only* 'USDT-FUTURES', 'USDC-FUTURES', 'COIN-FUTURES', 'SUSDT-FUTURES', 'SUSDC-FUTURES' or 'SCOIN-FUTURES'
2695
2696
  :returns dict: a dictionary of `ticker structures <https://docs.ccxt.com/#/?id=ticker-structure>`
2696
2697
  """
@@ -2704,15 +2705,20 @@ class bitget(Exchange, ImplicitAPI):
2704
2705
  market = self.market(sandboxSymbol)
2705
2706
  else:
2706
2707
  market = self.market(symbol)
2708
+ response = None
2707
2709
  request = {}
2708
2710
  type = None
2709
2711
  type, params = self.handle_market_type_and_params('fetchTickers', market, params)
2710
- response = None
2711
- if type == 'spot':
2712
+ # Calls like `.fetch_tickers(None, {subType:'inverse'})` should be supported for self exchange, so
2713
+ # as "options.defaultSubType" is also set in exchange options, we should consider `params.subType`
2714
+ # with higher priority and only default to spot, if `subType` is not set in params
2715
+ passedSubType = self.safe_string(params, 'subType')
2716
+ productType = None
2717
+ productType, params = self.handle_product_type_and_params(market, params)
2718
+ # only if passedSubType and productType is None, then use spot
2719
+ if type == 'spot' and passedSubType is None:
2712
2720
  response = self.publicSpotGetV2SpotMarketTickers(self.extend(request, params))
2713
2721
  else:
2714
- productType = None
2715
- productType, params = self.handle_product_type_and_params(market, params)
2716
2722
  request['productType'] = productType
2717
2723
  response = self.publicMixGetV2MixMarketTickers(self.extend(request, params))
2718
2724
  #
@@ -2772,7 +2778,7 @@ class bitget(Exchange, ImplicitAPI):
2772
2778
  # ]
2773
2779
  # }
2774
2780
  #
2775
- data = self.safe_value(response, 'data', [])
2781
+ data = self.safe_list(response, 'data', [])
2776
2782
  return self.parse_tickers(data, symbols)
2777
2783
 
2778
2784
  def parse_trade(self, trade, market: Market = None) -> Trade:
@@ -2993,7 +2999,7 @@ class bitget(Exchange, ImplicitAPI):
2993
2999
  # ]
2994
3000
  # }
2995
3001
  #
2996
- data = self.safe_value(response, 'data', [])
3002
+ data = self.safe_list(response, 'data', [])
2997
3003
  return self.parse_trades(data, market, since, limit)
2998
3004
 
2999
3005
  def fetch_trading_fee(self, symbol: str, params={}):
@@ -4001,7 +4007,7 @@ class bitget(Exchange, ImplicitAPI):
4001
4007
  # }
4002
4008
  # }
4003
4009
  #
4004
- data = self.safe_value(response, 'data', {})
4010
+ data = self.safe_dict(response, 'data', {})
4005
4011
  return self.parse_order(data, market)
4006
4012
 
4007
4013
  def create_order_request(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={}):
@@ -4418,7 +4424,7 @@ class bitget(Exchange, ImplicitAPI):
4418
4424
  # }
4419
4425
  # }
4420
4426
  #
4421
- data = self.safe_value(response, 'data', {})
4427
+ data = self.safe_dict(response, 'data', {})
4422
4428
  return self.parse_order(data, market)
4423
4429
 
4424
4430
  def cancel_order(self, id: str, symbol: Str = None, params={}):
@@ -4619,7 +4625,7 @@ class bitget(Exchange, ImplicitAPI):
4619
4625
  # }
4620
4626
  #
4621
4627
  data = self.safe_value(response, 'data', {})
4622
- orders = self.safe_value(data, 'successList', [])
4628
+ orders = self.safe_list(data, 'successList', [])
4623
4629
  return self.parse_orders(orders, market)
4624
4630
 
4625
4631
  def cancel_all_orders(self, symbol: Str = None, params={}):
@@ -4826,9 +4832,14 @@ class bitget(Exchange, ImplicitAPI):
4826
4832
  #
4827
4833
  if isinstance(response, str):
4828
4834
  response = json.loads(response)
4829
- data = self.safe_value(response, 'data')
4830
- first = self.safe_value(data, 0, data)
4835
+ data = self.safe_dict(response, 'data')
4836
+ if (data is not None) and not isinstance(data, list):
4837
+ return self.parse_order(data, market)
4838
+ dataList = self.safe_list(response, 'data', [])
4839
+ first = self.safe_dict(dataList, 0, {})
4831
4840
  return self.parse_order(first, market)
4841
+ # first = self.safe_dict(data, 0, data)
4842
+ # return self.parse_order(first, market)
4832
4843
 
4833
4844
  def fetch_open_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
4834
4845
  """
@@ -5105,10 +5116,10 @@ class bitget(Exchange, ImplicitAPI):
5105
5116
  data = self.safe_value(response, 'data')
5106
5117
  if type == 'spot':
5107
5118
  if (marginMode is not None) or stop:
5108
- resultList = self.safe_value(data, 'orderList', [])
5119
+ resultList = self.safe_list(data, 'orderList', [])
5109
5120
  return self.parse_orders(resultList, market, since, limit)
5110
5121
  else:
5111
- result = self.safe_value(data, 'entrustedList', [])
5122
+ result = self.safe_list(data, 'entrustedList', [])
5112
5123
  return self.parse_orders(result, market, since, limit)
5113
5124
  return self.parse_orders(data, market, since, limit)
5114
5125
 
@@ -5438,7 +5449,7 @@ class bitget(Exchange, ImplicitAPI):
5438
5449
  return self.parse_orders(self.safe_value(data, 'entrustedList', []), market, since, limit)
5439
5450
  if isinstance(response, str):
5440
5451
  response = json.loads(response)
5441
- orders = self.safe_value(response, 'data', [])
5452
+ orders = self.safe_list(response, 'data', [])
5442
5453
  return self.parse_orders(orders, market, since, limit)
5443
5454
 
5444
5455
  def fetch_ledger(self, code: Str = None, since: Int = None, limit: Int = None, params={}):
@@ -5809,10 +5820,10 @@ class bitget(Exchange, ImplicitAPI):
5809
5820
  #
5810
5821
  data = self.safe_value(response, 'data')
5811
5822
  if (market['swap']) or (market['future']):
5812
- fillList = self.safe_value(data, 'fillList', [])
5823
+ fillList = self.safe_list(data, 'fillList', [])
5813
5824
  return self.parse_trades(fillList, market, since, limit)
5814
5825
  elif marginMode is not None:
5815
- fills = self.safe_value(data, 'fills', [])
5826
+ fills = self.safe_list(data, 'fills', [])
5816
5827
  return self.parse_trades(fills, market, since, limit)
5817
5828
  return self.parse_trades(data, market, since, limit)
5818
5829
 
@@ -5870,8 +5881,8 @@ class bitget(Exchange, ImplicitAPI):
5870
5881
  # ]
5871
5882
  # }
5872
5883
  #
5873
- data = self.safe_value(response, 'data', [])
5874
- first = self.safe_value(data, 0, {})
5884
+ data = self.safe_list(response, 'data', [])
5885
+ first = self.safe_dict(data, 0, {})
5875
5886
  return self.parse_position(first, market)
5876
5887
 
5877
5888
  def fetch_positions(self, symbols: Strings = None, params={}) -> List[Position]:
@@ -6732,7 +6743,7 @@ class bitget(Exchange, ImplicitAPI):
6732
6743
  # }
6733
6744
  # }
6734
6745
  #
6735
- data = self.safe_value(response, 'data', {})
6746
+ data = self.safe_dict(response, 'data', {})
6736
6747
  return self.parse_open_interest(data, market)
6737
6748
 
6738
6749
  def parse_open_interest(self, interest, market: Market = None):
@@ -6811,7 +6822,7 @@ class bitget(Exchange, ImplicitAPI):
6811
6822
  # ]
6812
6823
  # }
6813
6824
  #
6814
- data = self.safe_value(response, 'data', [])
6825
+ data = self.safe_list(response, 'data', [])
6815
6826
  return self.parse_transfers(data, currency, since, limit)
6816
6827
 
6817
6828
  def transfer(self, code: str, amount: float, fromAccount: str, toAccount: str, params={}) -> TransferEntry:
@@ -7001,7 +7012,7 @@ class bitget(Exchange, ImplicitAPI):
7001
7012
  # "requestTime": "1700120731773"
7002
7013
  # }
7003
7014
  #
7004
- data = self.safe_value(response, 'data', [])
7015
+ data = self.safe_list(response, 'data', [])
7005
7016
  return self.parse_deposit_withdraw_fees(data, codes, 'coin')
7006
7017
 
7007
7018
  def borrow_cross_margin(self, code: str, amount: float, params={}):
@@ -7288,7 +7299,7 @@ class bitget(Exchange, ImplicitAPI):
7288
7299
  # }
7289
7300
  #
7290
7301
  data = self.safe_value(response, 'data', {})
7291
- liquidations = self.safe_value(data, 'resultList', [])
7302
+ liquidations = self.safe_list(data, 'resultList', [])
7292
7303
  return self.parse_liquidations(liquidations, market, since, limit)
7293
7304
 
7294
7305
  def parse_liquidation(self, liquidation, market: Market = None):
@@ -7716,7 +7727,7 @@ class bitget(Exchange, ImplicitAPI):
7716
7727
  # }
7717
7728
  #
7718
7729
  data = self.safe_value(response, 'data', {})
7719
- order = self.safe_value(data, 'successList', [])
7730
+ order = self.safe_list(data, 'successList', [])
7720
7731
  return self.parse_order(order[0], market)
7721
7732
 
7722
7733
  def close_all_positions(self, params={}) -> List[Position]:
@@ -7752,7 +7763,7 @@ class bitget(Exchange, ImplicitAPI):
7752
7763
  # }
7753
7764
  #
7754
7765
  data = self.safe_value(response, 'data', {})
7755
- orderInfo = self.safe_value(data, 'successList', [])
7766
+ orderInfo = self.safe_list(data, 'successList', [])
7756
7767
  return self.parse_positions(orderInfo, None, params)
7757
7768
 
7758
7769
  def fetch_margin_mode(self, symbol: str, params={}) -> MarginMode:
ccxt/bithumb.py CHANGED
@@ -487,7 +487,7 @@ class bithumb(Exchange, ImplicitAPI):
487
487
  # }
488
488
  # }
489
489
  #
490
- data = self.safe_value(response, 'data', {})
490
+ data = self.safe_dict(response, 'data', {})
491
491
  return self.parse_ticker(data, market)
492
492
 
493
493
  def parse_ohlcv(self, ohlcv, market: Market = None) -> list:
@@ -552,7 +552,7 @@ class bithumb(Exchange, ImplicitAPI):
552
552
  # }
553
553
  # }
554
554
  #
555
- data = self.safe_value(response, 'data', [])
555
+ data = self.safe_list(response, 'data', [])
556
556
  return self.parse_ohlcvs(data, market, timeframe, since, limit)
557
557
 
558
558
  def parse_trade(self, trade, market: Market = None) -> Trade:
@@ -660,7 +660,7 @@ class bithumb(Exchange, ImplicitAPI):
660
660
  # ]
661
661
  # }
662
662
  #
663
- data = self.safe_value(response, 'data', [])
663
+ data = self.safe_list(response, 'data', [])
664
664
  return self.parse_trades(data, market, since, limit)
665
665
 
666
666
  def create_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={}):
@@ -748,7 +748,7 @@ class bithumb(Exchange, ImplicitAPI):
748
748
  # }
749
749
  # }
750
750
  #
751
- data = self.safe_value(response, 'data')
751
+ data = self.safe_dict(response, 'data')
752
752
  return self.parse_order(self.extend(data, {'order_id': id}), market)
753
753
 
754
754
  def parse_order_status(self, status):
@@ -893,7 +893,7 @@ class bithumb(Exchange, ImplicitAPI):
893
893
  # ]
894
894
  # }
895
895
  #
896
- data = self.safe_value(response, 'data', [])
896
+ data = self.safe_list(response, 'data', [])
897
897
  return self.parse_orders(data, market, since, limit)
898
898
 
899
899
  def cancel_order(self, id: str, symbol: Str = None, params={}):
ccxt/bitmart.py CHANGED
@@ -1302,7 +1302,7 @@ class bitmart(Exchange, ImplicitAPI):
1302
1302
  tickersById = self.index_by(tickers, 'symbol')
1303
1303
  elif market['swap']:
1304
1304
  tickersById = self.index_by(tickers, 'contract_symbol')
1305
- ticker = self.safe_value(tickersById, market['id'])
1305
+ ticker = self.safe_dict(tickersById, market['id'])
1306
1306
  return self.parse_ticker(ticker, market)
1307
1307
 
1308
1308
  def fetch_tickers(self, symbols: Strings = None, params={}) -> Tickers:
@@ -1549,7 +1549,7 @@ class bitmart(Exchange, ImplicitAPI):
1549
1549
  # }
1550
1550
  #
1551
1551
  data = self.safe_value(response, 'data', {})
1552
- trades = self.safe_value(data, 'trades', [])
1552
+ trades = self.safe_list(data, 'trades', [])
1553
1553
  return self.parse_trades(trades, market, since, limit)
1554
1554
 
1555
1555
  def parse_ohlcv(self, ohlcv, market: Market = None) -> list:
@@ -1703,7 +1703,7 @@ class bitmart(Exchange, ImplicitAPI):
1703
1703
  # "trace": "96c989db-e0f5-46f5-bba6-60cfcbde699b"
1704
1704
  # }
1705
1705
  #
1706
- ohlcv = self.safe_value(response, 'data', [])
1706
+ ohlcv = self.safe_list(response, 'data', [])
1707
1707
  return self.parse_ohlcvs(ohlcv, market, timeframe, since, limit)
1708
1708
 
1709
1709
  def fetch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
@@ -1806,7 +1806,7 @@ class bitmart(Exchange, ImplicitAPI):
1806
1806
  # "trace": "4cad855074634097ac6ba5257c47305d.62.16959616054873723"
1807
1807
  # }
1808
1808
  #
1809
- data = self.safe_value(response, 'data', [])
1809
+ data = self.safe_list(response, 'data', [])
1810
1810
  return self.parse_trades(data, market, since, limit)
1811
1811
 
1812
1812
  def fetch_order_trades(self, id: str, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
@@ -1825,7 +1825,7 @@ class bitmart(Exchange, ImplicitAPI):
1825
1825
  'orderId': id,
1826
1826
  }
1827
1827
  response = self.privatePostSpotV4QueryOrderTrades(self.extend(request, params))
1828
- data = self.safe_value(response, 'data', {})
1828
+ data = self.safe_list(response, 'data', [])
1829
1829
  return self.parse_trades(data, None, since, limit)
1830
1830
 
1831
1831
  def custom_parse_balance(self, response, marketType) -> Balances:
@@ -2616,7 +2616,7 @@ class bitmart(Exchange, ImplicitAPI):
2616
2616
  # }
2617
2617
  #
2618
2618
  data = self.safe_value(response, 'data', {})
2619
- orders = self.safe_value(data, 'orders', [])
2619
+ orders = self.safe_list(data, 'orders', [])
2620
2620
  return self.parse_orders(orders, market, since, limit)
2621
2621
 
2622
2622
  def fetch_open_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
@@ -2731,7 +2731,7 @@ class bitmart(Exchange, ImplicitAPI):
2731
2731
  # "trace": "7f9d94g10f9d4513bc08a7rfc3a5559a.71.16957022303515933"
2732
2732
  # }
2733
2733
  #
2734
- data = self.safe_value(response, 'data', [])
2734
+ data = self.safe_list(response, 'data', [])
2735
2735
  return self.parse_orders(data, market, since, limit)
2736
2736
 
2737
2737
  def fetch_closed_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Order]:
@@ -2775,7 +2775,7 @@ class bitmart(Exchange, ImplicitAPI):
2775
2775
  response = self.privatePostSpotV4QueryHistoryOrders(self.extend(request, params))
2776
2776
  else:
2777
2777
  response = self.privateGetContractPrivateOrderHistory(self.extend(request, params))
2778
- data = self.safe_value(response, 'data', [])
2778
+ data = self.safe_list(response, 'data', [])
2779
2779
  return self.parse_orders(data, market, since, limit)
2780
2780
 
2781
2781
  def fetch_canceled_orders(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
@@ -2882,7 +2882,7 @@ class bitmart(Exchange, ImplicitAPI):
2882
2882
  # "trace": "4cad855075664097af6ba5257c47605d.63.14957831547451715"
2883
2883
  # }
2884
2884
  #
2885
- data = self.safe_value(response, 'data', {})
2885
+ data = self.safe_dict(response, 'data', {})
2886
2886
  return self.parse_order(data, market)
2887
2887
 
2888
2888
  def fetch_deposit_address(self, code: str, params={}):
@@ -2921,7 +2921,7 @@ class bitmart(Exchange, ImplicitAPI):
2921
2921
  # }
2922
2922
  # }
2923
2923
  #
2924
- data = self.safe_value(response, 'data', {})
2924
+ data = self.safe_dict(response, 'data', {})
2925
2925
  return self.parse_deposit_address(data, currency)
2926
2926
 
2927
2927
  def parse_deposit_address(self, depositAddress, currency=None):
@@ -3058,7 +3058,7 @@ class bitmart(Exchange, ImplicitAPI):
3058
3058
  # }
3059
3059
  #
3060
3060
  data = self.safe_value(response, 'data', {})
3061
- records = self.safe_value(data, 'records', [])
3061
+ records = self.safe_list(data, 'records', [])
3062
3062
  return self.parse_transactions(records, currency, since, limit)
3063
3063
 
3064
3064
  def fetch_deposit(self, id: str, code: Str = None, params={}):
@@ -3097,7 +3097,7 @@ class bitmart(Exchange, ImplicitAPI):
3097
3097
  # }
3098
3098
  #
3099
3099
  data = self.safe_value(response, 'data', {})
3100
- record = self.safe_value(data, 'record', {})
3100
+ record = self.safe_dict(data, 'record', {})
3101
3101
  return self.parse_transaction(record)
3102
3102
 
3103
3103
  def fetch_deposits(self, code: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Transaction]:
@@ -3147,7 +3147,7 @@ class bitmart(Exchange, ImplicitAPI):
3147
3147
  # }
3148
3148
  #
3149
3149
  data = self.safe_value(response, 'data', {})
3150
- record = self.safe_value(data, 'record', {})
3150
+ record = self.safe_dict(data, 'record', {})
3151
3151
  return self.parse_transaction(record)
3152
3152
 
3153
3153
  def fetch_withdrawals(self, code: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Transaction]:
@@ -3665,7 +3665,7 @@ class bitmart(Exchange, ImplicitAPI):
3665
3665
  # }
3666
3666
  #
3667
3667
  data = self.safe_value(response, 'data', {})
3668
- records = self.safe_value(data, 'records', [])
3668
+ records = self.safe_list(data, 'records', [])
3669
3669
  return self.parse_transfers(records, currency, since, limit)
3670
3670
 
3671
3671
  def fetch_borrow_interest(self, code: Str = None, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
@@ -3774,7 +3774,7 @@ class bitmart(Exchange, ImplicitAPI):
3774
3774
  # "trace": "7f9c94e10f9d4513bc08a7bfc2a5559a.72.16946575108274991"
3775
3775
  # }
3776
3776
  #
3777
- data = self.safe_value(response, 'data', {})
3777
+ data = self.safe_dict(response, 'data', {})
3778
3778
  return self.parse_open_interest(data, market)
3779
3779
 
3780
3780
  def parse_open_interest(self, interest, market: Market = None):
@@ -3930,7 +3930,7 @@ class bitmart(Exchange, ImplicitAPI):
3930
3930
  # }
3931
3931
  #
3932
3932
  data = self.safe_value(response, 'data', [])
3933
- first = self.safe_value(data, 0, {})
3933
+ first = self.safe_dict(data, 0, {})
3934
3934
  return self.parse_position(first, market)
3935
3935
 
3936
3936
  def fetch_positions(self, symbols: Strings = None, params={}):
ccxt/bitopro.py CHANGED
@@ -1574,7 +1574,7 @@ class bitopro(Exchange, ImplicitAPI):
1574
1574
  # ]
1575
1575
  # }
1576
1576
  #
1577
- data = self.safe_value(response, 'data', [])
1577
+ data = self.safe_list(response, 'data', [])
1578
1578
  return self.parse_deposit_withdraw_fees(data, codes, 'currency')
1579
1579
 
1580
1580
  def sign(self, path, api='public', method='GET', params={}, headers=None, body=None):
ccxt/bitrue.py CHANGED
@@ -2403,7 +2403,7 @@ class bitrue(Exchange, ImplicitAPI):
2403
2403
  # ]
2404
2404
  # }
2405
2405
  #
2406
- data = self.safe_value(response, 'data', [])
2406
+ data = self.safe_list(response, 'data', [])
2407
2407
  return self.parse_transactions(data, currency, since, limit)
2408
2408
 
2409
2409
  def fetch_withdrawals(self, code: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Transaction]:
@@ -2641,7 +2641,7 @@ class bitrue(Exchange, ImplicitAPI):
2641
2641
  # }
2642
2642
  # }
2643
2643
  #
2644
- data = self.safe_value(response, 'data', {})
2644
+ data = self.safe_dict(response, 'data', {})
2645
2645
  return self.parse_transaction(data, currency)
2646
2646
 
2647
2647
  def parse_deposit_withdraw_fee(self, fee, currency: Currency = None):
@@ -2692,7 +2692,7 @@ class bitrue(Exchange, ImplicitAPI):
2692
2692
  """
2693
2693
  self.load_markets()
2694
2694
  response = self.spotV1PublicGetExchangeInfo(params)
2695
- coins = self.safe_value(response, 'coins')
2695
+ coins = self.safe_list(response, 'coins')
2696
2696
  return self.parse_deposit_withdraw_fees(coins, codes, 'coin')
2697
2697
 
2698
2698
  def parse_transfer(self, transfer, currency=None):
@@ -2810,7 +2810,7 @@ class bitrue(Exchange, ImplicitAPI):
2810
2810
  # 'data': null
2811
2811
  # }
2812
2812
  #
2813
- data = self.safe_value(response, 'data', {})
2813
+ data = self.safe_dict(response, 'data', {})
2814
2814
  return self.parse_transfer(data, currency)
2815
2815
 
2816
2816
  def set_leverage(self, leverage: Int, symbol: Str = None, params={}):
ccxt/bitso.py CHANGED
@@ -670,7 +670,7 @@ class bitso(Exchange, ImplicitAPI):
670
670
  # ]
671
671
  # }
672
672
  #
673
- payload = self.safe_value(response, 'payload', [])
673
+ payload = self.safe_list(response, 'payload', [])
674
674
  return self.parse_ohlcvs(payload, market, timeframe, since, limit)
675
675
 
676
676
  def parse_ohlcv(self, ohlcv, market: Market = None) -> list:
@@ -1183,7 +1183,7 @@ class bitso(Exchange, ImplicitAPI):
1183
1183
  # }
1184
1184
  #
1185
1185
  transactions = self.safe_value(response, 'payload', [])
1186
- first = self.safe_value(transactions, 0, {})
1186
+ first = self.safe_dict(transactions, 0, {})
1187
1187
  return self.parse_transaction(first)
1188
1188
 
1189
1189
  def fetch_deposits(self, code: Str = None, since: Int = None, limit: Int = None, params={}) -> List[Transaction]:
@@ -1224,7 +1224,7 @@ class bitso(Exchange, ImplicitAPI):
1224
1224
  # }]
1225
1225
  # }
1226
1226
  #
1227
- transactions = self.safe_value(response, 'payload', [])
1227
+ transactions = self.safe_list(response, 'payload', [])
1228
1228
  return self.parse_transactions(transactions, currency, since, limit, params)
1229
1229
 
1230
1230
  def fetch_deposit_address(self, code: str, params={}):
@@ -1396,7 +1396,7 @@ class bitso(Exchange, ImplicitAPI):
1396
1396
  # }
1397
1397
  # }
1398
1398
  #
1399
- payload = self.safe_value(response, 'payload', {})
1399
+ payload = self.safe_list(response, 'payload', [])
1400
1400
  return self.parse_deposit_withdraw_fees(payload, codes)
1401
1401
 
1402
1402
  def parse_deposit_withdraw_fees(self, response, codes=None, currencyIdKey=None):
@@ -1524,7 +1524,7 @@ class bitso(Exchange, ImplicitAPI):
1524
1524
  # }
1525
1525
  #
1526
1526
  payload = self.safe_value(response, 'payload', [])
1527
- first = self.safe_value(payload, 0)
1527
+ first = self.safe_dict(payload, 0)
1528
1528
  return self.parse_transaction(first, currency)
1529
1529
 
1530
1530
  def safe_network(self, networkId):
ccxt/bitstamp.py CHANGED
@@ -1073,7 +1073,7 @@ class bitstamp(Exchange, ImplicitAPI):
1073
1073
  # }
1074
1074
  #
1075
1075
  data = self.safe_value(response, 'data', {})
1076
- ohlc = self.safe_value(data, 'ohlc', [])
1076
+ ohlc = self.safe_list(data, 'ohlc', [])
1077
1077
  return self.parse_ohlcvs(ohlc, market, timeframe, since, limit)
1078
1078
 
1079
1079
  def parse_balance(self, response) -> Balances: