- ioBroker Community Home
- Deutsch
- Skripten / Logik
- JavaScript
- Hilfe bei Skripte von request auf httpGet umbauen
NEWS
Hilfe bei Skripte von request auf httpGet umbauen
-
das Fronius-Script läuft alle 10 Minuten.
Hab das jetzt mal deaktiviert.
Mal beobachten.° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
@negalein sagte in Hilfe bei Skripte von request auf httpGet umbauen:
Server hat noch sehr viel Luft frei.
Der Traffic läuft aber auch über Switches und Router, ggf. noch über APs
@homoran sagte in Hilfe bei Skripte von request auf httpGet umbauen:
Der Traffic läuft aber auch über Switches und Router, ggf. noch über APs
Jep, aber auch da gibts keine Probleme.
Alles andere läuft (mit zT kürzeren Abfragen).° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
@homoran sagte in Hilfe bei Skripte von request auf httpGet umbauen:
Der Traffic läuft aber auch über Switches und Router, ggf. noch über APs
Jep, aber auch da gibts keine Probleme.
Alles andere läuft (mit zT kürzeren Abfragen).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

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

@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%2010IP 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
$tempidas auch in den DP schreibt?° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
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@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
script HP zum test
HP ScriptDanke, 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-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
url musst du auch anpassen
http://192.168.178.159/cm?cmnd=Dimmer%2010IP 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
$tempidas auch in den DP schreibt?@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%2010IP 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
$tempidas 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 lassennach 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 sagte in Hilfe bei Skripte von request auf httpGet umbauen:
method: 'POST',
@liv-in-sky ist dann wohl eher httpPost??
@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
-
@liv-in-sky sagte in Hilfe bei Skripte von request auf httpGet umbauen:
script HP zum test
HP ScriptDanke, läuft sofort ohne Fehler :)
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
-
@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%2010IP 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
$tempidas 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@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-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?nene
du musst das
http://192.168.178.159/cm?cmnd=Dimmer%2010mit dem:
http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365ersetzen -
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
-
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); });@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 nochconst 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 -
nene
du musst das
http://192.168.178.159/cm?cmnd=Dimmer%2010mit dem:
http://10.0.1.93/middleware.php/data.json?from=now&uuid[]=bc3edcd0-24c4-11ea-b257-bdbd9553c516&uuid[]=deda8550-24c4-11ea-b402-275ee0956365ersetzen -
° 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:
versuche mal das
in welche DP schreibt das Script??
Im Original steht in 3. Zeile nochconst dpPrices = "0_userdata.0.IQ_Sprit.IQ_Sprit";. Kann ich das so 1:1 ins Neue übernehmen?@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 nochconst 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
-
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
-
weiterer Ansatz zum IQ-Script:
IQ-Bash-Script -
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(); });@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')
° Node.js: 20.17.0 NPM: 10.8.2
° Proxmox, Ubuntu 22.04.3 LTS
° Fixer ---> iob fix -
weiterer Ansatz zum IQ-Script:
IQ-Bash-Script@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