ccxt 4.4.43__py2.py3-none-any.whl → 4.4.44__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 (78) hide show
  1. ccxt/__init__.py +1 -1
  2. ccxt/abstract/binance.py +1 -0
  3. ccxt/abstract/binancecoinm.py +1 -0
  4. ccxt/abstract/binanceus.py +1 -0
  5. ccxt/abstract/binanceusdm.py +1 -0
  6. ccxt/async_support/__init__.py +1 -1
  7. ccxt/async_support/base/exchange.py +1 -1
  8. ccxt/async_support/binance.py +57 -45
  9. ccxt/async_support/bingx.py +5 -0
  10. ccxt/async_support/bitfinex.py +6 -2
  11. ccxt/async_support/bitget.py +3 -1
  12. ccxt/async_support/bitmart.py +4 -7
  13. ccxt/async_support/bitmex.py +3 -5
  14. ccxt/async_support/bitstamp.py +5 -0
  15. ccxt/async_support/bybit.py +8 -23
  16. ccxt/async_support/coinbase.py +13 -9
  17. ccxt/async_support/coinbaseinternational.py +13 -9
  18. ccxt/async_support/coincatch.py +2 -2
  19. ccxt/async_support/coinex.py +5 -5
  20. ccxt/async_support/cryptocom.py +4 -2
  21. ccxt/async_support/defx.py +2 -2
  22. ccxt/async_support/delta.py +1 -1
  23. ccxt/async_support/gate.py +9 -4
  24. ccxt/async_support/gemini.py +5 -0
  25. ccxt/async_support/hashkey.py +9 -9
  26. ccxt/async_support/htx.py +101 -3
  27. ccxt/async_support/hyperliquid.py +5 -0
  28. ccxt/async_support/kraken.py +9 -2
  29. ccxt/async_support/krakenfutures.py +5 -0
  30. ccxt/async_support/kucoin.py +9 -7
  31. ccxt/async_support/kucoinfutures.py +5 -5
  32. ccxt/async_support/mexc.py +18 -12
  33. ccxt/async_support/ndax.py +1 -1
  34. ccxt/async_support/oceanex.py +1 -1
  35. ccxt/async_support/okx.py +5 -6
  36. ccxt/async_support/whitebit.py +4 -2
  37. ccxt/async_support/woo.py +5 -3
  38. ccxt/async_support/woofipro.py +5 -2
  39. ccxt/base/exchange.py +1 -1
  40. ccxt/binance.py +57 -45
  41. ccxt/bingx.py +5 -0
  42. ccxt/bitfinex.py +6 -2
  43. ccxt/bitget.py +3 -1
  44. ccxt/bitmart.py +4 -7
  45. ccxt/bitmex.py +3 -5
  46. ccxt/bitstamp.py +5 -0
  47. ccxt/bybit.py +8 -23
  48. ccxt/coinbase.py +13 -9
  49. ccxt/coinbaseinternational.py +13 -9
  50. ccxt/coincatch.py +2 -2
  51. ccxt/coinex.py +5 -5
  52. ccxt/cryptocom.py +4 -2
  53. ccxt/defx.py +2 -2
  54. ccxt/delta.py +1 -1
  55. ccxt/gate.py +9 -4
  56. ccxt/gemini.py +5 -0
  57. ccxt/hashkey.py +9 -9
  58. ccxt/htx.py +101 -3
  59. ccxt/hyperliquid.py +5 -0
  60. ccxt/kraken.py +9 -2
  61. ccxt/krakenfutures.py +5 -0
  62. ccxt/kucoin.py +9 -7
  63. ccxt/kucoinfutures.py +5 -5
  64. ccxt/mexc.py +18 -12
  65. ccxt/ndax.py +1 -1
  66. ccxt/oceanex.py +1 -1
  67. ccxt/okx.py +5 -6
  68. ccxt/pro/__init__.py +1 -1
  69. ccxt/pro/bitcoincom.py +4 -1
  70. ccxt/pro/bitopro.py +1 -1
  71. ccxt/whitebit.py +4 -2
  72. ccxt/woo.py +5 -3
  73. ccxt/woofipro.py +5 -2
  74. {ccxt-4.4.43.dist-info → ccxt-4.4.44.dist-info}/METADATA +4 -4
  75. {ccxt-4.4.43.dist-info → ccxt-4.4.44.dist-info}/RECORD +78 -78
  76. {ccxt-4.4.43.dist-info → ccxt-4.4.44.dist-info}/LICENSE.txt +0 -0
  77. {ccxt-4.4.43.dist-info → ccxt-4.4.44.dist-info}/WHEEL +0 -0
  78. {ccxt-4.4.43.dist-info → ccxt-4.4.44.dist-info}/top_level.txt +0 -0
ccxt/coinex.py CHANGED
@@ -532,11 +532,11 @@ class coinex(Exchange, ImplicitAPI):
532
532
  },
533
533
  'hedged': False,
534
534
  'trailing': False,
535
- # exchange-supported features
536
- # 'marketBuyRequiresPrice': True,
537
- # 'marketBuyByCost': True,
538
- # 'selfTradePrevention': True,
539
- # 'iceberg': True,
535
+ 'leverage': False,
536
+ 'marketBuyByCost': True,
537
+ 'marketBuyRequiresPrice': True,
538
+ 'selfTradePrevention': True, # todo: implement
539
+ 'iceberg': True, # todo implement
540
540
  },
541
541
  'createOrders': {
542
542
  'max': 5,
ccxt/cryptocom.py CHANGED
@@ -389,10 +389,12 @@ class cryptocom(Exchange, ImplicitAPI):
389
389
  'GTD': False,
390
390
  },
391
391
  'hedged': False,
392
- # exchange-supported features
393
- 'selfTradePrevention': True,
392
+ 'selfTradePrevention': True, # todo: implement
394
393
  'trailing': False,
395
394
  'iceberg': False,
395
+ 'leverage': False,
396
+ 'marketBuyByCost': True,
397
+ 'marketBuyRequiresPrice': True,
396
398
  },
397
399
  'createOrders': {
398
400
  'max': 10,
ccxt/defx.py CHANGED
@@ -925,10 +925,10 @@ class defx(Exchange, ImplicitAPI):
925
925
  id = self.safe_string(trade, 'id')
926
926
  oid = self.safe_string(trade, 'orderId')
927
927
  takerOrMaker = self.safe_string_lower(trade, 'role')
928
- buyerMaker = self.safe_string(trade, 'buyerMaker')
928
+ buyerMaker = self.safe_bool(trade, 'buyerMaker')
929
929
  side = self.safe_string_lower(trade, 'side')
930
930
  if buyerMaker is not None:
931
- if buyerMaker == 'true':
931
+ if buyerMaker:
932
932
  side = 'sell'
933
933
  else:
934
934
  side = 'buy'
ccxt/delta.py CHANGED
@@ -734,7 +734,7 @@ class delta(Exchange, ImplicitAPI):
734
734
  else:
735
735
  # other markets(swap, futures, move, spread, irs) seem to use the step of '1' contract
736
736
  amountPrecision = self.parse_number('1')
737
- linear = (settle == base)
737
+ linear = (settle == quote)
738
738
  optionType = None
739
739
  symbol = base + '/' + quote
740
740
  if swap or future or option:
ccxt/gate.py CHANGED
@@ -723,7 +723,7 @@ class gate(Exchange, ImplicitAPI):
723
723
  },
724
724
  },
725
725
  'features': {
726
- 'spot': {
726
+ 'default': {
727
727
  'sandbox': True,
728
728
  'createOrder': {
729
729
  'marginMode': True,
@@ -742,9 +742,11 @@ class gate(Exchange, ImplicitAPI):
742
742
  },
743
743
  'hedged': False,
744
744
  'trailing': False,
745
- # exchange-specific features
746
- 'iceberg': True,
747
- 'selfTradePrevention': True,
745
+ 'iceberg': True, # todo implement
746
+ 'selfTradePrevention': True, # todo implement
747
+ 'leverage': False,
748
+ 'marketBuyByCost': True,
749
+ 'marketBuyRequiresPrice': True,
748
750
  },
749
751
  'createOrders': {
750
752
  'max': 40, # NOTE! max 10 per symbol
@@ -780,6 +782,9 @@ class gate(Exchange, ImplicitAPI):
780
782
  'limit': 1000,
781
783
  },
782
784
  },
785
+ 'spot': {
786
+ 'extends': 'default',
787
+ },
783
788
  'forDerivatives': {
784
789
  'extends': 'spot',
785
790
  'createOrder': {
ccxt/gemini.py CHANGED
@@ -329,6 +329,11 @@ class gemini(Exchange, ImplicitAPI):
329
329
  },
330
330
  'hedged': False,
331
331
  'trailing': False,
332
+ 'leverage': False,
333
+ 'marketBuyByCost': True,
334
+ 'marketBuyRequiresPrice': False,
335
+ 'selfTradePrevention': False,
336
+ 'iceberg': False,
332
337
  },
333
338
  'createOrders': None,
334
339
  'fetchMyTrades': {
ccxt/hashkey.py CHANGED
@@ -380,13 +380,11 @@ class hashkey(Exchange, ImplicitAPI):
380
380
  },
381
381
  'hedged': False,
382
382
  'trailing': False,
383
- # exchange-supported features
384
- # 'marketBuyRequiresPrice': False,
385
- # 'marketBuyByCost': False,
386
- # 'selfTradePrevention': True,
387
- # 'twap': False,
388
- # 'iceberg': False,
389
- # 'oco': False,
383
+ 'leverage': False,
384
+ 'marketBuyByCost': True,
385
+ 'marketBuyRequiresPrice': True, # todo fix
386
+ 'selfTradePrevention': True, # todo implement
387
+ 'iceberg': False,
390
388
  },
391
389
  'createOrders': {
392
390
  'max': 20,
@@ -2393,8 +2391,10 @@ class hashkey(Exchange, ImplicitAPI):
2393
2391
  market = self.market(symbol)
2394
2392
  if not market['spot']:
2395
2393
  raise NotSupported(self.id + ' createMarketBuyOrderWithCost() is supported for spot markets only')
2396
- params['cost'] = cost
2397
- return self.create_order(symbol, 'market', 'buy', cost, None, params)
2394
+ req = {
2395
+ 'cost': cost,
2396
+ }
2397
+ return self.create_order(symbol, 'market', 'buy', cost, None, self.extend(req, params))
2398
2398
 
2399
2399
  def create_spot_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={}) -> Order:
2400
2400
  """
ccxt/htx.py CHANGED
@@ -114,6 +114,7 @@ class htx(Exchange, ImplicitAPI):
114
114
  'fetchOHLCV': True,
115
115
  'fetchOpenInterest': True,
116
116
  'fetchOpenInterestHistory': True,
117
+ 'fetchOpenInterests': True,
117
118
  'fetchOpenOrder': None,
118
119
  'fetchOpenOrders': True,
119
120
  'fetchOrder': True,
@@ -1269,9 +1270,11 @@ class htx(Exchange, ImplicitAPI):
1269
1270
  },
1270
1271
  'hedged': False,
1271
1272
  'trailing': False,
1272
- # exchange-specific features
1273
1273
  'iceberg': False,
1274
- 'selfTradePrevention': True,
1274
+ 'selfTradePrevention': True, # todo implement
1275
+ 'leverage': True, # todo implement
1276
+ 'marketBuyByCost': True,
1277
+ 'marketBuyRequiresPrice': True,
1275
1278
  },
1276
1279
  'createOrders': {
1277
1280
  'max': 10,
@@ -8003,6 +8006,100 @@ class htx(Exchange, ImplicitAPI):
8003
8006
  tick = self.safe_list(data, 'tick')
8004
8007
  return self.parse_open_interests_history(tick, market, since, limit)
8005
8008
 
8009
+ def fetch_open_interests(self, symbols: Strings = None, params={}):
8010
+ """
8011
+ Retrieves the open interest for a list of symbols
8012
+
8013
+ https://huobiapi.github.io/docs/dm/v1/en/#get-contract-open-interest-information
8014
+ https://huobiapi.github.io/docs/coin_margined_swap/v1/en/#get-swap-open-interest-information
8015
+ https://huobiapi.github.io/docs/usdt_swap/v1/en/#general-get-swap-open-interest-information
8016
+
8017
+ :param str[] [symbols]: a list of unified CCXT market symbols
8018
+ :param dict [params]: exchange specific parameters
8019
+ :returns dict[]: a list of `open interest structures <https://docs.ccxt.com/#/?id=open-interest-structure>`
8020
+ """
8021
+ self.load_markets()
8022
+ symbols = self.market_symbols(symbols)
8023
+ market = None
8024
+ if symbols is not None:
8025
+ symbolsLength = len(symbols)
8026
+ if symbolsLength > 0:
8027
+ first = self.safe_string(symbols, 0)
8028
+ market = self.market(first)
8029
+ request: dict = {}
8030
+ subType = None
8031
+ subType, params = self.handle_sub_type_and_params('fetchPositions', market, params, 'linear')
8032
+ marketType = None
8033
+ marketType, params = self.handle_market_type_and_params('fetchPositions', market, params)
8034
+ response = None
8035
+ if marketType == 'future':
8036
+ response = self.contractPublicGetApiV1ContractOpenInterest(self.extend(request, params))
8037
+ #
8038
+ # {
8039
+ # "status": "ok",
8040
+ # "data": [
8041
+ # {
8042
+ # "volume": 118850.000000000000000000,
8043
+ # "amount": 635.502025211544374189,
8044
+ # "symbol": "BTC",
8045
+ # "contract_type": "self_week",
8046
+ # "contract_code": "BTC220930",
8047
+ # "trade_amount": 1470.9400749347598691119206024033947897351,
8048
+ # "trade_volume": 286286,
8049
+ # "trade_turnover": 28628600.000000000000000000
8050
+ # }
8051
+ # ],
8052
+ # "ts": 1664337928805
8053
+ # }
8054
+ #
8055
+ elif subType == 'inverse':
8056
+ response = self.contractPublicGetSwapApiV1SwapOpenInterest(self.extend(request, params))
8057
+ #
8058
+ # {
8059
+ # "status": "ok",
8060
+ # "data": [
8061
+ # {
8062
+ # "volume": 518018.000000000000000000,
8063
+ # "amount": 2769.675777407074725180,
8064
+ # "symbol": "BTC",
8065
+ # "contract_code": "BTC-USD",
8066
+ # "trade_amount": 9544.4032080046491323463688602729806842458,
8067
+ # "trade_volume": 1848448,
8068
+ # "trade_turnover": 184844800.000000000000000000
8069
+ # }
8070
+ # ],
8071
+ # "ts": 1664337226028
8072
+ # }
8073
+ #
8074
+ else:
8075
+ request['contract_type'] = 'swap'
8076
+ response = self.contractPublicGetLinearSwapApiV1SwapOpenInterest(self.extend(request, params))
8077
+ #
8078
+ # {
8079
+ # "status": "ok",
8080
+ # "data": [
8081
+ # {
8082
+ # "volume": 7192610.000000000000000000,
8083
+ # "amount": 7192.610000000000000000,
8084
+ # "symbol": "BTC",
8085
+ # "value": 134654290.332000000000000000,
8086
+ # "contract_code": "BTC-USDT",
8087
+ # "trade_amount": 70692.804,
8088
+ # "trade_volume": 70692804,
8089
+ # "trade_turnover": 1379302592.9518,
8090
+ # "business_type": "swap",
8091
+ # "pair": "BTC-USDT",
8092
+ # "contract_type": "swap",
8093
+ # "trade_partition": "USDT"
8094
+ # }
8095
+ # ],
8096
+ # "ts": 1664336503144
8097
+ # }
8098
+ #
8099
+ data = self.safe_list(response, 'data', [])
8100
+ result = self.parse_open_interests(data)
8101
+ return self.filter_by_array(result, 'symbol', symbols)
8102
+
8006
8103
  def fetch_open_interest(self, symbol: str, params={}):
8007
8104
  """
8008
8105
  Retrieves the open interest of a currency
@@ -8161,8 +8258,9 @@ class htx(Exchange, ImplicitAPI):
8161
8258
  timestamp = self.safe_integer(interest, 'ts')
8162
8259
  amount = self.safe_number(interest, 'volume')
8163
8260
  value = self.safe_number(interest, 'value')
8261
+ marketId = self.safe_string(interest, 'contract_code')
8164
8262
  return self.safe_open_interest({
8165
- 'symbol': self.safe_string(market, 'symbol'),
8263
+ 'symbol': self.safe_symbol(marketId, market),
8166
8264
  'baseVolume': amount, # deprecated
8167
8265
  'quoteVolume': value, # deprecated
8168
8266
  'openInterestAmount': amount,
ccxt/hyperliquid.py CHANGED
@@ -246,6 +246,11 @@ class hyperliquid(Exchange, ImplicitAPI):
246
246
  },
247
247
  'hedged': False,
248
248
  'trailing': False,
249
+ 'leverage': False,
250
+ 'marketBuyByCost': False,
251
+ 'marketBuyRequiresPrice': False,
252
+ 'selfTradePrevention': False,
253
+ 'iceberg': False,
249
254
  },
250
255
  'createOrders': {
251
256
  'max': 1000,
ccxt/kraken.py CHANGED
@@ -464,6 +464,11 @@ class kraken(Exchange, ImplicitAPI):
464
464
  },
465
465
  'hedged': False,
466
466
  'trailing': True,
467
+ 'leverage': False,
468
+ 'marketBuyByCost': True,
469
+ 'marketBuyRequiresPrice': False,
470
+ 'selfTradePrevention': True, # todo implement
471
+ 'iceberg': True, # todo implement
467
472
  },
468
473
  'createOrders': None,
469
474
  'fetchMyTrades': {
@@ -1483,8 +1488,10 @@ class kraken(Exchange, ImplicitAPI):
1483
1488
  """
1484
1489
  self.load_markets()
1485
1490
  # only buy orders are supported by the endpoint
1486
- params['cost'] = cost
1487
- return self.create_order(symbol, 'market', side, cost, None, params)
1491
+ req = {
1492
+ 'cost': cost,
1493
+ }
1494
+ return self.create_order(symbol, 'market', side, 1, None, self.extend(req, params))
1488
1495
 
1489
1496
  def create_market_buy_order_with_cost(self, symbol: str, cost: float, params={}):
1490
1497
  """
ccxt/krakenfutures.py CHANGED
@@ -299,6 +299,11 @@ class krakenfutures(Exchange, ImplicitAPI):
299
299
  },
300
300
  'hedged': False,
301
301
  'trailing': False,
302
+ 'leverage': False,
303
+ 'marketBuyByCost': False,
304
+ 'marketBuyRequiresPrice': False,
305
+ 'selfTradePrevention': False,
306
+ 'iceberg': False,
302
307
  },
303
308
  'createOrders': {
304
309
  'max': 100,
ccxt/kucoin.py CHANGED
@@ -1025,11 +1025,11 @@ class kucoin(Exchange, ImplicitAPI):
1025
1025
  },
1026
1026
  'hedged': False,
1027
1027
  'trailing': False,
1028
- # exchange-supported features
1029
- # 'iceberg': True,
1030
- # 'selfTradePrevention': True,
1031
- # 'twap': False,
1032
- # 'oco': False,
1028
+ 'leverage': False,
1029
+ 'marketBuyByCost': True,
1030
+ 'marketBuyRequiresPrice': False,
1031
+ 'selfTradePrevention': True, # todo implement
1032
+ 'iceberg': True, # todo implement
1033
1033
  },
1034
1034
  'createOrders': {
1035
1035
  'max': 5,
@@ -2285,8 +2285,10 @@ class kucoin(Exchange, ImplicitAPI):
2285
2285
  :returns dict: an `order structure <https://docs.ccxt.com/#/?id=order-structure>`
2286
2286
  """
2287
2287
  self.load_markets()
2288
- params['cost'] = cost
2289
- return self.create_order(symbol, 'market', side, cost, None, params)
2288
+ req = {
2289
+ 'cost': cost,
2290
+ }
2291
+ return self.create_order(symbol, 'market', side, 0, None, self.extend(req, params))
2290
2292
 
2291
2293
  def create_market_buy_order_with_cost(self, symbol: str, cost: float, params={}):
2292
2294
  """
ccxt/kucoinfutures.py CHANGED
@@ -398,11 +398,11 @@ class kucoinfutures(kucoin, ImplicitAPI):
398
398
  },
399
399
  'hedged': False,
400
400
  'trailing': False,
401
- # exchange-supported features
402
- # 'iceberg': True,
403
- # 'selfTradePrevention': True,
404
- # 'twap': False,
405
- # 'oco': False,
401
+ 'leverage': True, # todo implement
402
+ 'marketBuyByCost': True,
403
+ 'marketBuyRequiresPrice': False,
404
+ 'selfTradePrevention': True, # todo implement
405
+ 'iceberg': True,
406
406
  },
407
407
  'createOrders': {
408
408
  'max': 20,
ccxt/mexc.py CHANGED
@@ -709,10 +709,12 @@ class mexc(Exchange, ImplicitAPI):
709
709
  'PO': True,
710
710
  'GTD': False,
711
711
  },
712
- 'hedged': False,
713
- # exchange-supported features
714
- 'selfTradePrevention': False,
712
+ 'hedged': True, # todo implement
715
713
  'trailing': False,
714
+ 'leverage': True, # todo implement
715
+ 'marketBuyByCost': True,
716
+ 'marketBuyRequiresPrice': False,
717
+ 'selfTradePrevention': False,
716
718
  'iceberg': False,
717
719
  },
718
720
  'createOrders': {
@@ -768,14 +770,14 @@ class mexc(Exchange, ImplicitAPI):
768
770
  'mark': True,
769
771
  'index': True,
770
772
  },
771
- 'triggerDirection': True,
773
+ 'triggerDirection': True, # todo
772
774
  'stopLossPrice': False, # todo
773
- 'takeProfitPrice': False,
775
+ 'takeProfitPrice': False, # todo
774
776
  'hedged': True,
777
+ 'leverage': True, # todo
778
+ 'marketBuyByCost': False,
775
779
  },
776
- 'createOrders': {
777
- 'max': 50,
778
- },
780
+ 'createOrders': None, # todo: needs implementation https://mexcdevelop.github.io/apidocs/contract_v1_en/#order-under-maintenance:~:text=Order%20the%20contract%20in%20batch
779
781
  'fetchMyTrades': {
780
782
  'marginMode': False,
781
783
  'limit': 100,
@@ -2186,8 +2188,10 @@ class mexc(Exchange, ImplicitAPI):
2186
2188
  market = self.market(symbol)
2187
2189
  if not market['spot']:
2188
2190
  raise NotSupported(self.id + ' createMarketBuyOrderWithCost() supports spot orders only')
2189
- params['cost'] = cost
2190
- return self.create_order(symbol, 'market', 'buy', 0, None, params)
2191
+ req = {
2192
+ 'cost': cost,
2193
+ }
2194
+ return self.create_order(symbol, 'market', 'buy', 0, None, self.extend(req, params))
2191
2195
 
2192
2196
  def create_market_sell_order_with_cost(self, symbol: str, cost: float, params={}):
2193
2197
  """
@@ -2204,8 +2208,10 @@ class mexc(Exchange, ImplicitAPI):
2204
2208
  market = self.market(symbol)
2205
2209
  if not market['spot']:
2206
2210
  raise NotSupported(self.id + ' createMarketBuyOrderWithCost() supports spot orders only')
2207
- params['cost'] = cost
2208
- return self.create_order(symbol, 'market', 'sell', 0, None, params)
2211
+ req = {
2212
+ 'cost': cost,
2213
+ }
2214
+ return self.create_order(symbol, 'market', 'sell', 0, None, self.extend(req, params))
2209
2215
 
2210
2216
  def create_order(self, symbol: str, type: OrderType, side: OrderSide, amount: float, price: Num = None, params={}):
2211
2217
  """
ccxt/ndax.py CHANGED
@@ -355,7 +355,7 @@ class ndax(Exchange, ImplicitAPI):
355
355
  #
356
356
  # {
357
357
  # "Authenticated": True,
358
- # "UserId":57765,
358
+ # "UserId":57764,
359
359
  # "SessionToken":"4a2a5857-c4e5-4fac-b09e-2c4c30b591a0"
360
360
  # }
361
361
  #
ccxt/oceanex.py CHANGED
@@ -497,7 +497,7 @@ class oceanex(Exchange, ImplicitAPI):
497
497
  # "funds":"6.0732952",
498
498
  # "market":"ethusdt",
499
499
  # "created_at":"2022-04-19T19:03:15Z",
500
- # "created_on":1650394995,
500
+ # "created_on":1650394994,
501
501
  # "side":"bid"
502
502
  # },
503
503
  # ]
ccxt/okx.py CHANGED
@@ -1206,7 +1206,6 @@ class okx(Exchange, ImplicitAPI):
1206
1206
  'brokerId': 'e847386590ce4dBC',
1207
1207
  },
1208
1208
  'features': {
1209
- # https://www.okx.com/docs-v5/en/#order-book-trading-trade-post-place-order
1210
1209
  'default': {
1211
1210
  'sandbox': True,
1212
1211
  'createOrder': {
@@ -1235,12 +1234,12 @@ class okx(Exchange, ImplicitAPI):
1235
1234
  'GTD': False,
1236
1235
  },
1237
1236
  'hedged': True,
1238
- # even though the below params not unified yet, it's useful metadata for users to know that exchange supports them
1239
- 'selfTradePrevention': True,
1240
1237
  'trailing': True,
1241
- 'twap': True,
1242
- 'iceberg': True,
1243
- 'oco': True,
1238
+ 'iceberg': True, # todo implement
1239
+ 'leverage': False,
1240
+ 'selfTradePrevention': True, # todo implement
1241
+ 'marketBuyByCost': True,
1242
+ 'marketBuyRequiresPrice': False,
1244
1243
  },
1245
1244
  'createOrders': {
1246
1245
  'max': 20,
ccxt/pro/__init__.py CHANGED
@@ -4,7 +4,7 @@
4
4
 
5
5
  # ----------------------------------------------------------------------------
6
6
 
7
- __version__ = '4.4.43'
7
+ __version__ = '4.4.44'
8
8
 
9
9
  # ----------------------------------------------------------------------------
10
10
 
ccxt/pro/bitcoincom.py CHANGED
@@ -22,7 +22,10 @@ class bitcoincom(hitbtc):
22
22
  'urls': {
23
23
  'logo': 'https://user-images.githubusercontent.com/1294454/97296144-514fa300-1861-11eb-952b-3d55d492200b.jpg',
24
24
  'api': {
25
- 'ws': 'wss://api.fmfw.io/api/2/ws',
25
+ 'ws': {
26
+ 'public': 'wss://api.fmfw.io/api/3/ws/public',
27
+ 'private': 'wss://api.fmfw.io/api/3/ws/trading',
28
+ },
26
29
  },
27
30
  },
28
31
  'fees': {
ccxt/pro/bitopro.py CHANGED
@@ -77,7 +77,7 @@ class bitopro(ccxt.async_support.bitopro):
77
77
  if limit is None:
78
78
  endPart = market['id']
79
79
  else:
80
- endPart = market['id'] + ':' + limit
80
+ endPart = market['id'] + ':' + self.number_to_string(limit)
81
81
  orderbook = await self.watch_public('order-books', messageHash, endPart)
82
82
  return orderbook.limit()
83
83
 
ccxt/whitebit.py CHANGED
@@ -1217,9 +1217,11 @@ class whitebit(Exchange, ImplicitAPI):
1217
1217
  :param dict [params]: extra parameters specific to the exchange API endpoint
1218
1218
  :returns dict: an `order structure <https://docs.ccxt.com/#/?id=order-structure>`
1219
1219
  """
1220
- params['cost'] = cost
1220
+ req = {
1221
+ 'cost': cost,
1222
+ }
1221
1223
  # only buy side is supported
1222
- return self.create_order(symbol, 'market', side, 0, None, params)
1224
+ return self.create_order(symbol, 'market', side, 0, None, self.extend(req, params))
1223
1225
 
1224
1226
  def create_market_buy_order_with_cost(self, symbol: str, cost: float, params={}) -> Order:
1225
1227
  """
ccxt/woo.py CHANGED
@@ -344,9 +344,11 @@ class woo(Exchange, ImplicitAPI):
344
344
  },
345
345
  'hedged': False,
346
346
  'trailing': True,
347
- # exchange specific params:
348
- # 'iceberg': True,
349
- # 'oco': True,
347
+ 'leverage': False,
348
+ 'marketBuyByCost': True,
349
+ 'marketBuyRequiresPrice': False,
350
+ 'selfTradePrevention': False,
351
+ 'iceberg': True, # todo implement
350
352
  },
351
353
  'createOrders': None,
352
354
  'fetchMyTrades': {
ccxt/woofipro.py CHANGED
@@ -327,8 +327,11 @@ class woofipro(Exchange, ImplicitAPI):
327
327
  },
328
328
  'hedged': False,
329
329
  'trailing': True,
330
- # exchange specific
331
- # 'iceberg': True,
330
+ 'leverage': True, # todo implement
331
+ 'marketBuyByCost': False,
332
+ 'marketBuyRequiresPrice': False,
333
+ 'selfTradePrevention': False,
334
+ 'iceberg': True, # todo implement
332
335
  },
333
336
  'createOrders': {
334
337
  'max': 10,
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ccxt
3
- Version: 4.4.43
3
+ Version: 4.4.44
4
4
  Summary: A JavaScript / TypeScript / Python / C# / PHP cryptocurrency trading library with support for 100+ exchanges
5
5
  Home-page: https://ccxt.com
6
6
  Author: Igor Kroitor
@@ -277,13 +277,13 @@ console.log(version, Object.keys(exchanges));
277
277
 
278
278
  All-in-one browser bundle (dependencies included), served from a CDN of your choice:
279
279
 
280
- * jsDelivr: https://cdn.jsdelivr.net/npm/ccxt@4.4.43/dist/ccxt.browser.min.js
281
- * unpkg: https://unpkg.com/ccxt@4.4.43/dist/ccxt.browser.min.js
280
+ * jsDelivr: https://cdn.jsdelivr.net/npm/ccxt@4.4.44/dist/ccxt.browser.min.js
281
+ * unpkg: https://unpkg.com/ccxt@4.4.44/dist/ccxt.browser.min.js
282
282
 
283
283
  CDNs are not updated in real-time and may have delays. Defaulting to the most recent version without specifying the version number is not recommended. Please, keep in mind that we are not responsible for the correct operation of those CDN servers.
284
284
 
285
285
  ```HTML
286
- <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/ccxt@4.4.43/dist/ccxt.browser.min.js"></script>
286
+ <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/ccxt@4.4.44/dist/ccxt.browser.min.js"></script>
287
287
  ```
288
288
 
289
289
  Creates a global `ccxt` object: