mirror of
https://github.com/python-kasa/python-kasa.git
synced 2025-01-23 05:07:09 +00:00
101 lines
3.1 KiB
Python
101 lines
3.1 KiB
Python
"""Base implementation for SMART modules."""
|
|
|
|
from __future__ import annotations
|
|
|
|
import logging
|
|
from typing import TYPE_CHECKING, Any, cast
|
|
|
|
from ..exceptions import DeviceError, KasaException, SmartErrorCode
|
|
from ..smart.smartmodule import SmartModule
|
|
|
|
if TYPE_CHECKING:
|
|
from .smartcamera import SmartCamera
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
class SmartCameraModule(SmartModule):
|
|
"""Base class for SMARTCAMERA modules."""
|
|
|
|
#: Query to execute during the main update cycle
|
|
QUERY_GETTER_NAME: str
|
|
#: Module name to be queried
|
|
QUERY_MODULE_NAME: str
|
|
#: Section name or names to be queried
|
|
QUERY_SECTION_NAMES: str | list[str]
|
|
|
|
REGISTERED_MODULES = {}
|
|
|
|
_device: SmartCamera
|
|
|
|
def query(self) -> dict:
|
|
"""Query to execute during the update cycle.
|
|
|
|
Default implementation uses the raw query getter w/o parameters.
|
|
"""
|
|
return {
|
|
self.QUERY_GETTER_NAME: {
|
|
self.QUERY_MODULE_NAME: {"name": self.QUERY_SECTION_NAMES}
|
|
}
|
|
}
|
|
|
|
async def call(self, method: str, params: dict | None = None) -> dict:
|
|
"""Call a method.
|
|
|
|
Just a helper method.
|
|
"""
|
|
if params:
|
|
module = next(iter(params))
|
|
section = next(iter(params[module]))
|
|
else:
|
|
module = "system"
|
|
section = "null"
|
|
|
|
if method[:3] == "get":
|
|
return await self._device._query_getter_helper(method, module, section)
|
|
|
|
if TYPE_CHECKING:
|
|
params = cast(dict[str, dict[str, Any]], params)
|
|
return await self._device._query_setter_helper(
|
|
method, module, section, params[module][section]
|
|
)
|
|
|
|
@property
|
|
def data(self) -> dict:
|
|
"""Return response data for the module."""
|
|
dev = self._device
|
|
q = self.query()
|
|
|
|
if not q:
|
|
return dev.sys_info
|
|
|
|
if len(q) == 1:
|
|
query_resp = dev._last_update.get(self.QUERY_GETTER_NAME, {})
|
|
if isinstance(query_resp, SmartErrorCode):
|
|
raise DeviceError(
|
|
f"Error accessing module data in {self._module}",
|
|
error_code=SmartErrorCode,
|
|
)
|
|
|
|
if not query_resp:
|
|
raise KasaException(
|
|
f"You need to call update() prior accessing module data"
|
|
f" for '{self._module}'"
|
|
)
|
|
|
|
return query_resp.get(self.QUERY_MODULE_NAME)
|
|
else:
|
|
found = {key: val for key, val in dev._last_update.items() if key in q}
|
|
for key in q:
|
|
if key not in found:
|
|
raise KasaException(
|
|
f"{key} not found, you need to call update() prior accessing"
|
|
f" module data for '{self._module}'"
|
|
)
|
|
if isinstance(found[key], SmartErrorCode):
|
|
raise DeviceError(
|
|
f"Error accessing module data {key} in {self._module}",
|
|
error_code=SmartErrorCode,
|
|
)
|
|
return found
|