108 lines
3.3 KiB
Python
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()
|