"""Utilities for Plugwise.""" from collections.abc import Awaitable, Callable, Coroutine from typing import Any, Concatenate from plugwise.exceptions import PlugwiseException from homeassistant.exceptions import HomeAssistantError from .const import DOMAIN from .entity import PlugwiseEntity def plugwise_command[_PlugwiseEntityT: PlugwiseEntity, **_P, _R]( func: Callable[Concatenate[_PlugwiseEntityT, _P], Awaitable[_R]], ) -> Callable[Concatenate[_PlugwiseEntityT, _P], Coroutine[Any, Any, _R]]: """Decorate Plugwise calls that send commands/make changes to the device. A decorator that wraps the passed in function, catches Plugwise errors, and requests an coordinator update to update status of the devices asap. """ async def handler( self: _PlugwiseEntityT, *args: _P.args, **kwargs: _P.kwargs ) -> _R: try: return await func(self, *args, **kwargs) except PlugwiseException as err: raise HomeAssistantError( translation_domain=DOMAIN, translation_key="error_communicating_with_api", translation_placeholders={ "error": str(err), }, ) from err finally: await self.coordinator.async_request_refresh() return handler