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
    280

  • 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.
  • amg_666A amg_666

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

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

    Das ist der Teil des Scripts:

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

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

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

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

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

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

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

    amg_666A 1 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

      liv-in-skyL Offline
      liv-in-skyL Offline
      liv-in-sky
      wrote on last edited by
      #26

      @johannesa

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

      dii dp-erstellung werden in einer function abgelegt

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

      der aufruf im schedule ist dann anders:

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

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

      ps: danke fürs script

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

      1 Reply Last reply
      0
      • ? Offline
        ? Offline
        A Former User
        wrote on last edited by
        #27

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

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

        liv-in-skyL 1 Reply Last reply
        1
        • ? A Former User

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

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

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          wrote on last edited by liv-in-sky
          #28

          @ciddi89

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

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

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

          ? 1 Reply Last reply
          0
          • liv-in-skyL liv-in-sky

            @ciddi89

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

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

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

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

            liv-in-skyL 1 Reply Last reply
            0
            • paul53P paul53

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

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

                      currRoom = getObject(id, 'rooms').enumNames[0];
                      if(typeof currRoom == 'object') currRoom = currRoom.de;
              
              amg_666A Offline
              amg_666A Offline
              amg_666
              wrote on last edited by
              #30

              @paul53 Irgendwie kapier ich es nicht. Es liegt an

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

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

              iobroker auf proxmox container

              paul53P 1 Reply Last reply
              0
              • amg_666A amg_666

                @paul53 Irgendwie kapier ich es nicht. Es liegt an

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

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

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

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

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

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

                1 Reply Last reply
                0
                • ? A Former User

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

                  liv-in-skyL Offline
                  liv-in-skyL Offline
                  liv-in-sky
                  wrote on last edited by
                  #32

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

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

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

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

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

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

                  ? 1 Reply Last reply
                  0
                  • liv-in-skyL liv-in-sky

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

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

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

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

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

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

                    @liv-in-sky said

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

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

                    liv-in-skyL 2 Replies Last reply
                    0
                    • ? A Former User

                      @liv-in-sky said

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

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

                      liv-in-skyL Offline
                      liv-in-skyL Offline
                      liv-in-sky
                      wrote on last edited by liv-in-sky
                      #34

                      @ciddi89 glaube ich nicht 🙂

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

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

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

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

                      paul53P 1 Reply Last reply
                      0
                      • liv-in-skyL liv-in-sky

                        @ciddi89 glaube ich nicht 🙂

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

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

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

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

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

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

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

                        liv-in-skyL 1 Reply Last reply
                        0
                        • paul53P paul53

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

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

                          liv-in-skyL Offline
                          liv-in-skyL Offline
                          liv-in-sky
                          wrote on last edited by
                          #36

                          @paul53 genau darüber denke ich gerade nach 🙂

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

                          1 Reply Last reply
                          0
                          • ? Offline
                            ? Offline
                            A Former User
                            wrote on last edited by
                            #37

                            @liv-in-sky said in Zigbee-Geräte überwachen:

                            glaube ich nicht

                            Danke 🙂

                            Sagen wir mal so, abgeneigt wäre ich nicht. Wollte mich eh früher oder später mit sowas beschäftigen da ich auch noch andere Ideen habe die evtl. einen Adapter wert währen. Müsste mich erst mal darin ein Arbeiten. 😃

                            J 1 Reply Last reply
                            0
                            • ? A Former User

                              @liv-in-sky said

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

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

                              liv-in-skyL Offline
                              liv-in-skyL Offline
                              liv-in-sky
                              wrote on last edited by liv-in-sky
                              #38

                              @ciddi89

                              ein beispiel: eine constante, die man als user definieren muss

                              theSektor ist der dp, der vom selektor gesucht wird
                              the Name ist die art, wo der hostname gesucht werden muss .. da habe ich noch nicht weiter überlegt,

                              zeile 1:

                              const myArrDev=[{"theSelektor":"zigbee.0.*.link_quality","theName":"common"}]
                              

                              dann vor der each schleife:

                               for(let x=0; x<myArrDev.length;x++){
                              
                                  var zigbee = $(myArrDev[x].theSelektor);
                              
                               
                              
                                  zigbee.each(function (id, i) {
                              
                                      currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                                      //hier braucht man eine function, die den hostnamen findet:
                                      if (myArrDev[x].theName=="common")  deviceName=getObject(currDeviceString).common.name
                              
                                      currRoom = getObject(id, 'rooms').enumNames[0];
                              
                               .... }
                              
                              
                              

                              dann fehlt nur noch eine funktion, die mit "myArrrDev.theName" auf den richtigen dp kommt. das kann in das script so eingesetzt werden und funktioniert noch)

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

                              ? 1 Reply Last reply
                              0
                              • liv-in-skyL liv-in-sky

                                @ciddi89

                                ein beispiel: eine constante, die man als user definieren muss

                                theSektor ist der dp, der vom selektor gesucht wird
                                the Name ist die art, wo der hostname gesucht werden muss .. da habe ich noch nicht weiter überlegt,

                                zeile 1:

                                const myArrDev=[{"theSelektor":"zigbee.0.*.link_quality","theName":"common"}]
                                

                                dann vor der each schleife:

                                 for(let x=0; x<myArrDev.length;x++){
                                
                                    var zigbee = $(myArrDev[x].theSelektor);
                                
                                 
                                
                                    zigbee.each(function (id, i) {
                                
                                        currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                                        //hier braucht man eine function, die den hostnamen findet:
                                        if (myArrDev[x].theName=="common")  deviceName=getObject(currDeviceString).common.name
                                
                                        currRoom = getObject(id, 'rooms').enumNames[0];
                                
                                 .... }
                                
                                
                                

                                dann fehlt nur noch eine funktion, die mit "myArrrDev.theName" auf den richtigen dp kommt. das kann in das script so eingesetzt werden und funktioniert noch)

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

                                @liv-in-sky okay das sollte ja machbar sein. Mal gucken ob sich Johannes das mal annehmen möchte aber ich versuche mich evtl auch mal daran. Werde mir mal die Umgebung fertig machen, mich ein bisschen einlesen und probiere mich da mal dran aus. 😄 Das Wetter hier in Ostfriesland ist sowieso inmoment total fürn a*** 😄

                                liv-in-skyL 1 Reply Last reply
                                0
                                • ? A Former User

                                  @liv-in-sky okay das sollte ja machbar sein. Mal gucken ob sich Johannes das mal annehmen möchte aber ich versuche mich evtl auch mal daran. Werde mir mal die Umgebung fertig machen, mich ein bisschen einlesen und probiere mich da mal dran aus. 😄 Das Wetter hier in Ostfriesland ist sowieso inmoment total fürn a*** 😄

                                  liv-in-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  wrote on last edited by
                                  #40

                                  @ciddi89

                                  ich habe nur noch ein wenig gespielt:

                                  sonoff ist soweit drin, dass keine fehler kommen - warte aber auf eure entscheidung und entwicklung

                                  nur soviel - evtl kann man das besser machen:

                                  zeile 1:

                                  const myArrDev=[{"theSelektor":"zigbee.0.*.link_quality","theName":"common"},
                                                  {"theSelektor":"sonoff.1.*.Wifi_RSSI","theName":"dp","thedpName":"Hostname"}
                                                  ]
                                  

                                  dann als beispiel , den hostnamen zu finden, der im gegesatz zu zigbee in einem dp zu finden ist

                                   for(let x=0; x<myArrDev.length;x++){
                                  
                                      var zigbee = $(myArrDev[x].theSelektor);
                                  
                                   
                                  
                                      zigbee.each(function (id, i) {
                                  
                                          currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                                          //hier braucht man eine function, die den hostnamen findet:
                                          if (myArrDev[x].theName=="common")  deviceName=getObject(currDeviceString).common.name
                                          if (myArrDev[x].theName=="dp") {
                                                                         let ida=id.split('.');
                                                                         let mySelect=$(ida[0]+'.'+ida[1]+'.'+ida[2]+'.*');
                                                                         mySelect.each(function (ad, i) {
                                                                             if (ad.includes(myArrDev[x].thedpName)) deviceName=getState(ad).val
                                                                         });
                                                                         
                                  
                                  
                                          }
                                  

                                  wenn unter "theName" "dp" steht , wird das ganze über einen selektor gesucht - wenn es einen dp mit Hostname gibt, nimm den namen

                                  so etwas braucht man auch noch für die batterie und auch link_quality
                                  in den listen sollte dann auch noch ein extra punkt rein - welche art von device

                                  Image 1.png

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

                                  ? 1 Reply Last reply
                                  0
                                  • liv-in-skyL liv-in-sky

                                    @ciddi89

                                    ich habe nur noch ein wenig gespielt:

                                    sonoff ist soweit drin, dass keine fehler kommen - warte aber auf eure entscheidung und entwicklung

                                    nur soviel - evtl kann man das besser machen:

                                    zeile 1:

                                    const myArrDev=[{"theSelektor":"zigbee.0.*.link_quality","theName":"common"},
                                                    {"theSelektor":"sonoff.1.*.Wifi_RSSI","theName":"dp","thedpName":"Hostname"}
                                                    ]
                                    

                                    dann als beispiel , den hostnamen zu finden, der im gegesatz zu zigbee in einem dp zu finden ist

                                     for(let x=0; x<myArrDev.length;x++){
                                    
                                        var zigbee = $(myArrDev[x].theSelektor);
                                    
                                     
                                    
                                        zigbee.each(function (id, i) {
                                    
                                            currDeviceString = id.slice(0, (id.lastIndexOf('.') + 1) - 1);
                                            //hier braucht man eine function, die den hostnamen findet:
                                            if (myArrDev[x].theName=="common")  deviceName=getObject(currDeviceString).common.name
                                            if (myArrDev[x].theName=="dp") {
                                                                           let ida=id.split('.');
                                                                           let mySelect=$(ida[0]+'.'+ida[1]+'.'+ida[2]+'.*');
                                                                           mySelect.each(function (ad, i) {
                                                                               if (ad.includes(myArrDev[x].thedpName)) deviceName=getState(ad).val
                                                                           });
                                                                           
                                    
                                    
                                            }
                                    

                                    wenn unter "theName" "dp" steht , wird das ganze über einen selektor gesucht - wenn es einen dp mit Hostname gibt, nimm den namen

                                    so etwas braucht man auch noch für die batterie und auch link_quality
                                    in den listen sollte dann auch noch ein extra punkt rein - welche art von device

                                    Image 1.png

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

                                    @liv-in-sky vielen vielen dank für den Input. Ich probiere mich mal in nächster Zeit ein wenig daran aus. 🙂 Mal schauen was man daraus so machen kann.

                                    liv-in-skyL 1 Reply Last reply
                                    0
                                    • ? A Former User

                                      @liv-in-sky vielen vielen dank für den Input. Ich probiere mich mal in nächster Zeit ein wenig daran aus. 🙂 Mal schauen was man daraus so machen kann.

                                      liv-in-skyL Offline
                                      liv-in-skyL Offline
                                      liv-in-sky
                                      wrote on last edited by
                                      #42

                                      @ciddi89 bin gespannt 🙂

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

                                      amg_666A 1 Reply Last reply
                                      0
                                      • liv-in-skyL liv-in-sky

                                        @ciddi89 bin gespannt 🙂

                                        amg_666A Offline
                                        amg_666A Offline
                                        amg_666
                                        wrote on last edited by
                                        #43

                                        ich hab noch ein Problemchen: Devices, die "offline" sind werden wie folgt angezeigt:
                                        ab8a3c0f-34cf-43c3-a845-663ecaeb1a97-grafik.png
                                        Alle stehen auf 26 Stunden, wenn ich in die Datenpunkte bei zigbee schaue, dann ist da z.B. bei msg_from_zigbee 27.01.22 21:44 was ja deutlich mehr als 26 Stunden ist.
                                        Irgendeine Idee woran das liegen könnte?

                                        iobroker auf proxmox container

                                        ? 1 Reply Last reply
                                        0
                                        • amg_666A amg_666

                                          ich hab noch ein Problemchen: Devices, die "offline" sind werden wie folgt angezeigt:
                                          ab8a3c0f-34cf-43c3-a845-663ecaeb1a97-grafik.png
                                          Alle stehen auf 26 Stunden, wenn ich in die Datenpunkte bei zigbee schaue, dann ist da z.B. bei msg_from_zigbee 27.01.22 21:44 was ja deutlich mehr als 26 Stunden ist.
                                          Irgendeine Idee woran das liegen könnte?

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

                                          @amg_666 Was steht denn bei dir in den Zeitstempel und bei zuletzt geändert vom Datenpunkt link_quality? Von dem Datenpunkt holt er sich ja die Zeit.

                                          amg_666A 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

                                          214

                                          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