power: implement timer functionality for gpio devices

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Eric Callahan 2021-10-13 19:10:45 -04:00
parent 2836600857
commit 838b25d288
1 changed files with 17 additions and 0 deletions

View File

@ -407,6 +407,12 @@ class GpioDevice(PowerDevice):
def __init__(self, config: ConfigHelper): def __init__(self, config: ConfigHelper):
super().__init__(config) super().__init__(config)
self.initial_state = config.getboolean('initial_state', False) self.initial_state = config.getboolean('initial_state', False)
self.timer: Optional[float] = config.getfloat('timer', None)
if self.timer is not None and self.timer < 0.000001:
raise config.error(
f"Option 'timer' in section [{config.get_name()}] must "
"be above 0.0")
self.timer_handle: Optional[asyncio.TimerHandle] = None
def configure_line(self, def configure_line(self,
config: ConfigHelper, config: ConfigHelper,
@ -460,6 +466,9 @@ class GpioDevice(PowerDevice):
pass pass
def set_power(self, state) -> None: def set_power(self, state) -> None:
if self.timer_handle is not None:
self.timer_handle.cancel()
self.timer_handle = None
try: try:
self.line.set_value(int(state == "on")) self.line.set_value(int(state == "on"))
except Exception: except Exception:
@ -468,9 +477,17 @@ class GpioDevice(PowerDevice):
logging.exception(msg) logging.exception(msg)
raise self.server.error(msg) from None raise self.server.error(msg) from None
self.state = state self.state = state
if self.state == "on" and self.timer is not None:
event_loop = self.server.get_event_loop()
power: PrinterPower = self.server.lookup_component("power")
self.timer_handle = event_loop.delay_callback(
self.timer, power.set_device_power, self.name, "off")
def close(self) -> None: def close(self) -> None:
self.line.release() self.line.release()
if self.timer_handle is not None:
self.timer_handle.cancel()
self.timer_handle = None
class RFDevice(GpioDevice): class RFDevice(GpioDevice):