Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Skript für Bluetooth-Heizkörperthermostat unter IoBroker

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Skript für Bluetooth-Heizkörperthermostat unter IoBroker

    This topic has been deleted. Only users with topic management privileges can see it.
    • Dutchman
      Dutchman Developer Most Active Administrators last edited by

      Setze Mal den Haken bei mit Ergebnis und Dan darunter einen debug Block mit der Variable result

      Sent from my iPhone using Tapatalk

      1 Reply Last reply Reply Quote 0
      • G
        gato last edited by

        hier das Logfile aus ioBroker…

        In Putty (siehe Bild mit schwarzem Hintergrund) kann ich das Skript so ausführen und die Verbindung zum Thermostat funktioniert. Er gibt sogar die Rückmeldung, das er den Wert gesetzt hat.
        8651_debug.jpg
        8651_putty.jpg

        1 Reply Last reply Reply Quote 0
        • K
          Karl_999 last edited by

          Ich sehe da noch immer keine Ausgabe des Aufrufs bzw. eine Erfolgsmeldung.

          Hänge doch bitte an den Aufruf noch ein

           >>\tmp\script.log 
          

          an (mit Leerzeichen vor dem >>).

          Das schreibt die Ausgabe dann in die angegebene Datei (wenn die Berechtigungen passen).

          1 Reply Last reply Reply Quote 0
          • G
            gato last edited by

            hinter welchen Aufruf soll das " >>\tmp\script.log" geschreiben werden?

            ./eQ-3-radiator-thermostat/eq3.exp <macadresse>temp 20.0 >>\tmp\script.log</macadresse>

            1 Reply Last reply Reply Quote 0
            • G
              gato last edited by

              Hallo zusammen,

              wie kann ich mit der Fehlersuche weitermachen?

              @ Karl_999: hinter welchen Aufruf schreibe ich " >>\tmp\script.log" ?

              Und wie kann ich dann dieses Logfile einsehen?

              Vielen Dank für eure Hilfe.

              1 Reply Last reply Reply Quote 0
              • G
                gato last edited by

                Was ich zwischenzeitlich herausgefunden habe, ist dass es definitiv am Pfad bzw. an dem spez. Befehl liegt.

                Meine Gegenprobe mit dem Befehl: wall "test" funktionierte mit dem gleichen Blockly Aufbau.

                Weis jemand von euch wie ich den Pfad "./eQ-3-radiator-thermostat/eq3.exp <macadresse>temp 20.0" anpassen muss, damit er mit iobroker kompatibel ist?</macadresse>

                1 Reply Last reply Reply Quote 0
                • K
                  kr4mb3 last edited by kr4mb3

                  @DennisK:

                  Weis jemand von euch wie ich den Pfad "./eQ-3-radiator-thermostat/eq3.exp <macadresse>temp 20.0" anpassen muss, damit er mit iobroker kompatibel ist?</macadresse> `

                  Ich habe mich die Tage auch mal mit dem Thermostat beschäftigt und mir basierend auf dem Code von Heckie75 ein Skript in ioBroker geschrieben, dass mir auch ein paar Datenpunkte erstellt. Sicherlich nicht der schönste Code, aber es funktioniert. Ich habe den Pfad zur eq3.exp-Datei absolut angegeben, damit ich den Code verwenden kann:

                  /*
                   script needs Heckie75/eQ-3-radiator-thermostat package.
                   see https://github.com/Heckie75/eQ-3-radiator-thermostat
                   thermostat must be paired via bluetooth 
                   exec command must be enabled in javascript adapter
                  */
                  
                  //Absolute Path to eQ-3-radiator-thermostat package and MAC of paired eQ3 thermostat
                  var eQ3 = "/home/pi/eQ-3-radiator-thermostat/eq3.exp";
                  var mac = "00:1A:22:0C:08:3E";
                  
                  //new iobroker states
                  createState('eQ3.control.boostOn', false, {type: "boolean", role: "button"});
                  createState('eQ3.control.boostOff', false, {type: "boolean", role: "button"});
                  createState('eQ3.control.boostSwitch', false, {type: "boolean", role: "switch"});
                  createState('eQ3.control.getStatus', false, {type: "boolean", role: "button"});
                  createState('eQ3.control.setMode', false, {max: 1, min: 0, states: {0:"auto",1:"manual"}});
                  createState('eQ3.control.setTemp');
                  createState('eQ3.control.setOffset');
                  createState('eQ3.control.command');
                  
                  createState('eQ3.status.Temperature');
                  createState('eQ3.status.Valve');
                  createState('eQ3.status.Mode');
                  createState('eQ3.status.VacationMode');
                  createState('eQ3.status.LowBattery');
                  createState('eQ3.status.OpenWindow');
                  createState('eQ3.status.Boost');
                  createState('eQ3.status.Locked');
                  createState('eQ3.status.OffsetTemp');
                  
                  createState('eQ3.device.MAC');
                  createState('eQ3.device.Name');
                  createState('eQ3.device.Vendor');
                  
                  createState('eQ3.timer.timerJSON');
                  
                  //Exec-Befehl
                  var eQ3exec = eQ3 + ' ' + mac + ' ';
                  
                  //Status
                  on({id: 'javascript.0.eQ3.control.getStatus', val: true}, function (obj) {
                      exec(eQ3exec + "status", function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });
                  });
                  
                  //Boost On
                  on({id: 'javascript.0.eQ3.control.boostOn', val: true}, function (obj) {
                       exec(eQ3exec + "boost", function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });
                  });
                  
                  //Boost Off
                  on({id: 'javascript.0.eQ3.control.boostOff', val: true}, function (obj) {
                       exec(eQ3exec + "boost off", function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });    
                  });
                  
                  //Boost Switch
                  on({id: 'javascript.0.eQ3.control.boostSwitch', change: "any"}, function (obj) {
                      var value = obj.state.val;
                      log (value);
                      if (value === true) {
                          exec(eQ3exec + "boost", function(err, stdout, stderr) {
                              eQ3status(stdout);
                              log ("Boost an");
                          });
                      }else if (value === false){
                          exec(eQ3exec + "boost off", function(err, stdout, stderr) {
                              eQ3status(stdout);
                              log ("Boost aus");
                          });
                      }
                  });
                  
                  //Set Temperature
                  on({id: 'javascript.0.eQ3.control.setTemp', change: "any"}, function (obj) {
                       var value = obj.state.val;
                       exec(eQ3exec + "temp " + value, function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });
                  });
                  
                  //Set Offset
                  on({id: 'javascript.0.eQ3.control.setOffset', change: "any"}, function (obj) {
                      var value = obj.state.val;
                      exec(eQ3exec + "offset " + value, function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });
                  });
                  
                  //Set Mode
                  on({id: 'javascript.0.eQ3.control.setMode', change: "any"}, function (obj) {
                       var value = obj.state.val;
                       if (value === 0) {
                          exec(eQ3exec + "auto", function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });
                       } else if (value === 1){
                            exec(eQ3exec + "manual", function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });
                       }
                  });
                  
                  //Custom Command
                  on({id: 'javascript.0.eQ3.control.command', change: "any"}, function (obj) {
                    var value = obj.state.val;
                    exec(eQ3exec + value, function(err, stdout, stderr) {
                           eQ3status(stdout);
                       });
                  });
                  
                  
                  
                  //Thermostat Status
                  function eQ3status(stdout) {
                      eQ3json();
                      
                          stdout = stdout.split("\n");
                          stdout.forEach(element => {
                      
                              switch(element.split(":")[0]){
                                  /*
                                  case "Temperature":
                                      setState('eQ3.status.Temperature', element.split(":")[1].trim());
                                      break;
                                  case "Valve":
                                      setState('eQ3.status.Valve', element.split(":")[1].trim());
                                      break;
                                  */
                                  case "Mode":
                                      setState('eQ3.status.Mode', element.split(":")[1].trim());
                                      break;
                                  case "Vacation mode":
                                      setState('eQ3.status.VacationMode', element.split(":")[1].trim());
                                      break;
                                  case "Offset temperature":
                                      setState('eQ3.status.OffsetTemp', element.split(":")[1].trim());
                                      break;
                                  case "Device name":
                                      setState('eQ3.device.Name', element.split(":")[1].trim());
                                      break;
                                  case "Device vendor":
                                      setState('eQ3.device.Vendor', element.split(":")[1].trim());
                                      break;
                                  case "":
                                      break;
                              }
                          });
                  }
                  
                  
                  //Thermostat Status JSON
                  function eQ3json(){
                      exec(eQ3exec + "json", function(err, stdout, stderr) {
                          obj = JSON.parse(stdout);
                          
                          //Status
                          setState('eQ3.status.LowBattery', obj.mode["low battery"]);
                          setState('eQ3.status.OpenWindow', obj.mode["open window"]);
                          setState('eQ3.status.Boost', obj.mode.boost);
                          setState('eQ3.status.Locked', obj.mode.locked);
                          setState('eQ3.status.Valve', obj.valve);
                          setState('eQ3.status.Temperature', obj.temperature);
                          
                          //Device
                          setState('eQ3.device.MAC', obj.mac);
                          
                          //Timer
                          setState('eQ3.timer.timerJSON', JSON.stringify(obj.timers));
                      });
                  }
                  
                  schedule('*/2 * * * *', function (obj) {
                      exec(eQ3exec + "status", function(err, stdout, stderr) {
                           eQ3status(stdout);
                      });
                  });
                  

                  Noch habe ich nicht alle Funktionen des Skripts von Heckie75 umgesetzt, aber mehr brauch ich aktuell nicht. Die Basissteuerung und die Abfrage des Status (alle 2 Minuten) reicht mir bisher. Vielleicht hilft dir oder anderen das ja als Vorlage.

                  Greetz

                  kr4mb3

                  1 Reply Last reply Reply Quote 0
                  • Matzebhv
                    Matzebhv last edited by

                    @DennisK:

                    Was ich zwischenzeitlich herausgefunden habe, ist dass es definitiv am Pfad bzw. an dem spez. Befehl liegt.

                    Meine Gegenprobe mit dem Befehl: wall "test" funktionierte mit dem gleichen Blockly Aufbau.

                    Weis jemand von euch wie ich den Pfad "./eQ-3-radiator-thermostat/eq3.exp <macadresse>temp 20.0" anpassen muss, damit er mit iobroker kompatibel ist?</macadresse> `

                    Laut deinem Screenshot liegt das Script im Homedir von root.

                    "/root/eQ-3-radiator-thermostat/eq3.exp <macadresse>temp 20.0"

                    Gruß

                    Matze</macadresse>

                    1 Reply Last reply Reply Quote 0
                    • O
                      oemer9119 last edited by

                      @kr4mb3:

                      @DennisK:

                      Weis jemand von euch wie ich den Pfad "./eQ-3-radiator-thermostat/eq3.exp <macadresse>temp 20.0" anpassen muss, damit er mit iobroker kompatibel ist?</macadresse> `

                      Ich habe mich die Tage auch mal mit dem Thermostat beschäftigt und mir basierend auf dem Code von Heckie75 ein Skript in ioBroker geschrieben, dass mir auch ein paar Datenpunkte erstellt. Sicherlich nicht der schönste Code, aber es funktioniert. Ich habe den Pfad zur eq3.exp-Datei absolut angegeben, damit ich den Code verwenden kann:

                      ! ````
                      /*
                      script needs Heckie75/eQ-3-radiator-thermostat package.
                      see https://github.com/Heckie75/eQ-3-radiator-thermostat
                      thermostat must be paired via bluetooth
                      exec command must be enabled in javascript adapter
                      */
                      ! //Absolute Path to eQ-3-radiator-thermostat package and MAC of paired eQ3 thermostat
                      var eQ3 = "/home/pi/eQ-3-radiator-thermostat/eq3.exp";
                      var mac = "00:00:00:00:00:00";
                      ! //new iobroker states
                      createState('eQ3.control.boostOn', false, {type: "boolean", role: "button"});
                      createState('eQ3.control.boostOff', false, {type: "boolean", role: "button"});
                      createState('eQ3.control.getStatus', false, {type: "boolean", role: "button"});
                      createState('eQ3.control.setMode', false, {max: 1, min: 0, states: {0:"auto",1:"manual"}});
                      createState('eQ3.control.setTemp');
                      createState('eQ3.control.setOffset');
                      createState('eQ3.control.command');
                      ! createState('eQ3.status.Temperature');
                      createState('eQ3.status.Valve');
                      createState('eQ3.status.Mode');
                      createState('eQ3.status.VacationMode');
                      createState('eQ3.status.LowBattery');
                      createState('eQ3.status.OpenWindow');
                      createState('eQ3.status.Boost');
                      createState('eQ3.status.Locked');
                      createState('eQ3.status.OffsetTemp');
                      ! createState('eQ3.device.MAC');
                      createState('eQ3.device.Name');
                      createState('eQ3.device.Vendor');
                      ! createState('eQ3.timer.timerJSON');
                      ! //Exec-Befehl
                      var eQ3exec = eQ3 + ' ' + mac + ' ';
                      ! //Status
                      on({id: 'javascript.0.eQ3.control.getStatus', val: true}, function (obj) {
                      exec(eQ3exec + "status", function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      });
                      ! //Boost On
                      on({id: 'javascript.0.eQ3.control.boostOn', val: true}, function (obj) {
                      exec(eQ3exec + "boost", function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      });
                      ! //Boost Off
                      on({id: 'javascript.0.eQ3.control.boostOff', val: true}, function (obj) {
                      exec(eQ3exec + "boost off", function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      });
                      ! //Set Temperature
                      on({id: 'javascript.0.eQ3.control.setTemp', change: "any"}, function (obj) {
                      var value = obj.state.val;
                      exec(eQ3exec + "temp " + value, function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      });
                      ! //Set Offset
                      on({id: 'javascript.0.eQ3.control.setOffset', change: "any"}, function (obj) {
                      var value = obj.state.val;
                      exec(eQ3exec + "offset " + value, function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      });
                      ! //Set Mode
                      on({id: 'javascript.0.eQ3.control.setMode', change: "any"}, function (obj) {
                      var value = obj.state.val;
                      if (value === 0) {
                      exec(eQ3exec + "auto", function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      } else if (value === 1){
                      exec(eQ3exec + "manual", function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      }
                      });
                      ! //Custom Command
                      on({id: 'javascript.0.eQ3.control.command', change: "any"}, function (obj) {
                      var value = obj.state.val;
                      exec(eQ3exec + value, function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      });
                      ! //Thermostat Status
                      function eQ3status(stdout) {
                      eQ3json();

                          stdout = stdout.split("\n");
                          stdout.forEach(element => {
                      
                              switch(element.split(":")[0]){
                                  case "Temperature":
                                      setState('eQ3.status.Temperature', element.split(":")[1]);
                                      break;
                                  case "Valve":
                                      setState('eQ3.status.Valve', element.split(":")[1]);
                                      break;
                                  case "Mode":
                                      setState('eQ3.status.Mode', element.split(":")[1]);
                                      break;
                                  case "Vacation mode":
                                      setState('eQ3.status.VacationMode', element.split(":")[1]);
                                      break;
                                  case "Offset temperature":
                                      setState('eQ3.status.OffsetTemp', element.split(":")[1]);
                                      break;
                                  case "Device name":
                                      setState('eQ3.device.Name', element.split(":")[1]);
                                      break;
                                  case "Device vendor":
                                      setState('eQ3.device.Vendor', element.split(":")[1]);
                                      break;
                                  case "":
                                      break;
                              }
                          });
                      

                      }

                      ! //Thermostat Status JSON
                      function eQ3json(){
                      exec(eQ3exec + "json", function(err, stdout, stderr) {
                      obj = JSON.parse(stdout);

                          //Status
                          setState('eQ3.status.LowBattery', obj.mode["low battery"]);
                          setState('eQ3.status.OpenWindow', obj.mode["open window"]);
                          setState('eQ3.status.Boost', obj.mode.boost);
                          setState('eQ3.status.Locked', obj.mode.locked);
                          
                          //Device
                          setState('eQ3.device.MAC', obj.mac);
                          
                          //Timer
                          setState('eQ3.timer.timerJSON', JSON.stringify(obj.timers));
                      });
                      

                      }

                      ! schedule('*/5 * * * *', function (obj) {
                      exec(eQ3exec + "status", function(err, stdout, stderr) {
                      eQ3status(stdout);
                      });
                      });
                      ! ````

                      Noch habe ich nicht alle Funktionen des Skripts von Heckie75 umgesetzt, aber mehr brauch ich aktuell nicht. Die Basissteuerung und die Abfrage des Status (alle 5 Minuten) reicht mir bisher. Vielleicht hilft dir oder anderen das ja als Vorlage.

                      Greetz

                      kr4mb3 `

                      Hallo,

                      Kann jemand vielleicht kurz erklären wie der das eingebunden hat mit dem code? Evtl für vis oder den cloud Adapter

                      1 Reply Last reply Reply Quote 0
                      • K
                        kr4mb3 last edited by

                        @oemer9119:

                        Hallo,

                        Kann jemand vielleicht kurz erklären wie der das eingebunden hat mit dem code? Evtl für vis oder den cloud Adapter `

                        Ich habe mir noch einen weiteren State erstellt, der den Boost Modus aktiviert bzw. deaktiviert:

                        createState('eQ3.control.boostSwitch', false, {type: "boolean", role: "switch"});
                        

                        Diese State habe ich dann im Cloud Adapter hinzugefügt, so kann ich per Alexa-Spracheingabe spontan den Boost Modus aktivieren, wenn es mir zu kalt ist. Den Temperaturwert per Cloud-Adapter zu erhöhen wäre auch sehr praktisch, ich habe es allerdings noch nicht hinbekommen, bestimmte absolute Werte zu übergeben, sondern bloß Prozentwerte…

                        In VIS solltest du eigentlich alle States aus dem Skript als Button oder als anderes Objekt einfügen können. Zum Beispiel mit dem hqWidget "Inner Temperature". Dort kann man die Zieltemperatur und den aktuellen Ventilstatus anzeigen. Und wenn du einen Sensor dafür hast, auch die aktuelle Temperatur. Und ein paar Stati aus dem Skript kann man auch als Signalbilder nutzen, zB ob der Boostmodus an ist, die Batterie leer ist oder das Fenster offen ist.

                        Greetz kr4mb3
                        3592_01_widget.png
                        3592_02_signalbilder.png

                        1 Reply Last reply Reply Quote 0
                        • O
                          oemer9119 last edited by

                          Hallo bekommst du werte zurück wenn du getstatus ausführst.

                          Ich bekomme immer ein Fehler.

                          Wenn der Code Läuft kriege ich nicht mal antwort über Putty, aber die Befehle werden trotzdem umgesetzt.

                          > Caught by controller[0]: at script.js.Heizung2:143:51

                          Oder Auch was mit Zeile 140.

                          1 Reply Last reply Reply Quote 0
                          • K
                            kr4mb3 last edited by

                            Hi oemer9119,

                            ja ich bekomme Werte zurück, wenn ich getStatus ausführe. Das passiert in meinem Skript ja in zwei Teilen. Zuerst werden Werte wie Batteriestatus oder Boost über die Funktion "eQ3json" abgerufen, danach der aktuelle Modus, die Temperatur, die Ventil-Stellung und der Name sowie Hersteller des Thermostats über die Funktion "eQ3status". Über Putty sieht der Befehl "status" bei mir zB so aus wie im Anhang.

                            Die Zeile 143 im Skript teilt zB die Zeile "Device Name" am Doppelpunkt, um nur den Namen selbst zu bekommen. Trim entfernt dann noch die ganzen Leerzeichen zwischen Doppelpunkt und dem Namen. Hat dein Thermostat evtl keinen Namen?!

                            Und Zeile 140 ermittelt die Offset Temperatur. Die Zeile im Rückgabewert tritt aber nur auf, wenn man auch den Offset-Wert verändert. Das sollte aber eigentlich keine Fehler aufwerfen. Hast du denn dein Thermostat auch erfolgreich mit dem ioBroker Host per Bluetooth gekoppelt?
                            3592_2019-01-02_22_38_55-window.png
                            3592_2019-01-02_22_53_50-window.png

                            1 Reply Last reply Reply Quote 0
                            • X
                              xatrix last edited by

                              @kr4mb3 said in Skript für Bluetooth-Heizkörperthermostat unter IoBroker:

                              ``

                              Hallo,

                              kannst du bitte das Script neu einbetten? Die Formatierung stimmt nicht mehr.

                              Danke

                              K 1 Reply Last reply Reply Quote 0
                              • K
                                kr4mb3 @xatrix last edited by

                                @xatrix Ist erledigt, ich hab mein aktuelles Skript in meinem Beitrag oben editiert.

                                pat 0 A 2 Replies Last reply Reply Quote 0
                                • P
                                  parabelflug1 last edited by

                                  Moin,
                                  ich häng meine Frage mal dran: Hab eq3.exp auch problemlos am laufen - hab heute aber Xiaomi Bluetooth Thermometer bekommen, sodass ich nun auch den BLE-Adapter installiert habe. Leider scheint sich beides zu beißen - der Javascript Adapter kackt mir mehrmals in der Stunde ab. Er prüft ja alle 30s auf neue Daten von den Thermostaten - vermutlich beißt sich's da.
                                  Wie macht ihr das?

                                  1 Reply Last reply Reply Quote 0
                                  • pat 0
                                    pat 0 @kr4mb3 last edited by pat 0

                                    @kr4mb3

                                    Hi kr4mb3, ich versuche gerade dein eq3 Skript im ioBroker einzubinden. Erstmal vielen Dank, dass du dir die Mühe gemacht hast und dein Skript zur Verfügung stellst. Ich habe deinen Code als Java Script importiert, MAC und Pfad geändert und gestartet. Das eQ3 Objekt und seine Eigenschaften tauchen dann auch in der Objektansicht auf, aktualisieren sich aber nicht.
                                    Auf Befehle reagiert das Thermostat leider auch nicht.

                                    Wenn ich die Heckie Befehle manuell ausführe, läuft es.

                                    Folgende Fehlermeldungen bekomme ich:
                                    25c10166-13d2-4431-9022-ac7083f68f6d-image.png

                                    Ist das Problem bekannt?

                                    Schonmal vielen Dank!

                                    1 Reply Last reply Reply Quote 0
                                    • A
                                      Android @kr4mb3 last edited by Android

                                      @kr4mb3
                                      Hallo Freunde,

                                      vielen Dank für den Skript.
                                      Funktioniert ganz gut.

                                      Meine Frage: hat ihn jemand weiter verbessert?
                                      ToDo:

                                      • Mehrere Thermostate gleichzeitig
                                      • Sicherheit

                                      Zum Punkt "Sicherheit":
                                      Es ist ja jedem klar, dass die Thermostate nicht durch Verschlüsselung geschützt sind. Wünschenswert wäre eine Funktion im Skript, die eine Fremdeinwirkung erkennt und gegensteuert. Umsetzbar wäre dies z.B. durch das Speichern des Status und regelmäßigen Vergleich der Strings. Hat da jemand eine Idee?

                                      1 Reply Last reply Reply Quote 0
                                      • First post
                                        Last post

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      943
                                      Online

                                      31.6k
                                      Users

                                      79.6k
                                      Topics

                                      1.3m
                                      Posts

                                      10
                                      21
                                      3117
                                      Loading More Posts
                                      • Oldest to Newest
                                      • Newest to Oldest
                                      • Most Votes
                                      Reply
                                      • Reply as topic
                                      Log in to reply
                                      Community
                                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                      The ioBroker Community 2014-2023
                                      logo