2019-11-09 19:18:41 +00:00
|
|
|
"""Support for WLED sensors."""
|
2021-03-18 14:08:35 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2019-11-09 19:18:41 +00:00
|
|
|
from datetime import timedelta
|
2021-04-30 18:38:59 +00:00
|
|
|
from typing import Any
|
2019-11-09 19:18:41 +00:00
|
|
|
|
2021-03-22 18:50:29 +00:00
|
|
|
from homeassistant.components.sensor import DEVICE_CLASS_CURRENT, SensorEntity
|
2019-11-09 19:18:41 +00:00
|
|
|
from homeassistant.config_entries import ConfigEntry
|
2020-03-21 22:14:41 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
DATA_BYTES,
|
|
|
|
DEVICE_CLASS_SIGNAL_STRENGTH,
|
|
|
|
DEVICE_CLASS_TIMESTAMP,
|
2020-09-05 19:09:14 +00:00
|
|
|
PERCENTAGE,
|
2020-10-01 14:14:29 +00:00
|
|
|
SIGNAL_STRENGTH_DECIBELS_MILLIWATT,
|
2020-03-21 22:14:41 +00:00
|
|
|
)
|
2021-04-22 15:04:28 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
2021-04-30 18:38:59 +00:00
|
|
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
2019-11-09 19:18:41 +00:00
|
|
|
from homeassistant.util.dt import utcnow
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
from . import WLEDDataUpdateCoordinator, WLEDDeviceEntity
|
2020-10-01 14:14:29 +00:00
|
|
|
from .const import ATTR_LED_COUNT, ATTR_MAX_POWER, CURRENT_MA, DOMAIN
|
2019-11-09 19:18:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_entry(
|
2021-04-22 15:04:28 +00:00
|
|
|
hass: HomeAssistant,
|
2019-11-09 19:18:41 +00:00
|
|
|
entry: ConfigEntry,
|
2021-04-30 18:38:59 +00:00
|
|
|
async_add_entities: AddEntitiesCallback,
|
2019-11-09 19:18:41 +00:00
|
|
|
) -> None:
|
|
|
|
"""Set up WLED sensor based on a config entry."""
|
2020-03-13 12:19:05 +00:00
|
|
|
coordinator: WLEDDataUpdateCoordinator = hass.data[DOMAIN][entry.entry_id]
|
2019-11-09 19:18:41 +00:00
|
|
|
|
|
|
|
sensors = [
|
2020-03-13 12:19:05 +00:00
|
|
|
WLEDEstimatedCurrentSensor(entry.entry_id, coordinator),
|
|
|
|
WLEDUptimeSensor(entry.entry_id, coordinator),
|
|
|
|
WLEDFreeHeapSensor(entry.entry_id, coordinator),
|
2020-03-21 22:14:41 +00:00
|
|
|
WLEDWifiBSSIDSensor(entry.entry_id, coordinator),
|
|
|
|
WLEDWifiChannelSensor(entry.entry_id, coordinator),
|
|
|
|
WLEDWifiRSSISensor(entry.entry_id, coordinator),
|
|
|
|
WLEDWifiSignalSensor(entry.entry_id, coordinator),
|
2019-11-09 19:18:41 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
async_add_entities(sensors, True)
|
|
|
|
|
|
|
|
|
2021-03-22 18:50:29 +00:00
|
|
|
class WLEDSensor(WLEDDeviceEntity, SensorEntity):
|
2019-11-09 19:18:41 +00:00
|
|
|
"""Defines a WLED sensor."""
|
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self,
|
2020-03-13 12:19:05 +00:00
|
|
|
*,
|
|
|
|
coordinator: WLEDDataUpdateCoordinator,
|
|
|
|
enabled_default: bool = True,
|
2019-11-09 19:18:41 +00:00
|
|
|
entry_id: str,
|
|
|
|
icon: str,
|
|
|
|
key: str,
|
2020-03-13 12:19:05 +00:00
|
|
|
name: str,
|
2021-03-18 14:08:35 +00:00
|
|
|
unit_of_measurement: str | None = None,
|
2019-11-09 19:18:41 +00:00
|
|
|
) -> None:
|
|
|
|
"""Initialize WLED sensor."""
|
|
|
|
self._unit_of_measurement = unit_of_measurement
|
|
|
|
self._key = key
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
super().__init__(
|
|
|
|
entry_id=entry_id,
|
|
|
|
coordinator=coordinator,
|
|
|
|
name=name,
|
|
|
|
icon=icon,
|
|
|
|
enabled_default=enabled_default,
|
|
|
|
)
|
2019-11-09 19:18:41 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self) -> str:
|
|
|
|
"""Return the unique ID for this sensor."""
|
2020-03-13 12:19:05 +00:00
|
|
|
return f"{self.coordinator.data.info.mac_address}_{self._key}"
|
2019-11-09 19:18:41 +00:00
|
|
|
|
|
|
|
@property
|
2021-05-09 17:34:21 +00:00
|
|
|
def unit_of_measurement(self) -> str | None:
|
2019-11-09 19:18:41 +00:00
|
|
|
"""Return the unit this state is expressed in."""
|
|
|
|
return self._unit_of_measurement
|
|
|
|
|
|
|
|
|
|
|
|
class WLEDEstimatedCurrentSensor(WLEDSensor):
|
|
|
|
"""Defines a WLED estimated current sensor."""
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
def __init__(self, entry_id: str, coordinator: WLEDDataUpdateCoordinator) -> None:
|
2019-11-09 19:18:41 +00:00
|
|
|
"""Initialize WLED estimated current sensor."""
|
|
|
|
super().__init__(
|
2020-03-13 12:19:05 +00:00
|
|
|
coordinator=coordinator,
|
|
|
|
entry_id=entry_id,
|
|
|
|
icon="mdi:power",
|
|
|
|
key="estimated_current",
|
|
|
|
name=f"{coordinator.data.info.name} Estimated Current",
|
|
|
|
unit_of_measurement=CURRENT_MA,
|
2019-11-09 19:18:41 +00:00
|
|
|
)
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
@property
|
2021-03-18 14:08:35 +00:00
|
|
|
def extra_state_attributes(self) -> dict[str, Any] | None:
|
2020-03-13 12:19:05 +00:00
|
|
|
"""Return the state attributes of the entity."""
|
|
|
|
return {
|
|
|
|
ATTR_LED_COUNT: self.coordinator.data.info.leds.count,
|
|
|
|
ATTR_MAX_POWER: self.coordinator.data.info.leds.max_power,
|
2019-11-09 19:18:41 +00:00
|
|
|
}
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
@property
|
2020-08-17 19:02:43 +00:00
|
|
|
def state(self) -> int:
|
2020-03-13 12:19:05 +00:00
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self.coordinator.data.info.leds.power
|
|
|
|
|
2020-08-10 15:50:03 +00:00
|
|
|
@property
|
2021-03-18 14:08:35 +00:00
|
|
|
def device_class(self) -> str | None:
|
2020-08-10 15:50:03 +00:00
|
|
|
"""Return the class of this sensor."""
|
|
|
|
return DEVICE_CLASS_CURRENT
|
|
|
|
|
2019-11-09 19:18:41 +00:00
|
|
|
|
|
|
|
class WLEDUptimeSensor(WLEDSensor):
|
|
|
|
"""Defines a WLED uptime sensor."""
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
def __init__(self, entry_id: str, coordinator: WLEDDataUpdateCoordinator) -> None:
|
2019-11-09 19:18:41 +00:00
|
|
|
"""Initialize WLED uptime sensor."""
|
|
|
|
super().__init__(
|
2020-03-13 12:19:05 +00:00
|
|
|
coordinator=coordinator,
|
2020-01-22 09:45:38 +00:00
|
|
|
enabled_default=False,
|
2020-03-13 12:19:05 +00:00
|
|
|
entry_id=entry_id,
|
|
|
|
icon="mdi:clock-outline",
|
|
|
|
key="uptime",
|
|
|
|
name=f"{coordinator.data.info.name} Uptime",
|
2019-11-09 19:18:41 +00:00
|
|
|
)
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
@property
|
2020-08-17 19:02:43 +00:00
|
|
|
def state(self) -> str:
|
2020-03-13 12:19:05 +00:00
|
|
|
"""Return the state of the sensor."""
|
|
|
|
uptime = utcnow() - timedelta(seconds=self.coordinator.data.info.uptime)
|
|
|
|
return uptime.replace(microsecond=0).isoformat()
|
|
|
|
|
2019-11-09 19:18:41 +00:00
|
|
|
@property
|
2021-03-18 14:08:35 +00:00
|
|
|
def device_class(self) -> str | None:
|
2019-11-09 19:18:41 +00:00
|
|
|
"""Return the class of this sensor."""
|
|
|
|
return DEVICE_CLASS_TIMESTAMP
|
|
|
|
|
|
|
|
|
|
|
|
class WLEDFreeHeapSensor(WLEDSensor):
|
|
|
|
"""Defines a WLED free heap sensor."""
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
def __init__(self, entry_id: str, coordinator: WLEDDataUpdateCoordinator) -> None:
|
2019-11-09 19:18:41 +00:00
|
|
|
"""Initialize WLED free heap sensor."""
|
|
|
|
super().__init__(
|
2020-03-13 12:19:05 +00:00
|
|
|
coordinator=coordinator,
|
2020-01-22 09:45:38 +00:00
|
|
|
enabled_default=False,
|
2020-03-13 12:19:05 +00:00
|
|
|
entry_id=entry_id,
|
|
|
|
icon="mdi:memory",
|
|
|
|
key="free_heap",
|
|
|
|
name=f"{coordinator.data.info.name} Free Memory",
|
|
|
|
unit_of_measurement=DATA_BYTES,
|
2019-11-09 19:18:41 +00:00
|
|
|
)
|
|
|
|
|
2020-03-13 12:19:05 +00:00
|
|
|
@property
|
2020-08-17 19:02:43 +00:00
|
|
|
def state(self) -> int:
|
2020-03-13 12:19:05 +00:00
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self.coordinator.data.info.free_heap
|
2020-03-21 22:14:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
class WLEDWifiSignalSensor(WLEDSensor):
|
|
|
|
"""Defines a WLED Wi-Fi signal sensor."""
|
|
|
|
|
|
|
|
def __init__(self, entry_id: str, coordinator: WLEDDataUpdateCoordinator) -> None:
|
|
|
|
"""Initialize WLED Wi-Fi signal sensor."""
|
|
|
|
super().__init__(
|
|
|
|
coordinator=coordinator,
|
|
|
|
enabled_default=False,
|
|
|
|
entry_id=entry_id,
|
|
|
|
icon="mdi:wifi",
|
|
|
|
key="wifi_signal",
|
|
|
|
name=f"{coordinator.data.info.name} Wi-Fi Signal",
|
2020-09-05 19:09:14 +00:00
|
|
|
unit_of_measurement=PERCENTAGE,
|
2020-03-21 22:14:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
@property
|
2020-08-17 19:02:43 +00:00
|
|
|
def state(self) -> int:
|
2020-03-21 22:14:41 +00:00
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self.coordinator.data.info.wifi.signal
|
|
|
|
|
|
|
|
|
|
|
|
class WLEDWifiRSSISensor(WLEDSensor):
|
|
|
|
"""Defines a WLED Wi-Fi RSSI sensor."""
|
|
|
|
|
|
|
|
def __init__(self, entry_id: str, coordinator: WLEDDataUpdateCoordinator) -> None:
|
|
|
|
"""Initialize WLED Wi-Fi RSSI sensor."""
|
|
|
|
super().__init__(
|
|
|
|
coordinator=coordinator,
|
|
|
|
enabled_default=False,
|
|
|
|
entry_id=entry_id,
|
|
|
|
icon="mdi:wifi",
|
|
|
|
key="wifi_rssi",
|
|
|
|
name=f"{coordinator.data.info.name} Wi-Fi RSSI",
|
2020-10-01 14:14:29 +00:00
|
|
|
unit_of_measurement=SIGNAL_STRENGTH_DECIBELS_MILLIWATT,
|
2020-03-21 22:14:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
@property
|
2020-08-17 19:02:43 +00:00
|
|
|
def state(self) -> int:
|
2020-03-21 22:14:41 +00:00
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self.coordinator.data.info.wifi.rssi
|
|
|
|
|
|
|
|
@property
|
2021-03-18 14:08:35 +00:00
|
|
|
def device_class(self) -> str | None:
|
2020-03-21 22:14:41 +00:00
|
|
|
"""Return the class of this sensor."""
|
|
|
|
return DEVICE_CLASS_SIGNAL_STRENGTH
|
|
|
|
|
|
|
|
|
|
|
|
class WLEDWifiChannelSensor(WLEDSensor):
|
|
|
|
"""Defines a WLED Wi-Fi Channel sensor."""
|
|
|
|
|
|
|
|
def __init__(self, entry_id: str, coordinator: WLEDDataUpdateCoordinator) -> None:
|
|
|
|
"""Initialize WLED Wi-Fi Channel sensor."""
|
|
|
|
super().__init__(
|
|
|
|
coordinator=coordinator,
|
|
|
|
enabled_default=False,
|
|
|
|
entry_id=entry_id,
|
|
|
|
icon="mdi:wifi",
|
|
|
|
key="wifi_channel",
|
|
|
|
name=f"{coordinator.data.info.name} Wi-Fi Channel",
|
|
|
|
)
|
|
|
|
|
|
|
|
@property
|
2020-08-17 19:02:43 +00:00
|
|
|
def state(self) -> int:
|
2020-03-21 22:14:41 +00:00
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self.coordinator.data.info.wifi.channel
|
|
|
|
|
|
|
|
|
|
|
|
class WLEDWifiBSSIDSensor(WLEDSensor):
|
|
|
|
"""Defines a WLED Wi-Fi BSSID sensor."""
|
|
|
|
|
|
|
|
def __init__(self, entry_id: str, coordinator: WLEDDataUpdateCoordinator) -> None:
|
|
|
|
"""Initialize WLED Wi-Fi BSSID sensor."""
|
|
|
|
super().__init__(
|
|
|
|
coordinator=coordinator,
|
|
|
|
enabled_default=False,
|
|
|
|
entry_id=entry_id,
|
|
|
|
icon="mdi:wifi",
|
|
|
|
key="wifi_bssid",
|
|
|
|
name=f"{coordinator.data.info.name} Wi-Fi BSSID",
|
|
|
|
)
|
|
|
|
|
|
|
|
@property
|
2020-08-17 19:02:43 +00:00
|
|
|
def state(self) -> str:
|
2020-03-21 22:14:41 +00:00
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self.coordinator.data.info.wifi.bssid
|