sensor.py 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. """
  2. Setup for different kinds of Tuya sensors
  3. """
  4. import logging
  5. from . import DOMAIN
  6. from .const import (
  7. CONF_DEVICE_ID,
  8. CONF_TYPE,
  9. )
  10. from .generic.sensor import TuyaLocalSensor
  11. from .helpers.device_config import get_config
  12. _LOGGER = logging.getLogger(__name__)
  13. async def async_setup_platform(hass, config, async_add_entities, discovery_info=None):
  14. """Set up the sensor device according to it's type."""
  15. data = hass.data[DOMAIN][discovery_info[CONF_DEVICE_ID]]
  16. device = data["device"]
  17. sensors = []
  18. cfg = get_config(discovery_info[CONF_TYPE])
  19. if cfg is None:
  20. raise ValueError(f"No device config found for {discovery_info}")
  21. ecfg = cfg.primary_entity
  22. if ecfg.entity == "sensor" and discovery_info.get(ecfg.config_id, False):
  23. data[ecfg.config_id] = TuyaLocalSensor(device, ecfg)
  24. sensors.append(data[ecfg.config_id])
  25. if ecfg.deprecated:
  26. _LOGGER.warning(ecfg.deprecation_message)
  27. _LOGGER.debug(f"Adding sensor for {discovery_info[ecfg.config_id]}")
  28. for ecfg in cfg.secondary_entities():
  29. if ecfg.entity == "sensor" and discovery_info.get(ecfg.config_id, False):
  30. data[ecfg.config_id] = TuyaLocalSensor(device, ecfg)
  31. sensors.append(data[ecfg.config_id])
  32. if ecfg.deprecated:
  33. _LOGGER.warning(ecfg.deprecation_message)
  34. _LOGGER.debug(f"Adding sensor for {discovery_info[ecfg.config_id]}")
  35. if not sensors:
  36. raise ValueError(f"{device.name} does not support use as a sensor device.")
  37. async_add_entities(sensors)
  38. async def async_setup_entry(hass, config_entry, async_add_entities):
  39. config = {**config_entry.data, **config_entry.options}
  40. await async_setup_platform(hass, {}, async_add_entities, config)