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

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

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

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

    @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
    #42

    @negalein

    script HP zum test

    /* 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 () {
    
       httpGet(druckerURL, function (error, response ) {                              // Einlesen der XML Information
       if (!error) {                                         // error check
          const body=response.data;
           // 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
    
    

    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
    • 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
      #43

      @negalein

      bei dem IQ script muss ich leider passen - da müßte jmd anders drüber schauen :-(

      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

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

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

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

        method: 'POST',

        @liv-in-sky ist dann wohl eher httpPost??

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

          @negalein

          wenn du testen magst - sendet alle 15 sek den wert an iob - kannste dann ein blockly machen und dir einen alarm geben, wenn der wert mal über 1 (sek) ist.

          mache alles auf der console unter /usr/local/bin

          • kopiere datei curl-format.txt ins verzeichnis /usr/local/bin
          • erstelle datei httptest (sudo nano httptest) im verzeichnis mit inhalt und ändere den datenpukt in allen zeilen - den dp musst du anlegen (number)
          • die url musst du auch anpassen

          
          #!/bin/bash
          dauer=`curl -w "@curl-format.txt"  -s 'http://192.168.178.159/cm?cmnd=Dimmer%2010' | grep time_total -m 1 | awk '{print $2}' | sed -e 's/s//'`
          #curl "http://192.168.178.59:8087/set/0_userdata.0.CONTROL-OWN.htttpget-test?value=$dauer"
          iobroker state set 0_userdata.0.CONTROL-OWN.htttpget-test $dauer
          echo Temp:  $dauer
          sleep 15
          tempi=`curl -w "@curl-format.txt"  -s 'http://192.168.178.159/cm?cmnd=Dimmer%2010' | grep time_total -m 1 | awk '{print $2}' | sed -e 's/s//'`
          iobroker state set 0_userdata.0.CONTROL-OWN.htttpget-test $tempi
          sleep 15
          tempi=`curl -w "@curl-format.txt"  -s 'http://192.168.178.159/cm?cmnd=Dimmer%2010' | grep time_total -m 1 | awk '{print $2}' | sed -e 's/s//'`
          iobroker state set 0_userdata.0.CONTROL-OWN.htttpget-test $tempi
          sleep 15
          tempi=`curl -w "@curl-format.txt"  -s 'http://192.168.178.159/cm?cmnd=Dimmer%2010' | grep time_total -m 1 | awk '{print $2}' | sed -e 's/s//'`
          iobroker state set 0_userdata.0.CONTROL-OWN.htttpget-test $tempi
          
          

          • sichern und befehl sudo chmod +x httptest ausführen
          • dann sudo crontab -e öffnen und folgenden eintrag eingeben: */1 * * * * /usr/local/bin/httptest

          Image 048.png

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

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

          url musst du auch anpassen

          http://192.168.178.159/cm?cmnd=Dimmer%2010

          IP die vom ioB schätze ich?
          was ist das ""Dimmer%2010"?

          ändere den datenpukt in allen zeilen - den dp musst du anlegen (number)

          0_userdata.0.Tests.htttpget-test --> hier schreibt er die Zeit dann rein?

          was ist das $tempi das auch in den DP schreibt?

          ° 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
          • liv-in-skyL liv-in-sky

            @negalein

            script HP zum test

            /* 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 () {
            
               httpGet(druckerURL, function (error, response ) {                              // Einlesen der XML Information
               if (!error) {                                         // error check
                  const body=response.data;
                   // 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
            
            

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

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

            script HP zum test
            HP Script

            Danke, läuft sofort ohne Fehler :)

            ° 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:

              url musst du auch anpassen

              http://192.168.178.159/cm?cmnd=Dimmer%2010

              IP die vom ioB schätze ich?
              was ist das ""Dimmer%2010"?

              ändere den datenpukt in allen zeilen - den dp musst du anlegen (number)

              0_userdata.0.Tests.htttpget-test --> hier schreibt er die Zeit dann rein?

              was ist das $tempi das auch in den DP schreibt?

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

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

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

              url musst du auch anpassen

              http://192.168.178.159/cm?cmnd=Dimmer%2010

              IP die vom ioB schätze ich?
              was ist das ""Dimmer%2010"?

              ändere den datenpukt in allen zeilen - den dp musst du anlegen (number)

              0_userdata.0.Tests.htttpget-test --> hier schreibt er die Zeit dann rein?

              was ist das $tempi das auch in den DP schreibt?

              das mit dem dimmer ist ein ansteuerung von einem tasmota mit leds dran - ich brauchte ws zum testen
              ja es wird die gesamtzeit reingeschrieben - den dp musst du anlegen - kann auch eine andere id haben wie bei meinem beispiel
              $tempi ist nur eine variable - die kannst du lassen

              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
              • HomoranH Homoran

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

                method: 'POST',

                @liv-in-sky ist dann wohl eher httpPost??

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

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

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

                method: 'POST',

                @liv-in-sky ist dann wohl eher httpPost??

                ir machen eher die ganzen settings sorgen, die man da für request braucht -

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

                da steige ich aus :-(

                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
                1
                • NegaleinN Negalein

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

                  script HP zum test
                  HP Script

                  Danke, läuft sofort ohne Fehler :)

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

                  @negalein

                  also - voll geschätzt - du musst axios in den zusätzlichen modulen in der javascriptinstanz haben !

                  versuche mal das - keine ahnung ob das auch nur ansatzweise funktioniert

                  user namen eintragen !

                  const axios = require('axios');
                  const qs = require('qs'); // Um die Daten für den POST-Request zu serialisieren
                  
                  const user = 'yourUsername'; // Benutzername hier einfügen
                  const pass = 'yourPassword'; // Passwort hier einfügen
                  
                  const optionsLogin = {
                   method: 'POST',
                   url: 'https://netservice.iqcard.at/de/login',
                   data: qs.stringify({
                     BENUID: user,
                     PASSWT: pass,
                     'login-form-submit': 'login'
                   }),
                   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'
                   },
                   maxRedirects: 5, // Anzahl der zu folgenden Redirects
                   withCredentials: true // für das Cookie-Handling
                  };
                  
                  const optionsPriceinfo = {
                   method: 'GET',
                   url: 'https://netservice.iqcard.at/de/netservice_preisinfo',
                   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'
                   },
                   maxRedirects: 5, // Anzahl der zu folgenden Redirects
                   withCredentials: true // für das Cookie-Handling
                  };
                  
                  // Anmeldung mit POST-Request
                  axios(optionsLogin)
                   .then(() => {
                     // Erfolgreiche Anmeldung, jetzt GET-Request für Preisinfo
                     return axios(optionsPriceinfo);
                   })
                   .then(response => {
                     // Verarbeitung der Antwort
                     const data = analyze(response.data);
                     log(data);
                     writeDatapoint(data);
                   })
                   .catch(error => {
                     console.error('Error making the request:', error);
                   });
                  
                  

                  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 sagte in Hilfe bei Skripte von request auf httpGet umbauen:

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

                    url musst du auch anpassen

                    http://192.168.178.159/cm?cmnd=Dimmer%2010

                    IP die vom ioB schätze ich?
                    was ist das ""Dimmer%2010"?

                    ändere den datenpukt in allen zeilen - den dp musst du anlegen (number)

                    0_userdata.0.Tests.htttpget-test --> hier schreibt er die Zeit dann rein?

                    was ist das $tempi das auch in den DP schreibt?

                    das mit dem dimmer ist ein ansteuerung von einem tasmota mit leds dran - ich brauchte ws zum testen
                    ja es wird die gesamtzeit reingeschrieben - den dp musst du anlegen - kann auch eine andere id haben wie bei meinem beispiel
                    $tempi ist nur eine variable - die kannst du lassen

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

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

                    das mit dem dimmer ist ein ansteuerung von einem tasmota mit leds dran

                    ok, nehm ich dann nur die ip vom ioB? Ohne hinten eas drann?
                    Oder muss da die vom VZ rein?

                    ° 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:

                      das mit dem dimmer ist ein ansteuerung von einem tasmota mit leds dran

                      ok, nehm ich dann nur die ip vom ioB? Ohne hinten eas drann?
                      Oder muss da die vom VZ rein?

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

                      @negalein

                      nene

                      du musst das

                      http://192.168.178.159/cm?cmnd=Dimmer%2010
                      

                      mit dem:

                      http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                      

                      ersetzen -

                      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

                        also - voll geschätzt - du musst axios in den zusätzlichen modulen in der javascriptinstanz haben !

                        versuche mal das - keine ahnung ob das auch nur ansatzweise funktioniert

                        user namen eintragen !

                        const axios = require('axios');
                        const qs = require('qs'); // Um die Daten für den POST-Request zu serialisieren
                        
                        const user = 'yourUsername'; // Benutzername hier einfügen
                        const pass = 'yourPassword'; // Passwort hier einfügen
                        
                        const optionsLogin = {
                         method: 'POST',
                         url: 'https://netservice.iqcard.at/de/login',
                         data: qs.stringify({
                           BENUID: user,
                           PASSWT: pass,
                           'login-form-submit': 'login'
                         }),
                         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'
                         },
                         maxRedirects: 5, // Anzahl der zu folgenden Redirects
                         withCredentials: true // für das Cookie-Handling
                        };
                        
                        const optionsPriceinfo = {
                         method: 'GET',
                         url: 'https://netservice.iqcard.at/de/netservice_preisinfo',
                         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'
                         },
                         maxRedirects: 5, // Anzahl der zu folgenden Redirects
                         withCredentials: true // für das Cookie-Handling
                        };
                        
                        // Anmeldung mit POST-Request
                        axios(optionsLogin)
                         .then(() => {
                           // Erfolgreiche Anmeldung, jetzt GET-Request für Preisinfo
                           return axios(optionsPriceinfo);
                         })
                         .then(response => {
                           // Verarbeitung der Antwort
                           const data = analyze(response.data);
                           log(data);
                           writeDatapoint(data);
                         })
                         .catch(error => {
                           console.error('Error making the request:', error);
                         });
                        
                        

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

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

                        versuche mal das

                        in welche DP schreibt das Script??
                        Im Original steht in 3. Zeile noch const dpPrices = "0_userdata.0.IQ_Sprit.IQ_Sprit";. Kann ich das so 1:1 ins Neue übernehmen?

                        ° 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
                        • liv-in-skyL liv-in-sky

                          @negalein

                          nene

                          du musst das

                          http://192.168.178.159/cm?cmnd=Dimmer%2010
                          

                          mit dem:

                          http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365
                          

                          ersetzen -

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

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

                          ersetzen

                          Ahh, gecheckt.

                          ° 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:

                            versuche mal das

                            in welche DP schreibt das Script??
                            Im Original steht in 3. Zeile noch const dpPrices = "0_userdata.0.IQ_Sprit.IQ_Sprit";. Kann ich das so 1:1 ins Neue übernehmen?

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

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

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

                            versuche mal das

                            in welche DP schreibt das Script??
                            Im Original steht in 3. Zeile noch const dpPrices = "0_userdata.0.IQ_Sprit.IQ_Sprit";. Kann ich das so 1:1 ins Neue übernehmen?

                            moment - ich muss noch was bei dem iq script ändern

                            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

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

                              ersetzen

                              Ahh, gecheckt.

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

                              @negalein

                              neuer versuch

                              der daten punkt ist ja im script definiert und sollte auch von dir angelegt sein (type text)

                              //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 axios = require('axios');
                              const cheerio = require("cheerio");
                              
                              let $;
                              async function main() {
                              
                              const optionsLogin = {
                               method: 'POST',
                               url: 'https://netservice.iqcard.at/de/login',
                               data: `BENUID=${user}&PASSWT=${pass}&login-form-submit=login`,
                               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'
                               },
                               maxRedirects: 5, // Anzahl der zu folgenden Redirects
                               withCredentials: true // für das Cookie-Handling
                              };
                              
                              const optionsPriceinfo = {
                               method: 'GET',
                               url: 'https://netservice.iqcard.at/de/netservice_preisinfo',
                               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'
                               },
                               maxRedirects: 5, // Anzahl der zu folgenden Redirects
                               withCredentials: true // für das Cookie-Handling
                              };
                              
                              // Anmeldung mit POST-Request
                              axios(optionsLogin)
                               .then(() => {
                                 // Erfolgreiche Anmeldung, jetzt GET-Request für Preisinfo
                                 return axios(optionsPriceinfo);
                               })
                               .then(response => {
                                 // Verarbeitung der Antwort
                                 const data = analyze(response.data);
                                 log(data);
                                 writeDatapoint(data);
                               })
                               .catch(error => {
                                 console.error('Error making the request:', error);
                               });
                              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();   
                              });
                              
                              

                              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
                              • LatziL Offline
                                LatziL Offline
                                Latzi
                                schrieb am zuletzt editiert von
                                #56

                                weiterer Ansatz zum IQ-Script:
                                IQ-Bash-Script

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

                                  @negalein

                                  neuer versuch

                                  der daten punkt ist ja im script definiert und sollte auch von dir angelegt sein (type text)

                                  //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 axios = require('axios');
                                  const cheerio = require("cheerio");
                                  
                                  let $;
                                  async function main() {
                                  
                                  const optionsLogin = {
                                   method: 'POST',
                                   url: 'https://netservice.iqcard.at/de/login',
                                   data: `BENUID=${user}&PASSWT=${pass}&login-form-submit=login`,
                                   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'
                                   },
                                   maxRedirects: 5, // Anzahl der zu folgenden Redirects
                                   withCredentials: true // für das Cookie-Handling
                                  };
                                  
                                  const optionsPriceinfo = {
                                   method: 'GET',
                                   url: 'https://netservice.iqcard.at/de/netservice_preisinfo',
                                   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'
                                   },
                                   maxRedirects: 5, // Anzahl der zu folgenden Redirects
                                   withCredentials: true // für das Cookie-Handling
                                  };
                                  
                                  // Anmeldung mit POST-Request
                                  axios(optionsLogin)
                                   .then(() => {
                                     // Erfolgreiche Anmeldung, jetzt GET-Request für Preisinfo
                                     return axios(optionsPriceinfo);
                                   })
                                   .then(response => {
                                     // Verarbeitung der Antwort
                                     const data = analyze(response.data);
                                     log(data);
                                     writeDatapoint(data);
                                   })
                                   .catch(error => {
                                     console.error('Error making the request:', error);
                                   });
                                  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();   
                                  });
                                  
                                  

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

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

                                  neuer versuch

                                  funktioniert leider nicht

                                  javascript.1
                                  2024-05-27 19:42:00.907	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                  
                                  javascript.1
                                  2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                  
                                  web.0
                                  2024-05-27 19:42:00.906	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                  
                                  web.0
                                  2024-05-27 19:42:00.906	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                  
                                  web.0
                                  2024-05-27 19:42:00.906	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                  
                                  web.0
                                  2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                  
                                  javascript.0
                                  2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                  
                                  javascript.0
                                  2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                  
                                  history.0
                                  2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                  
                                  history.0
                                  2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                  
                                  influxdb.2
                                  2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                  
                                  influxdb.2
                                  2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                  
                                  influxdb.0
                                  2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                  
                                  influxdb.0
                                  2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                  

                                  dc96e9c4-c535-42e9-a958-0f05c85dc0de-image.png

                                  ° 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
                                  • LatziL Latzi

                                    weiterer Ansatz zum IQ-Script:
                                    IQ-Bash-Script

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

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

                                    weiterer Ansatz zum IQ-Script:

                                    hast du das in Verwendung?

                                    Ist das ein normales JS?

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

                                    LatziL liv-in-skyL 2 Antworten Letzte Antwort
                                    0
                                    • NegaleinN Negalein

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

                                      weiterer Ansatz zum IQ-Script:

                                      hast du das in Verwendung?

                                      Ist das ein normales JS?

                                      LatziL Offline
                                      LatziL Offline
                                      Latzi
                                      schrieb am zuletzt editiert von
                                      #59

                                      @negalein
                                      Ja, das verwende ich.
                                      Nein, ist ein Bash-Script (so wie das Wetterstation-Script von SBORG), wird am Server ausgeführt

                                      1 Antwort Letzte Antwort
                                      0
                                      • NegaleinN Negalein

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

                                        neuer versuch

                                        funktioniert leider nicht

                                        javascript.1
                                        2024-05-27 19:42:00.907	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                        
                                        javascript.1
                                        2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                        
                                        web.0
                                        2024-05-27 19:42:00.906	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                        
                                        web.0
                                        2024-05-27 19:42:00.906	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                        
                                        web.0
                                        2024-05-27 19:42:00.906	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                        
                                        web.0
                                        2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                        
                                        javascript.0
                                        2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                        
                                        javascript.0
                                        2024-05-27 19:42:00.905	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                        
                                        history.0
                                        2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                        
                                        history.0
                                        2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                        
                                        influxdb.2
                                        2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                        
                                        influxdb.2
                                        2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                        
                                        influxdb.0
                                        2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Zeitraum.Zeitraum": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].date" => Cannot read properties of undefined (reading 'services')
                                        
                                        influxdb.0
                                        2024-05-27 19:42:00.904	error	Invalid read function for "alias.0.IQ-Sprit.Diesel.Preis.IQ_Sprit": "JSON.parse(val)['ÖSTERREICH'].services.Diesel[0].price" => Cannot read properties of undefined (reading 'services')
                                        

                                        dc96e9c4-c535-42e9-a958-0f05c85dc0de-image.png

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

                                        @negalein

                                        das sind keinen axios fehler - da ist ein problem mit dem datenpunkt

                                        du könntest mir deinenaccount geben und ich teste es mal bei mir - wenn ja,dann über chat

                                        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

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

                                          weiterer Ansatz zum IQ-Script:

                                          hast du das in Verwendung?

                                          Ist das ein normales JS?

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

                                          @negalein

                                          also : der zugriff funktioniert, aber das auslesen kann nicht funktionieren - weißt du noch, wo du das script her hast - und lief das schon mal ?

                                          das script von @latzi verstehe ich un dkann es auch nachvollziehen - dein script schau ich mir morgen früh nochmal an

                                          der unterschied ist der - dein script versucht die linken daten zu bekommen (was nicht wirklich funktioniert, weil das über ein internes script angezeigt wird

                                          das von latzi liest die rechten werte aus (schwarzer hintergrund)

                                          Image 001.png

                                          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

                                          LatziL 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

                                          372

                                          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