2022-02-12 02:52:31 +00:00
|
|
|
"""Helpers for Roku."""
|
|
|
|
from __future__ import annotations
|
|
|
|
|
2022-03-04 05:08:29 +00:00
|
|
|
from collections.abc import Awaitable, Callable, Coroutine
|
|
|
|
from functools import wraps
|
|
|
|
import logging
|
|
|
|
from typing import Any, TypeVar
|
|
|
|
|
|
|
|
from rokuecp import RokuConnectionError, RokuConnectionTimeoutError, RokuError
|
|
|
|
from typing_extensions import Concatenate, ParamSpec
|
|
|
|
|
|
|
|
from .entity import RokuEntity
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
2022-04-28 19:05:22 +00:00
|
|
|
_RokuEntityT = TypeVar("_RokuEntityT", bound=RokuEntity)
|
2022-03-04 05:08:29 +00:00
|
|
|
_P = ParamSpec("_P")
|
|
|
|
|
2022-02-12 02:52:31 +00:00
|
|
|
|
|
|
|
def format_channel_name(channel_number: str, channel_name: str | None = None) -> str:
|
|
|
|
"""Format a Roku Channel name."""
|
|
|
|
if channel_name is not None and channel_name != "":
|
|
|
|
return f"{channel_name} ({channel_number})"
|
|
|
|
|
|
|
|
return channel_number
|
2022-03-04 05:08:29 +00:00
|
|
|
|
|
|
|
|
2022-04-28 19:05:22 +00:00
|
|
|
def roku_exception_handler(
|
|
|
|
ignore_timeout: bool = False,
|
|
|
|
) -> Callable[
|
|
|
|
[Callable[Concatenate[_RokuEntityT, _P], Awaitable[Any]]],
|
|
|
|
Callable[Concatenate[_RokuEntityT, _P], Coroutine[Any, Any, None]],
|
|
|
|
]:
|
2022-03-04 05:08:29 +00:00
|
|
|
"""Decorate Roku calls to handle Roku exceptions."""
|
|
|
|
|
|
|
|
def decorator(
|
2022-04-28 19:05:22 +00:00
|
|
|
func: Callable[Concatenate[_RokuEntityT, _P], Awaitable[Any]],
|
|
|
|
) -> Callable[Concatenate[_RokuEntityT, _P], Coroutine[Any, Any, None]]:
|
2022-03-04 05:08:29 +00:00
|
|
|
@wraps(func)
|
2022-04-28 19:05:22 +00:00
|
|
|
async def wrapper(
|
|
|
|
self: _RokuEntityT, *args: _P.args, **kwargs: _P.kwargs
|
|
|
|
) -> None:
|
2022-03-04 05:08:29 +00:00
|
|
|
try:
|
|
|
|
await func(self, *args, **kwargs)
|
|
|
|
except RokuConnectionTimeoutError as error:
|
|
|
|
if not ignore_timeout and self.available:
|
|
|
|
_LOGGER.error("Error communicating with API: %s", error)
|
|
|
|
except RokuConnectionError as error:
|
|
|
|
if self.available:
|
|
|
|
_LOGGER.error("Error communicating with API: %s", error)
|
|
|
|
except RokuError as error:
|
|
|
|
if self.available:
|
|
|
|
_LOGGER.error("Invalid response from API: %s", error)
|
|
|
|
|
|
|
|
return wrapper
|
|
|
|
|
|
|
|
return decorator
|