Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Zigbee-Geräte überwachen

NEWS

  • Wartung am 15.11. – Forum ab 22:00 Uhr nicht erreichbar
    BluefoxB
    Bluefox
    12
    2
    248

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

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

Zigbee-Geräte überwachen

Zigbee-Geräte überwachen

Scheduled Pinned Locked Moved JavaScript
130 Posts 17 Posters 17.7k Views 31 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • J Offline
    J Offline
    JohannesA
    wrote on last edited by JohannesA
    #1

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

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

    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

    ? bahnuhrB liv-in-skyL A J 5 Replies Last reply
    5
    • 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. 😊

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

      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

      ? Offline
      ? Offline
      A Former User
      wrote on last edited by
      #2

      @johannesa Hey,

      vielen danke für das Skript! Das kommt gerade rechtzeitig, da bei mir ein Außensensor auch seit ein paar Tagen immer mal wieder aussteigt. Hatte auch schon an so ein Skript gedacht daher erspart mir das jetzt die Arbeit. 😄 Aber leider passt da irgend etwas noch nicht so richtig. Ich gucke mir das aber im laufe des Tages mal genauer an. Und gebe dann mal bescheid was es war.

      Wie gesagt danke noch einmal. 🙂

      Liebe Grüße

      Christian

      J 1 Reply Last reply
      0
      • ? A Former User

        @johannesa Hey,

        vielen danke für das Skript! Das kommt gerade rechtzeitig, da bei mir ein Außensensor auch seit ein paar Tagen immer mal wieder aussteigt. Hatte auch schon an so ein Skript gedacht daher erspart mir das jetzt die Arbeit. 😄 Aber leider passt da irgend etwas noch nicht so richtig. Ich gucke mir das aber im laufe des Tages mal genauer an. Und gebe dann mal bescheid was es war.

        Wie gesagt danke noch einmal. 🙂

        Liebe Grüße

        Christian

        J Offline
        J Offline
        JohannesA
        wrote on last edited by
        #3

        @ciddi89 Hallo Christian!

        Freut mich dass ich damit wem helfen konnte!

        Ich vermute dass deine Konfig anders ist als meine, bei mir läufts auf einem Raspi mit einem ConBee2 - Stick. Da kanns vielleicht zu Abweichungen bei den Datenpunkt-Bezeichnungen kommen, aber da endet meine Expertise dann auch schon. 😀

        Danke dass du mal drüber kontrollierst ob wo Fehler drin sind. Feedback und Verbesserungvorschläge sind gerne willkommen! Falls du Fragen hast, einfach melden.

        Der Auslöser für das Script war zwar der Temperaturfühler, aber wichtiger ist es eigentlich dass ich mitkrieg falls ein Wasserleck-Sensor oder ein Rauchmelder (die funken bei mir auch über ZigBee) aufgegeben hat.

        Bin gespannt wie das dann aussieht, wenns jemand macht, der Ahnung von Programmierung hat. 😇

        LG Johannes

        1 Reply Last reply
        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. 😊

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

          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

          bahnuhrB Offline
          bahnuhrB Offline
          bahnuhr
          Forum Testing Most Active
          wrote on last edited by
          #4

          @JohannesA

          Hallo Johannes,

          wenn ich diesen kleinen Teil ausführe (um DP zu erstellen):

          var basePath="0_userdata.0.Steuerzentrale.ZigbeeWatchdog.";
          var stateDevicesCount = basePath + "devices_count_all";
           
          if (getState(stateDevicesCount).notExist) createState(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' });
          
          

          kommt Fehler im log:

          javascript.0
          2022-02-03 09:31:21.745	warn	at script.js.Scripte.test7:8:3
          
          javascript.0
          2022-02-03 09:31:21.745	warn	at script.js.Scripte.test7:5:5
          
          javascript.0
          2022-02-03 09:31:21.739	warn	getState "0_userdata.0.Steuerzentrale.ZigbeeWatchdog.devices_count_all" not found (3)
          

          Ich dachte immer bisher, dass createstate unter "userdata" nicht geht.

          Geht dies nun doch?
          Aber warum bekomme ich Fehlermeldung?


          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

          ? paul53P 2 Replies Last reply
          0
          • bahnuhrB bahnuhr

            @JohannesA

            Hallo Johannes,

            wenn ich diesen kleinen Teil ausführe (um DP zu erstellen):

            var basePath="0_userdata.0.Steuerzentrale.ZigbeeWatchdog.";
            var stateDevicesCount = basePath + "devices_count_all";
             
            if (getState(stateDevicesCount).notExist) createState(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' });
            
            

            kommt Fehler im log:

            javascript.0
            2022-02-03 09:31:21.745	warn	at script.js.Scripte.test7:8:3
            
            javascript.0
            2022-02-03 09:31:21.745	warn	at script.js.Scripte.test7:5:5
            
            javascript.0
            2022-02-03 09:31:21.739	warn	getState "0_userdata.0.Steuerzentrale.ZigbeeWatchdog.devices_count_all" not found (3)
            

            Ich dachte immer bisher, dass createstate unter "userdata" nicht geht.

            Geht dies nun doch?
            Aber warum bekomme ich Fehlermeldung?

            ? Offline
            ? Offline
            A Former User
            wrote on last edited by A Former User
            #5

            @bahnuhr also bei mir kommt der Fehler nur wenn das Script das erste mal gestartet wird. Danach werden die Datenpunkte angelegt und der Fehler kommt auch nicht wieder. Also bei mir funktioniert createState generell in userdata.0. 🙈

            bahnuhrB 1 Reply Last reply
            0
            • ? A Former User

              @bahnuhr also bei mir kommt der Fehler nur wenn das Script das erste mal gestartet wird. Danach werden die Datenpunkte angelegt und der Fehler kommt auch nicht wieder. Also bei mir funktioniert createState generell in userdata.0. 🙈

              bahnuhrB Offline
              bahnuhrB Offline
              bahnuhr
              Forum Testing Most Active
              wrote on last edited by
              #6

              @ciddi89

              ja du hast recht.
              Beim 2 mal kam der Fehler nicht.
              Und DP wurde angelegt.

              mfg


              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

              bahnuhrB 1 Reply Last reply
              0
              • bahnuhrB bahnuhr

                @ciddi89

                ja du hast recht.
                Beim 2 mal kam der Fehler nicht.
                Und DP wurde angelegt.

                mfg

                bahnuhrB Offline
                bahnuhrB Offline
                bahnuhr
                Forum Testing Most Active
                wrote on last edited by
                #7

                Unter "alias" geht createstate nicht.
                Das hatte ich probiert.

                Wäre gut wenn es dort auch gehen würde.
                (gehört aber nicht hier rein 😉 )


                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 Reply Last reply
                0
                • ? Offline
                  ? Offline
                  A Former User
                  wrote on last edited by
                  #8

                  Soo habe mal ein paar Fehler korrigiert und ein bisschen ausgebessert was mir so auf den ersten Blick aufgefallen ist. 😃 Bin ja auch kein Profi aber man lernt ja immer dazu. Bei den Datenpunkterstellung waren bei 2-3 DPs der type falsch und auch ob er das erste mal mit 0 oder " " gefüttert werden soll. Den Fehler beim ersten Start habe ich wegbekommen, das die Datenpunkte noch nicht existieren und zusätzlich habe ich mir eine Funktion reingesetzt das er mir beim Start vom Skript schon mal die Datenpunkte befüttert. Jetzt meckert der Editor noch bei 3 Punkten und unterstreicht die Rot aber ich denke das kann man Ignorieren da es ja funktioniert. Wenn das Okay für dich ist @JohannesA, würde ich dann die von mir korrigierte Version hier runter setzen. 🙈

                  J 1 Reply Last reply
                  0
                  • bahnuhrB bahnuhr

                    @JohannesA

                    Hallo Johannes,

                    wenn ich diesen kleinen Teil ausführe (um DP zu erstellen):

                    var basePath="0_userdata.0.Steuerzentrale.ZigbeeWatchdog.";
                    var stateDevicesCount = basePath + "devices_count_all";
                     
                    if (getState(stateDevicesCount).notExist) createState(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' });
                    
                    

                    kommt Fehler im log:

                    javascript.0
                    2022-02-03 09:31:21.745	warn	at script.js.Scripte.test7:8:3
                    
                    javascript.0
                    2022-02-03 09:31:21.745	warn	at script.js.Scripte.test7:5:5
                    
                    javascript.0
                    2022-02-03 09:31:21.739	warn	getState "0_userdata.0.Steuerzentrale.ZigbeeWatchdog.devices_count_all" not found (3)
                    

                    Ich dachte immer bisher, dass createstate unter "userdata" nicht geht.

                    Geht dies nun doch?
                    Aber warum bekomme ich Fehlermeldung?

                    paul53P Offline
                    paul53P Offline
                    paul53
                    wrote on last edited by paul53
                    #9

                    @bahnuhr sagte:

                    if (getState(stateDevicesCount).notExist)
                    

                    Ersetze es durch

                    if (!existsState(stateDevicesCount))
                    

                    damit die Warnung auch beim ersten Mal ausbleibt.

                    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 Reply Last reply
                    0
                    • ? A Former User

                      Soo habe mal ein paar Fehler korrigiert und ein bisschen ausgebessert was mir so auf den ersten Blick aufgefallen ist. 😃 Bin ja auch kein Profi aber man lernt ja immer dazu. Bei den Datenpunkterstellung waren bei 2-3 DPs der type falsch und auch ob er das erste mal mit 0 oder " " gefüttert werden soll. Den Fehler beim ersten Start habe ich wegbekommen, das die Datenpunkte noch nicht existieren und zusätzlich habe ich mir eine Funktion reingesetzt das er mir beim Start vom Skript schon mal die Datenpunkte befüttert. Jetzt meckert der Editor noch bei 3 Punkten und unterstreicht die Rot aber ich denke das kann man Ignorieren da es ja funktioniert. Wenn das Okay für dich ist @JohannesA, würde ich dann die von mir korrigierte Version hier runter setzen. 🙈

                      J Offline
                      J Offline
                      JohannesA
                      wrote on last edited by JohannesA
                      #10

                      @ciddi89 Ja bitte - her damit! 🙂
                      Bin schon gespannt wie das Script jetzt aussieht! 😄
                      Sobald die Kinder im Bett sind und meine Frau General vorm Fernseher eingeschlafen ist, nutze ich die Zeit um dazuzulernen.

                      @paul53
                      Danke für den Hinweis! "exitsState" hab ich zwischendurch sogar schon mal verwendet um zu checken ob das Gerät den Datenpunkt für die Batterie hat. Da hätte ich selber auch drauf kommen können, dies gleich bei der Anlage zu verwenden! Aber wie @bahnuhr schon sagte, die Meldung kam dann ja nicht wieder. 😃

                      ? 1 Reply Last reply
                      0
                      • J JohannesA

                        @ciddi89 Ja bitte - her damit! 🙂
                        Bin schon gespannt wie das Script jetzt aussieht! 😄
                        Sobald die Kinder im Bett sind und meine Frau General vorm Fernseher eingeschlafen ist, nutze ich die Zeit um dazuzulernen.

                        @paul53
                        Danke für den Hinweis! "exitsState" hab ich zwischendurch sogar schon mal verwendet um zu checken ob das Gerät den Datenpunkt für die Batterie hat. Da hätte ich selber auch drauf kommen können, dies gleich bei der Anlage zu verwenden! Aber wie @bahnuhr schon sagte, die Meldung kam dann ja nicht wieder. 😃

                        ? Offline
                        ? Offline
                        A Former User
                        wrote on last edited by A Former User
                        #11

                        @johannesa ok gerne! Es sind bis jetzt ja nur Kleinigkeiten gewesen und davon wirklich nicht viele. Das mit der existsObject Funktion war ja auch meine erste Vermutung und Maßnahme um die Fehler im Log wegzubekommen beim ersten Start. Und da der Rest ja so funktioniert, ist ja alles Tip top und waren Schönheitskorrekturen. Nichts wildes. Wüsste auch erstmal nicht was man noch verbessern könnte. Aber da gibst sicher noch Profis die da bestimmt ganz andere Dinge sehen. 😄

                        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";
                        
                        
                        if (!existsObject(stateDevicesCount)) {createState(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' })};
                        if (!existsObject(stateDevicesLinkQuality)) {createState(stateDevicesLinkQuality, " ", { read: true, write: true, desc: "Liste Geräte Signalstärke", name: "Liste Geräte Signalstärke", type: 'string' })};
                        if (!existsObject(stateDevicesOfflineCount)) {createState(stateDevicesOfflineCount, 0, { read: true, write: true, desc: "Anzahl Geräte offline", name: "Anzahl Geräte offline",type: 'number' })};
                        if (!existsObject(stateDevicesOffline)) {createState(stateDevicesOffline, " ", { read: true, write: true, desc: "Liste Geräte offline", name: "Liste Geräte offline",type: 'string' })};
                        if (!existsObject(stateDevicesWithBattery)) {createState(stateDevicesWithBattery, " ", {read: true, write: true, desc: "Liste Geräte mit Batterie", name: "Liste Geräte mit Batterie", type: 'string'})};
                        if (!existsObject(stateDevicesWithBatteryCount)) {createState(stateDevicesWithBatteryCount, 0, {read: true, write: true, desc: "Anzahl Geräte mit Batterie", name: "Anzahl Geräte mit Batterie", type: 'number'})};
                        if (!existsObject(stateDevicesInfoList)) {createState(stateDevicesInfoList, " ", {read: true, write: true, desc: "Liste aller Geräte", name: "Liste aller Geräte", type: 'string'})};
                        if (!existsObject(stateDevicesLastCheck)) {createState(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 * * *", function () {
                            log("Run Zigbee-Watchdog");
                            zigbeeWatchdog();
                        });
                        
                        setTimeout (function () {
                            log("Run Zigbee-Watchdog");
                            zigbeeWatchdog();
                        }, 300);
                        

                        J 1 Reply Last reply
                        4
                        • ? A Former User

                          @johannesa ok gerne! Es sind bis jetzt ja nur Kleinigkeiten gewesen und davon wirklich nicht viele. Das mit der existsObject Funktion war ja auch meine erste Vermutung und Maßnahme um die Fehler im Log wegzubekommen beim ersten Start. Und da der Rest ja so funktioniert, ist ja alles Tip top und waren Schönheitskorrekturen. Nichts wildes. Wüsste auch erstmal nicht was man noch verbessern könnte. Aber da gibst sicher noch Profis die da bestimmt ganz andere Dinge sehen. 😄

                          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";
                          
                          
                          if (!existsObject(stateDevicesCount)) {createState(stateDevicesCount, 0, { read: true, write: true, desc: "Anzahl Geräte gesamt", name: "Anzahl Geräte gesamt",type: 'number' })};
                          if (!existsObject(stateDevicesLinkQuality)) {createState(stateDevicesLinkQuality, " ", { read: true, write: true, desc: "Liste Geräte Signalstärke", name: "Liste Geräte Signalstärke", type: 'string' })};
                          if (!existsObject(stateDevicesOfflineCount)) {createState(stateDevicesOfflineCount, 0, { read: true, write: true, desc: "Anzahl Geräte offline", name: "Anzahl Geräte offline",type: 'number' })};
                          if (!existsObject(stateDevicesOffline)) {createState(stateDevicesOffline, " ", { read: true, write: true, desc: "Liste Geräte offline", name: "Liste Geräte offline",type: 'string' })};
                          if (!existsObject(stateDevicesWithBattery)) {createState(stateDevicesWithBattery, " ", {read: true, write: true, desc: "Liste Geräte mit Batterie", name: "Liste Geräte mit Batterie", type: 'string'})};
                          if (!existsObject(stateDevicesWithBatteryCount)) {createState(stateDevicesWithBatteryCount, 0, {read: true, write: true, desc: "Anzahl Geräte mit Batterie", name: "Anzahl Geräte mit Batterie", type: 'number'})};
                          if (!existsObject(stateDevicesInfoList)) {createState(stateDevicesInfoList, " ", {read: true, write: true, desc: "Liste aller Geräte", name: "Liste aller Geräte", type: 'string'})};
                          if (!existsObject(stateDevicesLastCheck)) {createState(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 * * *", function () {
                              log("Run Zigbee-Watchdog");
                              zigbeeWatchdog();
                          });
                          
                          setTimeout (function () {
                              log("Run Zigbee-Watchdog");
                              zigbeeWatchdog();
                          }, 300);
                          

                          J Offline
                          J Offline
                          JohannesA
                          wrote on last edited by JohannesA
                          #12

                          @ciddi89
                          Vielen Dank für die "Version 2"! 🙂
                          Mit der Ergänzung bei der Datenpunkterstellung ist es jetzt wirklich plug&play! 😁

                          Freut mich dass auch ich meinen Beitrag zu diesem tollen Gewerk leisten kann! 🙂 Bisher hab ich ja nur "geschnorrt".

                          Die meisten Änderungen die du bei den Deklarationen gemacht hast, hat mir duckduckgo gerade erklärt.
                          Warum "const" statt "var" ist mir jetzt klar -> Anfängerfehler. Auch den Unterschied zwischen var und let hab ich theoretisch verstanden. Praktisch - naja, das zeigt sich vielleicht noch. 🤣

                          Aber kannst du mir noch erklären, was diese Codezeilen machen? Die kapier ich nicht:

                          let javascript_start = null
                          
                          
                          javascript_start = setTimeout (function () {
                              log("Run Zigbee-Watchdog");
                              zigbeeWatchdog();
                          }, 300);
                          

                          Vielleicht magst mir das noch kurz erläutern.

                          Und auf dein Lob hin ist bei mir die Motivation soeben durch die Decke gegangen. 😂

                          (hatte sogar kurz überlegt ob ich da vielleicht einen Watchdog-Adapter bauen sollte. Aber in Anbetracht des steinigen Weges vom Auspacken des Raspi bis jetzt wär das wie die Umsetzung einer bemannten Mars-Mission - deshalb schnell wieder zurück auf den Boden der Realität. 😃 )

                          ? paul53P 2 Replies Last reply
                          0
                          • J JohannesA

                            @ciddi89
                            Vielen Dank für die "Version 2"! 🙂
                            Mit der Ergänzung bei der Datenpunkterstellung ist es jetzt wirklich plug&play! 😁

                            Freut mich dass auch ich meinen Beitrag zu diesem tollen Gewerk leisten kann! 🙂 Bisher hab ich ja nur "geschnorrt".

                            Die meisten Änderungen die du bei den Deklarationen gemacht hast, hat mir duckduckgo gerade erklärt.
                            Warum "const" statt "var" ist mir jetzt klar -> Anfängerfehler. Auch den Unterschied zwischen var und let hab ich theoretisch verstanden. Praktisch - naja, das zeigt sich vielleicht noch. 🤣

                            Aber kannst du mir noch erklären, was diese Codezeilen machen? Die kapier ich nicht:

                            let javascript_start = null
                            
                            
                            javascript_start = setTimeout (function () {
                                log("Run Zigbee-Watchdog");
                                zigbeeWatchdog();
                            }, 300);
                            

                            Vielleicht magst mir das noch kurz erläutern.

                            Und auf dein Lob hin ist bei mir die Motivation soeben durch die Decke gegangen. 😂

                            (hatte sogar kurz überlegt ob ich da vielleicht einen Watchdog-Adapter bauen sollte. Aber in Anbetracht des steinigen Weges vom Auspacken des Raspi bis jetzt wär das wie die Umsetzung einer bemannten Mars-Mission - deshalb schnell wieder zurück auf den Boden der Realität. 😃 )

                            ? Offline
                            ? Offline
                            A Former User
                            wrote on last edited by
                            #13

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

                            Warum "const" statt "var" ist mir jetzt klar -> Anfängerfehler.

                            Naja, Theoretisch hätte man das auch alles in "var" lassen können. Aber ich habe mir das alles nach und nach angewöhnt Variabeln die auf Datenpunkte zeigen mit "const" zu deklarieren und alle anderen mit "let". Wieso, weshalb, warum hast du ja schon selbst nachgeforscht 😄

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

                            Aber kannst du mir noch erklären, was diese Codezeilen machen? Die kapier ich nicht:

                            Aber natürlich! Du hast ja schon die shedule Funktion, welche in der 6ten Minute nach der vollen Stunde ausgeführt wird, eingesetzt. Aber ich bin ein sehr ungeduldiger Mensch 😄 Daher habe ich diese Funktion mit reingenommen. Nach dem das Skript gestartet wurde, macht diese nach 300ms schon einmal ein Durchlauf mit deiner Hauptfunktion und befüllt die Datenpunkte. Das wird einmal gemacht nach Skriptstart und danach kommt halt der nächste Durchlauf wieder nach deinem Zeitplan.

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

                            Und auf dein Lob hin ist bei mir die Motivation soeben durch die Decke gegangen.

                            Naja ich bin selber am lernen. Und wie lernt man am besten? In dem man auch anderen Hilft und sich anguckt was die so machen und wie die ihren Code schreiben. Bin erstaunt wie schnell man immer wieder Verbesserungen findet und diese dann an seinen eigenen Skripten ausprobiert und nutzt. 😄

                            1 Reply Last reply
                            0
                            • J JohannesA

                              @ciddi89
                              Vielen Dank für die "Version 2"! 🙂
                              Mit der Ergänzung bei der Datenpunkterstellung ist es jetzt wirklich plug&play! 😁

                              Freut mich dass auch ich meinen Beitrag zu diesem tollen Gewerk leisten kann! 🙂 Bisher hab ich ja nur "geschnorrt".

                              Die meisten Änderungen die du bei den Deklarationen gemacht hast, hat mir duckduckgo gerade erklärt.
                              Warum "const" statt "var" ist mir jetzt klar -> Anfängerfehler. Auch den Unterschied zwischen var und let hab ich theoretisch verstanden. Praktisch - naja, das zeigt sich vielleicht noch. 🤣

                              Aber kannst du mir noch erklären, was diese Codezeilen machen? Die kapier ich nicht:

                              let javascript_start = null
                              
                              
                              javascript_start = setTimeout (function () {
                                  log("Run Zigbee-Watchdog");
                                  zigbeeWatchdog();
                              }, 300);
                              

                              Vielleicht magst mir das noch kurz erläutern.

                              Und auf dein Lob hin ist bei mir die Motivation soeben durch die Decke gegangen. 😂

                              (hatte sogar kurz überlegt ob ich da vielleicht einen Watchdog-Adapter bauen sollte. Aber in Anbetracht des steinigen Weges vom Auspacken des Raspi bis jetzt wär das wie die Umsetzung einer bemannten Mars-Mission - deshalb schnell wieder zurück auf den Boden der Realität. 😃 )

                              paul53P Offline
                              paul53P Offline
                              paul53
                              wrote on last edited by
                              #14

                              @johannesa sagte: was diese Codezeilen machen?

                              Da der Timer nicht mit clearTimeout(javascript_start) gestoppt wird (oder übersehe ich es?), kann man auf die Timer-Variable verzichten.

                              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 Reply Last reply
                              0
                              • paul53P paul53

                                @johannesa sagte: was diese Codezeilen machen?

                                Da der Timer nicht mit clearTimeout(javascript_start) gestoppt wird (oder übersehe ich es?), kann man auf die Timer-Variable verzichten.

                                ? Offline
                                ? Offline
                                A Former User
                                wrote on last edited by
                                #15

                                @paul53 said

                                Da der Timer nicht mit clearTimeout(javascript_start) gestoppt wird (oder übersehe ich es?), kann man auf die Timer-Variable verzichten.

                                Nein ist kein stopper drin. Aber danke für den Hinweis 🙂 Dann kann ich die ja wieder rausnehmen.

                                J 1 Reply Last reply
                                0
                                • ? A Former User

                                  @paul53 said

                                  Da der Timer nicht mit clearTimeout(javascript_start) gestoppt wird (oder übersehe ich es?), kann man auf die Timer-Variable verzichten.

                                  Nein ist kein stopper drin. Aber danke für den Hinweis 🙂 Dann kann ich die ja wieder rausnehmen.

                                  J Offline
                                  J Offline
                                  JohannesA
                                  wrote on last edited by
                                  #16

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

                                  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 Reply Last reply
                                  0
                                  • 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. 😀 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 😃 ).

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

                                    ? Offline
                                    ? Offline
                                    A Former User
                                    wrote on last edited by
                                    #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 Reply Last reply
                                    0
                                    • ? A Former User

                                      @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 Offline
                                      bahnuhrB Offline
                                      bahnuhr
                                      Forum Testing Most Active
                                      wrote on last edited by
                                      #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 Reply Last reply
                                      0
                                      • bahnuhrB bahnuhr

                                        @ciddi89

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

                                            log("Run Zigbee-Watchdog");
                                            zigbeeWatchdog();
                                        
                                        ? Offline
                                        ? Offline
                                        A Former User
                                        wrote on last edited by
                                        #19

                                        @bahnuhr danke das weiss ich. 😄 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 Replies Last reply
                                        0
                                        • ? A Former User

                                          @bahnuhr danke das weiss ich. 😄 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 Offline
                                          bahnuhrB Offline
                                          bahnuhr
                                          Forum Testing Most Active
                                          wrote on last edited by
                                          #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 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          91

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe