143 lines
4.5 KiB
Python
143 lines
4.5 KiB
Python
"""Doorsensor Support for the Nuki Lock."""
|
|
|
|
from __future__ import annotations
|
|
|
|
from pynuki.constants import STATE_DOORSENSOR_OPENED
|
|
from pynuki.device import NukiDevice
|
|
|
|
from homeassistant.components.binary_sensor import (
|
|
BinarySensorDeviceClass,
|
|
BinarySensorEntity,
|
|
)
|
|
from homeassistant.config_entries import ConfigEntry
|
|
from homeassistant.const import EntityCategory
|
|
from homeassistant.core import HomeAssistant
|
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|
|
|
from . import NukiEntity, NukiEntryData
|
|
from .const import ATTR_NUKI_ID, DOMAIN as NUKI_DOMAIN
|
|
|
|
|
|
async def async_setup_entry(
|
|
hass: HomeAssistant, entry: ConfigEntry, async_add_entities: AddEntitiesCallback
|
|
) -> None:
|
|
"""Set up the Nuki binary sensors."""
|
|
entry_data: NukiEntryData = hass.data[NUKI_DOMAIN][entry.entry_id]
|
|
|
|
entities: list[NukiEntity] = []
|
|
|
|
for lock in entry_data.locks:
|
|
if lock.is_door_sensor_activated:
|
|
entities.append(NukiDoorsensorEntity(entry_data.coordinator, lock))
|
|
entities.append(NukiBatteryCriticalEntity(entry_data.coordinator, lock))
|
|
entities.append(NukiBatteryChargingEntity(entry_data.coordinator, lock))
|
|
|
|
for opener in entry_data.openers:
|
|
entities.append(NukiRingactionEntity(entry_data.coordinator, opener))
|
|
entities.append(NukiBatteryCriticalEntity(entry_data.coordinator, opener))
|
|
|
|
async_add_entities(entities)
|
|
|
|
|
|
class NukiDoorsensorEntity(NukiEntity[NukiDevice], BinarySensorEntity):
|
|
"""Representation of a Nuki Lock Doorsensor."""
|
|
|
|
_attr_has_entity_name = True
|
|
_attr_name = None
|
|
_attr_device_class = BinarySensorDeviceClass.DOOR
|
|
|
|
@property
|
|
def unique_id(self) -> str:
|
|
"""Return a unique ID."""
|
|
return f"{self._nuki_device.nuki_id}_doorsensor"
|
|
|
|
# Deprecated, can be removed in 2024.10
|
|
@property
|
|
def extra_state_attributes(self):
|
|
"""Return the device specific state attributes."""
|
|
return {
|
|
ATTR_NUKI_ID: self._nuki_device.nuki_id,
|
|
}
|
|
|
|
@property
|
|
def available(self) -> bool:
|
|
"""Return true if door sensor is present and activated."""
|
|
return super().available and self._nuki_device.is_door_sensor_activated
|
|
|
|
@property
|
|
def door_sensor_state(self):
|
|
"""Return the state of the door sensor."""
|
|
return self._nuki_device.door_sensor_state
|
|
|
|
@property
|
|
def door_sensor_state_name(self):
|
|
"""Return the state name of the door sensor."""
|
|
return self._nuki_device.door_sensor_state_name
|
|
|
|
@property
|
|
def is_on(self):
|
|
"""Return true if the door is open."""
|
|
return self.door_sensor_state == STATE_DOORSENSOR_OPENED
|
|
|
|
|
|
class NukiRingactionEntity(NukiEntity[NukiDevice], BinarySensorEntity):
|
|
"""Representation of a Nuki Opener Ringaction."""
|
|
|
|
_attr_has_entity_name = True
|
|
_attr_translation_key = "ring_action"
|
|
|
|
@property
|
|
def unique_id(self) -> str:
|
|
"""Return a unique ID."""
|
|
return f"{self._nuki_device.nuki_id}_ringaction"
|
|
|
|
# Deprecated, can be removed in 2024.10
|
|
@property
|
|
def extra_state_attributes(self):
|
|
"""Return the device specific state attributes."""
|
|
return {
|
|
ATTR_NUKI_ID: self._nuki_device.nuki_id,
|
|
}
|
|
|
|
@property
|
|
def is_on(self) -> bool:
|
|
"""Return the value of the ring action state."""
|
|
return self._nuki_device.ring_action_state
|
|
|
|
|
|
class NukiBatteryCriticalEntity(NukiEntity[NukiDevice], BinarySensorEntity):
|
|
"""Representation of Nuki Battery Critical."""
|
|
|
|
_attr_has_entity_name = True
|
|
_attr_device_class = BinarySensorDeviceClass.BATTERY
|
|
_attr_entity_category = EntityCategory.DIAGNOSTIC
|
|
|
|
@property
|
|
def unique_id(self) -> str:
|
|
"""Return a unique ID."""
|
|
return f"{self._nuki_device.nuki_id}_battery_critical"
|
|
|
|
@property
|
|
def is_on(self) -> bool:
|
|
"""Return the value of the battery critical."""
|
|
return self._nuki_device.battery_critical
|
|
|
|
|
|
class NukiBatteryChargingEntity(NukiEntity[NukiDevice], BinarySensorEntity):
|
|
"""Representation of a Nuki Battery charging."""
|
|
|
|
_attr_has_entity_name = True
|
|
_attr_device_class = BinarySensorDeviceClass.BATTERY_CHARGING
|
|
_attr_entity_category = EntityCategory.DIAGNOSTIC
|
|
_attr_entity_registry_enabled_default = False
|
|
|
|
@property
|
|
def unique_id(self) -> str:
|
|
"""Return a unique ID."""
|
|
return f"{self._nuki_device.nuki_id}_battery_charging"
|
|
|
|
@property
|
|
def is_on(self) -> bool:
|
|
"""Return the value of the battery charging."""
|
|
return self._nuki_device.battery_charging
|