2021-09-27 19:11:55 +00:00
|
|
|
"""Common code for tplink."""
|
|
|
|
from __future__ import annotations
|
|
|
|
|
2022-01-09 05:03:18 +00:00
|
|
|
from collections.abc import Awaitable, Callable, Coroutine
|
|
|
|
from typing import Any, TypeVar
|
2021-09-27 19:11:55 +00:00
|
|
|
|
|
|
|
from kasa import SmartDevice
|
2022-01-04 17:37:46 +00:00
|
|
|
from typing_extensions import Concatenate, ParamSpec
|
2021-09-27 19:11:55 +00:00
|
|
|
|
|
|
|
from homeassistant.helpers import device_registry as dr
|
|
|
|
from homeassistant.helpers.entity import DeviceInfo
|
|
|
|
from homeassistant.helpers.update_coordinator import CoordinatorEntity
|
|
|
|
|
|
|
|
from .const import DOMAIN
|
|
|
|
from .coordinator import TPLinkDataUpdateCoordinator
|
|
|
|
|
2022-01-04 17:37:46 +00:00
|
|
|
_T = TypeVar("_T", bound="CoordinatedTPLinkEntity")
|
|
|
|
_P = ParamSpec("_P")
|
2021-09-27 19:11:55 +00:00
|
|
|
|
|
|
|
|
2022-01-04 17:37:46 +00:00
|
|
|
def async_refresh_after(
|
|
|
|
func: Callable[Concatenate[_T, _P], Awaitable[None]] # type: ignore[misc]
|
2022-01-09 05:03:18 +00:00
|
|
|
) -> Callable[Concatenate[_T, _P], Coroutine[Any, Any, None]]: # type: ignore[misc]
|
2021-09-27 19:11:55 +00:00
|
|
|
"""Define a wrapper to refresh after."""
|
|
|
|
|
2022-01-04 17:37:46 +00:00
|
|
|
async def _async_wrap(self: _T, *args: _P.args, **kwargs: _P.kwargs) -> None:
|
2021-09-27 19:11:55 +00:00
|
|
|
await func(self, *args, **kwargs)
|
|
|
|
await self.coordinator.async_request_refresh_without_children()
|
|
|
|
|
2022-01-04 17:37:46 +00:00
|
|
|
return _async_wrap
|
2021-09-27 19:11:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
class CoordinatedTPLinkEntity(CoordinatorEntity):
|
|
|
|
"""Common base class for all coordinated tplink entities."""
|
|
|
|
|
|
|
|
coordinator: TPLinkDataUpdateCoordinator
|
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self, device: SmartDevice, coordinator: TPLinkDataUpdateCoordinator
|
|
|
|
) -> None:
|
|
|
|
"""Initialize the switch."""
|
|
|
|
super().__init__(coordinator)
|
|
|
|
self.device: SmartDevice = device
|
2021-11-13 23:50:37 +00:00
|
|
|
self._attr_name = self.device.alias
|
2021-09-27 19:11:55 +00:00
|
|
|
self._attr_unique_id = self.device.device_id
|
|
|
|
|
|
|
|
@property
|
|
|
|
def device_info(self) -> DeviceInfo:
|
|
|
|
"""Return information about the device."""
|
2021-10-28 16:23:16 +00:00
|
|
|
return DeviceInfo(
|
|
|
|
connections={(dr.CONNECTION_NETWORK_MAC, self.device.mac)},
|
|
|
|
identifiers={(DOMAIN, str(self.device.device_id))},
|
|
|
|
manufacturer="TP-Link",
|
|
|
|
model=self.device.model,
|
|
|
|
name=self.device.alias,
|
|
|
|
sw_version=self.device.hw_info["sw_ver"],
|
|
|
|
)
|
2021-09-27 19:11:55 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self) -> bool:
|
|
|
|
"""Return true if switch is on."""
|
|
|
|
return bool(self.device.is_on)
|