NEWS
Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x
-
@Thomas-Braun sagte in Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x:
@AxelF1977 Da meldest du dich nicht als root an!
Ein Debian immer per 'sudo' managen.Iobroker wurde zu Beginn als „Root“ installiert wenn ich mich richtig zurück erinnere.
Außerdem kann man ruhig Root verwenden wenn man weiß was man macht.
Meine iobroker hauptinstallation stammt auch noch aus der Zeit und die manage ich schon ewig völlig problemlos als Root.
Aber zu dem JS Problemen habe ich am Handy im log was mit „Logs „ gesehen.
Da hat sich wenn ich das noch finde etwas geändert und musste auch in einige Adapter implementiert werden was das Schreiben in das log betrifft.
Glaube das ist in deinen scripten das Problem.
Ich suche mal.
-
@wendy2702 said in Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x:
Außerdem kann man ruhig Root verwenden wenn man weiß was man macht.
Außerdem kann man ruhig Root verwenden wenn man weiß was man macht.
Das ist aber genau der Punkt: Die meisten springen in den root rein und fuhrwerken eben ohne zu wissen was die da so treiben auf dem System rum. Je weiter man sich vom vorgesehenen Standard entfernt, umso mehr muss man sein System kennen.
-
@Thomas-Braun
Na wenn ich ich alles mit sudo unterm normalen User mache, kann ich zu 95% mein System genau so ruinieren, wenn ich gar nicht weiß was ich mache.
Könntest mal ein konkretes Beispiel dafür geben was ein 08/15 User mit root schießt was er mit "normalem User und sudo nicht schießen würde?
Klar ist und da hast vollkommen Recht, es ist nicht gedacht immer mit root angemeldet zu sein. -
Mal gesehen das schon auf zwei Fehler im Script hingewiesen wurde.
Ist das mal untersucht worden oder besteht nach dem downgrade überhaupt noch Interesse?
-
@Jan1
Klar, mit einem 'sudo rm -rf /' schaufelst du dir genauso ein Grab wie mit dem gleichen Befehl als root.
Aber wenn du als root unterwegs bist läuft das (u. U.) in einem anderem userenvironment ab. Mit 'sudo' läuft das zwar mit root-Rechten ab, allerdings im userspace. Das macht schon einen Unterschied.
Deswegen werden ja z. B. auch einige Systembefehle (wie z. B. 'ping') auch mit setuserid angelegt:pi@raspberrypi:/opt/iobroker $ ls -la /bin/ping -rwsr-xr-x 1 root root 55720 Aug 3 2018 /bin/ping
Warnhinweis: Die o.a. Befehle sollten nicht eingegeben werden, auch nicht testweise!
-
@Thomas-Braun
Für Dich vielleicht, für mich hört sich das schon wieder nur nach Bahnhof an und wer kommt schon auf die Idee sich sein root Verzeichnis löschen zu wollen? Ein User der nicht viele Plan hat, der kennt solche Befehle gar nicht und macht in der Regel eh fast alles mit copy & paste was er hier im Forum so liest. -
@Jan1 @Thomas-Braun @wendy2702
Ich mag ja dieses T-SHirt ...
[Nachtrag]
na gut, dann sicherheitshalber einen Hinweis:
Liebe Kinder, macht das NIEMALS ansonsten könnte es sein, dass ihr beim Aufruf eines ansich harmlosen Befehles alle Dateien und Verzeichnisse von eurem Linux System löscht!! -
@BBTown Mach das weg! Das ist böse!
-
@Thomas-Braun
aber erklärt wie ein DAU auf sone blöde Idee kommen kann -
Die Diskussion über die Verwendung des ersten Users als 'sudoer' und inaktivem root gab es intensiv mit Aufkommen der ersten Version von ubuntu. Die haben das soweit ich weiß als erste umfassend so gemacht. Mittlerweile macht Debian (von dem ubuntu ja abstammt) das aber aus guten Gründen auch so. Das ganze ist aber Debian-typisch heiß diskutiert worden.
-
@Thomas-Braun
Ja aber diese Gründe erschließen sich einem Linux Laien aber eben nicht, wenn nur in dem ständig darauf hingewiesen wird ohne dass mal ein Beispiel kommt, bei dem der Groschen fällt. Egal, wird eh gerade zu OT das ganze, wobei mich es wirklich an einem einfachen Beispiel erklärt interessieren würde, wo es für den normalen User gefährlicher wird. -
@wendy2702 sagte in Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x:
Mal gesehen das schon auf zwei Fehler im Script hingewiesen wurde.
Ist das mal untersucht worden oder besteht nach dem downgrade überhaupt noch Interesse?
Es besteht auf jeden Fall Interesse.
Ich habe jetzt nur die Befürchtung, dass das endlos gehen wirtd, also weil ich sehr viele Scripte habe, die bis auf die Blockly per Copy und Paste aus dem Forum kommen.
Aber gerne würde ich das weiter ergründen.
Ich poste gerne nochmal den gesamten Log der Javascript Instanz. Nur error oder alles? Damit die Fehler identifiziert werden können. Dann gerne die Scriptzeilen, um zu gucken was es denn ist.
Der Rest sind für mich jetzt hier alles bömische Dörfer
-
-
@Thomas-Braun
kannte ich bereits, aber viel schlauer hats mich nicht gemacht. Problem ist auch, dass sich ein Laie unterm normalen User sehr schnell angewöhnt, eh alles mit sudo auszuführen und ich denke, da sollte man eher mal drauf hinweisen, dass das eben auch ne blöde Idee ist. -
Ich kann mir einen Grund vorstellen, warum es mit JS-Controller 2.x läuft und mit 3.x Probleme gibt. Ab js-controller 3.x führen Fehler, die auftreten und nicht behandelt werden zum beenden des Adapters.
Das Fehler in einzelnen Skripten den javascript adapter crashen, finde ich dabei allerdings nicht so prickelnd. Hm. -
@Garfonso sagte in Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x:
Ich kann mir einen Grund vorstellen, warum es mit JS-Controller 2.x läuft und mit 3.x Probleme gibt. Ab js-controller 3.x führen Fehler, die auftreten und nicht behandelt werden zum beenden des Adapters.
Das klingt nach dem was bei mir passiert
@Garfonso sagte in Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x:
Das Fehler in einzelnen Skripten den javascript adapter crashen, finde ich dabei allerdings nicht so prickelnd. Hm.
Ich auch nicht. Aber wir grenzen ja das Problem ein. Alte Scripte, die jetzt Fehlerhaft sind.
-
@AxelF1977 wenn du einmal die fehlerhaften Skripte (ausgenommen Blocky) hier posten könntest, dann könnte man da mal draufschauen.
-
@J-A-R-V-I-S sagte in Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x:
@AxelF1977 wenn du einmal die fehlerhaften Skripte (ausgenommen Blocky) hier posten könntest, dann könnte man da mal draufschauen.
"Nur" die wo es error gibt im log oder auch warnings?
-
@AxelF1977
fang mal mit error an.
Am besten die, die oben in den logs die Fehler erzeugt haben. -
@Garfonso sagte in Scripte laufen nicht mehr seit Update auf JS-Controler 3.0x:
@AxelF1977
fang mal mit error an.
Am besten die, die oben in den logs die Fehler erzeugt haben.ok, zu diesen Fehlern
javascript.0 2020-05-03 18:19:35.039 error (28611) at script.js.Schwellwerte.Schwellwerte:754:1 javascript.0 2020-05-03 18:19:35.039 error (28611) at dpAnlegen (script.js.Schwellwerte.Schwellwerte:684:9) javascript.0 2020-05-03 18:19:35.039 error (28611) ReferenceError: logs is not defined javascript.0 2020-05-03 18:19:35.039 error (28611) ^ javascript.0 2020-05-03 18:19:35.039 error (28611) logs(pfad + schwellwerte[geraet].datenpunkt + " wurde angelegt","debug"); javascript.0 2020-05-03 18:19:35.038 error (28611) script.js.Schwellwerte.Schwellwerte: script.js.Schwellwerte.Schwellwerte:684
ist dass das Script
// todo: onAnlegen() Funktion in Funktion var loglevel = "warn"; // Loglevel des Scriptes (debug,info,warn,error) - benutzt die Funktion logs() var pfad = "Schwellwerte."; // ----------------------------------------------------------------------------- // Datenpunkte, für die Schwellwerte angelegt werden sollen // ----------------------------------------------------------------------------- // datenpunkt: Name des Datenpunkt für die Schwellwerte // liste: Verweis auf die entspechende Schwellwerteliste in diesem Script var schwellwerte = { "hm-rpc.3.0001D8A98C373C.6.POWER" : { "datenpunkt": "Strom.Fernseher.Nik", "liste": "wattFernseherNik" }, "hm-rpc.2.LEQ0847294.4.ACTUAL_TEMPERATURE"/*Nik Klima.TEMPERATURE*/ : { "datenpunkt": "Klima.Temperatur.Nik", "liste": "raumKlimaTemperatur" }, "hm-rpc.2.KEQ0509273.4.ACTUAL_TEMPERATURE"/*Küche Klima.TEMPERATURE*/ : { "datenpunkt": "Klima.Temperatur.Küche", "liste": "raumKlimaTemperatur" }, "hm-rpc.2.LEQ0999580.1.TEMPERATURE"/*Theo:1.TEMPERATURE*/ : { "datenpunkt": "Klima.Temperatur.Theo", "liste": "raumKlimaTemperatur" }, "hm-rpc.2.MEQ1587955.4.ACTUAL_TEMPERATURE"/*Wohnzimmer Klima.TEMPERATURE*/ : { "datenpunkt": "Klima.Temperatur.Wohnzimmer", "liste": "raumKlimaTemperatur" }, "hm-rpc.2.OEQ0578299.1.TEMPERATURE"/*Schlafzimmer Klima:1.TEMPERATURE*/ : { "datenpunkt": "Klima.Temperatur.Schlafzimmer", "liste": "raumKlimaTemperatur" }, "hm-rpc.2.OEQ0578951.1.TEMPERATURE"/*Bad Klima.TEMPERATURE*/ : { "datenpunkt": "Klima.Temperatur.Bad", "liste": "raumKlimaTemperatur" }, "hm-rpc.2.OEQ0578951.1.HUMIDITY"/*Bad Klima.HUMIDITY*/ : { "datenpunkt": "Klima.Luftfeuchtigkeit.Bad", "liste": "raumKlimaLuftfeuchtigkeit" }, "hm-rpc.2.OEQ0578299.1.HUMIDITY"/*Schlafzimmer Klima:1.HUMIDITY*/ : { "datenpunkt": "Klima.Luftfeuchtigkeit.Schlafzimmer", "liste": "raumKlimaLuftfeuchtigkeit" }, "hm-rpc.2.LEQ0999580.1.HUMIDITY"/*Theo Klima.HUMIDITY*/ : { "datenpunkt": "Klima.Luftfeuchtigkeit.Theo", "liste": "raumKlimaLuftfeuchtigkeit" }, "hm-rpc.2.OEQ1016368.1.TEMPERATURE"/*Balkon gr. Klima:1.TEMPERATURE*/ : { "datenpunkt": "Klima.Temperatur.Balkon", "liste": "draussenKlimaTemperatur" }, "hm-rpc.2.OEQ1016368.1.HUMIDITY"/*Balkon gr. Klima:1.HUMIDITY*/ : { "datenpunkt": "Klima.Luftfeuchtigkeit.Balkon", "liste": "raumKlimaLuftfeuchtigkeit" }, "hm-rpc.2.OEQ0700027.1.HUMIDITY"/*Küche Klima.HUMIDITY*/ : { "datenpunkt": "Klima.Luftfeuchtigkeit.Küche", "liste": "raumKlimaLuftfeuchtigkeit" }, "hm-rpc.2.OEQ0699199.1.HUMIDITY"/*Nik Klima.HUMIDITY*/ : { "datenpunkt": "Klima.Luftfeuchtigkeit.Nik", "liste": "raumKlimaLuftfeuchtigkeit" }, "hm-rpc.2.OEQ0699871.1.HUMIDITY"/*Wohnzimmer Klima.HUMIDITY*/ : { "datenpunkt": "Klima.Luftfeuchtigkeit.Wohnzimmer", "liste": "raumKlimaLuftfeuchtigkeit" } }; //load2core // ----------------------------------------------------------------------------- // Schwellwertelisten // ----------------------------------------------------------------------------- var liste = { "raumKlimaTemperatur": { "obereGrenzeBezeichnung": "sehr heiss", "obereGrenzeZahl": 4, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 15, "bezeichnung": "kalt", "zahl": -2, "color": "white", "backgroundColor": "dodgerblue" }, {"wert": 18, "bezeichnung": "kühl", "zahl": -1, "color": "black", "backgroundColor": "deepskyblue" }, {"wert": 22, "bezeichnung": "normal", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 24, "bezeichnung": "warm", "zahl": 1, "color": "black", "backgroundColor": "limegreen" }, {"wert": 26, "bezeichnung": "warm", "zahl": 2, "color": "black", "backgroundColor": "orange" }, {"wert": 30, "bezeichnung": "sehr warm", "zahl": 3, "color": "black", "backgroundColor": "orangered" } ] }, "raumKlimaLuftfeuchtigkeit": { "obereGrenzeBezeichnung": "Schimmel", "obereGrenzeZahl": 3, "ogColor": "white", "ogBackgroundColor": "dodgerblue", "schwellwerte": [ {"wert": 37, "bezeichnung": "trocken", "zahl": -1, "color": "black", "backgroundColor": "orange" }, {"wert": 60, "bezeichnung": "normal", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 70, "bezeichnung": "feucht", "zahl": 1, "color": "black", "backgroundColor": "deepskyblue" } ] }, "draussenKlimaTemperatur": { "obereGrenzeBezeichnung": "sehr heiss", "obereGrenzeZahl": 3, "ogColor": "white", "ogBackgroundColor": "orangered", "schwellwerte": [ {"wert": 0, "bezeichnung": "eisig", "zahl": -2, "color": "white", "backgroundColor": "dodgerblue" }, {"wert": 4, "bezeichnung": "kalt", "zahl": -1, "color": "black", "backgroundColor": "deepskyblue" }, {"wert": 12, "bezeichnung": "kühl", "zahl": -1, "color": "black", "backgroundColor": "#94fff4" }, {"wert": 18, "bezeichnung": "lauwarm", "zahl": 0, "color": "black", "backgroundColor": "#9dfd9d" }, {"wert": 24, "bezeichnung": "kühl", "zahl": 0, "color": "black", "backgroundColor": "limegreen" }, {"wert": 30, "bezeichnung": "warm", "zahl": 1, "color": "black", "backgroundColor": "orange" }, {"wert": 35, "bezeichnung": "warm", "zahl": 2, "color": "black", "backgroundColor": "orange" } ] }, "wattFernseherNik": { "obereGrenzeBezeichnung": "Fernseher an", "obereGrenzeZahl": 3, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0, "bezeichnung": "Alles aus", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 20, "bezeichnung": "Standby OK", "zahl": 1, "color": "black", "backgroundColor": "limegreen" }, {"wert": 50, "bezeichnung": "Standby ohne Sub", "zahl": 1, "color": "black", "backgroundColor": "yellow" }, {"wert": 100, "bezeichnung": "TV aus, Sub noch an", "zahl": 2, "color": "black", "backgroundColor": "orange" } ] }, "wattUSV": { "obereGrenzeBezeichnung": "hoher Verbrauch", "obereGrenzeZahl": 3, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0, "bezeichnung": "Alles aus", "zahl": -1, "color": "white", "backgroundColor": "red" }, {"wert": 60, "bezeichnung": "optimierter Verbrauch", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 80, "bezeichnung": "niedriger Verbrauch", "zahl": 1, "color": "black", "backgroundColor": "limegreen" }, {"wert": 110, "bezeichnung": "normaler Verrauch", "zahl": 1, "color": "black", "backgroundColor": "yellow" }, {"wert": 120, "bezeichnung": "erhöhter Verbrauch", "zahl": 2, "color": "black", "backgroundColor": "orange" } ] }, "wattSonos": { "obereGrenzeBezeichnung": "hoher Verbrauch", "obereGrenzeZahl": 3, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0, "bezeichnung": "Sonos aus", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 9, "bezeichnung": "Standby", "zahl": 1, "color": "black", "backgroundColor": "yellow" }, {"wert": 20, "bezeichnung": "Sonos ist an", "zahl": 2, "color": "black", "backgroundColor": "orange" } ] }, "wattEsxi": { "obereGrenzeBezeichnung": "sehr hoch", "obereGrenzeZahl": 3, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 13, "bezeichnung": "normal", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 14, "bezeichnung": "erhöht", "zahl": 1, "color": "black", "backgroundColor": "yellow" }, {"wert": 15, "bezeichnung": "hoch", "zahl": 2, "color": "black", "backgroundColor": "orange" } ] }, "sonosVol": { "obereGrenzeBezeichnung": "sehr laut", "obereGrenzeZahl": 5, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0, "bezeichnung": "aus", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 9, "bezeichnung": "leise", "zahl": 1, "color": "black", "backgroundColor": "limegreen" }, {"wert": 40, "bezeichnung": "normal", "zahl": 2, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 50, "bezeichnung": "etwas lauter", "zahl": 3, "color": "black", "backgroundColor": "yellow" }, {"wert": 60, "bezeichnung": "laut", "zahl": 4, "color": "black", "backgroundColor": "orange" } ] }, "windstaerke": { "obereGrenzeBezeichnung": "Orkan", "obereGrenzeZahl": 12, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 1, "bezeichnung": "Windstill", "zahl": 0, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 5, "bezeichnung": "leiser Zug", "zahl": 1, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 11, "bezeichnung": "leichte Briese", "zahl": 2, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 19, "bezeichnung": "schwacher Wind", "zahl": 3, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 28, "bezeichnung": "mäßiger Wind", "zahl": 4, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 38, "bezeichnung": "frischer Wind", "zahl": 5, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 49, "bezeichnung": "starker Wind", "zahl": 6, "color": "black", "backgroundColor": "yellow" }, {"wert": 61, "bezeichnung": "steifer Wind", "zahl": 7, "color": "black", "backgroundColor": "gold" }, {"wert": 74, "bezeichnung": "stürmischer Wind", "zahl": 8, "color": "black", "backgroundColor": "orange" }, {"wert": 88, "bezeichnung": "Sturm", "zahl": 9, "color": "black", "backgroundColor": "darkorange" }, {"wert": 102, "bezeichnung": "schwerer Sturm", "zahl": 10, "color": "black", "backgroundColor": "red" }, {"wert": 88, "bezeichnung": "orkanartiger Sturm", "zahl": 11, "color": "white", "backgroundColor": "darkorange" } ] }, "hdFreiProzent": { "obereGrenzeBezeichnung": "voll", "obereGrenzeZahl": 4, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 85, "bezeichnung": "viel frei", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 90, "bezeichnung": "gut", "zahl": 1, "color": "black", "backgroundColor": "limegreen" }, {"wert": 95, "bezeichnung": "erhöht", "zahl": 2, "color": "black", "backgroundColor": "yellow" }, {"wert": 98, "bezeichnung": "fast voll", "zahl": 3, "color": "black", "backgroundColor": "orange" } ] }, "uv-index": { "obereGrenzeBezeichnung": "UV Index nicht bekannt", "obereGrenzeZahl": 0, "ogColor": "gray", "ogBackgroundColor": "rgb(204,204,204)", "schwellwerte": [ {"wert": 2, "bezeichnung": "keine bis gering, UV Schutz nicht erforderlich", "zahl": 0, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 5, "bezeichnung": "mittel, UV Schutz sehr empfehlenswert", "zahl": 1, "color": "black", "backgroundColor": "rgb(204,204,204)" }, {"wert": 7, "bezeichnung": "hoch, UV Schutz erforderlich", "zahl": 2, "color": "red", "backgroundColor": "yellow" }, {"wert": 10, "bezeichnung": "sehr hoch, UV Schutz unbedingt erforderlich", "zahl": 3, "color": "black", "backgroundColor": "orange" }, {"wert": 99, "bezeichnung": "extrem, UV Schutz ist ein muss", "zahl": 4, "color": "white", "backgroundColor": "red" } ] }, "updates": { "obereGrenzeBezeichnung": "viele Updates", "obereGrenzeZahl": 4, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0, "bezeichnung": "Alles aktuell", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 3, "bezeichnung": "Update verfügbar", "zahl": 1, "color": "black", "backgroundColor": "yellow" }, {"wert": 5, "bezeichnung": "updates verfügbar", "zahl": 2, "color": "black", "backgroundColor": "orange" }, {"wert": 10, "bezeichnung": "mehrere updates", "zahl": 3, "color": "black", "backgroundColor": "darkorange" } ] }, "load2core": { "obereGrenzeBezeichnung": "Überlast", "obereGrenzeZahl": 5, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0.5, "bezeichnung": "Last niedrig", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 1.0, "bezeichnung": "Last norrmal", "zahl": 1, "color": "black", "backgroundColor": "limegreen" }, {"wert": 1.2, "bezeichnung": "erhöhte Last", "zahl": 2, "color": "black", "backgroundColor": "yellow" }, {"wert": 1.6, "bezeichnung": "Hohe Last", "zahl": 3, "color": "black", "backgroundColor": "orange" }, {"wert": 2.0, "bezeichnung": "sehr hohe Last", "zahl": 4, "color": "black", "backgroundColor": "darkorange" } ] }, "load1core": { "obereGrenzeBezeichnung": "Überlast", "obereGrenzeZahl": 5, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0.4, "bezeichnung": "Last niedrig", "zahl": 0, "color": "black", "backgroundColor": "lime" }, {"wert": 0.6, "bezeichnung": "Last norrmal", "zahl": 1, "color": "black", "backgroundColor": "limegreen" }, {"wert": 0.7, "bezeichnung": "erhöhte Last", "zahl": 2, "color": "black", "backgroundColor": "yellow" }, {"wert": 0.8, "bezeichnung": "Hohe Last", "zahl": 3, "color": "black", "backgroundColor": "orange" }, {"wert": 1.0, "bezeichnung": "sehr hohe Last", "zahl": 4, "color": "black", "backgroundColor": "darkorange" } ] }, "alarme": { "obereGrenzeBezeichnung": "Alarme stehen an", "obereGrenzeZahl": 1, "ogColor": "white", "ogBackgroundColor": "red", "schwellwerte": [ {"wert": 0, "bezeichnung": "keine Alarme", "zahl": 0, "color": "black", "backgroundColor": "lime" } ] }, "gruenGelb": { "obereGrenzeBezeichnung": "erhöht", "obereGrenzeZahl": 1, "ogColor": "black", "ogBackgroundColor": "yellow", "schwellwerte": [ {"wert": 0, "bezeichnung": "normal", "zahl": 0, "color": "black", "backgroundColor": "lime" } ] } }; /* UV-Index Gefährdung (UV-Gefahrenindex Schutzmaßnahmen 0-2 keine bis gering nicht erforderlich 3-5 mittel sehr empfehlenswert 6-7 hoch erforderlich 8-10 sehr hoch unbedingt erforderlich ab 11 extrem sind ein Muss */ function dpAnlegen() { for (var geraet in schwellwerte) { createState(pfad + schwellwerte[geraet].datenpunkt + ".text","initalisiert"); createState(pfad + schwellwerte[geraet].datenpunkt + ".zahl",0); createState(pfad + schwellwerte[geraet].datenpunkt + ".color","black"); createState(pfad + schwellwerte[geraet].datenpunkt + ".backgroundColor","silver"); logs(pfad + schwellwerte[geraet].datenpunkt + " wurde angelegt","debug"); } } //var reg = new RegExp("^javascript\\.\\d+\\." + hueSzenenApapterPfad.replace('.', '\\.') + ".*\\.szene"); //on(reg , function (obj) { function setSchwellwerte(obj) { if(liste[schwellwerte[obj.id].liste]){ //log("Liste: " + schwellwerte[obj.id].liste); logs("Anzahl Schwellwerte: " + liste[schwellwerte[obj.id].liste].schwellwerte.length),"debug"; //var schwellwerteListe = liste var bezeichnung = liste[schwellwerte[obj.id].liste].obereGrenzeBezeichnung; var zahl = liste[schwellwerte[obj.id].liste].obereGrenzeZahl; var color = liste[schwellwerte[obj.id].liste].ogColor; var backgroundColor = liste[schwellwerte[obj.id].liste].ogBackgroundColor; var test = 9999; for (var i = 0; i < liste[schwellwerte[obj.id].liste].schwellwerte.length; i++) { if (obj.state.val <= liste[schwellwerte[obj.id].liste].schwellwerte[i].wert) { bezeichnung = liste[schwellwerte[obj.id].liste].schwellwerte[i].bezeichnung; zahl = liste[schwellwerte[obj.id].liste].schwellwerte[i].zahl; test = liste[schwellwerte[obj.id].liste].schwellwerte[i].wert; color = liste[schwellwerte[obj.id].liste].schwellwerte[i].color; backgroundColor = liste[schwellwerte[obj.id].liste].schwellwerte[i].backgroundColor; break; } } setState(pfad + schwellwerte[obj.id].datenpunkt + ".text",bezeichnung); setState(pfad + schwellwerte[obj.id].datenpunkt + ".zahl",zahl); setState(pfad + schwellwerte[obj.id].datenpunkt + ".color",color); setState(pfad + schwellwerte[obj.id].datenpunkt + ".backgroundColor",backgroundColor); //logs (schwellwerte[obj.id].datenpunkt + " - State: " + obj.state.val + " ist kleiner/gleich: " + test + " - Bezeichnung: " + bezeichnung + " - Zahl: "+ zahl, "debug"); } else { log("Schwellwertliste für " + obj.id + " nicht vorhanden","error"); } } // TODO: die Subscription nicht im Loop anlegen! function onAnlegen() { for (var geraet in schwellwerte) { logs("Schedule angelegt: " + geraet,"debug"); on({id: geraet}, function(obj) { //log(obj.id + ": " + obj.state.val); setSchwellwerte(obj); }); } } function getSchwellwerte() { for (var geraet in schwellwerte) { var val = getState(geraet).val; var obj = { "id":geraet, "state": { "val":val } }; setSchwellwerte(obj); } } // main - Hauptprogramm (wird beim Scriptstart ausgeführt) // ============================================================================= dpAnlegen(); // Datenpunkte anlegen onAnlegen(); // Subscribes anlegen function main() { // Hauptprogramm getSchwellwerte(); } setTimeout(main, 500);
Ich würde die Scripte nach und nach posten, wenn die Fehler weg sind das nächste. Sonst komme ich da durcheinander.
Danke nochmal an alle für die riesen Hilfe!