NEWS
Zigbee2mqtt installation
-
Irgendwas ist da kaputt bei mir.
Name taucht gar nicht in der Flowvariable auf:
Jetzt werd ich ganz Banane..
vor der function Node wird msg.name doch ganz offensichtlich - auch laut debug node - nach msg.payload.name gesetzt.
Bei dem was die function node aber bekommt (bzw. was hinten aus der Function node raus kommt) ist das aber wieder in msg.name statt msg.payload.name.
Logischerweiße kann es dann nicht in der Flowvariable sein, weil msg.payload.name ja für die Function node nicht existiert.
Fehler in der Matrix??? -
@schmetterfliege Überprüfe Deine Kabel mal - vielleicht sind die zu eng zusammen und Du bypassed . Sprich die CHange Node ist gar nicht mit der function Node verbunden. - Wahrscheinlich ist die function Node direkt mit dem Vorgänger verbunden und Du hast die nicht richtig eingefügt.
Mach mal alle Kabel weg und verkabel noch mal neu.
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Überprüfe Deine Kabel mal - vielleicht sind die zu eng zusammen und Du bypassed . Sprich die CHange Node ist gar nicht mit der function Node verbunden. - Wahrscheinlich ist die function Node direkt mit dem Vorgänger verbunden und Du hast die nicht richtig eingeüftg.
omfg.... ich spring aus'm Fenster....
-
@schmetterfliege sagte in Zigbee2mqtt installation:
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Überprüfe Deine Kabel mal - vielleicht sind die zu eng zusammen und Du bypassed . Sprich die CHange Node ist gar nicht mit der function Node verbunden. - Wahrscheinlich ist die function Node direkt mit dem Vorgänger verbunden und Du hast die nicht richtig eingeüftg.
omfg.... ich spring aus'm Fenster....
Genau das habe ich vermutet.
-
so hart wie ich grad gern den Kopf schütteln würde, würde wahrscheinlich mein Genick brechen...
Danke dir - und sorry -
@schmetterfliege sagte in Zigbee2mqtt installation:
so hart wie ich grad gern den Kopf schütteln würde, würde wahrscheinlich mein Genick brechen...
Danke dir - und sorryNa zum Glück - muss ich nicht den Glauben an die IT verlieren. Ich hatte mal einen Kollegen der meinte bei solchen Phänomen immer: "Es gibt Dinge zwischen Himmel und Erde ... "
und ich habe mich immer geweigert so was zu akzeptieren. Das würde jedes IT-System in den Bereich des Esoterischen verschieben. -
@mickym
Na das traurige ist ja dass ich in der IT arbeite (wenn auch relativ speziell) und den Glauben an mich selbst verlieren muss -
Bei dem Teil wo ich das LastUpdate setze müsste ich auch nochmal was ändern.
Zwar splitte ich alles auf bevor ich das LastUpdate setze, aber der macht das scheinbar anhand der Topic, die bei allen aber gleich ist, und zwar die Topic von dem Sensor, der den Flow gerade getriggert hat.
Ich meine, diese Change Node hätten wir zusammen gemacht (also du hast sie mir vorbereitet und ich habe sie kopiert )
Die Timestamps im Flow sind definitiv unterschiedlich:
In der Change Node, das "payload.id" das da drin steht - was genau ist payload.id?
Aktuell sieht es mir danach aus dass payload.id == msg.topic ist, und er daher für alle Sensoren immer nur den einen Wert nimmt (zb Flur_1 wenn der Sensor gerade geupdated hat).
Wie muss ich das denn umbiegen dass er bei Büro auch Büro nutzt, Wohnzimmer dann Wohnzimmer usw? -
@mickym
Nachtrag:
Hab im Flow die Timestamps schon mal angepasst:
Weil in manchen Räumen mehrere Sensoren sind mit unterschiedlichen Namen.
D.h. ich möchte das LastUpdate auch nicht über den Raum setzen, sondern den jeweiligen Sensor.
Der dann im Flow eben wie im Screenshot abgespeichert ist. -
@schmetterfliege In der payload.id muss genau "Wohnzimmer", "Büro" etc. stehen. Mach halt eine debug Node hinter die split Node.
-
@schmetterfliege Das ist Käse. Was soll denn moments mit einem Objekt anfangen. Dann ändere die das statt Büro halt andere Variablen abgespeichert werden.
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege In der payload.id muss genau "Wohnzimmer", "Büro" etc. stehen. Mach halt eine debug Node hinter die split Node.
Na das ist ja das Problem:
Es gibt kein payload.id.
Und msg.topic ist wie gesagt bei allen gleich, je nachdem welcher Sensor grade das Update liefert:
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Das ist Käse. Was soll denn moments mit einem Objekt anfangen. Dann ändere die das statt Büro halt andere Variablen abgespeichert werden.
Okay, das kann ich natürlich machen.
Muss dann halt schauen dass ich niemals Sensoren habe die den gleichen Namen haben^^
Das hätte ich halt umgangen indem ich vorher auf Räume auftrenne. -
@schmetterfliege Du kannst doch die Variablen so abspeichern - als Kombi zwischen Sensorname und Raum.
-
@mickym said in Zigbee2mqtt installation:
@schmetterfliege Du kannst doch die Variablen so abspeichern - als Kombi zwischen Sensorname und Raum.
Done.
-
Bleibt die Frage, was payload.id sein soll.
Übergeben wird jedenfalls kein payload.id an die Change Node.
Nur ein parts.idWo finde ich denn das, was payload.id sein soll? In den Flowvariablen steht das auch nicht.
Oder sind das hier die "IDs"?
-
@schmetterfliege Schau halt mal mit einer Debug Node nach der split Node?
-
@mickym Der Debug aus dem Screenshot ist nach der Split Node
Was ich halt machen könnte, wäre msg.topic auf die entsprechenden Werte zu setzen wie sie in timestamps im Flow stehen.
Also zb. Büro/Besta.Und dann in der Change node payload.id durch msg.topic ersetzen.
Würde das funktionieren? -
jetzt is diese dämliche Tabelle wieder leer und bleibt leer obwohl ich die Änderungen rückgängig gemacht habe und die Tabelle definitiv die Objekte bekommt -.-
-
@schmetterfliege Na wenn es jetzt nicht funktioniert - dann klar. Ich frag mich nur, warum das alles mal funktioniert hat und wir hier nur wieder alles neu machen müssen. Die Dinge hängen halt alle zusammen und ich habe keine Ahnung was geändert wurde. Meines Erachtens haben wir sicher irgendwo die id gesetzt - aber ich habe jetzt sorry keine Ahnung mehr. Ich kann auch nicht alle Flows hier immer bei mir abgespeichert halten, die ich mal zusammen entwickelt habe.
Natürlich musst dann halt wieder neu machen und halt verstehen, was in der ChangeNode gemacht wird.
Aus dem Objekt wird mithilfe von $lookup aus dem Objekt timestamps der Wert des Keys ermittelt. Den Key haben wir mit payload.id mitgegeben gehabt. Das topic entspricht doch nicht den Namen der Objekte in timestamps. Setze halt so wie Du es jetzt abgespeichert hast, die payload.id entsprechend, wie Du sie im Kontext abspeicherst. Die muss ja Bestandteil des Objektes sein, damit die nachdem split verfügbar ist.
Bei solchen Dingen würde ich mir halt den Flow von damals importieren (kann den ja insgesamt deaktivieren) und dort dann suchen, wo die id im Objekt gesetzt wurde.