From c5a85e1033ac4af1cf200a9f61f8fca2ec8f1b6f Mon Sep 17 00:00:00 2001 From: JJ DORMARD Date: Thu, 31 Dec 2020 16:12:54 +0100 Subject: [PATCH] Added new branch, to be used with 433MHz-driven heaters --- plugin.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/plugin.py b/plugin.py index 7adceb8..5682248 100644 --- a/plugin.py +++ b/plugin.py @@ -5,6 +5,10 @@ http://www.antor.fr/apps/smart-virtual-thermostat-eng-2/?lang=en https://github.com/AntorFr/SmartVT Version: 0.4.10 (November 25, 2020) - see history.txt for versions history + +Branch to be used with 433MHz-driven heaters: +- Inverts the ON/OFF order (Simple 433MHz switch on pilot wire gives inverted order) +- Sends the switching orders even if the state of the switch hasn't changed. This is to prevent locking situations when one order was missed (heater remains stuck ON or OFF) """ """ @@ -430,7 +434,7 @@ def switchHeat(self, switch): idx = int(device["idx"]) if idx in self.Heaters: # this switch is one of our heaters if "Status" in device: - switches[idx] = True if device["Status"] == "On" else False + switches[idx] = True if device["Status"] == "Off" else False # Order inverted ! Domoticz.Debug("Heater switch {} currently is '{}'".format(idx, device["Status"])) else: Domoticz.Error("Device with idx={} does not seem to be a switch !".format(idx)) @@ -442,10 +446,10 @@ def switchHeat(self, switch): # flip on / off as needed self.heat = switch - command = "On" if switch else "Off" + command = "On" if not(switch) else "Off" # Order inverted ! Domoticz.Debug("Heating '{}'".format(command)) for idx in self.Heaters: - if switches[idx] != switch: # check if action needed + if True: # Always send order to the heater. This is to prevent lockup with non-acknowledged systems DomoticzAPI("type=command¶m=switchlight&idx={}&switchcmd={}".format(idx, command)) if switch: Domoticz.Debug("End Heat time = " + str(self.endheat))