Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [gelöst] Skript auf AXIOS/httpGet umbauen

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Skript auf AXIOS/httpGet umbauen

    This topic has been deleted. Only users with topic management privileges can see it.
    • Codierknecht
      Codierknecht Developer Most Active @DJMarc75 last edited by

      @djmarc75

      quick & dirty:

      async function updateLocation(latitude, longitude) {
          const url = `https://nominatim.openstreetmap.org/reverse?lat=${latitude}&lon=${longitude}&format=json`;
          const response = await axios.get(url);
          if (response && response.data.display_name) {
            return(response.data.display_name);
          }
      }
      
      1 Reply Last reply Reply Quote 0
      • M
        MCU @DJMarc75 last edited by MCU

        @djmarc75 Wenn du Blockly nutzt kannst du auch direkt den Block verwenden?
        2ae1f768-c9ce-4adf-b57d-acd251e9e75b-image.png

        09f8663b-e449-4ebd-8352-3ca5b6745fef-image.png

        <xml xmlns="https://developers.google.com/blockly/xml">
          <variables>
            <variable id="`eps4Xu;/O9P-h|FWJ-E">lat</variable>
            <variable id="qICBRrCi%-}_(mq;vWM^">lon</variable>
            <variable id=")AQ%}HdiHDw^ZDxO0d[?">response</variable>
          </variables>
          <block type="variables_set" id="2DF6oAFi1G}uOwa_3?)w" x="88" y="113">
            <field name="VAR" id="`eps4Xu;/O9P-h|FWJ-E">lat</field>
            <value name="VALUE">
              <block type="math_number" id="FduAcw*36HRQdJJcnT(M">
                <field name="NUM">52.52</field>
              </block>
            </value>
            <next>
              <block type="variables_set" id="flw^g!3aB+q_~hAO83[g">
                <field name="VAR" id="qICBRrCi%-}_(mq;vWM^">lon</field>
                <value name="VALUE">
                  <block type="math_number" id=":CT|HqW-VISJ=XBdNMzY">
                    <field name="NUM">13.405</field>
                  </block>
                </value>
                <next>
                  <block type="http_get" id="er#Datp2ZE*VyGUa%*Kv">
                    <field name="TIMEOUT">2000</field>
                    <field name="UNIT">ms</field>
                    <field name="TYPE">text</field>
                    <value name="URL">
                      <shadow type="text" id="Q_WE@|3:]0*%[l-.!;qf">
                        <field name="TEXT"></field>
                      </shadow>
                      <block type="text_join" id="-ys2STS:FUWU@%[8~o[=">
                        <mutation items="5"></mutation>
                        <value name="ADD0">
                          <block type="text" id="B25~4=^wMHf(vUb3ay~3">
                            <field name="TEXT">https://nominatim.openstreetmap.org/reverse.php?format=json&amp;lat=</field>
                          </block>
                        </value>
                        <value name="ADD1">
                          <block type="variables_get" id="3Y8[4Y4CR#bn(@$tYkc+">
                            <field name="VAR" id="`eps4Xu;/O9P-h|FWJ-E">lat</field>
                          </block>
                        </value>
                        <value name="ADD2">
                          <block type="text" id="==#V5Ah1PyKx_!-*~JfY">
                            <field name="TEXT">&amp;lon=</field>
                          </block>
                        </value>
                        <value name="ADD3">
                          <block type="variables_get" id="ya.!JwNXi/PO.!GZE@tX">
                            <field name="VAR" id="qICBRrCi%-}_(mq;vWM^">lon</field>
                          </block>
                        </value>
                        <value name="ADD4">
                          <block type="text" id="[JnnacT#;5U-rwb.89lc">
                            <field name="TEXT">&amp;zoom=18</field>
                          </block>
                        </value>
                      </block>
                    </value>
                    <statement name="STATEMENT">
                      <block type="debug" id="Z/p^=2Hb40.14a$HJF{b">
                        <field name="Severity">log</field>
                        <value name="TEXT">
                          <shadow type="text" id="X7.E)1NBlIOrpnS^9XwS">
                            <field name="TEXT">test</field>
                          </shadow>
                          <block type="variables_get" id="Jgr?*Epm}01s%F=YGUa+">
                            <field name="VAR" id=")AQ%}HdiHDw^ZDxO0d[?">response</field>
                          </block>
                        </value>
                      </block>
                    </statement>
                  </block>
                </next>
              </block>
            </next>
          </block>
        </xml>
        

        DJMarc75 1 Reply Last reply Reply Quote 3
        • DJMarc75
          DJMarc75 @MCU last edited by

          @mcu Jou, so (ähnlich) habe ich es mir eben auch zusammen gebastelt 😉

          Funktioniert !

          Merci auch an @Codierknecht & @Lucky_ESA

          Muss noch viel was JS angeht lernen.

          haus-automatisierung 1 Reply Last reply Reply Quote 0
          • haus-automatisierung
            haus-automatisierung Developer Most Active @DJMarc75 last edited by

            @djmarc75 Die Idee mit den neuen Versionen war ja eigentlich, nicht wieder in das gleiche Problem zu laufen wie aktuell mit request. Also am besten kommt axios gar nicht in deinem Code vor, sondern Du nutzt httpGet (oder die Blockly-Bausteine dafür).

            Dann können wir in Zukunft die Library darunter austauschen und alle Scripts laufen weiter.

            D 1 Reply Last reply Reply Quote 7
            • D
              darkiop Most Active @haus-automatisierung last edited by

              @haus-automatisierung

              Der httpGet Block hat aktuell keine Option um Zertifikatsfehler zu ignorieren oder?

              haus-automatisierung 1 Reply Last reply Reply Quote 0
              • haus-automatisierung
                haus-automatisierung Developer Most Active @darkiop last edited by

                @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.

                D 1 Reply Last reply Reply Quote 1
                • D
                  darkiop Most Active @haus-automatisierung last edited by

                  @haus-automatisierung

                  Stimmt - allerdings gerade im häuslichen Umfeld oft "normal".

                  Am Ende ist ist es ein abwägen von Risiko und Nutzen 😉

                  haus-automatisierung 1 Reply Last reply Reply Quote 0
                  • haus-automatisierung
                    haus-automatisierung Developer Most Active @darkiop last edited by

                    @darkiop Ja, und was ist der Nutzen von einer https Verbindung im LAN?

                    D 1 Reply Last reply Reply Quote 0
                    • D
                      darkiop Most Active @haus-automatisierung last edited by

                      @haus-automatisierung

                      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.

                      1 Reply Last reply Reply Quote 0
                      • bahnuhr
                        bahnuhr Forum Testing Most Active last edited by

                        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.

                        haus-automatisierung 1 Reply Last reply Reply Quote 0
                        • haus-automatisierung
                          haus-automatisierung Developer Most Active @bahnuhr last edited by

                          @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 nicht httpGet ?

                          https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#httpget

                          haus-automatisierung bahnuhr 2 Replies Last reply Reply Quote 1
                          • haus-automatisierung
                            haus-automatisierung Developer Most Active @haus-automatisierung last edited by haus-automatisierung

                            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
                                            });
                                        }
                                    });
                                }
                            });
                            
                            1 Reply Last reply Reply Quote 1
                            • bahnuhr
                              bahnuhr Forum Testing Most Active @haus-automatisierung last edited by

                              @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.

                              haus-automatisierung 1 Reply Last reply Reply Quote 0
                              • haus-automatisierung
                                haus-automatisierung Developer Most Active @bahnuhr last edited by haus-automatisierung

                                @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),
                                        });
                                    }
                                });
                                
                                
                                bahnuhr 1 Reply Last reply Reply Quote 1
                                • bahnuhr
                                  bahnuhr Forum Testing Most Active @haus-automatisierung last edited by

                                  @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.

                                  haus-automatisierung liv-in-sky 2 Replies Last reply Reply Quote 0
                                  • haus-automatisierung
                                    haus-automatisierung Developer Most Active @bahnuhr last edited by

                                    @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?

                                    bahnuhr 2 Replies Last reply Reply Quote 0
                                    • bahnuhr
                                      bahnuhr Forum Testing Most Active @haus-automatisierung last edited by

                                      @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

                                      1 Reply Last reply Reply Quote 0
                                      • bahnuhr
                                        bahnuhr Forum Testing Most Active @haus-automatisierung last edited by

                                        @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).

                                        joergeli 1 Reply Last reply Reply Quote 0
                                        • joergeli
                                          joergeli @bahnuhr last edited by

                                          @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.

                                          bahnuhr 1 Reply Last reply Reply Quote 2
                                          • bahnuhr
                                            bahnuhr Forum Testing Most Active @joergeli last edited by

                                            @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:
                                            dfc6a9bd-519c-4e78-b839-52dad719b8aa-image.png

                                            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.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            817
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            18
                                            59
                                            7166
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo