core/homeassistant/components/point/sensor.py

114 lines
3.3 KiB
Python
Raw Normal View History

"""Support for Minut Point sensors."""
2021-08-16 20:54:56 +00:00
from __future__ import annotations
from dataclasses import dataclass
import logging
2021-08-16 20:54:56 +00:00
from homeassistant.components.sensor import (
DOMAIN,
2021-12-16 21:29:54 +00:00
SensorDeviceClass,
2021-08-16 20:54:56 +00:00
SensorEntity,
SensorEntityDescription,
)
from homeassistant.config_entries import ConfigEntry
2021-12-16 21:29:54 +00:00
from homeassistant.const import PERCENTAGE, SOUND_PRESSURE_WEIGHTED_DBA, TEMP_CELSIUS
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__)
2019-07-31 19:25:30 +00:00
DEVICE_CLASS_SOUND = "sound_level"
2021-08-16 20:54:56 +00:00
@dataclass
class MinutPointRequiredKeysMixin:
"""Mixin for required keys."""
precision: int
@dataclass
class MinutPointSensorEntityDescription(
SensorEntityDescription, MinutPointRequiredKeysMixin
):
"""Describes MinutPoint sensor entity."""
SENSOR_TYPES: tuple[MinutPointSensorEntityDescription, ...] = (
MinutPointSensorEntityDescription(
key="temperature",
precision=1,
2021-12-16 21:29:54 +00:00
device_class=SensorDeviceClass.TEMPERATURE,
2021-08-16 20:54:56 +00:00
native_unit_of_measurement=TEMP_CELSIUS,
),
MinutPointSensorEntityDescription(
key="humidity",
precision=1,
2021-12-16 21:29:54 +00:00
device_class=SensorDeviceClass.HUMIDITY,
2021-08-16 20:54:56 +00:00
native_unit_of_measurement=PERCENTAGE,
),
MinutPointSensorEntityDescription(
key="sound",
precision=1,
device_class=DEVICE_CLASS_SOUND,
icon="mdi:ear-hearing",
native_unit_of_measurement=SOUND_PRESSURE_WEIGHTED_DBA,
),
)
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."""
2019-07-31 19:25:30 +00:00
async def async_discover_sensor(device_id):
"""Discover and add a discovered sensor."""
client = hass.data[POINT_DOMAIN][config_entry.entry_id]
2019-07-31 19:25:30 +00:00
async_add_entities(
2021-08-16 20:54:56 +00:00
[
MinutPointSensor(client, device_id, description)
for description in SENSOR_TYPES
],
2019-07-31 19:25:30 +00:00
True,
)
async_dispatcher_connect(
2019-07-31 19:25:30 +00:00
hass, POINT_DISCOVERY_NEW.format(DOMAIN, POINT_DOMAIN), async_discover_sensor
)
class MinutPointSensor(MinutPointEntity, SensorEntity):
"""The platform class required by Home Assistant."""
2021-08-16 20:54:56 +00:00
entity_description: MinutPointSensorEntityDescription
def __init__(
self, point_client, device_id, description: MinutPointSensorEntityDescription
):
"""Initialize the sensor."""
2021-08-16 20:54:56 +00:00
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._value = await self.device.sensor(self.device_class)
self._updated = parse_datetime(self.device.last_update)
self.async_write_ha_state()
@property
def native_value(self):
"""Return the state of the sensor."""
if self.value is None:
return None
2021-08-16 20:54:56 +00:00
return round(self.value, self.entity_description.precision)