2023-04-16 01:36:10 +02:00
|
|
|
from typing import Optional, Dict, Any, List, TYPE_CHECKING
|
|
|
|
|
2023-04-16 01:43:37 +02:00
|
|
|
from pyhon.parameter.base import HonParameter
|
|
|
|
from pyhon.parameter.enum import HonParameterEnum
|
|
|
|
from pyhon.parameter.fixed import HonParameterFixed
|
|
|
|
from pyhon.parameter.program import HonParameterProgram
|
|
|
|
from pyhon.parameter.range import HonParameterRange
|
2023-02-13 01:41:38 +01:00
|
|
|
|
2023-04-16 01:36:10 +02:00
|
|
|
if TYPE_CHECKING:
|
|
|
|
from pyhon import HonAPI
|
|
|
|
from pyhon.appliance import HonAppliance
|
|
|
|
|
2023-02-13 01:41:38 +01:00
|
|
|
|
|
|
|
class HonCommand:
|
2023-04-16 00:11:50 +02:00
|
|
|
def __init__(
|
2023-04-16 01:36:10 +02:00
|
|
|
self,
|
|
|
|
name: str,
|
|
|
|
attributes: Dict[str, Any],
|
|
|
|
api: "HonAPI",
|
|
|
|
appliance: "HonAppliance",
|
2023-05-06 16:07:28 +02:00
|
|
|
categories: Optional[Dict[str, "HonCommand"]] = None,
|
|
|
|
category_name: str = "",
|
2023-04-16 00:11:50 +02:00
|
|
|
):
|
2023-04-16 01:36:10 +02:00
|
|
|
self._api: HonAPI = api
|
|
|
|
self._appliance: "HonAppliance" = appliance
|
|
|
|
self._name: str = name
|
2023-05-06 16:07:28 +02:00
|
|
|
self._categories: Optional[Dict[str, "HonCommand"]] = categories
|
|
|
|
self._category_name: str = category_name
|
|
|
|
self._description: str = attributes.pop("description", "")
|
|
|
|
self._protocol_type: str = attributes.pop("protocolType", "")
|
|
|
|
self._parameters: Dict[str, HonParameter] = {}
|
|
|
|
self._data = {}
|
|
|
|
self._load_parameters(attributes)
|
2023-02-18 22:25:51 +01:00
|
|
|
|
2023-04-16 01:36:10 +02:00
|
|
|
def __repr__(self) -> str:
|
2023-02-18 22:25:51 +01:00
|
|
|
return f"{self._name} command"
|
2023-02-13 01:41:38 +01:00
|
|
|
|
2023-05-06 16:07:28 +02:00
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
return self._name
|
|
|
|
|
|
|
|
@property
|
|
|
|
def data(self):
|
|
|
|
return self._data
|
2023-02-13 01:41:38 +01:00
|
|
|
|
|
|
|
@property
|
2023-04-16 01:36:10 +02:00
|
|
|
def parameters(self) -> Dict[str, HonParameter]:
|
2023-03-06 19:45:46 +01:00
|
|
|
return self._parameters
|
2023-02-13 01:41:38 +01:00
|
|
|
|
2023-05-06 16:07:28 +02:00
|
|
|
def _load_parameters(self, attributes):
|
|
|
|
for key, items in attributes.items():
|
|
|
|
for name, data in items.items():
|
|
|
|
self._create_parameters(data, name, key)
|
|
|
|
|
|
|
|
def _create_parameters(self, data: Dict, name: str, parameter: str) -> None:
|
|
|
|
if name == "zoneMap" and self._appliance.zone:
|
|
|
|
data["default"] = self._appliance.zone
|
|
|
|
match data.get("typology"):
|
|
|
|
case "range":
|
|
|
|
self._parameters[name] = HonParameterRange(name, data, parameter)
|
|
|
|
case "enum":
|
|
|
|
self._parameters[name] = HonParameterEnum(name, data, parameter)
|
|
|
|
case "fixed":
|
|
|
|
self._parameters[name] = HonParameterFixed(name, data, parameter)
|
|
|
|
case _:
|
|
|
|
self._data[name] = data
|
|
|
|
return
|
|
|
|
if self._category_name:
|
|
|
|
if not self._categories:
|
|
|
|
self._parameters["program"] = HonParameterProgram("program", self, name)
|
|
|
|
|
|
|
|
def _parameters_by_group(self, group):
|
|
|
|
return {
|
|
|
|
name: v.value for name, v in self._parameters.items() if v.group == group
|
|
|
|
}
|
2023-02-13 01:41:38 +01:00
|
|
|
|
2023-04-16 01:36:10 +02:00
|
|
|
async def send(self) -> bool:
|
2023-05-06 16:07:28 +02:00
|
|
|
params = self._parameters_by_group("parameters")
|
|
|
|
ancillary_params = self._parameters_by_group("ancillary_parameters")
|
2023-04-16 01:36:10 +02:00
|
|
|
return await self._api.send_command(
|
2023-04-17 00:01:28 +02:00
|
|
|
self._appliance, self._name, params, ancillary_params
|
2023-04-09 20:55:36 +02:00
|
|
|
)
|
2023-02-13 01:41:38 +01:00
|
|
|
|
2023-04-15 23:02:37 +02:00
|
|
|
@property
|
2023-05-06 16:07:28 +02:00
|
|
|
def categories(self) -> Dict[str, "HonCommand"]:
|
|
|
|
if self._categories is None:
|
|
|
|
return {"_": self}
|
|
|
|
return self._categories
|
2023-04-15 23:02:37 +02:00
|
|
|
|
|
|
|
@property
|
2023-05-06 16:07:28 +02:00
|
|
|
def category(self) -> str:
|
|
|
|
return self._category_name
|
|
|
|
|
|
|
|
@category.setter
|
|
|
|
def category(self, category: str) -> None:
|
|
|
|
self._appliance.commands[self._name] = self.categories[category]
|
2023-02-18 22:25:51 +01:00
|
|
|
|
|
|
|
@property
|
2023-04-16 01:36:10 +02:00
|
|
|
def setting_keys(self) -> List[str]:
|
2023-05-06 16:07:28 +02:00
|
|
|
return list(
|
|
|
|
{param for cmd in self.categories.values() for param in cmd.parameters}
|
|
|
|
)
|
2023-02-18 22:25:51 +01:00
|
|
|
|
|
|
|
@property
|
2023-04-16 01:36:10 +02:00
|
|
|
def settings(self) -> Dict[str, HonParameter]:
|
2023-05-06 16:07:28 +02:00
|
|
|
result = {}
|
|
|
|
for command in self.categories.values():
|
|
|
|
for name, parameter in command.parameters.items():
|
|
|
|
if name in result:
|
|
|
|
continue
|
|
|
|
result[name] = parameter
|
|
|
|
return result
|