config.py 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. """
  2. Helper for general config
  3. """
  4. import logging
  5. from .. import DOMAIN
  6. from ..const import CONF_DEVICE_CID, CONF_DEVICE_ID, CONF_TYPE
  7. from .device_config import get_config
  8. _LOGGER = logging.getLogger(__name__)
  9. async def async_tuya_setup_platform(
  10. hass, async_add_entities, discovery_info, platform, entity_class
  11. ):
  12. """Common functions for async_setup_platform for each entity platform."""
  13. data = hass.data[DOMAIN][get_device_id(discovery_info)]
  14. device = data["device"]
  15. entities = []
  16. cfg = await hass.async_add_executor_job(
  17. get_config,
  18. discovery_info[CONF_TYPE],
  19. )
  20. if cfg is None:
  21. raise ValueError(f"No device config found for {discovery_info}")
  22. ecfg = cfg.primary_entity
  23. if ecfg.entity == platform:
  24. try:
  25. data[ecfg.config_id] = entity_class(device, ecfg)
  26. entities.append(data[ecfg.config_id])
  27. _LOGGER.debug("Adding %s for %s", platform, ecfg.config_id)
  28. except Exception as e:
  29. _LOGGER.error(
  30. "Error adding %s for %s: %s",
  31. ecfg.config_id,
  32. cfg.config,
  33. e,
  34. )
  35. for ecfg in cfg.secondary_entities():
  36. if ecfg.entity == platform:
  37. try:
  38. data[ecfg.config_id] = entity_class(device, ecfg)
  39. entities.append(data[ecfg.config_id])
  40. if ecfg.deprecated:
  41. _LOGGER.warning(ecfg.deprecation_message)
  42. _LOGGER.debug("Adding %s for %s", platform, ecfg.config_id)
  43. except Exception as e:
  44. _LOGGER.error(
  45. "Error adding %s for %s: %s",
  46. ecfg.config_id,
  47. cfg.config,
  48. e,
  49. )
  50. if not entities:
  51. raise ValueError(f"{device.name} does not support use as a {platform} device.")
  52. async_add_entities(entities)
  53. def get_device_id(config: dict):
  54. return (
  55. config[CONF_DEVICE_CID]
  56. if CONF_DEVICE_CID in config and config[CONF_DEVICE_CID] != ""
  57. else config[CONF_DEVICE_ID]
  58. )