Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. [gelöst] Adapter - Parser / Wartezeiten auslesen

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Adapter - Parser / Wartezeiten auslesen

    This topic has been deleted. Only users with topic management privileges can see it.
    • liv-in-sky
      liv-in-sky @Alexxx2005 last edited by liv-in-sky

      @Alexxx2005

      hab es nur überflogen - bin zeitlich etwas eng - vielleicht hilft das weiter

      probier mal das hier - es wird alle 30 sekunden gecheckt und dann ausgegeben

      mit sortierung

      test2.gif

      var cacheSelector = $('state[id=parser.0.*]');
      
      
      
      var cacheSelector = $('[id=parser.0.*]');
      
      
      schedule( "*/30 * * * * *",  function () {   
       
      var sortArr=[];
      var htmlString ="<table><tr><td>NAME   </td><td>IP   </td><td>   </td></tr>";
      
      //console.log(cacheSelector);
      
      
      
      var counter =0;
      
      cacheSelector.each(function(id, i) {
      
      counter = counter+1
      
      var devicename = getObject(id).common.name;
      
      var ip = id.replace(/_/g, ".");
      
      var ip = ip.replace(/parser.0./g, "");
      
      // log(id + " : " + devicename + " : " + ip );
      
      var devicenameName=devicename;
      
      devicename="Netzwerk.Gerät"+counter.toString()+".NameGerät";
      
      createState(devicename, 'empty', { name: 'Name des Geräts', desc: '', type: 'string', role: '',read: true, write: true });
      
      setStateDelayed(devicename, devicenameName, 800);
      
      
      devicename="Netzwerk.Gerät"+counter.toString()+".IPAdresse";
      
      setStateDelayed(devicename, ip, 800);
      
      createState(devicename, 'empty', { name: 'IP des Geräts', desc: '', type: 'string', role: '',read: true, write: true });
      
      var wert1 = getState(id).val;
      var wert0 = getState(id).val;
      
      if (wert1) wert1 = "✅";
      
      if (!wert1) wert1= "❌";
      
      let help = [devicename,ip,wert0,wert1];
      sortArr.push(help);
      //log(sortArr[0]);
      
      });
      
      function numSort(a, b) { 
         
        return parseInt(a[2]) - parseInt(b[2]);
      } 
      
      sortArr.sort(numSort);
               
      
      
      
             for (var i=0; i<sortArr.length;i++) {
                 htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] + "   </td><td>" + sortArr[i][3] + "</td></tr>";
             }      
      
      //htmlString=htmlString.concat("<tr><td>" + devicenameName + "   </td><td>" + ip + "   </td><td>" + wert1 + "</td></tr>");
      
      //log(counter);
      
      createState('Netzwerk.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
      
      createState('Netzwerk.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
      
      setStateDelayed('Netzwerk.Anzahl', counter, 800);
      setStateDelayed('Netzwerk.StringHTML', htmlString.concat("</table>"), 800);
      });
      
      

      1 Reply Last reply Reply Quote 1
      • A
        Alexxx2005 last edited by Alexxx2005

        @liv-in-sky

        Jawohl das sieht schon mal gut aus, habe soweit mal alles angepasst was ich
        machen konnte


        var cacheSelector = $('state[id=parser.0.]');
        var cacheSelector = $('[id=parser.0.
        ]');
        schedule( "*/30 * * * * *", function () {
        var sortArr=[];
        var htmlString ="<table><tr><td>Bahn </td><td>Wartezeit in Minuten </td><td> </td></tr>";
        //console.log(cacheSelector);
        var counter =0;
        cacheSelector.each(function(id, i) {
        counter = counter+1
        var devicename = getObject(id).common.name;
        var ip = id.replace(/_/g, ".");
        var ip = ip.replace(/parser.0./g, "");
        // log(id + " : " + devicename + " : " + ip );
        var devicenameName=devicename;
        devicename="Park.Wartezeit"+counter.toString()+".Bahn";
        createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
        setStateDelayed(devicename, devicenameName, 800);
        devicename="Park.Wartezeit"+counter.toString()+".Bahn";
        setStateDelayed(devicename, ip, 800);
        createState(devicename, 'empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
        var wert1 = getState(id).val;
        var wert0 = getState(id).val;
        if (wert1) wert1 = "✅";
        if (!wert1) wert1= "❌";
        let help = [devicename,ip,wert0,wert1];
        sortArr.push(help);
        //log(sortArr[0]);
        });
        function numSort(a, b) {

        return parseInt(a[2]) - parseInt(b[2]);

        }

        sortArr.sort(numSort);

           for (var i=0; i<sortArr.length;i++) {
        
               htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] + "   </td><td>" + sortArr[i][3] + "</td></tr>";
        
           }      
        

        //htmlString=htmlString.concat("<tr><td>" + devicenameName + " </td><td>" + ip + " </td><td>" + wert1 + "</td></tr>");
        //log(counter);
        createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
        createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
        setStateDelayed('Park.Anzahl', counter, 800);
        setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
        });

        Das Ergebniss :

        angepasst.PNG

        wenn ich nun bei :

        let help = [devicename,ip,wert0,wert1];
        

        den devicename, lösche erhalte ich diese Ausgabe :

        soll.PNG

        das würde meiner Vorstellung entsprechen, allerdings passt nun
        die Sortierung nicht mehr und nach dem Haken kommt ein
        "undefined"

        Leider verstehe ich nicht warum das jetzt kommt bzw. was ich noch
        löschen muss damit es nicht mehr kommt.

        Und was müßte man noch ändern für eine "absteigende Sortierung"

        Danke,

        Grüße Alex

        liv-in-sky 1 Reply Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @Alexxx2005 last edited by liv-in-sky

          @Alexxx2005

          hier wird sotiert - wenn du die werte im array änderst kommt es zu problemen

          function numSort(a, b) { 
              
             return parseInt(a[2]) - parseInt(b[2]);
          } 
          
          sortArr.sort(numSort);
          

          hier wird das array geschrieben:

          let help = [devicename,ip,wert0,wert1];
          

          devicename = 0, ip =1, wert0 =2 wert1=3

          in der sortierung wird auf wert [2] sortiert - das hat sich ja geändert, weil du etwas nicht mehr ins array schreibst - wenn der devicename fehlt, ist ip =0, wert0 = 1 und wert1=2 --> du musst die 2 auf die 1 ändern in der sortierung

          bei der ausgabe: es fehlt auch da der devicename also musst du auch dort den punktsortArr[i][3] löschen, da der nicht mehr existiert (undefined) - das array geht nur von 0 bis 2 (3 werte) nicht von 0 bis 3 (4 werte)

             htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] +  "</td></tr>";
          

          die sortierung umdrehen: versuch mal

          function numSort(a, b) { 
              
             return   parseInt(b[2]) - parseInt(a[2]);
          } 
          

          also b[2] und a[2] austauschen - bzw. steht da ja jetzt b[1]-a[1], da wir das oben umgestellt haben

          1 Reply Last reply Reply Quote 0
          • A
            Alexxx2005 last edited by

            Danke sehr gut erklärt, nun habe ich es verstanden, hätte jetzt noch zwei Fragen :

            Kreuze.PNG

            jede Bahn die nicht im Betrieb ist wird mit "null" und "X" ausgegeben,

            Ist es möglich das dies in der Liste ganz unten oder ganz oben ausgegeben wird.
            Ebenfalls würde mich noch interessieren ob es möglich ist die Tabelle :

            zweizeilig.png

            zwei Spaltig zu gespalten damit die Zeilen nicht zu lang werden und es ins VIS geht 🙂

            Grüße Alex

            liv-in-sky 2 Replies Last reply Reply Quote 0
            • liv-in-sky
              liv-in-sky @Alexxx2005 last edited by

              @Alexxx2005 das null ist irgendwie falsch - da müßte 0 stehen - dann würde es auch sortiert werden

              paste mal dein momentanes script

              Homoran 1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @Alexxx2005 last edited by

                @Alexxx2005 und zeige mal, was in den parser.0 datenpunkten steht - ist da schon de fehler vom parsen ? "null" ist ein "fehler" und bedeutet nicht 0

                den müßte man dann noch abfangen im script

                A 1 Reply Last reply Reply Quote 0
                • Homoran
                  Homoran Global Moderator Administrators @liv-in-sky last edited by

                  @liv-in-sky sagte in Adapter - Parser soll Wartezeiten auslesen:

                  da müßte 0 stehen

                  unendlich wäre sinnvoller 😉

                  liv-in-sky 1 Reply Last reply Reply Quote 0
                  • liv-in-sky
                    liv-in-sky @Homoran last edited by

                    @Homoran unendlich oder "not available"

                    Homoran 1 Reply Last reply Reply Quote 0
                    • Homoran
                      Homoran Global Moderator Administrators @liv-in-sky last edited by

                      @liv-in-sky
                      Wenn es in Zahlen ausgedrückt werden soll ist bei geschlossen die Wartezeit unendlich oder pragmatich 999(9999) je nach anzahl der Stellen

                      liv-in-sky 1 Reply Last reply Reply Quote 0
                      • liv-in-sky
                        liv-in-sky @Homoran last edited by

                        @Homoran jo - da hast du wohl recht

                        1 Reply Last reply Reply Quote 0
                        • A
                          Alexxx2005 @liv-in-sky last edited by Alexxx2005

                          @liv-in-sky

                          parser.PNG

                          Das "Null" steht drin weil die Bahn heute nicht geloggt wird kp.
                          Sie erscheint auch nicht auf der Homepage , wenn ich z.b. einen
                          falschen Link eingebe kommt ebenfalls "Null"

                          Dachte man kann beim parser bei Ersatz eine Ersatzzahl definieren
                          aber das funktioniert nicht.

                          Grüße Alex

                          liv-in-sky 1 Reply Last reply Reply Quote 0
                          • liv-in-sky
                            liv-in-sky @Alexxx2005 last edited by

                            @Alexxx2005 soll den eine solche "null"-bahn überhaupt in der tabelle erscheinben oder soll sie mit einem bestimmten wert bzw. bild erscheinen 🔐 oder🔒 oder ⏳ oder r♾️ siehe https://emojipedia.org/objects/

                            poste noch das script

                            A 1 Reply Last reply Reply Quote 0
                            • A
                              Alexxx2005 @liv-in-sky last edited by Homoran

                              @liv-in-sky also am besten wäre das Locked Symbol 🔒 wahrscheinlich ist die Bahn dann defekt oder über Winterzeit geschlossen...

                              var cacheSelector = $('state[id=parser.0.*]');
                              var cacheSelector = $('[id=parser.0.*]');
                              schedule( "*/03 * * * * *",  function () {   
                              var sortArr=[];
                              var htmlString ="<table><tr><td>Bahn   </td><td>Wartezeit   </td><td>   </td></tr>";
                              //console.log(cacheSelector);
                              var counter =0;
                              cacheSelector.each(function(id, i) {
                              counter = counter+1
                              var devicename = getObject(id).common.name;
                              var ip = id.replace(/_/g, ".");
                              var ip = ip.replace(/parser.0./g, "");
                              // log(id + " : " + devicename + " : " + ip );
                              var devicenameName=devicename;
                              devicename="Park.Wartezeit"+counter.toString()+".BahnName";
                              createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                              setStateDelayed(devicename, devicenameName, 800);
                              devicename="Park.Wartezeit"+counter.toString()+".Bahn";
                              setStateDelayed(devicename, ip, 800);
                              createState('empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                              var wert2 = getState(id).val;
                              var wert1 = getState(id).val;
                              if (wert2) wert2 = "✅";
                              if (!wert2) wert2= "❌";
                              let help = [ip,wert1,wert2];
                              sortArr.push(help);
                              //log(sortArr[0]);
                              });
                              function numSort(a, b) { 
                                return parseInt(b[1]) - parseInt(a[1]);
                              } 
                              sortArr.sort(numSort);
                                     for (var i=0; i<sortArr.length;i++) {
                                         htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] +  "</td></tr>";
                                     }      
                              //htmlString=htmlString.concat("<tr><td>" + devicenameName + "   </td><td>" + ip + "   </td><td>" + wert1 + "</td></tr>");
                              //log(counter);
                              createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
                              createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
                              setStateDelayed('Park.Anzahl', counter, 800);
                              setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
                              });
                              

                              liv-in-sky 1 Reply Last reply Reply Quote 0
                              • liv-in-sky
                                liv-in-sky @Alexxx2005 last edited by liv-in-sky

                                @Alexxx2005 ich schau mal - bitte poste scripts im code tag

                                Image 2.png

                                1 Reply Last reply Reply Quote 0
                                • A
                                  Alexxx2005 last edited by

                                  Ah so ist's richtig 🙂

                                  var cacheSelector = $('state[id=parser.0.*]');
                                  var cacheSelector = $('[id=parser.0.*]');
                                  schedule( "*/03 * * * * *",  function () {   
                                  var sortArr=[];
                                  var htmlString ="<table><tr><td>Bahn   </td><td>Wartezeit   </td><td>   </td></tr>";
                                  //console.log(cacheSelector);
                                  var counter =0;
                                  cacheSelector.each(function(id, i) {
                                  counter = counter+1
                                  var devicename = getObject(id).common.name;
                                  var ip = id.replace(/_/g, ".");
                                  var ip = ip.replace(/parser.0./g, "");
                                  // log(id + " : " + devicename + " : " + ip );
                                  var devicenameName=devicename;
                                  devicename="Park.Wartezeit"+counter.toString()+".BahnName";
                                  createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                  setStateDelayed(devicename, devicenameName, 800);
                                  devicename="Park.Wartezeit"+counter.toString()+".Bahn";
                                  setStateDelayed(devicename, ip, 800);
                                  createState('empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                  var wert2 = getState(id).val;
                                  var wert1 = getState(id).val;
                                  if (wert2) wert2 = "✅";
                                  if (!wert2) wert2= "❌";
                                  let help = [ip,wert1,wert2];
                                  sortArr.push(help);
                                  //log(sortArr[0]);
                                  });
                                  function numSort(a, b) { 
                                   return parseInt(b[1]) - parseInt(a[1]);
                                  } 
                                  sortArr.sort(numSort);
                                        for (var i=0; i<sortArr.length;i++) {
                                            htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] +  "</td></tr>";
                                        }      
                                  //htmlString=htmlString.concat("<tr><td>" + devicenameName + "   </td><td>" + ip + "   </td><td>" + wert1 + "</td></tr>");
                                  //log(counter);
                                  createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
                                  createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
                                  setStateDelayed('Park.Anzahl', counter, 800);
                                  setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
                                  });
                                  

                                  liv-in-sky 1 Reply Last reply Reply Quote 1
                                  • liv-in-sky
                                    liv-in-sky @Alexxx2005 last edited by liv-in-sky

                                    @Alexxx2005

                                    ok neuer test

                                    
                                    
                                    schedule( "*/20 * * * * *", function () {
                                    var cacheSelector = $('[id=parser.0.*]');
                                    var sortArr=[];
                                    var htmlString ="<table><tr><td>Bahn </td><td>Wartezeit </td><td> </td><td>&ensp;&ensp;&ensp;</td><td>Bahn &ensp;&ensp;&ensp;</td><td>Wartezeit </td><td> </td></tr>";/*+
                                                           "<tr>&ensp;<td></td><td></td><td></td><td></td><td></td><td></td></tr>" */;
                                    //console.log(cacheSelector);
                                    var counter =0;
                                    
                                    cacheSelector.each(function(id, i) {
                                    
                                    counter = counter+1
                                    
                                    var devicename = getObject(id).common.name;
                                    
                                    var ip = id.replace(/_/g, ".");
                                    
                                    var ip = ip.replace(/parser.0./g, "");
                                    
                                    
                                    var ip = id.replace(/_/g, ".");
                                    var ip = ip.replace(/parser.0./g, "");
                                    // log(id + " : " + devicename + " : " + ip );
                                    var devicenameName=devicename;
                                    
                                    devicename="Park.Wartezeit"+counter.toString()+".BahnName";
                                    createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                    setStateDelayed(devicename, devicenameName, 800);
                                    devicename="Park.Wartezeit"+counter.toString()+".Bahn";
                                    setStateDelayed(devicename, ip, 800);
                                    createState(devicename,'empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                    var wert1;
                                    var wert2;
                                    if ( getState(id).val==null) {wert1= "🔒"; wert2="999999";} 
                                    else {
                                         
                                         var wert2 = getState(id).val;
                                         var wert1 = getState(id).val;
                                         if (wert1) wert1 = "✅";
                                         if (!wert1) wert1= "❌";
                                    }
                                    let help = [ip,wert2,wert1];
                                    sortArr.push(help);
                                    
                                    });
                                    function numSort(a, b) {
                                    return parseInt(a[1]) - parseInt(b[1]);
                                    }
                                    sortArr.sort(numSort);
                                    for (var i=0; i<sortArr.length;i++) {   
                                       if (sortArr[i][1]!="999999") {
                                       if(i%2==0) {htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "</td><td>&ensp;&ensp;&ensp;" + sortArr[i][1] + "&ensp;&ensp;&ensp;</td><td>" + sortArr[i][2]+"&ensp;&ensp;&ensp;"+"<td>&ensp;&ensp;&ensp;</td>" ;}// +"</td>"         + " <td>"        + " </td><td>"   + "</td></tr>";}
                                       else{htmlString=htmlString+      "<td>" + sortArr[i][0]  + " </td><td>&ensp;&ensp;&ensp;"   + sortArr[i][1]  + "&ensp;&ensp;&ensp;</td><td>"   + sortArr[i][2] + "</td></tr>"}}
                                       else{
                                           if(i%2==0) {htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "</td><td>&ensp;&ensp;&ensp;" + "out" + "&ensp;&ensp;&ensp;</td><td>" + sortArr[i][2]+"&ensp;&ensp;&ensp;" ;}// +"</td>"         + " <td>"        + " </td><td>"   + "</td></tr>";}
                                       else{htmlString=htmlString+      "<td>" + sortArr[i][0]  + " </td><td>&ensp;&ensp;&ensp;"   + "out"  + "&ensp;&ensp;&ensp;</td><td>"   + sortArr[i][2] + "</td></tr>"}
                                    
                                       }
                                    
                                    }
                                    //htmlString=htmlString.concat("<tr><td>" + devicenameName + " </td><td>" + ip + " </td><td>" + wert1 + "</td></tr>");
                                    //log(counter);
                                    createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
                                    createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
                                    setStateDelayed('Park.Anzahl', counter, 800);
                                    setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
                                    });
                                    

                                    ich habe mal versucht, das ganze in 2 tabellen nebeneinander darzustellen - weiß nicht ob das gefällt ?

                                    test3.gif

                                    A 1 Reply Last reply Reply Quote 0
                                    • A
                                      Alexxx2005 @liv-in-sky last edited by

                                      @liv-in-sky

                                      doch das ist super , sieht gut aus. Es zeigt bei mir nur die oberen drei rechten Spalten zu weit links an , es da noch ein kleiner Bug im "htmlstring" oder warum zeigt es die drei markierten Bahnen so an ?

                                      Bug.PNG

                                      Grüße Alex

                                      Homoran liv-in-sky 3 Replies Last reply Reply Quote 0
                                      • Homoran
                                        Homoran Global Moderator Administrators @Alexxx2005 last edited by

                                        @Alexxx2005 sagte in Adapter - Parser soll Wartezeiten auslesen:

                                        Es zeigt bei mir nur die oberen drei rechten Spalten zu weit links an

                                        ich tippe darauf, dass es an dem Schloss - icon, resp. der dazugehörigen Formatierung liegt

                                        1 Reply Last reply Reply Quote 0
                                        • liv-in-sky
                                          liv-in-sky @Alexxx2005 last edited by

                                          @Alexxx2005 ich überprüfe nochmal - falls du was am script geändert hast, bitte wieder posten, damit ich damit arbeiten kann, sonst musst du wieder nachträglich ändern

                                          nur zur sicherheit - die werte stimmen alle ? es geht nur um die formatierung ?

                                          1 Reply Last reply Reply Quote 0
                                          • liv-in-sky
                                            liv-in-sky @Alexxx2005 last edited by liv-in-sky

                                            @Alexxx2005 du kannst mal zum test das schloss mit einem haken austauschen und nachsehen, ob das problem bleibt - somit könnten wir das icon ausschließem ( @Homoran )

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            905
                                            Online

                                            31.9k
                                            Users

                                            80.2k
                                            Topics

                                            1.3m
                                            Posts

                                            parser adapter
                                            5
                                            53
                                            2176
                                            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