- ioBroker Community Home
- Deutsch
- Skripten / Logik
- JavaScript
- Hilfe bei Skripte von request auf httpGet umbauen
NEWS
Hilfe bei Skripte von request auf httpGet umbauen
-
bei meinem script habe ich den timeout auf 3000 gesetzt - teste mal das evtl mit 4000
aber dann macht eine 2-sekunden abfrage keinen sinn - dass müßte dann angeglichen werden - z.b. abfrage alle 5 sek
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
bei meinem script habe ich den timeout auf 3000 gesetzt - teste mal das evtl mit 4000
Danke dir.
Meldungen sind weg. Den Schedule hab ich auf 10 erhöht.Könntest du bei den anderen auch noch helfen?
° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
//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 functionvar logging = true; var debugging = false; var debugging_response = false; //nur im Fehlerfall auf true. Hiermit wird die Antwort der Internetadresse protokolliert var CCU_Version = 3; //Hier eine Zahl eintragen: 2 = CCU2 // 3 = CCU3 // 4 = Rasperrymatic //Datenpunkt auswählen wo die installierte Version ersichtlich ist (aus Homematic.Rega Adapter) const id_Version_installiert = "hm-rega.0.QEQ1301545.0.FIRMWARE_VERSION"; //Datenpunkt muss manuell angelegt werden. Kann irgendwo angelegt werden. Anschließend hier ersetzen const id_Version_Internet = '0_userdata.0.CCU3.Servicemeldungen.Verfuegbare_CCU-Firmware'; const id_Update_Internet = '0_userdata.0.CCU3.Servicemeldungen.Update_verfuegbar'; var observation = true; //Dauerhafte Überwachung der Firmware (true = aktiv // false =inaktiv) var onetime = true; //Prüft beim Scriptstart auf aktuelle Firmware //Prio für Pushover var prio_Firmware = 0; //Variablen für Pushover var sendpush = false; //true = verschickt per Pushover Nachrchten // false = Pushover wird nicht benutzt var pushover_Instanz0 = 'pushover.0'; // Pushover instance für Pio = 0 var pushover_Instanz1 = 'pushover.1'; // Pushover instance für Pio = 1 var pushover_Instanz2 = 'pushover.2'; // Pushover instance für Pio = 2 var pushover_Instanz3 = 'pushover.3'; // Pushover instance für Pio = -1 oder -2 let _prio; let _titel; let _message; var _device = 'TPhone'; //Welches Gerät soll die Nachricht bekommen //var _device = 'All'; //Variablen für Telegram var sendtelegram = true; //true = verschickt per Telegram Nachrchten // false = Telegram wird nicht benutzt var user_telegram = ''; //User der die Nachricht bekommen soll //Variable zum verschicken der Servicemeldungen per eMail var sendmail = false; //true = verschickt per email Nachrchten // false = email wird nicht benutzt // ab hier keine Änderung let _message_tmp; var request = require('request'); function send_pushover_V4 (_device, _message, _titel, _prio) { if (_prio === 0){let pushover_Instanz = pushover_Instanz0} else if (_prio == 1){pushover_Instanz = pushover_Instanz1} else if (_prio == 2){pushover_Instanz = pushover_Instanz2} else {pushover_Instanz = pushover_Instanz3} sendTo(pushover_Instanz, { device: _device, message: _message, title: _titel, priority: _prio, retry: 60, expire: 600, html: 1 }); } function send_telegram (_message, user_telegram) { sendTo('telegram.0', { text: _message, user: user_telegram, parse_mode: 'HTML' }); } function send_mail (_message) { sendTo("email", { //from: "iobroker@mydomain.com", //to: "aabbcc@gmail.com", subject: "Servicemeldung", text: _message }); } function func_Version(){ var Version_Internet = getState(id_Version_Internet).val; var ccu2 = 'http://update.homematic.com/firmware/download?cmd=js_check_version&version=12345&product=HM-CCU2&serial=12345'; var ccu3 = 'http://update.homematic.com/firmware/download?cmd=js_check_version&version=12345&product=HM-CCU3&serial=9A499D4429'; var Raspi = 'https://gitcdn.xyz/repo/jens-maus/RaspberryMatic/master/release/LATEST-VERSION.js?_version_=CURRENT_VERSION'; let ccu; if(CCU_Version == 3){ccu = ccu3;} else if(CCU_Version == 4){ccu = Raspi;} else {ccu = ccu2;} url = ccu; request({url : url}, function (error, response, body) { var Version_installiert = (getState(id_Version_installiert).val).trim(); var Version = body.split("'"); if(error){ log('error: ' + error); } else { if(Version_Internet === ''){ if(logging){ log('ausgewähltes Objekt leer. Firmware wird erstmalig gesetzt.'); } setState(id_Version_Internet,Version[1]); } if(Version_installiert == Version[1]){ setState(id_Update_Internet,false); if(logging){ log('Installierte Firmware '+Version_installiert +' der CCU ist aktuell'); } } else{ setState(id_Update_Internet,true); if(logging){ log('Installierte Firmware '+Version_installiert +' der CCU ist nicht aktuell. Aktuell verfügbare Version: '+Version[1]); } if(Version_Internet == Version[1]){ if(debugging){ log('[DEBUG] ' +'Version Internet hat sich nicht verändert'); } } else { if(debugging){ log('[DEBUG] ' +'Installierte Firmware der CCU ist nicht aktuell.'); } setState(id_Version_Internet,Version[1]); _message_tmp = 'Installierte Firmware der CCU ist nicht aktuell. Installiert: ' +Version_installiert +' --- Verfügbare Version: '+Version[1]; //Push verschicken if(sendpush){ _prio = prio_Firmware; _titel = 'CCU-Firmware'; _message = _message_tmp; send_pushover_V4(_device, _message, _titel, _prio); } if(sendtelegram){ _message = _message_tmp; send_telegram(_message, user_telegram); } if(sendmail){ _message = _message_tmp; send_mail(_message); } } } if(debugging_response){ log('body: ' + body); log('Länge ' + Version.length + ' --- Version: ' + Version[1]); log('response: ' + JSON.stringify(response)); } } } ); } if(observation){ //Nachts einmalig ausführen 00:30 Schaltzeiten berechnen schedule("54 05 * * *", func_Version); } if(onetime){ //beim Starten func_Version(); }var request = require("request"); var myJson = {}; var pfad = "Fronius_Symo_Hybrid_Max."; //var idDAY_ENERGY = pfad + "ENERGY_DAY"; var idPAC = pfad + "PAC"; var idYEAR_ENERGY = pfad + "ENERGY_YEAR"; var idTOTAL_ENERGY = pfad + "ENERGY_TOTAL"; //createState(idDAY_ENERGY, 0, { // name: 'Energie Tag', // desc: 'Energie Tag', // type: 'number', // role: 'value', // unit: 'Wh' //}); createState(idPAC, 0, { name: 'Leistung', desc: 'Leistung', type: 'number', role: 'value', unit: 'W' }); createState(idYEAR_ENERGY, 0, { name: 'Energie Jahr', desc: 'Energie Jahr', type: 'number', role: 'value', unit: 'Wh' }); createState(idTOTAL_ENERGY, 0, { name: 'Energie Total', desc: 'Energie Total', type: 'number', role: 'value', unit: 'Wh' }); function parseJson(text) { if (text === "") return {}; try { json = JSON.parse(text); } catch (ex) { json = {}; } if(!json) json = {}; return json; } function readJson(url, callback) { request(url, function (err, state, body){ if (body) { var json = parseJson(body); callback(null, json); } else { var error = "(" + err + ") ERROR bei Abfrage von: " + url; log(error, "warn"); callback(error, null); } }); } var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System'; function main() { readJson(url, function(err,json) { if(!err) { myJson = json; // log("DAY_ENERGY: " + myJson.Body.Data.DAY_ENERGY.Values[1],"info"); log("PAC: " + myJson.Body.Data.PAC.Values[1],"info"); log("YEAR_ENERGY: " + myJson.Body.Data.YEAR_ENERGY.Values[1],"info"); log("TOTAL_ENERGY: " + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info"); // setState(idDAY_ENERGY ,myJson.Body.Data.DAY_ENERGY.Values[1]); setState(idPAC ,myJson.Body.Data.PAC.Values[1]); setState(idYEAR_ENERGY ,myJson.Body.Data.YEAR_ENERGY.Values[1]); setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]); } else { log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn"); myJson = {}; } }); } schedule("*/10 * * * * *", function () { // alle 10 Sekunden die Werte abfragen main(); }); // Beim Skriptstart die Werte abfragen setTimeout(main,500);var request = require("request"); var myJson = {}; var pfad = "Fronius_Symo_Hybrid_Max."; var idDAY_ENERGY = pfad + "ENERGY_DAY"; //var idPAC = pfad + "PAC"; //var idYEAR_ENERGY = pfad + "ENERGY_YEAR"; //var idTOTAL_ENERGY = pfad + "ENERGY_TOTAL"; createState(idDAY_ENERGY, 0, { name: 'Energie Tag', desc: 'Energie Tag', type: 'number', role: 'value', unit: 'Wh' }); //createState(idPAC, 0, { // name: 'Leistung', // desc: 'Leistung', // type: 'number', // role: 'value', // unit: 'W' //}); //createState(idYEAR_ENERGY, 0, { // name: 'Energie Jahr', // desc: 'Energie Jahr', // type: 'number', // role: 'value', // unit: 'Wh' //}); //createState(idTOTAL_ENERGY, 0, { // name: 'Energie Total', // desc: 'Energie Total', // type: 'number', // role: 'value', // unit: 'Wh' //}); function parseJson(text) { if (text === "") return {}; try { json = JSON.parse(text); } catch (ex) { json = {}; } if(!json) json = {}; return json; } function readJson(url, callback) { request(url, function (err, state, body){ if (body) { var json = parseJson(body); callback(null, json); } else { var error = "(" + err + ") ERROR bei Abfrage von: " + url; log(error, "warn"); callback(error, null); } }); } var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System'; function main() { readJson(url, function(err,json) { if(!err) { myJson = json; log("DAY_ENERGY: " + myJson.Body.Data.DAY_ENERGY.Values[1],"info"); // log("PAC: " + myJson.Body.Data.PAC.Values[1],"info"); // log("YEAR_ENERGY: " + myJson.Body.Data.YEAR_ENERGY.Values[1],"info"); // log("TOTAL_ENERGY: " + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info"); setState(idDAY_ENERGY ,myJson.Body.Data.DAY_ENERGY.Values[1]); // setState(idPAC ,myJson.Body.Data.PAC.Values[1]); // setState(idYEAR_ENERGY ,myJson.Body.Data.YEAR_ENERGY.Values[1]); // setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]); } else { log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn"); myJson = {}; } }); } schedule("59 23 * * *", function () { // täglich um 23 Uhr 59 Minuten main(); }); // Beim Skriptstart die Werte abfragen setTimeout(main,500);° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
//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 functionvar 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);Muss jetzt dann weg
Komme Mittag wieder, wenn sich kein anderer findet, sehe ich mir das annach 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
-
Muss jetzt dann weg
Komme Mittag wieder, wenn sich kein anderer findet, sehe ich mir das an@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
Komme Mittag wieder, wenn sich kein anderer findet, sehe ich mir das an
Danke :hugging_face:
° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
Komme Mittag wieder, wenn sich kein anderer findet, sehe ich mir das an
Danke :hugging_face:
die fronius scripte könntest du evtl selbst probieren - die sind ähnlich, wie das , was wir gerade gemacht hatten
nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html
-
die fronius scripte könntest du evtl selbst probieren - die sind ähnlich, wie das , was wir gerade gemacht hatten
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
die fronius scripte könntest du evtl selbst probieren - die sind ähnlich, wie das , was wir gerade gemacht hatten
würde es so funktionieren?
//var request = require("request"); var myJson = {}; var pfad = "Fronius_Symo_Hybrid_Max."; //var idDAY_ENERGY = pfad + "ENERGY_DAY"; var idPAC = pfad + "PAC"; var idYEAR_ENERGY = pfad + "ENERGY_YEAR"; var idTOTAL_ENERGY = pfad + "ENERGY_TOTAL"; //createState(idDAY_ENERGY, 0, { // name: 'Energie Tag', // desc: 'Energie Tag', // type: 'number', // role: 'value', // unit: 'Wh' //}); createState(idPAC, 0, { name: 'Leistung', desc: 'Leistung', type: 'number', role: 'value', unit: 'W' }); createState(idYEAR_ENERGY, 0, { name: 'Energie Jahr', desc: 'Energie Jahr', type: 'number', role: 'value', unit: 'Wh' }); createState(idTOTAL_ENERGY, 0, { name: 'Energie Total', desc: 'Energie Total', type: 'number', role: 'value', unit: 'Wh' }); function parseJson(text) { if (text === "") return {}; try { json = JSON.parse(text); } catch (ex) { json = {}; } if(!json) json = {}; return json; } function readJson(url, callback) { httpGet(url, { timeout: 3000, responseType: 'text' },function(err,response) { const body=response.data; var json = parseJson(body); callback(null, json); } else { var error = "(" + err + ") ERROR bei Abfrage von: " + url; log(error, "warn"); callback(error, null); } }); } var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System'; function main() { readJson(url, function(err,json) { if(!err) { myJson = json; // log("DAY_ENERGY: " + myJson.Body.Data.DAY_ENERGY.Values[1],"info"); log("PAC: " + myJson.Body.Data.PAC.Values[1],"info"); log("YEAR_ENERGY: " + myJson.Body.Data.YEAR_ENERGY.Values[1],"info"); log("TOTAL_ENERGY: " + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info"); // setState(idDAY_ENERGY ,myJson.Body.Data.DAY_ENERGY.Values[1]); setState(idPAC ,myJson.Body.Data.PAC.Values[1]); setState(idYEAR_ENERGY ,myJson.Body.Data.YEAR_ENERGY.Values[1]); setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]); } else { log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn"); myJson = {}; } }); } schedule("*/10 * * * * *", function () { // alle 10 Sekunden die Werte abfragen main(); }); // Beim Skriptstart die Werte abfragen setTimeout(main,500);var request = require("request");geändert in
//var request = require("request");und
request(url, function (err, state, body){ if (body) {ersetz durch
httpGet(url, { timeout: 3000, responseType: 'text' },function(err,response) { const body=response.data;° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
die fronius scripte könntest du evtl selbst probieren - die sind ähnlich, wie das , was wir gerade gemacht hatten
würde es so funktionieren?
//var request = require("request"); var myJson = {}; var pfad = "Fronius_Symo_Hybrid_Max."; //var idDAY_ENERGY = pfad + "ENERGY_DAY"; var idPAC = pfad + "PAC"; var idYEAR_ENERGY = pfad + "ENERGY_YEAR"; var idTOTAL_ENERGY = pfad + "ENERGY_TOTAL"; //createState(idDAY_ENERGY, 0, { // name: 'Energie Tag', // desc: 'Energie Tag', // type: 'number', // role: 'value', // unit: 'Wh' //}); createState(idPAC, 0, { name: 'Leistung', desc: 'Leistung', type: 'number', role: 'value', unit: 'W' }); createState(idYEAR_ENERGY, 0, { name: 'Energie Jahr', desc: 'Energie Jahr', type: 'number', role: 'value', unit: 'Wh' }); createState(idTOTAL_ENERGY, 0, { name: 'Energie Total', desc: 'Energie Total', type: 'number', role: 'value', unit: 'Wh' }); function parseJson(text) { if (text === "") return {}; try { json = JSON.parse(text); } catch (ex) { json = {}; } if(!json) json = {}; return json; } function readJson(url, callback) { httpGet(url, { timeout: 3000, responseType: 'text' },function(err,response) { const body=response.data; var json = parseJson(body); callback(null, json); } else { var error = "(" + err + ") ERROR bei Abfrage von: " + url; log(error, "warn"); callback(error, null); } }); } var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System'; function main() { readJson(url, function(err,json) { if(!err) { myJson = json; // log("DAY_ENERGY: " + myJson.Body.Data.DAY_ENERGY.Values[1],"info"); log("PAC: " + myJson.Body.Data.PAC.Values[1],"info"); log("YEAR_ENERGY: " + myJson.Body.Data.YEAR_ENERGY.Values[1],"info"); log("TOTAL_ENERGY: " + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info"); // setState(idDAY_ENERGY ,myJson.Body.Data.DAY_ENERGY.Values[1]); setState(idPAC ,myJson.Body.Data.PAC.Values[1]); setState(idYEAR_ENERGY ,myJson.Body.Data.YEAR_ENERGY.Values[1]); setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]); } else { log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn"); myJson = {}; } }); } schedule("*/10 * * * * *", function () { // alle 10 Sekunden die Werte abfragen main(); }); // Beim Skriptstart die Werte abfragen setTimeout(main,500);var request = require("request");geändert in
//var request = require("request");und
request(url, function (err, state, body){ if (body) {ersetz durch
httpGet(url, { timeout: 3000, responseType: 'text' },function(err,response) { const body=response.data;@negalein sagte: ersetz durch
Besser:httpGet(url, { timeout: 3000, responseType: 'text' }, function(err, response) { if(!err) { const body = response.data;Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs -
@negalein sagte: ersetz durch
Besser:httpGet(url, { timeout: 3000, responseType: 'text' }, function(err, response) { if(!err) { const body = response.data;° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
bei dem "Volkszähler-Script" bin ich jetzt schon mit dem Timeout auf 10000 rauf.
Trotzdem kommt immer wieder die Warn-Meldung.Kann man diese Warn-Meldung unterdrücken?
Oder besser mit dem Timeout testen, bis die Meldung nicht mehr kommt?° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
bei dem "Volkszähler-Script" bin ich jetzt schon mit dem Timeout auf 10000 rauf.
Trotzdem kommt immer wieder die Warn-Meldung.Kann man diese Warn-Meldung unterdrücken?
Oder besser mit dem Timeout testen, bis die Meldung nicht mehr kommt?@negalein bei einem timeout von 10 sekunden denke ich, dass es evtl ein andres problem gibt - eigentlich sind 2000-4000 schon zu lange -
kannst du mal den volkszähler neustarten - ansonsten fällt mir gerade nix dazu ein
kommt der fehler immer? wenn ja, funktioniert es ein paarmal und ab einem zeitpunkt dann nicht mehr - oder funktioniert es immer wieder mal ?
nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html
-
@negalein bei einem timeout von 10 sekunden denke ich, dass es evtl ein andres problem gibt - eigentlich sind 2000-4000 schon zu lange -
kannst du mal den volkszähler neustarten - ansonsten fällt mir gerade nix dazu ein
kommt der fehler immer? wenn ja, funktioniert es ein paarmal und ab einem zeitpunkt dann nicht mehr - oder funktioniert es immer wieder mal ?
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
eigentlich sind 2000-4000 schon zu lange -
ehrlich?
ich hatte mit dem Wiffi bei 2000 auch einige timeout exceeded, nach Erhöhung auf 4000 bisher keinen einzigen mehr.
Später hab ich gesehen, dass im Originalskript 3000 msec timeout eingestellt waren.ich denke dass es u.a. auch auf das Netzwerk und das angesprochene Gerät ankommt.
Beim Wiffi ist WLAN und ESP im Spiel.kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.
Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -
-
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
eigentlich sind 2000-4000 schon zu lange -
ehrlich?
ich hatte mit dem Wiffi bei 2000 auch einige timeout exceeded, nach Erhöhung auf 4000 bisher keinen einzigen mehr.
Später hab ich gesehen, dass im Originalskript 3000 msec timeout eingestellt waren.ich denke dass es u.a. auch auf das Netzwerk und das angesprochene Gerät ankommt.
Beim Wiffi ist WLAN und ESP im Spiel.ja ehrlich - ein device , dass solange braucht ist seltsam
wobei ich auch bei den sonoffs mit httpget immer auf 4000 gehe, da ich sonst fehler habe -
ich bin mir nicht sicher, ob diese 2000 wirklich 2 sekunden reine abfrage sind oder ob das irgendwie mehr beinhaltet
selbst das auslesen eines unifi controllers mit massig daten dauert keine 2 sekunden (wenn das netwerk in ordnung ist)
nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html
-
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
eigentlich sind 2000-4000 schon zu lange -
ehrlich?
ich hatte mit dem Wiffi bei 2000 auch einige timeout exceeded, nach Erhöhung auf 4000 bisher keinen einzigen mehr.
Später hab ich gesehen, dass im Originalskript 3000 msec timeout eingestellt waren.ich denke dass es u.a. auch auf das Netzwerk und das angesprochene Gerät ankommt.
Beim Wiffi ist WLAN und ESP im Spiel.@homoran sagte in Hilfe bei Skripte von request auf httpGet umbauen:
WLAN und ESP i
das vermute ich auch - da ist aber dann die frage, ob es mit dem alten request auch immer zu fehlern gekommen ist (das script war auf "alle 2 sekunde abfrage" gestellt
nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html
-
ja ehrlich - ein device , dass solange braucht ist seltsam
wobei ich auch bei den sonoffs mit httpget immer auf 4000 gehe, da ich sonst fehler habe -
ich bin mir nicht sicher, ob diese 2000 wirklich 2 sekunden reine abfrage sind oder ob das irgendwie mehr beinhaltet
selbst das auslesen eines unifi controllers mit massig daten dauert keine 2 sekunden (wenn das netwerk in ordnung ist)
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
ich bin mir nicht sicher, ob diese 2000 wirklich 2 sekunden reine abfrage sind oder ob das irgendwie mehr beinhaltet
// `timeout` specifies the number of milliseconds before the request times out. // If the request takes longer than `timeout`, the request will be aborted.Was meinst Du mit "reine Abfrage"? Es geht einfach um die Zeit, in welcher auf eine Antwort vom Server gewartet wird. 2 Sekunden ist ja schon eine Ewigkeit.
🧑🎓 Autor des beliebten ioBroker-Master-Kurses
🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
📚 Meine inoffizielle ioBroker Dokumentation -
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
ich bin mir nicht sicher, ob diese 2000 wirklich 2 sekunden reine abfrage sind oder ob das irgendwie mehr beinhaltet
// `timeout` specifies the number of milliseconds before the request times out. // If the request takes longer than `timeout`, the request will be aborted.Was meinst Du mit "reine Abfrage"? Es geht einfach um die Zeit, in welcher auf eine Antwort vom Server gewartet wird. 2 Sekunden ist ja schon eine Ewigkeit.
@haus-automatisierung das dachte ich auch - aber irgendwie sind doch diese zeiten zu lange - was war den ein timeout bei dem request ? weißt du das
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
-
@negalein bei einem timeout von 10 sekunden denke ich, dass es evtl ein andres problem gibt - eigentlich sind 2000-4000 schon zu lange -
kannst du mal den volkszähler neustarten - ansonsten fällt mir gerade nix dazu ein
kommt der fehler immer? wenn ja, funktioniert es ein paarmal und ab einem zeitpunkt dann nicht mehr - oder funktioniert es immer wieder mal ?
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
kommt der fehler immer? wenn ja, funktioniert es ein paarmal und ab einem zeitpunkt dann nicht mehr - oder funktioniert es immer wieder mal ?
alle 10 Minuten. Und zur vollen Stunde 1x in 1 Minute.
wenn es so bleibt, kann ich mit den 336 Warns in 24 Std. leben! :grin:
Werde den Timeout mal etwas runtersetzen und beobachten.
kannst du mal den volkszähler neustarten
schon gdemacht, ohne Auswirkung
@homoran sagte in Hilfe bei Skripte von request auf httpGet umbauen:
ich denke dass es u.a. auch auf das Netzwerk und das angesprochene Gerät ankommt.
Der Pi hängt mit LAN im Netz.
Meldungen kommen erst seit httpGet.@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
das vermute ich auch - da ist aber dann die frage, ob es mit dem alten request auch immer zu fehlern gekommen ist (das script war auf "alle 2 sekunde abfrage" gestellt
siehe oben
° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
//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 functionvar 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);bitte testen CCu3 script
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;} let url = ccu; // request({url : url}, httpGet(url, function (error, response) { var Version_installiert = (getState(id_Version_installiert).val).trim(); var Version = response.data.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: ' + response.data); log('Länge ' + Version.length + ' --- Version: ' + Version[1]); log('response: ' + JSON.stringify(response.data)); } } } ); } if(observation){ //Nachts einmalig ausführen 00:30 Schaltzeiten berechnen schedule("54 05 * * *", func_Version); } if(onetime){ //beim Starten func_Version(); }nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html
-
@haus-automatisierung das dachte ich auch - aber irgendwie sind doch diese zeiten zu lange - was war den ein timeout bei dem request ? weißt du das
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
aber irgendwie sind doch diese zeiten zu lange
Kannst Du ja mal mit curl o.ä. messen wie lange die Antwort dauert. Default bei
requestwar glaube ich0. Aber alleine für die asynchronen Funktionen (mit Promises) muss ich ja einen default Timeout angeben, da sonst ein Script ggf. "für immer" hängen bleibt und wartet.🧑🎓 Autor des beliebten ioBroker-Master-Kurses
🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
📚 Meine inoffizielle ioBroker Dokumentation -
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
kommt der fehler immer? wenn ja, funktioniert es ein paarmal und ab einem zeitpunkt dann nicht mehr - oder funktioniert es immer wieder mal ?
alle 10 Minuten. Und zur vollen Stunde 1x in 1 Minute.
wenn es so bleibt, kann ich mit den 336 Warns in 24 Std. leben! :grin:
Werde den Timeout mal etwas runtersetzen und beobachten.
kannst du mal den volkszähler neustarten
schon gdemacht, ohne Auswirkung
@homoran sagte in Hilfe bei Skripte von request auf httpGet umbauen:
ich denke dass es u.a. auch auf das Netzwerk und das angesprochene Gerät ankommt.
Der Pi hängt mit LAN im Netz.
Meldungen kommen erst seit httpGet.@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
das vermute ich auch - da ist aber dann die frage, ob es mit dem alten request auch immer zu fehlern gekommen ist (das script war auf "alle 2 sekunde abfrage" gestellt
siehe oben
@negalein sagte in Hilfe bei Skripte von request auf httpGet umbauen:
Der Pi hängt mit LAN im Netz.
Meldungen kommen erst seit httpGet.wenn das vorher lief und jetzt nicht - was könnte das sein - leider keine ahnung
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
-
bitte testen CCu3 script
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;} let url = ccu; // request({url : url}, httpGet(url, function (error, response) { var Version_installiert = (getState(id_Version_installiert).val).trim(); var Version = response.data.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: ' + response.data); log('Länge ' + Version.length + ' --- Version: ' + Version[1]); log('response: ' + JSON.stringify(response.data)); } } } ); } if(observation){ //Nachts einmalig ausführen 00:30 Schaltzeiten berechnen schedule("54 05 * * *", func_Version); } if(onetime){ //beim Starten func_Version(); }@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
bitte testen CCu3 script
Danke, perfekt.
Infos wurden sofort ausgelesen.° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix