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. JavaScript
  5. Zigbee-Geräte überwachen

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.2k

Zigbee-Geräte überwachen

Geplant Angeheftet Gesperrt Verschoben JavaScript
130 Beiträge 17 Kommentatoren 17.9k Aufrufe 31 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.
  • J JohannesA

    @ciddi89
    Guten Morgen!
    Danke für die Erklärung! Diese Funktion wird so also nur einmal ausgeführt. richtig? Also wenn ich zum Beispiel den Raspi neu starte, oder auch nur den JavaScript-Adapter.
    Das ist perfekt, genau das brauche ich noch wo anders um den Zeitpunkt des letzten Neustarts umzuwandeln. :grinning: So kommt eines zum anderen.

    Mir ist heute früh noch aufgefallen, dass die Visualisierung die JSON-Table in Jarvis nicht richtig dargestellt hat. Hatte zwar keine Zeit mehr dem genauer nachzugehen bevor ich ins Büro musste, aber es lässt mir keine Ruhe. Ich hab schnell die Quelltexte verglichen und vermute, dass es daran liegt:

    Zugeordneten Raum suchen - bei mir:

    currRoom = getObject(id, 'rooms').enumNames[0].de;
    

    Zugeordneten Raum suchen - bei dir:

    currRoom = getObject(id, 'rooms').enumNames[0];
    

    Ich vermute, dass es daran liegt, denn genau die Raumzuordnung hat mich ganz schön Nerven gekostet.

    Weil ich Räume selber angelegt habe (Kinderzimmer den Namen zugeordnet) musste ich im Expertenmodus unter "enums.rooms" von ioBroker bei den selber erstellten Räumen die "de"-Bezeichnung in den Objektdaten dazu anlegen. (das werde mein Leben lang auswendig wissen :smiley: ).

    Den Thread wo ich das herhab finde ich gerade nicht, aber es entstand dadurch dass ich selbst erstellte und vordefinierte Räume gemischt hab.

    Wenn ich mich recht erinnere haben die "Standard"-Räume den Namen mit "name: (de=Küche,en=Kitchen,etc...)" angegeben und selber definierte nur "name:eigenerRaum" oder "name:(en=eigenerRaum)" oder so ähnlich. da müsste ich am Abend nochmal im Detail schauen.

    Jedenfalls schätze ich dass das ".de" hinten dran soll. oder man fragt ab was bei deinem Code retour kommt und nimmt gegebenenfalls das Ergebnis von meinem. :)

    Werds mir am Abend nochmal ansehen und den Beitrag ergänzen. :+1:

    ? Offline
    ? Offline
    Ein ehemaliger Benutzer
    schrieb am zuletzt editiert von
    #17

    @johannesa said in Zigbee-Geräte überwachen:

    Diese Funktion wird so also nur einmal ausgeführt. richtig?

    Genau das ist richtig! Habe es in meinen Codetags auch nochmal so angepasst wie Paul geschrieben hatte. Also ohne Variabel da diese dann ja wirklich unnötig ist.

    Ah okay danke für deine Erklärung. Das kann dann auf jeden fall daran liegen. Ich habe es nur rausgenommen, da bei mir ein Fehler kommt wenn ich es drin lasse. Wahrscheinlich weil es bei mir nirgends so deklariert ist wie du es beschrieben hast. Dann müsstest du für dich das '.de' wieder da hintersetzen.

    bahnuhrB 1 Antwort Letzte Antwort
    0
    • ? Ein ehemaliger Benutzer

      @johannesa said in Zigbee-Geräte überwachen:

      Diese Funktion wird so also nur einmal ausgeführt. richtig?

      Genau das ist richtig! Habe es in meinen Codetags auch nochmal so angepasst wie Paul geschrieben hatte. Also ohne Variabel da diese dann ja wirklich unnötig ist.

      Ah okay danke für deine Erklärung. Das kann dann auf jeden fall daran liegen. Ich habe es nur rausgenommen, da bei mir ein Fehler kommt wenn ich es drin lasse. Wahrscheinlich weil es bei mir nirgends so deklariert ist wie du es beschrieben hast. Dann müsstest du für dich das '.de' wieder da hintersetzen.

      bahnuhrB Online
      bahnuhrB Online
      bahnuhr
      Forum Testing Most Active
      schrieb am zuletzt editiert von
      #18

      @ciddi89

      Du kannst es auch noch einfacher machen.
      Timeout brauchst du dort nicht.

          log("Run Zigbee-Watchdog");
          zigbeeWatchdog();
      

      Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
      Danke.
      gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
      ScreenToGif :https://www.screentogif.com/downloads.html

      ? 1 Antwort Letzte Antwort
      0
      • bahnuhrB bahnuhr

        @ciddi89

        Du kannst es auch noch einfacher machen.
        Timeout brauchst du dort nicht.

            log("Run Zigbee-Watchdog");
            zigbeeWatchdog();
        
        ? Offline
        ? Offline
        Ein ehemaliger Benutzer
        schrieb am zuletzt editiert von
        #19

        @bahnuhr danke das weiss ich. :D Ich weiss ehrlich gesagt in Moment garnicht mehr woher ich das habe aber irgendwie habe ich das bei allen mein Skripten, das ich den paar ms zeit lasse nach Skriptstart um ausgeführt zu werden. Ich glaube ich hatte da mal was aufgeschnappt das beim neu starten nicht alles auf einmal dann abgefragt wird wegen Auslastung und so. Ob es wirklich Sinn macht ist die andere Sache. Aber das kann ja bestimmt einer sagen der mehr Ahnung davon hat. :)

        bahnuhrB paul53P 2 Antworten Letzte Antwort
        0
        • ? Ein ehemaliger Benutzer

          @bahnuhr danke das weiss ich. :D Ich weiss ehrlich gesagt in Moment garnicht mehr woher ich das habe aber irgendwie habe ich das bei allen mein Skripten, das ich den paar ms zeit lasse nach Skriptstart um ausgeführt zu werden. Ich glaube ich hatte da mal was aufgeschnappt das beim neu starten nicht alles auf einmal dann abgefragt wird wegen Auslastung und so. Ob es wirklich Sinn macht ist die andere Sache. Aber das kann ja bestimmt einer sagen der mehr Ahnung davon hat. :)

          bahnuhrB Online
          bahnuhrB Online
          bahnuhr
          Forum Testing Most Active
          schrieb am zuletzt editiert von
          #20

          @ciddi89 sagte in Zigbee-Geräte überwachen:

          das beim neu starten nicht alles auf einmal dann abgefragt

          Das stimmt natürlich. Wenn das komplette System neu startet, dann starten die Scripte gleichzeitig.


          Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
          Danke.
          gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
          ScreenToGif :https://www.screentogif.com/downloads.html

          1 Antwort Letzte Antwort
          0
          • frana120500F Offline
            frana120500F Offline
            frana120500
            schrieb am zuletzt editiert von
            #21

            Moin zusammen,
            wie kann ich denn aus der json, die jetzt beispielsweise in "devices_offline_list" steht, das so extrahieren, dass er mir eine Telegram Benachrichtigung sendet?

            J 1 Antwort Letzte Antwort
            0
            • ? Ein ehemaliger Benutzer

              @bahnuhr danke das weiss ich. :D Ich weiss ehrlich gesagt in Moment garnicht mehr woher ich das habe aber irgendwie habe ich das bei allen mein Skripten, das ich den paar ms zeit lasse nach Skriptstart um ausgeführt zu werden. Ich glaube ich hatte da mal was aufgeschnappt das beim neu starten nicht alles auf einmal dann abgefragt wird wegen Auslastung und so. Ob es wirklich Sinn macht ist die andere Sache. Aber das kann ja bestimmt einer sagen der mehr Ahnung davon hat. :)

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

              @ciddi89 sagte: paar ms zeit lasse nach Skriptstart um ausgeführt zu werden.

              Das ist wegen der asynchronen createState(), die fertig sein müssen, wenn auf die Datenpunkte mit getState() / setState() zugegriffen wird.

              @johannesa sagte in Zigbee-Geräte überwachen:

              die Raumzuordnung hat mich ganz schön Nerven gekostet.

              Mache es so:

                      currRoom = getObject(id, 'rooms').enumNames[0];
                      if(typeof currRoom == 'object') currRoom = currRoom.de;
              

              Damit sind beide Fälle abgedeckt.

              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

                @ciddi89 sagte: paar ms zeit lasse nach Skriptstart um ausgeführt zu werden.

                Das ist wegen der asynchronen createState(), die fertig sein müssen, wenn auf die Datenpunkte mit getState() / setState() zugegriffen wird.

                @johannesa sagte in Zigbee-Geräte überwachen:

                die Raumzuordnung hat mich ganz schön Nerven gekostet.

                Mache es so:

                        currRoom = getObject(id, 'rooms').enumNames[0];
                        if(typeof currRoom == 'object') currRoom = currRoom.de;
                

                Damit sind beide Fälle abgedeckt.

                ? Offline
                ? Offline
                Ein ehemaliger Benutzer
                schrieb am zuletzt editiert von
                #23

                @paul53 Vielen dank für deine Erklärung und dein Hinweis. Habe es mit eingefügt. :) Ich hoffe ja das ich irgendwann auch nur einen Bruchteil von dem kann was du in Javascript kannst. :D

                @JohannesA Habe es in den Script, welches ich weiter oben gepostet habe ergänzt. Vielleicht kannst du ja prüfen ob es jetzt bei dir funktioniert?

                amg_666A 1 Antwort Letzte Antwort
                0
                • ? Ein ehemaliger Benutzer

                  @paul53 Vielen dank für deine Erklärung und dein Hinweis. Habe es mit eingefügt. :) Ich hoffe ja das ich irgendwann auch nur einen Bruchteil von dem kann was du in Javascript kannst. :D

                  @JohannesA Habe es in den Script, welches ich weiter oben gepostet habe ergänzt. Vielleicht kannst du ja prüfen ob es jetzt bei dir funktioniert?

                  amg_666A Offline
                  amg_666A Offline
                  amg_666
                  schrieb am zuletzt editiert von
                  #24

                  @JohannesA
                  Beim Starten lief das Skirpt mit den oben erwähnten diversen Warnungen durch und die DP wurden angelegt.
                  Dann passiert aber nichts mehr, die DP bleiben leer und er loggt jede Menge Fehler:

                  javascript.0
                  	2022-02-04 12:06:00.036	error	at processTimers (internal/timers.js:500:7)
                  javascript.0
                  	2022-02-04 12:06:00.035	error	at listOnTimeout (internal/timers.js:557:17)
                  javascript.0
                  	2022-02-04 12:06:00.035	error	at Timeout._onTimeout (/opt/iobroker/node_modules/node-schedule/lib/Invocation.js:228:7)
                  javascript.0
                  	2022-02-04 12:06:00.035	error	at /opt/iobroker/node_modules/node-schedule/lib/Invocation.js:268:28
                  javascript.0
                  	2022-02-04 12:06:00.035	error	at Job.invoke (/opt/iobroker/node_modules/node-schedule/lib/Job.js:168:15)
                  javascript.0
                  	2022-02-04 12:06:00.035	error	at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1316:34)
                  javascript.0
                  	2022-02-04 12:06:00.035	error	at Object.<anonymous> (script.js.Tests.zigbee_watchdog:243:5)
                  javascript.0
                  	2022-02-04 12:06:00.034	error	at zigbeeWatchdog (script.js.Tests.zigbee_watchdog:83:12)
                  javascript.0
                  	2022-02-04 12:06:00.034	error	at Object.result.each (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:814:29)
                  javascript.0
                  	2022-02-04 12:06:00.034	error	at script.js.Tests.zigbee_watchdog:89:55
                  javascript.0
                  	2022-02-04 12:06:00.033	error	script.js.Tests.zigbee_watchdog: TypeError: Cannot read property 'de' of undefined
                  javascript.0
                  	2022-02-04 12:06:00.021	info	script.js.Tests.zigbee_watchdog: Run Zigbee-Watchdog
                  

                  Das ist der Teil des Scripts:

                      zigbee.each(function (id, i) {
                  
                          currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                  
                          deviceName=getObject(currDeviceString).common.name
                  
                          currRoom = getObject(id, 'rooms').enumNames[0].de;
                  

                  wo es bei mir keine Raumzuordnung auf die zigbee devices gibt. Vielleicht hab ichs überlesen, aber der Hinweis, dass das gefüllt sein muss wäre gut...

                  iobroker auf proxmox container

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • amg_666A amg_666

                    @JohannesA
                    Beim Starten lief das Skirpt mit den oben erwähnten diversen Warnungen durch und die DP wurden angelegt.
                    Dann passiert aber nichts mehr, die DP bleiben leer und er loggt jede Menge Fehler:

                    javascript.0
                    	2022-02-04 12:06:00.036	error	at processTimers (internal/timers.js:500:7)
                    javascript.0
                    	2022-02-04 12:06:00.035	error	at listOnTimeout (internal/timers.js:557:17)
                    javascript.0
                    	2022-02-04 12:06:00.035	error	at Timeout._onTimeout (/opt/iobroker/node_modules/node-schedule/lib/Invocation.js:228:7)
                    javascript.0
                    	2022-02-04 12:06:00.035	error	at /opt/iobroker/node_modules/node-schedule/lib/Invocation.js:268:28
                    javascript.0
                    	2022-02-04 12:06:00.035	error	at Job.invoke (/opt/iobroker/node_modules/node-schedule/lib/Job.js:168:15)
                    javascript.0
                    	2022-02-04 12:06:00.035	error	at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1316:34)
                    javascript.0
                    	2022-02-04 12:06:00.035	error	at Object.<anonymous> (script.js.Tests.zigbee_watchdog:243:5)
                    javascript.0
                    	2022-02-04 12:06:00.034	error	at zigbeeWatchdog (script.js.Tests.zigbee_watchdog:83:12)
                    javascript.0
                    	2022-02-04 12:06:00.034	error	at Object.result.each (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:814:29)
                    javascript.0
                    	2022-02-04 12:06:00.034	error	at script.js.Tests.zigbee_watchdog:89:55
                    javascript.0
                    	2022-02-04 12:06:00.033	error	script.js.Tests.zigbee_watchdog: TypeError: Cannot read property 'de' of undefined
                    javascript.0
                    	2022-02-04 12:06:00.021	info	script.js.Tests.zigbee_watchdog: Run Zigbee-Watchdog
                    

                    Das ist der Teil des Scripts:

                        zigbee.each(function (id, i) {
                    
                            currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                    
                            deviceName=getObject(currDeviceString).common.name
                    
                            currRoom = getObject(id, 'rooms').enumNames[0].de;
                    

                    wo es bei mir keine Raumzuordnung auf die zigbee devices gibt. Vielleicht hab ichs überlesen, aber der Hinweis, dass das gefüllt sein muss wäre gut...

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

                    @amg_666 sagte: wo es bei mir keine Raumzuordnung auf die zigbee devices gibt.

                    Dann erweitere um die Abfrage, ob Raum vorhanden / ein Objekt ist:

                            currRoom = getObject(id, 'rooms').enumNames[0];
                            if(typeof currRoom == 'object') currRoom = currRoom.de;
                    

                    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

                    amg_666A 1 Antwort Letzte Antwort
                    0
                    • J JohannesA

                      Hallo liebes Forum!

                      Nachdem die Kälte den Zigbee-Temperatursensor im Garten unwissentlich ausser Gefecht gesetzt hatte, habe ich mich daran gesetzt, sowas hinkünftig zu vermeiden.

                      Basierend auf das Script zur Überwachung von Zigbee-Geräten von @sebastian0010 (siehe Beitrag hier) habe ich einen umfassenden "Zigbee-Watchdog" gemacht.

                      Dieses überwacht sämtliche Geräte auf folgende Parameter:

                      a) wie lang liegt der letzte Kontakt zum Coordinator zurück
                      b) bei batteriebetriebenen Sensoren/Aktoren wird der Batteriezustand überwacht
                      c) die Signalqualität der Funkverbindung abgefragt

                      wodurch ich relativ schnell mitbekommen kann, dass ein Sensor ausfällt weil die Batterie plötzlich zusammengebrochen ist und sich nicht langsam entleert hat.

                      Die Daten werden dann im JSON-Format in vorgegebenen Datenpunkte gespeichert bzw. "Summen" in Datenpunkte abgelegt. Ich starte dieses Script immer 6 Minuten nach der vollen Stunde und visualisiere die Daten in Jarvis.

                      Dieses Script möchte ich hier zur Verfügung stellen - vielleicht kann es ja jemand brauchen.


                      Wichtig: Bitte die verbesserte Version von @ciddi89
                      aus diesem Beitrag verwenden!

                      Originalversion:

                      const basePath = "0_userdata.0.Steuerzentrale.ZigbeeWatchdog.";
                      const stateDevicesCount = basePath + "devices_count_all";
                      const stateDevicesLinkQuality = basePath + "devices_link_quality_list";
                      const stateDevicesOfflineCount = basePath + "devices_offline_count";
                      const stateDevicesOffline = basePath + "devices_offline_list";
                      const stateDevicesWithBatteryCount=basePath + "devices_battery_count";
                      const stateDevicesWithBattery=basePath + "devices_battery_list";
                      const stateDevicesInfoList=basePath + "devices_list_all";
                      const stateDevicesLastCheck=basePath + "lastCheck";
                       
                       
                      async function doStates(){
                       
                         if (!(await existsStateAsync(stateDevicesCount))) await createStateAsync(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' });
                         if (!(await existsStateAsync(stateDevicesLinkQuality))) await createStateAsync(stateDevicesLinkQuality, "", { read: true, write: true, desc: "Liste Geräte Signalstärke", name: "Liste Geräte Signalstärke", type: 'string' });
                         if (!(await existsStateAsync(stateDevicesOfflineCount))) await createStateAsync(stateDevicesOfflineCount, 0, { read: true, write: true, desc: "Anzahl Geräte offline", name: "Anzahl Geräte offline",type: 'number' });
                         if (!(await existsStateAsync(stateDevicesOffline))) await createStateAsync(stateDevicesOffline, "", { read: true, write: true, desc: "Liste Geräte offline", name: "Liste Geräte offline",type: 'string' });
                         if (!(await existsStateAsync(stateDevicesWithBattery))) await createStateAsync(stateDevicesWithBattery, "", {read: true, write: true, desc: "Liste Geräte mit Batterie", name: "Liste Geräte mit Batterie", type: 'string'});
                         if (!(await existsStateAsync(stateDevicesWithBatteryCount))) await createStateAsync(stateDevicesWithBatteryCount, 0, {read: true, write: true, desc: "Anzahl Geräte mit Batterie", name: "Anzahl Geräte mit Batterie", type: 'number'});
                         if (!(await existsStateAsync(stateDevicesInfoList))) await createStateAsync(stateDevicesInfoList, "", {read: true, write: true, desc: "Liste aller Geräte", name: "Liste aller Geräte", type: 'string'}); 
                         if (!(await existsStateAsync(stateDevicesLastCheck))) await createStateAsync(stateDevicesLastCheck, "", {read: true, write: true, desc: "Zeitpunkt letzter Überprüfung", name: "Zeitpunkt letzter Überprüfung", type: 'string'});
                       
                      }
                       
                       
                       
                      function zigbeeWatchdog() {
                       
                         let maxMinutes = 300; // "Gerät offline" - Wert in Minuten: Gilt erst, wenn Gerät länger als X Minuten keine Meldung gesendet hat 
                         let arrOfflineDevices = []; //JSON-Info alle offline-Geräte
                         let arrLinkQualityDevices = []; //JSON-Info alle offline-Geräte
                         let arrBatteryPowered = []; //JSON-Info alle batteriebetriebenen Geräte
                         let arrListAllDevices = []; //JSON-Info Gesamtliste mit Info je Gerät
                         let currDeviceString;
                         let currDeviceBatteryString;
                         let currRoom;
                         let deviceName;
                         let linkQuality;
                         let lastContact;
                         let lastContactString;
                         let offlineDevicesCount;
                         let deviceCounter=0;
                         let batteryPoweredCount=0;
                         let batteryHealth;
                       
                         const zigbee = $('zigbee.0.*.link_quality');
                       
                         zigbee.each(function (id, i) {
                             currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                             deviceName=getObject(currDeviceString).common.name
                             currRoom = getObject(id, 'rooms').enumNames[0];
                             if(typeof currRoom == 'object') currRoom = currRoom.de;
                       
                       
                       
                             // 1. Link-Qualität des Gerätes ermitteln
                             //---------------------------------------
                             
                             linkQuality=parseFloat((100/255 * getState(id).val).toFixed(2)) + "%"; // Linkqualität in % verwenden
                             //linkQuality=getState(id).val; // ALTERNATIV: Echt-Wert der Linkqualität (0-255) verwenden
                             
                             arrLinkQualityDevices.push({device: deviceName, room: currRoom, link_quality: linkQuality});
                       
                       
                             // 2. Wann bestand letzter Kontakt zum Gerät
                             //------------------------      
                             lastContact = Math.round((new Date() - new Date(getState(id).ts)) / 1000 / 60);
                             // 2b. wenn seit X Minuten kein Kontakt mehr besteht, nimm Gerät in Liste auf
                             //Rechne auf Tage um, wenn mehr als 48 Stunden seit letztem Kontakt vergangen sind
                             lastContactString=Math.round(lastContact) + " Minuten";
                             if (Math.round(lastContact) > 100) {
                                 lastContactString=Math.round(lastContact/60) + " Stunden";
                             } 
                             if (Math.round(lastContact/60) > 48) {
                                 lastContactString=Math.round(lastContact/60/24) + " Tagen";
                             } 
                             if ( lastContact > maxMinutes) {
                                 arrOfflineDevices.push({device: deviceName, room: currRoom, lastContact: lastContactString});
                             }
                       
                             // 3. Batteriestatus abfragen
                             currDeviceBatteryString=currDeviceString+".battery";
                             if (existsState(currDeviceBatteryString)) {
                                 batteryHealth=getState(currDeviceBatteryString).val + "%"; // Batteriestatus in %
                                 arrBatteryPowered.push({device: deviceName, room: currRoom, battery: batteryHealth});
                             } else batteryHealth="-";
                            
                         arrListAllDevices.push({device: deviceName, room: currRoom, battery: batteryHealth, lastContact: lastContactString, link_quality: linkQuality});
                       
                         });
                       
                       
                         // 1b. Zähle, wie viele Zigbee-Geräte existieren
                         //---------------------------------------------       
                         deviceCounter=arrLinkQualityDevices.length;
                             //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                             if (deviceCounter == 0) { 
                                 arrLinkQualityDevices.push({device: "--keine--", room: "", link_quality: ""})
                                 arrListAllDevices.push({device: "--keine--", room: "", battery: "", lastContact: "", link_quality: ""});
                             }
                       
                         // 2c. Wie viele Geräte sind offline?
                         //------------------------   
                         offlineDevicesCount=arrOfflineDevices.length;
                             //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                             if (offlineDevicesCount == 0) { 
                                 arrOfflineDevices.push({device: "--keine--", room: "", lastContact: ""})
                             }
                       
                         // 3c. Wie viele Geräte sind batteriebetrieben?
                         //------------------------   
                         batteryPoweredCount=arrBatteryPowered.length;
                             //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                             if (batteryPoweredCount == 0) { 
                                 arrBatteryPowered.push({device: "--keine--", room: "", battery: ""})
                             }
                       
                      /* Optionale Erweiterung, 02. März 2022
                          // Sende Benachrichtigungen falls sich die Anzahl der "Offline-Geräte" im Vergleich zur letzten Prüfung erhöht hat.
                          // Hinweis: 
                          // Der Datenpunkt "SendText2Log" wird bei mir von einem Blockly überwacht, welches bei Änderung den neuen Text per Telegram an mich weiterleitet
                       
                       let offlineDevicesCountOld = getState(stateDevicesOfflineCount).val;
                          if (offlineDevicesCount > offlineDevicesCountOld) {
                              //log("Anzahl Geräte hat sich geändert!");
                              let infotext = "Folgende " + offlineDevicesCount + " Geräte sind seit einiger Zeit nicht erreichbar: \n";
                              for (const id of arrOfflineDevices) {
                                  infotext = infotext + "\n" + id["device"] + " " + id["room"] + " (" + id["lastContact"] + ")";
                              }
                              log(infotext);
                              setState("0_userdata.0.LogMessages.SendText2Log", infotext);
                              setState("jarvis.0.addNotification", '{"title": "Zigbee-Netzwerk (' + formatDate(new Date(), "DD.MM.YYYY - hh:mm:ss") + ')","message":" ' + offlineDevicesCount + ' Geräte sind nicht erreichbar","display": "drawer"}');
                          }
                      */
                      
                         // SETZE STATES
                         setState(stateDevicesCount, deviceCounter);
                         setState(stateDevicesLinkQuality, JSON.stringify(arrLinkQualityDevices));
                         setState(stateDevicesOfflineCount, offlineDevicesCount);
                         setState(stateDevicesOffline, JSON.stringify(arrOfflineDevices));
                         setState(stateDevicesWithBatteryCount, batteryPoweredCount);
                         setState(stateDevicesWithBattery, JSON.stringify(arrBatteryPowered));
                         setState(stateDevicesInfoList, JSON.stringify(arrListAllDevices));
                         setState(stateDevicesLastCheck, [formatDate(new Date(), "DD.MM.YYYY"),' - ',formatDate(new Date(), "hh:mm:ss")].join(''));
                      }
                       
                      schedule("6 */1 * * *", async function () {
                         log("Run Zigbee-Watchdog");
                         await doStates().then(zigbeeWatchdog);
                      });
                       
                      setTimeout (async function () {
                         log("Run Zigbee-Watchdog");
                         await doStates().then(zigbeeWatchdog);
                      }, 300);
                      
                      
                      /* Optionale Erweiterung, 2. März 2022
                      //Script überprüft an vordefinierten Zeitpunkten den Batteriestand der Zigbee-Geräte  und macht entsprechend meldung, wenn der Batteriestatus unter x% fällt
                      // Hinweis: 
                      // Der Datenpunkt "SendText2Log" wird bei mir von einem Blockly überwacht, welches bei Änderung den neuen Text per Telegram an mich weiterleitet
                      // bei mir passiert dies 3x pro Woche
                       
                      schedule('{"time":{"exactTime":true,"start":"12:50"},"period":{"days":1,"dows":"[2,4,6]"}}', async function () {
                          //log("Anzahl Geräte hat sich geändert!");
                          const batteryWarningMin = 75; //Ab wie viel % Rest-Batteriestand soll gewarnt werden?
                          let weakCount = 0;
                          let batteryData = JSON.parse(getState(stateDevicesWithBattery).val);
                          let infotext = "Status Batterien: \n";
                          for (const id of batteryData) {
                              let batteryValue = id["battery"].replace("%", "");
                              if (batteryValue < batteryWarningMin) {
                                  infotext = infotext + "\n" + id["device"] + " " + id["room"] + " (" + id["battery"] + ")";
                                  ++weakCount;
                              }
                          }
                          log("Batteriezustand: " + infotext);
                          if (weakCount > 0) {
                              log("Batteriezustand: " + infotext);
                              setState("0_userdata.0.LogMessages.SendText2Log", infotext);
                              setState("jarvis.0.addNotification", '{"title": "Zigbee-Netzwerk (' + formatDate(new Date(), "DD.MM.YYYY - hh:mm:ss") + ')","message":" ' + weakCount + ' Geräte mit schwacher Batterie","display": "drawer"}');
                          } /*else {
                              setState("0_userdata.0.LogMessages.SendText2Log", "Batterien der Zigbee-Geräte in Ordnung");
                          }*/
                      });
                      */
                      
                      


                      Theoretisch sollte es "Plug & Play" sein, aber möglicherweise ist es dort und da nicht ganz "rund" oder fehlerfrei gelöst.
                      Ich habe erst mit diesem Vorhaben angefangen, mich mit Programmierung zu beschäftigen. :blush:

                      Ihr Profis hättet dies vermutlich in ein paar Minuten erledigt, für mich war es eine echte Herausforderung! :upside_down_face:

                      Aja, vielen Dank an alle für die tolle Arbeit hier und an alle bei denen ich abgekupfert und anhand deren Scripten ich ein bisschen was gelernt hab.

                      Liebe Grüße

                      Johannes

                      liv-in-skyL Offline
                      liv-in-skyL Offline
                      liv-in-sky
                      schrieb am zuletzt editiert von
                      #26

                      @johannesa

                      ich habe mal die erstellung der datenpunkte geändert - evtl willst du das so einfügen - dann kommt auch kein warning beim ersten mal

                      dii dp-erstellung werden in einer function abgelegt

                      async function doStates(){
                      
                      if (!(await existsStateAsync(stateDevicesCount))) await createStateAsync(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' });
                      
                      if (!(await existsStateAsync(stateDevicesLinkQuality))) await createStateAsync(stateDevicesLinkQuality, "", { read: true, write: true, desc: "Liste Geräte Signalstärke", name: "Liste Geräte Signalstärke", type: 'string' });
                      
                      if (!(await existsStateAsync(stateDevicesOfflineCount))) await createStateAsync(stateDevicesOfflineCount, 0, { read: true, write: true, desc: "Anzahl Geräte offline", name: "Anzahl Geräte offline",type: 'number' });
                      
                      if (!(await existsStateAsync(stateDevicesOffline))) await createStateAsync(stateDevicesOffline, " ", { read: true, write: true, desc: "Liste Geräte offline", name: "Liste Geräte offline",type: 'string' });
                      
                      if (!(await existsStateAsync(stateDevicesWithBattery))) await createStateAsync(stateDevicesWithBattery, "", {read: true, write: true, desc: "Liste Geräte mit Batterie", name: "Liste Geräte mit Batterie", type: 'string'});
                      
                      if (!(await existsStateAsync(stateDevicesWithBatteryCount))) await createStateAsync(stateDevicesWithBatteryCount, 0, {read: true, write: true, desc: "Anzahl Geräte mit Batterie", name: "Anzahl Geräte mit Batterie", type: 'number'});
                      
                      if (!(await existsStateAsync(stateDevicesInfoList))) await createStateAsync(stateDevicesInfoList, " ", {read: true, write: true, desc: "Liste aller Geräte", name: "Liste aller Geräte", type: 'string'});
                      
                      if (!(await existsStateAsync(stateDevicesLastCheck))) await createStateAsync(stateDevicesLastCheck, " ", {read: true, write: true, desc: "Zeitpunkt letzter Überprüfung", name: "Zeitpunkt letzter Überprüfung", type: 'string'});
                      }
                      

                      der aufruf im schedule ist dann anders:

                      
                      schedule("6 */1 * * *", async function () {
                      
                         log("Run Zigbee-Watchdog");
                         await doStates().then(zigbeeWatchdog);
                        // zigbeeWatchdog()
                      
                      });
                      

                      das .de musste ich auch raus tun bei den enums - evtl noch wissenswert - wenn man die enums noch anlegen muss, muss die javascript instanz neugestartet werden, sonst kommt undefined zurück

                      ps: danke fürs script

                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

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

                        War mal so Frei und habe nun alle Vorschläge schonmal mit reingenommen. Das mit der async Funktion hatte ich auch erst in betracht gezogen aber dann gelassen weil es dann ja auch ohne ging. Zumindest bei mir. Habe es nun aber übernommen. Danke @liv-in-sky 🙈

                        const basePath = "0_userdata.0.Steuerzentrale.ZigbeeWatchdog.";
                        const stateDevicesCount = basePath + "devices_count_all";
                        const stateDevicesLinkQuality = basePath + "devices_link_quality_list";
                        const stateDevicesOfflineCount = basePath + "devices_offline_count";
                        const stateDevicesOffline = basePath + "devices_offline_list";
                        const stateDevicesWithBatteryCount=basePath + "devices_battery_count";
                        const stateDevicesWithBattery=basePath + "devices_battery_list";
                        const stateDevicesInfoList=basePath + "devices_list_all";
                        const stateDevicesLastCheck=basePath + "lastCheck";
                        
                        
                        async function doStates(){
                        
                           if (!(await existsStateAsync(stateDevicesCount))) await createStateAsync(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' });
                           if (!(await existsStateAsync(stateDevicesLinkQuality))) await createStateAsync(stateDevicesLinkQuality, "", { read: true, write: true, desc: "Liste Geräte Signalstärke", name: "Liste Geräte Signalstärke", type: 'string' });
                           if (!(await existsStateAsync(stateDevicesOfflineCount))) await createStateAsync(stateDevicesOfflineCount, 0, { read: true, write: true, desc: "Anzahl Geräte offline", name: "Anzahl Geräte offline",type: 'number' });
                           if (!(await existsStateAsync(stateDevicesOffline))) await createStateAsync(stateDevicesOffline, "", { read: true, write: true, desc: "Liste Geräte offline", name: "Liste Geräte offline",type: 'string' });
                           if (!(await existsStateAsync(stateDevicesWithBattery))) await createStateAsync(stateDevicesWithBattery, "", {read: true, write: true, desc: "Liste Geräte mit Batterie", name: "Liste Geräte mit Batterie", type: 'string'});
                           if (!(await existsStateAsync(stateDevicesWithBatteryCount))) await createStateAsync(stateDevicesWithBatteryCount, 0, {read: true, write: true, desc: "Anzahl Geräte mit Batterie", name: "Anzahl Geräte mit Batterie", type: 'number'});
                           if (!(await existsStateAsync(stateDevicesInfoList))) await createStateAsync(stateDevicesInfoList, "", {read: true, write: true, desc: "Liste aller Geräte", name: "Liste aller Geräte", type: 'string'}); 
                           if (!(await existsStateAsync(stateDevicesLastCheck))) await createStateAsync(stateDevicesLastCheck, "", {read: true, write: true, desc: "Zeitpunkt letzter Überprüfung", name: "Zeitpunkt letzter Überprüfung", type: 'string'});
                        
                        }
                        
                        
                        
                        function zigbeeWatchdog() {
                        
                           let maxMinutes = 300; // "Gerät offline" - Wert in Minuten: Gilt erst, wenn Gerät länger als X Minuten keine Meldung gesendet hat 
                           let arrOfflineDevices = []; //JSON-Info alle offline-Geräte
                           let arrLinkQualityDevices = []; //JSON-Info alle offline-Geräte
                           let arrBatteryPowered = []; //JSON-Info alle batteriebetriebenen Geräte
                           let arrListAllDevices = []; //JSON-Info Gesamtliste mit Info je Gerät
                           let currDeviceString;
                           let currDeviceBatteryString;
                           let currRoom;
                           let deviceName;
                           let linkQuality;
                           let lastContact;
                           let lastContactString;
                           let offlineDevicesCount;
                           let deviceCounter=0;
                           let batteryPoweredCount=0;
                           let batteryHealth;
                        
                           const zigbee = $('zigbee.0.*.link_quality');
                        
                           zigbee.each(function (id, i) {
                               currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                               deviceName=getObject(currDeviceString).common.name
                               currRoom = getObject(id, 'rooms').enumNames[0];
                               if(typeof currRoom == 'object') currRoom = currRoom.de;
                        
                        
                        
                               // 1. Link-Qualität des Gerätes ermitteln
                               //---------------------------------------
                               
                               linkQuality=parseFloat((100/255 * getState(id).val).toFixed(2)) + "%"; // Linkqualität in % verwenden
                               //linkQuality=getState(id).val; // ALTERNATIV: Echt-Wert der Linkqualität (0-255) verwenden
                               
                               arrLinkQualityDevices.push({device: deviceName, room: currRoom, link_quality: linkQuality});
                        
                        
                               // 2. Wann bestand letzter Kontakt zum Gerät
                               //------------------------      
                               lastContact = Math.round((new Date() - new Date(getState(id).ts)) / 1000 / 60);
                               // 2b. wenn seit X Minuten kein Kontakt mehr besteht, nimm Gerät in Liste auf
                               //Rechne auf Tage um, wenn mehr als 48 Stunden seit letztem Kontakt vergangen sind
                               lastContactString=Math.round(lastContact) + " Minuten";
                               if (Math.round(lastContact) > 100) {
                                   lastContactString=Math.round(lastContact/60) + " Stunden";
                               } 
                               if (Math.round(lastContact/60) > 48) {
                                   lastContactString=Math.round(lastContact/60/24) + " Tagen";
                               } 
                               if ( lastContact > maxMinutes) {
                                   arrOfflineDevices.push({device: deviceName, room: currRoom, lastContact: lastContactString});
                               }
                        
                               // 3. Batteriestatus abfragen
                               currDeviceBatteryString=currDeviceString+".battery";
                               if (existsState(currDeviceBatteryString)) {
                                   batteryHealth=getState(currDeviceBatteryString).val + "%"; // Batteriestatus in %
                                   arrBatteryPowered.push({device: deviceName, room: currRoom, battery: batteryHealth});
                               } else batteryHealth="-";
                              
                           arrListAllDevices.push({device: deviceName, room: currRoom, battery: batteryHealth, lastContact: lastContactString, link_quality: linkQuality});
                        
                           });
                        
                        
                           // 1b. Zähle, wie viele Zigbee-Geräte existieren
                           //---------------------------------------------       
                           deviceCounter=arrLinkQualityDevices.length;
                               //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                               if (deviceCounter == 0) { 
                                   arrLinkQualityDevices.push({device: "--keine--", room: "", link_quality: ""})
                                   arrListAllDevices.push({device: "--keine--", room: "", battery: "", lastContact: "", link_quality: ""});
                               }
                        
                           // 2c. Wie viele Geräte sind offline?
                           //------------------------   
                           offlineDevicesCount=arrOfflineDevices.length;
                               //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                               if (offlineDevicesCount == 0) { 
                                   arrOfflineDevices.push({device: "--keine--", room: "", lastContact: ""})
                               }
                        
                           // 3c. Wie viele Geräte sind batteriebetrieben?
                           //------------------------   
                           batteryPoweredCount=arrBatteryPowered.length;
                               //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                               if (batteryPoweredCount == 0) { 
                                   arrBatteryPowered.push({device: "--keine--", room: "", battery: ""})
                               }
                        
                           // SETZE STATES
                           setState(stateDevicesCount, deviceCounter);
                           setState(stateDevicesLinkQuality, JSON.stringify(arrLinkQualityDevices));
                           setState(stateDevicesOfflineCount, offlineDevicesCount);
                           setState(stateDevicesOffline, JSON.stringify(arrOfflineDevices));
                           setState(stateDevicesWithBatteryCount, batteryPoweredCount);
                           setState(stateDevicesWithBattery, JSON.stringify(arrBatteryPowered));
                           setState(stateDevicesInfoList, JSON.stringify(arrListAllDevices));
                           setState(stateDevicesLastCheck, [formatDate(new Date(), "DD.MM.YYYY"),' - ',formatDate(new Date(), "hh:mm:ss")].join(''));
                        }
                        
                        schedule("6 */1 * * *", async function () {
                           log("Run Zigbee-Watchdog");
                           await doStates().then(zigbeeWatchdog);
                        });
                        
                        setTimeout (async function () {
                           log("Run Zigbee-Watchdog");
                           await doStates().then(zigbeeWatchdog);
                        }, 300);
                        

                        liv-in-skyL 1 Antwort Letzte Antwort
                        1
                        • ? Ein ehemaliger Benutzer

                          War mal so Frei und habe nun alle Vorschläge schonmal mit reingenommen. Das mit der async Funktion hatte ich auch erst in betracht gezogen aber dann gelassen weil es dann ja auch ohne ging. Zumindest bei mir. Habe es nun aber übernommen. Danke @liv-in-sky 🙈

                          const basePath = "0_userdata.0.Steuerzentrale.ZigbeeWatchdog.";
                          const stateDevicesCount = basePath + "devices_count_all";
                          const stateDevicesLinkQuality = basePath + "devices_link_quality_list";
                          const stateDevicesOfflineCount = basePath + "devices_offline_count";
                          const stateDevicesOffline = basePath + "devices_offline_list";
                          const stateDevicesWithBatteryCount=basePath + "devices_battery_count";
                          const stateDevicesWithBattery=basePath + "devices_battery_list";
                          const stateDevicesInfoList=basePath + "devices_list_all";
                          const stateDevicesLastCheck=basePath + "lastCheck";
                          
                          
                          async function doStates(){
                          
                             if (!(await existsStateAsync(stateDevicesCount))) await createStateAsync(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' });
                             if (!(await existsStateAsync(stateDevicesLinkQuality))) await createStateAsync(stateDevicesLinkQuality, "", { read: true, write: true, desc: "Liste Geräte Signalstärke", name: "Liste Geräte Signalstärke", type: 'string' });
                             if (!(await existsStateAsync(stateDevicesOfflineCount))) await createStateAsync(stateDevicesOfflineCount, 0, { read: true, write: true, desc: "Anzahl Geräte offline", name: "Anzahl Geräte offline",type: 'number' });
                             if (!(await existsStateAsync(stateDevicesOffline))) await createStateAsync(stateDevicesOffline, "", { read: true, write: true, desc: "Liste Geräte offline", name: "Liste Geräte offline",type: 'string' });
                             if (!(await existsStateAsync(stateDevicesWithBattery))) await createStateAsync(stateDevicesWithBattery, "", {read: true, write: true, desc: "Liste Geräte mit Batterie", name: "Liste Geräte mit Batterie", type: 'string'});
                             if (!(await existsStateAsync(stateDevicesWithBatteryCount))) await createStateAsync(stateDevicesWithBatteryCount, 0, {read: true, write: true, desc: "Anzahl Geräte mit Batterie", name: "Anzahl Geräte mit Batterie", type: 'number'});
                             if (!(await existsStateAsync(stateDevicesInfoList))) await createStateAsync(stateDevicesInfoList, "", {read: true, write: true, desc: "Liste aller Geräte", name: "Liste aller Geräte", type: 'string'}); 
                             if (!(await existsStateAsync(stateDevicesLastCheck))) await createStateAsync(stateDevicesLastCheck, "", {read: true, write: true, desc: "Zeitpunkt letzter Überprüfung", name: "Zeitpunkt letzter Überprüfung", type: 'string'});
                          
                          }
                          
                          
                          
                          function zigbeeWatchdog() {
                          
                             let maxMinutes = 300; // "Gerät offline" - Wert in Minuten: Gilt erst, wenn Gerät länger als X Minuten keine Meldung gesendet hat 
                             let arrOfflineDevices = []; //JSON-Info alle offline-Geräte
                             let arrLinkQualityDevices = []; //JSON-Info alle offline-Geräte
                             let arrBatteryPowered = []; //JSON-Info alle batteriebetriebenen Geräte
                             let arrListAllDevices = []; //JSON-Info Gesamtliste mit Info je Gerät
                             let currDeviceString;
                             let currDeviceBatteryString;
                             let currRoom;
                             let deviceName;
                             let linkQuality;
                             let lastContact;
                             let lastContactString;
                             let offlineDevicesCount;
                             let deviceCounter=0;
                             let batteryPoweredCount=0;
                             let batteryHealth;
                          
                             const zigbee = $('zigbee.0.*.link_quality');
                          
                             zigbee.each(function (id, i) {
                                 currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                                 deviceName=getObject(currDeviceString).common.name
                                 currRoom = getObject(id, 'rooms').enumNames[0];
                                 if(typeof currRoom == 'object') currRoom = currRoom.de;
                          
                          
                          
                                 // 1. Link-Qualität des Gerätes ermitteln
                                 //---------------------------------------
                                 
                                 linkQuality=parseFloat((100/255 * getState(id).val).toFixed(2)) + "%"; // Linkqualität in % verwenden
                                 //linkQuality=getState(id).val; // ALTERNATIV: Echt-Wert der Linkqualität (0-255) verwenden
                                 
                                 arrLinkQualityDevices.push({device: deviceName, room: currRoom, link_quality: linkQuality});
                          
                          
                                 // 2. Wann bestand letzter Kontakt zum Gerät
                                 //------------------------      
                                 lastContact = Math.round((new Date() - new Date(getState(id).ts)) / 1000 / 60);
                                 // 2b. wenn seit X Minuten kein Kontakt mehr besteht, nimm Gerät in Liste auf
                                 //Rechne auf Tage um, wenn mehr als 48 Stunden seit letztem Kontakt vergangen sind
                                 lastContactString=Math.round(lastContact) + " Minuten";
                                 if (Math.round(lastContact) > 100) {
                                     lastContactString=Math.round(lastContact/60) + " Stunden";
                                 } 
                                 if (Math.round(lastContact/60) > 48) {
                                     lastContactString=Math.round(lastContact/60/24) + " Tagen";
                                 } 
                                 if ( lastContact > maxMinutes) {
                                     arrOfflineDevices.push({device: deviceName, room: currRoom, lastContact: lastContactString});
                                 }
                          
                                 // 3. Batteriestatus abfragen
                                 currDeviceBatteryString=currDeviceString+".battery";
                                 if (existsState(currDeviceBatteryString)) {
                                     batteryHealth=getState(currDeviceBatteryString).val + "%"; // Batteriestatus in %
                                     arrBatteryPowered.push({device: deviceName, room: currRoom, battery: batteryHealth});
                                 } else batteryHealth="-";
                                
                             arrListAllDevices.push({device: deviceName, room: currRoom, battery: batteryHealth, lastContact: lastContactString, link_quality: linkQuality});
                          
                             });
                          
                          
                             // 1b. Zähle, wie viele Zigbee-Geräte existieren
                             //---------------------------------------------       
                             deviceCounter=arrLinkQualityDevices.length;
                                 //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                                 if (deviceCounter == 0) { 
                                     arrLinkQualityDevices.push({device: "--keine--", room: "", link_quality: ""})
                                     arrListAllDevices.push({device: "--keine--", room: "", battery: "", lastContact: "", link_quality: ""});
                                 }
                          
                             // 2c. Wie viele Geräte sind offline?
                             //------------------------   
                             offlineDevicesCount=arrOfflineDevices.length;
                                 //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                                 if (offlineDevicesCount == 0) { 
                                     arrOfflineDevices.push({device: "--keine--", room: "", lastContact: ""})
                                 }
                          
                             // 3c. Wie viele Geräte sind batteriebetrieben?
                             //------------------------   
                             batteryPoweredCount=arrBatteryPowered.length;
                                 //falls keine Geräte vorhanden sind, passe Datenpunkt-Inhalt der Geräte-Liste an
                                 if (batteryPoweredCount == 0) { 
                                     arrBatteryPowered.push({device: "--keine--", room: "", battery: ""})
                                 }
                          
                             // SETZE STATES
                             setState(stateDevicesCount, deviceCounter);
                             setState(stateDevicesLinkQuality, JSON.stringify(arrLinkQualityDevices));
                             setState(stateDevicesOfflineCount, offlineDevicesCount);
                             setState(stateDevicesOffline, JSON.stringify(arrOfflineDevices));
                             setState(stateDevicesWithBatteryCount, batteryPoweredCount);
                             setState(stateDevicesWithBattery, JSON.stringify(arrBatteryPowered));
                             setState(stateDevicesInfoList, JSON.stringify(arrListAllDevices));
                             setState(stateDevicesLastCheck, [formatDate(new Date(), "DD.MM.YYYY"),' - ',formatDate(new Date(), "hh:mm:ss")].join(''));
                          }
                          
                          schedule("6 */1 * * *", async function () {
                             log("Run Zigbee-Watchdog");
                             await doStates().then(zigbeeWatchdog);
                          });
                          
                          setTimeout (async function () {
                             log("Run Zigbee-Watchdog");
                             await doStates().then(zigbeeWatchdog);
                          }, 300);
                          

                          liv-in-skyL Offline
                          liv-in-skyL Offline
                          liv-in-sky
                          schrieb am zuletzt editiert von liv-in-sky
                          #28

                          @ciddi89

                          ich mache updates der scripte immer im ersten post - dann weiß man immer wo die aktuelle version liegt

                          dann verweiße ich zum ersten post , bei einer änderung

                          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                          ? 1 Antwort Letzte Antwort
                          0
                          • liv-in-skyL liv-in-sky

                            @ciddi89

                            ich mache updates der scripte immer im ersten post - dann weiß man immer wo die aktuelle version liegt

                            dann verweiße ich zum ersten post , bei einer änderung

                            ? Offline
                            ? Offline
                            Ein ehemaliger Benutzer
                            schrieb am zuletzt editiert von
                            #29

                            @liv-in-sky ja letztendlich liegt es ja an @JohannesA ob er das so übernimmt und wenn ja, kann er es ja im ersten Post ändern. Aber der kann erst heut Abend darüber schauen. Wollte nur schon mal die Arbeit abnehmen. 🙈

                            liv-in-skyL 1 Antwort Letzte Antwort
                            0
                            • paul53P paul53

                              @amg_666 sagte: wo es bei mir keine Raumzuordnung auf die zigbee devices gibt.

                              Dann erweitere um die Abfrage, ob Raum vorhanden / ein Objekt ist:

                                      currRoom = getObject(id, 'rooms').enumNames[0];
                                      if(typeof currRoom == 'object') currRoom = currRoom.de;
                              
                              amg_666A Offline
                              amg_666A Offline
                              amg_666
                              schrieb am zuletzt editiert von
                              #30

                              @paul53 Irgendwie kapier ich es nicht. Es liegt an

                                currRoom = getObject(id, 'rooms').enumNames[0].de;
                              

                              Wieso ".de" ? Ich hab das gelöscht und jetzt werden dei Datenpunkte korrekt befüllt.

                              iobroker auf proxmox container

                              paul53P 1 Antwort Letzte Antwort
                              0
                              • amg_666A amg_666

                                @paul53 Irgendwie kapier ich es nicht. Es liegt an

                                  currRoom = getObject(id, 'rooms').enumNames[0].de;
                                

                                Wieso ".de" ? Ich hab das gelöscht und jetzt werden dei Datenpunkte korrekt befüllt.

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

                                @amg_666 sagte: Ich hab das gelöscht und jetzt werden dei Datenpunkte korrekt befüllt.

                                Das ist o.k., wenn die Räume nicht benötigt werden / nicht zugewiesen sind.
                                Andernfalls mach die vorgeschlagene Änderung.

                                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
                                • ? Ein ehemaliger Benutzer

                                  @liv-in-sky ja letztendlich liegt es ja an @JohannesA ob er das so übernimmt und wenn ja, kann er es ja im ersten Post ändern. Aber der kann erst heut Abend darüber schauen. Wollte nur schon mal die Arbeit abnehmen. 🙈

                                  liv-in-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  schrieb am zuletzt editiert von
                                  #32

                                  @ciddi89 ok - thread inhaber und mit thread-poster verwechselt - sorry

                                  überlege gerade , ob man noch andere devices einbinden kann- wäre dann ja fast ein adapter wert :-)

                                  hatte erst gestern ein problem mit einem sonoff device - habe zwar eigene tabellen für die geräte, aber eine sammlung aller geräte, die offline sind, wäre schon nicht schlecht

                                  z.b https://forum.iobroker.net/topic/51217/html-tabelle-für-zigbee-devices-vis-übersicht

                                  theoretisch die verschieden device-selektoren als array eintragen - in diesem array definiert man, zum einen das device (sonoff,zigbee) und noch zusätzlich die definition des z.b device name - dann das ganze existierende in einer schleife über alle im array

                                  nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                  ? 1 Antwort Letzte Antwort
                                  0
                                  • liv-in-skyL liv-in-sky

                                    @ciddi89 ok - thread inhaber und mit thread-poster verwechselt - sorry

                                    überlege gerade , ob man noch andere devices einbinden kann- wäre dann ja fast ein adapter wert :-)

                                    hatte erst gestern ein problem mit einem sonoff device - habe zwar eigene tabellen für die geräte, aber eine sammlung aller geräte, die offline sind, wäre schon nicht schlecht

                                    z.b https://forum.iobroker.net/topic/51217/html-tabelle-für-zigbee-devices-vis-übersicht

                                    theoretisch die verschieden device-selektoren als array eintragen - in diesem array definiert man, zum einen das device (sonoff,zigbee) und noch zusätzlich die definition des z.b device name - dann das ganze existierende in einer schleife über alle im array

                                    ? Offline
                                    ? Offline
                                    Ein ehemaliger Benutzer
                                    schrieb am zuletzt editiert von Ein ehemaliger Benutzer
                                    #33

                                    @liv-in-sky said

                                    überlege gerade , ob man noch andere devices einbinden kann- wäre dann ja fast ein adapter wert :-)

                                    Die Idee hatte der threadersteller auch schon. Da könnte man wenigstens alle Devices zusammen fassen. (Ble, hm-ip, Zigbee usw.) Aber leider reichen unsere skills dafür nicht aus 😂

                                    liv-in-skyL 2 Antworten Letzte Antwort
                                    0
                                    • ? Ein ehemaliger Benutzer

                                      @liv-in-sky said

                                      überlege gerade , ob man noch andere devices einbinden kann- wäre dann ja fast ein adapter wert :-)

                                      Die Idee hatte der threadersteller auch schon. Da könnte man wenigstens alle Devices zusammen fassen. (Ble, hm-ip, Zigbee usw.) Aber leider reichen unsere skills dafür nicht aus 😂

                                      liv-in-skyL Offline
                                      liv-in-skyL Offline
                                      liv-in-sky
                                      schrieb am zuletzt editiert von liv-in-sky
                                      #34

                                      @ciddi89 glaube ich nicht :-)

                                      das schwierige ist nur - wie man die verschiedenen dp reinbringt und in den listen kommt dann noch ein punkt dazu - sonoff, zigbee,..), damit man das auch weiß, welches device es ist

                                      da ja der name des devices bei zigbee vom common.name kommt und bei sonoff vom dp ....hostname (sonoff ist da etwas doof, weil es drei verschiedene möglichkeiten geben kann, wo der hostname dp ist), wahrscheinlich muss dann wiederum mit selektoren arbeiten, die die richtigen dp finden

                                      liegt an euch, ob ihr lust habt, dass anzugehen - unterstützung bekommt ihr sicher von uns hier im forum

                                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                      paul53P 1 Antwort Letzte Antwort
                                      0
                                      • liv-in-skyL liv-in-sky

                                        @ciddi89 glaube ich nicht :-)

                                        das schwierige ist nur - wie man die verschiedenen dp reinbringt und in den listen kommt dann noch ein punkt dazu - sonoff, zigbee,..), damit man das auch weiß, welches device es ist

                                        da ja der name des devices bei zigbee vom common.name kommt und bei sonoff vom dp ....hostname (sonoff ist da etwas doof, weil es drei verschiedene möglichkeiten geben kann, wo der hostname dp ist), wahrscheinlich muss dann wiederum mit selektoren arbeiten, die die richtigen dp finden

                                        liegt an euch, ob ihr lust habt, dass anzugehen - unterstützung bekommt ihr sicher von uns hier im forum

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

                                        @liv-in-sky sagte: der name des devices bei zigbee

                                        Die Frage ist, ob es immer der Name des Device-Objektes sein soll, der angezeigt wird. Da es unterschiedlich viele Ebenen vom Datenpunkt bis zum Device-Objekt gibt, kann man das in einer Funktion berücksichtigen.

                                        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

                                        liv-in-skyL 1 Antwort Letzte Antwort
                                        0
                                        • paul53P paul53

                                          @liv-in-sky sagte: der name des devices bei zigbee

                                          Die Frage ist, ob es immer der Name des Device-Objektes sein soll, der angezeigt wird. Da es unterschiedlich viele Ebenen vom Datenpunkt bis zum Device-Objekt gibt, kann man das in einer Funktion berücksichtigen.

                                          liv-in-skyL Offline
                                          liv-in-skyL Offline
                                          liv-in-sky
                                          schrieb am zuletzt editiert von
                                          #36

                                          @paul53 genau darüber denke ich gerade nach :-)

                                          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          901

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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