Navigation

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

    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

    Abfrage der Erreichbarkeit der Sensoren

    This topic has been deleted. Only users with topic management privileges can see it.
    • ?
      A Former User @DGR last edited by

      @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 Reply Last reply Reply Quote 0
      • paul53
        paul53 @DGR last edited by

        @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 2 Replies Last reply Reply Quote 0
        • D
          DGR @paul53 last edited by

          @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 Reply Last reply Reply Quote 0
          • D
            DGR @Guest last edited by DGR

            @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 Reply Last reply Reply Quote 0
            • ?
              A Former User last edited by A Former User

              @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 Reply Last reply Reply Quote 0
              • D
                DGR @Guest last edited by

                @brainbug
                auch 26.05.22
                Zeitstempel.JPG

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

                andere Zeitstempel:
                Zeitstempel3.JPG Zeitstempel2.JPG

                paul53 1 Reply Last reply Reply Quote 0
                • D
                  DGR @paul53 last edited by

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

                  paul53 1 Reply Last reply Reply Quote 0
                  • paul53
                    paul53 @DGR last edited by 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 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @DGR last edited by 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 1 Reply Last reply Reply Quote 0
                      • D
                        DGR @paul53 last edited by

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

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

                          @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).

                          1 Reply Last reply Reply Quote 0
                          • D
                            DGR @paul53 last edited by

                            @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.

                            paul53 1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 @DGR last edited by 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 1 Reply Last reply Reply Quote 0
                              • D
                                DGR @paul53 last edited by DGR

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

                                paul53 1 Reply Last reply Reply Quote 0
                                • paul53
                                  paul53 @DGR last edited by 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 1 Reply Last reply Reply Quote 0
                                  • D
                                    DGR @paul53 last edited by

                                    @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 Reply Last reply Reply Quote 0
                                    • H
                                      hmarius1 @htrecksler last edited by

                                      @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 Reply Last reply Reply Quote 1
                                      • First post
                                        Last post

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      906
                                      Online

                                      31.9k
                                      Users

                                      80.2k
                                      Topics

                                      1.3m
                                      Posts

                                      blockly
                                      5
                                      25
                                      1961
                                      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