NEWS
MQTT Adapter sendMessage2Client Escape "
-
Hallo!
Ich verwende einen Victron Wechselrichter und quatsche mit dem per MQTT Adapter im Client Modus.
Das Problem ist um den Modus zu wechseln, braucht der Wechselrichter einen value im JSON Format:
z.b: {"value":9}Wie kann ich das richtig escapen?
Ich kann das schicken versuchen wie ich will, die Anführungszeichen werden immer escaped. Wenn ich als ganzes Objekt schicken versuche dann kommt am Broker undefined an.
Versuche:
sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/BatteryLife/State', message:'{"value" : 9}'}); sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/BatteryLife/State', message:"{'value' : 9}"}); sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/BatteryLife/State', message:{"value" : 9}}); sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/BatteryLife/State', message:"{\"value\" : 9}"});
Klappt leider alles nicht. Das Ergebnis am Broker ist immer:
Sollte aber so sein damit es klappt:
Vielen Dank schon mal für jede Hilfe!
-
@maxx8888 Du escapsed das nicht, sondern du sendest das Objekt so wie es ist.
Du lässt das Object wie es ist und stringifizierst das Objekt.
message:JSON.stringify({value : 9})
Ein JSON String ist ein stringifiziertes Objekt, um als String Objekte über eine Vielzahl von Protokollen zu senden. Ein JSON String als String zu definieren, wird immer scheitern.
-
Oh mann, Knopf im Kopf... Vielen Dank! So wird es funktionieren!
-
Tja,
Ist zwar lange her und ich habe immer wieder damit rumgespielt, aber es funktioniert leider nach wie vor nicht.
sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/AcPowerSetPoint', message:JSON.stringify({value: -0})});
Endet wieder in einen escapen String am MQTT Explorer:
-
@maxx8888 sagte in MQTT Adapter sendMessage2Client Escape ":
sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/AcPowerSetPoint', message:JSON.stringify({value: -0})});
Na bis auf das Minuszeichen vor der 0 sollte es funktionieren. Wenn Du allerdings mqtt.0 als Broker betreibst - hat das Ding wieder ein Problem - deshalb nutze ich als Broker mosquitto.
Das funktioniert aber:
sendTo('mqtt.3', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/AcPowerSetPoint', message:JSON.stringify({value:0})});
Wenn ich den gleichen Befehl an einen Broker schicke - dann geht das auch nicht.
Aber wie gesagt - den Adapter würde ich sowieso nicht als Broker betreiben - da hat mit der zuviele Bugs.
-
@maxx8888
Ich sende meine Dinge so wie du... nur das : ist immer'{"key": 1}'
Nutze aber wie mickym mosquitto
-
Wie macht ihr das genau?
Klingt interessant. Ich habe wohl auch schon einen Mosquitto Docker laufen der die Daten vom Venus OS abruft. Aber parallel mqtt.0 direkt zum Venus OS.
Verstehe ich das richtig das ihr im IOBroker schon auch einen mqtt Adapter am laufen habt, aber mit Mosquitto verbunden anstatt mit Venus OS? -
@maxx8888 Ja. Ich glaube VenusOS agiert auch als Broker. In dem Fall hättest Du 2 Broker in Deinem System und bräuchtest deshalb 2 Instanzen von dem mqtt- Adapter.
-
MQTT.0 Adapter ist als Client/Subscriber konfiguriert im IOBroker.
Also bei mir im Moment:
VenusOS(Broker) -> MQTT.0 Adapter(Client)Parallel damit ich auch im Mosquitto alle Daten habe:
VenusOS(Broker) -> Mosquitto(Broker)Haben wir dann nicht doch die gleichen Settings?
-
@maxx8888 Nein das geht nicht, das sind 2 verschiedene Broker. Aber das brauchst Du dann ja nicht, weil wenn Du den mqtt-Adapter als Client konfiguriert hast, dann sollte er auch das Objekt richtig schreiben. Also in meinem 1. Beispiel funktionierte das ja. Ob ich jetzt mosquitto oder den VenusOS als Broker nutze sollte dann eigentlich aus iobroker Sicht keinen Unterschied machen
-
Es tut mir Leid ich stehe jetzt etwas auf der Leitung. Was funktioniert da nicht?
Könntest Du mir bitte nochmal genau erklären wie Du aus ioBroker eine MQTT Message an Victron schickst.Ich habe nur das Problem das bei mir der mqtt.0 Adapter bei einem "sendMessage2Client" die message scheinbar falsch escaped. Alle 3 Teilnehmer funktionieren an sich normal, ich sehe alle Daten überall.
Ich kann auch andere Daten die keine Kombination aus {"xxx":"xxx"} enthalten ganz normal an Victron schicken:
Um Venus MQTT aktiv zu halten schicke ich zb:
//Refresh all: sendTo('mqtt.0', 'sendMessage2Client', {topic:"R/dca6322aed74/keepalive", message:"#"});
Hier gibt es das escaping Problem nicht.
Dieses tritt nur auf wenn die Message die man schickt und diese eine Kombination aus {"xxx":"xxx"}enthält:
sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/AcPowerSetPoint', message:JSON.stringify({value: 0})});
Hier meine Adapter Settings:
-
@maxx8888 Ich bin ehrlich gesagt überfragt, warum das bei Dir nicht tut. Bei mir tut es wenn der mqtt Adapter ein Client ist. Ich habe keine Ahnung warum das bei Dir nicht tut.
Ich habe bei den Adaptersettings nichts angehakt - aber glaube nicht, dass das einen Unterschied macht. Ich habe leider keine Ahnung. Sorry.
Genau der gleiche String nur mqtt.3
-
Perfekt!
Das hat geholfen. Problem ist das setting "Zustandsobject als MQTT Nachricht senden".
Ich habe das abgehakt, und siehe da, das Problem ist weg.Dafür hat das keepalive Kommando nicht mehr geklappt und Venus OS hört auf Daten zu schicken.
Hier scheint aber die ältere Variante auch zu funktionieren.Vielen Dank für Deinen Screenshot vom Adapter. Der war Gold wert
//Keepalive: sendTo('mqtt.0', 'sendMessage2Client', {topic:"R/dca6322aed74/system/0/Serial", message: ''}); //ACPowerSetpoint sendTo('mqtt.0', 'sendMessage2Client', {topic:'W/dca6322aed74/settings/0/Settings/CGwacs/AcPowerSetPoint', message:'{"value" : ' + 0 +'}'});
-
@maxx8888 Du kannst ja eine zusätzliche Instanz installieren mit anderen Einstellungen. Es können sich ja beliebig viele Clients an einen mqtt-Broker anmelden.