82 lines
2.8 KiB
Python
82 lines
2.8 KiB
Python
"""Support for StarLine lock."""
|
|
from __future__ import annotations
|
|
|
|
from typing import Any
|
|
|
|
from homeassistant.components.lock import LockEntity
|
|
from homeassistant.config_entries import ConfigEntry
|
|
from homeassistant.core import HomeAssistant
|
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
|
|
|
from .account import StarlineAccount, StarlineDevice
|
|
from .const import DOMAIN
|
|
from .entity import StarlineEntity
|
|
|
|
|
|
async def async_setup_entry(
|
|
hass: HomeAssistant, entry: ConfigEntry, async_add_entities: AddEntitiesCallback
|
|
) -> None:
|
|
"""Set up the StarLine lock."""
|
|
account: StarlineAccount = hass.data[DOMAIN][entry.entry_id]
|
|
entities = []
|
|
for device in account.api.devices.values():
|
|
if device.support_state:
|
|
lock = StarlineLock(account, device)
|
|
if lock.is_locked is not None:
|
|
entities.append(lock)
|
|
async_add_entities(entities)
|
|
|
|
|
|
class StarlineLock(StarlineEntity, LockEntity):
|
|
"""Representation of a StarLine lock."""
|
|
|
|
def __init__(self, account: StarlineAccount, device: StarlineDevice) -> None:
|
|
"""Initialize the lock."""
|
|
super().__init__(account, device, "lock", "Security")
|
|
|
|
@property
|
|
def available(self) -> bool:
|
|
"""Return True if entity is available."""
|
|
return super().available and self._device.online
|
|
|
|
@property
|
|
def extra_state_attributes(self) -> dict[str, bool]:
|
|
"""Return the state attributes of the lock.
|
|
|
|
Possible dictionary keys:
|
|
add_h - Additional sensor alarm status (high level)
|
|
add_l - Additional channel alarm status (low level)
|
|
door - Doors alarm status
|
|
hbrake - Hand brake alarm status
|
|
hijack - Hijack mode status
|
|
hood - Hood alarm status
|
|
ign - Ignition alarm status
|
|
pbrake - Brake pedal alarm status
|
|
shock_h - Shock sensor alarm status (high level)
|
|
shock_l - Shock sensor alarm status (low level)
|
|
tilt - Tilt sensor alarm status
|
|
trunk - Trunk alarm status
|
|
Documentation: https://developer.starline.ru/#api-Device-DeviceState
|
|
"""
|
|
return self._device.alarm_state
|
|
|
|
@property
|
|
def icon(self) -> str:
|
|
"""Icon to use in the frontend, if any."""
|
|
return (
|
|
"mdi:shield-check-outline" if self.is_locked else "mdi:shield-alert-outline"
|
|
)
|
|
|
|
@property
|
|
def is_locked(self) -> bool | None:
|
|
"""Return true if lock is locked."""
|
|
return self._device.car_state.get("arm")
|
|
|
|
def lock(self, **kwargs: Any) -> None:
|
|
"""Lock the car."""
|
|
self._account.api.set_car_state(self._device.device_id, "arm", True)
|
|
|
|
def unlock(self, **kwargs: Any) -> None:
|
|
"""Unlock the car."""
|
|
self._account.api.set_car_state(self._device.device_id, "arm", False)
|