diff options
author | Maxim Devaev <[email protected]> | 2021-09-08 05:43:36 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2021-09-08 05:43:36 +0300 |
commit | 98ad1145a8782d3b82516dd9f81c86d9e80391c5 (patch) | |
tree | b8f348f0815e8ee72236bf9879af779c95727755 /kvmd/plugins/ugpio/tesmart.py | |
parent | 939c63fe7daf2ddc9a05c9e0fbeab63cb5c6f0c1 (diff) |
string pins
Diffstat (limited to 'kvmd/plugins/ugpio/tesmart.py')
-rw-r--r-- | kvmd/plugins/ugpio/tesmart.py | 24 |
1 files changed, 11 insertions, 13 deletions
diff --git a/kvmd/plugins/ugpio/tesmart.py b/kvmd/plugins/ugpio/tesmart.py index 7fbd37db..27cf0038 100644 --- a/kvmd/plugins/ugpio/tesmart.py +++ b/kvmd/plugins/ugpio/tesmart.py @@ -24,7 +24,9 @@ import asyncio from typing import Tuple from typing import Dict +from typing import Callable from typing import Optional +from typing import Any from ...logging import get_logger @@ -33,6 +35,7 @@ from ... import aiotools from ...yamlconf import Option +from ...validators.basic import valid_number from ...validators.basic import valid_float_f0 from ...validators.basic import valid_float_f01 from ...validators.net import valid_ip_or_host @@ -79,15 +82,9 @@ class Plugin(BaseUserGpioDriver): # pylint: disable=too-many-instance-attribute "state_poll": Option(10.0, type=valid_float_f01), } - def register_input(self, pin: int, debounce: float) -> None: - if not (0 <= pin < 16): - raise RuntimeError(f"Unsupported port number: {pin}") - _ = debounce - - def register_output(self, pin: int, initial: Optional[bool]) -> None: - if not (0 <= pin < 16): - raise RuntimeError(f"Unsupported port number: {pin}") - _ = initial + @classmethod + def get_pin_validator(cls) -> Callable[[Any], str]: + return (lambda arg: str(valid_number(arg, min=0, max=15, name="Tesmart channel"))) async def run(self) -> None: prev_active = -2 @@ -104,12 +101,13 @@ class Plugin(BaseUserGpioDriver): # pylint: disable=too-many-instance-attribute async def cleanup(self) -> None: await self.__close_device() - async def read(self, pin: int) -> bool: - return (self.__active == pin) + async def read(self, pin: str) -> bool: + return (self.__active == int(pin)) - async def write(self, pin: int, state: bool) -> None: + async def write(self, pin: str, state: bool) -> None: + assert 0 <= pin <= 15 if state: - await self.__send_command("{:c}{:c}".format(1, pin + 1).encode()) + await self.__send_command("{:c}{:c}".format(1, int(pin) + 1).encode()) await self.__update_notifier.notify() await asyncio.sleep(self.__switch_delay) # Slowdown |