2023-08-03 20:43:41 +02:00
|
|
|
import logging
|
|
|
|
|
|
|
|
|
|
|
|
class base(dict):
|
|
|
|
"""A base device for all devicetypes
|
|
|
|
|
|
|
|
Args:
|
|
|
|
mqtt_client (mqtt.mqtt_client): A MQTT Client instance
|
|
|
|
topic (str): the base topic for this device
|
|
|
|
"""
|
|
|
|
PROPERTIES = []
|
|
|
|
|
2023-10-22 20:13:18 +02:00
|
|
|
def __init__(self, mqtt_client, topic):
|
2023-08-03 20:43:41 +02:00
|
|
|
super().__init__()
|
|
|
|
self.mqtt_client = mqtt_client
|
|
|
|
self.topic = topic
|
|
|
|
#
|
|
|
|
self.logger = logging.getLogger('devices')
|
|
|
|
for entry in self.topic.split('/'):
|
|
|
|
self.logger = self.logger.getChild(entry)
|
2023-10-22 20:13:18 +02:00
|
|
|
#
|
|
|
|
self.__power_on_inst__ = []
|
2023-08-03 20:43:41 +02:00
|
|
|
|
|
|
|
def __set__(self, key, data):
|
|
|
|
if key in self.PROPERTIES:
|
|
|
|
self.logger.debug("Setting new property %s to %s", key, repr(data))
|
|
|
|
self[key] = data
|
|
|
|
else:
|
|
|
|
self.logger.warning("Ignoring unsupported property %s", key)
|
2023-10-22 20:13:18 +02:00
|
|
|
|
|
|
|
def power_on(self):
|
|
|
|
for i in self.__power_on_inst__:
|
|
|
|
i.power_on_action()
|
|
|
|
|
|
|
|
def register_power_on_instance(self, inst):
|
|
|
|
if inst not in self.__power_on_inst__:
|
|
|
|
self.__power_on_inst__.append(inst)
|
|
|
|
|
|
|
|
def power_on_action(self):
|
|
|
|
pass
|