NEWS
[gelöst] Skript auf AXIOS/httpGet umbauen
-
Der httpGet Block hat aktuell keine Option um Zertifikatsfehler zu ignorieren oder?
-
@darkiop sagte in [gelöst] Skript auf AXIOS umbauen:
Der httpGet Block hat aktuell keine Option um Zertifikatsfehler zu ignorieren
Ja, richtig. Weiß auch noch nicht ob ich das anbieten soll. Immerhin ist die Validierung ein Sicherheitsfeature.
-
Stimmt - allerdings gerade im häuslichen Umfeld oft "normal".
Am Ende ist ist es ein abwägen von Risiko und Nutzen
-
@darkiop Ja, und was ist der Nutzen von einer https Verbindung im LAN?
-
Lässt sich manchmal ja nicht ohne zusätzlichen Aufwand (z.B. per ReverseProxy) vermeiden.
Unser SMA WR liefert das WebUi per https aus, eine Möglichkeit ein eigenes Zertifikat zu hinterlegen gibt es imho nicht.
Hier läuft alles über einen internen ReverseProxy, mir ist nur aufgefallen das die Option SSL Prüfungen abzuschalten, noch nicht implementiert ist.
-
Guten Morgen,
bin auch gerade an dem Thema dran:
mit request lasse ich mir Bilder der cam an telegram senden, wie folgt:
var ip = 159; var vUser = "Dieter"; var cam = "Test"; var request = require('request'); var fs = require('fs'); request.get({url: 'http://192.168.243.' + ip + ':88//cgi-bin/CGIProxy.fcgi?cmd=snapPicture2&usr=xx&pwd=xx', encoding: 'binary'}, function (err, response, body) { fs.writeFile('/opt/iobroker/iobroker-data/tmp/snap' + ip + '.jpg', body, 'binary', function(err) { if (err) { console.error(err); } else { log('Snapshot sent '+ ip); sendTo('telegram.0', {user: vUser, text: '/opt/iobroker/iobroker-data/tmp/snap' + ip + '.jpg', caption: cam}); } }); });
Wenn ich dies nun mit axios versuche, klappt dies nicht:
var ip = 159; var vUser = "Dieter"; var cam = "Test"; const axios = require('axios'); var fs = require('fs'); axios.get({url: 'http://192.168.243.' + ip + ':88//cgi-bin/CGIProxy.fcgi?cmd=snapPicture2&usr=xx&pwd=xx', encoding: 'binary'}, function (err, response, body) { fs.writeFile('/opt/iobroker/iobroker-data/tmp/snap' + ip + '.jpg', body, 'binary', function(err) { if (err) { console.error(err); } else { log('Snapshot sent '+ ip); sendTo('telegram.0', {user: vUser, text: '/opt/iobroker/iobroker-data/tmp/snap' + ip + '.jpg', caption: cam}); } }); });
Kann der axios diesen "binary" nicht ?
Oder liegt es an etwas anderes ?Vielleicht auch ne Info wie der Befehl mit httpget aussehen müsste.
Danke. -
@bahnuhr sagte in [gelöst] Skript auf AXIOS umbauen:
Kann der axios diesen "binary" nicht ?
Du kannst nicht einfach nur 1:1 die Funktion austauschen. Dokumentation gibts hier: https://github.com/axios/axios
Das Ganze heißt
responseEncoding: 'binary',
im Config-Objekt. Aber warum nutzt Du nichthttpGet
?https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#httpget
-
nicht getestet, nur im Forum programmiert
const fs = require('node:fs'); const ip = 159; const vUser = 'Dieter'; const cam = 'Test'; httpGet(`http://192.168.243.${ip}:88/cgi-bin/CGIProxy.fcgi?cmd=snapPicture2&usr=xx&pwd=xx`, { responseType: 'arraybuffer' }, (err, response) => { if (err) { console.error(err); } else { const filePath = `/opt/iobroker/iobroker-data/tmp/snap${ip}.jpg`; fs.writeFile(filePath, response.data, (err) => { if (err) { console.error(err); } else { log(`Snapshot sent: ${ip}`); sendTo('telegram.0', { user: vUser, text: filePath, caption: cam }); } }); } });
-
@haus-automatisierung sagte in [gelöst] Skript auf AXIOS umbauen:
Aber warum nutzt Du nicht httpGet ?
weil es mit der 7.8.0 noch nicht funktioniert.
und die 7.9.0 ist noch nicht stable.Muss ich wohl mal die beta installieren.
-
@bahnuhr sagte in [gelöst] Skript auf AXIOS umbauen:
Muss ich wohl mal die beta installieren.
In 8.3.0 habe ich heute noch eine weitere Funktion eingefügt. Damit wird das noch kürzer:
const ip = 159; const user = 'Dieter'; const caption = 'Test'; httpGet(`http://192.168.243.${ip}:88/cgi-bin/CGIProxy.fcgi?cmd=snapPicture2&usr=xx&pwd=xx`, { responseType: 'arraybuffer' }, (err, response) => { if (err) { console.error(err); } else { sendTo('telegram.0', { user, caption, text: createTempFile(`snap${ip}.jpg`, response.data), }); } });
-
@haus-automatisierung
so, habs ausprobiert (bin jetzt auf 8.3.0).Wenn ich folgenden kleinen code ausführe:
httpGet(`http://192.168.243.203/YamahaExtendedControl/v1/main/setPower?power=standby`, { responseType: 'text' }, (err, response) => { if (err) { console.error(err); } else { log (""); } });
kommt trotzdem im log:
script.js.Scripte.test6: request package is deprecated - please use httpGet (or a stable lib like axios) instead!
Warum kommt dies im log ?
(httpGet ist in JS auch rot unterstrichen)Benutze doch httpGet.
-
@bahnuhr sagte in [gelöst] Skript auf AXIOS umbauen:
Warum kommt dies im log ?
(httpGet ist in JS auch rot unterstrichen)Kann ich nicht reproduzieren, die Meldung kommt auch nur, wenn
require
aufgerufen wird. Und das passiert bei Dir im Script ja nicht.Du hast aber schon über npm installiert (und nicht über GitHub), oder?
-
@haus-automatisierung sagte in [gelöst] Skript auf AXIOS umbauen:
Und das passiert bei Dir im Script ja nicht.
korrekt, aber die Meldung kommt trotzdem.
@haus-automatisierung sagte in [gelöst] Skript auf AXIOS umbauen:
Du hast aber schon über npm installiert (und nicht über GitHub), oder?
ja, über npm
-
@haus-automatisierung sagte in [gelöst] Skript auf AXIOS umbauen:
die Meldung kommt auch nur, wenn require aufgerufen wird.
Das ist bei mir nicht so.
Habe mal iob komplett neu gestartet.Meldung kommt, obwohl im aufgerufenen Script kein request drin steht.
(wohl aber noch bei anderen).Kann es sein, dass die Meldung trotzdem kommt, weil irgendwo noch ein request drin steht (von den gefühlt 500 Scripten).
-
@bahnuhr sagte in [gelöst] Skript auf AXIOS umbauen:
Kann es sein, dass die Meldung trotzdem kommt, weil irgendwo noch ein request drin steht (von den gefühlt 500 Scripten).
Meines Erachtens nicht, da ich ebenfalls gerade am Umbauen von request auf httpGet bin.
Bei bereits auf httpGet umgestellten Scripten kommt keine request-deprecated-Meldung mehr, bei den Scripten die noch request verwenden, kommt sie noch. -
@joergeli
Danke für die Info.
Bei mir ist das nicht ! so.Folgendes Script zum Starten von Licht:
// Bewegung: Bad_EG -> Dimmer einschalten on('alias.0.HM.Bewegung.Bad_EG.MOTION', function (obj) { // Bewegung erkannt var Status_auto = getState('javascript.0.System.Automatik.Licht.Bad_EG').val; // Automatik Licht true var Licht_level = getState('alias.0.HM.Dimmer.Bad_EG.LEVEL').val; // Licht level aktuell var Hell = getState('alias.0.HM.Bewegung.Bad_EG.BRIGHTNESS').val; // Helligkeit var Modus_Dusche = getState('javascript.0.System.Modus.Modus_Dusche').val; // Modus Dusche aktiv? if(Status_auto === true && Licht_level === 0 && Modus_Dusche == false) { // Automatik Licht auf true und Licht ist aus und Modus überprüfen if (Hell < 35) { setState('alias.0.HM.Dimmer.Bad_EG.LEVEL',5); log("Helligkeit = " + Hell + "; Dimmer Bad_EG auf 5% eingeschaltet."); setTimeout(function() { pruef_aus(); }, 120000); // nach 2 min. Prüfung } } }); function pruef_aus() { var level = getState('alias.0.HM.Dimmer.Bad_EG.LEVEL').val; // Licht level aktuell var Modus_Dusche = getState('javascript.0.System.Modus.Modus_Dusche').val; // Modus Dusche aktiv? if (level > 0) { if (getState('alias.0.HM.Bewegung.Bad_EG.MOTION').val == false){ if (Modus_Dusche == false) { setState('alias.0.HM.Dimmer.Bad_EG.LEVEL', 0); log("Licht Bad EG ausgeschaltet."); } } else { log("Licht Bad EG nicht ausgeschaltet. Erneute Prüfung nach 2 min."); setTimeout(function() { pruef_aus (); }, 120000); // nach 2 min. erneute Prüfung } } } // ----------------------------------------------------------------------------------------------------------- // Bewegung: Bad_EG -> Spiegelschrank einschalten on('mqtt.2.Wemos_BadEG.PIR1', function (obj) { // Bewegung erkannt mit Wemos var Status_auto2 = getState('javascript.0.System.Automatik.Licht.Bad_EG').val; // Automatik Licht true var Licht_state = getState('mqtt.2.Wemos_BadEG.POWER').val; // Licht Spiegelschrank aktuell var Hell2 = getState('alias.0.HM.Bewegung.Bad_EG.BRIGHTNESS').val; // Helligkeit var Modus_Dusche2 = getState('javascript.0.System.Modus.Modus_Dusche').val; // Modus Dusche aktiv? if(obj.state.val == "ON" && Status_auto2 == true && Licht_state == "OFF" && Modus_Dusche2 == false) { // Automatik Licht auf true und Licht ist aus und Modus überprüfen if (Hell2 < 100) { httpGet("http://192.168.243.175/cm?cmnd=Power1%20On", { responseType: 'text' }, (err, response) => { if (err) { console.error(err); } else { log (""); } }); log("Helligkeit = " + Hell2 + "; Licht Bad EG - Spiegelschrank eingeschaltet."); setTimeout(function() { pruef_aus2(); }, 120000); // nach 2 min. Prüfung } } }); function pruef_aus2() { var state2 = getState('mqtt.2.Wemos_BadEG.POWER').val; // Licht Spiegelschrank aktuell var Modus_Dusche2 = getState('javascript.0.System.Modus.Modus_Dusche').val; // Modus Dusche aktiv? if (state2 == "ON") { if (getState('alias.0.HM.Bewegung.Bad_EG.MOTION').val === false){ if (Modus_Dusche2 === false) { httpGet("http://192.168.243.175/cm?cmnd=Power1%20Off", { responseType: 'text' }, (err, response) => { if (err) { console.error(err); } else { log (""); } }); log("Licht Bad EG - Spiegelschrank ausgeschaltet."); } } else { log("Licht Bad EG - Spiegelschrank nicht ausgeschaltet. Erneute Prüfung nach 2 min."); setTimeout(function() { pruef_aus2(); }, 120000); // nach 2 min. erneute Prüfung } } } // Bewegung: Bad_EG -> Spiegelschrank - Status ändert sich on('mqtt.2.Wemos_BadEG.POWER', function (obj) { // Status Power ändert sich if (obj.state.val == "ON") { if (getState("javascript.0.Geräte.Bad-EG.Spiegelschrank").val != true) { setState("javascript.0.Geräte.Bad-EG.Spiegelschrank", true); } } else { if (getState("javascript.0.Geräte.Bad-EG.Spiegelschrank").val != false) { setState("javascript.0.Geräte.Bad-EG.Spiegelschrank", false); }} }); on('javascript.0.Geräte.Bad-EG.Spiegelschrank', function (obj) { // Status Variable ändert sich if (obj.state.val == true) { if (getState("mqtt.2.Wemos_BadEG.POWER").val != "ON") { httpGet("http://192.168.243.175/cm?cmnd=Power1%20On", { responseType: 'text' }, (err, response) => { if (err) { console.error(err); } else { log (""); } }); } } else { if (getState("mqtt.2.Wemos_BadEG.POWER").val != "OFF") { httpGet("http://192.168.243.175/cm?cmnd=Power1%20Off", { responseType: 'text' }, (err, response) => { if (err) { console.error(err); } else { log (""); } }); }} });
Wenn ich dieses Script neu starte mit:
dann kommt sofort im log:
javascript.0 08:31:27.975 info Start JavaScript script.js.Scripte.Licht.Bad_EG (JavaScript/js) javascript.0 08:31:27.987 warn script.js.Scripte.Licht.Bad_EG: request package is deprecated - please use httpGet (or a stable lib like axios) instead! javascript.0 08:31:27.987 info script.js.Scripte.Licht.Bad_EG: registered 4 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
und dieses ist umgestellt auf httpGet.
Äußerst merkwürdig das ganze.
-
@bahnuhr sagte in [gelöst] Skript auf AXIOS umbauen:
arum kommt dies im log ?
(httpGet ist in JS auch rot unterstrichen)
Benutze doch httpGet.hatte das auch - das passierte als ich ein script kopierte und dieses dann auf httpget änderte- obwohl das orginal abgeschalten war, kam diese meldung
habe dann das alte nochmal gestartet und wieder beendet, dann war die meldung weg
-
@liv-in-sky sagte in [gelöst] Skript auf AXIOS umbauen:
habe dann das alte nochmal gestartet und wieder beendet, dann war die meldung weg
Dieser Versuch hab ich schon hinter mir.
iob hatte ich gestern komplett neu gestartet.Meldung kommt trotzdem !
-
@bahnuhr Hast Du Scripts in global liegen?
-
@haus-automatisierung sagte in [gelöst] Skript auf AXIOS umbauen:
@bahnuhr Hast Du Scripts in global liegen?
ja !
Das ist ne Idee, schau ich gleich mal nach.Nachtrag:
alle durchgeschaut; da ist nix mit request.
Nachtrag2:
doch eines gefunden, ändere das gleich mal ab.