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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. [Gelöst] Pi-Hole Daten auslesen

NEWS

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

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

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

[Gelöst] Pi-Hole Daten auslesen

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
47 Beiträge 13 Kommentatoren 13.4k Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • chucky666C Online
    chucky666C Online
    chucky666
    schrieb am zuletzt editiert von
    #41

    Hallo

    Wird hier noch weiterentwickelt?

    Gruß

    Gesendet von iPad mit Tapatalk Pro

    P 1 Antwort Letzte Antwort
    0
    • chucky666C chucky666

      Hallo

      Wird hier noch weiterentwickelt?

      Gruß

      Gesendet von iPad mit Tapatalk Pro

      P Offline
      P Offline
      pix
      schrieb am zuletzt editiert von
      #42

      Hallo,

      seit der neuen Version von pi-hole (glaube, v5) passt mein Skript nicht mehr so ganz. Habe einige Anpassungen gemacht. Bitte nicht einfach copy/paste und loslegen, da auch individuelle Anpassungen nötig sind (Pfad, influxDB, IP des pihole)

      Wer das alte Skript noch hat und nicht oder zusätzlich den Pi-Hole-Adapter nutzt, kann hier die Korrekturen für die neuen RegEx-Abfragen finden. Die Muster mussten angepasst werden, da die Weboberfläche der neuesten Pi-Hole Version einen anderen Quellcode hat. Wer keine Infos mehr parsen will, kann hier auch aufhören zu lesen :)

      /* Pi-hole
      pi-hole JSON Leser und Statusseiten Parser
      InfluxDB Vorbereitung
      
      23.04.2017 von Pix erstellt
      28.05.2017 let tabelle umgestellt
      31.05.2017 forceCreation und common/influx
      11.02.2018 Parse Temperatur, LOAD, Mem, Aktivitität; jeweils mit Farbe
                Code optimiert
                Ablauf optimiert
      26.02.2018 Update der Serversoftware wird abgefragt
      01.03.2018 Muster zur Temperaturerkennung optimiert
      17.07.2020 Anpassung RegExp, da Pi-Hole Adminkonsole neuen Quelltext hat
                
      todo: Reaktionen mit Optin und telegram bei Serverausfall, Temperatur zu hoch, etc.           
           Farben korrekt einlesen (wenn überhaupt noch nötig)
           Update bereit Mitteilung korrekt auslesen (jetzt über API nicht mehr über Web)
      */
      
      const fC = false; // forceCreation
      const logging = true;
      const pfad = ".Pi-hole.";
      const zeitplan = "*/5 * * * *"; // alle 5 Minuten
      const zeitplan_parse = "*/1 * * * *"; // minütlich
      const ip_pihole = "192.xxx.xxx.xxx"; // <------ IP des PI-Hole
      
      
      // #############################################################################
      // ab hier nix mehr ändern
      
      const url = "http://" + ip_pihole + "/admin/api.php";
      const url_parse = "http://" + ip_pihole + "/admin/index.php";
      
      // Instanz des Javascript-Adapters ermitteln
      let instanz = "javascript." + instance;
      if (logging) log(instanz);
      
      // ID definieren
      const idJSON             = instanz + pfad + "JSON",
           idDomains          = instanz + pfad + "Domains_blocked",
           idDNSQueries       = instanz + pfad + "DNS_queries",
           idAdsBlocked       = instanz + pfad + "Ads_blocked",
           idAdsPercentage    = instanz + pfad + "Ads_percentage",
           idActive           = instanz + pfad + "aktiv",
           idTemp             = instanz + pfad + "Temperatur",
           idTempFarbe        = instanz + pfad + "Farbe.Temperatur",
           idMemory           = instanz + pfad + "Speicher",
           idMemoryFarbe      = instanz + pfad + "Farbe.Speicher",
           idVersionFTL       = instanz + pfad + "Version.FTL",
           idVersionPihole    = instanz + pfad + "Version.Pihole",
           idVersionInterface = instanz + pfad + "Version.Interface",
           idLoad             = instanz + pfad + "Load",
           idLoadFarbe        = instanz + pfad + "Farbe.Load",
           idAktiv            = instanz + pfad + "aktiv_parse",
           idAktivFarbe       = instanz + pfad + "Farbe.aktiv_parse",
           idTabelle          = instanz + pfad + "Tabelle",
           idUpdate           = instanz + pfad + "Update";
      
      // States erstellen
      createState(idJSON, "", fC, {
         name: "JSON Datei vom Pi-hole Server",
         desc: "Kopie der JSON Datei",
         type: "string",
         read: true,
         write: true,
         role: "json",
         custom: {
             "influxdb.0": {
                 "enabled": false,
                 "changesOnly": false,
                 "debounce": "",
                 "retention": 657000 // 1 Monat
             }
         }
      });
      createState(idDomains, 0, fC, {
         name: "Pi-hole Domains blocked today", 
         desc: "Heute blockierte Domains (API)",
         type: "number", 
         def:  0,
         read: true,
         write: true,
         role: "value",
         custom: {
             "influxdb.0": {
                 "enabled": true,
                 "changesOnly": true,
                 "debounce": "",
                 "retention": 657000 // 1 Monat
             }
         }
      });
      createState(idDNSQueries, 0, fC, {
         name: "Pi-hole DNS Queries today", 
         desc: "Heutige DOmain Name Server Anfragen (API)",
         type: "number", 
         def:  0,
         read: true,
         write: true,
         role: "value",
         custom: {
             "influxdb.0": {
                 "enabled": true,
                 "changesOnly": true,
                 "debounce": "",
                 "retention": 657000 // 1 Monat
             }
         }
      });
      createState(idAdsBlocked, 0, fC, {
         name: "Pi-hole Ads blocked today", 
         desc: "Heute blockierte Werbungen (API)",
         type: "number", 
         def:  0,
         read: true,
         write: true,
         role: "value",
         custom: {
             "influxdb.0": {
                 "enabled": true,
                 "changesOnly": true,
                 "debounce": "",
                 "retention": 657000 // 1 Monat
             }
         }
      });
      createState(idAdsPercentage, 0, fC, {
         name: "Pi-hole Ads percentage today", 
         desc: "Anteil heute blockierter Werbungen an allen Werbungen (API)", // weiß nicht, ob das korrekt übersetzt ist
         type: "number", 
         def:  0,
         read: true,
         write: true,
         min: 0,
         max: 100,
         role: "value",
         custom: {
             "influxdb.0": {
                 "enabled": true,
                 "changesOnly": true,
                 "debounce": "",
                 "retention": 63072000 // 2 Jahre
             }
         }
      });
      createState(idActive, false, fC, {
         name: "Ist der Pi-hole Server aktiv?", 
         desc: "Liefert das Webinterface pi.hole/admin/api.php Daten? (API)",
         type: "boolean", 
         read: true,
         write: true,
         role: "indicator",
         custom: {
             "influxdb.0": {
                 "enabled": false,
                 "changesOnly": false,
                 "debounce": "",
                 "retention": 657000 // 1 Monat
             }
         }
      });
      createState(idAktiv, false, fC, {
         name: "Ist der Pi-hole Server aktiv?", 
         desc: "Läuft der Server (Webseite)",
         type: "boolean", 
         read: true,
         write: true,
         role: "indicator",
         custom: {
             "influxdb.0": {
                 "enabled": false,
                 "changesOnly": false,
                 "debounce": "",
                 "retention": 657000 // 1 Monat
             }
         }
      });
      createState(idAktivFarbe, "#FFFFFFF", fC, {
         name: "Pi-hole Aktivität HEX-Farbwert", 
         desc: "Indikator Farbwert Aktivität des Pi-Hole Servers (Webseite)",
         type: "string",
         def:  "#FFFFFF",
         read: true,
         write: true,
         role: "text"
      });
      createState(idLoad, "0", fC, {
         name: "Pi-hole CPU Load", 
         desc: "CPU Belastung (Load) des Pi-Hole Servers (Webseite)",
         type: "string",
         def:  "0",
         read: true,
         write: true,
         role: "text"
      });
      createState(idLoadFarbe, "#FFFFFFF", fC, {
         name: "Pi-hole Load HEX-Farbwert", 
         desc: "Indikator Farbwert LOAD des Pi-Hole Servers (Webseite)",
         type: "string",
         def:  "#FFFFFF",
         read: true,
         write: true,
         role: "text"
      });
      createState(idTemp, 0, fC, {
         name: "Pi-hole Temperatur", 
         desc: "Wärmeentwicklung des Pi-Hole Servers (Webseite)",
         type: "number",
         unit: "°C",
         def:  0,
         read: true,
         write: true,
         role: "value.temperature",
         custom: {
             "influxdb.0": {
                 "enabled": true,
                 "changesOnly": true,
                 "debounce": "",
                 "retention": 63072000 // 2 Jahre
             }
         }
      });
      createState(idTempFarbe, "#FFFFFFF", fC, {
         name: "Pi-hole Temperatur HEX-Farbwert", 
         desc: "Indikator Farbwert des Pi-Hole Servers (Webseite)",
         type: "string",
         def:  "#FFFFFF",
         read: true,
         write: true,
         role: "text"
      });
      createState(idVersionPihole, "", fC, {
         name: "Pi-hole Version", 
         desc: "Software Version Pi-hole (Webseite)",
         type: "string",
         def:  "",
         read: true,
         write: true,
         role: "text"
      });
      createState(idVersionFTL, "", fC, {
         name: "FTL Version", 
         desc: "Software Version FTL (Webseite)",
         type: "string",
         def:  "",
         read: true,
         write: true,
         role: "text"
      });
      createState(idVersionInterface, "", fC, {
         name: "Web Interface Version", 
         desc: "Software Version Web Interface (Webseite)",
         type: "string",
         def:  "",
         read: true,
         write: true,
         role: "text"
      });
      createState(idMemory, 0, fC, {
         name: "Pi-hole Speichernutzung", 
         desc: "von Pi-Hole belegter Hauptspeicher (Webseite)",
         type: "number",
         unit: "%",
         def:  0,
         read: true,
         write: true,
         min: 0,
         max: 100,
         role: "value",
         custom: {
             "influxdb.0": {
                 "enabled": true,
                 "changesOnly": true,
                 "debounce": "",
                 "retention": 63072000 // 2 Jahre
             }
         }
      });
      createState(idMemoryFarbe, "#FFFFFFF", fC, {
         name: "Pi-hole Speichernutzung HEX-Farbwert", 
         desc: "Indikator Farbwert Speichernutzung des Pi-Hole Servers (Webseite)",
         type: "string",
         def:  "#FFFFFF",
         read: true,
         write: true,
         role: "text"
      });
      createState(idTabelle, "", true, {
         name: "Pi-hole HTML Tabelle",
         desc: "HMTL Tabelle mit den Daten der JSON-Datei",
         type: "string",
         read: true,
         write: true,
         role: "html",
         custom: {
             "influxdb.0": {
                 "enabled": false,
                 "changesOnly": false,
                 "debounce": "",
                 "retention": 63072000 // 2 Jahre
             }
         }
      });
      createState(idUpdate, false, fC, {
         name: "Ist ein Pi-hole Softwareupdate möglich?", 
         desc: "Gibt es eine neue Version der Serversoftware? (Webseite)",
         type: "boolean", 
         read: true,
         write: true,
         role: "indicator"
      });
      
      
      // let request = require("request");
      
      function parseWebsite() { // für Version 3.3 seit 17.7.2020 für 5.1
         let options = {
             url: url_parse,
             headers: {
                 "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.1"
             }
         }; 
         try {
             request(options, function (error, response, body) {
                 if (!error && response.statusCode == 200) {              // kein Fehler, Inhalt in body
                     // Temperatur Zahl
                     // const temp_pattern = /\d{1,2}\.?\d*(?=&nbsp;&deg;C)/; // vor v5 
                     const temp_pattern = /\d{1,2}\.?\d*(?=<\/span><span id="tempdisplay")/; // ab v5
                     if (body.match(temp_pattern) === null) log("gesuchter Quellcode (Temperatur Pi-Hole) nicht gefunden", "error");
                     else {
                         let temp_arr =  body.match(temp_pattern);
                         let temp = parseFloat(temp_arr[0]);
                         temp = parseFloat( temp.toFixed(1) );
                         if (logging) log("Temperatur: " + temp + "°C");
                         setState(idTemp, temp);        
                     }
                     // Temperatur Farbe String
                     // const tempfarbe_pattern = /.{7}(?="><\/i> Temp)/; // vor v5
                     const tempfarbe_pattern = /.{7}(?="><\/i> Temp)/; // ab v5
                     if (body.match(tempfarbe_pattern) === null) log("gesuchter Quellcode (Temperatur Farbe Pi-Hole) nicht gefunden", "error");
                     else {
                         let tempfarbe_arr =  body.match(tempfarbe_pattern);
                         if (logging) log("Temperatur-Farbe (HEX-Wert): " + tempfarbe_arr[0]);
                         setState(idTempFarbe, tempfarbe_arr[0]);        
                     }
                     // Speicherbelegung Zahl
                     // const mem_pattern = /\d{1,2}\.\d{1}(?=&thinsp;%<\/a>)/; // vor v5
                     const mem_pattern = /\d{1,2}\.?\d*(?=&thinsp;%)/; // ab v5
                     if (body.match(mem_pattern) === null) log("gesuchter Quellcode (Speicherbelegung Pi-Hole) nicht gefunden", "error");
                     else {
                         let mem_arr =  body.match(mem_pattern);
                         let mem = parseFloat(mem_arr[0]);
                         if (logging) log("Speicherbelegung: " + mem + "%");
                         setState(idMemory, mem);        
                     }
                     // Farbe Speicherbelegung String / HEX-Wert
                     //const memfarbe_pattern = /.{7}(?="><\/i> Memory)/; // vor v5
                     const memfarbe_pattern = /(?<=text-).*(?="\>\<\/i\>.*Memory usage:&nbsp)/; // ab v5
                     if (body.match(memfarbe_pattern) === null) log("gesuchter Quellcode (Farbe Speicherbelegung Pi-Hole) nicht gefunden", "error");
                     else {
                         let memfarbe_arr =  body.match(memfarbe_pattern);
                         if (logging) log("Speicherbelegung Farbe: " + memfarbe_arr[0]);
                         setState(idMemoryFarbe, memfarbe_arr[0]);        
                     }
                     // LOAD String zB 0 0 0 oder 10.4 1.45 0
                     const load_pattern = /Load:&nbsp;&nbsp;(\d*|\d*\.\d*)&nbsp;&nbsp;(\d*|\d*\.\d*)&nbsp;&nbsp;(\d*|\d*\.\d*)/;
                     if (body.match(load_pattern) === null) log("gesuchter Quellcode (LOAD Pi-Hole) nicht gefunden", "error");
                     else {
                         let load_arr =  body.match(load_pattern);
                         let load0 = load_arr[0].replace(/Load:/i,"");
                         let load = load0.replace(/&nbsp;/g,"  ");
                         if (logging) log("CPU LOAD Server: " + load);
                         setState(idLoad, load);        
                     }
                     // Farbe LOAD String / HEX-Wert
                     // const loadfarbe_pattern = /.{7}(?="><\/i>.*Load:)/; // vor v5
                     const loadfarbe_pattern = /(?<=text-).*(?="\>\<\/i\>.*Load:&nbsp)/; // ab v5
                     if (body.match(loadfarbe_pattern) === null) log("gesuchter Quellcode (Farbe LOAD Pi-Hole) nicht gefunden", "error");
                     else {
                         let loadfarbe_arr =  body.match(loadfarbe_pattern);
                         if (logging) log("LOAD Farbe: " + loadfarbe_arr[0]);
                         setState(idLoadFarbe, loadfarbe_arr[0]);        
                     }
                     // Version Pihole zB 3.2.1 String
                     //const versionpi_pattern = /<b>Pi-hole Version \s*<\/b>\s*v\d*(\.\d*)*\.\d*/; // x.x.x oder x.x // vor v5
                     const versionpi_pattern = /(?<=pi-hole\/releases\/)v*v\d*(\.\d*)*\.\d*/; // x.x.x oder x.x // ab v5
                     if (body.match(versionpi_pattern) === null) log("gesuchter Quellcode (Pi-Hole Version) nicht gefunden", "error");
                     else {
                         let versionpi_arr =  body.match(versionpi_pattern);
                         let versionpi = versionpi_arr[0].replace(/<b>Pi-hole Version <\/b> v/,"");
                         if (logging) log("Version Pihole Server: " + versionpi);
                         setState(idVersionPihole, versionpi);        
                     }
                     // Version FTL zB 3.2.1 String
                     // const versionftl_pattern = /<b>FTL Version.*v\d*(\.\d*)*\.\d*/; // vor v5
                     const versionftl_pattern = /(?<=FTL\/releases\/)v*v\d*(\.\d*)*\.\d*/; // ab v5
                     if (body.match(versionftl_pattern) === null) log("gesuchter Quellcode (FTL Version) nicht gefunden", "error");
                     else {
                         let versionftl_arr =  body.match(versionftl_pattern);
                         let versionftl = versionftl_arr[0].replace(/<b>FTL Version.*v/,"");
                         if (logging) log("FTL Version Pihole Server: " + versionftl);
                         setState(idVersionFTL, versionftl);        
                     }
                     // Version Web Interface zB 3.2.1 String
                     //const versioninterface_pattern = /<b>Web Interface Version.*<\/b>v\d*(\.\d*)*\.\d*/; // vor v5
                     const versioninterface_pattern = /(?<=AdminLTE\/releases\/)v*v\d*(\.\d*)*\.\d*/; // ab v5
                     if (body.match(versioninterface_pattern) === null) log("gesuchter Quellcode (Web Interface Version) nicht gefunden", "error");
                     else {
                         let versioninterface_arr =  body.match(versioninterface_pattern);
                         let versioninterface = versioninterface_arr[0].replace(/<b>Web Interface Version.*<\/b>v/,"");
                         if (logging) log("Web Interface Version Pihole Server: " + versioninterface);
                         setState(idVersionInterface, versioninterface);        
                     }
                     // Aktiv zB true/false boolean holt das aus String
                     //const aktiv_pattern = /i>.*(?=<\/a><a id="temperature">)/; // vor v5
                     const aktiv_pattern = /(?<=\/i> ).*(?=\<\/span><span id="temperature">)/; // ab v5
                     if (body.match(aktiv_pattern) === null) log("gesuchter Quellcode (Pi-hole aktiv) nicht gefunden", "error");
                     else {
                         let aktiv_arr =  body.match(aktiv_pattern);
                         let aktiv = aktiv_arr[0].replace(/i>\s*/,"");
                         let aktiv_bool = (aktiv === "Active") ? true : false;
                         if (logging) log("Pihole Server aktiv? " + aktiv + "(" + aktiv_bool + ")");
                         setState(idAktiv, aktiv_bool);     
                     }
                     // Farbe Aktiv String / HEX-Wert
                     // const aktivfarbe_pattern = /.{7}(?="><\/i.*<\/a><a id="temperature">)/; // vor v5
                     const aktivfarbe_pattern = /(?<=text-).*(?="\>\<\/i> .*\<\/span><span id="temperature">)/; // ab v5
                     
                     if (body.match(aktivfarbe_pattern) === null) log("gesuchter Quellcode (Farbe Aktivität Pi-Hole) nicht gefunden", "error");
                     else {
                         let aktivfarbe_arr =  body.match(aktivfarbe_pattern);
                         if (logging) log("Aktivität Farbe: " + aktivfarbe_arr[0]);
                         setState(idAktivFarbe, aktivfarbe_arr[0]);        
                     }
                     // Update available // to be updated v5
                     const update_pattern = /Update available!/;
                     if (body.match(update_pattern) === null) setState(idUpdate, false); //log("gesuchter Quellcode (Update Warnung) nicht gefunden", "error");
                     else {
                         let update_arr =  body.match(update_pattern);
                         let update = update_arr[0];
                         let update_bool = update === ("Update available!") ? true : false;
                         if (logging) log("Pihole Softwareupdate möglich? (" + update_bool + ")");
                         setState(idUpdate, update_bool);          
                     }
                 } else {
                     log("StatusCode = " + response.statusCode);
                     log(error, "error");                               // Error beim Einlesen
                 }
             });
         } catch (e) {
             log("Fehler (try) leseWebseite (Pi-Hole Index.html): " + e, "error");
         }
         if (logging) log("Pi-Hole Webseite eingelesen, Temperatur und Speicherbelegung gespeichert");
      }
      
      
      function readPihole() {
         if (logging) log("Pi-hole: URL " + url + " wird abgefragt ...");
         let tabelle ="<table class=\"pihole_tabelle\"><caption>Pi-hole</caption><thead><tr><th>Admin Service: " + url + "</th></tr></thead><tbody>";
         request(url, function (error, response, body) {
             if (!error && response.statusCode == 200) {
                 let result;
                 let dnsblocked,
                     dnsqueries,
                     adsblocked,
                     adspercentage; 
                 try{
                     result = JSON.parse(body);
                     let data = JSON.stringify(result, null, 2);
                     if (logging) log(data);
                     if (logging) log(body);
                     setState(idJSON, data);
                     if (logging) log("JSON: "+ getState(idJSON).val);
                     
                     if (result) { // CHECK
                     
                         setState(idActive, true);
                         if (logging) log("Pi-hole liefert Daten und ist aktiv");
                         // http://forum.iobroker.net/viewtopic.php?f=24&t=6053&sid=65e9ec9396fe557147e535c5a4631982#p68823
                         dnsblocked = (result.domains_being_blocked)/*.replace(/,/, "")*/;
                         dnsqueries = (result.dns_queries_today)/*.replace(/,/, "")*/;
                         adsblocked = result.ads_blocked_today;
                         adspercentage = result.ads_percentage_today;
                         
                         if ( isNaN(parseFloat(adspercentage)) === false ) {
                             setState(idAdsPercentage, parseFloat(adspercentage));
                         } else setState(idAdsPercentage, 100);
                         setState(idDomains, parseFloat(dnsblocked));
                         setState(idDNSQueries, parseFloat(dnsqueries));
                         setState(idAdsBlocked, parseFloat(adsblocked));
                     
                         // Eintrag anfügen
                         tabelle += "<tr><td class=\"pihole_label\">Anzahl blockierter Domains:</td>"
                                 +  "<td class=\"pihole_data\">" + dnsblocked + "</td></tr>"
                                 
                                 +  "<tr><td class=\"pihole_label\">DNS-Abfragen (heute):</td>"
                                 +  "<td class=\"pihole_data\">" + dnsqueries + "</td></tr>"
                             
                                 +  "<tr><td class=\"pihole_label\">Blockierte Werbung (heute):</td>"
                                 +  "<td class=\"pihole_data\">" + adsblocked + "</td></tr>"
                             
                                 +  "<tr><td class=\"pihole_label\">Werbeanteil (heute in Prozent):</td>"
                                 +  "<td class=\"pihole_data\">" + adspercentage + "</td></tr>";
                     } else tabelle += "<tr><td class=\"pihole_data\">Pi-hole nicht gefunden!</td></tr>";
                     // Ende Teil,d er aus dem Try raus kann
                 } catch (fehler_try) {
                     log("Pi-hole - Parse Fehler: " + fehler_try, "error");
                 }    
             } else {
                 log("Pi-hole - Fehler: " + error, "warn");
             }
             tabelle += "</tbody></table>";  
             setState(idTabelle, tabelle);                     
             if (logging) log("HTML-Tabelle: " + tabelle);
         });   // Ende request 
      }
      
      function main() {
         readPihole();
         setTimeout(parseWebsite, 3000); // verzögertes Parsen
      }
      schedule(zeitplan_parse, parseWebsite);
      schedule(zeitplan, readPihole);
      setTimeout(main, 500);
      

      Vielleicht hilft es jemandem.

      Gruß
      Pix

      ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

      haselchenH 1 Antwort Letzte Antwort
      4
      • P pix

        Hallo,

        seit der neuen Version von pi-hole (glaube, v5) passt mein Skript nicht mehr so ganz. Habe einige Anpassungen gemacht. Bitte nicht einfach copy/paste und loslegen, da auch individuelle Anpassungen nötig sind (Pfad, influxDB, IP des pihole)

        Wer das alte Skript noch hat und nicht oder zusätzlich den Pi-Hole-Adapter nutzt, kann hier die Korrekturen für die neuen RegEx-Abfragen finden. Die Muster mussten angepasst werden, da die Weboberfläche der neuesten Pi-Hole Version einen anderen Quellcode hat. Wer keine Infos mehr parsen will, kann hier auch aufhören zu lesen :)

        /* Pi-hole
        pi-hole JSON Leser und Statusseiten Parser
        InfluxDB Vorbereitung
        
        23.04.2017 von Pix erstellt
        28.05.2017 let tabelle umgestellt
        31.05.2017 forceCreation und common/influx
        11.02.2018 Parse Temperatur, LOAD, Mem, Aktivitität; jeweils mit Farbe
                  Code optimiert
                  Ablauf optimiert
        26.02.2018 Update der Serversoftware wird abgefragt
        01.03.2018 Muster zur Temperaturerkennung optimiert
        17.07.2020 Anpassung RegExp, da Pi-Hole Adminkonsole neuen Quelltext hat
                  
        todo: Reaktionen mit Optin und telegram bei Serverausfall, Temperatur zu hoch, etc.           
             Farben korrekt einlesen (wenn überhaupt noch nötig)
             Update bereit Mitteilung korrekt auslesen (jetzt über API nicht mehr über Web)
        */
        
        const fC = false; // forceCreation
        const logging = true;
        const pfad = ".Pi-hole.";
        const zeitplan = "*/5 * * * *"; // alle 5 Minuten
        const zeitplan_parse = "*/1 * * * *"; // minütlich
        const ip_pihole = "192.xxx.xxx.xxx"; // <------ IP des PI-Hole
        
        
        // #############################################################################
        // ab hier nix mehr ändern
        
        const url = "http://" + ip_pihole + "/admin/api.php";
        const url_parse = "http://" + ip_pihole + "/admin/index.php";
        
        // Instanz des Javascript-Adapters ermitteln
        let instanz = "javascript." + instance;
        if (logging) log(instanz);
        
        // ID definieren
        const idJSON             = instanz + pfad + "JSON",
             idDomains          = instanz + pfad + "Domains_blocked",
             idDNSQueries       = instanz + pfad + "DNS_queries",
             idAdsBlocked       = instanz + pfad + "Ads_blocked",
             idAdsPercentage    = instanz + pfad + "Ads_percentage",
             idActive           = instanz + pfad + "aktiv",
             idTemp             = instanz + pfad + "Temperatur",
             idTempFarbe        = instanz + pfad + "Farbe.Temperatur",
             idMemory           = instanz + pfad + "Speicher",
             idMemoryFarbe      = instanz + pfad + "Farbe.Speicher",
             idVersionFTL       = instanz + pfad + "Version.FTL",
             idVersionPihole    = instanz + pfad + "Version.Pihole",
             idVersionInterface = instanz + pfad + "Version.Interface",
             idLoad             = instanz + pfad + "Load",
             idLoadFarbe        = instanz + pfad + "Farbe.Load",
             idAktiv            = instanz + pfad + "aktiv_parse",
             idAktivFarbe       = instanz + pfad + "Farbe.aktiv_parse",
             idTabelle          = instanz + pfad + "Tabelle",
             idUpdate           = instanz + pfad + "Update";
        
        // States erstellen
        createState(idJSON, "", fC, {
           name: "JSON Datei vom Pi-hole Server",
           desc: "Kopie der JSON Datei",
           type: "string",
           read: true,
           write: true,
           role: "json",
           custom: {
               "influxdb.0": {
                   "enabled": false,
                   "changesOnly": false,
                   "debounce": "",
                   "retention": 657000 // 1 Monat
               }
           }
        });
        createState(idDomains, 0, fC, {
           name: "Pi-hole Domains blocked today", 
           desc: "Heute blockierte Domains (API)",
           type: "number", 
           def:  0,
           read: true,
           write: true,
           role: "value",
           custom: {
               "influxdb.0": {
                   "enabled": true,
                   "changesOnly": true,
                   "debounce": "",
                   "retention": 657000 // 1 Monat
               }
           }
        });
        createState(idDNSQueries, 0, fC, {
           name: "Pi-hole DNS Queries today", 
           desc: "Heutige DOmain Name Server Anfragen (API)",
           type: "number", 
           def:  0,
           read: true,
           write: true,
           role: "value",
           custom: {
               "influxdb.0": {
                   "enabled": true,
                   "changesOnly": true,
                   "debounce": "",
                   "retention": 657000 // 1 Monat
               }
           }
        });
        createState(idAdsBlocked, 0, fC, {
           name: "Pi-hole Ads blocked today", 
           desc: "Heute blockierte Werbungen (API)",
           type: "number", 
           def:  0,
           read: true,
           write: true,
           role: "value",
           custom: {
               "influxdb.0": {
                   "enabled": true,
                   "changesOnly": true,
                   "debounce": "",
                   "retention": 657000 // 1 Monat
               }
           }
        });
        createState(idAdsPercentage, 0, fC, {
           name: "Pi-hole Ads percentage today", 
           desc: "Anteil heute blockierter Werbungen an allen Werbungen (API)", // weiß nicht, ob das korrekt übersetzt ist
           type: "number", 
           def:  0,
           read: true,
           write: true,
           min: 0,
           max: 100,
           role: "value",
           custom: {
               "influxdb.0": {
                   "enabled": true,
                   "changesOnly": true,
                   "debounce": "",
                   "retention": 63072000 // 2 Jahre
               }
           }
        });
        createState(idActive, false, fC, {
           name: "Ist der Pi-hole Server aktiv?", 
           desc: "Liefert das Webinterface pi.hole/admin/api.php Daten? (API)",
           type: "boolean", 
           read: true,
           write: true,
           role: "indicator",
           custom: {
               "influxdb.0": {
                   "enabled": false,
                   "changesOnly": false,
                   "debounce": "",
                   "retention": 657000 // 1 Monat
               }
           }
        });
        createState(idAktiv, false, fC, {
           name: "Ist der Pi-hole Server aktiv?", 
           desc: "Läuft der Server (Webseite)",
           type: "boolean", 
           read: true,
           write: true,
           role: "indicator",
           custom: {
               "influxdb.0": {
                   "enabled": false,
                   "changesOnly": false,
                   "debounce": "",
                   "retention": 657000 // 1 Monat
               }
           }
        });
        createState(idAktivFarbe, "#FFFFFFF", fC, {
           name: "Pi-hole Aktivität HEX-Farbwert", 
           desc: "Indikator Farbwert Aktivität des Pi-Hole Servers (Webseite)",
           type: "string",
           def:  "#FFFFFF",
           read: true,
           write: true,
           role: "text"
        });
        createState(idLoad, "0", fC, {
           name: "Pi-hole CPU Load", 
           desc: "CPU Belastung (Load) des Pi-Hole Servers (Webseite)",
           type: "string",
           def:  "0",
           read: true,
           write: true,
           role: "text"
        });
        createState(idLoadFarbe, "#FFFFFFF", fC, {
           name: "Pi-hole Load HEX-Farbwert", 
           desc: "Indikator Farbwert LOAD des Pi-Hole Servers (Webseite)",
           type: "string",
           def:  "#FFFFFF",
           read: true,
           write: true,
           role: "text"
        });
        createState(idTemp, 0, fC, {
           name: "Pi-hole Temperatur", 
           desc: "Wärmeentwicklung des Pi-Hole Servers (Webseite)",
           type: "number",
           unit: "°C",
           def:  0,
           read: true,
           write: true,
           role: "value.temperature",
           custom: {
               "influxdb.0": {
                   "enabled": true,
                   "changesOnly": true,
                   "debounce": "",
                   "retention": 63072000 // 2 Jahre
               }
           }
        });
        createState(idTempFarbe, "#FFFFFFF", fC, {
           name: "Pi-hole Temperatur HEX-Farbwert", 
           desc: "Indikator Farbwert des Pi-Hole Servers (Webseite)",
           type: "string",
           def:  "#FFFFFF",
           read: true,
           write: true,
           role: "text"
        });
        createState(idVersionPihole, "", fC, {
           name: "Pi-hole Version", 
           desc: "Software Version Pi-hole (Webseite)",
           type: "string",
           def:  "",
           read: true,
           write: true,
           role: "text"
        });
        createState(idVersionFTL, "", fC, {
           name: "FTL Version", 
           desc: "Software Version FTL (Webseite)",
           type: "string",
           def:  "",
           read: true,
           write: true,
           role: "text"
        });
        createState(idVersionInterface, "", fC, {
           name: "Web Interface Version", 
           desc: "Software Version Web Interface (Webseite)",
           type: "string",
           def:  "",
           read: true,
           write: true,
           role: "text"
        });
        createState(idMemory, 0, fC, {
           name: "Pi-hole Speichernutzung", 
           desc: "von Pi-Hole belegter Hauptspeicher (Webseite)",
           type: "number",
           unit: "%",
           def:  0,
           read: true,
           write: true,
           min: 0,
           max: 100,
           role: "value",
           custom: {
               "influxdb.0": {
                   "enabled": true,
                   "changesOnly": true,
                   "debounce": "",
                   "retention": 63072000 // 2 Jahre
               }
           }
        });
        createState(idMemoryFarbe, "#FFFFFFF", fC, {
           name: "Pi-hole Speichernutzung HEX-Farbwert", 
           desc: "Indikator Farbwert Speichernutzung des Pi-Hole Servers (Webseite)",
           type: "string",
           def:  "#FFFFFF",
           read: true,
           write: true,
           role: "text"
        });
        createState(idTabelle, "", true, {
           name: "Pi-hole HTML Tabelle",
           desc: "HMTL Tabelle mit den Daten der JSON-Datei",
           type: "string",
           read: true,
           write: true,
           role: "html",
           custom: {
               "influxdb.0": {
                   "enabled": false,
                   "changesOnly": false,
                   "debounce": "",
                   "retention": 63072000 // 2 Jahre
               }
           }
        });
        createState(idUpdate, false, fC, {
           name: "Ist ein Pi-hole Softwareupdate möglich?", 
           desc: "Gibt es eine neue Version der Serversoftware? (Webseite)",
           type: "boolean", 
           read: true,
           write: true,
           role: "indicator"
        });
        
        
        // let request = require("request");
        
        function parseWebsite() { // für Version 3.3 seit 17.7.2020 für 5.1
           let options = {
               url: url_parse,
               headers: {
                   "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.1"
               }
           }; 
           try {
               request(options, function (error, response, body) {
                   if (!error && response.statusCode == 200) {              // kein Fehler, Inhalt in body
                       // Temperatur Zahl
                       // const temp_pattern = /\d{1,2}\.?\d*(?=&nbsp;&deg;C)/; // vor v5 
                       const temp_pattern = /\d{1,2}\.?\d*(?=<\/span><span id="tempdisplay")/; // ab v5
                       if (body.match(temp_pattern) === null) log("gesuchter Quellcode (Temperatur Pi-Hole) nicht gefunden", "error");
                       else {
                           let temp_arr =  body.match(temp_pattern);
                           let temp = parseFloat(temp_arr[0]);
                           temp = parseFloat( temp.toFixed(1) );
                           if (logging) log("Temperatur: " + temp + "°C");
                           setState(idTemp, temp);        
                       }
                       // Temperatur Farbe String
                       // const tempfarbe_pattern = /.{7}(?="><\/i> Temp)/; // vor v5
                       const tempfarbe_pattern = /.{7}(?="><\/i> Temp)/; // ab v5
                       if (body.match(tempfarbe_pattern) === null) log("gesuchter Quellcode (Temperatur Farbe Pi-Hole) nicht gefunden", "error");
                       else {
                           let tempfarbe_arr =  body.match(tempfarbe_pattern);
                           if (logging) log("Temperatur-Farbe (HEX-Wert): " + tempfarbe_arr[0]);
                           setState(idTempFarbe, tempfarbe_arr[0]);        
                       }
                       // Speicherbelegung Zahl
                       // const mem_pattern = /\d{1,2}\.\d{1}(?=&thinsp;%<\/a>)/; // vor v5
                       const mem_pattern = /\d{1,2}\.?\d*(?=&thinsp;%)/; // ab v5
                       if (body.match(mem_pattern) === null) log("gesuchter Quellcode (Speicherbelegung Pi-Hole) nicht gefunden", "error");
                       else {
                           let mem_arr =  body.match(mem_pattern);
                           let mem = parseFloat(mem_arr[0]);
                           if (logging) log("Speicherbelegung: " + mem + "%");
                           setState(idMemory, mem);        
                       }
                       // Farbe Speicherbelegung String / HEX-Wert
                       //const memfarbe_pattern = /.{7}(?="><\/i> Memory)/; // vor v5
                       const memfarbe_pattern = /(?<=text-).*(?="\>\<\/i\>.*Memory usage:&nbsp)/; // ab v5
                       if (body.match(memfarbe_pattern) === null) log("gesuchter Quellcode (Farbe Speicherbelegung Pi-Hole) nicht gefunden", "error");
                       else {
                           let memfarbe_arr =  body.match(memfarbe_pattern);
                           if (logging) log("Speicherbelegung Farbe: " + memfarbe_arr[0]);
                           setState(idMemoryFarbe, memfarbe_arr[0]);        
                       }
                       // LOAD String zB 0 0 0 oder 10.4 1.45 0
                       const load_pattern = /Load:&nbsp;&nbsp;(\d*|\d*\.\d*)&nbsp;&nbsp;(\d*|\d*\.\d*)&nbsp;&nbsp;(\d*|\d*\.\d*)/;
                       if (body.match(load_pattern) === null) log("gesuchter Quellcode (LOAD Pi-Hole) nicht gefunden", "error");
                       else {
                           let load_arr =  body.match(load_pattern);
                           let load0 = load_arr[0].replace(/Load:/i,"");
                           let load = load0.replace(/&nbsp;/g,"  ");
                           if (logging) log("CPU LOAD Server: " + load);
                           setState(idLoad, load);        
                       }
                       // Farbe LOAD String / HEX-Wert
                       // const loadfarbe_pattern = /.{7}(?="><\/i>.*Load:)/; // vor v5
                       const loadfarbe_pattern = /(?<=text-).*(?="\>\<\/i\>.*Load:&nbsp)/; // ab v5
                       if (body.match(loadfarbe_pattern) === null) log("gesuchter Quellcode (Farbe LOAD Pi-Hole) nicht gefunden", "error");
                       else {
                           let loadfarbe_arr =  body.match(loadfarbe_pattern);
                           if (logging) log("LOAD Farbe: " + loadfarbe_arr[0]);
                           setState(idLoadFarbe, loadfarbe_arr[0]);        
                       }
                       // Version Pihole zB 3.2.1 String
                       //const versionpi_pattern = /<b>Pi-hole Version \s*<\/b>\s*v\d*(\.\d*)*\.\d*/; // x.x.x oder x.x // vor v5
                       const versionpi_pattern = /(?<=pi-hole\/releases\/)v*v\d*(\.\d*)*\.\d*/; // x.x.x oder x.x // ab v5
                       if (body.match(versionpi_pattern) === null) log("gesuchter Quellcode (Pi-Hole Version) nicht gefunden", "error");
                       else {
                           let versionpi_arr =  body.match(versionpi_pattern);
                           let versionpi = versionpi_arr[0].replace(/<b>Pi-hole Version <\/b> v/,"");
                           if (logging) log("Version Pihole Server: " + versionpi);
                           setState(idVersionPihole, versionpi);        
                       }
                       // Version FTL zB 3.2.1 String
                       // const versionftl_pattern = /<b>FTL Version.*v\d*(\.\d*)*\.\d*/; // vor v5
                       const versionftl_pattern = /(?<=FTL\/releases\/)v*v\d*(\.\d*)*\.\d*/; // ab v5
                       if (body.match(versionftl_pattern) === null) log("gesuchter Quellcode (FTL Version) nicht gefunden", "error");
                       else {
                           let versionftl_arr =  body.match(versionftl_pattern);
                           let versionftl = versionftl_arr[0].replace(/<b>FTL Version.*v/,"");
                           if (logging) log("FTL Version Pihole Server: " + versionftl);
                           setState(idVersionFTL, versionftl);        
                       }
                       // Version Web Interface zB 3.2.1 String
                       //const versioninterface_pattern = /<b>Web Interface Version.*<\/b>v\d*(\.\d*)*\.\d*/; // vor v5
                       const versioninterface_pattern = /(?<=AdminLTE\/releases\/)v*v\d*(\.\d*)*\.\d*/; // ab v5
                       if (body.match(versioninterface_pattern) === null) log("gesuchter Quellcode (Web Interface Version) nicht gefunden", "error");
                       else {
                           let versioninterface_arr =  body.match(versioninterface_pattern);
                           let versioninterface = versioninterface_arr[0].replace(/<b>Web Interface Version.*<\/b>v/,"");
                           if (logging) log("Web Interface Version Pihole Server: " + versioninterface);
                           setState(idVersionInterface, versioninterface);        
                       }
                       // Aktiv zB true/false boolean holt das aus String
                       //const aktiv_pattern = /i>.*(?=<\/a><a id="temperature">)/; // vor v5
                       const aktiv_pattern = /(?<=\/i> ).*(?=\<\/span><span id="temperature">)/; // ab v5
                       if (body.match(aktiv_pattern) === null) log("gesuchter Quellcode (Pi-hole aktiv) nicht gefunden", "error");
                       else {
                           let aktiv_arr =  body.match(aktiv_pattern);
                           let aktiv = aktiv_arr[0].replace(/i>\s*/,"");
                           let aktiv_bool = (aktiv === "Active") ? true : false;
                           if (logging) log("Pihole Server aktiv? " + aktiv + "(" + aktiv_bool + ")");
                           setState(idAktiv, aktiv_bool);     
                       }
                       // Farbe Aktiv String / HEX-Wert
                       // const aktivfarbe_pattern = /.{7}(?="><\/i.*<\/a><a id="temperature">)/; // vor v5
                       const aktivfarbe_pattern = /(?<=text-).*(?="\>\<\/i> .*\<\/span><span id="temperature">)/; // ab v5
                       
                       if (body.match(aktivfarbe_pattern) === null) log("gesuchter Quellcode (Farbe Aktivität Pi-Hole) nicht gefunden", "error");
                       else {
                           let aktivfarbe_arr =  body.match(aktivfarbe_pattern);
                           if (logging) log("Aktivität Farbe: " + aktivfarbe_arr[0]);
                           setState(idAktivFarbe, aktivfarbe_arr[0]);        
                       }
                       // Update available // to be updated v5
                       const update_pattern = /Update available!/;
                       if (body.match(update_pattern) === null) setState(idUpdate, false); //log("gesuchter Quellcode (Update Warnung) nicht gefunden", "error");
                       else {
                           let update_arr =  body.match(update_pattern);
                           let update = update_arr[0];
                           let update_bool = update === ("Update available!") ? true : false;
                           if (logging) log("Pihole Softwareupdate möglich? (" + update_bool + ")");
                           setState(idUpdate, update_bool);          
                       }
                   } else {
                       log("StatusCode = " + response.statusCode);
                       log(error, "error");                               // Error beim Einlesen
                   }
               });
           } catch (e) {
               log("Fehler (try) leseWebseite (Pi-Hole Index.html): " + e, "error");
           }
           if (logging) log("Pi-Hole Webseite eingelesen, Temperatur und Speicherbelegung gespeichert");
        }
        
        
        function readPihole() {
           if (logging) log("Pi-hole: URL " + url + " wird abgefragt ...");
           let tabelle ="<table class=\"pihole_tabelle\"><caption>Pi-hole</caption><thead><tr><th>Admin Service: " + url + "</th></tr></thead><tbody>";
           request(url, function (error, response, body) {
               if (!error && response.statusCode == 200) {
                   let result;
                   let dnsblocked,
                       dnsqueries,
                       adsblocked,
                       adspercentage; 
                   try{
                       result = JSON.parse(body);
                       let data = JSON.stringify(result, null, 2);
                       if (logging) log(data);
                       if (logging) log(body);
                       setState(idJSON, data);
                       if (logging) log("JSON: "+ getState(idJSON).val);
                       
                       if (result) { // CHECK
                       
                           setState(idActive, true);
                           if (logging) log("Pi-hole liefert Daten und ist aktiv");
                           // http://forum.iobroker.net/viewtopic.php?f=24&t=6053&sid=65e9ec9396fe557147e535c5a4631982#p68823
                           dnsblocked = (result.domains_being_blocked)/*.replace(/,/, "")*/;
                           dnsqueries = (result.dns_queries_today)/*.replace(/,/, "")*/;
                           adsblocked = result.ads_blocked_today;
                           adspercentage = result.ads_percentage_today;
                           
                           if ( isNaN(parseFloat(adspercentage)) === false ) {
                               setState(idAdsPercentage, parseFloat(adspercentage));
                           } else setState(idAdsPercentage, 100);
                           setState(idDomains, parseFloat(dnsblocked));
                           setState(idDNSQueries, parseFloat(dnsqueries));
                           setState(idAdsBlocked, parseFloat(adsblocked));
                       
                           // Eintrag anfügen
                           tabelle += "<tr><td class=\"pihole_label\">Anzahl blockierter Domains:</td>"
                                   +  "<td class=\"pihole_data\">" + dnsblocked + "</td></tr>"
                                   
                                   +  "<tr><td class=\"pihole_label\">DNS-Abfragen (heute):</td>"
                                   +  "<td class=\"pihole_data\">" + dnsqueries + "</td></tr>"
                               
                                   +  "<tr><td class=\"pihole_label\">Blockierte Werbung (heute):</td>"
                                   +  "<td class=\"pihole_data\">" + adsblocked + "</td></tr>"
                               
                                   +  "<tr><td class=\"pihole_label\">Werbeanteil (heute in Prozent):</td>"
                                   +  "<td class=\"pihole_data\">" + adspercentage + "</td></tr>";
                       } else tabelle += "<tr><td class=\"pihole_data\">Pi-hole nicht gefunden!</td></tr>";
                       // Ende Teil,d er aus dem Try raus kann
                   } catch (fehler_try) {
                       log("Pi-hole - Parse Fehler: " + fehler_try, "error");
                   }    
               } else {
                   log("Pi-hole - Fehler: " + error, "warn");
               }
               tabelle += "</tbody></table>";  
               setState(idTabelle, tabelle);                     
               if (logging) log("HTML-Tabelle: " + tabelle);
           });   // Ende request 
        }
        
        function main() {
           readPihole();
           setTimeout(parseWebsite, 3000); // verzögertes Parsen
        }
        schedule(zeitplan_parse, parseWebsite);
        schedule(zeitplan, readPihole);
        setTimeout(main, 500);
        

        Vielleicht hilft es jemandem.

        Gruß
        Pix

        haselchenH Offline
        haselchenH Offline
        haselchen
        Most Active
        schrieb am zuletzt editiert von haselchen
        #43

        @pix
        Erstmal hervorragende Arbeit!! Durch dein Skript hat sich meine VIS erweitert :)

        Bei den Farben kommt nun das heraus in den Datenpunkten
        da15ae2b-0f2c-4447-8e83-e8b98c6a9365-image.png

        Dadurch bekomme ich in der VIS nicht mehr die aktuelle Farbe in den Kreisen
        26846904-b4a1-4d0b-a9eb-d10d7076daa2-image.png

        Wie komme ich aus diesem "Dilemma" ?

        @Glasfaser Du hast doch auch immer gute Ideen?! :stuck_out_tongue_winking_eye:

        Synology DS218+ & 2 x Fujitsu Esprimo (VM/Container) + FritzBox7590 + 2 AVM 3000 Repeater & Homematic & HUE & Osram & Xiaomi, NPM 10.9.4, Nodejs 22.21.0 ,JS Controller 7.0.7 ,Admin 7.7.19

        1 Antwort Letzte Antwort
        0
        • NashraN Offline
          NashraN Offline
          Nashra
          Most Active Forum Testing
          schrieb am zuletzt editiert von
          #44

          @pix
          gestern Abend folgende Meldung

          Gestern 22:30	error	javascript.0	gesuchter Quellcode (Farbe Aktivität Pi-Hole) nicht gefunden
          Gestern 22:30	error	javascript.0	gesuchter Quellcode (Pi-hole aktiv) nicht gefunden
          Gestern 22:30	error	javascript.0	gesuchter Quellcode (Temperatur Farbe Pi-Hole) nicht gefunden
          Gestern 22:30	error	javascript.0	gesuchter Quellcode (Temperatur Pi-Hole) nicht gefunden
          

          pi-hole.PNG

          Letztes aktuelles Skript vom 17.07.2020

          Gruß Ralf
          Mir egal, wer Dein Vater ist! Wenn ich hier angel, wird nicht übers Wasser gelaufen!!

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

          P 1 Antwort Letzte Antwort
          0
          • NashraN Nashra

            @pix
            gestern Abend folgende Meldung

            Gestern 22:30	error	javascript.0	gesuchter Quellcode (Farbe Aktivität Pi-Hole) nicht gefunden
            Gestern 22:30	error	javascript.0	gesuchter Quellcode (Pi-hole aktiv) nicht gefunden
            Gestern 22:30	error	javascript.0	gesuchter Quellcode (Temperatur Farbe Pi-Hole) nicht gefunden
            Gestern 22:30	error	javascript.0	gesuchter Quellcode (Temperatur Pi-Hole) nicht gefunden
            

            pi-hole.PNG

            Letztes aktuelles Skript vom 17.07.2020

            P Offline
            P Offline
            pix
            schrieb am zuletzt editiert von
            #45

            @nashra Hallo,

            vermutlich hast du ein Update der Pi-Hole Software gemacht. Ich habe das Abgreifen der Daten aus der Weboberfläche mittlerweile wieder gelassen. Ist auf Dauer zu viel Aufwand für wenig Nutzen. Wenn ich Nähe Informationen brauch, öffne ich sowieso die Pi-Hole Weboberfläche.

            Gruß
            Pix

            ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

            NashraN haselchenH 2 Antworten Letzte Antwort
            0
            • P pix

              @nashra Hallo,

              vermutlich hast du ein Update der Pi-Hole Software gemacht. Ich habe das Abgreifen der Daten aus der Weboberfläche mittlerweile wieder gelassen. Ist auf Dauer zu viel Aufwand für wenig Nutzen. Wenn ich Nähe Informationen brauch, öffne ich sowieso die Pi-Hole Weboberfläche.

              Gruß
              Pix

              NashraN Offline
              NashraN Offline
              Nashra
              Most Active Forum Testing
              schrieb am zuletzt editiert von
              #46

              @pix
              Haste auch wieder recht, so wichtig sind die Daten nicht :stuck_out_tongue_winking_eye:

              Gruß Ralf
              Mir egal, wer Dein Vater ist! Wenn ich hier angel, wird nicht übers Wasser gelaufen!!

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

              1 Antwort Letzte Antwort
              0
              • P pix

                @nashra Hallo,

                vermutlich hast du ein Update der Pi-Hole Software gemacht. Ich habe das Abgreifen der Daten aus der Weboberfläche mittlerweile wieder gelassen. Ist auf Dauer zu viel Aufwand für wenig Nutzen. Wenn ich Nähe Informationen brauch, öffne ich sowieso die Pi-Hole Weboberfläche.

                Gruß
                Pix

                haselchenH Offline
                haselchenH Offline
                haselchen
                Most Active
                schrieb am zuletzt editiert von haselchen
                #47

                @pix

                Ich hab dein Script vom 17.7.20 gestern rausgekramt.
                Ich benutze die Infos für ne VIS Seite.
                Einzig die Farben (gefüllte Kreise) für LOAD etc. lassen sich in der VIS nicht mehr anzeigen.
                Aber das ist jammern auf hohem Niveau.
                Der Rest funktioniert.

                Synology DS218+ & 2 x Fujitsu Esprimo (VM/Container) + FritzBox7590 + 2 AVM 3000 Repeater & Homematic & HUE & Osram & Xiaomi, NPM 10.9.4, Nodejs 22.21.0 ,JS Controller 7.0.7 ,Admin 7.7.19

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


                Support us

                ioBroker
                Community Adapters
                Donate
                FAQ Cloud / IOT
                HowTo: Node.js-Update
                HowTo: Backup/Restore
                Downloads
                BLOG

                699

                Online

                32.4k

                Benutzer

                81.5k

                Themen

                1.3m

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

                • Du hast noch kein Konto? Registrieren

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