2019-02-13 20:21:14 +00:00
|
|
|
"""Base Entity for all TelldusLive entities."""
|
2018-12-04 09:08:40 +00:00
|
|
|
from datetime import datetime
|
|
|
|
import logging
|
|
|
|
|
2019-12-08 08:48:08 +00:00
|
|
|
from tellduslive import BATTERY_LOW, BATTERY_OK, BATTERY_UNKNOWN
|
|
|
|
|
2021-10-22 15:04:25 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
ATTR_BATTERY_LEVEL,
|
|
|
|
ATTR_MANUFACTURER,
|
|
|
|
ATTR_MODEL,
|
|
|
|
ATTR_VIA_DEVICE,
|
|
|
|
DEVICE_DEFAULT_NAME,
|
|
|
|
)
|
2018-12-04 09:08:40 +00:00
|
|
|
from homeassistant.core import callback
|
|
|
|
from homeassistant.helpers.dispatcher import async_dispatcher_connect
|
2021-10-22 15:04:25 +00:00
|
|
|
from homeassistant.helpers.entity import DeviceInfo, Entity
|
2018-12-04 09:08:40 +00:00
|
|
|
|
|
|
|
from .const import SIGNAL_UPDATE_ENTITY
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
ATTR_LAST_UPDATED = "time_last_updated"
|
2018-12-04 09:08:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TelldusLiveEntity(Entity):
|
|
|
|
"""Base class for all Telldus Live entities."""
|
|
|
|
|
2022-08-27 02:03:50 +00:00
|
|
|
_attr_should_poll = False
|
|
|
|
|
2018-12-04 09:08:40 +00:00
|
|
|
def __init__(self, client, device_id):
|
|
|
|
"""Initialize the entity."""
|
|
|
|
self._id = device_id
|
|
|
|
self._client = client
|
|
|
|
self._name = self.device.name
|
|
|
|
self._async_unsub_dispatcher_connect = None
|
|
|
|
|
|
|
|
async def async_added_to_hass(self):
|
|
|
|
"""Call when entity is added to hass."""
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.debug("Created device %s", self)
|
2018-12-04 09:08:40 +00:00
|
|
|
self._async_unsub_dispatcher_connect = async_dispatcher_connect(
|
2019-07-31 19:25:30 +00:00
|
|
|
self.hass, SIGNAL_UPDATE_ENTITY, self._update_callback
|
|
|
|
)
|
2018-12-04 09:08:40 +00:00
|
|
|
|
|
|
|
async def async_will_remove_from_hass(self):
|
|
|
|
"""Disconnect dispatcher listener when removed."""
|
|
|
|
if self._async_unsub_dispatcher_connect:
|
|
|
|
self._async_unsub_dispatcher_connect()
|
|
|
|
|
|
|
|
@callback
|
|
|
|
def _update_callback(self):
|
|
|
|
"""Return the property of the device might have changed."""
|
|
|
|
if self.device.name:
|
|
|
|
self._name = self.device.name
|
2020-04-01 21:19:51 +00:00
|
|
|
self.async_write_ha_state()
|
2018-12-04 09:08:40 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def device_id(self):
|
|
|
|
"""Return the id of the device."""
|
|
|
|
return self._id
|
|
|
|
|
|
|
|
@property
|
|
|
|
def device(self):
|
|
|
|
"""Return the representation of the device."""
|
|
|
|
return self._client.device(self.device_id)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def _state(self):
|
|
|
|
"""Return the state of the device."""
|
|
|
|
return self.device.state
|
|
|
|
|
|
|
|
@property
|
|
|
|
def assumed_state(self):
|
|
|
|
"""Return true if unable to access real state of entity."""
|
|
|
|
return True
|
|
|
|
|
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return name of device."""
|
|
|
|
return self._name or DEVICE_DEFAULT_NAME
|
|
|
|
|
|
|
|
@property
|
|
|
|
def available(self):
|
|
|
|
"""Return true if device is not offline."""
|
|
|
|
return self._client.is_available(self.device_id)
|
|
|
|
|
|
|
|
@property
|
2021-03-11 19:16:26 +00:00
|
|
|
def extra_state_attributes(self):
|
2018-12-04 09:08:40 +00:00
|
|
|
"""Return the state attributes."""
|
|
|
|
attrs = {}
|
|
|
|
if self._battery_level:
|
|
|
|
attrs[ATTR_BATTERY_LEVEL] = self._battery_level
|
|
|
|
if self._last_updated:
|
|
|
|
attrs[ATTR_LAST_UPDATED] = self._last_updated
|
|
|
|
return attrs
|
|
|
|
|
|
|
|
@property
|
|
|
|
def _battery_level(self):
|
|
|
|
"""Return the battery level of a device."""
|
|
|
|
if self.device.battery == BATTERY_LOW:
|
|
|
|
return 1
|
|
|
|
if self.device.battery == BATTERY_UNKNOWN:
|
|
|
|
return None
|
|
|
|
if self.device.battery == BATTERY_OK:
|
|
|
|
return 100
|
|
|
|
return self.device.battery # Percentage
|
|
|
|
|
|
|
|
@property
|
|
|
|
def _last_updated(self):
|
|
|
|
"""Return the last update of a device."""
|
2019-07-31 19:25:30 +00:00
|
|
|
return (
|
|
|
|
str(datetime.fromtimestamp(self.device.lastUpdated))
|
|
|
|
if self.device.lastUpdated
|
|
|
|
else None
|
|
|
|
)
|
2018-12-04 09:08:40 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self) -> str:
|
|
|
|
"""Return a unique ID."""
|
|
|
|
return self._id
|
2018-12-23 18:13:49 +00:00
|
|
|
|
|
|
|
@property
|
2021-10-22 15:04:25 +00:00
|
|
|
def device_info(self) -> DeviceInfo:
|
2018-12-23 18:13:49 +00:00
|
|
|
"""Return device info."""
|
|
|
|
device = self._client.device_info(self.device.device_id)
|
2021-10-22 15:04:25 +00:00
|
|
|
device_info = DeviceInfo(
|
|
|
|
identifiers={("tellduslive", self.device.device_id)},
|
|
|
|
name=self.device.name,
|
|
|
|
)
|
2021-10-18 12:01:23 +00:00
|
|
|
if (model := device.get("model")) is not None:
|
2021-10-22 15:04:25 +00:00
|
|
|
device_info[ATTR_MODEL] = model.title()
|
2021-10-18 12:01:23 +00:00
|
|
|
if (protocol := device.get("protocol")) is not None:
|
2021-10-22 15:04:25 +00:00
|
|
|
device_info[ATTR_MANUFACTURER] = protocol.title()
|
2021-10-18 12:01:23 +00:00
|
|
|
if (client := device.get("client")) is not None:
|
2021-10-22 15:04:25 +00:00
|
|
|
device_info[ATTR_VIA_DEVICE] = ("tellduslive", client)
|
2019-01-29 00:46:37 +00:00
|
|
|
return device_info
|