Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Hilfe bei Skripte von request auf httpGet umbauen

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.6k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.1k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    2.9k

Hilfe bei Skripte von request auf httpGet umbauen

Geplant Angeheftet Gesperrt Verschoben JavaScript
132 Beiträge 16 Kommentatoren 16.9k Aufrufe 12 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • NegaleinN Negalein

    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

    arteckA Offline
    arteckA Offline
    arteck
    Developer Most Active
    schrieb am zuletzt editiert von arteck
    #2

    @negalein hatten wir die Tage schon mal...

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

    zigbee hab ich, zwave auch, nuc's genauso und HA auch

    1 Antwort Letzte Antwort
    0
    • NegaleinN Offline
      NegaleinN Offline
      Negalein
      Global Moderator
      schrieb am zuletzt editiert von
      #3

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

      ° Node.js: 20.17.0 NPM: 10.8.2
      ° Proxmox, Ubuntu 22.04.3 LTS
      ° Fixer ---> iob fix

      liv-in-skyL 1 Antwort Letzte Antwort
      0
      • NegaleinN Negalein

        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

        liv-in-skyL Offline
        liv-in-skyL Offline
        liv-in-sky
        schrieb am zuletzt editiert von
        #4

        @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");
                }
            });
        });
         
        
        

        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

        1 Antwort Letzte Antwort
        0
        • NegaleinN Negalein

          @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-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          schrieb am zuletzt editiert von
          #5

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

          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

          NegaleinN 1 Antwort Letzte Antwort
          0
          • liv-in-skyL liv-in-sky

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

            NegaleinN Offline
            NegaleinN Offline
            Negalein
            Global Moderator
            schrieb am zuletzt editiert von
            #6

            @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
            

            ° Node.js: 20.17.0 NPM: 10.8.2
            ° Proxmox, Ubuntu 22.04.3 LTS
            ° Fixer ---> iob fix

            liv-in-skyL 1 Antwort Letzte Antwort
            0
            • NegaleinN Negalein

              @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-skyL Offline
              liv-in-skyL Offline
              liv-in-sky
              schrieb am zuletzt editiert von liv-in-sky
              #7

              @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

              nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

              NegaleinN 1 Antwort Letzte Antwort
              0
              • liv-in-skyL 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

                NegaleinN Offline
                NegaleinN Offline
                Negalein
                Global Moderator
                schrieb am zuletzt editiert von
                #8

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

                ° Node.js: 20.17.0 NPM: 10.8.2
                ° Proxmox, Ubuntu 22.04.3 LTS
                ° Fixer ---> iob fix

                1 Antwort Letzte Antwort
                0
                • NegaleinN Offline
                  NegaleinN Offline
                  Negalein
                  Global Moderator
                  schrieb am zuletzt editiert von Negalein
                  #9

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

                  ° Node.js: 20.17.0 NPM: 10.8.2
                  ° Proxmox, Ubuntu 22.04.3 LTS
                  ° Fixer ---> iob fix

                  liv-in-skyL HomoranH 5 Antworten Letzte Antwort
                  0
                  • NegaleinN 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-skyL Offline
                    liv-in-skyL Offline
                    liv-in-sky
                    schrieb am zuletzt editiert von
                    #10

                    @negalein

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

                    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                    NegaleinN 1 Antwort Letzte Antwort
                    0
                    • liv-in-skyL liv-in-sky

                      @negalein

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

                      NegaleinN Offline
                      NegaleinN Offline
                      Negalein
                      Global Moderator
                      schrieb am zuletzt editiert von
                      #11

                      @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 :hugging_face:

                      ° Node.js: 20.17.0 NPM: 10.8.2
                      ° Proxmox, Ubuntu 22.04.3 LTS
                      ° Fixer ---> iob fix

                      liv-in-skyL 1 Antwort Letzte Antwort
                      0
                      • NegaleinN Negalein

                        @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 :hugging_face:

                        liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        schrieb am zuletzt editiert von
                        #12

                        @negalein

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

                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                        NegaleinN 1 Antwort Letzte Antwort
                        1
                        • liv-in-skyL liv-in-sky

                          @negalein

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

                          NegaleinN Offline
                          NegaleinN Offline
                          Negalein
                          Global Moderator
                          schrieb am zuletzt editiert von
                          #13

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

                          ° Node.js: 20.17.0 NPM: 10.8.2
                          ° Proxmox, Ubuntu 22.04.3 LTS
                          ° Fixer ---> iob fix

                          paul53P 1 Antwort Letzte Antwort
                          0
                          • NegaleinN Negalein

                            @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;
                            
                            paul53P Offline
                            paul53P Offline
                            paul53
                            schrieb am zuletzt editiert von
                            #14

                            @negalein sagte: ersetz durch
                            Besser:

                                httpGet(url, { timeout: 3000, responseType: 'text' }, function(err, response) {
                                    if(!err) {
                                        const body = response.data;
                            

                            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                            NegaleinN 1 Antwort Letzte Antwort
                            2
                            • paul53P paul53

                              @negalein sagte: ersetz durch
                              Besser:

                                  httpGet(url, { timeout: 3000, responseType: 'text' }, function(err, response) {
                                      if(!err) {
                                          const body = response.data;
                              
                              NegaleinN Offline
                              NegaleinN Offline
                              Negalein
                              Global Moderator
                              schrieb am zuletzt editiert von
                              #15

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

                              Besser

                              Danke, funktioniert. :)

                              ° Node.js: 20.17.0 NPM: 10.8.2
                              ° Proxmox, Ubuntu 22.04.3 LTS
                              ° Fixer ---> iob fix

                              1 Antwort Letzte Antwort
                              0
                              • NegaleinN Offline
                                NegaleinN Offline
                                Negalein
                                Global Moderator
                                schrieb am zuletzt editiert von
                                #16

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

                                ° Node.js: 20.17.0 NPM: 10.8.2
                                ° Proxmox, Ubuntu 22.04.3 LTS
                                ° Fixer ---> iob fix

                                liv-in-skyL 1 Antwort Letzte Antwort
                                0
                                • NegaleinN Negalein

                                  @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-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  schrieb am zuletzt editiert von
                                  #17

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

                                  nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                  HomoranH NegaleinN 2 Antworten Letzte Antwort
                                  0
                                  • liv-in-skyL liv-in-sky

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

                                    HomoranH Nicht stören
                                    HomoranH Nicht stören
                                    Homoran
                                    Global Moderator Administrators
                                    schrieb am zuletzt editiert von
                                    #18

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

                                    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                    liv-in-skyL 2 Antworten Letzte Antwort
                                    0
                                    • HomoranH Homoran

                                      @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-skyL Offline
                                      liv-in-skyL Offline
                                      liv-in-sky
                                      schrieb am zuletzt editiert von
                                      #19

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

                                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                      haus-automatisierungH 1 Antwort Letzte Antwort
                                      0
                                      • HomoranH Homoran

                                        @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-skyL Offline
                                        liv-in-skyL Offline
                                        liv-in-sky
                                        schrieb am zuletzt editiert von
                                        #20

                                        @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

                                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                        1 Antwort Letzte Antwort
                                        0
                                        • liv-in-skyL liv-in-sky

                                          @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-automatisierungH Offline
                                          haus-automatisierungH Offline
                                          haus-automatisierung
                                          Developer Most Active
                                          schrieb am zuletzt editiert von
                                          #21

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

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

                                            // `timeout` specifies the number of milliseconds before the request times out.
                                            // If the request takes longer than `timeout`, the request will be aborted.
                                          

                                          Was meinst Du mit "reine Abfrage"? Es geht einfach um die Zeit, in welcher auf eine Antwort vom Server gewartet wird. 2 Sekunden ist ja schon eine Ewigkeit.

                                          🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                                          🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                                          📚 Meine inoffizielle ioBroker Dokumentation

                                          liv-in-skyL 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          649

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe