Navigation

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

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Ereignisliste erzeugen

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

      Hallo,

      um eine Ereignisliste:
      609_bildschirmfoto_2015-09-06_um_20.46.22.png
      zu erzeugen, kann man folgendes Skript verwenden:

      `createState("vEreignisse","
      
      *   first
      
      ");
      
      var sensorsST = $('channel[state.id=*.STATE](functions=ST)').each(function(id) {
          var val = getObject(id).common.name;
          log("DeviceST=" + val);
      });
      
      var sensorsVS = $('channel[state.id=*.STATE](functions=VS)').each(function(id) {
          var val = getObject(id).common.name;
          log("DeviceVS=" + val);
      });
      
      var sensorsBW = $('channel[state.id=*.MOTION](functions=BW)').each(function(id) {
          var val = getObject(id).common.name;
          log("DeviceBW=" + val);
      });
      
      var vAlarmanlage = $('state[id="hm-rega.0.3747"]').each(function(id) {
          var val = getObject(id).common.name;
          log("Alarmanlage=" + val);
      });
      
      function ereignis(text) {
          log("ereignis "+text);
          var ereignisStr = getState("vEreignisse").val;
          var ereignisArr;
          ereignisArr = ereignisStr.replace(/`
      
      `*   /, "").replace(/<\/li><\/ul>/, "").split("*   ");
              ereignisArr = ereignisArr.reverse();
              ereignisArr.push(text);
              ereignisArr.reverse().splice(99); // Liste auf 20 Einträge beschränken
              var str = ereignisArr.join("`
      *   `");
              setState("vEreignisse", "
      
          *   "+str+"
      
          ");
          }
      
          function timestamp(ts) {
              var now=new Date(ts);
              var day = now.getDate();
              var month = now.getMonth() + 1;
              var year = now.getFullYear();
              var weekday = now.getDay();
              var hours = now.getHours();
              var minutes = now.getMinutes();
              var seconds = now.getSeconds();
              var day0  = ((day < 10) ? "0" : "");
              var month0  = ((month < 10) ? "0" : "");
              var hours0  = ((hours < 10) ? "0" : "");
              var minutes0  = ((minutes < 10) ? "0" : "");
              var seconds0  = ((seconds < 10) ? "0" : "");
              var output = year + "-" + month0 + month + "-" + day0 + day + " " + hours0 + hours + ":" + minutes0 + minutes + ":" + seconds0 + seconds;  
              return output;
      
          }
      
          function room(obj) {
              var devname=obj.deviceName;
              var dp = getObject(obj.id,"rooms");
              var raum=dp.enumNames;
          //    var raum="---";
              var rooms ={"ST-05" : "OG Balkontür", "ST-02" : "OG Wohnzimmer BW", "ST-03" : "EG Treppenhaustür"
                , "ST-01" : "EG Wintergarten" , "ST-04" : "EG Eingangstür"
                , "BW-01" : "UG Garage" , "BW-02" : "EG Wintergarten" , "BW-03" : "OG Wohnzimmer"   
                , "VS-01" : "EG Eingangstür" , "VS-02" : "UG Eingangstür" , "VS-03" : "UG Waschküche" 
                , "VS-04" : "UG Garagentor" , "VS-05" : "EG Balkontür Atrium" , "VS-06" : "EG Relaxraum" 
                , "VS-07" : "OG Balkontür" , "VS-08" : "OG Dachfenster" , "VS-09" : "EG Katzen R" 
                , "VS-10" : "EG Katzen L" , "VS-11" : "EG Wintergarten" , "VS-12" : "EG Wohnzimmerfenster" 
                , "VS-13" : "EG Küche L" , "VS-14" : "EG Küche R" , "VS-15" : "EG Abstellkammer" 
                , "VS-16" : "EG Trepphaus" , "VS-17" : "OG Gästezimmer" , "VS-18" : "OG Ankleidezimmer" 
      
              };
              if (devname in rooms) {
                  return rooms[devname];
              }
              return raum;
          }
      
          sensorsST.on(function(obj) {
            var aktion="AUTO";
            if (obj.newState.val == 1) {
              aktion="OFF";
            }
            var ts=timestamp(obj.newState.ts);
              ereignis(ts + " " + obj.deviceName + " " + room(obj) + " " + aktion);
          //    log("OBJ=" + JSON.stringify(obj,null,2));
          })
      
          sensorsVS.on(function(obj) {
            var aktion="ZU";
            if (obj.newState.val == 1) {
              aktion="AUF";
            }
            var ts=timestamp(obj.newState.ts);
              ereignis(ts + " " + obj.deviceName + " " + room(obj) + " " + aktion);
          //    log("OBJ=" + JSON.stringify(obj,null,2));
          })
      
          sensorsBW.on(function(obj) {
            if (obj.newState.val == 1) {
            var ts=timestamp(obj.newState.ts);
              ereignis(ts + " " + obj.deviceName + " " + room(obj) + " " + "Bewegung");
          //    log("OBJ=" + JSON.stringify(obj,null,2));
            }
      
          })
      
          vAlarmanlage.on(function(obj) {
            var aktion="Haus alles gesichert";
            if (obj.newState.val == 1) {
              aktion="im Haus/Lüften";
            }
            if (obj.newState.val == 2) {
              aktion="OFF";
            }
            var ts=timestamp(obj.newState.ts);
              ereignis(ts + " Alarmstatus: " + aktion);
              log("OBJ=" + JSON.stringify(obj,null,2));
          })`
      
          mit den Funktionen sensorsXX Frage ich alle Sensoren, die zu einer Gruppe gehören ab,
      
          bei VS = Verschluß, BW = Bewegung und ST = Statusänderung/Schalter
      
          mit vAlarmanlage Frage ich einen einzelnen Datenpunkt ab, hier eine Variable.
      
          Im unteren Bereich des Skriptes muss zu jeder Funktion eine *.on Funktion dazu erstellt werden.
      
          Diese kann je nach Geräteart die Ausgabe umformulieren.
      
          UPDATE: Angepasst an neue Timestamps!
      
      
      1 Reply Last reply Reply Quote 0
      • F
        Fitti last edited by

        Hallo Sissiwup,

        vielen Dank für die Wissensteilung. Kann man immer benötigen.

        Wofür hast Du es entwickelt, was machst Du damit dann?

        Viele Grüße,

        Fitti

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

          Hallo,

          kannst du evtl. audioconcept http://forum.iobroker.org/viewtopic.php?f=21&t=1289#p10621 weiterhelfen? Ich bin jetzt ein paar Tage weg und er benötigt Unterstützung bei der Ereignisliste.

          Gruß

          Pix

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

            @Fitti:

            Wofür hast Du es entwickelt, was machst Du damit dann? `

            Um "wichtige" Ereignisse des Tages in einer Liste darzustellen, die dann in Vis mit eingebunden ist.

            Ich lasse mir z.B. u.a. folgende Punkte anzeigen:

            • Anwesenheiten

            • Haustür geöffnet

            • Internetausfall / neue IP-Adresse

            • Anrufe in Abewesenheit

            • Änderungen von Logikschaltern (Logik ein/aus)

            • Änderung von diversen Variablen

            • …

            Die letzten 30 Ereignisse werden in einer Liste in VIS dargestellt.

            1 Reply Last reply Reply Quote 0
            • H
              HKF8770 last edited by

              Ich hat das Skript kopiert, doch komme ich nicht ganz klar was ich hier dann neu anlegen muss. Ich verstehe es so dass ich für jedes Aktor den ich abfragen möchte eine eigenen .on Bereich erstellen muss. Verstehe ich das richtig? Isr es der untere Bereich den ich für jeden Aktor anlegen muss? Wenn ja muss ich dann sensorBW gegen den namen des Aktors tauschen?

              sensorsBW.on(function(obj) {

              if (obj.newState.val == 1) {

              var ts=timestamp(obj.newState.ts*1000);

              ereignis(ts + " " + obj.deviceName + " " + room(obj) + " " + "Bewegung");

              // log("OBJ=" + JSON.stringify(obj,null,2));

              }

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

                Hallo,

                es gehört immer ein oberer Bereich, wo du die Geräte/Sensoren auswählst, die du überwachen willst.

                Mit dem "on" definierst du, was passieren soll, wenn die Änderung eintritt, die du überwachst.

                1 Reply Last reply Reply Quote 0
                • H
                  HKF8770 last edited by

                  Läuft soweit doch habe ich folgende Frage:

                  Habe eine Abfrage der Temperaturen definiert, welche auch geht

                  var sensorsTemp = $('channel[state.id=*.TEMPERATURE]').each(function(id) {
                      var val = getObject(id).common.name;
                      log("===> Ereignisliste Temperatur=" + val);
                  

                  der untere Teil ist wie folgt:

                  sensorsTemp.on(function(obj) {
                    if (obj.newState.val > -100) {
                    var ts=timestamp(obj.newState.ts*1000);
                      ereignis(ts + " " + obj.deviceName + " " + room(obj) + " " + "Grad");
                      log("OBJ=" + JSON.stringify(obj,null,2));
                  

                  Ich möchte abr die Gradzahl mit einbinden, wie frag ich die ab?

                  var val = getObject(id).common.name gibt ja den Manen das Sensors.

                  wie heist dass wenn ich den Wert möchte??

                  getObject(id).????????

                  Bin für jeden Tipp dankbar

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

                    @HKF8770:

                    wie heist dass wenn ich den Wert möchte?? `
                    innerhalb der callback-Funktion von on(function(obj) {…})

                    var wert = obj.newState.val;
                    

                    sonst

                    var wert = getState(id).val;
                    
                    1 Reply Last reply Reply Quote 0
                    • H
                      HKF8770 last edited by

                      Supper…danke.

                      getObject(id).common.name gibt mir ja den Namen des Gerätes wieder. Wie bekomme ich den namen des Kanals?

                      1 Reply Last reply Reply Quote 0
                      • H
                        HKF8770 last edited by

                        Habe ein Problem mit den functions.

                        Ich habe die Kanäle entsprechend manuell über "Aufzählung" hinzugefügt und zuvor die Kategorie Licht angelegt

                        Wenn ich (functions=Licht) weg lasse geht alles.

                            var sensorsLicht = $('channel[state.id=*.STATE]').each(function(id) {  //(functions=Licht)
                            var val = getObject(id).common.name;
                            log("===> Ereignisliste Licht=" + val);
                        });
                        

                        möchte ich nach STATE und Functions selektieren gehts nicht mehr.

                           var sensorsLicht = $('channel[state.id=*.STATE](functions=Licht)').each(function(id) {  //(functions=Licht)
                            var val = getObject(id).common.name;
                            log("===> Ereignisliste Licht=" + val);
                        });
                        

                        Ich hab schon LIcht oder licht probiert aber es kommt kein Ergebnis.

                        QWie gesagt lass ich es weg bekomme ich einen Eintrag so dass das Skript ja funktioniert.

                        Was mach ich falsch / übersehe ich?
                        212_skript_1.jpg

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

                          @HKF8770:

                          Wenn ich (functions=Licht) weg lasse geht alles. `
                          Hast Du es mal mit (functions=licht) versucht ?

                          1 Reply Last reply Reply Quote 0
                          • H
                            HKF8770 last edited by

                            geht leider weder noch….Mach ich irgendwo nen Fehler?

                            Ich lege die funtions auf dem Reiter "Aufzählunbgen" manuell an. unter enum.funtions mit dem + lege ich die Unterkategorie an die ja im Skript auch abgefragt wird. Dann in der Unterkategorie ganz rechts über das Buch ergänze ich die entsprechenden Datenpunkte. z.B.xxxxxx.state oder xxxxxx.motion, immer das was ich abfragen möchte.

                            Das ist so doch richtig, oder?

                            1 Reply Last reply Reply Quote 0
                            • H
                              HKF8770 last edited by

                              Hab Lösung gefunden.

                              • alle functions manuell gelöscht (Papierkorb rechts)

                              • Adapter hm-rega neu synchronisiert

                              Dachte wenn ich Änderungen an edn Gewerken der CCU2 mache wird dies mit iobrokler synchronisiert, wenn ich hm-rega neu starte….dem ist aber wohl nicht so. Erst nachdem ich alle functions gelöscht hatte und neu synchronisiert hatte, war dies identisch zu der CCU2.

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

                                Hallo

                                seit gestern ( update io Broker )stimmt die zeit in der Ereignisliste nicht mit der richtigen Zeit überein

                                ![](<ATTACHMENT 516_ereignisliste.jpg )~~[attachment=0]~~ereignisliste.JPG[/attachment]" />

                                mus am dem Script etwas geändert werden ?

                                Gruß Stephan

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

                                  Hallo,

                                  da ioBroker jetzt mit Millisekunden umgehen kann, brauchst du im Skript nicht mehr umzurechnen. Das heißt, überall wo im Code der Timestamp mit eintausend multipliziert wird, kürzt du die Multiplikation weg ("*1000").

                                  zB hier````
                                  var ts=timestamp(obj.newState.ts*1000);

                                  Um den Code noch mehr zu vereinfachen, kannst du den Timestmp auch direkt an die ereignis-Funktion übergeben und gleich ganz die Variable ts weglassen:
                                  

                                  ereignis(obj.state.ts + " Alarmstatus: " + aktion);

                                  
                                  Wenn dir das alles zuviel ist, änderst du in der function timestamp die zweite Zeile in
                                  

                                  var now=new Date(ts/1000);

                                  Geht, ist aber nicht so schön.
                                  
                                  Gruß
                                  
                                  Pix
                                  1 Reply Last reply Reply Quote 0
                                  • sissiwup
                                    sissiwup last edited by

                                    Hallo,

                                    hab es oben angepasst. Geht jetzt mit neuen TimeStamps

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

                                      Vielleicht wird so was interessant.

                                      Alle events werden aus dem history/sql Adapter gelesen.

                                      `/* Read events from history adapter.
                                         Define the list of IDs, that must be shown. 
                                         Additionally for every ID the display name and number of events can be defined. 
                                      */
                                      
                                      var historyInstance = 'sql.0'; // can be history adapter too
                                      // ofcourse all IDs must be enabled for history
                                      var states = {
                                          "javascript.0.graph.minutes"/*graph.minutes*/:      { name: 'Minutes', count: 15},
                                          "system.adapter.admin.0.memRss"/*admin.0.memRss*/ : { name: 'Memory'}
                                      };
                                      var timeout = null; // de-bounce
                                      
                                      // create variable, where the list will be stored
                                      createState('eventList', '', function () {
                                          //first execute
                                          readAllEvents();
                                      });
                                      
                                      function publishEvents(events) {
                                          // AS HTML
                                          /*var table = '';
                                          for (var e = 0; e < events.length; e++) {
                                              table += '';
                                          }
                                          table += '
                                      
                                      | ' + formatDate(events[e].time, 'hh:mm:ss.sss') + ' | ' + states[events[e].id].name + ' | ' + events[e].val + ' |
                                      
                                      ';*/
                                      
                                          // as JSON
                                          for (var e = 0; e < events.length; e++) {
                                             events[e].time = formatDate(events[e].time, 'hh:mm:ss.sss');
                                             events[e].id   = states[events[e].id].name || events[e].id; 
                                          }
                                          setState('eventList', JSON.stringify(events), true);
                                      }
                                      
                                      function readOneId(id, number, events, cb) {
                                          var end = new Date().getTime();
                                      
                                          sendTo(historyInstance, 'getHistory', {
                                              id: id,
                                              options: {
                                                  end:        end,
                                                  aggregate: 'none',
                                                  count:      number || 10
                                              }
                                          }, function (result) {
                                              if (result.result) {
                                                  for (var i = 0; i < result.result.length; i++) {
                                                      events.push({id: id, time: result.result[i].ts, val: result.result[i].val});
                                                  }
                                              } 
                                              cb();
                                          });
                                      }
                                      
                                      // read events for all IDs
                                      function readAllEvents() {
                                          timeout = null;
                                          var ready = 0;
                                          var events = [];
                                          for (var id in states) {
                                              ready++;
                                              readOneId(id, 10, events, function () {
                                                  if (!--ready) {
                                                      events.sort(function (a, b) {
                                                          if (a.time < b.time) return 1;
                                                          if (a.time > b.time) return -1;
                                                          return 0;    
                                                      });
                                      
                                                      publishEvents(events);
                                                  }
                                              });
                                          }
                                      }
                                      
                                      // subscribe on all changes
                                      for (var id in states) {
                                          on(id, function () {
                                              if (timeout) return;
                                              // de-bounce creation
                                              timeout = setTimeout(readAllEvents, 500);
                                          });
                                      }` 
                                       ![48_2016-05-25_23_51_20-edit_vis.png](/assets/uploads/files/48_2016-05-25_23_51_20-edit_vis.png) 
                                      Widget:
                                      
                                      >! ~~[spoiler]~~`~~[code]~~[{"tpl":"tplTableBody","data":{"visibility-cond":"==","visibility-val":1,"static_value":"","gestures-offsetX":0,"gestures-offsetY":0,"signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-oid":"javascript.0.eventList","colCount":"3","colName1":"Time","colWidth1":"60px","colAttr1":"time","table_oid":"javascript.0.eventList","colName2":"Event","colWidth2":"80px","colAttr2":"id","colName3":"Value","colWidth3":"60px","colAttr3":"val","hide_header":false,"class":""},"style":{"left":"760px","top":"315px","width":"332px","height":"200px"},"widgetSet":"basic"}][/code]`[/spoiler][/i][/i]
                                      
                                      1 Reply Last reply Reply Quote 0
                                      • C
                                        ChristianF last edited by

                                        Ich danke ebenfalls sehr für dieses Script, ist eine tolle Sache !

                                        Allerdings habe ich mit diesem Abschnitt so meine Probleme:

                                            var rooms ={"ST-05" : "OG Balkontür", "ST-02" : "OG Wohnzimmer BW", "ST-03" : "EG Treppenhaustür"
                                              , "ST-01" : "EG Wintergarten" , "ST-04" : "EG Eingangstür"
                                              , "BW-01" : "UG Garage" , "BW-02" : "EG Wintergarten" , "BW-03" : "OG Wohnzimmer"   
                                              , "VS-01" : "EG Eingangstür" , "VS-02" : "UG Eingangstür" , "VS-03" : "UG Waschküche"
                                              , "VS-04" : "UG Garagentor" , "VS-05" : "EG Balkontür Atrium" , "VS-06" : "EG Relaxraum"
                                              , "VS-07" : "OG Balkontür" , "VS-08" : "OG Dachfenster" , "VS-09" : "EG Katzen R"
                                              , "VS-10" : "EG Katzen L" , "VS-11" : "EG Wintergarten" , "VS-12" : "EG Wohnzimmerfenster"
                                              , "VS-13" : "EG Küche L" , "VS-14" : "EG Küche R" , "VS-15" : "EG Abstellkammer"
                                              , "VS-16" : "EG Trepphaus" , "VS-17" : "OG Gästezimmer" , "VS-18" : "OG Ankleidezimmer"
                                        

                                        Wie muss ich das an meine Räume anpassen? Was muss dort genau stehen? Ich bin ein bisschen lost..

                                        Danke!

                                        Viele grüße

                                        Christian

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

                                          Wenn ich das richtig sehe, ist das eine etwas unglückliche Textformatierung, die dir Probleme macht.

                                          var rooms = {
                                              "ST-05": "OG Balkontür",
                                              "ST-02": "OG Wohnzimmer BW",
                                              "ST-03": "EG Treppenhaustür",
                                              "ST-01": "EG Wintergarten",
                                              "ST-04": "EG Eingangstür",
                                              "BW-01": "UG Garage",
                                              "BW-02": "EG Wintergarten",
                                              "BW-03": "OG Wohnzimmer",
                                              "VS-01": "EG Eingangstür",
                                              "VS-02": "UG Eingangstür",
                                              "VS-03": "UG Waschküche",
                                              "VS-04": "UG Garagentor",
                                              "VS-05": "EG Balkontür Atrium",
                                              "VS-06": "EG Relaxraum",
                                              "VS-07": "OG Balkontür",
                                              "VS-08": "OG Dachfenster",
                                              "VS-09": "EG Katzen R",
                                              "VS-10": "EG Katzen L",
                                              "VS-11": "EG Wintergarten",
                                              "VS-12": "EG Wohnzimmerfenster",
                                              "VS-13": "EG Küche L",
                                              "VS-14": "EG Küche R",
                                              "VS-15": "EG Abstellkammer",
                                              "VS-16": "EG Trepphaus",
                                              "VS-17": "OG Gästezimmer",
                                              "VS-18": "OG Ankleidezimmer"
                                          };
                                          
                                          

                                          Wenn du dir nun die Ausgabe ansiehst: 261_bildschirmfoto_202015-09-06_20um_2020.46.22.png Es sind also nur Bezeichnungen.

                                          Das Skript lauscht auf deine Sensoren an anderer Stelle:

                                          var sensorsST = $('channel[state.id=*.STATE](functions=ST)').each(function(id) {
                                              var val = getObject(id).common.name;
                                              log("DeviceST=" + val);
                                          });
                                          
                                          var sensorsVS = $('channel[state.id=*.STATE](functions=VS)').each(function(id) {
                                              var val = getObject(id).common.name;
                                              log("DeviceVS=" + val);
                                          });
                                          
                                          var sensorsBW = $('channel[state.id=*.MOTION](functions=BW)').each(function(id) {
                                              var val = getObject(id).common.name;
                                              log("DeviceBW=" + val);
                                          });
                                          
                                          var vAlarmanlage = $('state[id="hm-rega.0.3747"]').each(function(id) {
                                              var val = getObject(id).common.name;
                                              log("Alarmanlage=" + val);
                                          });
                                          
                                          

                                          Es lauscht in den Gewerken ST, BW, VS (vermute BW= Bewegungsmelder, VS= Verschluss, ST ???), ob die angegebenen Datenpunkte sich ändern. Dazu wird auf die REGA-Variable Alarmanlage gelauscht.

                                          Gruß

                                          Pix

                                          1 Reply Last reply Reply Quote 0
                                          • M
                                            michihorn last edited by

                                            @ruhr70:

                                            @Fitti:

                                            Wofür hast Du es entwickelt, was machst Du damit dann? `

                                            Um "wichtige" Ereignisse des Tages in einer Liste darzustellen, die dann in Vis mit eingebunden ist.

                                            Ich lasse mir z.B. u.a. folgende Punkte anzeigen:

                                            • Anwesenheiten

                                            • Haustür geöffnet

                                            • Internetausfall / neue IP-Adresse

                                            • Anrufe in Abewesenheit

                                            • Änderungen von Logikschaltern (Logik ein/aus)

                                            • Änderung von diversen Variablen

                                            • …

                                            Die letzten 30 Ereignisse werden in einer Liste in VIS dargestellt. `

                                            Hallo

                                            wie realisierst Du denn Internetausfall?

                                            Michael

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            824
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            21
                                            89
                                            18294
                                            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