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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Praktische Anwendungen (Showcase)
  4. Material Design Widets: Netzwerk Status

NEWS

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

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

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

Material Design Widets: Netzwerk Status

Geplant Angeheftet Gesperrt Verschoben Praktische Anwendungen (Showcase)
280 Beiträge 50 Kommentatoren 52.0k Aufrufe 65 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • KnallochseK Offline
    KnallochseK Offline
    Knallochse
    schrieb am zuletzt editiert von Knallochse
    #267

    Mir ist gerade aufgefallen, das leider die Zeiten des an/abgemeldet Status nicht mehr angezeigt werden. (Rest z.Bsp. OnlineStatus funktioniert)
    2662CAAD-B7A2-4205-B7BC-E827E12D1809.jpeg
    Hat noch jemand dieses Widget mit dem dazugehörigen Script im Einsatz und könnte das mal überprüfen?

    HM&HMIP über 100 Geräte + IoBroker auf DS918+ uvm.

    sigi234S 1 Antwort Letzte Antwort
    0
    • KnallochseK Knallochse

      Mir ist gerade aufgefallen, das leider die Zeiten des an/abgemeldet Status nicht mehr angezeigt werden. (Rest z.Bsp. OnlineStatus funktioniert)
      2662CAAD-B7A2-4205-B7BC-E827E12D1809.jpeg
      Hat noch jemand dieses Widget mit dem dazugehörigen Script im Einsatz und könnte das mal überprüfen?

      sigi234S Online
      sigi234S Online
      sigi234
      Forum Testing Most Active
      schrieb am zuletzt editiert von
      #268

      @knallochse sagte in Material Design Widets: Netzwerk Status:

      Hat noch jemand dieses Widget mit dem dazugehörigen Script im Einsatz und könnte das mal überprüfen?

      https://forum.iobroker.net/topic/54865/invalide-date/2?_=1652443601033

      Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
      Immer Daten sichern!

      1 Antwort Letzte Antwort
      1
      • H Offline
        H Offline
        Hausbaer
        schrieb am zuletzt editiert von
        #269

        Ich habe zwei Instanzen des TR-064 Adapters.

        Instanz 1 wertet mir die Sensoren / Steckdosen etc (Shelly, TP-Link....) aus, die per WLan verbunden sind.
        Instanz 2 liefert die Geräte, die im Netz als "User" angemeldet sind (Mobiltelefone, Tabs, Rechner usw).

        Für die Instanz 1 läuft das Scrip ohne Probleme.

        /* Versionshistorie:
        * 
        * 1.0.2:
        * - neu: Anzeige der letzten An- und Abmeldung
        * - neu: Verwendung eigener Bilder möglich
        * 
        * 1.0.1:
        * - neu: In dem Mapping der IP-Adressen kann jetzt eine URL vergeben werden ('http' oder direkt eine spezifische URL)
        * - geändert: Styling der Details
        * - entfernt: MAC-Adresse
        * 
        * 1.0.0:
        * - Initial Release
        */
        
        const moment = require("moment");
        
        
        
        // Datenpunkte anlegen falls nicht vorhanden ********************************
        
        if ( !existsState("0_userdata.0.vis.SensorStatus.jsonList")){createState("0_userdata.0.vis.SensorStatus.jsonList", false, {type: 'string'})}; 
        if ( !existsState("0_userdata.0.vis.SensorStatus.sortMode")){createState("0_userdata.0.vis.SensorStatus.sortMode", false, {type: 'string'})}; 
        if ( !existsState("0_userdata.0.vis.SensorStatus.filterMode")){createState("0_userdata.0.vis.SensorStatus.filterMode", false, {type: 'string'})};
        
        
        // Skript Einstellungen *************************************************************************************************************************************************
        
        let dpList = '0_userdata.0.vis.SensorStatus.jsonList';          // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
        
        let dpSortMode = '0_userdata.0.vis.SensorStatus.sortMode';      // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
        let dpFilterMode = '0_userdata.0.vis.SensorStatus.filterMode"';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
        
        const checkInterval = 30;                                         // Interval wie oft Status der Skripte aktualisiert werden soll (in Sekunden)
        
        let sprache = 'de';                                               // Sprache für formatierung letzte Änderung
        let formatierungLastChange = "ddd DD.MM - HH:mm";                 // Formatierung letzte Änderung -> siehe momentjs library
        
        let imagePath = '/vis.0/bilder/geraete/'                          // Pfad zu den verwendeten Bildern (bitte über den VIS Dateimanager hochladen)
                                                                         // nach Variable imagePath suchen und die entsprechenden Zeilen aus- bzw. einkommentieren
                                                                         // Das Bild (Dateiformat png) in der Mapping-Liste hinterlegen
        //let defaultImage = 'ip-network-outline';                          // Standardbild, falls kein Bild angegeben wurde (Material Design Icons)
        let defaultImage = `${imagePath}default.png`;                   // Standardbild, falls kein Bild angegeben wurde (eigenes Bild)
        
        let farbeGeraetOnline = '0_userdata.0.einstellung_farben_schriftarten.farbe-4';                                  // Status Bar Farbe wenn Geräte online ist
        let farbeGeraetOffline = '0_userdata.0.einstellung_farben_schriftarten.farbe-5';                             // Status Bar Farbe wenn Geräte offline ist
        
        let sortResetAfter = 120;                                         // Sortierung nach X Sekunden auf sortReset zurücksetzen (0=deaktiviert)
        let sortReset = 'name'                                            // Sortierung auf die zurückgesetzt werden soll
        
        let filterResetAfter = 120;                                       // Filter nach X Sekunden zurücksetzen (0=deaktiviert)
        
        const deviceNames = 
        [{ ip: "192.168.8.110", alias: "Steckdose Drucker",                 image: "tp-link_hs110",              link: "http" },
        { ip: "192.168.8.111", alias: "Flur EG und Keller Licht",          image: "shelly-2-5",                 link: "http://192.168.8.111" },
        { ip: "192.168.8.112", alias: "Flur EG FBH",                       image: "shelly-1",                   link: "http://192.168.8.112" },
        { ip: "192.168.8.113", alias: "Bad FBH",                           image: "shelly-1",                   link: "http://192.168.8.113" },
        { ip: "192.168.8.114", alias: "Küche FBH",                         image: "shelly-1",                   link: "http://192.168.8.114" },
        { ip: "192.168.8.115", alias: "Esszimmer FBH",                     image: "shelly-1",                   link: "http://192.168.8.115" },
        { ip: "192.168.8.116", alias: "Fenster FBH",                       image: "shelly-1",                   link: "http://192.168.8.116" },
        { ip: "192.168.8.117", alias: "Wohnzimmer FBH",                    image: "shelly-1",                   link: "http://192.168.8.117" },
        { ip: "192.168.8.118", alias: "Pumpe FBH",                         image: "shelly-1",                   link: "http://192.168.8.118" },
        { ip: "192.168.8.119", alias: "Flur DG Licht",                     image: "shelly-2-5",                 link: "http://192.168.8.119" },
        { ip: "192.168.8.120", alias: "Volumio",                           image: "shelly-1",                   link: "http://192.168.8.120" },
        { ip: "192.168.8.130", alias: "Melkkammer Licht und Heizspirale",  image: "shelly-2-5",                 link: "http://192.168.8.130" },
        { ip: "192.168.8.131", alias: "Heizraum Licht",                    image: "shelly-1",                   link: "http://192.168.8.131" },
        { ip: "192.168.8.132", alias: "Stall Licht",                       image: "shelly-1",                   link: "http://192.168.8.132" },
        { ip: "192.168.8.133", alias: "Stodl Licht",                       image: "shelly-1",                   link: "http://192.168.8.133" },
        { ip: "192.168.8.134", alias: "Solaranlage",                       image: "shelly-plug-s",              link: "http://192.168.8.134" },
        { ip: "192.168.8.140", alias: "Garage neu Licht außen",            image: "shelly-1",                   link: "http://192.168.8.140" },
        { ip: "192.168.8.141", alias: "Garage neu und Troidlager Licht",   image: "shelly-2-5",                 link: "http://192.168.8.141" },
        { ip: "192.168.8.142", alias: "Garage neu Tor 1",              image: "shelly-1",                   link: "http://192.168.8.142" },
        { ip: "192.168.8.143", alias: "Garage neu Tor 2",               image: "shelly-1",                   link: "http://192.168.8.143" },
        { ip: "192.168.8.146", alias: "Garage neu Tor 2 geschlossen",   image: "shelly-door-2",              link: "http://192.168.8.146" },
        { ip: "192.168.8.147", alias: "Garage neu Tor 1 geschlossen",  image: "shelly-door-2",              link: "http://192.168.8.147" },
        { ip: "192.168.8.150", alias: "Garage alt Licht außen und RH",     image: "shelly-2-5",                 link: "http://192.168.8.150" },
        { ip: "192.168.8.151", alias: "Garage alt Tor 3",                 image: "shelly-1-plus",              link: "http://192.168.8.151" },
        { ip: "192.168.8.152", alias: "Garage alt Tor 4",                image: "shelly-1-plus",              link: "http://192.168.8.152" },
        { ip: "192.168.8.153", alias: "Garage alt Tor 3 geschlossen",     image: "shelly-door-2",              link: "http://192.168.8.153" },
        { ip: "192.168.8.154", alias: "Garage alt Tor 4 geschlossen",    image: "shelly-door-2",              link: "http://192.168.8.154" },
        { ip: "192.168.8.155", alias: "Garage alt Licht",              image: "shelly-1",                   link: "http://192.168.8.155" },
        ];
        
        // **********************************************************************************************************************************************************************
        
        // Fomate für moment Lib
        moment.locale(sprache);
        
        // auf Änderungen aktiver Skripts hören
        let activeSelector = `[id=tr-064.0.devices.*.active]`;
        let deviceActiveList = $(activeSelector);
        if (deviceActiveList.length === 0) {
           // Fehlermeldung ausgeben, wenn selector kein result liefert
           console.error(`no result for selector '${activeSelector}'`)
        } else {
           // listener nur für Änderung bei alive
           deviceActiveList.on(netzwerkStatus);
        } 
        
        // auf Änderungen der Sortieung hören
        on({ id: dpSortMode, change: 'any' }, netzwerkStatus);
        on({ id: dpSortMode, change: 'any' }, resetSort);
        
        // // auf Änderungen der Filter hören
        on({ id: dpFilterMode, change: 'any' }, netzwerkStatus);
        on({ id: dpFilterMode, change: 'any' }, resetFilter);
        
        
        // Funktion adapterStatus alle x Sekunden ausführen
        schedule('*/' + checkInterval + ' * * * * *', netzwerkStatus);
        
        function netzwerkStatus() {
           try {
               let deviceList = [];
        
               for (var i = 0; i <= deviceActiveList.length - 1; i++) {
                   let id = deviceActiveList[i].replace('.active', '');
                   let obj = getObject(id);
        
                   let pattern = /(?:\d{1,3}\.){3}\d{1,3}/i;
        
                   let ipAddress = obj.common.name.match(pattern)[0];
                   let image = defaultImage;
                   let deviceName = obj.common.name.replace(/ \((?:\d{1,3}\.){3}\d{1,3}\)/g, '');
                   let device = deviceNames.find(element => element.ip == ipAddress);
                   let listType = 'text';
                   let buttonLink = '';
        
                   if(device) {
                       deviceName = device.alias;
                       //image = device.image;
                       image = `${imagePath}${device.image}.png`;
        
                       if(device.link) {
                           listType = 'buttonLink';
        
                           if(device.link == 'http') {
                               buttonLink = `http://${ipAddress}`;
                           } else {
                               buttonLink = device.link;
                           }
                       }
                   }
        
                   let macAddress = obj.native.mac;
                   let imageColor = '{0_userdata.0.einstellung_farben_schriftarten.farbe-8}';
                   let statusBarColor = farbeGeraetOffline;
                   let status = 2;
        
                   if (getState(deviceActiveList[i]).val) {
                       statusBarColor = farbeGeraetOnline;
                       status = 1;
                   }
        
                   if(listType === 'buttonLink') {
                       deviceName = `<span style="text-decoration: underline">${deviceName}</span>`                
                   }
        
                   let lastSignIn = 'noch nicht angemeldet';
                   let lastSignOff = 'noch nicht abgemeldet';
        
                   // Letzte Anmeldung auslesen
                   if(existsState(id + '.lastActive')) {
                       lastSignIn = 'angemeldet seit: ' + moment((getState(id + '.lastActive').val)).format("DD.MM.YY HH:mm:ss");
                   }        
        
                   // Letzte Abmeldung auslesen
                   if(existsState(id + '.lastInactive')) {
                       lastSignOff = 'abgemeldet seit: ' + moment((getState(id + '.lastInactive').val)).format("DD.MM.YY HH:mm:ss");
                   }
        
                   let subText = `<div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-3}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-3}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-5}">${ipAddress}</div>
                                  <div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-2}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-4}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-6}">${lastSignIn}</div>
                                  <div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-2}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-4}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-6}">${lastSignOff}</div>`
        
        
                   deviceList.push({
                       text: deviceName,
                       subText: subText,
                       statusBarColor: statusBarColor,
                       image: image,
                       imageColor: imageColor,
                       listType: listType,
                       buttonLink: buttonLink,
                       showValueLabel: false,
                       name: deviceName,
                       ipAddress: ipAddress,
                       status: status
                   });
               }
        
               let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
        
               if (sortMode === 'name' || sortMode === 'ipAddress') {
                   deviceList.sort(function (a, b) {
                       return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                   });
               } else if (sortMode === 'status') {
                   deviceList.sort(function (a, b) {
                       return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                   });
               } else {
                   // default: nach name sortieren
                   sortMode = 'name'
                   deviceList.sort(function (a, b) {
                       return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                   });
               }
        
        
               let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
        
               if (filterMode && filterMode !== null && filterMode !== '') {
                   if (filterMode === 'offline') {
                       deviceList = deviceList.filter(function (item) {
                           return item.status === 2;
                       });
                   } else if (filterMode === 'online') {
                       deviceList = deviceList.filter(function (item) {
                           return item.status === 1;
                       });
                   }
               }
        
        
               let result = JSON.stringify(deviceList);
               if (getState(dpList) !== result) {
                   setState(dpList, result, true);
               }
        
           } catch (err) {
               console.error(`[netzwerkStatus] error: ${err.message}, stack: ${err.stack}`);
           }
        }
        
        function resetSort() {
           let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
        
           if (sortResetAfter > 0) {
               setTimeout(function () {
                   if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                       setState(dpSortMode, sortReset);
                   }
               }, sortResetAfter * 1000);
           }
        }
        
        function resetFilter() {
           let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
        
           if (filterResetAfter > 0) {
               setTimeout(function () {
                   if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                       setState(dpFilterMode, '');
                   }
               }, filterResetAfter * 1000);
           }
        }
        
        // Beim Staren des Skriptes Adapter Status abrufen
        netzwerkStatus();
        
        function myHelper() {
           return {
               getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                   if (existsState(id)) {
                       return prepand + getState(id).val + append;
                   } else {
                       return nullValue;
                   }
               },
               getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                   if (myHelper().checkCommonPropertyExist(object, prop)) {
                       return prepand + object.common[prop] + append;
                   } else {
                       return nullValue;
                   }
               },
               checkCommonPropertyExist: function (object, prop) {
                   if (object && object.common && object.common[prop]) {
                       return true;
                   } else {
                       return false;
                   }
               }
           }
        }
        

        Für die Instanz 2 erhalte ich aber folgende Fehlermeldungen:

        script.js.Neue-Skripte.it-adapter.it-geraete_221209: [GeraeteStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.GeraeteStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:131:59) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1214:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:596:29) at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5909:56) at processImmediate (node:internal/timers:466:21)
        
        
        script.js.Neue-Skripte.it-adapter.it-geraete_221209: [GeraeteStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.GeraeteStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:131:59) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1565:34) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28 at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7) at listOnTimeout (node:internal/timers:559:17) at processTimers (node:internal/timers:502:7)
        

        Dazu hier das Script:

        /* Versionshistorie:
        * 
        * 1.0.2:
        * - neu: Anzeige der letzten An- und Abmeldung
        * - neu: Verwendung eigener Bilder möglich
        * 
        * 1.0.1:
        * - neu: In dem Mapping der IP-Adressen kann jetzt eine URL vergeben werden ('http' oder direkt eine spezifische URL)
        * - geändert: Styling der Details
        * - entfernt: MAC-Adresse
        * 
        * 1.0.0:
        * - Initial Release
        */
        
        const moment = require("moment");
        
        
        // Datenpunkte anlegen falls nicht vorhanden ********************************
        
        if ( !existsState("0_userdata.0.vis.GeraeteStatus.jsonList")){createState("0_userdata.0.vis.GeraeteStatus.jsonList", false, {type: 'string'})}; 
        if ( !existsState("0_userdata.0.vis.GeraeteStatus.sortMode")){createState("0_userdata.0.vis.GeraeteStatus.sortMode", false, {type: 'string'})}; 
        if ( !existsState("0_userdata.0.vis.GeraeteStatus.filterMode")){createState("0_userdata.0.vis.GeraeteStatus.filterMode", false, {type: 'string'})};
        
        
        
        // Skript Einstellungen *************************************************************************************************************************************************
        
        let dpList = '0_userdata.0.vis.GeraeteStatus.jsonList';          // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
        
        let dpSortMode = '0_userdata.0.vis.GeraeteStatussortMode';      // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
        let dpFilterMode = '0_userdata.0.vis.GeraeteStatus.filterMode';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
        
        const checkInterval = 30;                                         // Interval wie oft Status der Skripte aktualisiert werden soll (in Sekunden)
        
        let sprache = 'de';                                               // Sprache für formatierung letzte Änderung
        let formatierungLastChange = "ddd DD.MM - HH:mm";                 // Formatierung letzte Änderung -> siehe momentjs library
        
        let imagePath =  '/vis.0/bilder/geraete/' 		                  // Pfad zu den verwendeten Bildern (bitte über den VIS Dateimanager hochladen)
                                                                         // nach Variable imagePath suchen und die entsprechenden Zeilen aus- bzw. einkommentieren
                                                                         // Das Bild (Dateiformat png) in der Mapping-Liste hinterlegen
        let defaultImage = 'ip-network-outline';                          // Standardbild, falls kein Bild angegeben wurde (Material Design Icons)
        //let defaultImage = `${imagePath}default.png`;                   // Standardbild, falls kein Bild angegeben wurde (eigenes Bild)
        
        let farbeGeraetOnline = 'green';                                  // Status Bar Farbe wenn Geräte online ist
        let farbeGeraetOffline = 'FireBrick';                             // Status Bar Farbe wenn Geräte offline ist
        
        let sortResetAfter = 120;                                         // Sortierung nach X Sekunden auf sortReset zurücksetzen (0=deaktiviert)
        let sortReset = 'name'                                            // Sortierung auf die zurückgesetzt werden soll
        
        let filterResetAfter = 120;                                       // Filter nach X Sekunden zurücksetzen (0=deaktiviert)
        
        const deviceNames = 
        [{ ip: "192.168.8.201", alias: "Laptop Büro WLan",                  image: "notebook",                   link: "http" },
        { ip: "192.168.8.202", alias: "Laptop Büro Lan",                   image: "notebook",                   link: "http" },
        { ip: "192.168.8.203", alias: "Iobroker",                          image: "raspi1",                     link: "http://192.168.8.203:8081" },
        { ip: "192.168.8.204", alias: "Laptop 2",                      image: "notebook",                   link: "http" },
        { ip: "192.168.8.205", alias: "Laptop 3",                       image: "notebook",                   link: "http" },
        { ip: "192.168.8.206", alias: "FireTV Stick Wohnzimmer",           image: "firetvstick",                link: "http" },
        { ip: "192.168.8.207", alias: "Homematic CCU3",                    image: "ccu3",                       link: "http://192.168.8.207" },
        { ip: "192.168.8.208", alias: "Drucker",                           image: "canon",                      link: "http" },
        { ip: "192.168.8.209", alias: "Metatmo Wetter",                    image: "netatmo",                    link: "http" },
        { ip: "192.168.8.210", alias: "Handy 1",                        image: "redmi8t",                    link: "http" },
        { ip: "192.168.8.211", alias: "Handy 2",                        image: "s3neo",                      link: "http" },
        { ip: "192.168.8.212", alias: "Handy 3",                      image: "mi11",                       link: "http" },
        { ip: "192.168.8.213", alias: "Handy 4",                       image: "honor20",                    link: "http" },
        { ip: "192.168.8.214", alias: "Volumio",                           image: "radio2",                     link: "http://192.168.8.214/browse" },
        { ip: "192.168.8.215", alias: "Anzeige Küche",                     image: "anzeige",                    link: "http" },
        { ip: "192.168.8.216", alias: "Arbeit",                     image: "notebook",                   link: "http" },
        { ip: "192.168.8.217", alias: "Feuerwehr",                  image: "notebook",                   link: "http" },
        { ip: "192.168.8.218", alias: "Raspi Testsystem",                  image: "kodi",                       link: "http://192.168.8.218:8081" },
        { ip: "192.168.8.219", alias: "Egon",                              image: "wr153e",                     link: "http" },
        { ip: "192.168.8.220", alias: "Heizkessel",                        image: "froling_dual",               link: "http" },
        { ip: "192.168.8.221", alias: "Raspi Strom",                       image: "iobroker",                   link: "http" },
        { ip: "192.168.8.222", alias: "NAS",                               image: "iobroker",                   link: "http://192.168.8.222" },
        { ip: "192.168.8.223", alias: "Desktop1",                     image: "desktop",                    link: "http" },
        { ip: "192.168.8.224", alias: "Raspi Heizung",                     image: "iobroker",                   link: "http" },
        { ip: "192.168.8.225", alias: "Uhr",                         image: "fenix7",                     link: "http" },
        { ip: "192.168.8.233", alias: "WD MyCloud",                        image: "mycloud",                    link: "http://192.168.8.233" },
        ];
         
        // **********************************************************************************************************************************************************************
        
        // Fomate für moment Lib
        moment.locale(sprache);
        
        // auf Änderungen aktiver Skripts hören
        let activeSelector = `[id=tr-064.1.devices.*.active]`;
        let deviceActiveList = $(activeSelector);
        if (deviceActiveList.length === 0) {
           // Fehlermeldung ausgeben, wenn selector kein result liefert
           console.error(`no result for selector '${activeSelector}'`)
        } else {
           // listener nur für Änderung bei alive
           deviceActiveList.on(GeraeteStatus);
        } 
        
        // auf Änderungen der Sortieung hören
        on({ id: dpSortMode, change: 'any' }, GeraeteStatus);
        on({ id: dpSortMode, change: 'any' }, resetSort);
        
        // // auf Änderungen der Filter hören
        on({ id: dpFilterMode, change: 'any' }, GeraeteStatus);
        on({ id: dpFilterMode, change: 'any' }, resetFilter);
        
        
        // Funktion GeraeteStatus alle x Sekunden ausführen
        schedule('*/' + checkInterval + ' * * * * *', GeraeteStatus);
        
        function GeraeteStatus() {
           try {
               let deviceList = [];
        
               for (var i = 0; i <= deviceActiveList.length - 1; i++) {
                   let id = deviceActiveList[i].replace('.active', '');
                   let obj = getObject(id);
        
                   let pattern = /(?:\d{1,3}\.){3}\d{1,3}/i;
        
                   let ipAddress = obj.common.name.match(pattern)[0];
                   let image = defaultImage;
                   let deviceName = obj.common.name.replace(/ \((?:\d{1,3}\.){3}\d{1,3}\)/g, '');
                   let device = deviceNames.find(element => element.ip == ipAddress);
                   let listType = 'text';
                   let buttonLink = '';
        
                   if(device) {
                       deviceName = device.alias;
                       image = device.image;
                       //image = `${imagePath}${device.image}.png`;
        
                       if(device.link) {
                           listType = 'buttonLink';
        
                           if(device.link == 'http') {
                               buttonLink = `http://${ipAddress}`;
                           } else {
                               buttonLink = device.link;
                           }
                       }
                   }
        
                   let macAddress = obj.native.mac;
                   let imageColor = 'black';
                   let statusBarColor = farbeGeraetOffline;
                   let status = 2;
        
                   if (getState(deviceActiveList[i]).val) {
                       statusBarColor = farbeGeraetOnline;
                       status = 1;
                   }
        
                   if(listType === 'buttonLink') {
                       deviceName = `<span style="text-decoration: underline">${deviceName}</span>`                
                   }
        
                   let lastSignIn = 'noch nicht angemeldet';
                   let lastSignOff = 'noch nicht abgemeldet';
        
                   // Letzte Anmeldung auslesen
                   if(existsState(id + '.lastActive')) {
                       lastSignIn = 'angemeldet seit: ' + moment((getState(id + '.lastActive').val)).format("DD.MM.YY HH:mm:ss");
                   }        
        
                   // Letzte Abmeldung auslesen
                   if(existsState(id + '.lastInactive')) {
                       lastSignOff = 'abgemeldet seit: ' + moment((getState(id + '.lastInactive').val)).format("DD.MM.YY HH:mm:ss");
                   }
        
                   let subText = `<div style="color: black; font-family: RobotoCondensed-BoldItalic">${ipAddress}</div>
                                  <div style="color: grey; font-family: RobotoCondensed-Regular">${lastSignIn}</div>
                                  <div style="color: grey; font-family: RobotoCondensed-Regular">${lastSignOff}</div>`
        
                   deviceList.push({
                       text: deviceName,
                       subText: subText,
                       statusBarColor: statusBarColor,
                       image: image,
                       imageColor: imageColor,
                       listType: listType,
                       buttonLink: buttonLink,
                       showValueLabel: false,
                       name: deviceName,
                       ipAddress: ipAddress,
                       status: status
                   });
               }
        
               let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
        
               if (sortMode === 'name' || sortMode === 'ipAddress') {
                   deviceList.sort(function (a, b) {
                       return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                   });
               } else if (sortMode === 'status') {
                   deviceList.sort(function (a, b) {
                       return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                   });
               } else {
                   // default: nach name sortieren
                   sortMode = 'name'
                   deviceList.sort(function (a, b) {
                       return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                   });
               }
        
        
               let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
        
               if (filterMode && filterMode !== null && filterMode !== '') {
                   if (filterMode === 'offline') {
                       deviceList = deviceList.filter(function (item) {
                           return item.status === 2;
                       });
                   } else if (filterMode === 'online') {
                       deviceList = deviceList.filter(function (item) {
                           return item.status === 1;
                       });
                   }
               }
        
        
               let result = JSON.stringify(deviceList);
               if (getState(dpList) !== result) {
                   setState(dpList, result, true);
               }
        
           } catch (err) {
               console.error(`[GeraeteStatus] error: ${err.message}, stack: ${err.stack}`);
           }
        }
        
        function resetSort() {
           let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
        
           if (sortResetAfter > 0) {
               setTimeout(function () {
                   if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                       setState(dpSortMode, sortReset);
                   }
               }, sortResetAfter * 1000);
           }
        }
        
        function resetFilter() {
           let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
        
           if (filterResetAfter > 0) {
               setTimeout(function () {
                   if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                       setState(dpFilterMode, '');
                   }
               }, filterResetAfter * 1000);
           }
        }
        
        // Beim Staren des Skriptes GeraeteStatus abrufen
        GeraeteStatus();
        
        function myHelper() {
           return {
               getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                   if (existsState(id)) {
                       return prepand + getState(id).val + append;
                   } else {
                       return nullValue;
                   }
               },
               getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                   if (myHelper().checkCommonPropertyExist(object, prop)) {
                       return prepand + object.common[prop] + append;
                   } else {
                       return nullValue;
                   }
               },
               checkCommonPropertyExist: function (object, prop) {
                   if (object && object.common && object.common[prop]) {
                       return true;
                   } else {
                       return false;
                   }
               }
           }
        }
        

        Wo liegt hier der Fehler?

        S 1 Antwort Letzte Antwort
        0
        • H Offline
          H Offline
          Hausbaer
          schrieb am zuletzt editiert von
          #270

          Keiner ne Idee?

          1 Antwort Letzte Antwort
          0
          • H Hausbaer

            Ich habe zwei Instanzen des TR-064 Adapters.

            Instanz 1 wertet mir die Sensoren / Steckdosen etc (Shelly, TP-Link....) aus, die per WLan verbunden sind.
            Instanz 2 liefert die Geräte, die im Netz als "User" angemeldet sind (Mobiltelefone, Tabs, Rechner usw).

            Für die Instanz 1 läuft das Scrip ohne Probleme.

            /* Versionshistorie:
            * 
            * 1.0.2:
            * - neu: Anzeige der letzten An- und Abmeldung
            * - neu: Verwendung eigener Bilder möglich
            * 
            * 1.0.1:
            * - neu: In dem Mapping der IP-Adressen kann jetzt eine URL vergeben werden ('http' oder direkt eine spezifische URL)
            * - geändert: Styling der Details
            * - entfernt: MAC-Adresse
            * 
            * 1.0.0:
            * - Initial Release
            */
            
            const moment = require("moment");
            
            
            
            // Datenpunkte anlegen falls nicht vorhanden ********************************
            
            if ( !existsState("0_userdata.0.vis.SensorStatus.jsonList")){createState("0_userdata.0.vis.SensorStatus.jsonList", false, {type: 'string'})}; 
            if ( !existsState("0_userdata.0.vis.SensorStatus.sortMode")){createState("0_userdata.0.vis.SensorStatus.sortMode", false, {type: 'string'})}; 
            if ( !existsState("0_userdata.0.vis.SensorStatus.filterMode")){createState("0_userdata.0.vis.SensorStatus.filterMode", false, {type: 'string'})};
            
            
            // Skript Einstellungen *************************************************************************************************************************************************
            
            let dpList = '0_userdata.0.vis.SensorStatus.jsonList';          // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
            
            let dpSortMode = '0_userdata.0.vis.SensorStatus.sortMode';      // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
            let dpFilterMode = '0_userdata.0.vis.SensorStatus.filterMode"';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
            
            const checkInterval = 30;                                         // Interval wie oft Status der Skripte aktualisiert werden soll (in Sekunden)
            
            let sprache = 'de';                                               // Sprache für formatierung letzte Änderung
            let formatierungLastChange = "ddd DD.MM - HH:mm";                 // Formatierung letzte Änderung -> siehe momentjs library
            
            let imagePath = '/vis.0/bilder/geraete/'                          // Pfad zu den verwendeten Bildern (bitte über den VIS Dateimanager hochladen)
                                                                             // nach Variable imagePath suchen und die entsprechenden Zeilen aus- bzw. einkommentieren
                                                                             // Das Bild (Dateiformat png) in der Mapping-Liste hinterlegen
            //let defaultImage = 'ip-network-outline';                          // Standardbild, falls kein Bild angegeben wurde (Material Design Icons)
            let defaultImage = `${imagePath}default.png`;                   // Standardbild, falls kein Bild angegeben wurde (eigenes Bild)
            
            let farbeGeraetOnline = '0_userdata.0.einstellung_farben_schriftarten.farbe-4';                                  // Status Bar Farbe wenn Geräte online ist
            let farbeGeraetOffline = '0_userdata.0.einstellung_farben_schriftarten.farbe-5';                             // Status Bar Farbe wenn Geräte offline ist
            
            let sortResetAfter = 120;                                         // Sortierung nach X Sekunden auf sortReset zurücksetzen (0=deaktiviert)
            let sortReset = 'name'                                            // Sortierung auf die zurückgesetzt werden soll
            
            let filterResetAfter = 120;                                       // Filter nach X Sekunden zurücksetzen (0=deaktiviert)
            
            const deviceNames = 
            [{ ip: "192.168.8.110", alias: "Steckdose Drucker",                 image: "tp-link_hs110",              link: "http" },
            { ip: "192.168.8.111", alias: "Flur EG und Keller Licht",          image: "shelly-2-5",                 link: "http://192.168.8.111" },
            { ip: "192.168.8.112", alias: "Flur EG FBH",                       image: "shelly-1",                   link: "http://192.168.8.112" },
            { ip: "192.168.8.113", alias: "Bad FBH",                           image: "shelly-1",                   link: "http://192.168.8.113" },
            { ip: "192.168.8.114", alias: "Küche FBH",                         image: "shelly-1",                   link: "http://192.168.8.114" },
            { ip: "192.168.8.115", alias: "Esszimmer FBH",                     image: "shelly-1",                   link: "http://192.168.8.115" },
            { ip: "192.168.8.116", alias: "Fenster FBH",                       image: "shelly-1",                   link: "http://192.168.8.116" },
            { ip: "192.168.8.117", alias: "Wohnzimmer FBH",                    image: "shelly-1",                   link: "http://192.168.8.117" },
            { ip: "192.168.8.118", alias: "Pumpe FBH",                         image: "shelly-1",                   link: "http://192.168.8.118" },
            { ip: "192.168.8.119", alias: "Flur DG Licht",                     image: "shelly-2-5",                 link: "http://192.168.8.119" },
            { ip: "192.168.8.120", alias: "Volumio",                           image: "shelly-1",                   link: "http://192.168.8.120" },
            { ip: "192.168.8.130", alias: "Melkkammer Licht und Heizspirale",  image: "shelly-2-5",                 link: "http://192.168.8.130" },
            { ip: "192.168.8.131", alias: "Heizraum Licht",                    image: "shelly-1",                   link: "http://192.168.8.131" },
            { ip: "192.168.8.132", alias: "Stall Licht",                       image: "shelly-1",                   link: "http://192.168.8.132" },
            { ip: "192.168.8.133", alias: "Stodl Licht",                       image: "shelly-1",                   link: "http://192.168.8.133" },
            { ip: "192.168.8.134", alias: "Solaranlage",                       image: "shelly-plug-s",              link: "http://192.168.8.134" },
            { ip: "192.168.8.140", alias: "Garage neu Licht außen",            image: "shelly-1",                   link: "http://192.168.8.140" },
            { ip: "192.168.8.141", alias: "Garage neu und Troidlager Licht",   image: "shelly-2-5",                 link: "http://192.168.8.141" },
            { ip: "192.168.8.142", alias: "Garage neu Tor 1",              image: "shelly-1",                   link: "http://192.168.8.142" },
            { ip: "192.168.8.143", alias: "Garage neu Tor 2",               image: "shelly-1",                   link: "http://192.168.8.143" },
            { ip: "192.168.8.146", alias: "Garage neu Tor 2 geschlossen",   image: "shelly-door-2",              link: "http://192.168.8.146" },
            { ip: "192.168.8.147", alias: "Garage neu Tor 1 geschlossen",  image: "shelly-door-2",              link: "http://192.168.8.147" },
            { ip: "192.168.8.150", alias: "Garage alt Licht außen und RH",     image: "shelly-2-5",                 link: "http://192.168.8.150" },
            { ip: "192.168.8.151", alias: "Garage alt Tor 3",                 image: "shelly-1-plus",              link: "http://192.168.8.151" },
            { ip: "192.168.8.152", alias: "Garage alt Tor 4",                image: "shelly-1-plus",              link: "http://192.168.8.152" },
            { ip: "192.168.8.153", alias: "Garage alt Tor 3 geschlossen",     image: "shelly-door-2",              link: "http://192.168.8.153" },
            { ip: "192.168.8.154", alias: "Garage alt Tor 4 geschlossen",    image: "shelly-door-2",              link: "http://192.168.8.154" },
            { ip: "192.168.8.155", alias: "Garage alt Licht",              image: "shelly-1",                   link: "http://192.168.8.155" },
            ];
            
            // **********************************************************************************************************************************************************************
            
            // Fomate für moment Lib
            moment.locale(sprache);
            
            // auf Änderungen aktiver Skripts hören
            let activeSelector = `[id=tr-064.0.devices.*.active]`;
            let deviceActiveList = $(activeSelector);
            if (deviceActiveList.length === 0) {
               // Fehlermeldung ausgeben, wenn selector kein result liefert
               console.error(`no result for selector '${activeSelector}'`)
            } else {
               // listener nur für Änderung bei alive
               deviceActiveList.on(netzwerkStatus);
            } 
            
            // auf Änderungen der Sortieung hören
            on({ id: dpSortMode, change: 'any' }, netzwerkStatus);
            on({ id: dpSortMode, change: 'any' }, resetSort);
            
            // // auf Änderungen der Filter hören
            on({ id: dpFilterMode, change: 'any' }, netzwerkStatus);
            on({ id: dpFilterMode, change: 'any' }, resetFilter);
            
            
            // Funktion adapterStatus alle x Sekunden ausführen
            schedule('*/' + checkInterval + ' * * * * *', netzwerkStatus);
            
            function netzwerkStatus() {
               try {
                   let deviceList = [];
            
                   for (var i = 0; i <= deviceActiveList.length - 1; i++) {
                       let id = deviceActiveList[i].replace('.active', '');
                       let obj = getObject(id);
            
                       let pattern = /(?:\d{1,3}\.){3}\d{1,3}/i;
            
                       let ipAddress = obj.common.name.match(pattern)[0];
                       let image = defaultImage;
                       let deviceName = obj.common.name.replace(/ \((?:\d{1,3}\.){3}\d{1,3}\)/g, '');
                       let device = deviceNames.find(element => element.ip == ipAddress);
                       let listType = 'text';
                       let buttonLink = '';
            
                       if(device) {
                           deviceName = device.alias;
                           //image = device.image;
                           image = `${imagePath}${device.image}.png`;
            
                           if(device.link) {
                               listType = 'buttonLink';
            
                               if(device.link == 'http') {
                                   buttonLink = `http://${ipAddress}`;
                               } else {
                                   buttonLink = device.link;
                               }
                           }
                       }
            
                       let macAddress = obj.native.mac;
                       let imageColor = '{0_userdata.0.einstellung_farben_schriftarten.farbe-8}';
                       let statusBarColor = farbeGeraetOffline;
                       let status = 2;
            
                       if (getState(deviceActiveList[i]).val) {
                           statusBarColor = farbeGeraetOnline;
                           status = 1;
                       }
            
                       if(listType === 'buttonLink') {
                           deviceName = `<span style="text-decoration: underline">${deviceName}</span>`                
                       }
            
                       let lastSignIn = 'noch nicht angemeldet';
                       let lastSignOff = 'noch nicht abgemeldet';
            
                       // Letzte Anmeldung auslesen
                       if(existsState(id + '.lastActive')) {
                           lastSignIn = 'angemeldet seit: ' + moment((getState(id + '.lastActive').val)).format("DD.MM.YY HH:mm:ss");
                       }        
            
                       // Letzte Abmeldung auslesen
                       if(existsState(id + '.lastInactive')) {
                           lastSignOff = 'abgemeldet seit: ' + moment((getState(id + '.lastInactive').val)).format("DD.MM.YY HH:mm:ss");
                       }
            
                       let subText = `<div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-3}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-3}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-5}">${ipAddress}</div>
                                      <div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-2}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-4}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-6}">${lastSignIn}</div>
                                      <div style="color: {0_userdata.0.einstellung_farben_schriftarten.farbe-2}; font-size: {0_userdata.0.einstellung_farben_schriftarten.schriftgrosse-4}; font-family: {0_userdata.0.einstellung_farben_schriftarten.schriftart-6}">${lastSignOff}</div>`
            
            
                       deviceList.push({
                           text: deviceName,
                           subText: subText,
                           statusBarColor: statusBarColor,
                           image: image,
                           imageColor: imageColor,
                           listType: listType,
                           buttonLink: buttonLink,
                           showValueLabel: false,
                           name: deviceName,
                           ipAddress: ipAddress,
                           status: status
                       });
                   }
            
                   let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
            
                   if (sortMode === 'name' || sortMode === 'ipAddress') {
                       deviceList.sort(function (a, b) {
                           return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                       });
                   } else if (sortMode === 'status') {
                       deviceList.sort(function (a, b) {
                           return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                       });
                   } else {
                       // default: nach name sortieren
                       sortMode = 'name'
                       deviceList.sort(function (a, b) {
                           return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                       });
                   }
            
            
                   let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
            
                   if (filterMode && filterMode !== null && filterMode !== '') {
                       if (filterMode === 'offline') {
                           deviceList = deviceList.filter(function (item) {
                               return item.status === 2;
                           });
                       } else if (filterMode === 'online') {
                           deviceList = deviceList.filter(function (item) {
                               return item.status === 1;
                           });
                       }
                   }
            
            
                   let result = JSON.stringify(deviceList);
                   if (getState(dpList) !== result) {
                       setState(dpList, result, true);
                   }
            
               } catch (err) {
                   console.error(`[netzwerkStatus] error: ${err.message}, stack: ${err.stack}`);
               }
            }
            
            function resetSort() {
               let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
            
               if (sortResetAfter > 0) {
                   setTimeout(function () {
                       if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                           setState(dpSortMode, sortReset);
                       }
                   }, sortResetAfter * 1000);
               }
            }
            
            function resetFilter() {
               let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
            
               if (filterResetAfter > 0) {
                   setTimeout(function () {
                       if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                           setState(dpFilterMode, '');
                       }
                   }, filterResetAfter * 1000);
               }
            }
            
            // Beim Staren des Skriptes Adapter Status abrufen
            netzwerkStatus();
            
            function myHelper() {
               return {
                   getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                       if (existsState(id)) {
                           return prepand + getState(id).val + append;
                       } else {
                           return nullValue;
                       }
                   },
                   getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                       if (myHelper().checkCommonPropertyExist(object, prop)) {
                           return prepand + object.common[prop] + append;
                       } else {
                           return nullValue;
                       }
                   },
                   checkCommonPropertyExist: function (object, prop) {
                       if (object && object.common && object.common[prop]) {
                           return true;
                       } else {
                           return false;
                       }
                   }
               }
            }
            

            Für die Instanz 2 erhalte ich aber folgende Fehlermeldungen:

            script.js.Neue-Skripte.it-adapter.it-geraete_221209: [GeraeteStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.GeraeteStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:131:59) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1214:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:596:29) at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5909:56) at processImmediate (node:internal/timers:466:21)
            
            
            script.js.Neue-Skripte.it-adapter.it-geraete_221209: [GeraeteStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.GeraeteStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:131:59) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1565:34) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28 at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7) at listOnTimeout (node:internal/timers:559:17) at processTimers (node:internal/timers:502:7)
            

            Dazu hier das Script:

            /* Versionshistorie:
            * 
            * 1.0.2:
            * - neu: Anzeige der letzten An- und Abmeldung
            * - neu: Verwendung eigener Bilder möglich
            * 
            * 1.0.1:
            * - neu: In dem Mapping der IP-Adressen kann jetzt eine URL vergeben werden ('http' oder direkt eine spezifische URL)
            * - geändert: Styling der Details
            * - entfernt: MAC-Adresse
            * 
            * 1.0.0:
            * - Initial Release
            */
            
            const moment = require("moment");
            
            
            // Datenpunkte anlegen falls nicht vorhanden ********************************
            
            if ( !existsState("0_userdata.0.vis.GeraeteStatus.jsonList")){createState("0_userdata.0.vis.GeraeteStatus.jsonList", false, {type: 'string'})}; 
            if ( !existsState("0_userdata.0.vis.GeraeteStatus.sortMode")){createState("0_userdata.0.vis.GeraeteStatus.sortMode", false, {type: 'string'})}; 
            if ( !existsState("0_userdata.0.vis.GeraeteStatus.filterMode")){createState("0_userdata.0.vis.GeraeteStatus.filterMode", false, {type: 'string'})};
            
            
            
            // Skript Einstellungen *************************************************************************************************************************************************
            
            let dpList = '0_userdata.0.vis.GeraeteStatus.jsonList';          // Datenpunkt für IconList Widget (Typ: Zeichenkette (String))
            
            let dpSortMode = '0_userdata.0.vis.GeraeteStatussortMode';      // Datenpunkt für Sortieren (Typ: Zeichenkette (String))
            let dpFilterMode = '0_userdata.0.vis.GeraeteStatus.filterMode';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
            
            const checkInterval = 30;                                         // Interval wie oft Status der Skripte aktualisiert werden soll (in Sekunden)
            
            let sprache = 'de';                                               // Sprache für formatierung letzte Änderung
            let formatierungLastChange = "ddd DD.MM - HH:mm";                 // Formatierung letzte Änderung -> siehe momentjs library
            
            let imagePath =  '/vis.0/bilder/geraete/' 		                  // Pfad zu den verwendeten Bildern (bitte über den VIS Dateimanager hochladen)
                                                                             // nach Variable imagePath suchen und die entsprechenden Zeilen aus- bzw. einkommentieren
                                                                             // Das Bild (Dateiformat png) in der Mapping-Liste hinterlegen
            let defaultImage = 'ip-network-outline';                          // Standardbild, falls kein Bild angegeben wurde (Material Design Icons)
            //let defaultImage = `${imagePath}default.png`;                   // Standardbild, falls kein Bild angegeben wurde (eigenes Bild)
            
            let farbeGeraetOnline = 'green';                                  // Status Bar Farbe wenn Geräte online ist
            let farbeGeraetOffline = 'FireBrick';                             // Status Bar Farbe wenn Geräte offline ist
            
            let sortResetAfter = 120;                                         // Sortierung nach X Sekunden auf sortReset zurücksetzen (0=deaktiviert)
            let sortReset = 'name'                                            // Sortierung auf die zurückgesetzt werden soll
            
            let filterResetAfter = 120;                                       // Filter nach X Sekunden zurücksetzen (0=deaktiviert)
            
            const deviceNames = 
            [{ ip: "192.168.8.201", alias: "Laptop Büro WLan",                  image: "notebook",                   link: "http" },
            { ip: "192.168.8.202", alias: "Laptop Büro Lan",                   image: "notebook",                   link: "http" },
            { ip: "192.168.8.203", alias: "Iobroker",                          image: "raspi1",                     link: "http://192.168.8.203:8081" },
            { ip: "192.168.8.204", alias: "Laptop 2",                      image: "notebook",                   link: "http" },
            { ip: "192.168.8.205", alias: "Laptop 3",                       image: "notebook",                   link: "http" },
            { ip: "192.168.8.206", alias: "FireTV Stick Wohnzimmer",           image: "firetvstick",                link: "http" },
            { ip: "192.168.8.207", alias: "Homematic CCU3",                    image: "ccu3",                       link: "http://192.168.8.207" },
            { ip: "192.168.8.208", alias: "Drucker",                           image: "canon",                      link: "http" },
            { ip: "192.168.8.209", alias: "Metatmo Wetter",                    image: "netatmo",                    link: "http" },
            { ip: "192.168.8.210", alias: "Handy 1",                        image: "redmi8t",                    link: "http" },
            { ip: "192.168.8.211", alias: "Handy 2",                        image: "s3neo",                      link: "http" },
            { ip: "192.168.8.212", alias: "Handy 3",                      image: "mi11",                       link: "http" },
            { ip: "192.168.8.213", alias: "Handy 4",                       image: "honor20",                    link: "http" },
            { ip: "192.168.8.214", alias: "Volumio",                           image: "radio2",                     link: "http://192.168.8.214/browse" },
            { ip: "192.168.8.215", alias: "Anzeige Küche",                     image: "anzeige",                    link: "http" },
            { ip: "192.168.8.216", alias: "Arbeit",                     image: "notebook",                   link: "http" },
            { ip: "192.168.8.217", alias: "Feuerwehr",                  image: "notebook",                   link: "http" },
            { ip: "192.168.8.218", alias: "Raspi Testsystem",                  image: "kodi",                       link: "http://192.168.8.218:8081" },
            { ip: "192.168.8.219", alias: "Egon",                              image: "wr153e",                     link: "http" },
            { ip: "192.168.8.220", alias: "Heizkessel",                        image: "froling_dual",               link: "http" },
            { ip: "192.168.8.221", alias: "Raspi Strom",                       image: "iobroker",                   link: "http" },
            { ip: "192.168.8.222", alias: "NAS",                               image: "iobroker",                   link: "http://192.168.8.222" },
            { ip: "192.168.8.223", alias: "Desktop1",                     image: "desktop",                    link: "http" },
            { ip: "192.168.8.224", alias: "Raspi Heizung",                     image: "iobroker",                   link: "http" },
            { ip: "192.168.8.225", alias: "Uhr",                         image: "fenix7",                     link: "http" },
            { ip: "192.168.8.233", alias: "WD MyCloud",                        image: "mycloud",                    link: "http://192.168.8.233" },
            ];
             
            // **********************************************************************************************************************************************************************
            
            // Fomate für moment Lib
            moment.locale(sprache);
            
            // auf Änderungen aktiver Skripts hören
            let activeSelector = `[id=tr-064.1.devices.*.active]`;
            let deviceActiveList = $(activeSelector);
            if (deviceActiveList.length === 0) {
               // Fehlermeldung ausgeben, wenn selector kein result liefert
               console.error(`no result for selector '${activeSelector}'`)
            } else {
               // listener nur für Änderung bei alive
               deviceActiveList.on(GeraeteStatus);
            } 
            
            // auf Änderungen der Sortieung hören
            on({ id: dpSortMode, change: 'any' }, GeraeteStatus);
            on({ id: dpSortMode, change: 'any' }, resetSort);
            
            // // auf Änderungen der Filter hören
            on({ id: dpFilterMode, change: 'any' }, GeraeteStatus);
            on({ id: dpFilterMode, change: 'any' }, resetFilter);
            
            
            // Funktion GeraeteStatus alle x Sekunden ausführen
            schedule('*/' + checkInterval + ' * * * * *', GeraeteStatus);
            
            function GeraeteStatus() {
               try {
                   let deviceList = [];
            
                   for (var i = 0; i <= deviceActiveList.length - 1; i++) {
                       let id = deviceActiveList[i].replace('.active', '');
                       let obj = getObject(id);
            
                       let pattern = /(?:\d{1,3}\.){3}\d{1,3}/i;
            
                       let ipAddress = obj.common.name.match(pattern)[0];
                       let image = defaultImage;
                       let deviceName = obj.common.name.replace(/ \((?:\d{1,3}\.){3}\d{1,3}\)/g, '');
                       let device = deviceNames.find(element => element.ip == ipAddress);
                       let listType = 'text';
                       let buttonLink = '';
            
                       if(device) {
                           deviceName = device.alias;
                           image = device.image;
                           //image = `${imagePath}${device.image}.png`;
            
                           if(device.link) {
                               listType = 'buttonLink';
            
                               if(device.link == 'http') {
                                   buttonLink = `http://${ipAddress}`;
                               } else {
                                   buttonLink = device.link;
                               }
                           }
                       }
            
                       let macAddress = obj.native.mac;
                       let imageColor = 'black';
                       let statusBarColor = farbeGeraetOffline;
                       let status = 2;
            
                       if (getState(deviceActiveList[i]).val) {
                           statusBarColor = farbeGeraetOnline;
                           status = 1;
                       }
            
                       if(listType === 'buttonLink') {
                           deviceName = `<span style="text-decoration: underline">${deviceName}</span>`                
                       }
            
                       let lastSignIn = 'noch nicht angemeldet';
                       let lastSignOff = 'noch nicht abgemeldet';
            
                       // Letzte Anmeldung auslesen
                       if(existsState(id + '.lastActive')) {
                           lastSignIn = 'angemeldet seit: ' + moment((getState(id + '.lastActive').val)).format("DD.MM.YY HH:mm:ss");
                       }        
            
                       // Letzte Abmeldung auslesen
                       if(existsState(id + '.lastInactive')) {
                           lastSignOff = 'abgemeldet seit: ' + moment((getState(id + '.lastInactive').val)).format("DD.MM.YY HH:mm:ss");
                       }
            
                       let subText = `<div style="color: black; font-family: RobotoCondensed-BoldItalic">${ipAddress}</div>
                                      <div style="color: grey; font-family: RobotoCondensed-Regular">${lastSignIn}</div>
                                      <div style="color: grey; font-family: RobotoCondensed-Regular">${lastSignOff}</div>`
            
                       deviceList.push({
                           text: deviceName,
                           subText: subText,
                           statusBarColor: statusBarColor,
                           image: image,
                           imageColor: imageColor,
                           listType: listType,
                           buttonLink: buttonLink,
                           showValueLabel: false,
                           name: deviceName,
                           ipAddress: ipAddress,
                           status: status
                       });
                   }
            
                   let sortMode = myHelper().getStateValueIfExist(dpSortMode, 'name');
            
                   if (sortMode === 'name' || sortMode === 'ipAddress') {
                       deviceList.sort(function (a, b) {
                           return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                       });
                   } else if (sortMode === 'status') {
                       deviceList.sort(function (a, b) {
                           return a[sortMode] == b[sortMode] ? 0 : +(a[sortMode] < b[sortMode]) || -1;
                       });
                   } else {
                       // default: nach name sortieren
                       sortMode = 'name'
                       deviceList.sort(function (a, b) {
                           return a[sortMode].toLowerCase() == b[sortMode].toLowerCase() ? 0 : +(a[sortMode].toLowerCase() > b[sortMode].toLowerCase()) || -1;
                       });
                   }
            
            
                   let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
            
                   if (filterMode && filterMode !== null && filterMode !== '') {
                       if (filterMode === 'offline') {
                           deviceList = deviceList.filter(function (item) {
                               return item.status === 2;
                           });
                       } else if (filterMode === 'online') {
                           deviceList = deviceList.filter(function (item) {
                               return item.status === 1;
                           });
                       }
                   }
            
            
                   let result = JSON.stringify(deviceList);
                   if (getState(dpList) !== result) {
                       setState(dpList, result, true);
                   }
            
               } catch (err) {
                   console.error(`[GeraeteStatus] error: ${err.message}, stack: ${err.stack}`);
               }
            }
            
            function resetSort() {
               let sortMode = myHelper().getStateValueIfExist(dpSortMode, null);
            
               if (sortResetAfter > 0) {
                   setTimeout(function () {
                       if (sortMode !== null && sortMode === myHelper().getStateValueIfExist(dpSortMode, null)) {
                           setState(dpSortMode, sortReset);
                       }
                   }, sortResetAfter * 1000);
               }
            }
            
            function resetFilter() {
               let filterMode = myHelper().getStateValueIfExist(dpFilterMode, null);
            
               if (filterResetAfter > 0) {
                   setTimeout(function () {
                       if (filterMode !== null && filterMode === myHelper().getStateValueIfExist(dpFilterMode, null)) {
                           setState(dpFilterMode, '');
                       }
                   }, filterResetAfter * 1000);
               }
            }
            
            // Beim Staren des Skriptes GeraeteStatus abrufen
            GeraeteStatus();
            
            function myHelper() {
               return {
                   getStateValueIfExist: function (id, nullValue = undefined, prepand = '', append = '') {
                       if (existsState(id)) {
                           return prepand + getState(id).val + append;
                       } else {
                           return nullValue;
                       }
                   },
                   getCommonPropertyIfExist: function (object, prop, nullValue = undefined, prepand = '', append = '') {
                       if (myHelper().checkCommonPropertyExist(object, prop)) {
                           return prepand + object.common[prop] + append;
                       } else {
                           return nullValue;
                       }
                   },
                   checkCommonPropertyExist: function (object, prop) {
                       if (object && object.common && object.common[prop]) {
                           return true;
                       } else {
                           return false;
                       }
                   }
               }
            }
            

            Wo liegt hier der Fehler?

            S Offline
            S Offline
            stephan61
            schrieb am zuletzt editiert von
            #271

            @hausbaer in Zeile 31 fehlt ein Punkt

            Gruß Stephan

            DJMarc75D H 2 Antworten Letzte Antwort
            0
            • S stephan61

              @hausbaer in Zeile 31 fehlt ein Punkt

              Gruß Stephan

              DJMarc75D Online
              DJMarc75D Online
              DJMarc75
              schrieb am zuletzt editiert von DJMarc75
              #272

              @stephan61 da fehlt kein Punkt sondern ist ein " zuviel drin. :grinning:

              EDIT: ja, im zweiten Skript fehlt der Punkt - sorry @stephan61

              Lehrling seit 1975 !!!
              Beitrag geholfen ? dann gerne ein upvote rechts unten im Beitrag klicken ;)
              https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge

              1 Antwort Letzte Antwort
              0
              • S stephan61

                @hausbaer in Zeile 31 fehlt ein Punkt

                Gruß Stephan

                H Offline
                H Offline
                Hausbaer
                schrieb am zuletzt editiert von
                #273

                @stephan61 sagte in Material Design Widets: Netzwerk Status:

                @hausbaer in Zeile 31 fehlt ein Punkt

                Gruß Stephan

                Sorry, ich seh es grad nicht. :thinking_face:
                Wo fehlt hier ein Punkt?

                
                let dpFilterMode = '0_userdata.0.vis.GeraeteStatus.filterMode';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
                
                DJMarc75D 1 Antwort Letzte Antwort
                0
                • H Hausbaer

                  @stephan61 sagte in Material Design Widets: Netzwerk Status:

                  @hausbaer in Zeile 31 fehlt ein Punkt

                  Gruß Stephan

                  Sorry, ich seh es grad nicht. :thinking_face:
                  Wo fehlt hier ein Punkt?

                  
                  let dpFilterMode = '0_userdata.0.vis.GeraeteStatus.filterMode';  // Datenpunkt für Filter (Typ: Zeichenkette (String))
                  
                  DJMarc75D Online
                  DJMarc75D Online
                  DJMarc75
                  schrieb am zuletzt editiert von
                  #274

                  @hausbaer Zeile 31:

                  let dpSortMode = '0_userdata.0.vis.GeraeteStatussortMode';
                  
                  let dpSortMode = '0_userdata.0.vis.GeraeteStatus.sortMode';
                  

                  Lehrling seit 1975 !!!
                  Beitrag geholfen ? dann gerne ein upvote rechts unten im Beitrag klicken ;)
                  https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge

                  H 1 Antwort Letzte Antwort
                  0
                  • DJMarc75D DJMarc75

                    @hausbaer Zeile 31:

                    let dpSortMode = '0_userdata.0.vis.GeraeteStatussortMode';
                    
                    let dpSortMode = '0_userdata.0.vis.GeraeteStatus.sortMode';
                    
                    H Offline
                    H Offline
                    Hausbaer
                    schrieb am zuletzt editiert von
                    #275

                    @djmarc75
                    Ah jetzt. :grimacing:

                    Das ändert aber nichts an der Fehlermeldung:

                    script.js.Neue-Skripte.it-adapter.it-geraete_221209: [netzwerkStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0') at Object.netzwerkStatus (script.js.Neue-Skripte.it-adapter.it-geraete_221209:130:59) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1214:38) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:596:29) at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5909:56) at processImmediate (node:internal/timers:466:21)
                    
                    1 Antwort Letzte Antwort
                    0
                    • R Rosi8818

                      @gargano :+1: :+1: :+1:
                      jepp, ich freu mich so, eine Menge gelernt dank deiner Geduld :)
                      Danke

                      H Offline
                      H Offline
                      Hausbaer
                      schrieb am zuletzt editiert von
                      #276

                      @rosi8818 sagte in Material Design Widets: Netzwerk Status:

                      @gargano :+1: :+1: :+1:
                      jepp, ich freu mich so, eine Menge gelernt dank deiner Geduld :)
                      Danke

                      Kannst du das Script mal hier posten? Ich hab eine ähnliche Situation - und das will einfach nicht.....

                      1 Antwort Letzte Antwort
                      0
                      • B Offline
                        B Offline
                        Bongo
                        schrieb am zuletzt editiert von
                        #277

                        Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                        javascript.0
                        	2023-02-16 09:44:30.158	error	script.js.common.Vis.NetzwerkStatus: [netzwerkStatus] error: Cannot read properties of null (reading 'common'), stack: TypeError: Cannot read properties of null (reading 'common') at Object.netzwerkStatus (script.js.common.Vis.NetzwerkStatus:166:33) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1595:34) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28 at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7) at listOnTimeout (node:internal/timers:559:17) at processTimers (node:internal/timers:502:7)
                        javascript.0
                        	2023-02-16 09:44:30.156	warn	script.js.common.Vis.NetzwerkStatus: Object "tr-064.0.devices.Saturn" does not exist
                        

                        Das Objekt tr-064.0.devices.Saturn aus der Warnung gibt es wirklich nicht. Ich habe es aber auch nirgends definiert.
                        In der Fritzbox steht Saturn unter "Ungenutze Verbindungen". Das war ein alter PC.

                        Der Error scheint in Zeile 166 zu sein. Da sieht es so aus:
                        hc_1645.png

                        Zur Sicherheit habe ich das Script aus dem ersten Thread nochmal runter geladen. Aber das selbe Problem.

                        Gibt es dazu eine Lösung? Ich habe nichts gefunden.
                        Achso, bis vor ein paar Tagen ist es ohne Probleme gelaufen.

                        Gruß
                        Bongo

                        Script - Die sprechende Kaffeemaschine – Home Connect
                        Script - JUDO Wasserenthärtung - Connectivity-Modul API

                        B 1 Antwort Letzte Antwort
                        0
                        • B Bongo

                          Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                          javascript.0
                          	2023-02-16 09:44:30.158	error	script.js.common.Vis.NetzwerkStatus: [netzwerkStatus] error: Cannot read properties of null (reading 'common'), stack: TypeError: Cannot read properties of null (reading 'common') at Object.netzwerkStatus (script.js.common.Vis.NetzwerkStatus:166:33) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1595:34) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28 at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7) at listOnTimeout (node:internal/timers:559:17) at processTimers (node:internal/timers:502:7)
                          javascript.0
                          	2023-02-16 09:44:30.156	warn	script.js.common.Vis.NetzwerkStatus: Object "tr-064.0.devices.Saturn" does not exist
                          

                          Das Objekt tr-064.0.devices.Saturn aus der Warnung gibt es wirklich nicht. Ich habe es aber auch nirgends definiert.
                          In der Fritzbox steht Saturn unter "Ungenutze Verbindungen". Das war ein alter PC.

                          Der Error scheint in Zeile 166 zu sein. Da sieht es so aus:
                          hc_1645.png

                          Zur Sicherheit habe ich das Script aus dem ersten Thread nochmal runter geladen. Aber das selbe Problem.

                          Gibt es dazu eine Lösung? Ich habe nichts gefunden.
                          Achso, bis vor ein paar Tagen ist es ohne Probleme gelaufen.

                          B Offline
                          B Offline
                          Bongo
                          schrieb am zuletzt editiert von
                          #278

                          @bongo sagte in Material Design Widets: Netzwerk Status:

                          Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                          Für die Nachwelt wie ich es gelöst habe:

                          • Script NetzwerkStatus gestoppt
                          • tr-064 Adapter gestoppt und gelöscht.
                          • Objektbaum von tr-064 gelöscht.
                          • Javascript Adapter neu gestartet.
                          • tr-064 Adapter installiert und Geräte über "Geräte suchen" hinzugefügt.
                          • Script NetzwerkStatus neu gestartet.

                          Läuft ohne Fehlermeldung!

                          Vielleicht hätte es den einen oder anderen Schritt nicht gebraucht.
                          Jedenfalls hat das script ein Device gefunden, das im Objektbaum und im Json Datenpunkt nicht vorhanden war. Zumindest nicht sichtbar. Ich denke der TR-064 Adapter war das Problem, der ein nicht aktives Device versteckt hat.

                          Gruß
                          Bongo

                          Script - Die sprechende Kaffeemaschine – Home Connect
                          Script - JUDO Wasserenthärtung - Connectivity-Modul API

                          B 2 Antworten Letzte Antwort
                          0
                          • B Bongo

                            @bongo sagte in Material Design Widets: Netzwerk Status:

                            Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                            Für die Nachwelt wie ich es gelöst habe:

                            • Script NetzwerkStatus gestoppt
                            • tr-064 Adapter gestoppt und gelöscht.
                            • Objektbaum von tr-064 gelöscht.
                            • Javascript Adapter neu gestartet.
                            • tr-064 Adapter installiert und Geräte über "Geräte suchen" hinzugefügt.
                            • Script NetzwerkStatus neu gestartet.

                            Läuft ohne Fehlermeldung!

                            Vielleicht hätte es den einen oder anderen Schritt nicht gebraucht.
                            Jedenfalls hat das script ein Device gefunden, das im Objektbaum und im Json Datenpunkt nicht vorhanden war. Zumindest nicht sichtbar. Ich denke der TR-064 Adapter war das Problem, der ein nicht aktives Device versteckt hat.

                            B Offline
                            B Offline
                            Bongo
                            schrieb am zuletzt editiert von
                            #279

                            @bongo sagte in Material Design Widets: Netzwerk Status:

                            @bongo sagte in Material Design Widets: Netzwerk Status:

                            Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                            Für die Nachwelt wie ich es gelöst habe:

                            Nachdem über Nacht für die Datensicherung der Container gestopt und wieder gestartet war, kam die Fehlermeldung wieder.
                            Dann habe ich das Script neu gestartet, dann war die Fehlermeldung wieder weg. Verrückt!

                            Gruß
                            Bongo

                            Script - Die sprechende Kaffeemaschine – Home Connect
                            Script - JUDO Wasserenthärtung - Connectivity-Modul API

                            1 Antwort Letzte Antwort
                            0
                            • B Bongo

                              @bongo sagte in Material Design Widets: Netzwerk Status:

                              Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                              Für die Nachwelt wie ich es gelöst habe:

                              • Script NetzwerkStatus gestoppt
                              • tr-064 Adapter gestoppt und gelöscht.
                              • Objektbaum von tr-064 gelöscht.
                              • Javascript Adapter neu gestartet.
                              • tr-064 Adapter installiert und Geräte über "Geräte suchen" hinzugefügt.
                              • Script NetzwerkStatus neu gestartet.

                              Läuft ohne Fehlermeldung!

                              Vielleicht hätte es den einen oder anderen Schritt nicht gebraucht.
                              Jedenfalls hat das script ein Device gefunden, das im Objektbaum und im Json Datenpunkt nicht vorhanden war. Zumindest nicht sichtbar. Ich denke der TR-064 Adapter war das Problem, der ein nicht aktives Device versteckt hat.

                              B Offline
                              B Offline
                              Bongo
                              schrieb am zuletzt editiert von
                              #280

                              @bongo sagte in Material Design Widets: Netzwerk Status:

                              @bongo sagte in Material Design Widets: Netzwerk Status:

                              Hi, diese Meldung haben schon mehrere bekommen aber eine Lösung konnte ich nicht finden:

                              Für die Nachwelt wie ich es gelöst habe:

                              Jetzt kommt diese Fehlermeldung:

                              error: javascript.0 (188) script.js.common.Vis.NetzwerkStatus: [netzwerkStatus] error: Cannot read properties of null (reading '0'), stack: TypeError: Cannot read properties of null (reading '0')
                                  at Object.netzwerkStatus (script.js.common.Vis.NetzwerkStatus:172:59)
                                  at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1595:34)
                                  at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15)
                                  at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28
                                  at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7)
                                  at listOnTimeout (node:internal/timers:559:17)
                                  at processTimers (node:internal/timers:502:7)
                              

                              Ich glaube mit diesem Script gebe ich auf. :-(

                              Gruß
                              Bongo

                              Script - Die sprechende Kaffeemaschine – Home Connect
                              Script - JUDO Wasserenthärtung - Connectivity-Modul API

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


                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              823

                              Online

                              32.4k

                              Benutzer

                              81.5k

                              Themen

                              1.3m

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

                              • Du hast noch kein Konto? Registrieren

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