NEWS
[Vorlage] Variable Zeitsteuerung mit VIS Editor
-
@ak1
Ich würde ein Object namens Daylight erstellen, dass true bzw false in Abhängigkeit der Astro Zeit aufweist.
Wenn Uhrzeit zwischen sunrise und sunset = true
Ansonsten false.
Dieses Object dann als weitere Bedingung in Timer einbinden. -
@GiuseppeS
Das klingt gut und logisch. Ein Skript würde dann den Wert dieses Objektes setzen. Was wäre ein geeigneter Trigger, um so ein Skript auszulösen? Oder müsste das Skript einfach zyklisch alle paar Minuten laufen lassen? -
@ak1
Würde selbst alle 5 Minuten triggern. Dadurch hat man zwar eine größere Abweichung zwischen Object und Realität aber mir würde es genügen.Edit:
Hatte hier alternativ eine weitere Lösung beschrieben. Aber war eher unnötig kompliziert. Falls schon gelesen, bitte ignorieren. -
@ak1 sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:
….Hat jemand einen Ansatz, wie man ggf. Bedingungen gestalten kann, die z.B. Die aktuelle Zeit und Astro-Zeiten berücksichtigen?
….Ganz einfach …. nimm dieses Skript/Datenpunkte , als Bedingung :
.
.
Skript:
-
-
Hallo zusammen,
wie bekomme ich das repariert?
2019-10-02 21:03:00.011 warn at Timer.processTimers (timers.js:223:10) javascript.1 2019-10-02 21:03:00.011 warn at listOnTimeout (timers.js:263:5) javascript.1 2019-10-02 21:03:00.011 warn at tryOnTimeout (timers.js:300:5) javascript.1 2019-10-02 21:03:00.011 warn at ontimeout (timers.js:438:13) javascript.1 2019-10-02 21:03:00.011 warn at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1856:34) javascript.1 2019-10-02 21:03:00.011 warn at Object.<anonymous> (script.js.common.Anwesenheitssimulation.AS_Bad:54:11) javascript.1 2019-10-02 21:03:00.011 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1276:20) javascript.1 2019-10-02 21:03:00.009 warn State "control.0.presence_abscence.AS_Bad_2" not found
Es gibt den State/das Objekt "AS_Bad_2" nicht mehr. Es gibt auch keinen Timer mehr dazu und auch kein Überbleibsel in der Aufzählung "Timers".
Allerdings hatte ich den Fehler gemacht, entsprechende Timer zu löschen, dann das Objekt zu entfernen und anschließend das Zeitsteuerungsskript neu zu starten. Erst dann ist mir aufgefallen, dass ich noch eine "AS_Bad_2"-Leiche in der Aufzählung habe.Ich dachte ich hätte nun alles korrigiert, aber diese Warnung taucht immer wieder auf.
Kann ich das irgendwo bereinigen?
Danke und Gruß
ak1 -
-
@sigi234
Ja, habe ich. Auf dem Adapter .0 läuft normalerweise alles, was schon "produktiv" ist. Auf .1 laufen die Skripte, an denen ich noch am Basteln bin. -
@ak1 sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:
@sigi234
Ja, habe ich. Auf dem Adapter .0 läuft normalerweise alles, was schon "produktiv" ist. Auf .1 laufen die Skripte, an denen ich noch am Basteln bin.Leg den DP noch mal an.
control.0.presence_abscence.AS_Bad_2
-
@sigi234
Habe ich jetzt nochmal gemacht. Ich habe ihn auch in "Timers" Aufzählung aufgenommen.
Mal sehen, ob sich die Warnung irgendwann wiederholt. Ich meine, sie kam bislang nur einmal täglich.Noch als Hintergrundinformation: Ich benutze die Zeitsteuerung ja für eine Anwesenheitssimulation. Und ich möchte da durch die Timer nicht unmittelbar Lampen schalten. Vielmehr schalte ich von mir angelegte Objekte/States, die dann wieder mein Skripte für Küche, Bad, ... triggern. Das gibt mir mehr Flexibilität und funktioniert eigentlich sehr gut.
-
@ak1
Wenn Du ein Gerät über die Vis löschst (d.h. alle Timer löschen), dann wird das Gerät auch aus dem Haupt JSON gelöscht.
Beim jedem Neustart des Scripts wird die hinterlegte Aufzählung durchlaufen, wenn vermeintlich neue Geräte in der Aufzählung vorhanden sind, werden diese Geräte mit den beiden Default Timer erstellt. War das bei dir auch der Fall oder wurde aufgrund der Leiche schon mit Fehlern abgebrochen? Hätte mMn noch stattfinden müssen.
Ansonsten mal TimerJSON hier anfügen. Dann kann man da noch rein schauen.Nachdem du den Fehlerfall hattest, hast du mal den PC neu gestartet? Würde ich empfehlen, manchmal laufen irgendwelche alten fehlerhaften Codes im JS wenn nicht neu gestartet wird. Liegt vllt an der JS Sandbox Funktionalität. Der User Glasfaser hatte zumindest auch schonmal merkwürdiges Verhalten, was mit Neustart behoben wurde.
-
@GiuseppeS sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:
Nachdem du den Fehlerfall hattest, hast du mal den PC neu gestartet? Würde ich empfehlen, manchmal laufen irgendwelche alten fehlerhaften Codes im JS wenn nicht neu gestartet wird. Liegt vllt an der JS Sandbox Funktionalität.
Da kann ich ein Liedchen von singen …. Link Text
Der User Glasfaser hatte zumindest auch schonmal merkwürdiges Verhalten, was mit Neustart behoben wurde.
Jipp … der Tip war
-
Besten Dank für die Hinweise. Im Timer JSON war keine Spur von AS_Bad_2 zu finden. Aber wie gesagt, ich habe jetzt den besagten Datenpunkt nochmal angelegt. Das Skript hat ihn beim Neustart auch ordentlich gefunden. Außerdem habe ich meine ioBroker-(virtuelle)-Maschine neu gestartet. Ich bin mir tatsächlich nicht sicher, ob ich das vorher gemacht hatte.
Jetzt warte ich erstmal, dann lösche ich die beiden Standardtimer für AS_Bad_2, nehme den Datenpunkt aus der Aufzählung, lösche den Datenpunkt und starte dann das Skript nochmal. Ich hoffe, dass dann AS_Bad_2 nicht mehr als Zombie umhergeht -
Nur ein kleiner Hinweis bzgl. Sommerzeit/Winterzeit:
Astro-Zeiten wurden laut Vorlage immer um 15:05 Uhr neu berechnet und um 15:10 Uhr mit Funktion recalc() verwendet. Diese Zeiten stehen in den Zeilen 481/482.
Heute Morgen hatte es den Nachteil, dass die oft genutzten Sunrise Zeiten noch in Sommerzeit waren. Bitte die Zeiten in den Zeilen 481/482 anpassen. Mit 4:00 Uhr und 4:01 Uhr sollte nichts mehr schief gehen:
// Astro-Zeiten werden täglich aktualisiert, anschließend neu Berechnung der Timer schedule('0 4 * * *', setAstro); schedule('1 4 * * *', recalc);
Im ersten Post habe ich das bereits angepasst. Weiterhin viel Spaß mit dem Skript.
-
Skripte wurden geändert …
@GiuseppeS sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:
….. Weiterhin viel Spaß mit dem Skript.
Funktioniert super …… Danke .
-
Absolut super das script, sehr brauchbar, vielen Dank für deine Arbeit! Müsste eigendlich ein Adapter sein, Zeitschaltungen braucht doch fast jeder für sein SmartHome, gibt es Bestrebungen in die Richtung?
Eine kleine Frage hätte ich noch:
Wäre es möglich, das Überwachen einer Bedingung einzubauen? D.h. wenn wegen einer Bedingung nicht geschaltet wird, die Bedingung dann aber wegfällt und noch geschaltet sein sollte, er nachträglich noch schaltet?
Also z.B. Rollladen soll von 15-17 Uhr geschlossen sein, wird aber nicht da um 15Uhr die Türe offen ist. Um 15:30 Uhr wird die Türe geschlossen, und Rolladen soll dann runterfahren.
Hab das bisher über ein zusatzscript und Datenpunkt mit "sollzustand" gelöst den ich jeweils prüfe, finde ich aber etwas unschön, da ich dann ja die Bedingung gleich weglassen könnte. -
@dbweb
Bestrebungen dieses Skript als Adapter zur Verfügung zu stellen, gibt es aus unterschiedlichen Gründen nicht. Ein Adapter ist viel komplexer als ein Skript. Ein Adapter würde aus meiner Sicht nur Sinn machen, wenn zusätzlich ein VIS Widget für die Darstellung zur Verfügung gestellt wird; hier wäre ich aber ein blutiger Anfänger...Die Idee, dass Timer nachträglich (innerhalb eines Zeitfensters) ausgeführt werden, wenn Bedingungen sich positiv ändern, ist absolut verständlich. Die kam mir nämlich auch schon
Auch @K_o_bold hatte sich diesbezüglich in der Vergangenheit gemeldet.
Zum Beispiel für eine Anwesenheitssimulation, die sofort startet, wenn man das Haus verlässt und die sunset Zeit überschritten ist.
Wie müsste die Konfiguration eines Timers aussehen: Im PopUp ein neuer Schalter "Timer merken" und ein Dropdown für die Zeit in 10-Minuten Schritten?Das Scripten wäre schon komplex. Wären bestimmt x hundert Code-Zeilen...
-
genau diese Interaktion mit dem Rollladen die @dbweb erwähnt hat, habe ich dir auch schon mal genannt :-).
Wäre es vielleicht einfacher für dich, ein zweites Skript zu erstellen, in dem die Trigger nicht die Zeit sondern die Bedingungen sind?
Und im Popup dann einen Schalter einbauen, wo man definieren kann ob man Zeit oder Bedingungs Trigger verwenden will? -
Beim Adapter wäre halt die Frage, ob die Konfiguration der Zeiten nicht als separater Tab im Admin sein sollte und man nur optional das Widget installiert, falls man die Zeiten vom vis aus einstellen möchte.
Adapter sind ja nicht per se komplizierter, es käme halt noch ein "Adaptergerüst" um dein Script. Dafür hast du im Adapter etwas mehr Möglichkeiten, Dinge die man jetzt im Script ändern muss könnte man in der Adapterkonfiguration oder automatisch machen, dein Script wäre damit auch für Leute zugänglich, die sich nicht an Javascript rantrauen (wieso auch immer). Ich würde mich auch anbieten dir dabei zu helfenWegen den Bedinungen schreibe ich später etwas, muss mal schauen wie du das alles im Code umgesetzt hast um eine Idee zu haben wie man das "einfach" einbauen könnte.
-
@K_o_bold sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:
genau diese Interaktion mit dem Rollladen die @dbweb erwähnt hat, habe ich dir auch schon mal genannt :-).
Wäre es vielleicht einfacher für dich, ein zweites Skript zu erstellen, in dem die Trigger nicht die Zeit sondern die Bedingungen sind?
Und im Popup dann einen Schalter einbauen, wo man definieren kann ob man Zeit oder Bedingungs Trigger verwenden will?Ein Trigger sollte schon zumindest ein Zeitfenster haben, um eine Aktion auszuführen. Ansonsten wäre es ja einfacher mit Blockly etwas gemäß "Wenn Trigger, dann Aktion X".