NEWS
Javascript 6.1.0 - Neue Funktionen (Beta)
-
@marty56 Ok, da muss ggf Doku erweitert werden.
Die Alias Definition ist immer der ZWEITE parameter.
Also "nur ne ID" wird zu {alias: {id: aliasId}} im common.
Wenn Du an der Alias definition rumschrauben willst dann musst du das als zweiten Parameter angeben, also in deinem Fall
createAlias('alias.0.Test.test', {id:'hm-rpc.0.KEQ0172616.1.STATE', read:'!val'},true,
bzw im zweiten Fall:
createAlias('alias.0.Test.geraet_low_bat', {id: 'zigbee.0.00158d0002a1a494.battery',read: "val < 20 ? true : false" },true, { type: "mixed", unit: "%", })
PS: ich hab es innden javascript docs noch erwähnt, wobei da schon stand:
alias
: can be either an existing state id as string or a object with full alias definition including read/write ids and read/write functions.
Jetzt ist noch ein "Not: Alias definitions can not be set as part of the common parameter!" dazugekommen.
-
@apollon77 Danke für die Erklärungen.
Ich habe jetzt all meine Aliases auf das neue API umgestellt, alle alten Aliases gelöscht und dann wieder neu generiert.
Leider ist dieser allgemeine, sporadische Alias Error immer noch da. Schade.
2022-11-05 07:19:34.891 - error: admin.0 (516) Alias subscription error. Please check your alias definitions: sourceId=zigbee.0.00158d0003e57190.transition_time, sourceObj={"type":"state","common":{"name":"Transition time","type":"number","unit":"sec","read":false,"write":true,"role":"state"},"native":{},"from":"system.adapter.zigbee.0","user":"system.user.admin","ts":1653374903543,"_id":"zigbee.0.00158d0003e57190.transition_time","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}} 2022-11-05 07:19:34.891 - error: admin.0 (516) Alias subscription error. Please check your alias definitions: sourceId=zigbee.0.00158d0003e57190.available, sourceObj={"type":"state","common":{"name":"Available","type":"boolean","read":true,"write":false,"role":"state"},"native":{},"from":"system.adapter.zigbee.0","user":"system.user.admin","ts":1653374903521,"_id":"zigbee.0.00158d0003e57190.available","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
-
@marty56 Am Ende wegen dem Fehler wieder die Frage: Kannst du klar reprduzieren wann und warum es kommt?
-
@apollon77
Ich habe nochmal ein bisschen geforscht.Ich habe 380 Aliases. Davon sind 308 direkt unter alias.0.
Die anderen 80 sind in Unterverzeichnissen.
Alle Aliases, die in Unterverzeichnissen gespeichert sind, kommen in den Error Logs nicht vor, die anderen 308 werden alle als Error geloggt.Vielleicht hängt es mit der Menge der Aliases zusammen, die unter einem Verzeichnis gespeichert werden können.
-
@marty56 Menge sollte nicht ... Auch die Lokation sollte an sich egal sein ... und mit nem adapterstart von dem Adapter der meckert ists wider weg für ne weile, korrekt?
-
Es kommt bei mir unregelmäßig, so ca. 1 -2 pro Tag.
Ich kann es nicht mit einem Adapterstart in Zusammenhang bringen. -
@apollon77, ich hänge mich hier mal mit dran, da das 'Problem' (hat bisher keinen Einfluss auf irgendwelche Funktionalitäten), bei mir auch auftritt:
Fehlermeldung, z. B.:Alias subscription error. Please check your alias definitions: sourceId=deconz.0.Lights.58.on, sourceObj={"type":"state","common":{"name":"BlitzPlug05 AL on","type":"boolean","role":"switch","read":true,"write":true},"native":{},"from":"system.adapter.deconz.0","user":"system.user.admin","ts":1653067264363,"_id":"deconz.0.Lights.58.on","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}}
oder auch:
Alias subscription error. Please check your alias definitions: sourceId=deconz.0.Sensors.87.consumption, sourceObj={"type":"state","common":{"name":"Consumption 87 consumption","type":"number","role":"value.power.consumption","read":true,"write":false,"unit":"Wh","def":0},"native":{},"from":"system.adapter.deconz.0","user":"system.user.admin","ts":1653210287074,"_id":"deconz.0.Sensors.87.consumption","acl":{"object":1636,"state":1636,"owner":"system.user.admin","ownerGroup":"system.group.administrator"}}
Ich habe zwar (noch) nicht so viele Aliase, aber auch eine eigene Struktur in den Aliasen angelegt, da ich da sonst nichts wiederfinde
Also neben:
alias.0.[Ein Alias]auch so etwas wie:
alias.Licht.[[verschiedene Aliase]
alias.Remote.[versch. Aliase)
alias.Schalt.[versch. Aliase]
usw.Ich stelle die Fehlermeldungen meist fest, wenn ich irgendwas an meinen Blocklys editiert habe, oder aber auch, wie gerade eben, wenn ich ein paar überflüssig gewordene Variablen gelöscht habe (Umzug von javascript.0.[ordner].[irgendwas] nach '0_userdata.0.[ordner].[irgendwas]).
Allerdings hatten diese Änderungen rein gar nichts mit den im Log angezeigten Alias-Fehlermeldungen zu tun.Ohne jegliches Zutun scheinen die Meldungen nicht zu kommen, zumindest habe ich das bisher bei sporadischen Blicken aufs Log nicht feststellen können.
Ein Gedanke: Müsste ich meine Aliasstruktur evtl. eine Ebene tiefer hängen? - also immer zusätzlich noch ein '.0.' einschieben?
-
@pedder007 sagte: alias.Licht.[[verschiedene Aliase]
Alle Alias-Objekte müssen unter "alias.0" erstellt werden. Im Tab "Objekte" geht es auch nicht anders. Wie hast Du sie erstellt?
-
@paul53 danke, das ging schnell
Wie meinst Du das genau?
Muss ich die '.0.' immer dazwischen haben, oder müssen ALLE Aliase immer direkt unter '.0.' definiert sein?
Weil wenn letzteres, also ohne weitere Zwischenebene (Kategorisierung), wird das aber schnell extrem unübersichtlich. -
@paul53 said in Javascript 6.1.0 - Neue Funktionen (Beta):
Wie hast Du sie erstellt?
über die Umbenennungs-Funktion, bzw. dann später einfach kopiert und auf andere Objekte umdefiniert
-
@pedder007 sagte: Muss ich die '.0.' immer dazwischen haben
Ja.
@pedder007 sagte in Javascript 6.1.0 - Neue Funktionen (Beta):
müssen ALLE Aliase immer direkt unter '.0.' definiert sein?
Nein, möglichst keine: Immer eine Objektstruktur verwenden!
-
-
@apollon77 Danke schön, bin jetzt auf v6.1.3 läuft alles top bis jetzt.
Grüße
Fabio -
Ich habe mir einen Alias für die Helligkeitssteuerung der Tablets gemacht. Da über den FullyAdapter Read und Write verschiedene DPs sind, verwende ich dafür
createAlias('0_Test.Maverick.Helligkeit', {id: {read: 'fullybrowser.0.10_1_2_103.Info.screenBrightness', write: 'fullybrowser.0.10_1_2_103.Commands.screenBrightness'}},ForceCreate, { type: "number", unit: "%" });
(ForceCreate ist eine vorher gesetzte Variable, momentan auf true)
Das klappt bis dahin auch gut und die Helligkeit lässt sich steuern und anzeigen. Allerdings ist die Helligkeit hier 0-255, ich hätte aber gerne 0-100%. Also muss ich nach meinem Verständnis nochread: "val/2.55", write: "val*2.55"
einfügen. Aber an welcher Stelle genau? Meine Versuche bis jetzt mit verschiedenen Positionen waren erfolglos.
-
@labersack sagte: Aber an welcher Stelle genau?
Unter common.alias:
"alias": { "id": { "read": "fullybrowser.0.10_1_2_103.Info.screenBrightness", "write": "fullybrowser.0.10_1_2_103.Commands.screenBrightness" }, "read": "val/2.55", "write": "val*2.55" }
-
@paul53
Ja, als Ergebnis.
Nur wo im createAlias-Befehl? -
@labersack sagte: wo im createAlias-Befehl?
createAlias('0_Test.Maverick.Helligkeit', { id: { read: 'fullybrowser.0.10_1_2_103.Info.screenBrightness', write: 'fullybrowser.0.10_1_2_103.Commands.screenBrightness' }, read: "val/2.55", write: "val*2.55" }, ForceCreate, { type: "number", unit: "%" });
-
@paul53
Das hatte ich auch schon probiert, damit klappt es teilweise.
Es wird die Struktur wie aus deinem vorletzten Post erzeugt.
Setzten des Alias auf 50 setzt ...Commands.brightness auf 127,5, bis dahin wie gewünscht.
Im ...Info.screenBrightness steht aber dann 10 und vermutlich dadurch im alias 3,921...%
Das Tablett selber schaltet übrigens auf ziemlich Dunkel, also das ist eher 10 als 127,5 (von 255). -
@labersack muss da vllt noch ein Math.floor() dazu? Weil ich eher annehme das kommawerte nicht unterstützt sind. Sind es vllt genau die kommawerte die das Problem sind?
-
@apollon77
Tatsächlich hat der Adapter mit Probleme mit Dezimalwerten: wenn ich in den direkten DP vom Adapter 127.5 schreibe, setzt er die Helligkeit auch auf falsche Werte.
Ich habe den Alias deswegen auf math.Round angepasst, trotzdem kann ich über den Alias nicht die Helligkeit korrekt steuern, sobald ich auf Prozent umrechne. Wenn ich als Wert 0-255 belasse, klappt es einwandfrei.
Zusätzliche Schwierigkeit könnte auch sein, dass die Rückmeldung in INFO bis zu 10 Sekunden nach Setzten des COMMANDS kommt, also nicht wegen Alias, sondern bei dem Adapter an sich. Man kann die Zeit im Adapter zwar auch kürzer einstellen, aber das habe ich aus Erfahrungen der Vergangenheit auf 10s stehen.Wenn ich den DP wie folgt erstellen lasse:
{ "common": { "type": "number", "unit": "%", "alias": { "id": { "read": "fullybrowser.0.10_1_2_103.Info.screenBrightness", "write": "fullybrowser.0.10_1_2_103.Commands.screenBrightness" }, "read": "math.Round(val/2.55)", "write": "math.Round(val*2.55)" }, "name": "screenBrightness", "role": "value" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1671117642794, "_id": "alias.0.0_Test.Maverick.Helligkeit", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" } }
Dann kann ich nichts steuern. Gesetzte Werte im Alias werden nicht nach COMMANDS geschrieben. Auch direkt in den DP COMMANDS geschriebene Werte kommen nicht im Alias an, aber steuern die Helligkieit und kommen nach ein paar Sekunden in INFO.
Ohne math.Round oder math.Floor klappt es, aber eben mit falschen Werten. Habe ich noch einen Syntax-Fehler beim Runden? Sieht für mich eigentlich richtig aus....