Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Hilfe bei Skripte von request auf 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

    Hilfe bei Skripte von request auf httpGet umbauen

    This topic has been deleted. Only users with topic management privileges can see it.
    • Negalein
      Negalein Global Moderator last edited by

      Hallo

      Ich habe 8 Scripte, wo noch request läuft.
      Reicht mWn nicht, einfach request durch httpGet zu ersetzen.

      Könnte da wer über meine Scripte drüberschaun und mir dabei behilflich sein?

      Das ist zB eins von den 8.

      var url = "http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365";
      var pfad = "Volkszaehler.";
      var idAKTUELLER_VERBRAUCH = pfad + "AKTUELLER_VERBRAUCH";
      var idAKTUELLE_ERZEUGUNG = pfad + "AKTUELLE_LIEFERUNG";
      // var idAKTUELLE_HEIZUNG = pfad + "AKTUELLE_HEIZUNG";
       
       
      // Vorgegebene Funktion, die nur dazu dient, das JSON einzulesen
      // Angelehnt an: http://www.iobroker.net/docu/?page_id=3691
      var request = require("request");
      function readJson(url, callback) {
          request(url, function(err, state, body) {
              if (body) {
                  var json = {};
                  if (body !== "") {
                      try {
                          json = JSON.parse(body);
                      } catch (ex) {
                          json = {};
                      }
                      if (!json) {
                          json = {};
                      }
                  }
                  callback(null, json);
              } else {
                  var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                  log(error, "warn");
                  callback(error, null);
              }
          });
      }
       
      // Erzeugen der Objekte in ioBroker
      createState(idAKTUELLER_VERBRAUCH, 0, {
          name: 'Aktueller Verbrauch',
          desc: 'Aktueller Verbrauch',
          type: 'number',
          role: 'value',
          unit: 'W'
      });
      createState(idAKTUELLE_ERZEUGUNG, 0, {
          name: 'Aktuelle Erzeugung',
          desc: 'Aktuelle Erzeugung',
          type: 'number',
          role: 'value',
          unit: 'W'
      });
      // createState(idAKTUELLE_HEIZUNG, 0, {
      //     name: 'Aktuelle Heizung',
      //     desc: 'Aktuelle Heizung',
      //     type: 'number',
      //     role: 'value',
      //     unit: 'W'
      // });
       
      // Startet das Skript alle 2 Sekunden neu
      schedule("*/2 * * * * *", function() {
          readJson(url, function(err, json) {
              if (!err) {
                  var wert1 = json.data[0].tuples[0][1];
                  var wert2 = json.data[1].tuples[0][1];
                  // var wert3 = json.data[2].tuples[0][1];
                  // Setzen der Werte in ioBroker
                  // Man füllt die oben erzeugten Objekte jetzt mit den Werten
                  setState(idAKTUELLER_VERBRAUCH, wert1);
                  setState(idAKTUELLE_ERZEUGUNG, wert2);
                  // setState(idAKTUELLE_HEIZUNG, wert3);
              } else {
                  log("Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.", "warn");
              }
          });
      });
      
      

      Der Tipp von @paul53

      Lass Zeile 10 weg und ersetze Zeilen 12, 13 durch

         httpGet(url, (err, response) => {
             if(!err) {
                 const body = response.data;
      

      Die Funktion liest nicht nur das JSON ein, sondern wandelt es auch in ein Objekt.

      bringt mir eine Warnung

      javascript.0 2024-05-21 22:00:04.003	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
      javascript.0 2024-05-21 22:00:04.003	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
      

      Danke

      arteck liv-in-sky 2 Replies Last reply Reply Quote 0
      • arteck
        arteck Developer Most Active @Negalein last edited by arteck

        @negalein hatten wir die Tage schon mal...

        https://forum.iobroker.net/topic/74901/request-ablösen-durch-httpget?_=1716783342175

        1 Reply Last reply Reply Quote 0
        • Negalein
          Negalein Global Moderator last edited by

          @arteck sagte in Hilfe bei Skripte von request auf httpGet umbauen:

          hatten wir die Tage schon mal...

          Danke, den hab ich bereits durchforstet und versucht in meinen Scripten umzusetzen.

          Ich hab jetzt nochmal den Vorschlag von @paul53 versucht.
          Es klappt jetzt. Keine Ahnung, warum vorher die Meldungen gekommen sind.

          liv-in-sky 1 Reply Last reply Reply Quote 0
          • liv-in-sky
            liv-in-sky @Negalein last edited by

            @negalein sagte in Hilfe bei Skripte von request auf httpGet umbauen:

            Lass Zeile 10 weg und ersetze Zeilen 12, 13 durch

            müßte dann so aussehen
            (ist das gewollt, dass das alle 2 sekunden ausgeführt wird ?)

            var url = "http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365";
            var pfad = "Volkszaehler.";
            var idAKTUELLER_VERBRAUCH = pfad + "AKTUELLER_VERBRAUCH";
            var idAKTUELLE_ERZEUGUNG = pfad + "AKTUELLE_LIEFERUNG";
            // var idAKTUELLE_HEIZUNG = pfad + "AKTUELLE_HEIZUNG";
             
             
            // Vorgegebene Funktion, die nur dazu dient, das JSON einzulesen
            // Angelehnt an: http://www.iobroker.net/docu/?page_id=3691
            //var request = require("request");
            function readJson(url, callback) {
                httpGet(url, { timeout: 3000, responseType: 'text' },function(err,response) {
                    const body=response.data;
                    if (!err) {
                        var json = {};
                        if (body !== "") {
                            try {
                                json = JSON.parse(body);
                            } catch (ex) {
                                json = {};
                            }
                            if (!json) {
                                json = {};
                            }
                        }
                        callback(null, json);
                    } else {
                        var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                        log(error, "warn");
                        callback(error, null);
                    }
                });
            }
             
            // Erzeugen der Objekte in ioBroker
            createState(idAKTUELLER_VERBRAUCH, 0, {
                name: 'Aktueller Verbrauch',
                desc: 'Aktueller Verbrauch',
                type: 'number',
                role: 'value',
                unit: 'W'
            });
            createState(idAKTUELLE_ERZEUGUNG, 0, {
                name: 'Aktuelle Erzeugung',
                desc: 'Aktuelle Erzeugung',
                type: 'number',
                role: 'value',
                unit: 'W'
            });
            // createState(idAKTUELLE_HEIZUNG, 0, {
            //     name: 'Aktuelle Heizung',
            //     desc: 'Aktuelle Heizung',
            //     type: 'number',
            //     role: 'value',
            //     unit: 'W'
            // });
             
            // Startet das Skript alle 2 Sekunden neu
            schedule("*/2 * * * * *", function() {
                readJson(url, function(err, json) {
                    if (!err) {
                        var wert1 = json.data[0].tuples[0][1];
                        var wert2 = json.data[1].tuples[0][1];
                        // var wert3 = json.data[2].tuples[0][1];
                        // Setzen der Werte in ioBroker
                        // Man füllt die oben erzeugten Objekte jetzt mit den Werten
                        setState(idAKTUELLER_VERBRAUCH, wert1);
                        setState(idAKTUELLE_ERZEUGUNG, wert2);
                        // setState(idAKTUELLE_HEIZUNG, wert3);
                    } else {
                        log("Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.", "warn");
                    }
                });
            });
             
            
            
            1 Reply Last reply Reply Quote 0
            • liv-in-sky
              liv-in-sky @Negalein last edited by

              @negalein sorry - -du hast es schon erledigt - hatte ich nicht gesehen

              Negalein 1 Reply Last reply Reply Quote 0
              • Negalein
                Negalein Global Moderator @liv-in-sky last edited by

                @liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:

                sorry - -du hast es schon erledigt - hatte ich nicht gesehen

                Danke.
                Hab gerade gesehn, dass wieder die Meldungen kkommen.
                Liegt das an Die Funktion liest nicht nur das JSON ein, sondern wandelt es auch in ein Objekt.?

                javascript.0
                2024-05-27 08:01:14.003	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:01:14.002	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:01:12.004	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:01:12.004	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:01:10.004	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:01:10.004	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:01:08.002	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:01:08.002	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:01:06.003	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:01:06.002	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:01:04.004	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:01:04.003	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:00:14.003	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:00:14.003	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:00:12.004	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:00:12.003	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:00:10.007	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:00:10.007	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:00:08.002	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:00:08.002	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:00:06.003	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:00:06.003	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                javascript.0
                2024-05-27 08:00:04.006	warn	script.js.common.Volkszaehler: Fehler beim Auslesen des JSON fuer Volkszaehler. Keine Daten erhalten.
                
                javascript.0
                2024-05-27 08:00:04.006	warn	script.js.common.Volkszaehler: (timeout of 2000ms exceeded) ERROR bei Abfrage von: http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                
                liv-in-sky 1 Reply Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @Negalein last edited by liv-in-sky

                  @negalein

                  bei meinem script habe ich den timeout auf 3000 gesetzt - teste mal das evtl mit 4000

                  aber dann macht eine 2-sekunden abfrage keinen sinn - dass müßte dann angeglichen werden - z.b. abfrage alle 5 sek

                  Negalein 1 Reply Last reply Reply Quote 0
                  • Negalein
                    Negalein Global Moderator @liv-in-sky last edited by

                    @liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:

                    bei meinem script habe ich den timeout auf 3000 gesetzt - teste mal das evtl mit 4000

                    Danke dir.
                    Meldungen sind weg. Den Schedule hab ich auf 10 erhöht.

                    Könntest du bei den anderen auch noch helfen?

                    1 Reply Last reply Reply Quote 0
                    • Negalein
                      Negalein Global Moderator last edited by Negalein

                      @liv-in-sky

                      //hier bitte konfigurieren
                      //datenpunkt sollte vor skriptstart bereits existieren und mit Typ Text erstellt worden sein
                      const dpPrices = "0_userdata.0.IQ_Sprit.IQ_Sprit";
                      let user = "xxxxxxxxxx";
                      let pass = "xxxxxxxxxx";
                       
                      //ab hier nix verändern
                      const request = require("request");
                      const cheerio = require("cheerio");
                       
                      let $;
                      async function main() {
                       
                        var optionsLogin = {
                          method: 'POST',
                          url: "https://netservice.iqcard.at/de/login",
                          body: "BENUID=" + user + "&PASSWT=" + pass + "&login-form-submit=login",
                          jar: true,
                          followRedirect: true,
                          followAllRedirects: true,
                          headers: {
                            "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
                            "accept-encoding": "gzip, deflate, br",
                            "accept-language": "de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7",
                            "cache-control": "no-cache",
                            "content-type": "application/x-www-form-urlencoded",
                            "dnt": "1",
                            "origin": "https://netservice.iqcard.at",
                            "pragma": "no-cache",
                            "sec-ch-ua": "\"Not?A_Brand\";v=\"8\", \"Chromium\";v=\"108\", \"Google Chrome\";v=\"108\"",
                            "sec-ch-ua-mobile": "?0",
                            "sec-ch-ua-platform": "\"Windows\"",
                            "sec-fetch-dest": "empty",
                            "sec-fetch-mode": "cors",
                            "sec-fetch-site": "same-origin",
                            "upgrade-insecure-requests": "1",
                            "User-Agent": " Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36",
                            "cookie": "cAccept=true; NETSERVICE=true; IQCARDPASSWT=; IQCARDBENUID= ",
                            "Referer": "https://netservice.iqcard.at/de/kunden"
                          }
                        };
                        var optionsPriceinfo = {
                          method: 'GET',
                          url: "https://netservice.iqcard.at/de/netservice_preisinfo",
                          jar: true,
                          followRedirect: true,
                          followAllRedirects: true,
                          headers: {
                            "accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
                            "accept-encoding": "gzip, deflate, br",
                            "accept-language": "de-DE,de;q=0.9,en-US;q=0.8,en;q=0.7",
                            "cache-control": "no-cache",
                            "dnt": "1",
                            "origin": "https://netservice.iqcard.at",
                            "pragma": "no-cache",
                            "sec-ch-ua": "\"Not?A_Brand\";v=\"8\", \"Chromium\";v=\"108\", \"Google Chrome\";v=\"108\"",
                            "sec-ch-ua-mobile": "?0",
                            "sec-ch-ua-platform": "\"Windows\"",
                            "sec-fetch-dest": "empty",
                            "sec-fetch-mode": "cors",
                            "sec-fetch-site": "same-origin",
                            "sec-fetch-user": "?1",
                            "upgrade-insecure-requests": "1",
                            "User-Agent": " Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36",
                            "Referer": "https://netservice.iqcard.at/de/netservice"
                          }
                        };
                       
                        request.jar();
                        request.post(optionsLogin, () => {
                          request.get(optionsPriceinfo, (error, response, body) => {
                            let data = analyze(body);
                            log(data);
                            writeDatapoint(data);
                          });
                        });
                       function writeDatapoint(data) {
                         log("write dpPrices");
                         setState(dpPrices,JSON.stringify(data));
                       }
                      }
                      main()
                       
                      function analyze(body) {
                        $ = cheerio.load(body);
                        let countrys = $(".row > div > fieldset");
                        let data = {}
                        for (var i = 1; i < countrys.length; i++) {
                          let country = getCountry(countrys[i]);
                          data[country.countryname] = country;
                        }
                        return data;
                      }
                      function getCountry(country) {
                        let data = {};
                        data.services = {};
                        data.info = "";
                        data.countryname = $(country).find("> legend").text().trim();
                        let sections = $(country).find(".panel .panel-heading");
                        for (var i = 0; i < sections.length; i++) {
                          let section = $(sections[i]);
                          let title = section.text().trim();
                          let fields = $(section.next().find("fieldset"));
                          if (fields.length > 0) {
                            data.services[title] = getGasPrices(fields);
                          } else {
                            data.services[title] = getOtherServices(section.next());
                          }
                        }
                        if (sections.length == 0) data.info = $(country).contents().filter((i, el) => el.nodeType == 3).text().trim();
                        return data;
                      }
                      function getGasPrices(fields) {
                        let data = [];
                        for (var i = 0; i < fields.contents().length; i++) {
                          let field = fields.contents()[i];
                          if (field.nodeType == 3 && field.data.replace(/\s/gm, "") != "") {
                            let date = field.data.replace(/\s/gm, "");
                            let price = $(field).next().text();
                            data.push({ date: date, price: price });
                          }
                        }
                        return data;
                      }
                      function getOtherServices(fields) {
                        return fields.text().trim();
                      }  
                      
                       
                      schedule("59 * * * *", async function () {
                         main();   
                      });
                      

                      /* bringt den Druckertintenstand von WEB enabled HP Tintenstrahler in ioBroker
                         Drucker HP Tintenstand für iobroker ermitteln
                        Basierend auf CCU2 Script fuer HP Drucker http://homematic-forum.de/forum/viewtopic.php?f=31&t=25140
                        und dem angepassten Script von PiX aus iobroker  http://forum.iobroker.de/viewtopic.php?f=21&t=910&p=6931&hilit=drucker&sid=6780c0b33361e199846dcb584c8dc289&sid=6780c0b33361e199846dcb584c8dc289#p6931
                        Author : looxer01 - 22.12.2015
                        Version 0.2 29.01.2015        Druckerparameter jetzt einstellbar im Bereich der Einstellungen
                        kosmetik ykuendig
                      */
                       
                      // hier Drucker parameter einstellen - vor dem ersten Speichern des Scripts
                       
                      var druckerIP       = '10.0.1.15';            // Drucker IP 
                      var druckermod      = "HPOJ9012";                   // Drucker Modell - Strukturelement in den Variablen
                      var TinteID         = "963";                  // Tinte - Tintenbezeichnung
                      var TinteCyanBez    = "3JA05A";                // Bezeichnung fuer Cyan
                      var TinteMagentaBez = "3JA06A";                // Bezeichnung fuer Magenta
                      var TinteYellowBez  = "3JA07A";                // Bezeichnung fuer Yellow
                      var TinteBlackBez   = "3JA17A";                // Bezeichnung fuer Black
                       
                      // ENDE der Einstellungen
                       
                      var druckerURL      = "http://" + druckerIP + "/DevMgmt/ConsumableConfigDyn.xml";          // URL nicht ändern
                      var request         = require('request');                                                   // Enabling for URL Request
                      var cut0            = "dd:Capacity";                                                        // Marker für capacity
                      var cut1            = "dd:ConsumableLabelCode";                                             // Marker für color
                      var cut2            = "dd:ConsumablePercentageLevelRemaining";                              // Marker für Level
                       
                      var level_C  = 0;                                                                           // Tintenlevel
                      var level_M  = 0;                                                                           // Tintenlevel
                      var level_Y  = 0;                                                                           // Tintenlevel
                      var level_K  = 0;                                                                           // Tintenlevel
                       
                      var DruckIP         = "Drucker.HP." + druckermod + ".IP";                                   // Variable für create states
                      var DruckerName     = "Drucker.HP." + druckermod + ".Name";                                 // Variable für create states
                      var Modell          = "Drucker.HP." + druckermod + ".Modell";                               // Variable für create states
                      var Tinte           = "Drucker.HP." + druckermod + ".Tinte";                                // Variable für create states
                       
                      var CyanInk         = "Drucker.HP." + druckermod + ".Color1Cyan.Ink";                       // Variable für create states
                      var MagentaInk      = "Drucker.HP." + druckermod + ".Color2Magenta.Ink";                    // Variable für create states
                      var YellowInk       = "Drucker.HP." + druckermod + ".Color3Yellow.Ink";                     // Variable für create states
                      var BlackInk        = "Drucker.HP." + druckermod + ".Color4Black.Ink";                      // Variable für create states
                       
                      var CyanLevel       = "Drucker.HP." + druckermod + ".Color1Cyan.Level";                     // Variable für create states
                      var MagentaLevel    = "Drucker.HP." + druckermod + ".Color2Magenta.Level";                  // Variable für create states
                      var YellowLevel     = "Drucker.HP." + druckermod + ".Color3Yellow.Level";                   // Variable für create states
                      var BlackLevel      = "Drucker.HP." + druckermod + ".Color4Black.Level";                    // Variable für create states
                       
                      // Anlegen der Variablen
                      createState(DruckIP,druckerIP);
                      createState(DruckerName,druckermod);
                      createState(Tinte,TinteID);
                       
                      createState(CyanInk,TinteCyanBez);
                      createState(MagentaInk,TinteMagentaBez);
                      createState(YellowInk,TinteYellowBez);
                      createState(BlackInk,TinteBlackBez);
                       
                      createState(CyanLevel,0);
                      createState(MagentaLevel,0);
                      createState(YellowLevel,0);
                      createState(BlackLevel),0;
                       
                      // Schedule für die Updates
                      schedule("0 */6 * * *",  Drucker);      // Schedule alle 6 Stunden
                      Drucker();                              // Sofort beim Scriptstart einmal laufen lassen
                       
                      function Drucker () {
                       
                          request(druckerURL, function (error, response, body) {                              // Einlesen der XML Information
                          if (!error && response.statusCode == 200) {                                         // error check
                       
                              // Farbe nummer 1  
                              var TagEndMarker = '<'; 
                              var null_position = body.indexOf(cut0) + cut0.length + 1 ;
                              var eins_position = body.indexOf(cut1, null_position) + cut1.length  + 1;       // erste Position finden
                              var color =   body.substring(eins_position, eins_position+1) ;                  // erste Position ist die Farbe
                              var zwei_position = body.indexOf(cut2)+ cut2.length  + 1;                       // zweite Position finden
                              var level_string = body.substring(zwei_position, body.indexOf(TagEndMarker, zwei_position));
                              var eins_lastpos = eins_position;                                               // merken position eins
                              var zwei_lastpos = zwei_position;                                               // merken position zwei
                              
                       
                              if("C" == color){ level_C  = level_string; }
                              if("M" == color){ level_M  = level_string; }
                              if("Y" == color){ level_Y  = level_string; }
                              if("K" == color){ level_K  = level_string; }
                       
                              eins_lastpos = eins_position + 10;
                              zwei_lastpos = zwei_position + 10;               
                       
                              // Farbe nummer 2   
                              eins_position = body.indexOf(cut1, eins_lastpos) + cut1.length + 1 ;
                              color =   body.substring(eins_position, eins_position+1) ;
                              zwei_position = body.indexOf(cut2,zwei_lastpos)+ cut2.length  + 1;
                              level_string = body.substring(zwei_position, body.indexOf(TagEndMarker, zwei_position));
                       
                              if("C" == color){ level_C  = level_string; }
                              if("M" == color){ level_M  = level_string; }
                              if("Y" == color){ level_Y  = level_string; }
                              if("K" == color){ level_K  = level_string; }
                       
                              eins_lastpos = eins_position + 10;
                              zwei_lastpos = zwei_position + 10;               
                       
                              // Farbe nummer 3   
                              eins_position = body.indexOf(cut1, eins_lastpos) + cut1.length  + 1;
                              color =   body.substring(eins_position, eins_position+1) ;
                              zwei_position = body.indexOf(cut2,zwei_lastpos)+ cut2.length  + 1;
                              level_string = body.substring(zwei_position, body.indexOf(TagEndMarker, zwei_position));
                       
                              if("C" == color){ level_C  = level_string; }
                              if("M" == color){ level_M  = level_string; }
                              if("Y" == color){ level_Y  = level_string; }
                              if("K" == color){ level_K  = level_string; }
                       
                              eins_lastpos = eins_position + 10;
                              zwei_lastpos = zwei_position + 10;               
                       
                              // Farbe nummer 4 
                              eins_position = body.indexOf(cut1, eins_lastpos) + cut1.length  + 1;
                              color =   body.substring(eins_position, eins_position+1) ;
                              zwei_position = body.indexOf(cut2,zwei_lastpos)+ cut2.length  + 1;
                              level_string = body.substring(zwei_position, body.indexOf(TagEndMarker, zwei_position));
                       
                              if("C" == color){ level_C  = level_string; }
                              if("M" == color){ level_M  = level_string; }
                              if("Y" == color){ level_Y  = level_string; }
                              if("K" == color){ level_K  = level_string; }
                       
                              eins_lastpos = eins_position + 10;
                              zwei_lastpos = zwei_position + 10;               
                       
                              log('Drucker Level  C ' + level_C  , "info");
                              log('Drucker Level  M ' + level_M  , "info");
                              log('Drucker Level  Y ' + level_Y  , "info");
                              log('Drucker Level  K ' + level_K  , "info");
                       
                              // der folgende Bereich muss für ggf abweichenden Druckertyp angepasst werden
                              setState(CyanLevel, level_C);
                              setState(MagentaLevel, level_M);
                              setState(YellowLevel, level_Y);
                              setState(BlackLevel, level_K);
                              setState(DruckIP, druckerIP);
                       
                          } else  {  //   if (!error && response.statusCode == 200) {
                              log(error);
                              log('Kein Drucker gefunden');
                          }
                       
                          }); // end of request
                       
                      } // end of function
                      

                      var logging = true; 
                      var debugging = false; 
                      var debugging_response = false;       //nur im Fehlerfall auf true. Hiermit wird die Antwort der Internetadresse protokolliert
                      var CCU_Version = 3;                  //Hier eine Zahl eintragen: 2 = CCU2 // 3 = CCU3 // 4 = Rasperrymatic
                      //Datenpunkt auswählen wo die installierte Version ersichtlich ist (aus Homematic.Rega Adapter)
                      const id_Version_installiert = "hm-rega.0.QEQ1301545.0.FIRMWARE_VERSION";
                      //Datenpunkt muss manuell angelegt werden. Kann irgendwo angelegt werden. Anschließend hier ersetzen
                      const id_Version_Internet = '0_userdata.0.CCU3.Servicemeldungen.Verfuegbare_CCU-Firmware';
                      const id_Update_Internet = '0_userdata.0.CCU3.Servicemeldungen.Update_verfuegbar';
                       
                       
                      var observation = true;         //Dauerhafte Überwachung der Firmware (true = aktiv // false =inaktiv)
                      var onetime = true;             //Prüft beim Scriptstart auf aktuelle Firmware
                       
                      //Prio für Pushover
                      var prio_Firmware = 0;
                       
                       
                      //Variablen für Pushover
                      var sendpush = false;            //true = verschickt per Pushover Nachrchten // false = Pushover wird nicht benutzt
                      var pushover_Instanz0 =  'pushover.0';     // Pushover instance für Pio = 0
                      var pushover_Instanz1 =  'pushover.1';     // Pushover instance für Pio = 1
                      var pushover_Instanz2 =  'pushover.2';     // Pushover instance für Pio = 2
                      var pushover_Instanz3 =  'pushover.3';     // Pushover instance für Pio = -1 oder -2
                      let _prio;
                      let _titel;
                      let _message;
                      var _device = 'TPhone';         //Welches Gerät soll die Nachricht bekommen
                      //var _device = 'All'; 
                       
                      //Variablen für Telegram
                      var sendtelegram = true;            //true = verschickt per Telegram Nachrchten // false = Telegram wird nicht benutzt
                      var user_telegram = '';             //User der die Nachricht bekommen soll
                       
                      //Variable zum verschicken der Servicemeldungen per eMail
                      var sendmail = false;            //true = verschickt per email Nachrchten // false = email wird nicht benutzt
                       
                       
                      // ab hier keine Änderung
                       
                      let _message_tmp;
                      var request = require('request');
                       
                      function send_pushover_V4 (_device, _message, _titel, _prio) {
                              if (_prio === 0){let pushover_Instanz =  pushover_Instanz0}
                              else if (_prio == 1){pushover_Instanz =  pushover_Instanz1}
                              else if (_prio == 2){pushover_Instanz =  pushover_Instanz2}
                              else {pushover_Instanz =  pushover_Instanz3}
                              sendTo(pushover_Instanz, { 
                              device: _device,
                              message: _message, 
                              title: _titel, 
                              priority: _prio,
                              retry: 60,
                              expire: 600,
                              html: 1
                          }); 
                      }
                       
                      function send_telegram (_message, user_telegram) {
                          sendTo('telegram.0', { 
                              text: _message,
                              user: user_telegram,
                              parse_mode: 'HTML'
                          }); 
                      }
                       
                      function send_mail (_message) {
                          sendTo("email", {
                              //from:    "iobroker@mydomain.com",
                              //to:      "aabbcc@gmail.com",
                              subject: "Servicemeldung",
                              text:    _message
                          });
                      }
                       
                      function func_Version(){
                          var Version_Internet = getState(id_Version_Internet).val;
                          var ccu2 = 'http://update.homematic.com/firmware/download?cmd=js_check_version&version=12345&product=HM-CCU2&serial=12345';
                          var ccu3 = 'http://update.homematic.com/firmware/download?cmd=js_check_version&version=12345&product=HM-CCU3&serial=9A499D4429';
                          var Raspi = 'https://gitcdn.xyz/repo/jens-maus/RaspberryMatic/master/release/LATEST-VERSION.js?_version_=CURRENT_VERSION';
                          let ccu;
                          if(CCU_Version == 3){ccu = ccu3;}
                          else if(CCU_Version == 4){ccu = Raspi;}
                          else {ccu = ccu2;}
                          url = ccu;
                       
                          request({url : url},
                       
                              function (error, response, body) {
                                  var Version_installiert = (getState(id_Version_installiert).val).trim();
                                  var Version = body.split("'");
                                  if(error){
                                      log('error: ' + error);
                                  } else {
                                      if(Version_Internet === ''){
                                          if(logging){
                                              log('ausgewähltes Objekt leer. Firmware wird erstmalig gesetzt.');
                                          }
                                          setState(id_Version_Internet,Version[1]);
                                      }
                                      
                                      if(Version_installiert == Version[1]){
                                          setState(id_Update_Internet,false);
                                          if(logging){
                                              log('Installierte Firmware '+Version_installiert  +' der CCU ist aktuell');
                                          }
                                      }
                                      else{
                                          setState(id_Update_Internet,true);
                                          if(logging){
                                              log('Installierte Firmware '+Version_installiert  +' der CCU ist nicht aktuell. Aktuell verfügbare Version: '+Version[1]);
                                          }
                                          
                                          if(Version_Internet == Version[1]){
                                              if(debugging){
                                                  log('[DEBUG] ' +'Version Internet hat sich nicht verändert');
                                              }
                                          } else {
                                              if(debugging){
                                                  log('[DEBUG] ' +'Installierte Firmware der CCU ist nicht aktuell.');
                                              }
                                              setState(id_Version_Internet,Version[1]);
                                               _message_tmp = 'Installierte Firmware der CCU ist nicht aktuell. Installiert: ' +Version_installiert +' --- Verfügbare Version: '+Version[1];
                                              
                                               //Push verschicken
                                              if(sendpush){
                                                  _prio = prio_Firmware;
                                                  _titel = 'CCU-Firmware';
                                                  _message = _message_tmp;
                                                  send_pushover_V4(_device, _message, _titel, _prio);
                                              }
                                              if(sendtelegram){
                                                  _message = _message_tmp;
                                                  send_telegram(_message, user_telegram);
                                              }
                                              if(sendmail){
                                                  _message = _message_tmp;
                                                  send_mail(_message);
                                              }
                                          }         
                                      }
                              
                                      if(debugging_response){
                                          log('body: ' + body);
                                          log('Länge ' + Version.length + ' --- Version: ' + Version[1]);
                                          log('response: ' + JSON.stringify(response));
                                      }
                                  }
                              }
                          );
                      }
                       
                      if(observation){
                          //Nachts einmalig ausführen 00:30 Schaltzeiten berechnen
                          schedule("54 05 * * *", func_Version);
                      }
                       
                      if(onetime){
                          //beim Starten
                          func_Version();
                      }
                      

                      var request = require("request");
                      
                      var myJson = {};
                      
                      var pfad = "Fronius_Symo_Hybrid_Max.";
                      
                      //var idDAY_ENERGY        = pfad + "ENERGY_DAY";
                      var idPAC               = pfad + "PAC";
                      var idYEAR_ENERGY       = pfad + "ENERGY_YEAR";
                      var idTOTAL_ENERGY      = pfad + "ENERGY_TOTAL";
                      
                      
                      //createState(idDAY_ENERGY, 0, {
                      //    name: 'Energie Tag',
                      //    desc: 'Energie Tag',
                      //    type: 'number',
                      //    role: 'value',
                      //    unit: 'Wh'
                      //});
                      
                      createState(idPAC, 0, {
                          name: 'Leistung',
                          desc: 'Leistung',
                          type: 'number',
                          role: 'value',
                          unit: 'W'
                      });
                      
                      createState(idYEAR_ENERGY, 0, {
                          name: 'Energie Jahr',
                          desc: 'Energie Jahr',
                          type: 'number',
                          role: 'value',
                          unit: 'Wh'
                      });
                      
                      createState(idTOTAL_ENERGY, 0, {
                          name: 'Energie Total',
                          desc: 'Energie Total',
                          type: 'number',
                          role: 'value',
                          unit: 'Wh'
                      });
                      
                      
                      
                      
                      function parseJson(text) {
                          if (text === "") return {};
                          try {
                              json = JSON.parse(text);
                          } catch (ex) {
                              json = {};
                          }
                          if(!json) json = {};
                          return json;
                      }
                      
                      function readJson(url, callback) {
                          request(url, function (err, state, body){
                              if (body) {
                                  var json = parseJson(body);
                                  callback(null, json);
                              } else {
                                  var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                                  log(error, "warn");  
                                  callback(error, null);
                              }
                          });
                      }
                      
                      
                      var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System';
                      
                      function main() {
                          readJson(url, function(err,json) {
                              if(!err) {
                                  myJson = json;
                      //            log("DAY_ENERGY: "      + myJson.Body.Data.DAY_ENERGY.Values[1],"info");
                                  log("PAC: "             + myJson.Body.Data.PAC.Values[1],"info");
                                  log("YEAR_ENERGY: "     + myJson.Body.Data.YEAR_ENERGY.Values[1],"info");
                                  log("TOTAL_ENERGY: "    + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info");
                      //            setState(idDAY_ENERGY   ,myJson.Body.Data.DAY_ENERGY.Values[1]);
                                  setState(idPAC          ,myJson.Body.Data.PAC.Values[1]);
                                  setState(idYEAR_ENERGY  ,myJson.Body.Data.YEAR_ENERGY.Values[1]);
                                  setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]);
                              } else {
                                  log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn");
                                  myJson = {};
                              }
                          });
                      }
                      
                      schedule("*/10 * * * * *", function () { // alle 10 Sekunden die Werte abfragen
                          main();
                      });
                      
                      // Beim Skriptstart die Werte abfragen
                      setTimeout(main,500);
                      

                      var request = require("request");
                      
                      var myJson = {};
                      
                      var pfad = "Fronius_Symo_Hybrid_Max.";
                      
                      var idDAY_ENERGY        = pfad + "ENERGY_DAY";
                      //var idPAC               = pfad + "PAC";
                      //var idYEAR_ENERGY       = pfad + "ENERGY_YEAR";
                      //var idTOTAL_ENERGY      = pfad + "ENERGY_TOTAL";
                      
                      
                      createState(idDAY_ENERGY, 0, {
                          name: 'Energie Tag',
                          desc: 'Energie Tag',
                          type: 'number',
                          role: 'value',
                          unit: 'Wh'
                      });
                      
                      //createState(idPAC, 0, {
                      //    name: 'Leistung',
                      //   desc: 'Leistung',
                      //    type: 'number',
                      //    role: 'value',
                      //    unit: 'W'
                      //});
                      
                      //createState(idYEAR_ENERGY, 0, {
                      //    name: 'Energie Jahr',
                      //    desc: 'Energie Jahr',
                      //    type: 'number',
                      //    role: 'value',
                      //    unit: 'Wh'
                      //});
                      
                      //createState(idTOTAL_ENERGY, 0, {
                      //    name: 'Energie Total',
                      //    desc: 'Energie Total',
                      //    type: 'number',
                      //    role: 'value',
                      //    unit: 'Wh'
                      //});
                      
                      
                      
                      
                      function parseJson(text) {
                          if (text === "") return {};
                          try {
                              json = JSON.parse(text);
                          } catch (ex) {
                              json = {};
                          }
                          if(!json) json = {};
                          return json;
                      }
                      
                      function readJson(url, callback) {
                          request(url, function (err, state, body){
                              if (body) {
                                  var json = parseJson(body);
                                  callback(null, json);
                              } else {
                                  var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                                  log(error, "warn");  
                                  callback(error, null);
                              }
                          });
                      }
                      
                      
                      var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System';
                      
                      function main() {
                          readJson(url, function(err,json) {
                              if(!err) {
                                  myJson = json;
                                  log("DAY_ENERGY: "      + myJson.Body.Data.DAY_ENERGY.Values[1],"info");
                      //            log("PAC: "             + myJson.Body.Data.PAC.Values[1],"info");
                      //            log("YEAR_ENERGY: "     + myJson.Body.Data.YEAR_ENERGY.Values[1],"info");
                      //            log("TOTAL_ENERGY: "    + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info");
                                  setState(idDAY_ENERGY   ,myJson.Body.Data.DAY_ENERGY.Values[1]);
                      //            setState(idPAC          ,myJson.Body.Data.PAC.Values[1]);
                      //            setState(idYEAR_ENERGY  ,myJson.Body.Data.YEAR_ENERGY.Values[1]);
                      //            setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]);
                              } else {
                                  log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn");
                                  myJson = {};
                              }
                          });
                      }
                      
                      schedule("59 23 * * *", function () { // täglich um 23 Uhr 59 Minuten
                          main();
                      });
                      
                      // Beim Skriptstart die Werte abfragen
                      setTimeout(main,500);
                      

                      liv-in-sky Homoran 5 Replies Last reply Reply Quote 0
                      • liv-in-sky
                        liv-in-sky @Negalein last edited by

                        @negalein

                        Muss jetzt dann weg
                        Komme Mittag wieder, wenn sich kein anderer findet, sehe ich mir das an

                        Negalein 1 Reply Last reply Reply Quote 0
                        • Negalein
                          Negalein Global Moderator @liv-in-sky last edited by

                          @liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:

                          Komme Mittag wieder, wenn sich kein anderer findet, sehe ich mir das an

                          Danke 🤗

                          liv-in-sky 1 Reply Last reply Reply Quote 0
                          • liv-in-sky
                            liv-in-sky @Negalein last edited by

                            @negalein

                            die fronius scripte könntest du evtl selbst probieren - die sind ähnlich, wie das , was wir gerade gemacht hatten

                            Negalein 1 Reply Last reply Reply Quote 1
                            • Negalein
                              Negalein Global Moderator @liv-in-sky last edited by

                              @liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:

                              die fronius scripte könntest du evtl selbst probieren - die sind ähnlich, wie das , was wir gerade gemacht hatten

                              würde es so funktionieren?

                              //var request = require("request");
                               
                              var myJson = {};
                               
                              var pfad = "Fronius_Symo_Hybrid_Max.";
                               
                              //var idDAY_ENERGY        = pfad + "ENERGY_DAY";
                              var idPAC               = pfad + "PAC";
                              var idYEAR_ENERGY       = pfad + "ENERGY_YEAR";
                              var idTOTAL_ENERGY      = pfad + "ENERGY_TOTAL";
                               
                               
                              //createState(idDAY_ENERGY, 0, {
                              //    name: 'Energie Tag',
                              //    desc: 'Energie Tag',
                              //    type: 'number',
                              //    role: 'value',
                              //    unit: 'Wh'
                              //});
                               
                              createState(idPAC, 0, {
                                  name: 'Leistung',
                                  desc: 'Leistung',
                                  type: 'number',
                                  role: 'value',
                                  unit: 'W'
                              });
                               
                              createState(idYEAR_ENERGY, 0, {
                                  name: 'Energie Jahr',
                                  desc: 'Energie Jahr',
                                  type: 'number',
                                  role: 'value',
                                  unit: 'Wh'
                              });
                               
                              createState(idTOTAL_ENERGY, 0, {
                                  name: 'Energie Total',
                                  desc: 'Energie Total',
                                  type: 'number',
                                  role: 'value',
                                  unit: 'Wh'
                              });
                               
                               
                               
                               
                              function parseJson(text) {
                                  if (text === "") return {};
                                  try {
                                      json = JSON.parse(text);
                                  } catch (ex) {
                                      json = {};
                                  }
                                  if(!json) json = {};
                                  return json;
                              }
                               
                              function readJson(url, callback) {
                                  httpGet(url, { timeout: 3000, responseType: 'text' },function(err,response) {
                                      const body=response.data;
                                          var json = parseJson(body);
                                          callback(null, json);
                                      } else {
                                          var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                                          log(error, "warn");  
                                          callback(error, null);
                                      }
                                  });
                              }
                               
                               
                              var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System';
                               
                              function main() {
                                  readJson(url, function(err,json) {
                                      if(!err) {
                                          myJson = json;
                              //            log("DAY_ENERGY: "      + myJson.Body.Data.DAY_ENERGY.Values[1],"info");
                                          log("PAC: "             + myJson.Body.Data.PAC.Values[1],"info");
                                          log("YEAR_ENERGY: "     + myJson.Body.Data.YEAR_ENERGY.Values[1],"info");
                                          log("TOTAL_ENERGY: "    + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info");
                              //            setState(idDAY_ENERGY   ,myJson.Body.Data.DAY_ENERGY.Values[1]);
                                          setState(idPAC          ,myJson.Body.Data.PAC.Values[1]);
                                          setState(idYEAR_ENERGY  ,myJson.Body.Data.YEAR_ENERGY.Values[1]);
                                          setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]);
                                      } else {
                                          log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn");
                                          myJson = {};
                                      }
                                  });
                              }
                               
                              schedule("*/10 * * * * *", function () { // alle 10 Sekunden die Werte abfragen
                                  main();
                              });
                               
                              // Beim Skriptstart die Werte abfragen
                              setTimeout(main,500);
                              

                              var request = require("request");
                              

                              geändert in

                              //var request = require("request");
                              

                              und

                                  request(url, function (err, state, body){
                                      if (body) {
                              

                              ersetz durch

                                  httpGet(url, { timeout: 3000, responseType: 'text' },function(err,response) {
                                      const body=response.data;
                              
                              paul53 1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 @Negalein last edited by

                                @negalein sagte: ersetz durch
                                Besser:

                                    httpGet(url, { timeout: 3000, responseType: 'text' }, function(err, response) {
                                        if(!err) {
                                            const body = response.data;
                                
                                Negalein 1 Reply Last reply Reply Quote 2
                                • Negalein
                                  Negalein Global Moderator @paul53 last edited by

                                  @paul53 sagte in Hilfe bei Skripte von request auf httpGet umbauen:

                                  Besser

                                  Danke, funktioniert. 🙂

                                  1 Reply Last reply Reply Quote 0
                                  • Negalein
                                    Negalein Global Moderator last edited by

                                    @paul53

                                    bei dem "Volkszähler-Script" bin ich jetzt schon mit dem Timeout auf 10000 rauf.
                                    Trotzdem kommt immer wieder die Warn-Meldung.

                                    Kann man diese Warn-Meldung unterdrücken?
                                    Oder besser mit dem Timeout testen, bis die Meldung nicht mehr kommt?

                                    liv-in-sky 1 Reply Last reply Reply Quote 0
                                    • liv-in-sky
                                      liv-in-sky @Negalein last edited by

                                      @negalein bei einem timeout von 10 sekunden denke ich, dass es evtl ein andres problem gibt - eigentlich sind 2000-4000 schon zu lange -

                                      kannst du mal den volkszähler neustarten - ansonsten fällt mir gerade nix dazu ein

                                      kommt der fehler immer? wenn ja, funktioniert es ein paarmal und ab einem zeitpunkt dann nicht mehr - oder funktioniert es immer wieder mal ?

                                      Homoran Negalein 2 Replies Last reply Reply Quote 0
                                      • Homoran
                                        Homoran Global Moderator Administrators @liv-in-sky last edited by

                                        @liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:

                                        eigentlich sind 2000-4000 schon zu lange -

                                        ehrlich?
                                        ich hatte mit dem Wiffi bei 2000 auch einige timeout exceeded, nach Erhöhung auf 4000 bisher keinen einzigen mehr.
                                        Später hab ich gesehen, dass im Originalskript 3000 msec timeout eingestellt waren.

                                        ich denke dass es u.a. auch auf das Netzwerk und das angesprochene Gerät ankommt.
                                        Beim Wiffi ist WLAN und ESP im Spiel.

                                        liv-in-sky 2 Replies Last reply Reply Quote 0
                                        • liv-in-sky
                                          liv-in-sky @Homoran last edited by

                                          @homoran

                                          ja ehrlich - ein device , dass solange braucht ist seltsam

                                          wobei ich auch bei den sonoffs mit httpget immer auf 4000 gehe, da ich sonst fehler habe -

                                          ich bin mir nicht sicher, ob diese 2000 wirklich 2 sekunden reine abfrage sind oder ob das irgendwie mehr beinhaltet

                                          selbst das auslesen eines unifi controllers mit massig daten dauert keine 2 sekunden (wenn das netwerk in ordnung ist)

                                          haus-automatisierung 1 Reply Last reply Reply Quote 0
                                          • liv-in-sky
                                            liv-in-sky @Homoran last edited by

                                            @homoran sagte in Hilfe bei Skripte von request auf httpGet umbauen:

                                            WLAN und ESP i

                                            das vermute ich auch - da ist aber dann die frage, ob es mit dem alten request auch immer zu fehlern gekommen ist (das script war auf "alle 2 sekunde abfrage" gestellt

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            910
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            16
                                            132
                                            9198
                                            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