Use centralized KnxEntity for all KNX platforms (#40381)
This commit is contained in:
parent
c13fbf795d
commit
3d6434be75
12 changed files with 206 additions and 338 deletions
|
@ -3,72 +3,41 @@ from typing import Any, Dict, Optional
|
|||
|
||||
from xknx.devices import BinarySensor as XknxBinarySensor
|
||||
|
||||
from homeassistant.components.binary_sensor import BinarySensorEntity
|
||||
from homeassistant.core import callback
|
||||
from homeassistant.components.binary_sensor import DEVICE_CLASSES, BinarySensorEntity
|
||||
|
||||
from .const import ATTR_COUNTER, DATA_KNX
|
||||
from .const import ATTR_COUNTER, DOMAIN
|
||||
from .knx_entity import KnxEntity
|
||||
|
||||
|
||||
async def async_setup_platform(hass, config, async_add_entities, discovery_info=None):
|
||||
"""Set up binary sensor(s) for KNX platform."""
|
||||
entities = []
|
||||
for device in hass.data[DATA_KNX].xknx.devices:
|
||||
for device in hass.data[DOMAIN].xknx.devices:
|
||||
if isinstance(device, XknxBinarySensor):
|
||||
entities.append(KNXBinarySensor(device))
|
||||
async_add_entities(entities)
|
||||
|
||||
|
||||
class KNXBinarySensor(BinarySensorEntity):
|
||||
class KNXBinarySensor(KnxEntity, BinarySensorEntity):
|
||||
"""Representation of a KNX binary sensor."""
|
||||
|
||||
def __init__(self, device: XknxBinarySensor):
|
||||
"""Initialize of KNX binary sensor."""
|
||||
self.device = device
|
||||
|
||||
@callback
|
||||
def async_register_callbacks(self):
|
||||
"""Register callbacks to update hass after device was changed."""
|
||||
|
||||
async def after_update_callback(device: XknxBinarySensor):
|
||||
"""Call after device was updated."""
|
||||
self.async_write_ha_state()
|
||||
|
||||
self.device.register_device_updated_cb(after_update_callback)
|
||||
|
||||
async def async_added_to_hass(self):
|
||||
"""Store register state change callback."""
|
||||
self.async_register_callbacks()
|
||||
|
||||
async def async_update(self):
|
||||
"""Request a state update from KNX bus."""
|
||||
await self.device.sync()
|
||||
|
||||
@property
|
||||
def name(self):
|
||||
"""Return the name of the KNX device."""
|
||||
return self.device.name
|
||||
|
||||
@property
|
||||
def available(self):
|
||||
"""Return True if entity is available."""
|
||||
return self.hass.data[DATA_KNX].connected
|
||||
|
||||
@property
|
||||
def should_poll(self):
|
||||
"""No polling needed within KNX."""
|
||||
return False
|
||||
super().__init__(device)
|
||||
|
||||
@property
|
||||
def device_class(self):
|
||||
"""Return the class of this sensor."""
|
||||
return self.device.device_class
|
||||
if self._device.device_class in DEVICE_CLASSES:
|
||||
return self._device.device_class
|
||||
return None
|
||||
|
||||
@property
|
||||
def is_on(self):
|
||||
"""Return true if the binary sensor is on."""
|
||||
return self.device.is_on()
|
||||
return self._device.is_on()
|
||||
|
||||
@property
|
||||
def device_state_attributes(self) -> Optional[Dict[str, Any]]:
|
||||
"""Return device specific state attributes."""
|
||||
return {ATTR_COUNTER: self.device.counter}
|
||||
return {ATTR_COUNTER: self._device.counter}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue