ccxt 4.4.9__py2.py3-none-any.whl → 4.4.10__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 (77) hide show
  1. ccxt/__init__.py +1 -1
  2. ccxt/abstract/oceanex.py +5 -0
  3. ccxt/ascendex.py +5 -4
  4. ccxt/async_support/__init__.py +1 -1
  5. ccxt/async_support/ascendex.py +5 -4
  6. ccxt/async_support/base/exchange.py +1 -1
  7. ccxt/async_support/binance.py +8 -11
  8. ccxt/async_support/bingx.py +20 -21
  9. ccxt/async_support/bitfinex2.py +7 -16
  10. ccxt/async_support/bitget.py +8 -7
  11. ccxt/async_support/bitmart.py +4 -3
  12. ccxt/async_support/bitmex.py +7 -6
  13. ccxt/async_support/blofin.py +7 -16
  14. ccxt/async_support/bybit.py +18 -16
  15. ccxt/async_support/coinex.py +19 -5
  16. ccxt/async_support/delta.py +6 -5
  17. ccxt/async_support/deribit.py +4 -3
  18. ccxt/async_support/digifinex.py +18 -4
  19. ccxt/async_support/gate.py +32 -13
  20. ccxt/async_support/hashkey.py +6 -6
  21. ccxt/async_support/hitbtc.py +6 -5
  22. ccxt/async_support/htx.py +23 -6
  23. ccxt/async_support/hyperliquid.py +6 -1
  24. ccxt/async_support/krakenfutures.py +6 -5
  25. ccxt/async_support/kucoinfutures.py +13 -2
  26. ccxt/async_support/mexc.py +4 -3
  27. ccxt/async_support/oceanex.py +80 -4
  28. ccxt/async_support/okx.py +17 -3
  29. ccxt/async_support/oxfun.py +7 -7
  30. ccxt/async_support/phemex.py +4 -3
  31. ccxt/async_support/poloniexfutures.py +13 -2
  32. ccxt/async_support/vertex.py +6 -5
  33. ccxt/async_support/whitebit.py +14 -13
  34. ccxt/async_support/woo.py +42 -21
  35. ccxt/async_support/woofipro.py +19 -6
  36. ccxt/async_support/xt.py +5 -3
  37. ccxt/base/exchange.py +1 -1
  38. ccxt/base/types.py +1 -0
  39. ccxt/binance.py +8 -11
  40. ccxt/bingx.py +20 -21
  41. ccxt/bitfinex2.py +7 -16
  42. ccxt/bitget.py +8 -7
  43. ccxt/bitmart.py +4 -3
  44. ccxt/bitmex.py +7 -6
  45. ccxt/blofin.py +7 -16
  46. ccxt/bybit.py +18 -16
  47. ccxt/coinex.py +19 -5
  48. ccxt/delta.py +6 -5
  49. ccxt/deribit.py +4 -3
  50. ccxt/digifinex.py +18 -4
  51. ccxt/gate.py +32 -13
  52. ccxt/hashkey.py +6 -6
  53. ccxt/hitbtc.py +6 -5
  54. ccxt/htx.py +23 -6
  55. ccxt/hyperliquid.py +6 -1
  56. ccxt/krakenfutures.py +6 -5
  57. ccxt/kucoinfutures.py +13 -2
  58. ccxt/mexc.py +4 -3
  59. ccxt/oceanex.py +80 -4
  60. ccxt/okx.py +17 -3
  61. ccxt/oxfun.py +7 -7
  62. ccxt/phemex.py +4 -3
  63. ccxt/poloniexfutures.py +13 -2
  64. ccxt/pro/__init__.py +1 -1
  65. ccxt/pro/deribit.py +39 -2
  66. ccxt/pro/gate.py +1 -1
  67. ccxt/vertex.py +6 -5
  68. ccxt/whitebit.py +14 -13
  69. ccxt/woo.py +42 -21
  70. ccxt/woofipro.py +19 -6
  71. ccxt/xt.py +5 -3
  72. ccxt-4.4.10.dist-info/METADATA +636 -0
  73. {ccxt-4.4.9.dist-info → ccxt-4.4.10.dist-info}/RECORD +76 -76
  74. ccxt-4.4.9.dist-info/METADATA +0 -636
  75. {ccxt-4.4.9.dist-info → ccxt-4.4.10.dist-info}/LICENSE.txt +0 -0
  76. {ccxt-4.4.9.dist-info → ccxt-4.4.10.dist-info}/WHEEL +0 -0
  77. {ccxt-4.4.9.dist-info → ccxt-4.4.10.dist-info}/top_level.txt +0 -0
ccxt/htx.py CHANGED
@@ -6,7 +6,7 @@
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.htx import ImplicitAPI
8
8
  import hashlib
9
- from ccxt.base.types import Account, Balances, Currencies, Currency, Int, IsolatedBorrowRate, IsolatedBorrowRates, LedgerEntry, LeverageTier, LeverageTiers, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFeeInterface, Transaction, TransferEntry
9
+ from ccxt.base.types import Account, Balances, Currencies, Currency, Int, IsolatedBorrowRate, IsolatedBorrowRates, LedgerEntry, LeverageTier, LeverageTiers, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, FundingRate, FundingRates, 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 AuthenticationError
@@ -202,7 +202,7 @@ class htx(Exchange, ImplicitAPI):
202
202
  },
203
203
  'www': 'https://www.huobi.com',
204
204
  'referral': {
205
- 'url': 'https://www.huobi.com/en-us/v/register/double-invite/?inviter_id=11343840&invite_code=6rmm2223',
205
+ 'url': 'https://www.htx.com.vc/invite/en-us/1h?invite_code=6rmm2223',
206
206
  'discount': 0.15,
207
207
  },
208
208
  'doc': [
@@ -6382,7 +6382,7 @@ class htx(Exchange, ImplicitAPI):
6382
6382
  sorted = self.sort_by(rates, 'timestamp')
6383
6383
  return self.filter_by_symbol_since_limit(sorted, market['symbol'], since, limit)
6384
6384
 
6385
- def parse_funding_rate(self, contract, market: Market = None):
6385
+ def parse_funding_rate(self, contract, market: Market = None) -> FundingRate:
6386
6386
  #
6387
6387
  # {
6388
6388
  # "status": "ok",
@@ -6401,6 +6401,9 @@ class htx(Exchange, ImplicitAPI):
6401
6401
  nextFundingRate = self.safe_number(contract, 'estimated_rate')
6402
6402
  fundingTimestamp = self.safe_integer(contract, 'funding_time')
6403
6403
  nextFundingTimestamp = self.safe_integer(contract, 'next_funding_time')
6404
+ fundingTimeString = self.safe_string(contract, 'funding_time')
6405
+ nextFundingTimeString = self.safe_string(contract, 'next_funding_time')
6406
+ millisecondsInterval = Precise.string_sub(nextFundingTimeString, fundingTimeString)
6404
6407
  marketId = self.safe_string(contract, 'contract_code')
6405
6408
  symbol = self.safe_symbol(marketId, market)
6406
6409
  return {
@@ -6421,9 +6424,20 @@ class htx(Exchange, ImplicitAPI):
6421
6424
  'previousFundingRate': None,
6422
6425
  'previousFundingTimestamp': None,
6423
6426
  'previousFundingDatetime': None,
6427
+ 'interval': self.parse_funding_interval(millisecondsInterval),
6424
6428
  }
6425
6429
 
6426
- def fetch_funding_rate(self, symbol: str, params={}):
6430
+ def parse_funding_interval(self, interval):
6431
+ intervals: dict = {
6432
+ '3600000': '1h',
6433
+ '14400000': '4h',
6434
+ '28800000': '8h',
6435
+ '57600000': '16h',
6436
+ '86400000': '24h',
6437
+ }
6438
+ return self.safe_string(intervals, interval, interval)
6439
+
6440
+ def fetch_funding_rate(self, symbol: str, params={}) -> FundingRate:
6427
6441
  """
6428
6442
  fetch the current funding rate
6429
6443
  :param str symbol: unified market symbol
@@ -6460,12 +6474,12 @@ class htx(Exchange, ImplicitAPI):
6460
6474
  result = self.safe_value(response, 'data', {})
6461
6475
  return self.parse_funding_rate(result, market)
6462
6476
 
6463
- def fetch_funding_rates(self, symbols: Strings = None, params={}):
6477
+ def fetch_funding_rates(self, symbols: Strings = None, params={}) -> FundingRates:
6464
6478
  """
6465
6479
  fetch the funding rate for multiple markets
6466
6480
  :param str[]|None symbols: list of unified market symbols
6467
6481
  :param dict [params]: extra parameters specific to the exchange API endpoint
6468
- :returns dict: a dictionary of `funding rates structures <https://docs.ccxt.com/#/?id=funding-rates-structure>`, indexe by market symbols
6482
+ :returns dict[]: a list of `funding rate structures <https://docs.ccxt.com/#/?id=funding-rates-structure>`, indexed by market symbols
6469
6483
  """
6470
6484
  self.load_markets()
6471
6485
  symbols = self.market_symbols(symbols)
@@ -8096,6 +8110,9 @@ class htx(Exchange, ImplicitAPI):
8096
8110
  def fetch_settlement_history(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
8097
8111
  """
8098
8112
  Fetches historical settlement records
8113
+ :see: https://huobiapi.github.io/docs/dm/v1/en/#query-historical-settlement-records-of-the-platform-interface
8114
+ :see: https://huobiapi.github.io/docs/coin_margined_swap/v1/en/#query-historical-settlement-records-of-the-platform-interface
8115
+ :see: https://huobiapi.github.io/docs/usdt_swap/v1/en/#general-query-historical-settlement-records-of-the-platform-interface
8099
8116
  :param str symbol: unified symbol of the market to fetch the settlement history for
8100
8117
  :param int [since]: timestamp in ms, value range = current time - 90 days,default = current time - 90 days
8101
8118
  :param int [limit]: page items, default 20, shall not exceed 50
ccxt/hyperliquid.py CHANGED
@@ -1926,6 +1926,7 @@ class hyperliquid(Exchange, ImplicitAPI):
1926
1926
  # "crossed": True,
1927
1927
  # "dir": "Close Long",
1928
1928
  # "fee": "0.050062",
1929
+ # "feeToken": "USDC",
1929
1930
  # "hash": "0x09d77c96791e98b5775a04092584ab010d009445119c71e4005c0d634ea322bc",
1930
1931
  # "liquidationMarkPx": null,
1931
1932
  # "oid": 3929354691,
@@ -1984,7 +1985,11 @@ class hyperliquid(Exchange, ImplicitAPI):
1984
1985
  'price': price,
1985
1986
  'amount': amount,
1986
1987
  'cost': None,
1987
- 'fee': {'cost': fee, 'currency': 'USDC'},
1988
+ 'fee': {
1989
+ 'cost': fee,
1990
+ 'currency': self.safe_string(trade, 'feeToken'),
1991
+ 'rate': None,
1992
+ },
1988
1993
  }, market)
1989
1994
 
1990
1995
  def fetch_position(self, symbol: str, params={}):
ccxt/krakenfutures.py CHANGED
@@ -6,7 +6,7 @@
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.krakenfutures import ImplicitAPI
8
8
  import hashlib
9
- from ccxt.base.types import Balances, Currency, Int, Leverage, Leverages, LeverageTier, LeverageTiers, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TransferEntry
9
+ from ccxt.base.types import Balances, Currency, Int, Leverage, Leverages, LeverageTier, LeverageTiers, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, FundingRate, FundingRates, Trade, TransferEntry
10
10
  from typing import List
11
11
  from ccxt.base.errors import ExchangeError
12
12
  from ccxt.base.errors import AuthenticationError
@@ -2030,10 +2030,10 @@ class krakenfutures(Exchange, ImplicitAPI):
2030
2030
  result[code] = account
2031
2031
  return self.safe_balance(result)
2032
2032
 
2033
- def fetch_funding_rates(self, symbols: Strings = None, params={}):
2033
+ def fetch_funding_rates(self, symbols: Strings = None, params={}) -> FundingRates:
2034
2034
  """
2035
+ fetch the current funding rates for multiple markets
2035
2036
  :see: https://docs.futures.kraken.com/#http-api-trading-v3-api-market-data-get-tickers
2036
- fetch the current funding rates
2037
2037
  :param str[] symbols: unified market symbols
2038
2038
  :param dict [params]: extra parameters specific to the exchange API endpoint
2039
2039
  :returns Order[]: an array of `funding rate structures <https://docs.ccxt.com/#/?id=funding-rate-structure>`
@@ -2041,7 +2041,7 @@ class krakenfutures(Exchange, ImplicitAPI):
2041
2041
  self.load_markets()
2042
2042
  marketIds = self.market_ids(symbols)
2043
2043
  response = self.publicGetTickers(params)
2044
- tickers = self.safe_value(response, 'tickers')
2044
+ tickers = self.safe_list(response, 'tickers', [])
2045
2045
  fundingRates = []
2046
2046
  for i in range(0, len(tickers)):
2047
2047
  entry = tickers[i]
@@ -2054,7 +2054,7 @@ class krakenfutures(Exchange, ImplicitAPI):
2054
2054
  fundingRates.append(parsed)
2055
2055
  return self.index_by(fundingRates, 'symbol')
2056
2056
 
2057
- def parse_funding_rate(self, ticker, market: Market = None):
2057
+ def parse_funding_rate(self, ticker, market: Market = None) -> FundingRate:
2058
2058
  #
2059
2059
  # {"ask": 26.283,
2060
2060
  # "askSize": 4.6,
@@ -2108,6 +2108,7 @@ class krakenfutures(Exchange, ImplicitAPI):
2108
2108
  'previousFundingRate': None,
2109
2109
  'previousFundingTimestamp': None,
2110
2110
  'previousFundingDatetime': None,
2111
+ 'interval': None,
2111
2112
  }
2112
2113
 
2113
2114
  def fetch_funding_rate_history(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
ccxt/kucoinfutures.py CHANGED
@@ -5,7 +5,7 @@
5
5
 
6
6
  from ccxt.kucoin import kucoin
7
7
  from ccxt.abstract.kucoinfutures import ImplicitAPI
8
- from ccxt.base.types import Balances, Currency, Int, Leverage, LeverageTier, MarginMode, MarginModification, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFeeInterface, Transaction, TransferEntry
8
+ from ccxt.base.types import Balances, Currency, Int, Leverage, LeverageTier, MarginMode, MarginModification, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, FundingRate, Trade, TradingFeeInterface, Transaction, TransferEntry
9
9
  from typing import List
10
10
  from ccxt.base.errors import AuthenticationError
11
11
  from ccxt.base.errors import PermissionDenied
@@ -2046,7 +2046,7 @@ class kucoinfutures(kucoin, ImplicitAPI):
2046
2046
  'trades': None,
2047
2047
  }, market)
2048
2048
 
2049
- def fetch_funding_rate(self, symbol: str, params={}):
2049
+ def fetch_funding_rate(self, symbol: str, params={}) -> FundingRate:
2050
2050
  """
2051
2051
  fetch the current funding rate
2052
2052
  :see: https://www.kucoin.com/docs/rest/futures-trading/funding-fees/get-current-funding-rate
@@ -2093,8 +2093,19 @@ class kucoinfutures(kucoin, ImplicitAPI):
2093
2093
  'previousFundingRate': None,
2094
2094
  'previousFundingTimestamp': None,
2095
2095
  'previousFundingDatetime': None,
2096
+ 'interval': self.parse_funding_interval(self.safe_string(data, 'granularity')),
2096
2097
  }
2097
2098
 
2099
+ def parse_funding_interval(self, interval):
2100
+ intervals: dict = {
2101
+ '3600000': '1h',
2102
+ '14400000': '4h',
2103
+ '28800000': '8h',
2104
+ '57600000': '16h',
2105
+ '86400000': '24h',
2106
+ }
2107
+ return self.safe_string(intervals, interval, interval)
2108
+
2098
2109
  def parse_balance(self, response) -> Balances:
2099
2110
  result: dict = {
2100
2111
  'info': response,
ccxt/mexc.py CHANGED
@@ -6,7 +6,7 @@
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.mexc import ImplicitAPI
8
8
  import hashlib
9
- from ccxt.base.types import Account, Balances, Currencies, Currency, IndexType, Int, Leverage, LeverageTier, LeverageTiers, MarginModification, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, Trade, TradingFees, Transaction, TransferEntry
9
+ from ccxt.base.types import Account, Balances, Currencies, Currency, IndexType, Int, Leverage, LeverageTier, LeverageTiers, MarginModification, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, FundingRate, Trade, TradingFees, Transaction, TransferEntry
10
10
  from typing import List
11
11
  from ccxt.base.errors import ExchangeError
12
12
  from ccxt.base.errors import AuthenticationError
@@ -3904,7 +3904,7 @@ class mexc(Exchange, ImplicitAPI):
3904
3904
  })
3905
3905
  return result
3906
3906
 
3907
- def parse_funding_rate(self, contract, market: Market = None):
3907
+ def parse_funding_rate(self, contract, market: Market = None) -> FundingRate:
3908
3908
  #
3909
3909
  # {
3910
3910
  # "symbol": "BTC_USDT",
@@ -3940,9 +3940,10 @@ class mexc(Exchange, ImplicitAPI):
3940
3940
  'previousFundingRate': None,
3941
3941
  'previousFundingTimestamp': None,
3942
3942
  'previousFundingDatetime': None,
3943
+ 'interval': None,
3943
3944
  }
3944
3945
 
3945
- def fetch_funding_rate(self, symbol: str, params={}):
3946
+ def fetch_funding_rate(self, symbol: str, params={}) -> FundingRate:
3946
3947
  """
3947
3948
  fetch the current funding rate
3948
3949
  :see: https://mexcdevelop.github.io/apidocs/contract_v1_en/#get-contract-funding-rate
ccxt/oceanex.py CHANGED
@@ -5,7 +5,7 @@
5
5
 
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.oceanex import ImplicitAPI
8
- from ccxt.base.types import Balances, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFees
8
+ from ccxt.base.types import Balances, Currency, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFees
9
9
  from typing import List
10
10
  from ccxt.base.errors import ExchangeError
11
11
  from ccxt.base.errors import AuthenticationError
@@ -54,9 +54,9 @@ class oceanex(Exchange, ImplicitAPI):
54
54
  'fetchClosedOrders': True,
55
55
  'fetchCrossBorrowRate': False,
56
56
  'fetchCrossBorrowRates': False,
57
- 'fetchDepositAddress': False,
58
- 'fetchDepositAddresses': False,
59
- 'fetchDepositAddressesByNetwork': False,
57
+ 'fetchDepositAddress': 'emulated',
58
+ 'fetchDepositAddresses': None,
59
+ 'fetchDepositAddressesByNetwork': True,
60
60
  'fetchIsolatedBorrowRate': False,
61
61
  'fetchIsolatedBorrowRates': False,
62
62
  'fetchMarkets': True,
@@ -117,6 +117,11 @@ class oceanex(Exchange, ImplicitAPI):
117
117
  'order/delete',
118
118
  'order/delete/multi',
119
119
  'orders/clear',
120
+ '/withdraws/special/new',
121
+ '/deposit_address',
122
+ '/deposit_addresses',
123
+ '/deposit_history',
124
+ '/withdraw_history',
120
125
  ],
121
126
  },
122
127
  },
@@ -858,6 +863,77 @@ class oceanex(Exchange, ImplicitAPI):
858
863
  data = self.safe_list(response, 'data')
859
864
  return self.parse_orders(data)
860
865
 
866
+ def fetch_deposit_addresses_by_network(self, code: str, params={}):
867
+ """
868
+ fetch the deposit addresses for a currency associated with self account
869
+ :see: https://api.oceanex.pro/doc/v1/#deposit-addresses-post
870
+ :param str code: unified currency code
871
+ :param dict [params]: extra parameters specific to the exchange API endpoint
872
+ :returns dict: a dictionary `address structures <https://docs.ccxt.com/#/?id=address-structure>`, indexed by the network
873
+ """
874
+ self.load_markets()
875
+ currency = self.currency(code)
876
+ request: dict = {
877
+ 'currency': currency['id'],
878
+ }
879
+ response = self.privatePostDepositAddresses(self.extend(request, params))
880
+ #
881
+ # {
882
+ # code: '0',
883
+ # message: 'Operation successful',
884
+ # data: {
885
+ # data: {
886
+ # currency_id: 'usdt',
887
+ # display_name: 'USDT',
888
+ # num_of_resources: '3',
889
+ # resources: [
890
+ # {
891
+ # chain_name: 'TRC20',
892
+ # currency_id: 'usdt',
893
+ # address: 'TPcS7VgKMFmpRrWY82GbJzDeMnemWxEbpg',
894
+ # memo: '',
895
+ # deposit_status: 'enabled'
896
+ # },
897
+ # ...
898
+ # ]
899
+ # }
900
+ # }
901
+ # }
902
+ #
903
+ data = self.safe_dict(response, 'data', {})
904
+ data2 = self.safe_dict(data, 'data', {})
905
+ resources = self.safe_list(data2, 'resources', [])
906
+ result = {}
907
+ for i in range(0, len(resources)):
908
+ resource = resources[i]
909
+ enabled = self.safe_string(resource, 'deposit_status')
910
+ if enabled == 'enabled':
911
+ parsedAddress = self.parse_deposit_address(resource, currency)
912
+ result[parsedAddress['currency']] = parsedAddress
913
+ return result
914
+
915
+ def parse_deposit_address(self, depositAddress, currency: Currency = None):
916
+ #
917
+ # {
918
+ # chain_name: 'TRC20',
919
+ # currency_id: 'usdt',
920
+ # address: 'TPcS7VgKMFmpRrWY82GbJzDeMnemWxEbpg',
921
+ # memo: '',
922
+ # deposit_status: 'enabled'
923
+ # }
924
+ #
925
+ address = self.safe_string(depositAddress, 'address')
926
+ self.check_address(address)
927
+ currencyId = self.safe_string(depositAddress, 'currency_id')
928
+ networkId = self.safe_string(depositAddress, 'chain_name')
929
+ return {
930
+ 'info': depositAddress,
931
+ 'currency': self.safe_currency_code(currencyId, currency),
932
+ 'address': address,
933
+ 'tag': self.safe_string(depositAddress, 'memo'),
934
+ 'network': self.network_id_to_code(networkId),
935
+ }
936
+
861
937
  def sign(self, path, api='public', method='GET', params={}, headers=None, body=None):
862
938
  url = self.urls['api']['rest'] + '/' + self.version + '/' + self.implode_params(path, params)
863
939
  query = self.omit(params, self.extract_params(path))
ccxt/okx.py CHANGED
@@ -6,7 +6,7 @@
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.okx import ImplicitAPI
8
8
  import hashlib
9
- from ccxt.base.types import Account, Balances, Conversion, CrossBorrowRate, CrossBorrowRates, Currencies, Currency, Greeks, Int, LedgerEntry, Leverage, LeverageTier, MarginModification, Market, MarketInterface, Num, Option, OptionChain, Order, OrderBook, OrderRequest, CancellationRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, Trade, TradingFeeInterface, Transaction, TransferEntry
9
+ from ccxt.base.types import Account, Balances, Conversion, CrossBorrowRate, CrossBorrowRates, Currencies, Currency, Greeks, Int, LedgerEntry, Leverage, LeverageTier, MarginModification, Market, MarketInterface, Num, Option, OptionChain, Order, OrderBook, OrderRequest, CancellationRequest, OrderSide, OrderType, Position, Str, Strings, Ticker, Tickers, FundingRate, Trade, TradingFeeInterface, Transaction, TransferEntry
10
10
  from typing import List
11
11
  from typing import Any
12
12
  from ccxt.base.errors import ExchangeError
@@ -5622,7 +5622,7 @@ class okx(Exchange, ImplicitAPI):
5622
5622
  headers['OK-ACCESS-SIGN'] = signature
5623
5623
  return {'url': url, 'method': method, 'body': body, 'headers': headers}
5624
5624
 
5625
- def parse_funding_rate(self, contract, market: Market = None):
5625
+ def parse_funding_rate(self, contract, market: Market = None) -> FundingRate:
5626
5626
  #
5627
5627
  # {
5628
5628
  # "fundingRate": "0.00027815",
@@ -5656,6 +5656,9 @@ class okx(Exchange, ImplicitAPI):
5656
5656
  symbol = self.safe_symbol(marketId, market)
5657
5657
  nextFundingRate = self.safe_number(contract, 'nextFundingRate')
5658
5658
  fundingTime = self.safe_integer(contract, 'fundingTime')
5659
+ fundingTimeString = self.safe_string(contract, 'fundingTime')
5660
+ nextFundingTimeString = self.safe_string(contract, 'nextFundingRate')
5661
+ millisecondsInterval = Precise.string_sub(nextFundingTimeString, fundingTimeString)
5659
5662
  # https://www.okx.com/support/hc/en-us/articles/360053909272-Ⅸ-Introduction-to-perpetual-swap-funding-fee
5660
5663
  # > The current interest is 0.
5661
5664
  return {
@@ -5676,9 +5679,20 @@ class okx(Exchange, ImplicitAPI):
5676
5679
  'previousFundingRate': None,
5677
5680
  'previousFundingTimestamp': None,
5678
5681
  'previousFundingDatetime': None,
5682
+ 'interval': self.parse_funding_interval(millisecondsInterval),
5679
5683
  }
5680
5684
 
5681
- def fetch_funding_rate(self, symbol: str, params={}):
5685
+ def parse_funding_interval(self, interval):
5686
+ intervals: dict = {
5687
+ '3600000': '1h',
5688
+ '14400000': '4h',
5689
+ '28800000': '8h',
5690
+ '57600000': '16h',
5691
+ '86400000': '24h',
5692
+ }
5693
+ return self.safe_string(intervals, interval, interval)
5694
+
5695
+ def fetch_funding_rate(self, symbol: str, params={}) -> FundingRate:
5682
5696
  """
5683
5697
  fetch the current funding rate
5684
5698
  :see: https://www.okx.com/docs-v5/en/#public-data-rest-api-get-funding-rate
ccxt/oxfun.py CHANGED
@@ -6,7 +6,7 @@
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.oxfun import ImplicitAPI
8
8
  import hashlib
9
- from ccxt.base.types import Account, Balances, Bool, Currencies, Currency, Int, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
9
+ from ccxt.base.types import Account, Balances, Bool, Currencies, Currency, Int, Market, Num, Order, OrderBook, OrderRequest, OrderSide, OrderType, Str, Strings, Ticker, Tickers, FundingRate, FundingRates, Trade, Transaction, TransferEntry
10
10
  from typing import List
11
11
  from ccxt.base.errors import ExchangeError
12
12
  from ccxt.base.errors import AuthenticationError
@@ -83,7 +83,7 @@ class oxfun(Exchange, ImplicitAPI):
83
83
  'fetchDepositWithdrawFee': False,
84
84
  'fetchDepositWithdrawFees': False,
85
85
  'fetchFundingHistory': True,
86
- 'fetchFundingRate': False,
86
+ 'fetchFundingRate': 'emulated',
87
87
  'fetchFundingRateHistory': True,
88
88
  'fetchFundingRates': True,
89
89
  'fetchIndexOHLCV': False,
@@ -987,10 +987,10 @@ class oxfun(Exchange, ImplicitAPI):
987
987
  timestamp = self.safe_integer(data, 'lastUpdatedAt')
988
988
  return self.parse_order_book(data, market['symbol'], timestamp)
989
989
 
990
- def fetch_funding_rates(self, symbols: Strings = None, params={}):
990
+ def fetch_funding_rates(self, symbols: Strings = None, params={}) -> FundingRates:
991
991
  """
992
+ fetch the current funding rates for multiple markets
992
993
  :see: https://docs.ox.fun/?json#get-v3-funding-estimates
993
- fetch the current funding rates
994
994
  :param str[] symbols: unified market symbols
995
995
  :param dict [params]: extra parameters specific to the exchange API endpoint
996
996
  :returns Order[]: an array of `funding rate structures <https://docs.ccxt.com/#/?id=funding-rate-structure>`
@@ -1020,14 +1020,13 @@ class oxfun(Exchange, ImplicitAPI):
1020
1020
  result = self.parse_funding_rates(data)
1021
1021
  return self.filter_by_array(result, 'symbol', symbols)
1022
1022
 
1023
- def parse_funding_rate(self, fundingRate, market: Market = None):
1023
+ def parse_funding_rate(self, fundingRate, market: Market = None) -> FundingRate:
1024
1024
  #
1025
1025
  # {
1026
1026
  # "marketCode": "OX-USD-SWAP-LIN",
1027
1027
  # "fundingAt": "1715515200000",
1028
1028
  # "estFundingRate": "0.000200000"
1029
- # },
1030
- #
1029
+ # }
1031
1030
  #
1032
1031
  symbol = self.safe_string(fundingRate, 'marketCode')
1033
1032
  market = self.market(symbol)
@@ -1050,6 +1049,7 @@ class oxfun(Exchange, ImplicitAPI):
1050
1049
  'previousFundingRate': None,
1051
1050
  'previousFundingTimestamp': None,
1052
1051
  'previousFundingDatetime': None,
1052
+ 'interval': None,
1053
1053
  }
1054
1054
 
1055
1055
  def fetch_funding_rate_history(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
ccxt/phemex.py CHANGED
@@ -7,7 +7,7 @@ from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.phemex import ImplicitAPI
8
8
  import hashlib
9
9
  import numbers
10
- from ccxt.base.types import Balances, Currencies, Currency, Int, LeverageTier, LeverageTiers, MarginModification, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, Transaction, TransferEntry
10
+ from ccxt.base.types import Balances, Currencies, Currency, Int, LeverageTier, LeverageTiers, MarginModification, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, FundingRate, Trade, Transaction, TransferEntry
11
11
  from typing import List
12
12
  from ccxt.base.errors import ExchangeError
13
13
  from ccxt.base.errors import AuthenticationError
@@ -3741,7 +3741,7 @@ class phemex(Exchange, ImplicitAPI):
3741
3741
  value = Precise.string_mul(value, tickPrecision)
3742
3742
  return value
3743
3743
 
3744
- def fetch_funding_rate(self, symbol: str, params={}):
3744
+ def fetch_funding_rate(self, symbol: str, params={}) -> FundingRate:
3745
3745
  """
3746
3746
  fetch the current funding rate
3747
3747
  :param str symbol: unified market symbol
@@ -3786,7 +3786,7 @@ class phemex(Exchange, ImplicitAPI):
3786
3786
  result = self.safe_value(response, 'result', {})
3787
3787
  return self.parse_funding_rate(result, market)
3788
3788
 
3789
- def parse_funding_rate(self, contract, market: Market = None):
3789
+ def parse_funding_rate(self, contract, market: Market = None) -> FundingRate:
3790
3790
  #
3791
3791
  # {
3792
3792
  # "askEp": 2332500,
@@ -3845,6 +3845,7 @@ class phemex(Exchange, ImplicitAPI):
3845
3845
  'previousFundingRate': None,
3846
3846
  'previousFundingTimestamp': None,
3847
3847
  'previousFundingDatetime': None,
3848
+ 'interval': None,
3848
3849
  }
3849
3850
 
3850
3851
  def set_margin(self, symbol: str, amount: float, params={}) -> MarginModification:
ccxt/poloniexfutures.py CHANGED
@@ -6,7 +6,7 @@
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.poloniexfutures import ImplicitAPI
8
8
  import hashlib
9
- from ccxt.base.types import Balances, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade
9
+ from ccxt.base.types import Balances, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, FundingRate, Trade
10
10
  from typing import List
11
11
  from ccxt.base.errors import AuthenticationError
12
12
  from ccxt.base.errors import AccountSuspended
@@ -1527,7 +1527,7 @@ class poloniexfutures(Exchange, ImplicitAPI):
1527
1527
  'trades': None,
1528
1528
  }, market)
1529
1529
 
1530
- def fetch_funding_rate(self, symbol: str, params={}):
1530
+ def fetch_funding_rate(self, symbol: str, params={}) -> FundingRate:
1531
1531
  """
1532
1532
  fetch the current funding rate
1533
1533
  :see: https://api-docs.poloniex.com/futures/api/futures-index#get-premium-index
@@ -1571,8 +1571,19 @@ class poloniexfutures(Exchange, ImplicitAPI):
1571
1571
  'previousFundingRate': self.safe_number(data, 'value'),
1572
1572
  'previousFundingTimestamp': fundingTimestamp,
1573
1573
  'previousFundingDatetime': self.iso8601(fundingTimestamp),
1574
+ 'interval': self.parse_funding_interval(self.safe_string(data, 'interval')),
1574
1575
  }
1575
1576
 
1577
+ def parse_funding_interval(self, interval):
1578
+ intervals: dict = {
1579
+ '3600000': '1h',
1580
+ '14400000': '4h',
1581
+ '28800000': '8h',
1582
+ '57600000': '16h',
1583
+ '86400000': '24h',
1584
+ }
1585
+ return self.safe_string(intervals, interval, interval)
1586
+
1576
1587
  def fetch_my_trades(self, symbol: Str = None, since: Int = None, limit: Int = None, params={}):
1577
1588
  """
1578
1589
  fetch all trades made by the user
ccxt/pro/__init__.py CHANGED
@@ -4,7 +4,7 @@
4
4
 
5
5
  # ----------------------------------------------------------------------------
6
6
 
7
- __version__ = '4.4.9'
7
+ __version__ = '4.4.10'
8
8
 
9
9
  # ----------------------------------------------------------------------------
10
10
 
ccxt/pro/deribit.py CHANGED
@@ -6,7 +6,7 @@
6
6
  import ccxt.async_support
7
7
  from ccxt.async_support.base.ws.cache import ArrayCache, ArrayCacheBySymbolById, ArrayCacheByTimestamp
8
8
  import hashlib
9
- from ccxt.base.types import Balances, Int, Order, OrderBook, Str, Ticker, Trade
9
+ from ccxt.base.types import Balances, Int, Order, OrderBook, Str, Strings, Ticker, Tickers, Trade
10
10
  from ccxt.async_support.base.ws.client import Client
11
11
  from typing import List
12
12
  from ccxt.base.errors import ExchangeError
@@ -22,7 +22,7 @@ class deribit(ccxt.async_support.deribit):
22
22
  'ws': True,
23
23
  'watchBalance': True,
24
24
  'watchTicker': True,
25
- 'watchTickers': False,
25
+ 'watchTickers': True,
26
26
  'watchTrades': True,
27
27
  'watchTradesForSymbols': True,
28
28
  'watchMyTrades': True,
@@ -189,6 +189,43 @@ class deribit(ccxt.async_support.deribit):
189
189
  request = self.deep_extend(message, params)
190
190
  return await self.watch(url, channel, request, channel, request)
191
191
 
192
+ async def watch_tickers(self, symbols: Strings = None, params={}) -> Tickers:
193
+ """
194
+ :see: https://docs.deribit.com/#ticker-instrument_name-interval
195
+ watches a price ticker, a statistical calculation with the information calculated over the past 24 hours for all markets of a specific list
196
+ :param str[] [symbols]: unified symbol of the market to fetch the ticker for
197
+ :param dict [params]: extra parameters specific to the exchange API endpoint
198
+ :param str [params.interval]: specify aggregation and frequency of notifications. Possible values: 100ms, raw
199
+ :returns dict: a `ticker structure <https://docs.ccxt.com/#/?id=ticker-structure>`
200
+ """
201
+ await self.load_markets()
202
+ symbols = self.market_symbols(symbols, None, False)
203
+ url = self.urls['api']['ws']
204
+ interval = self.safe_string(params, 'interval', '100ms')
205
+ params = self.omit(params, 'interval')
206
+ await self.load_markets()
207
+ if interval == 'raw':
208
+ await self.authenticate()
209
+ channels = []
210
+ for i in range(0, len(symbols)):
211
+ market = self.market(symbols[i])
212
+ channels.append('ticker.' + market['id'] + '.' + interval)
213
+ message: dict = {
214
+ 'jsonrpc': '2.0',
215
+ 'method': 'public/subscribe',
216
+ 'params': {
217
+ 'channels': channels,
218
+ },
219
+ 'id': self.request_id(),
220
+ }
221
+ request = self.deep_extend(message, params)
222
+ newTickers = await self.watch_multiple(url, channels, request, channels, request)
223
+ if self.newUpdates:
224
+ tickers: dict = {}
225
+ tickers[newTickers['symbol']] = newTickers
226
+ return tickers
227
+ return self.filter_by_array(self.tickers, 'symbol', symbols)
228
+
192
229
  def handle_ticker(self, client: Client, message):
193
230
  #
194
231
  # {
ccxt/pro/gate.py CHANGED
@@ -332,7 +332,7 @@ class gate(ccxt.async_support.gate):
332
332
  symbol = market['symbol']
333
333
  if market['swap'] is not True:
334
334
  raise NotSupported(self.id + ' fetchOrdersByStatusWs is only supported by swap markets. Use rest API for other markets')
335
- request, requestParams = self.fetchOrdersByStatusRequest(status, symbol, since, limit, params)
335
+ request, requestParams = self.prepareOrdersByStatusRequest(status, symbol, since, limit, params)
336
336
  newRequest = self.omit(request, ['settle'])
337
337
  messageType = self.get_type_by_market(market)
338
338
  channel = messageType + '.order_list'
ccxt/vertex.py CHANGED
@@ -5,7 +5,7 @@
5
5
 
6
6
  from ccxt.base.exchange import Exchange
7
7
  from ccxt.abstract.vertex import ImplicitAPI
8
- from ccxt.base.types import Balances, Currencies, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, Trade, TradingFees
8
+ from ccxt.base.types import Balances, Currencies, Int, Market, Num, Order, OrderBook, OrderSide, OrderType, Str, Strings, Ticker, Tickers, FundingRate, FundingRates, Trade, TradingFees
9
9
  from typing import List
10
10
  from ccxt.base.errors import ExchangeError
11
11
  from ccxt.base.errors import AuthenticationError
@@ -1154,7 +1154,7 @@ class vertex(Exchange, ImplicitAPI):
1154
1154
  rows = self.safe_list(response, 'candlesticks', [])
1155
1155
  return self.parse_ohlcvs(rows, market, timeframe, since, limit)
1156
1156
 
1157
- def parse_funding_rate(self, ticker, market: Market = None):
1157
+ def parse_funding_rate(self, ticker, market: Market = None) -> FundingRate:
1158
1158
  #
1159
1159
  # {
1160
1160
  # "product_id": 4,
@@ -1208,9 +1208,10 @@ class vertex(Exchange, ImplicitAPI):
1208
1208
  'previousFundingRate': None,
1209
1209
  'previousFundingTimestamp': None,
1210
1210
  'previousFundingDatetime': None,
1211
+ 'interval': None,
1211
1212
  }
1212
1213
 
1213
- def fetch_funding_rate(self, symbol: str, params={}):
1214
+ def fetch_funding_rate(self, symbol: str, params={}) -> FundingRate:
1214
1215
  """
1215
1216
  fetch the current funding rate
1216
1217
  :see: https://docs.vertexprotocol.com/developer-resources/api/archive-indexer/funding-rate
@@ -1235,13 +1236,13 @@ class vertex(Exchange, ImplicitAPI):
1235
1236
  #
1236
1237
  return self.parse_funding_rate(response, market)
1237
1238
 
1238
- def fetch_funding_rates(self, symbols: Strings = None, params={}):
1239
+ def fetch_funding_rates(self, symbols: Strings = None, params={}) -> FundingRates:
1239
1240
  """
1240
1241
  fetches funding rates for multiple markets
1241
1242
  :see: https://docs.vertexprotocol.com/developer-resources/api/v2/contracts
1242
1243
  :param str[] symbols: unified symbols of the markets to fetch the funding rates for, all market funding rates are returned if not assigned
1243
1244
  :param dict [params]: extra parameters specific to the exchange API endpoint
1244
- :returns dict: an array of `funding rate structures <https://docs.ccxt.com/#/?id=funding-rate-structure>`
1245
+ :returns dict[]: an array of `funding rate structures <https://docs.ccxt.com/#/?id=funding-rate-structure>`
1245
1246
  """
1246
1247
  self.load_markets()
1247
1248
  request = {}