core/homeassistant/components/point/sensor.py

108 lines
3.3 KiB
Python

"""Support for Minut Point sensors."""
from __future__ import annotations
from dataclasses import dataclass
import logging
from homeassistant.components.sensor import (
DOMAIN,
SensorDeviceClass,
SensorEntity,
SensorEntityDescription,
)
from homeassistant.config_entries import ConfigEntry
from homeassistant.const import PERCENTAGE, UnitOfSoundPressure, UnitOfTemperature
from homeassistant.core import HomeAssistant
from homeassistant.helpers.dispatcher import async_dispatcher_connect
from homeassistant.helpers.entity_platform import AddEntitiesCallback
from homeassistant.util.dt import parse_datetime
from . import MinutPointEntity
from .const import DOMAIN as POINT_DOMAIN, POINT_DISCOVERY_NEW
_LOGGER = logging.getLogger(__name__)
@dataclass(frozen=True)
class MinutPointRequiredKeysMixin:
"""Mixin for required keys."""
precision: int
@dataclass(frozen=True)
class MinutPointSensorEntityDescription(
SensorEntityDescription, MinutPointRequiredKeysMixin
):
"""Describes MinutPoint sensor entity."""
SENSOR_TYPES: tuple[MinutPointSensorEntityDescription, ...] = (
MinutPointSensorEntityDescription(
key="temperature",
precision=1,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
MinutPointSensorEntityDescription(
key="humidity",
precision=1,
device_class=SensorDeviceClass.HUMIDITY,
native_unit_of_measurement=PERCENTAGE,
),
MinutPointSensorEntityDescription(
key="sound",
precision=1,
device_class=SensorDeviceClass.SOUND_PRESSURE,
native_unit_of_measurement=UnitOfSoundPressure.WEIGHTED_DECIBEL_A,
),
)
async def async_setup_entry(
hass: HomeAssistant,
config_entry: ConfigEntry,
async_add_entities: AddEntitiesCallback,
) -> None:
"""Set up a Point's sensors based on a config entry."""
async def async_discover_sensor(device_id):
"""Discover and add a discovered sensor."""
client = hass.data[POINT_DOMAIN][config_entry.entry_id]
async_add_entities(
[
MinutPointSensor(client, device_id, description)
for description in SENSOR_TYPES
],
True,
)
async_dispatcher_connect(
hass, POINT_DISCOVERY_NEW.format(DOMAIN, POINT_DOMAIN), async_discover_sensor
)
class MinutPointSensor(MinutPointEntity, SensorEntity):
"""The platform class required by Home Assistant."""
entity_description: MinutPointSensorEntityDescription
def __init__(
self, point_client, device_id, description: MinutPointSensorEntityDescription
) -> None:
"""Initialize the sensor."""
super().__init__(point_client, device_id, description.device_class)
self.entity_description = description
async def _update_callback(self):
"""Update the value of the sensor."""
_LOGGER.debug("Update sensor value for %s", self)
if self.is_updated:
self._attr_native_value = await self.device.sensor(self.device_class)
if self.native_value is not None:
self._attr_native_value = round(
self.native_value, self.entity_description.precision
)
self._updated = parse_datetime(self.device.last_update)
self.async_write_ha_state()