From 368d051a297bc9bd5377e33afe641a8afaf9479b Mon Sep 17 00:00:00 2001 From: Daniel Klaffenbach Date: Sat, 25 Aug 2018 14:50:41 +0200 Subject: [PATCH] Fix callbacks for channel 0 Events can be fired for entities and channels, so we also need to register callbacks for the HMChannel instance - even on channel 0. This fixes the updating of the `UNREACH` flag, which until now is only updated when reloading pyhomematic. See danielperna84/pyhomematic#121 --- pyhomematic/devicetypes/generic.py | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/pyhomematic/devicetypes/generic.py b/pyhomematic/devicetypes/generic.py index ea456433c..5490deb37 100644 --- a/pyhomematic/devicetypes/generic.py +++ b/pyhomematic/devicetypes/generic.py @@ -59,6 +59,9 @@ def event(self, interface_id, key, value): % (self._ADDRESS, interface_id, key, value)) if key == PARAM_UNREACH: self._unreach = value + if not self._eventcallbacks: + LOG.debug("HMGeneric.event: No callbacks registered for event %s (%s)", key, str(self)) + for callback in self._eventcallbacks: LOG.debug("HMDevice.event: Using callback %s " % str(callback)) callback(self._ADDRESS, interface_id, key, value) @@ -352,9 +355,14 @@ def setEventCallback(self, callback, bequeath=True, channel=0): Signature for callback-functions: foo(address, interface_id, key, value) """ if hasattr(callback, '__call__'): + LOG.debug( + "Adding callback '%s' for %s:%s (%s)", + str(callback), self._name, channel, str(self) + ) + if channel == 0: self._eventcallbacks.append(callback) - elif not bequeath and channel > 0 and channel in self._hmchannels: + if not bequeath and channel in self._hmchannels: self._hmchannels[channel]._eventcallbacks.append(callback) if bequeath: for channel, device in self._hmchannels.items():