NEWS
[gelöst] JSON POST für Liquid-Check-Messung
-
@qwertz
Genügt es nicht, jede Stunde abzufragen? Etwa soconst url = 'http://10.11.12.46/infos.json'; const path = '0_userdata.0.Zisterne.Messung.'; const idPegel = path + 'Pegel'; const idVol = path + 'Volumen'; schedule('7 * * * *', function() { request(url, function(error, response, body) { if(error) log(error, 'warn'); else if(body) { let werte = JSON.parse(body).payload.measure; setState(idPegel, werte.level, true); setState(idVol, werte.content, true); } }); });
-
Hi !
Danke für den Tip.
Es geht aber nicht ums Auslesen der infos.json sondern um das Triggern einer neuen physischen Messung über die Command URL.
Hintergrund: Das Gerät startet dann eine kleine Pumpe und drückt Luft in den Messschlauch.
Das Auslesen der bestehenden Werte aus der letzten physischen Messung klappt schon mit einem anderen Skript ( s.anderer alter Beitrag https://forum.iobroker.net/post/579295)
Besten Gruß,
Sebastian -
@qwertz sagte: Was ist gemeint mit "im Body senden"
Ersetze mal form: durch body:
- body - entity body for PATCH, POST and PUT requests. Must be a Buffer, String or ReadStream. If json is true, then body must be a JSON-serializable object.
-
@paul53
Habe es so laufen lassen: Dabei crasht der komplette Adapter...'*/60 * * * *' var request = require('request'); request.post({ url: 'http://10.11.12.46/command', body: {"header":{"namespace":"Device.Control","name":"StartMeasure","messageId":"1","payloadVersion":"1"},"payload":null} }, function(error, response, body) { if (error) log(error, 'error'); });
2021-04-21 19:21:31.765 - error: javascript.0 (29353) script.js.Zisterne_auslesen_Trigger: {} 2021-04-21 19:21:31.766 - info: javascript.0 (29353) script.js.Zisterne_auslesen_Trigger: registered 0 subscriptions and 0 schedules 2021-04-21 19:21:31.840 - error: javascript.0 (29353) Request error: Error: Argument error, options.body. 2021-04-21 19:21:31.851 - error: javascript.0 (29353) An error happened which is most likely from one of your scripts, but the originating script could not be detected. 2021-04-21 19:21:31.852 - error: javascript.0 (29353) Error: The first argument must be of type string or an instance of Buffer. Received an instance of Object 2021-04-21 19:21:31.853 - error: javascript.0 (29353) TypeError [ERR_INVALID_ARG_TYPE]: The first argument must be of type string or an instance of Buffer. Received an instance of Object at write_ (_http_outgoing.js:653:11) at ClientRequest.write (_http_outgoing.js:621:15) at Request.write (/opt/iobroker/node_modules/request/request.js:1494:27) at end (/opt/iobroker/node_modules/request/request.js:549:18) at Immediate._onImmediate (/opt/iobroker/node_modules/request/request.js:578:7) at processImmediate (internal/timers.js:456:21) 2021-04-21 19:21:32.851 - info: javascript.0 (29353) Stop script script.js.Doorbird_Klingel_an_CCU1_aus 2021-04-21 19:21:32.924 - error: host.iobroker Caught by controller[0]: TypeError [ERR_INVALID_ARG_TYPE]: The first argument must be of type string or an instance of Buffer. Received an instance of Object 2021-04-21 19:21:32.926 - error: host.iobroker Caught by controller[0]: at write_ (_http_outgoing.js:653:11) 2021-04-21 19:21:32.926 - error: host.iobroker Caught by controller[0]: at ClientRequest.write (_http_outgoing.js:621:15) 2021-04-21 19:21:32.927 - error: host.iobroker Caught by controller[0]: at Request.write (/opt/iobroker/node_modules/request/request.js:1494:27) 2021-04-21 19:21:32.927 - error: host.iobroker Caught by controller[0]: at end (/opt/iobroker/node_modules/request/request.js:549:18) 2021-04-21 19:21:32.927 - error: host.iobroker Caught by controller[0]: at Immediate._onImmediate (/opt/iobroker/node_modules/request/request.js:578:7) 2021-04-21 19:21:32.927 - error: host.iobroker Caught by controller[0]: at processImmediate (internal/timers.js:456:21) 2021-04-21 19:21:32.928 - error: host.iobroker instance system.adapter.javascript.0 terminated with code 1 (JS_CONTROLLER_STOPPED) 2021-04-21 19:21:32.928 - info: host.iobroker Restart adapter system.adapter.javascript.0 because enabled
-
Zur Doku für andere Liquid-Check Nutzer: Habe es jetzt geschafft die Messung am zu starten mit folgendem Skript:
on({id: '0_userdata.0.Zisterne_Messung_Trigger', val: true}, script1); function script1() { console.log('Zisterne_Messung_gestartet_durch_Skript'); var request = require('request'); var myObj = {"header":{"namespace":"Device.Control","name":"StartMeasure","messageId":"1","payloadVersion":"1"},"payload":null} var options = { url: 'http://10.11.12.46/command', method: 'POST', body:JSON.stringify(myObj) }; request(options,function (error, response, body){ }); }
Mit einem Bool-Schalter-Objekt wird ich das Skript getriggert.
-
@qwertz Hallo zusammen,
Ich bin auf der Suche nach einem verlässlichen Füllstandssensor, der nach Möglichkeit an 230V anliegt (und daher außerhalb meines Flachwassertanks zu montierten ist) und zuverlässig Änderungen des Füllstandes (am liebsten in Prozent) an den iobroker übermittelt.
Ist das mit dem Liquid Check so möglich?
Welche Lösungen verwendet ihr?
Um die Gartenbewässerung wirklich smart zu gestalten benötige ich hier einen zuverlässigen Sensor auf den man sich verlassen kann...
LG -
@matthias-i
Hi
Bei LiquidCheck geht nur ein dünner Plastikschlauch in den Tank. Pneumatische Messung. Kein Strom !
Der Schlauch geht dann in das Messgerät, welches irgendwo in der Nähe von einer Steckdose platziert werden kann. Das Messgerät wird über USB 5V DC versorgt. WLAN-Webserver mit API.
Läuft seit ca. einem Jahr zuverlässig. -
Hallo erstmal
Ich nutze das LiquidCheck Script von qwertz und es klappt auch super! Herzlichen Dank dafür!!!!
Jetz kommt aber inzwischen die Warnung von der JS Engine:
"request package is deprecated - please use httpGet (or a stable lib like axios) instead!"Daher hier in Ergänzung der entsprechende httpPost Aufruf :
on({id: '0_userdata.0.Zisterne_Messung_Trigger', val: true}, script1); function script1() { console.log('Zisterne_Messung_gestartet_durch_Skript'); httpPost('http://10.11.12.46/command', {"header":{ "namespace" : "Device.Control" , "name" : "StartMeasure" , "messageId" : "1" , "payloadVersion" : "1" } , "payload" : null }, (error, response) => { if (error) console.error('Unerwarteter Fehler - ' + error); }); }
LG
-
@odysseus said in [gelöst] JSON POST für Liquid-Check-Messung:
Hallo erstmal
Ich nutze das LiquidCheck Script von qwertz und es klappt auch super! Herzlichen Dank dafür!!!!
Jetzt kommt aber inzwischen die Warnung von der JS Engine:
"request package is deprecated - please use httpGet (or a stable lib like axios) instead!"Daher hier in Ergänzung der entsprechende httpPost Aufruf :
on({id: '0_userdata.0.Zisterne_Messung_Trigger', val: true}, script1); function script1() { console.log('Zisterne_Messung_gestartet_durch_Skript'); httpPost('http://10.11.12.46/command', {"header":{ "namespace" : "Device.Control" , "name" : "StartMeasure" , "messageId" : "1" , "payloadVersion" : "1" } , "payload" : null }, (error, response) => { if (error) console.error('Unerwarteter Fehler - ' + error); }); }
LG
-
@odysseus Danke dir ! Hatte die Meldung im Log auch schon gesehen, aber bisher verdrängt.