Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Abfrage der Erreichbarkeit der Sensoren

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    354

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.6k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.5k

Abfrage der Erreichbarkeit der Sensoren

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
blockly
25 Beiträge 5 Kommentatoren 2.8k Aufrufe 3 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • htreckslerH htrecksler

    @brainbug muss es unbedingt Blockly sein?
    Bei mir läuft ein javascript welches einen Bodenfeuchtesensor überwacht.
    Hab ich irgendwann mal hier im Forum gefunden und es läuft recht zuverlässig, ist jedoch kein Blockly.

    //Das Script überprüft regelmässig die Datenpunkte auf Aktualisierung
     
    //Angabe des Datenpunkts= Datenpunkt der Überwacht werden soll
    //StateBezeichnung= Unter pfad_javascript.StateBezeichung wird ein State angelegt; True = Daten sind aktuell / False = Daten veraltet
    //Zeit in Sekunden = Zeit die vergangen sein darf seit der letzen Aktualisierung des Datenpunkts  (0 = default Zeit wird genommen).
     
    schedule("*/3 * * * *" , function () {                                  
     
        // Angabe des Datenpunkts;StateBezeichnung;Zeit in Sekunden
        var ueberwachung = ['mqtt.0.Sensoren.Sensor03.Feuchtigkeit;Bodenfeuchte_Hinten;660', 
                            'mqtt.0.Sensoren.Sensor02.Feuchtigkeit;Bodenfeuchte_Vorne;660'];
    
     
        var default_zeit = 400;
        var pfad_userdata ='0_userdata.0.watchdog.';   // !Punkt nicht vergessen am Ende!
     
     
        //------------------------------------------------------------------
        //Ab hier nichts mehr Ändern
        //------------------------------------------------------------------
        var zeit= Math.floor(Date.now() / 1000);
        var differenz, lchange;
        var daten, tchange;
     
        ueberwachung.forEach(function(item, index, array) 
        {
            // Array Splitten
               daten = item.split(";");
     
            //Datenpunkt erstellen wenn nicht vorhanden
                createState(pfad_userdata + daten[1], { read: true, write: false, name: "Watchdog " + daten[1], type: "boolean", role: " ", def: "false"});
     
            //Differenz Zeit default oder manuell?
                differenz = parseInt(daten[2]);
                if (differenz == 0) differenz=default_zeit;
     
            //Zeitstempel abfragen in Sekunden
                tchange=parseInt(getState(daten[0]).ts / 1000);
                
            //Vergleichen der Zeitstempel
                    if ((zeit-tchange)>differenz)
                    {
                        setState(pfad_userdata + daten[1], false);
                        //setState("telegram.0.communicate.response", daten[1] + ' - ' + "Info: Sensor nicht erreichbar");
                        //console.log(daten[1] + "  ist älter als " + differenz + " Sekunden", 'warn');
                    }
                    else
                    {
                        setState(pfad_userdata + daten[1], true);
                        //console.log(daten[1] + "  ist jünger als " + differenz + " Sekunden");
                    } 
     
        });  
    });
     
    
    
    ? Offline
    ? Offline
    Ein ehemaliger Benutzer
    schrieb am zuletzt editiert von
    #6

    @htrecksler mir ist das egal wie der TO das dann macht. Ich komme persönlich mit Blockly am besten klar da ich kein js kann.

    htreckslerH 1 Antwort Letzte Antwort
    0
    • ? Ein ehemaliger Benutzer

      @htrecksler mir ist das egal wie der TO das dann macht. Ich komme persönlich mit Blockly am besten klar da ich kein js kann.

      htreckslerH Offline
      htreckslerH Offline
      htrecksler
      Forum Testing
      schrieb am zuletzt editiert von
      #7

      @brainbug irgendwie stehe ich mit den "Antworten" Button auf Kriegsfuss.
      Die Antwort sollte natürlich an @DGR gehen. :-)

      Gruss Hermann

      ioBroker auf Proxmox (Debian) auf IntelNuc als Produktivsystem

      1 Antwort Letzte Antwort
      0
      • htreckslerH htrecksler

        @brainbug muss es unbedingt Blockly sein?
        Bei mir läuft ein javascript welches einen Bodenfeuchtesensor überwacht.
        Hab ich irgendwann mal hier im Forum gefunden und es läuft recht zuverlässig, ist jedoch kein Blockly.

        //Das Script überprüft regelmässig die Datenpunkte auf Aktualisierung
         
        //Angabe des Datenpunkts= Datenpunkt der Überwacht werden soll
        //StateBezeichnung= Unter pfad_javascript.StateBezeichung wird ein State angelegt; True = Daten sind aktuell / False = Daten veraltet
        //Zeit in Sekunden = Zeit die vergangen sein darf seit der letzen Aktualisierung des Datenpunkts  (0 = default Zeit wird genommen).
         
        schedule("*/3 * * * *" , function () {                                  
         
            // Angabe des Datenpunkts;StateBezeichnung;Zeit in Sekunden
            var ueberwachung = ['mqtt.0.Sensoren.Sensor03.Feuchtigkeit;Bodenfeuchte_Hinten;660', 
                                'mqtt.0.Sensoren.Sensor02.Feuchtigkeit;Bodenfeuchte_Vorne;660'];
        
         
            var default_zeit = 400;
            var pfad_userdata ='0_userdata.0.watchdog.';   // !Punkt nicht vergessen am Ende!
         
         
            //------------------------------------------------------------------
            //Ab hier nichts mehr Ändern
            //------------------------------------------------------------------
            var zeit= Math.floor(Date.now() / 1000);
            var differenz, lchange;
            var daten, tchange;
         
            ueberwachung.forEach(function(item, index, array) 
            {
                // Array Splitten
                   daten = item.split(";");
         
                //Datenpunkt erstellen wenn nicht vorhanden
                    createState(pfad_userdata + daten[1], { read: true, write: false, name: "Watchdog " + daten[1], type: "boolean", role: " ", def: "false"});
         
                //Differenz Zeit default oder manuell?
                    differenz = parseInt(daten[2]);
                    if (differenz == 0) differenz=default_zeit;
         
                //Zeitstempel abfragen in Sekunden
                    tchange=parseInt(getState(daten[0]).ts / 1000);
                    
                //Vergleichen der Zeitstempel
                        if ((zeit-tchange)>differenz)
                        {
                            setState(pfad_userdata + daten[1], false);
                            //setState("telegram.0.communicate.response", daten[1] + ' - ' + "Info: Sensor nicht erreichbar");
                            //console.log(daten[1] + "  ist älter als " + differenz + " Sekunden", 'warn');
                        }
                        else
                        {
                            setState(pfad_userdata + daten[1], true);
                            //console.log(daten[1] + "  ist jünger als " + differenz + " Sekunden");
                        } 
         
            });  
        });
         
        
        
        D Offline
        D Offline
        DGR
        schrieb am zuletzt editiert von
        #8

        @htrecksler
        Hallo,
        ich habe Blockly zunächst mal wie im Video (Brainbug) nachgebaut. Es läuft auch nach Anpassung der Abfragezeit (2 Stunden).

        Das Problem mit javascript ist, dass ich mich damit überhaupt nicht auskenne.

        Bei meinen Tests bin ich allerdings auf weitere Probleme gestoßen, die nicht unmittelbar mit meinem eingestellten Thema zu tun haben:

        1. Unterschied Zeitstempel und "lastupdated": welche Angabe ist für den Zeitpunkt des Ausfalls der Erreichbarkeit relevant ? Im Video wird nur der Zeitstempel abgefragt, ich habe aber den Eindruck, dass der betreffende Sensor seit dem Datum/Uhrzeit von "lastupdated" nicht mehr arbeitet.
        2. Bisher ließen sich die nicht erreichbaren Sensoren nur über Löschen bei den Objekten und in der Phoscon-App und anschließender "Neuinstallation" wieder verfügbar machen. Der Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.
        ? paul53P 2 Antworten Letzte Antwort
        0
        • D DGR

          @htrecksler
          Hallo,
          ich habe Blockly zunächst mal wie im Video (Brainbug) nachgebaut. Es läuft auch nach Anpassung der Abfragezeit (2 Stunden).

          Das Problem mit javascript ist, dass ich mich damit überhaupt nicht auskenne.

          Bei meinen Tests bin ich allerdings auf weitere Probleme gestoßen, die nicht unmittelbar mit meinem eingestellten Thema zu tun haben:

          1. Unterschied Zeitstempel und "lastupdated": welche Angabe ist für den Zeitpunkt des Ausfalls der Erreichbarkeit relevant ? Im Video wird nur der Zeitstempel abgefragt, ich habe aber den Eindruck, dass der betreffende Sensor seit dem Datum/Uhrzeit von "lastupdated" nicht mehr arbeitet.
          2. Bisher ließen sich die nicht erreichbaren Sensoren nur über Löschen bei den Objekten und in der Phoscon-App und anschließender "Neuinstallation" wieder verfügbar machen. Der Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.
          ? Offline
          ? Offline
          Ein ehemaliger Benutzer
          schrieb am zuletzt editiert von
          #9

          @dgr
          Im Spoiler ist mein Blockly drin.
          Wenn das lastupdated = dem "Zuletzt geändert" steht dann kannst du daran die Verbindung nicht testen. Der Zeitstempel ändert sich bei mir nicht mehr wenn die Verbindung verloren geht. Somit bleibt nach der eingestellten Abfragezeit die Zeit gleich und es kommt eine Meldung.

          D 1 Antwort Letzte Antwort
          0
          • D DGR

            @htrecksler
            Hallo,
            ich habe Blockly zunächst mal wie im Video (Brainbug) nachgebaut. Es läuft auch nach Anpassung der Abfragezeit (2 Stunden).

            Das Problem mit javascript ist, dass ich mich damit überhaupt nicht auskenne.

            Bei meinen Tests bin ich allerdings auf weitere Probleme gestoßen, die nicht unmittelbar mit meinem eingestellten Thema zu tun haben:

            1. Unterschied Zeitstempel und "lastupdated": welche Angabe ist für den Zeitpunkt des Ausfalls der Erreichbarkeit relevant ? Im Video wird nur der Zeitstempel abgefragt, ich habe aber den Eindruck, dass der betreffende Sensor seit dem Datum/Uhrzeit von "lastupdated" nicht mehr arbeitet.
            2. Bisher ließen sich die nicht erreichbaren Sensoren nur über Löschen bei den Objekten und in der Phoscon-App und anschließender "Neuinstallation" wieder verfügbar machen. Der Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.
            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #10

            @dgr sagte: Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.

            Um diesen Nachteil zu vermeiden, gibt es Alias. Dann muss nur noch an einer Stelle angepasst werden.

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

            D 2 Antworten Letzte Antwort
            0
            • paul53P paul53

              @dgr sagte: Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.

              Um diesen Nachteil zu vermeiden, gibt es Alias. Dann muss nur noch an einer Stelle angepasst werden.

              D Offline
              D Offline
              DGR
              schrieb am zuletzt editiert von
              #11

              @paul53 Danke. Das kannte ich nicht. Bei mir gibt es im Objektbaum alias, darunter 0 aber sonst nichts. Da muss ich mich erstmal mit befassen, aber gut, dass es eine solche Möglichkeit gibt.

              1 Antwort Letzte Antwort
              0
              • ? Ein ehemaliger Benutzer

                @dgr
                Im Spoiler ist mein Blockly drin.
                Wenn das lastupdated = dem "Zuletzt geändert" steht dann kannst du daran die Verbindung nicht testen. Der Zeitstempel ändert sich bei mir nicht mehr wenn die Verbindung verloren geht. Somit bleibt nach der eingestellten Abfragezeit die Zeit gleich und es kommt eine Meldung.

                D Offline
                D Offline
                DGR
                schrieb am zuletzt editiert von DGR
                #12

                @brainbug
                heute: 27.05.2022
                Ich habe einen Fenster-/Türsensor mit:
                Zeitstempel.JPG
                Wert von "lastupdated" = 2022-05-22T13.57 ....
                Zeitstempel = 2022-05-26 04:38....
                Zuletzt geändert = 2022-05-22T13:57 ....

                Der Sensor arbeitet mindestens seit 4 Tagen nicht mehr, also Annahme seit 22.05.22 (lastupdated/Zuletzt geändert).
                Es ist eigentlich egal, seit wann er nicht mehr arbeitet. Wichtig ist nur, dass erkannt wird, dass er nicht mehr arbeitet und das läuft ja.
                Trotzdem bleibt die Frage für mich, was bedeutet der Wert von "lastupdated" (bzw. "zuletzt aktualisiert") ?
                Der Zeitstempel hat sich gestern zuletzt geändert. Wodurch aber ?

                1 Antwort Letzte Antwort
                0
                • ? Offline
                  ? Offline
                  Ein ehemaliger Benutzer
                  schrieb am zuletzt editiert von Ein ehemaliger Benutzer
                  #13

                  @DGR Ah, jetzt sehe ich das auch das beim deconz den Wert lastupdated gibt. Kannst du mal bei battery schauen welcher Zeitstempel dort angezeigt wird?

                  D 1 Antwort Letzte Antwort
                  0
                  • ? Ein ehemaliger Benutzer

                    @DGR Ah, jetzt sehe ich das auch das beim deconz den Wert lastupdated gibt. Kannst du mal bei battery schauen welcher Zeitstempel dort angezeigt wird?

                    D Offline
                    D Offline
                    DGR
                    schrieb am zuletzt editiert von
                    #14

                    @brainbug
                    auch 26.05.22
                    Zeitstempel.JPG

                    seltsam: "Zuletzt geändert: 2022-03-23 ...."

                    andere Zeitstempel:
                    Zeitstempel3.JPG Zeitstempel2.JPG

                    paul53P 1 Antwort Letzte Antwort
                    0
                    • paul53P paul53

                      @dgr sagte: Nachteil ist, dass ich dann auch in ioBroker-vis wieder an einigen Stellen Änderungen vornehmen muss und leider dann auch im o.g. Blockly.

                      Um diesen Nachteil zu vermeiden, gibt es Alias. Dann muss nur noch an einer Stelle angepasst werden.

                      D Offline
                      D Offline
                      DGR
                      schrieb am zuletzt editiert von
                      #15

                      @paul53 Ich habe festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:
                      Alias02.JPG Alias01.JPG

                      paul53P 1 Antwort Letzte Antwort
                      0
                      • D DGR

                        @paul53 Ich habe festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:
                        Alias02.JPG Alias01.JPG

                        paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von paul53
                        #16

                        @dgr sagte: festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:

                        Das kann ich bei mir nicht nachvollziehen. Aktualisiere mal den Original-Datenpunkt ohne den Wert zu ändern mit "Bestätigt".

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        D 1 Antwort Letzte Antwort
                        0
                        • D DGR

                          @brainbug
                          auch 26.05.22
                          Zeitstempel.JPG

                          seltsam: "Zuletzt geändert: 2022-03-23 ...."

                          andere Zeitstempel:
                          Zeitstempel3.JPG Zeitstempel2.JPG

                          paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von paul53
                          #17

                          @dgr sagte: seltsam: "Zuletzt geändert: 2022-03-23

                          Was ist daran seltsam? Immer noch 100 % (keine Wertänderung).

                          "indicator.reachable" wurde durch ein Skript aktualisiert!

                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                          D 1 Antwort Letzte Antwort
                          0
                          • paul53P paul53

                            @dgr sagte: festgestellt, dass mit Alias nicht alles so läuft wie direkt vom Objekt:

                            Das kann ich bei mir nicht nachvollziehen. Aktualisiere mal den Original-Datenpunkt ohne den Wert zu ändern mit "Bestätigt".

                            D Offline
                            D Offline
                            DGR
                            schrieb am zuletzt editiert von
                            #18

                            @paul53
                            Wie meinst du das mit Aktualisieren des Datenpunktes ? Das ist ein Sensor, der aktuell nicht erreichbar ist.
                            Bestätigt ist "true".

                            paul53P 1 Antwort Letzte Antwort
                            0
                            • D DGR

                              @paul53
                              Wie meinst du das mit Aktualisieren des Datenpunktes ? Das ist ein Sensor, der aktuell nicht erreichbar ist.
                              Bestätigt ist "true".

                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von
                              #19

                              @dgr sagte: Wie meinst du das mit Aktualisieren des Datenpunktes ?

                              Im Tab "Objekte" den existierenden Wert mit Bestätigt "true" noch mal absenden, damit getriggert wird (für den Alias).

                              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                              1 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @dgr sagte: seltsam: "Zuletzt geändert: 2022-03-23

                                Was ist daran seltsam? Immer noch 100 % (keine Wertänderung).

                                "indicator.reachable" wurde durch ein Skript aktualisiert!

                                D Offline
                                D Offline
                                DGR
                                schrieb am zuletzt editiert von
                                #20

                                @paul53
                                ein Datenpunkt eines Sensors, der aktuell nicht erreichbar ist. Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                                paul53P 1 Antwort Letzte Antwort
                                0
                                • D DGR

                                  @paul53
                                  ein Datenpunkt eines Sensors, der aktuell nicht erreichbar ist. Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  schrieb am zuletzt editiert von paul53
                                  #21

                                  @dgr sagte: Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                                  Ja, mittels Skript. Ist "reachable" nicht "read only" (indicator)?

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  D 1 Antwort Letzte Antwort
                                  0
                                  • paul53P paul53

                                    @dgr sagte: Es wurde "reachable" für die Darstellung in vis auf "falsch" gesetzt, weil nicht erreichbar.

                                    Ja, mittels Skript. Ist "reachable" nicht "read only" (indicator)?

                                    D Offline
                                    D Offline
                                    DGR
                                    schrieb am zuletzt editiert von DGR
                                    #22

                                    @paul53
                                    funktioniert ! Anderer Sensor (ist erreichbar):
                                    reachable_steuern.JPG

                                    paul53P 1 Antwort Letzte Antwort
                                    0
                                    • D DGR

                                      @paul53
                                      funktioniert ! Anderer Sensor (ist erreichbar):
                                      reachable_steuern.JPG

                                      paul53P Offline
                                      paul53P Offline
                                      paul53
                                      schrieb am zuletzt editiert von paul53
                                      #23

                                      @dgr sagte: Anderer Sensor (ist erreichbar):

                                      Man sollte einen "read only" Datenpunkt eines Adapters nicht per Skript schreiben. Die gehören dem Adapter!

                                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                      D 1 Antwort Letzte Antwort
                                      0
                                      • paul53P paul53

                                        @dgr sagte: Anderer Sensor (ist erreichbar):

                                        Man sollte einen "read only" Datenpunkt eines Adapters nicht per Skript schreiben. Die gehören dem Adapter!

                                        D Offline
                                        D Offline
                                        DGR
                                        schrieb am zuletzt editiert von
                                        #24

                                        @paul53
                                        dann werde ich mir wohl für die Erreichbarkeit der Adapter eigene Datenpunkte anlegen müssen.
                                        War das nun die Ursache für die Unterschiede Objekt-Alias ?
                                        Ich teste das mal und melde mich mit den Ergebnissen (kann aber dauern).

                                        1 Antwort Letzte Antwort
                                        0
                                        • htreckslerH htrecksler

                                          @brainbug muss es unbedingt Blockly sein?
                                          Bei mir läuft ein javascript welches einen Bodenfeuchtesensor überwacht.
                                          Hab ich irgendwann mal hier im Forum gefunden und es läuft recht zuverlässig, ist jedoch kein Blockly.

                                          //Das Script überprüft regelmässig die Datenpunkte auf Aktualisierung
                                           
                                          //Angabe des Datenpunkts= Datenpunkt der Überwacht werden soll
                                          //StateBezeichnung= Unter pfad_javascript.StateBezeichung wird ein State angelegt; True = Daten sind aktuell / False = Daten veraltet
                                          //Zeit in Sekunden = Zeit die vergangen sein darf seit der letzen Aktualisierung des Datenpunkts  (0 = default Zeit wird genommen).
                                           
                                          schedule("*/3 * * * *" , function () {                                  
                                           
                                              // Angabe des Datenpunkts;StateBezeichnung;Zeit in Sekunden
                                              var ueberwachung = ['mqtt.0.Sensoren.Sensor03.Feuchtigkeit;Bodenfeuchte_Hinten;660', 
                                                                  'mqtt.0.Sensoren.Sensor02.Feuchtigkeit;Bodenfeuchte_Vorne;660'];
                                          
                                           
                                              var default_zeit = 400;
                                              var pfad_userdata ='0_userdata.0.watchdog.';   // !Punkt nicht vergessen am Ende!
                                           
                                           
                                              //------------------------------------------------------------------
                                              //Ab hier nichts mehr Ändern
                                              //------------------------------------------------------------------
                                              var zeit= Math.floor(Date.now() / 1000);
                                              var differenz, lchange;
                                              var daten, tchange;
                                           
                                              ueberwachung.forEach(function(item, index, array) 
                                              {
                                                  // Array Splitten
                                                     daten = item.split(";");
                                           
                                                  //Datenpunkt erstellen wenn nicht vorhanden
                                                      createState(pfad_userdata + daten[1], { read: true, write: false, name: "Watchdog " + daten[1], type: "boolean", role: " ", def: "false"});
                                           
                                                  //Differenz Zeit default oder manuell?
                                                      differenz = parseInt(daten[2]);
                                                      if (differenz == 0) differenz=default_zeit;
                                           
                                                  //Zeitstempel abfragen in Sekunden
                                                      tchange=parseInt(getState(daten[0]).ts / 1000);
                                                      
                                                  //Vergleichen der Zeitstempel
                                                          if ((zeit-tchange)>differenz)
                                                          {
                                                              setState(pfad_userdata + daten[1], false);
                                                              //setState("telegram.0.communicate.response", daten[1] + ' - ' + "Info: Sensor nicht erreichbar");
                                                              //console.log(daten[1] + "  ist älter als " + differenz + " Sekunden", 'warn');
                                                          }
                                                          else
                                                          {
                                                              setState(pfad_userdata + daten[1], true);
                                                              //console.log(daten[1] + "  ist jünger als " + differenz + " Sekunden");
                                                          } 
                                           
                                              });  
                                          });
                                           
                                          
                                          
                                          H Offline
                                          H Offline
                                          hmarius1
                                          schrieb am zuletzt editiert von
                                          #25

                                          @htrecksler ich habe das mal ein bisschen überarbeitet. Der createState war nicht korrekte und das Log hat Fehler geworfen. Das Objekt was angelegt wurde war nur Read Only.

                                          Hier die angepasste Version:

                                          //Das Script überprüft regelmässig die Datenpunkte auf Aktualisierung
                                          
                                           
                                          
                                          //Angabe des Datenpunkts= Datenpunkt der Überwacht werden soll
                                          
                                          //StateBezeichnung= Unter pfad_javascript.StateBezeichung wird ein State angelegt; True = Daten sind aktuell / False = Daten veraltet
                                          
                                          //Zeit in Sekunden = Zeit die vergangen sein darf seit der letzen Aktualisierung des Datenpunkts  (0 = default Zeit wird genommen).
                                          
                                           
                                          
                                          schedule("*/3 * * * *" , function () {                                  
                                          
                                           
                                          
                                              // Angabe des Datenpunkts;StateBezeichnung;Zeit in Sekunden
                                          
                                              var ueberwachung = ['mqtt.0.Wetterstation.Batterie;Wetterstation;440'];
                                          
                                           
                                          
                                           
                                          
                                              var default_zeit = 400;
                                          
                                              var pfad_userdata ='0_userdata.0.watchdog.';   // !Punkt nicht vergessen am Ende!
                                          
                                           
                                          
                                           
                                          
                                              //------------------------------------------------------------------
                                          
                                              //Ab hier nichts mehr Ändern
                                          
                                              //------------------------------------------------------------------
                                          
                                              var zeit= Math.floor(Date.now() / 1000);
                                          
                                              var differenz, lchange;
                                          
                                              var daten, tchange;
                                          
                                           
                                          
                                              ueberwachung.forEach(function(item, index, array) 
                                          
                                              {
                                          
                                                  // Array Splitten
                                          
                                                     daten = item.split(";");
                                          
                                           
                                          
                                                  //Datenpunkt erstellen wenn nicht vorhanden
                                          
                                                      createState(pfad_userdata + daten[1], {
                                                          read: true,
                                                          write: true,
                                                          name: "Watchdog " + daten[1],
                                                          type: "boolean",
                                                          def: false
                                                      } )
                                          
                                           
                                          
                                                  //Differenz Zeit default oder manuell?
                                          
                                                      differenz = parseInt(daten[2]);
                                          
                                                      if (differenz == 0) differenz=default_zeit;
                                          
                                           
                                          
                                                  //Zeitstempel abfragen in Sekunden
                                          
                                                      tchange=parseInt(getState(daten[0]).ts / 1000);
                                          
                                                      
                                          
                                                  //Vergleichen der Zeitstempel
                                          
                                                          if ((zeit-tchange)>differenz)
                                          
                                                          {
                                          
                                                              setState(pfad_userdata + daten[1], false);
                                          
                                                              //setState("telegram.0.communicate.response", daten[1] + ' - ' + "Info: Sensor nicht erreichbar");
                                          
                                                              //console.log(daten[1] + "  ist älter als " + differenz + " Sekunden", 'warn');
                                          
                                                          }
                                          
                                                          else
                                          
                                                          {
                                          
                                                              setState(pfad_userdata + daten[1], true);
                                          
                                                              //console.log(daten[1] + "  ist jünger als " + differenz + " Sekunden");
                                          
                                                          } 
                                          
                                           
                                          
                                              });  
                                          
                                          });
                                          
                                          1 Antwort Letzte Antwort
                                          1
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          335

                                          Online

                                          32.5k

                                          Benutzer

                                          81.8k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe