@htrecksler ich habe das mal ein bisschen überarbeitet. Der createState war nicht korrekte und das Log hat Fehler geworfen. Das Objekt was angelegt wurde war nur Read Only.
Hier die angepasste Version:
//Das Script überprüft regelmässig die Datenpunkte auf Aktualisierung
//Angabe des Datenpunkts= Datenpunkt der Überwacht werden soll
//StateBezeichnung= Unter pfad_javascript.StateBezeichung wird ein State angelegt; True = Daten sind aktuell / False = Daten veraltet
//Zeit in Sekunden = Zeit die vergangen sein darf seit der letzen Aktualisierung des Datenpunkts (0 = default Zeit wird genommen).
schedule("*/3 * * * *" , function () {
// Angabe des Datenpunkts;StateBezeichnung;Zeit in Sekunden
var ueberwachung = ['mqtt.0.Wetterstation.Batterie;Wetterstation;440'];
var default_zeit = 400;
var pfad_userdata ='0_userdata.0.watchdog.'; // !Punkt nicht vergessen am Ende!
//------------------------------------------------------------------
//Ab hier nichts mehr Ändern
//------------------------------------------------------------------
var zeit= Math.floor(Date.now() / 1000);
var differenz, lchange;
var daten, tchange;
ueberwachung.forEach(function(item, index, array)
{
// Array Splitten
daten = item.split(";");
//Datenpunkt erstellen wenn nicht vorhanden
createState(pfad_userdata + daten[1], {
read: true,
write: true,
name: "Watchdog " + daten[1],
type: "boolean",
def: false
} )
//Differenz Zeit default oder manuell?
differenz = parseInt(daten[2]);
if (differenz == 0) differenz=default_zeit;
//Zeitstempel abfragen in Sekunden
tchange=parseInt(getState(daten[0]).ts / 1000);
//Vergleichen der Zeitstempel
if ((zeit-tchange)>differenz)
{
setState(pfad_userdata + daten[1], false);
//setState("telegram.0.communicate.response", daten[1] + ' - ' + "Info: Sensor nicht erreichbar");
//console.log(daten[1] + " ist älter als " + differenz + " Sekunden", 'warn');
}
else
{
setState(pfad_userdata + daten[1], true);
//console.log(daten[1] + " ist jünger als " + differenz + " Sekunden");
}
});
});