Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Skript LOWBAT

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Skript LOWBAT

    This topic has been deleted. Only users with topic management privileges can see it.
    • D
      Dice19 last edited by

      Kann ich die Anzahl der Lichter reduzieren um 1 ?

      Bei mir zählt er einen Zwischenstecker mit Messfunktion als Licht mit…

      Danke

      Tobias

      1 Reply Last reply Reply Quote 0
      • T
        tempestas last edited by

        Eventuell habe ich es übersehen aber als In fo:

        Bei Homematic IP heißt der state nicht mehr "LOWBAT" sondern LOW_BAT

        müsste man also im Skript noch ein weiteres

           cacheSelectorLOW_BAT.each(function (id, i) {                         // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP
              var status = getState(id).val;                                  // Zustand *.LOW_BAT abfragen (jedes Element)
              var obj    = getObject(id);
              if (status === true) {                                          // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                 textLOWBAT.push(obj.common.name);                           // Zu Array hinzufügen
              }       
        
        

        einsetzen sowie entsprechend den "on" function noch ergänzen

        Nachtrag:

        wenn ich das Skript von der HP so einsetze, ergibt sich etwas nicht logsiches im Log:

        > javascript.0 script.js.common.Batteriestatus: Anzahl Geräte: 0 # davon LOWBAT erkannt: 38

        ich glaube, im Skript muss es nicht heißen:

              ++anzahlLOWBAT;   
        

        sondern:

              ++moeglicheLOWBAT;   
        
        1 Reply Last reply Reply Quote 0
        • N
          noxx last edited by

          funktioniert das skript bei jedem sensor?

          ich verstehe hier nicht den Zusammenhang zwischen Lichter und Batteriestatus (LOWBAT)! :?

          ich möchte mir zb den Batteriestatus von folgenden Geräten anzueigen:

          rflink.0.channels.Cresta_4.BAT

          false
          2880_1.png

          1 Reply Last reply Reply Quote 0
          • P
            pix last edited by

            Hallo,

            es gibt keinen Zusammenhang zwischen Lichtern und Batteriestatus. Man kan eben alle gleichnamigen Datenpunkte mit bestimmten Wert zählen. Lichter haben häufig den Datenpunkt STATE (=true wenn an) und sind zB dem Gewerk "Lichter" zugeordnet, der Batteriestatus eines Gerätes ist häufig LOWBAT. Wenn du nur BAT zählen willst, dann brauchst du das Skript nur minimal abwandeln (LOWBAT zu BAT)

            Gruß

            Pix

            1 Reply Last reply Reply Quote 0
            • N
              noxx last edited by

              es reicht Zeile 4 anzupassen?

              ! ````
              createState('zählenLowbat.möglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
              createState('zählenLowbat.anzahlLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
              createState('zählenLowbat.textLOWBAT', " "); // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
              ! var cacheSelectorLOWBAT = $('channel[state.id=*.BAT]');
              ! function countLowbat(obj) {
              // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
              var moeglicheLOWBAT = 0;
              var anzahlLOWBAT = 0;
              var textLOWBAT = [];
              ! if (obj) {
              log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
              } else {
              log('Ausgelöst bei Timer');
              }
              ! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
              var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
              var obj = getObject(id);
              if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
              textLOWBAT.push(obj.common.name); // Zu Array hinzufügen
              }
              log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
              ++anzahlLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
              });
              ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
              log("Text: " + textLOWBAT);
              log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " + anzahlLOWBAT);
              ! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
              setState("zählenLowbat.textLOWBAT", textLOWBAT.join(',
              ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
              setState("zählenLowbat.anzahlLOWBAT", textLOWBAT.length); // Schreibt die aktuelle Anzahl der Geräte im System
              setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT); // Schreibt die aktuelle Anzahl der vorhandene Geräte
              }
              ! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung . LOWBAT in allen Gewerken
              countLowbat(obj);
              });
              schedule("
              /60 * * * *", function () { //oder!! soll entweder ausgelöst werden alle 10 Minuten
              log("===>Will be triggered every 60 minutes!");
              countLowbat();
              });

              1 Reply Last reply Reply Quote 0
              • P
                pix last edited by

                Yep! Sollte reichen.

                Klappt es?

                1 Reply Last reply Reply Quote 0
                • N
                  noxx last edited by

                  weiß ich noch nicht….

                  08:57:45.984	[info]	javascript.0 Start javascript script.js.common.Batteriestatus
                  08:57:45.985	[info]	javascript.0 script.js.common.Batteriestatus: registered 4 subscriptions and 1 schedule
                  09:00:01.013	[info]	javascript.0 script.js.common.Batteriestatus: ===>Will be triggered every 60 minutes!
                  09:00:01.015	[info]	javascript.0 script.js.common.Batteriestatus: Ausgelöst bei Timer
                  09:00:01.015	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 0: Cresta_ 1 Low battery: false
                  09:00:01.016	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 1: Cresta_ 2 Low battery: false
                  09:00:01.016	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 2: Cresta_ 4 Low battery: false
                  09:00:01.016	[info]	javascript.0 script.js.common.Batteriestatus: Geräte Nr. 3: Cresta_ 5 Low battery: false
                  09:00:01.017	[info]	javascript.0 script.js.common.Batteriestatus: Text:
                  09:00:01.017	[info]	javascript.0 script.js.common.Batteriestatus: Anzahl Geräte: 0 # davon LOWBAT erkannt: 4
                  

                  Wie binde ich denn zb eine Benachrichtigung per pushover ein, wenn eine Batterie leer ist?

                  EDIT

                  Mich verwirren die letzten beiden LOG Zeilen

                  09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Text:
                  09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Anzahl Geräte: 0 # davon LOWBAT erkannt: 4
                  

                  Zeile 1 ist nach "Text:" leer

                  Zeile 2 hätte ich jetzt eher "Anzahl Geräte: 4" und "LOWBAT erkannt: 0" erwartet. Also 4 Geräte gefunden und keine Batterie leer.

                  1 Reply Last reply Reply Quote 0
                  • T
                    tempestas last edited by

                    @noxx:

                    Mich verwirren die letzten beiden LOG Zeilen

                    09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Text:
                    09:00:01.017   [info]   javascript.0 script.js.common.Batteriestatus: Anzahl Geräte: 0 # davon LOWBAT erkannt: 4
                    

                    Zeile 1 ist nach "Text:" leer

                    Zeile 2 hätte ich jetzt eher "Anzahl Geräte: 4" und "LOWBAT erkannt: 0" erwartet. Also 4 Geräte gefunden und keine Batterie leer. `

                    Hallo noxx,

                    schau mal 6 Beiträge weiter oben. Dort habe ich genau das angemerkt und korrigiert. Ist ein Dreher im Skript von der Homepage.

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

                      @tempestas:

                      Ist ein Dreher im Skript von der Homepage. `
                      Stimmt, war einer meiner ersten Versuche in Javascript. Hier die Korrektur:

                      ! ````
                      createState('zählenLowbat.möglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
                      createState('zählenLowbat.anzahlLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
                      createState('zählenLowbat.textLOWBAT', " "); // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
                      ! var cacheSelectorLOWBAT = $('channel[state.id=*.LOWBAT]');
                      ! function countLowbat(obj) {
                      // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                      var moeglicheLOWBAT = 0;
                      var textLOWBAT = [];
                      ! if (obj) {
                      log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                      } else {
                      log('Ausgelöst bei Timer');
                      }
                      ! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                      var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                      var obj = getObject(id);
                      if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                      textLOWBAT.push(obj.common.name); // Zu Array hinzufügen
                      }
                      log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                      ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                      });
                      ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                      log("Text: " + textLOWBAT.join(', '));
                      log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " + textLOWBAT.length);
                      ! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                      setState("zählenLowbat.textLOWBAT", textLOWBAT.join(',
                      ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
                      setState("zählenLowbat.anzahlLOWBAT", textLOWBAT.length); // Schreibt die aktuelle Anzahl der Geräte im System
                      setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT); // Schreibt die aktuelle Anzahl der vorhandene Geräte
                      }
                      ! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung . LOWBAT in allen Gewerken
                      countLowbat(obj);
                      });
                      schedule("
                      /60 * * * *", function () { //oder!! soll entweder ausgelöst werden alle 10 Minuten
                      countLowbat();
                      });

                      1 Reply Last reply Reply Quote 0
                      • S
                        starfish last edited by

                        ist zwar trivial, aber auf Zeile 29 fehlt ein ")"

                           log("Text: " + textLOWBAT.join(', '));
                        
                        1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 last edited by

                          @starfish:

                          auf Zeile 29 fehlt ein ") `
                          Danke, ist korrigiert.

                          1 Reply Last reply Reply Quote 0
                          • kmxak
                            kmxak Most Active last edited by

                            bekomme teilweise paar fehler:

                            javascript.0	2017-10-07 11:00:00.731	error	at script.js.User.Homematic.Batterie_Check:24:51
                            javascript.0	2017-10-07 11:00:00.731	error	Error in callback: TypeError: Cannot read property 'common' of null
                            javascript.0	2017-10-07 11:00:00.730	warn	Object "hm-rpc.3.NEQ0000566.0.LOWBAT" does not exist
                            javascript.0	2017-10-07 11:00:00.730	warn	Object "hm-rpc.3.NEQ0000566.0.LOWBAT" does not exist
                            javascript.0	2017-10-07 11:00:00.730	warn	at script.js.User.Homematic.Batterie_Check:19:20
                            javascript.0	2017-10-07 11:00:00.729	warn	State "hm-rpc.3.NEQ0000566.0.LOWBAT" not found
                            javascript.0	2017-10-07 11:00:00.729	info	script.js.User.Homematic.Batterie_Check: Geräte Nr. 35: undefined: null
                            javascript.0	2017-10-07 11:00:00.729	warn	at script.js.User.Homematic.Batterie_Check:19:20
                            javascript.0	2017-10-07 11:00:00.729	warn	State "hm-rpc.2.OEQ0181147.0.LOWBAT" not found
                            
                            1 Reply Last reply Reply Quote 0
                            • T
                              tempestas last edited by

                              Sind das homematic Ip Geräte?

                              Die haben als Datenpunkt Low_Bat nicht Lowbat.

                              Steht hier imho auch schon im thread in einem meiner Postings

                              Edit:

                              Jup, eine Seite weiter vorne… War nicht schwer zu finden

                              1 Reply Last reply Reply Quote 0
                              • kmxak
                                kmxak Most Active last edited by

                                ein fertiges Script gibt es aber noch nicht?

                                Das sind ja nur die Warnungen

                                Der Error kommt von dem CuxD Gerät

                                1 Reply Last reply Reply Quote 0
                                • T
                                  tempestas last edited by

                                  Was steht denn in Zeile 24 bei dir im Skript.

                                  Zum Thema "ein fertiges Skript gibts nicht?":

                                  doch, hier im Thread. Für Homematic IP einfach ergänzen, wie es auf der Vorseite dargestellt ist

                                  1 Reply Last reply Reply Quote 0
                                  • kmxak
                                    kmxak Most Active last edited by

                                             textLOWBAT.push(obj.common.name);                           // Zu Array hinzufügen
                                          }                
                                          log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                          ++moeglicheLOWBAT;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                       }); 
                                    

                                    24 in der Mitte.

                                    ich wusste gestern nicht wo hin mit der ergänzung

                                    hier das angepasste script weiß aber nicht ob das richtig ist und das mit der on änderung weiß ich nicht wie.

                                    ! ````
                                    createState('zählenLowbat.möglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
                                    createState('zählenLowbat.anzahlLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
                                    createState('zählenLowbat.textLOWBAT', " "); // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
                                    ! var cacheSelectorLOWBAT = $('channel[state.id=*.LOWBAT]');
                                    ! function countLowbat(obj) {
                                    // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                    var moeglicheLOWBAT = 0;
                                    var textLOWBAT = [];
                                    ! if (obj) {
                                    log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                    } else {
                                    log('Ausgelöst bei Timer');
                                    }
                                    ! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                    var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                    var obj = getObject(id);
                                    if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                    textLOWBAT.push(obj.common.name); // Zu Array hinzufügen
                                    }
                                    log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                    ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                    });
                                    cacheSelectorLOW_BAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP
                                    var status = getState(id).val; // Zustand *.LOW_BAT abfragen (jedes Element)
                                    var obj = getObject(id);
                                    if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                    textLOWBAT.push(obj.common.name); // Zu Array hinzufügen
                                    }
                                    log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                    ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                    });
                                    ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                    log("Text: " + textLOWBAT.join(', '));
                                    log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " + textLOWBAT.length);
                                    ! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                                    setState("zählenLowbat.textLOWBAT", textLOWBAT.join(',
                                    ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
                                    setState("zählenLowbat.anzahlLOWBAT", textLOWBAT.length); // Schreibt die aktuelle Anzahl der Geräte im System
                                    setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT); // Schreibt die aktuelle Anzahl der vorhandene Geräte
                                    }
                                    ! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung . LOWBAT in allen Gewerken
                                    countLowbat(obj);
                                    });
                                    schedule("
                                    /60 * * * *", function () { //oder!! soll entweder ausgelöst werden alle 10 Minuten
                                    countLowbat();
                                    });

                                    1 Reply Last reply Reply Quote 0
                                    • T
                                      tempestas last edited by

                                      Also bei mir heißen CUXD nicht z.B. NEQ….. oder OEQ..

                                      das sollten schon "echte" HM Geräte sein imho

                                      ! ````
                                      createState('zählenLowbat.möglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen Geräte
                                      createState('zählenLowbat.anzahlLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
                                      createState('zählenLowbat.textLOWBAT', " "); // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
                                      ! var cacheSelectorLOWBAT = $('channel[state.id=.LOWBAT]');
                                      var cacheSelectorLOW_BAT = $('channel[state.id=
                                      .LOW_BAT]'); // für Homematic IP, dort LOWBAT in LOW_BAT umbenannt
                                      ! function countLowbat(obj) {
                                      // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0
                                      var moeglicheLOWBAT = 0;
                                      var anzahlLOWBAT = 0;
                                      var textLOWBAT = [];
                                      ! if (obj) {
                                      log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
                                      } else {
                                      log('Ausgelöst bei Timer');
                                      }
                                      ! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
                                      var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)
                                      var obj = getObject(id);
                                      if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                      textLOWBAT.push(obj.common.name); // Zu Array hinzufügen
                                      }
                                      log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                      ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                      });
                                      ! cacheSelectorLOW_BAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP
                                      var status = getState(id).val; // Zustand *.LOW_BAT abfragen (jedes Element)
                                      var obj = getObject(id);
                                      if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                      textLOWBAT.push(obj.common.name); // Zu Array hinzufügen
                                      }
                                      log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                      ++moeglicheLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                      });
                                      ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                                      log("Text: " + textLOWBAT);
                                      log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " + anzahlLOWBAT);
                                      ! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                                      setState("zählenLowbat.textLOWBAT", textLOWBAT.join(',
                                      ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
                                      setState("zählenLowbat.anzahlLOWBAT", textLOWBAT.length); // Schreibt die aktuelle Anzahl der Geräte im System
                                      setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT); // Schreibt die aktuelle Anzahl der vorhandene Geräte
                                      }
                                      ! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken
                                      countLowbat(obj);
                                      });
                                      ! cacheSelectorLOW_BAT.on(function(obj) { // bei Zustandänderung *. LOW_BAT in allen Gewerken
                                      countLowbat(obj);
                                      });
                                      ! schedule("0 */6 * * *", function () { //ausgelöst alle 6 Stunden
                                      countLowbat();
                                      });

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

                                        Die Variable anzahlLOWBAT wird nicht aktualisiert. Ersetze sie bitte durch textLOWBAT.length.

                                           log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " +  textLOWBAT.length);
                                        
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • T
                                          tempestas last edited by

                                          stimmt, dürfte aber nur fürs Log relevant sein. Die state wird ja direkt durch .length gesetzt

                                          1 Reply Last reply Reply Quote 0
                                          • D
                                            dali3 last edited by

                                            Anfängerfrage:

                                            Was müsste ich Script angepasst werden, falls dies ohne CCU2 etc. läuft?

                                            (Siehe meinen anderen Thread: http://forum.iobroker.net/viewtopic.php … 40#p107442)

                                            (Dito für Lichter, Fenster sowie Lowbat)

                                            Vielen Dank für eure Hilfe im Voraus.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            784
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            44
                                            201
                                            39742
                                            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