mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 05:07:41 +00:00
Add YoLink lock V2 support (#124202)
* Add Lock V2 Support * Change as suggestions
This commit is contained in:
parent
c4e5d67551
commit
f8ac952cd7
@ -1,11 +1,11 @@
|
|||||||
"""YoLink Lock."""
|
"""YoLink Lock V1/V2."""
|
||||||
|
|
||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
from typing import Any
|
from typing import Any
|
||||||
|
|
||||||
from yolink.client_request import ClientRequest
|
from yolink.client_request import ClientRequest
|
||||||
from yolink.const import ATTR_DEVICE_LOCK
|
from yolink.const import ATTR_DEVICE_LOCK, ATTR_DEVICE_LOCK_V2
|
||||||
|
|
||||||
from homeassistant.components.lock import LockEntity
|
from homeassistant.components.lock import LockEntity
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
@ -27,7 +27,8 @@ async def async_setup_entry(
|
|||||||
entities = [
|
entities = [
|
||||||
YoLinkLockEntity(config_entry, device_coordinator)
|
YoLinkLockEntity(config_entry, device_coordinator)
|
||||||
for device_coordinator in device_coordinators.values()
|
for device_coordinator in device_coordinators.values()
|
||||||
if device_coordinator.device.device_type == ATTR_DEVICE_LOCK
|
if device_coordinator.device.device_type
|
||||||
|
in [ATTR_DEVICE_LOCK, ATTR_DEVICE_LOCK_V2]
|
||||||
]
|
]
|
||||||
async_add_entities(entities)
|
async_add_entities(entities)
|
||||||
|
|
||||||
@ -50,6 +51,11 @@ class YoLinkLockEntity(YoLinkEntity, LockEntity):
|
|||||||
def update_entity_state(self, state: dict[str, Any]) -> None:
|
def update_entity_state(self, state: dict[str, Any]) -> None:
|
||||||
"""Update HA Entity State."""
|
"""Update HA Entity State."""
|
||||||
state_value = state.get("state")
|
state_value = state.get("state")
|
||||||
|
if self.coordinator.device.device_type == ATTR_DEVICE_LOCK_V2:
|
||||||
|
self._attr_is_locked = (
|
||||||
|
state_value["lock"] == "locked" if state_value is not None else None
|
||||||
|
)
|
||||||
|
else:
|
||||||
self._attr_is_locked = (
|
self._attr_is_locked = (
|
||||||
state_value == "locked" if state_value is not None else None
|
state_value == "locked" if state_value is not None else None
|
||||||
)
|
)
|
||||||
@ -57,14 +63,29 @@ class YoLinkLockEntity(YoLinkEntity, LockEntity):
|
|||||||
|
|
||||||
async def call_lock_state_change(self, state: str) -> None:
|
async def call_lock_state_change(self, state: str) -> None:
|
||||||
"""Call setState api to change lock state."""
|
"""Call setState api to change lock state."""
|
||||||
|
if self.coordinator.device.device_type == ATTR_DEVICE_LOCK_V2:
|
||||||
|
await self.call_device(
|
||||||
|
ClientRequest("setState", {"state": {"lock": state}})
|
||||||
|
)
|
||||||
|
else:
|
||||||
await self.call_device(ClientRequest("setState", {"state": state}))
|
await self.call_device(ClientRequest("setState", {"state": state}))
|
||||||
self._attr_is_locked = state == "lock"
|
self._attr_is_locked = state == "lock"
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
async def async_lock(self, **kwargs: Any) -> None:
|
async def async_lock(self, **kwargs: Any) -> None:
|
||||||
"""Lock device."""
|
"""Lock device."""
|
||||||
await self.call_lock_state_change("lock")
|
state_param = (
|
||||||
|
"locked"
|
||||||
|
if self.coordinator.device.device_type == ATTR_DEVICE_LOCK_V2
|
||||||
|
else "lock"
|
||||||
|
)
|
||||||
|
await self.call_lock_state_change(state_param)
|
||||||
|
|
||||||
async def async_unlock(self, **kwargs: Any) -> None:
|
async def async_unlock(self, **kwargs: Any) -> None:
|
||||||
"""Unlock device."""
|
"""Unlock device."""
|
||||||
await self.call_lock_state_change("unlock")
|
state_param = (
|
||||||
|
"unlocked"
|
||||||
|
if self.coordinator.device.device_type == ATTR_DEVICE_LOCK_V2
|
||||||
|
else "unlock"
|
||||||
|
)
|
||||||
|
await self.call_lock_state_change(state_param)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user