Home Assistant Unofficial Reference 2024.12.1
sensor.py
Go to the documentation of this file.
1 """Support for power sensors in WeMo Insight devices."""
2 
3 from __future__ import annotations
4 
5 from collections.abc import Callable
6 from dataclasses import dataclass
7 from typing import cast
8 
10  SensorDeviceClass,
11  SensorEntity,
12  SensorEntityDescription,
13  SensorStateClass,
14 )
15 from homeassistant.config_entries import ConfigEntry
16 from homeassistant.const import UnitOfEnergy, UnitOfPower
17 from homeassistant.core import HomeAssistant
18 from homeassistant.helpers.entity_platform import AddEntitiesCallback
19 from homeassistant.helpers.typing import StateType
20 
21 from . import async_wemo_dispatcher_connect
22 from .coordinator import DeviceCoordinator
23 from .entity import WemoEntity
24 
25 
26 @dataclass(frozen=True)
28  """SensorEntityDescription for WeMo AttributeSensor entities."""
29 
30  # AttributeSensor does not support UNDEFINED,
31  # restrict the type to str | None.
32  name: str | None = None
33  state_conversion: Callable[[StateType], StateType] | None = None
34  unique_id_suffix: str | None = None
35 
36 
37 ATTRIBUTE_SENSORS = (
39  name="Current Power",
40  device_class=SensorDeviceClass.POWER,
41  state_class=SensorStateClass.MEASUREMENT,
42  native_unit_of_measurement=UnitOfPower.WATT,
43  key="current_power_watts",
44  unique_id_suffix="currentpower",
45  state_conversion=lambda state: round(cast(float, state), 2),
46  ),
48  name="Today Energy",
49  device_class=SensorDeviceClass.ENERGY,
50  state_class=SensorStateClass.TOTAL_INCREASING,
51  native_unit_of_measurement=UnitOfEnergy.KILO_WATT_HOUR,
52  key="today_kwh",
53  unique_id_suffix="todaymw",
54  state_conversion=lambda state: round(cast(float, state), 2),
55  ),
56 )
57 
58 
60  hass: HomeAssistant,
61  _config_entry: ConfigEntry,
62  async_add_entities: AddEntitiesCallback,
63 ) -> None:
64  """Set up WeMo sensors."""
65 
66  async def _discovered_wemo(coordinator: DeviceCoordinator) -> None:
67  """Handle a discovered Wemo device."""
69  AttributeSensor(coordinator, description)
70  for description in ATTRIBUTE_SENSORS
71  if hasattr(coordinator.wemo, description.key)
72  )
73 
74  await async_wemo_dispatcher_connect(hass, _discovered_wemo)
75 
76 
78  """Sensor that reads attributes of a wemo device."""
79 
80  entity_description: AttributeSensorDescription
81 
82  def __init__(
83  self, coordinator: DeviceCoordinator, description: AttributeSensorDescription
84  ) -> None:
85  """Init AttributeSensor."""
86  super().__init__(coordinator)
87  self.entity_descriptionentity_description = description
88 
89  @property
90  def name_suffix(self) -> str | None:
91  """Return the name of the entity."""
92  return self.entity_descriptionentity_description.name
93 
94  @property
95  def unique_id_suffix(self) -> str | None:
96  """Suffix to append to the WeMo device's unique ID."""
97  return self.entity_descriptionentity_description.unique_id_suffix
98 
99  def convert_state(self, value: StateType) -> StateType:
100  """Convert native state to a value appropriate for the sensor."""
101  if (convert := self.entity_descriptionentity_description.state_conversion) is None:
102  return None
103  return convert(value)
104 
105  @property
106  def native_value(self) -> StateType:
107  """Return the value of the device attribute."""
108  return self.convert_stateconvert_state(getattr(self.wemowemowemo, self.entity_descriptionentity_description.key))
StateType convert_state(self, StateType value)
Definition: sensor.py:99
None __init__(self, DeviceCoordinator coordinator, AttributeSensorDescription description)
Definition: sensor.py:84
None async_setup_entry(HomeAssistant hass, ConfigEntry _config_entry, AddEntitiesCallback async_add_entities)
Definition: sensor.py:63
None async_wemo_dispatcher_connect(HomeAssistant hass, DispatchCallback dispatch)
Definition: __init__.py:159