"""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)