climate.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. """
  2. Setup for different kinds of Tuya climate devices
  3. """
  4. import logging
  5. from . import DOMAIN
  6. from .const import (
  7. CONF_CLIMATE,
  8. CONF_DEVICE_ID,
  9. CONF_TYPE,
  10. )
  11. from .generic.climate import TuyaLocalClimate
  12. from .helpers.device_config import config_for_legacy_use
  13. _LOGGER = logging.getLogger(__name__)
  14. async def async_setup_platform(hass, config, async_add_entities, discovery_info=None):
  15. """Set up the Tuya device according to its type."""
  16. data = hass.data[DOMAIN][discovery_info[CONF_DEVICE_ID]]
  17. device = data["device"]
  18. cfg = config_for_legacy_use(discovery_info[CONF_TYPE])
  19. ecfg = cfg.primary_entity
  20. if ecfg.entity != "climate":
  21. for ecfg in cfg.secondary_entities():
  22. if ecfg.entity == "climate":
  23. break
  24. if ecfg.entity != "climate":
  25. raise ValueError(f"{device.name} does not support use as a climate device.")
  26. if ecfg.deprecated:
  27. _LOGGER.warning(ecfg.deprecation_message)
  28. legacy_class = ecfg.legacy_class
  29. # Transition: generic climate entity exists, but is not complete. More
  30. # complex climate devices still need a device specific class.
  31. # If legacy_class exists, use it, otherwise use the generic climate class.
  32. if legacy_class is not None:
  33. data[CONF_CLIMATE] = legacy_class(device)
  34. else:
  35. data[CONF_CLIMATE] = TuyaLocalClimate(device, ecfg)
  36. async_add_entities([data[CONF_CLIMATE]])
  37. _LOGGER.debug(f"Adding climate device for {discovery_info[CONF_TYPE]}")
  38. async def async_setup_entry(hass, config_entry, async_add_entities):
  39. config = {**config_entry.data, **config_entry.options}
  40. discovery_info = {
  41. CONF_DEVICE_ID: config[CONF_DEVICE_ID],
  42. CONF_TYPE: config[CONF_TYPE],
  43. }
  44. await async_setup_platform(hass, {}, async_add_entities, discovery_info)