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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Unifi WLAN Script

NEWS

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

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

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

Unifi WLAN Script

Geplant Angeheftet Gesperrt Verschoben JavaScript
380 Beiträge 13 Kommentatoren 57.3k Aufrufe 13 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.
  • liv-in-skyL liv-in-sky

    hab mal das script auf meine bedürfnisse angepaßt

    • die neuen änderungen von thehowbox sind nicht integriert - auch kein zweites netzwerk
    • möglichkeit für iqontrol anzeige(als popup) und formatierung ist integriert
    • standardmäßig wird eine tabelle für clients und voucher erzeugt
    • auf wunsch kann eine anwesenheitskontrolle eingeschaltet werden - alle unifi clients bekommen einen datenpunkt (ähnlich wie im ping adapter)
    • voucher abfrage kann aktiviert werden
    • standard pfad für datenpunkt-verzeichnispfad kann eingestellt werden (falls man schon ein laufendes script hat kann hier ein neuer datenpfad konfiguriert werden
    • es werden nur updates geschrieben (für clients, vouchers (datenpunkte /file)) , um zu verhindern, dass dauernd etwas geschrieben oder brechnet wird
      falls man das script und existierende datenpunkte hat - bitte alle datenpunkte löschen !!!

    
    
    const unifi_username = "xxxxxx";
    const unifi_password = "xxxxxxxxx!";
    const unifi_controller = "https://192.xxx.xxx.xxx:8443";
    const wifi_id = "xxxnnnnaaaaakkkkkkaaaa";
    
    const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
    var fs = require('fs')
    const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
    const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
    let writeFile = true;
    let  writeFileVar = 0;
    let writeClientTable = true;
    let writeAnwesenheit = true;
    let listeDatenpunkte = [];
    let listeDatenpunkteNew = [];
    let listeDatenpunkteAlt = [];
    
    // Datenpunkte Hauptpfad wählen
    const dpPrefix = "javascript.2.";
    
    //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
    let  iqontrol = false;
    let  anwesenheit = false; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects löschen
    let vouchers = false;
    
    // Hier Definition iqontrol-Style für Popup
    const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
    const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
    let cookies = [];
    let loggedIn = false;
    let debug = false;
    
    if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
    if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
    
    //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
    
    //Datenpunkt für Wifi Status erstellen
    createState(dpPrefix + "WLANUnifi.Wifi_Status", {
        name: 'Unifi Wifi Status', 
        role: 'boolean',
        read:  true, 
        write: true,
    });
     
    //Datenpunkt Button für Wifi an erstellen
    createState(dpPrefix + "WLANUnifi.Wifi_an", {
        name: 'Unifi Wifi an', 
        role: 'switch',
        read:  true, 
        write: true,
        type: "boolean",
        "smartName": {
        "de": "02Gäste Wlan an",
        "smartType": "SWITCH"
    }
    });
       setStateDelayed(dpPrefix + "WLANUnifi.Wifi_an", false, 300);
     
    //Datenpunkt Button für Wifi aus erstellen
    createState(dpPrefix + "WLANUnifi.Wifi_aus", {
        name: 'Unifi Wifi aus', 
        role: 'switch',
        read:  true, 
        write: true,
        type: "boolean",
        "smartName": {
        "de": "03Gäste Wlan aus",
        "smartType": "SWITCH"
    }
    });
       setStateDelayed(dpPrefix + "WLANUnifi.Wifi_aus", false, 300);
    
    if (true) {
    createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
        name: 'Unifi Wifi Clients Table', 
        role: 'string',
        read:  true, 
        write: true,
    });}
    
    
    if (vouchers) {
    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
        name: 'Unifi Wifi Vouchers', 
        role: 'string',
        read:  true, 
        write: true,
    });
    
    for (var i = 1; i < 21; i++) { 
        var x=i.toString();
        if (i<10) x="0"+x;
       createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
        name: 'Unifi Voucher_Code'+x, 
        role: 'string',
        read:  true, 
        write: true,
        });
    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
        name: 'Unifi Voucher_Code_erstellt'+x, 
        role: 'string',
        read:  true, 
        write: true,
        });
    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".duration", {
        name: 'Unifi Voucher_Code_duration'+x, 
        role: 'string',
        read:  true, 
        write: true,
        });
    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".expires", {
        name: 'Unifi Voucher_Code_expires'+x, 
        role: 'string',
        read:  true, 
        write: true,
        });
    }}
     
    createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
    if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
     
    function dlog(message) {
       if(debug)
           console.log(message);
    }
     
    async function login() {
       return new Promise(async (resolve, reject) => {
           let resp = await request.post({
               resolveWithFullResponse: true,
               url: unifi_controller + "/api/login",
               body: JSON.stringify({ username: unifi_username, password: unifi_password }),
               headers: { 'Content-Type': 'application/json' }
           }).catch((e) => { dlog("login: reject"), reject(e) });
           
           if(resp != null) {
               dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
               if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                   let set_cookies = resp.headers["set-cookie"];
                   for(i = 0; i < set_cookies.length; i++) {
                       let cookie = set_cookies[i];
                       cookie = cookie.split(";")[0];
                       cookies.push(cookie);
                   }
               } else {
                   dlog("login: no cookies to set!")
               }
               loggedIn = true;
               resolve();
           } else {
               dlog("login: rejected")
               reject("resp = null");
           }
       });
    }
     
    async function getStatus() {
        return new Promise(async (resolve, reject) => {
            dlog("nur mal so");
            if(!loggedIn) await login().catch((e) => reject(e));
            let resp = await request.get({
                url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                headers: { Cookie: cookies.join("; ") }
            }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
        
    dlog("got response " + JSON.stringify(resp));
    dlog(typeof resp);
    resp = JSON.parse(resp);
    dlog(resp.meta);
    dlog(resp.meta.rc);
            
            let wlanOn = resp.data[0].enabled;
            dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
            setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
            if(resp != null && resp.meta && resp.meta.rc == "ok") {
                dlog("Status erfolgreich geholt!");
                dlog(resp);
                let wlanOn = resp.data[0].enabled;
                dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                
                resolve(wlanOn);
            } else {
                dlog("nicht ok...")
                
                reject(JSON.stringify(resp));
            }
        });
    }
    
    
      async function getClients() {
    
        
        return new Promise(async (resolve, reject) => {
            dlog("nur mal so");
            if(!loggedIn) await login().catch((e) => reject(e));
            let resp = await request.get({
                url: unifi_controller + "/api/s/default/stat/sta/",
                headers: { Cookie: cookies.join("; ") }
            }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
       
    dlog("got response " + JSON.stringify(resp));
    dlog(typeof resp);
    dlog("--------------------- " + resp);
    resp = JSON.parse(resp);
    dlog(resp.meta);
    dlog(resp.meta.rc);
    dlog(resp.data[2].hostname);
    dlog(resp.data.length);
    var anzahlClients = resp.data.length;
     setState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients);
    
    
    var clientListe = "";
    getExistingClients();
    
    //erstelle aktuelles array
    
    listeDatenpunkteNew=[];
    for (var i = 0; i < resp.data.length; i++) { 
        listeDatenpunkteNew[i] = resp.data[i].hostname;}
       
    
    // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
    dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
    if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
    dlog("ClientTable "+writeClientTable.toString());
    dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
    
    
    // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
    if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
    dlog("writeAnwesenheit "+writeAnwesenheit.toString());
    dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
    
    // erstelle htmlclientliste wenn listenDaten verändert  
         if ( writeClientTable ) {
          for (var i = 0; i < resp.data.length; i++)  {
            dlog(resp.data[i].hostname + " --- " + resp.data[i].essid + " --- " + resp.data[i].mac);
            clientListe = clientListe.concat("<tr><td>"+resp.data[i].hostname+"&ensp;</td><td>"+resp.data[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].mac+"</td></tr>");
            dlog(clientListe);
            var ipWandler= resp.data[i].ip;
            if (anwesenheit && writeAnwesenheit) {
               createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, {
               name: ipWandler, 
               role: 'boolean',
               read:  true, 
               write: true,
               });
            }
          
          if (anwesenheit && listeDatenpunkteNew.indexOf(resp.data[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
            dlog("gefunden"+resp.data[i].hostname);
            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, true, 300);}
      } }
          
      
    if (anwesenheit) {
    for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
     if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
         dlog("nicht gefunden"+listeDatenpunkte[b]);
         setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 300);}}}
    
    if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl angemeldeteClients:"+resp.data.length+"</p>"));
    
    dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
    if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
    });
    
    }
    
    function getExistingClients() {
     listeDatenpunkte = [];
    
     var cacheSelectorState = $('state[state.id=javascript.2.WLANUnifi.Wifi_Client_States.*]');
       cacheSelectorState.each(function (id, c) {
         if (!id.includes("undefined")) {
          listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
    });
    }
    
    
    
    async function getVouchers() {
        return new Promise(async (resolve, reject) => {
            dlog("nur mal so");
            if(!loggedIn) await login().catch((e) => reject(e));
            let resp = await request.get({
                url: unifi_controller + "/api/s/default/stat/voucher",
                headers: { Cookie: cookies.join("; ") }
            }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
       
    dlog("got response " + JSON.stringify(resp));
    dlog(typeof resp);
    dlog("--------------------- " + resp);
    resp = JSON.parse(resp);
    
    dlog(resp.meta);
    dlog(resp.meta.rc);
    dlog(resp.data[1].code);
    dlog(resp.data.length);
    dlog(JSON.stringify(resp).length.toString());
    var laengeMessage=JSON.stringify(resp).length;
    if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
    writeFileVar=JSON.stringify(resp).length;
    
    if (writeFile) {
    var clientListe = "<tr><td>DURATION&ensp;</td><td>STATUSEXPIRES&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
    
    for (var i = 1; i < 21; i++) { 
        var x=i.toString();
        if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
        
    for (var i = 0; i < resp.data.length; i++) { 
       var zeit= resp.data[i].create_time*1000
       let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
    
       clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
       var y=i+1; 
       var yy=y.toString();
       if (y<10 )  yy="0"+yy;
      
       if (i<20  )  {
           dlog(zeit1);
           setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
           setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".duration", resp.data[i].duration );
           setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".expires", resp.data[i].status_expires );
           setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy, resp.data[i].code );
       }}
    }
    if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl Vouchers:"+resp.data.length+"</p>"));}
    if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
    if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
    });
    
    }
     
    async function dlogout() {
       return new Promise(async (resolve, reject) => {
           let resp = await request.get({
               url: unifi_controller + "/dlogout",
               headers: { Cookie: cookies.join("; ") }
           }).catch((e) => reject(e));
           if(resp != null) {
               dlog("Du bist nun ausgedloggt.");
               dlog(resp);
               resolve();
           } else {
               reject("resp = null");
           }
       });
    }
     
    async function setWifi(enabled) {
       return new Promise(async (resolve, reject) => {
           dlog("setWifi: start set wifi");
           if(!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
           dlog("setWifi: now setting wifi");
           let resp = request.post({
               url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi_id,
               body: JSON.stringify({ enabled }),
               headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
           }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
           dlog("setWifi: got response")
           if(resp != null) {
               dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
               dlog(resp);
               resolve();
           } else {
               dlog("setWifi: rejetced")
               dlog("resp: " + JSON.stringify(resp));
               reject("msg: " + JSON.parse(resp.body).meta.msg);
           }
       });
    }
    
    
    
     
    async function test() {
       dlog("starting test");
       await setWifi(false).catch((e) => dlog("reject1: " + e));
       dlog("getting status");
       let wlan = await getStatus().catch((e) => dlog("reject2: " + e));
       console.log("fin")
       console.log(wlan);
    }
    
    setInterval(async () => {
       await getStatus();
        setTimeout(function () {
       getClients();
            }, 2000);
            setTimeout(function () {
      if (vouchers) getVouchers();
        }, 5000);
    }, 20000); // Aktualisiert alle 20 Minuten.
    
    
    on(dpPrefix + "WLANUnifi.Wifi_an", (state) => {
        setWifi(true);
        setTimeout(function () {
            getStatus();
            setState(dpPrefix + "WLANUnifi.Wifi_an", false);
    }, 10000);
    });
    on(dpPrefix + "WLANUnifi.Wifi_aus", (state) => {
        setWifi(false);
        setTimeout(function () {
          getStatus();   
           setState(dpPrefix + "WLANUnifi.Wifi_aus", false);
    }, 12000);
    });
    
    //test();
    

    evtl kommt noch die "zweite netzwerk" sache dazu - kann ich nicht garantieren

    • wer will - bitte testen und kurzes feedback - ob es läuft

    clients in iqontrol:

    Image 3.png
    voucher in iqontrol:
    Image 4.png
    sieht so aus:
    Image 5.png

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

    @thewhobox

    hi versuche gerade deine tricks zu implementieren

    dieser abschnitt funktioniert nicht - könntest du mir da helfen

    //Reagiert auf manuelle änderungen vom Datenpunkt
    //ACK muss false sein!
    on({ id: wifiDPs, ack: false }, (dp) => {
        log("yes");
       let wlan_id = dp.id.substring(dp.id.lastIndexOf(".")+1);
       log("State Changed: " + wlan_id);
       setWifi(dp.state.val, wifis[wlan_id].id);
    });
    
    

    rein theoretisch müßte doch beim setzen eines der netzwerke auf true das log "yes" erscheinen macht es aber nicht - was könnte der fehler sein

    weiter oben wird ja ein array mit den id's erzeugt

    //Erstelle Datenpunkte für die WLANs automatisch
    for(let wifi_name in wifis) {
       wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].id);
        dlog(wifiDPs[1]);
        createState(dpPrefix + "WLANUnifi."+ wifi_name, {
           name: wifis[wifi_name].desc,
           role: 'state',
           read: true,
           write: true,
           type: "boolean",
           smartName: {
               de: wifis[wifi_name].smart,
               smartType: "SWITCH"
           }
       });
    }
    

    aber getriggeret wird nicht

    nachtrag:
    was geht ist das ein/ausschalten von "hand" z.b :

     setWifi(true, wifis.WLAN_01_Guest);
    

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

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

      hab mal das script auf meine bedürfnisse angepaßt

      • die neuen änderungen von thehowbox sind nicht integriert - auch kein zweites netzwerk
      • möglichkeit für iqontrol anzeige(als popup) und formatierung ist integriert
      • standardmäßig wird eine tabelle für clients und voucher erzeugt
      • auf wunsch kann eine anwesenheitskontrolle eingeschaltet werden - alle unifi clients bekommen einen datenpunkt (ähnlich wie im ping adapter)
      • voucher abfrage kann aktiviert werden
      • standard pfad für datenpunkt-verzeichnispfad kann eingestellt werden (falls man schon ein laufendes script hat kann hier ein neuer datenpfad konfiguriert werden
      • es werden nur updates geschrieben (für clients, vouchers (datenpunkte /file)) , um zu verhindern, dass dauernd etwas geschrieben oder brechnet wird
        falls man das script und existierende datenpunkte hat - bitte alle datenpunkte löschen !!!

      
      
      const unifi_username = "xxxxxx";
      const unifi_password = "xxxxxxxxx!";
      const unifi_controller = "https://192.xxx.xxx.xxx:8443";
      const wifi_id = "xxxnnnnaaaaakkkkkkaaaa";
      
      const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
      var fs = require('fs')
      const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
      const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
      let writeFile = true;
      let  writeFileVar = 0;
      let writeClientTable = true;
      let writeAnwesenheit = true;
      let listeDatenpunkte = [];
      let listeDatenpunkteNew = [];
      let listeDatenpunkteAlt = [];
      
      // Datenpunkte Hauptpfad wählen
      const dpPrefix = "javascript.2.";
      
      //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
      let  iqontrol = false;
      let  anwesenheit = false; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects löschen
      let vouchers = false;
      
      // Hier Definition iqontrol-Style für Popup
      const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
      const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
      let cookies = [];
      let loggedIn = false;
      let debug = false;
      
      if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
      if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
      
      //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
      
      //Datenpunkt für Wifi Status erstellen
      createState(dpPrefix + "WLANUnifi.Wifi_Status", {
          name: 'Unifi Wifi Status', 
          role: 'boolean',
          read:  true, 
          write: true,
      });
       
      //Datenpunkt Button für Wifi an erstellen
      createState(dpPrefix + "WLANUnifi.Wifi_an", {
          name: 'Unifi Wifi an', 
          role: 'switch',
          read:  true, 
          write: true,
          type: "boolean",
          "smartName": {
          "de": "02Gäste Wlan an",
          "smartType": "SWITCH"
      }
      });
         setStateDelayed(dpPrefix + "WLANUnifi.Wifi_an", false, 300);
       
      //Datenpunkt Button für Wifi aus erstellen
      createState(dpPrefix + "WLANUnifi.Wifi_aus", {
          name: 'Unifi Wifi aus', 
          role: 'switch',
          read:  true, 
          write: true,
          type: "boolean",
          "smartName": {
          "de": "03Gäste Wlan aus",
          "smartType": "SWITCH"
      }
      });
         setStateDelayed(dpPrefix + "WLANUnifi.Wifi_aus", false, 300);
      
      if (true) {
      createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
          name: 'Unifi Wifi Clients Table', 
          role: 'string',
          read:  true, 
          write: true,
      });}
      
      
      if (vouchers) {
      createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
          name: 'Unifi Wifi Vouchers', 
          role: 'string',
          read:  true, 
          write: true,
      });
      
      for (var i = 1; i < 21; i++) { 
          var x=i.toString();
          if (i<10) x="0"+x;
         createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
          name: 'Unifi Voucher_Code'+x, 
          role: 'string',
          read:  true, 
          write: true,
          });
      createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
          name: 'Unifi Voucher_Code_erstellt'+x, 
          role: 'string',
          read:  true, 
          write: true,
          });
      createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".duration", {
          name: 'Unifi Voucher_Code_duration'+x, 
          role: 'string',
          read:  true, 
          write: true,
          });
      createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".expires", {
          name: 'Unifi Voucher_Code_expires'+x, 
          role: 'string',
          read:  true, 
          write: true,
          });
      }}
       
      createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
      if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
       
      function dlog(message) {
         if(debug)
             console.log(message);
      }
       
      async function login() {
         return new Promise(async (resolve, reject) => {
             let resp = await request.post({
                 resolveWithFullResponse: true,
                 url: unifi_controller + "/api/login",
                 body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                 headers: { 'Content-Type': 'application/json' }
             }).catch((e) => { dlog("login: reject"), reject(e) });
             
             if(resp != null) {
                 dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                 if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                     let set_cookies = resp.headers["set-cookie"];
                     for(i = 0; i < set_cookies.length; i++) {
                         let cookie = set_cookies[i];
                         cookie = cookie.split(";")[0];
                         cookies.push(cookie);
                     }
                 } else {
                     dlog("login: no cookies to set!")
                 }
                 loggedIn = true;
                 resolve();
             } else {
                 dlog("login: rejected")
                 reject("resp = null");
             }
         });
      }
       
      async function getStatus() {
          return new Promise(async (resolve, reject) => {
              dlog("nur mal so");
              if(!loggedIn) await login().catch((e) => reject(e));
              let resp = await request.get({
                  url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                  headers: { Cookie: cookies.join("; ") }
              }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
          
      dlog("got response " + JSON.stringify(resp));
      dlog(typeof resp);
      resp = JSON.parse(resp);
      dlog(resp.meta);
      dlog(resp.meta.rc);
              
              let wlanOn = resp.data[0].enabled;
              dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
              setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
              if(resp != null && resp.meta && resp.meta.rc == "ok") {
                  dlog("Status erfolgreich geholt!");
                  dlog(resp);
                  let wlanOn = resp.data[0].enabled;
                  dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                  setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                  
                  resolve(wlanOn);
              } else {
                  dlog("nicht ok...")
                  
                  reject(JSON.stringify(resp));
              }
          });
      }
      
      
        async function getClients() {
      
          
          return new Promise(async (resolve, reject) => {
              dlog("nur mal so");
              if(!loggedIn) await login().catch((e) => reject(e));
              let resp = await request.get({
                  url: unifi_controller + "/api/s/default/stat/sta/",
                  headers: { Cookie: cookies.join("; ") }
              }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
         
      dlog("got response " + JSON.stringify(resp));
      dlog(typeof resp);
      dlog("--------------------- " + resp);
      resp = JSON.parse(resp);
      dlog(resp.meta);
      dlog(resp.meta.rc);
      dlog(resp.data[2].hostname);
      dlog(resp.data.length);
      var anzahlClients = resp.data.length;
       setState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients);
      
      
      var clientListe = "";
      getExistingClients();
      
      //erstelle aktuelles array
      
      listeDatenpunkteNew=[];
      for (var i = 0; i < resp.data.length; i++) { 
          listeDatenpunkteNew[i] = resp.data[i].hostname;}
         
      
      // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
      dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
      if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
      dlog("ClientTable "+writeClientTable.toString());
      dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
      
      
      // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
      if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
      dlog("writeAnwesenheit "+writeAnwesenheit.toString());
      dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
      
      // erstelle htmlclientliste wenn listenDaten verändert  
           if ( writeClientTable ) {
            for (var i = 0; i < resp.data.length; i++)  {
              dlog(resp.data[i].hostname + " --- " + resp.data[i].essid + " --- " + resp.data[i].mac);
              clientListe = clientListe.concat("<tr><td>"+resp.data[i].hostname+"&ensp;</td><td>"+resp.data[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].mac+"</td></tr>");
              dlog(clientListe);
              var ipWandler= resp.data[i].ip;
              if (anwesenheit && writeAnwesenheit) {
                 createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, {
                 name: ipWandler, 
                 role: 'boolean',
                 read:  true, 
                 write: true,
                 });
              }
            
            if (anwesenheit && listeDatenpunkteNew.indexOf(resp.data[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
              dlog("gefunden"+resp.data[i].hostname);
              setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, true, 300);}
        } }
            
        
      if (anwesenheit) {
      for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
       if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
           dlog("nicht gefunden"+listeDatenpunkte[b]);
           setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 300);}}}
      
      if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl angemeldeteClients:"+resp.data.length+"</p>"));
      
      dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
      if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
      });
      
      }
      
      function getExistingClients() {
       listeDatenpunkte = [];
      
       var cacheSelectorState = $('state[state.id=javascript.2.WLANUnifi.Wifi_Client_States.*]');
         cacheSelectorState.each(function (id, c) {
           if (!id.includes("undefined")) {
            listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
      });
      }
      
      
      
      async function getVouchers() {
          return new Promise(async (resolve, reject) => {
              dlog("nur mal so");
              if(!loggedIn) await login().catch((e) => reject(e));
              let resp = await request.get({
                  url: unifi_controller + "/api/s/default/stat/voucher",
                  headers: { Cookie: cookies.join("; ") }
              }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
         
      dlog("got response " + JSON.stringify(resp));
      dlog(typeof resp);
      dlog("--------------------- " + resp);
      resp = JSON.parse(resp);
      
      dlog(resp.meta);
      dlog(resp.meta.rc);
      dlog(resp.data[1].code);
      dlog(resp.data.length);
      dlog(JSON.stringify(resp).length.toString());
      var laengeMessage=JSON.stringify(resp).length;
      if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
      writeFileVar=JSON.stringify(resp).length;
      
      if (writeFile) {
      var clientListe = "<tr><td>DURATION&ensp;</td><td>STATUSEXPIRES&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
      
      for (var i = 1; i < 21; i++) { 
          var x=i.toString();
          if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
          
      for (var i = 0; i < resp.data.length; i++) { 
         var zeit= resp.data[i].create_time*1000
         let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
      
         clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
         var y=i+1; 
         var yy=y.toString();
         if (y<10 )  yy="0"+yy;
        
         if (i<20  )  {
             dlog(zeit1);
             setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
             setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".duration", resp.data[i].duration );
             setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".expires", resp.data[i].status_expires );
             setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy, resp.data[i].code );
         }}
      }
      if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl Vouchers:"+resp.data.length+"</p>"));}
      if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
      if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
      });
      
      }
       
      async function dlogout() {
         return new Promise(async (resolve, reject) => {
             let resp = await request.get({
                 url: unifi_controller + "/dlogout",
                 headers: { Cookie: cookies.join("; ") }
             }).catch((e) => reject(e));
             if(resp != null) {
                 dlog("Du bist nun ausgedloggt.");
                 dlog(resp);
                 resolve();
             } else {
                 reject("resp = null");
             }
         });
      }
       
      async function setWifi(enabled) {
         return new Promise(async (resolve, reject) => {
             dlog("setWifi: start set wifi");
             if(!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
             dlog("setWifi: now setting wifi");
             let resp = request.post({
                 url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi_id,
                 body: JSON.stringify({ enabled }),
                 headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
             }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
             dlog("setWifi: got response")
             if(resp != null) {
                 dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                 dlog(resp);
                 resolve();
             } else {
                 dlog("setWifi: rejetced")
                 dlog("resp: " + JSON.stringify(resp));
                 reject("msg: " + JSON.parse(resp.body).meta.msg);
             }
         });
      }
      
      
      
       
      async function test() {
         dlog("starting test");
         await setWifi(false).catch((e) => dlog("reject1: " + e));
         dlog("getting status");
         let wlan = await getStatus().catch((e) => dlog("reject2: " + e));
         console.log("fin")
         console.log(wlan);
      }
      
      setInterval(async () => {
         await getStatus();
          setTimeout(function () {
         getClients();
              }, 2000);
              setTimeout(function () {
        if (vouchers) getVouchers();
          }, 5000);
      }, 20000); // Aktualisiert alle 20 Minuten.
      
      
      on(dpPrefix + "WLANUnifi.Wifi_an", (state) => {
          setWifi(true);
          setTimeout(function () {
              getStatus();
              setState(dpPrefix + "WLANUnifi.Wifi_an", false);
      }, 10000);
      });
      on(dpPrefix + "WLANUnifi.Wifi_aus", (state) => {
          setWifi(false);
          setTimeout(function () {
            getStatus();   
             setState(dpPrefix + "WLANUnifi.Wifi_aus", false);
      }, 12000);
      });
      
      //test();
      

      evtl kommt noch die "zweite netzwerk" sache dazu - kann ich nicht garantieren

      • wer will - bitte testen und kurzes feedback - ob es läuft

      clients in iqontrol:

      Image 3.png
      voucher in iqontrol:
      Image 4.png
      sieht so aus:
      Image 5.png

      dslraserD Offline
      dslraserD Offline
      dslraser
      Forum Testing Most Active
      schrieb am zuletzt editiert von
      #104

      @liv-in-sky
      Ich bin wieder zu Hause und habe gleich mal den Rechner angemacht:face_with_cowboy_hat:
      ich habe Dein Script 1:1 übernommen und es läuft alles ! Prima Arbeit:+1:
      Aus den Button hast Du Switch gemacht, dann würde ja eigentlich auch einer reichen ? Also einer für an/aus. Ich habe es für mich nur leicht abgewandelt, ich habe in den Datenpunkten das "Wifi" entfernt, da ich es gern unter Unifi finden möchte.
      iQontrol als PopUp und iframe läuft auch, top!

      Soll ich Deine Variante in den ersten Beitrag stellen ? Bzw., soll ich die vorerst finale Variante immer oben im ersten Beitrag einfügen ? (lässt sich dann für die Nachwelt besser finden ? )

      liv-in-skyL 1 Antwort Letzte Antwort
      0
      • dslraserD dslraser

        @liv-in-sky
        Ich bin wieder zu Hause und habe gleich mal den Rechner angemacht:face_with_cowboy_hat:
        ich habe Dein Script 1:1 übernommen und es läuft alles ! Prima Arbeit:+1:
        Aus den Button hast Du Switch gemacht, dann würde ja eigentlich auch einer reichen ? Also einer für an/aus. Ich habe es für mich nur leicht abgewandelt, ich habe in den Datenpunkten das "Wifi" entfernt, da ich es gern unter Unifi finden möchte.
        iQontrol als PopUp und iframe läuft auch, top!

        Soll ich Deine Variante in den ersten Beitrag stellen ? Bzw., soll ich die vorerst finale Variante immer oben im ersten Beitrag einfügen ? (lässt sich dann für die Nachwelt besser finden ? )

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

        @dslraser hi - danke für's feedback
        ich bin noch am integrieren - mehrere wlans werden schon angezeigt (status) - aber leider das ein-ausschalten check ich nicht (wußte nicht mal, dass man auf ein array triggern kann - siehe letzten post von mir - warte doch noch ein wenig mit dem einstellen auf die erste seite - vielleicht antwortet thewhobox noch und ich kann das fertigmachen - immer hin geht das ein/ausschalten von hand

        wenn du die iqontrol popups anders formatiert willst - einfach ein paar ideen einbringen - (farbe, ...) - dann schau'n wir was geht

        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

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

          @dslraser hi - danke für's feedback
          ich bin noch am integrieren - mehrere wlans werden schon angezeigt (status) - aber leider das ein-ausschalten check ich nicht (wußte nicht mal, dass man auf ein array triggern kann - siehe letzten post von mir - warte doch noch ein wenig mit dem einstellen auf die erste seite - vielleicht antwortet thewhobox noch und ich kann das fertigmachen - immer hin geht das ein/ausschalten von hand

          wenn du die iqontrol popups anders formatiert willst - einfach ein paar ideen einbringen - (farbe, ...) - dann schau'n wir was geht

          dslraserD Offline
          dslraserD Offline
          dslraser
          Forum Testing Most Active
          schrieb am zuletzt editiert von
          #106

          @liv-in-sky sagte in Unifi WLAN Script:

          wenn du die iqontrol popups anders formatiert willst - einfach ein paar ideen einbringen - (farbe, ...) - dann schau'n wir was geht

          schön wären deutsche Begriffe an dieser Stelle.

          DURATION  STATUSEXPIRES

          aber leider das ein-ausschalten check ich nicht

          das habe ich weiter oben auch schon gefragt, na mal sehen...

          liv-in-skyL 1 Antwort Letzte Antwort
          0
          • dslraserD dslraser

            @liv-in-sky sagte in Unifi WLAN Script:

            wenn du die iqontrol popups anders formatiert willst - einfach ein paar ideen einbringen - (farbe, ...) - dann schau'n wir was geht

            schön wären deutsche Begriffe an dieser Stelle.

            DURATION  STATUSEXPIRES

            aber leider das ein-ausschalten check ich nicht

            das habe ich weiter oben auch schon gefragt, na mal sehen...

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

            @dslraser

            duration = dauer
            statusexpires = ablaufstatus ????

            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

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

              @dslraser

              duration = dauer
              statusexpires = ablaufstatus ????

              dslraserD Offline
              dslraserD Offline
              dslraser
              Forum Testing Most Active
              schrieb am zuletzt editiert von
              #108

              @liv-in-sky sagte in Unifi WLAN Script:

              statusexpires

              Bildschirmfoto 2019-09-01 um 20.44.04.png

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

                hab mal das script auf meine bedürfnisse angepaßt

                • die neuen änderungen von thehowbox sind nicht integriert - auch kein zweites netzwerk
                • möglichkeit für iqontrol anzeige(als popup) und formatierung ist integriert
                • standardmäßig wird eine tabelle für clients und voucher erzeugt
                • auf wunsch kann eine anwesenheitskontrolle eingeschaltet werden - alle unifi clients bekommen einen datenpunkt (ähnlich wie im ping adapter)
                • voucher abfrage kann aktiviert werden
                • standard pfad für datenpunkt-verzeichnispfad kann eingestellt werden (falls man schon ein laufendes script hat kann hier ein neuer datenpfad konfiguriert werden
                • es werden nur updates geschrieben (für clients, vouchers (datenpunkte /file)) , um zu verhindern, dass dauernd etwas geschrieben oder brechnet wird
                  falls man das script und existierende datenpunkte hat - bitte alle datenpunkte löschen !!!

                
                
                const unifi_username = "xxxxxx";
                const unifi_password = "xxxxxxxxx!";
                const unifi_controller = "https://192.xxx.xxx.xxx:8443";
                const wifi_id = "xxxnnnnaaaaakkkkkkaaaa";
                
                const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                var fs = require('fs')
                const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
                const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
                let writeFile = true;
                let  writeFileVar = 0;
                let writeClientTable = true;
                let writeAnwesenheit = true;
                let listeDatenpunkte = [];
                let listeDatenpunkteNew = [];
                let listeDatenpunkteAlt = [];
                
                // Datenpunkte Hauptpfad wählen
                const dpPrefix = "javascript.2.";
                
                //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
                let  iqontrol = false;
                let  anwesenheit = false; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects löschen
                let vouchers = false;
                
                // Hier Definition iqontrol-Style für Popup
                const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                let cookies = [];
                let loggedIn = false;
                let debug = false;
                
                if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                
                //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                
                //Datenpunkt für Wifi Status erstellen
                createState(dpPrefix + "WLANUnifi.Wifi_Status", {
                    name: 'Unifi Wifi Status', 
                    role: 'boolean',
                    read:  true, 
                    write: true,
                });
                 
                //Datenpunkt Button für Wifi an erstellen
                createState(dpPrefix + "WLANUnifi.Wifi_an", {
                    name: 'Unifi Wifi an', 
                    role: 'switch',
                    read:  true, 
                    write: true,
                    type: "boolean",
                    "smartName": {
                    "de": "02Gäste Wlan an",
                    "smartType": "SWITCH"
                }
                });
                   setStateDelayed(dpPrefix + "WLANUnifi.Wifi_an", false, 300);
                 
                //Datenpunkt Button für Wifi aus erstellen
                createState(dpPrefix + "WLANUnifi.Wifi_aus", {
                    name: 'Unifi Wifi aus', 
                    role: 'switch',
                    read:  true, 
                    write: true,
                    type: "boolean",
                    "smartName": {
                    "de": "03Gäste Wlan aus",
                    "smartType": "SWITCH"
                }
                });
                   setStateDelayed(dpPrefix + "WLANUnifi.Wifi_aus", false, 300);
                
                if (true) {
                createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
                    name: 'Unifi Wifi Clients Table', 
                    role: 'string',
                    read:  true, 
                    write: true,
                });}
                
                
                if (vouchers) {
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
                    name: 'Unifi Wifi Vouchers', 
                    role: 'string',
                    read:  true, 
                    write: true,
                });
                
                for (var i = 1; i < 21; i++) { 
                    var x=i.toString();
                    if (i<10) x="0"+x;
                   createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
                    name: 'Unifi Voucher_Code'+x, 
                    role: 'string',
                    read:  true, 
                    write: true,
                    });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
                    name: 'Unifi Voucher_Code_erstellt'+x, 
                    role: 'string',
                    read:  true, 
                    write: true,
                    });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".duration", {
                    name: 'Unifi Voucher_Code_duration'+x, 
                    role: 'string',
                    read:  true, 
                    write: true,
                    });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".expires", {
                    name: 'Unifi Voucher_Code_expires'+x, 
                    role: 'string',
                    read:  true, 
                    write: true,
                    });
                }}
                 
                createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                 
                function dlog(message) {
                   if(debug)
                       console.log(message);
                }
                 
                async function login() {
                   return new Promise(async (resolve, reject) => {
                       let resp = await request.post({
                           resolveWithFullResponse: true,
                           url: unifi_controller + "/api/login",
                           body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                           headers: { 'Content-Type': 'application/json' }
                       }).catch((e) => { dlog("login: reject"), reject(e) });
                       
                       if(resp != null) {
                           dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                           if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                               let set_cookies = resp.headers["set-cookie"];
                               for(i = 0; i < set_cookies.length; i++) {
                                   let cookie = set_cookies[i];
                                   cookie = cookie.split(";")[0];
                                   cookies.push(cookie);
                               }
                           } else {
                               dlog("login: no cookies to set!")
                           }
                           loggedIn = true;
                           resolve();
                       } else {
                           dlog("login: rejected")
                           reject("resp = null");
                       }
                   });
                }
                 
                async function getStatus() {
                    return new Promise(async (resolve, reject) => {
                        dlog("nur mal so");
                        if(!loggedIn) await login().catch((e) => reject(e));
                        let resp = await request.get({
                            url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                            headers: { Cookie: cookies.join("; ") }
                        }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
                    
                dlog("got response " + JSON.stringify(resp));
                dlog(typeof resp);
                resp = JSON.parse(resp);
                dlog(resp.meta);
                dlog(resp.meta.rc);
                        
                        let wlanOn = resp.data[0].enabled;
                        dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                        setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                        if(resp != null && resp.meta && resp.meta.rc == "ok") {
                            dlog("Status erfolgreich geholt!");
                            dlog(resp);
                            let wlanOn = resp.data[0].enabled;
                            dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                            setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                            
                            resolve(wlanOn);
                        } else {
                            dlog("nicht ok...")
                            
                            reject(JSON.stringify(resp));
                        }
                    });
                }
                
                
                  async function getClients() {
                
                    
                    return new Promise(async (resolve, reject) => {
                        dlog("nur mal so");
                        if(!loggedIn) await login().catch((e) => reject(e));
                        let resp = await request.get({
                            url: unifi_controller + "/api/s/default/stat/sta/",
                            headers: { Cookie: cookies.join("; ") }
                        }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                   
                dlog("got response " + JSON.stringify(resp));
                dlog(typeof resp);
                dlog("--------------------- " + resp);
                resp = JSON.parse(resp);
                dlog(resp.meta);
                dlog(resp.meta.rc);
                dlog(resp.data[2].hostname);
                dlog(resp.data.length);
                var anzahlClients = resp.data.length;
                 setState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients);
                
                
                var clientListe = "";
                getExistingClients();
                
                //erstelle aktuelles array
                
                listeDatenpunkteNew=[];
                for (var i = 0; i < resp.data.length; i++) { 
                    listeDatenpunkteNew[i] = resp.data[i].hostname;}
                   
                
                // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
                dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
                if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
                dlog("ClientTable "+writeClientTable.toString());
                dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
                
                
                // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
                if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
                dlog("writeAnwesenheit "+writeAnwesenheit.toString());
                dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
                
                // erstelle htmlclientliste wenn listenDaten verändert  
                     if ( writeClientTable ) {
                      for (var i = 0; i < resp.data.length; i++)  {
                        dlog(resp.data[i].hostname + " --- " + resp.data[i].essid + " --- " + resp.data[i].mac);
                        clientListe = clientListe.concat("<tr><td>"+resp.data[i].hostname+"&ensp;</td><td>"+resp.data[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].mac+"</td></tr>");
                        dlog(clientListe);
                        var ipWandler= resp.data[i].ip;
                        if (anwesenheit && writeAnwesenheit) {
                           createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, {
                           name: ipWandler, 
                           role: 'boolean',
                           read:  true, 
                           write: true,
                           });
                        }
                      
                      if (anwesenheit && listeDatenpunkteNew.indexOf(resp.data[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
                        dlog("gefunden"+resp.data[i].hostname);
                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, true, 300);}
                  } }
                      
                  
                if (anwesenheit) {
                for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
                 if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
                     dlog("nicht gefunden"+listeDatenpunkte[b]);
                     setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 300);}}}
                
                if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl angemeldeteClients:"+resp.data.length+"</p>"));
                
                dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                });
                
                }
                
                function getExistingClients() {
                 listeDatenpunkte = [];
                
                 var cacheSelectorState = $('state[state.id=javascript.2.WLANUnifi.Wifi_Client_States.*]');
                   cacheSelectorState.each(function (id, c) {
                     if (!id.includes("undefined")) {
                      listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
                });
                }
                
                
                
                async function getVouchers() {
                    return new Promise(async (resolve, reject) => {
                        dlog("nur mal so");
                        if(!loggedIn) await login().catch((e) => reject(e));
                        let resp = await request.get({
                            url: unifi_controller + "/api/s/default/stat/voucher",
                            headers: { Cookie: cookies.join("; ") }
                        }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                   
                dlog("got response " + JSON.stringify(resp));
                dlog(typeof resp);
                dlog("--------------------- " + resp);
                resp = JSON.parse(resp);
                
                dlog(resp.meta);
                dlog(resp.meta.rc);
                dlog(resp.data[1].code);
                dlog(resp.data.length);
                dlog(JSON.stringify(resp).length.toString());
                var laengeMessage=JSON.stringify(resp).length;
                if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                writeFileVar=JSON.stringify(resp).length;
                
                if (writeFile) {
                var clientListe = "<tr><td>DURATION&ensp;</td><td>STATUSEXPIRES&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                
                for (var i = 1; i < 21; i++) { 
                    var x=i.toString();
                    if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
                    
                for (var i = 0; i < resp.data.length; i++) { 
                   var zeit= resp.data[i].create_time*1000
                   let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                
                   clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                   var y=i+1; 
                   var yy=y.toString();
                   if (y<10 )  yy="0"+yy;
                  
                   if (i<20  )  {
                       dlog(zeit1);
                       setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                       setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".duration", resp.data[i].duration );
                       setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".expires", resp.data[i].status_expires );
                       setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy, resp.data[i].code );
                   }}
                }
                if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl Vouchers:"+resp.data.length+"</p>"));}
                if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
                if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
                });
                
                }
                 
                async function dlogout() {
                   return new Promise(async (resolve, reject) => {
                       let resp = await request.get({
                           url: unifi_controller + "/dlogout",
                           headers: { Cookie: cookies.join("; ") }
                       }).catch((e) => reject(e));
                       if(resp != null) {
                           dlog("Du bist nun ausgedloggt.");
                           dlog(resp);
                           resolve();
                       } else {
                           reject("resp = null");
                       }
                   });
                }
                 
                async function setWifi(enabled) {
                   return new Promise(async (resolve, reject) => {
                       dlog("setWifi: start set wifi");
                       if(!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                       dlog("setWifi: now setting wifi");
                       let resp = request.post({
                           url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi_id,
                           body: JSON.stringify({ enabled }),
                           headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                       }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
                       dlog("setWifi: got response")
                       if(resp != null) {
                           dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                           dlog(resp);
                           resolve();
                       } else {
                           dlog("setWifi: rejetced")
                           dlog("resp: " + JSON.stringify(resp));
                           reject("msg: " + JSON.parse(resp.body).meta.msg);
                       }
                   });
                }
                
                
                
                 
                async function test() {
                   dlog("starting test");
                   await setWifi(false).catch((e) => dlog("reject1: " + e));
                   dlog("getting status");
                   let wlan = await getStatus().catch((e) => dlog("reject2: " + e));
                   console.log("fin")
                   console.log(wlan);
                }
                
                setInterval(async () => {
                   await getStatus();
                    setTimeout(function () {
                   getClients();
                        }, 2000);
                        setTimeout(function () {
                  if (vouchers) getVouchers();
                    }, 5000);
                }, 20000); // Aktualisiert alle 20 Minuten.
                
                
                on(dpPrefix + "WLANUnifi.Wifi_an", (state) => {
                    setWifi(true);
                    setTimeout(function () {
                        getStatus();
                        setState(dpPrefix + "WLANUnifi.Wifi_an", false);
                }, 10000);
                });
                on(dpPrefix + "WLANUnifi.Wifi_aus", (state) => {
                    setWifi(false);
                    setTimeout(function () {
                      getStatus();   
                       setState(dpPrefix + "WLANUnifi.Wifi_aus", false);
                }, 12000);
                });
                
                //test();
                

                evtl kommt noch die "zweite netzwerk" sache dazu - kann ich nicht garantieren

                • wer will - bitte testen und kurzes feedback - ob es läuft

                clients in iqontrol:

                Image 3.png
                voucher in iqontrol:
                Image 4.png
                sieht so aus:
                Image 5.png

                dslraserD Offline
                dslraserD Offline
                dslraser
                Forum Testing Most Active
                schrieb am zuletzt editiert von
                #109

                @liv-in-sky sagte in Unifi WLAN Script:

                auf wunsch kann eine anwesenheitskontrolle eingeschaltet werden - alle unifi clients bekommen einen datenpunkt (ähnlich wie im ping adapter)

                Die DP werden im Moment aber nicht aktualisiert, oder ?

                liv-in-skyL 1 Antwort Letzte Antwort
                0
                • dslraserD dslraser

                  @liv-in-sky sagte in Unifi WLAN Script:

                  statusexpires

                  Bildschirmfoto 2019-09-01 um 20.44.04.png

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

                  @dslraser

                  zu ändern - habe es auch übenrommen - zeile ungefähr 312- in der getVoucher() funktion - das hier einfügen

                  var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                  

                  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

                  dslraserD 1 Antwort Letzte Antwort
                  0
                  • dslraserD dslraser

                    @liv-in-sky sagte in Unifi WLAN Script:

                    auf wunsch kann eine anwesenheitskontrolle eingeschaltet werden - alle unifi clients bekommen einen datenpunkt (ähnlich wie im ping adapter)

                    Die DP werden im Moment aber nicht aktualisiert, oder ?

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

                    @dslraser sagte in Unifi WLAN Script:

                    @liv-in-sky sagte in Unifi WLAN Script:

                    auf wunsch kann eine anwesenheitskontrolle eingeschaltet werden - alle unifi clients bekommen einen datenpunkt (ähnlich wie im ping adapter)

                    Die DP werden im Moment aber nicht aktualisiert, oder ?

                    welche genau ?

                    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

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

                      @dslraser sagte in Unifi WLAN Script:

                      @liv-in-sky sagte in Unifi WLAN Script:

                      auf wunsch kann eine anwesenheitskontrolle eingeschaltet werden - alle unifi clients bekommen einen datenpunkt (ähnlich wie im ping adapter)

                      Die DP werden im Moment aber nicht aktualisiert, oder ?

                      welche genau ?

                      dslraserD Offline
                      dslraserD Offline
                      dslraser
                      Forum Testing Most Active
                      schrieb am zuletzt editiert von
                      #112

                      @liv-in-sky
                      Wifi_Client_State

                      oder hast Du da eine längere Zeit eingestellt ? Für eine Anwesenheitskontrolle sollte sich der Status direkt ändern, oder habe ich was falsch verstanden ?

                      liv-in-skyL 1 Antwort Letzte Antwort
                      0
                      • dslraserD dslraser

                        @liv-in-sky
                        Wifi_Client_State

                        oder hast Du da eine längere Zeit eingestellt ? Für eine Anwesenheitskontrolle sollte sich der Status direkt ändern, oder habe ich was falsch verstanden ?

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

                        @dslraser

                        du musst " anwesenheit" auf true setzen am scriptanfang - das problem - beim einloggen der geräte geht es schnell, dass man den neuen status bekommt- beim ausloggen aus dem wlan kann es mehrere minuten dauern bis der unifi controller das bemerkt - ich sage im controller imdu musst " anwesenheit" auf true setzen am scriptanfang - das problem - beim einloggen der geräte geht es schnell, dass man den neuen status bekommt- beim ausloggen aus dem wlan kann es mehrere minuten dauern bis der unifi controller das bemerkt - ich sage im controller immer gerät wiederverbinden - dann wird schnell geupdatetmer gerät wiederverbinden - dann wird schnell geupdatet

                        die werden nur upgedated wenn sich im wlan etwas an oder abgemeldet haben

                        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

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

                          @dslraser

                          du musst " anwesenheit" auf true setzen am scriptanfang - das problem - beim einloggen der geräte geht es schnell, dass man den neuen status bekommt- beim ausloggen aus dem wlan kann es mehrere minuten dauern bis der unifi controller das bemerkt - ich sage im controller imdu musst " anwesenheit" auf true setzen am scriptanfang - das problem - beim einloggen der geräte geht es schnell, dass man den neuen status bekommt- beim ausloggen aus dem wlan kann es mehrere minuten dauern bis der unifi controller das bemerkt - ich sage im controller immer gerät wiederverbinden - dann wird schnell geupdatetmer gerät wiederverbinden - dann wird schnell geupdatet

                          die werden nur upgedated wenn sich im wlan etwas an oder abgemeldet haben

                          dslraserD Offline
                          dslraserD Offline
                          dslraser
                          Forum Testing Most Active
                          schrieb am zuletzt editiert von
                          #114

                          @liv-in-sky
                          ich habe es gerade mal mit meinem Handy nachgestellt. Hier ist es raus, wenn es im Controller raus ist

                          Bildschirmfoto 2019-09-01 um 21.11.59.png

                          hier bleibt es true
                          Bildschirmfoto 2019-09-01 um 21.12.51.png

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

                            @dslraser

                            zu ändern - habe es auch übenrommen - zeile ungefähr 312- in der getVoucher() funktion - das hier einfügen

                            var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                            
                            dslraserD Offline
                            dslraserD Offline
                            dslraser
                            Forum Testing Most Active
                            schrieb am zuletzt editiert von dslraser
                            #115

                            @liv-in-sky sagte in Unifi WLAN Script:

                            var clientListe = "<tr><td>DAUER </td><td>STATUS-ABGELAUFEN    </td><td>CODE</td>  </td><td>ERSTELLT</td></tr> ";

                            damit wird aber in iQontrol noch nichts anderes angezeigt, welche stelle ist es für iQontrol ?

                            liv-in-skyL 1 Antwort Letzte Antwort
                            0
                            • dslraserD dslraser

                              @liv-in-sky sagte in Unifi WLAN Script:

                              var clientListe = "<tr><td>DAUER </td><td>STATUS-ABGELAUFEN    </td><td>CODE</td>  </td><td>ERSTELLT</td></tr> ";

                              damit wird aber in iQontrol noch nichts anderes angezeigt, welche stelle ist es für iQontrol ?

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

                              @dslraser

                              sorry - ich bin "überprogrammiert" - lass uns morgen weitermachen - heute geht nix mehr

                              nur noch eines -
                              du hast doch etwas geändert - ich hoffe beim ändern der datenpunkte ist nichts schiefgegangen

                              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

                              dslraserD 3 Antworten Letzte Antwort
                              0
                              • liv-in-skyL liv-in-sky

                                @dslraser

                                sorry - ich bin "überprogrammiert" - lass uns morgen weitermachen - heute geht nix mehr

                                nur noch eines -
                                du hast doch etwas geändert - ich hoffe beim ändern der datenpunkte ist nichts schiefgegangen

                                dslraserD Offline
                                dslraserD Offline
                                dslraser
                                Forum Testing Most Active
                                schrieb am zuletzt editiert von
                                #117

                                @liv-in-sky sagte in Unifi WLAN Script:

                                du hast doch etwas geändert - ich hoffe beim ändern der datenpunkte ist nichts schiefgegangen

                                ich habe nochmal Dein Script unverändert genommen, auch da bleiben die Geräte auf true (jedenfalls mein Handy), auch wenn es nicht mehr im WLAN ist.

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

                                  @dslraser

                                  sorry - ich bin "überprogrammiert" - lass uns morgen weitermachen - heute geht nix mehr

                                  nur noch eines -
                                  du hast doch etwas geändert - ich hoffe beim ändern der datenpunkte ist nichts schiefgegangen

                                  dslraserD Offline
                                  dslraserD Offline
                                  dslraser
                                  Forum Testing Most Active
                                  schrieb am zuletzt editiert von
                                  #118

                                  @liv-in-sky
                                  noch ein kurzes Feedback zu den Vouchern. Ich habe mich eben mal mit einem Voucher im Gäste WLAN angemeldet. Es wird nun bei der Anzahl korrekt einer weniger angezeigt. Der benutzte Voucher wird aber noch in der iQontol Liste angezeigt. Auch in den Datenpunkten werden noch genau so viele Objekte befüllt angezeigt wie vorher. Da passt irgendwas noch nicht.

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

                                    @dslraser

                                    sorry - ich bin "überprogrammiert" - lass uns morgen weitermachen - heute geht nix mehr

                                    nur noch eines -
                                    du hast doch etwas geändert - ich hoffe beim ändern der datenpunkte ist nichts schiefgegangen

                                    dslraserD Offline
                                    dslraserD Offline
                                    dslraser
                                    Forum Testing Most Active
                                    schrieb am zuletzt editiert von
                                    #119

                                    @liv-in-sky
                                    ach und noch was, die Voucher werden in den DP nicht angezeigt

                                    Bildschirmfoto 2019-09-01 um 22.43.43.png
                                    so sieht es bei mir aus

                                    dslraserD 1 Antwort Letzte Antwort
                                    0
                                    • dslraserD dslraser

                                      @liv-in-sky
                                      ach und noch was, die Voucher werden in den DP nicht angezeigt

                                      Bildschirmfoto 2019-09-01 um 22.43.43.png
                                      so sieht es bei mir aus

                                      dslraserD Offline
                                      dslraserD Offline
                                      dslraser
                                      Forum Testing Most Active
                                      schrieb am zuletzt editiert von
                                      #120

                                      @dslraser sagte in Unifi WLAN Script:

                                      @liv-in-sky
                                      ach und noch was, die Voucher werden in den DP nicht angezeigt

                                      Bildschirmfoto 2019-09-01 um 22.43.43.png
                                      so sieht es bei mir aus

                                      Edit: ich habe den Codeteil von weiter oben eingebaut, da werden mir die Voucher angezeigt. (ich habe aber jetzt nicht nach Unterschieden gesucht)

                                      dieser hier funktioniert bei mir

                                      async function getVouchers() {
                                          return new Promise(async (resolve, reject) => {
                                              dlog("nur mal so");
                                              if(!loggedIn) await login().catch((e) => reject(e));
                                              let resp = await request.get({
                                                  url: unifi_controller + "/api/s/default/stat/voucher",
                                                  headers: { Cookie: cookies.join("; ") }
                                              }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                         
                                      dlog("got response " + JSON.stringify(resp));
                                      dlog(typeof resp);
                                      dlog("--------------------- " + resp);
                                      resp = JSON.parse(resp);
                                       
                                      dlog(resp.meta);
                                      dlog(resp.meta.rc);
                                      dlog(resp.data[1].code);
                                      dlog(resp.data.length);
                                      dlog(JSON.stringify(resp).length.toString());
                                      var laengeMessage=JSON.stringify(resp).length;
                                      if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                      writeFileVar=JSON.stringify(resp).length;
                                      var clientListe = "<tr><td>DURATION&ensp;</td><td>STATUSEXPIRES&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                                       
                                       
                                      for (var i = 1; i < 21; i++) { 
                                          var x=i.toString();
                                          if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setState("javascript.0.WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "");}
                                          
                                      for (var i = 0; i < resp.data.length; i++) { 
                                         var zeit= resp.data[i].create_time*1000
                                         let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                       
                                         clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                                         var y=i+1; 
                                         var yy=y.toString();
                                         if (y<10 )  yy="0"+yy;
                                        
                                         if (i<20  )  {
                                             log(zeit1);
                                             setState("javascript.0.WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                             setState("javascript.0.WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".duration", resp.data[i].duration );
                                             setState("javascript.0.WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".expires", resp.data[i].status_expires );
                                             setState("javascript.0.WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy, resp.data[i].code );
                                         }
                                      }
                                      if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl Vouchers:"+resp.data.length+"</p>"));}
                                      setState("javascript.0.WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
                                      setState("javascript.0.WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
                                      });
                                       
                                      }
                                      
                                      

                                      1 Antwort Letzte Antwort
                                      0
                                      • liv-in-skyL Offline
                                        liv-in-skyL Offline
                                        liv-in-sky
                                        schrieb am zuletzt editiert von liv-in-sky
                                        #121

                                        moin -

                                        ich habe nochmal getestet und dummen fehler gefunden - sorry

                                        • bitte nur das script von mir benutzen - sonst kann ich keine fehleranalyse machen
                                          wichtig
                                        • bitte alte datenpunkte löschen bevor du das script neu laufen läßt
                                        • der pfad der constante const=dpPrefix muss mit der javascript instanz übereinsimmen, in dem das script läuft
                                          javascript-instanz 0 muss dann const dpPrefix = "javascript.0."; lauten (da lag mein denkfehler)

                                        bitte nochmal testen

                                        const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                                        var fs = require('fs')
                                        const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
                                        const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
                                        let writeFile = true;
                                        let  writeFileVar = 0;
                                        let writeClientTable = true;
                                        let writeAnwesenheit = true;
                                        let listeDatenpunkte = [];
                                        let listeDatenpunkteNew = [];
                                        let listeDatenpunkteAlt = [];
                                        
                                        // Datenpunkte Hauptpfad wählen
                                        const dpPrefix = "javascript.2.";
                                        
                                        //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
                                        let  iqontrol = true;
                                        let  anwesenheit = true; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects löschen
                                        let vouchers = true;
                                        
                                        // Hier Definition iqontrol-Style für Popup
                                        const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                        const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                        let cookies = [];
                                        let loggedIn = false;
                                        let debug = false;
                                        
                                        if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                        if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                        
                                        //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                                        
                                        //Datenpunkt für Wifi Status erstellen
                                        createState(dpPrefix + "WLANUnifi.Wifi_Status", {
                                           name: 'Unifi Wifi Status', 
                                           role: 'boolean',
                                           read:  true, 
                                           write: true,
                                        });
                                        
                                        //Datenpunkt Button für Wifi an erstellen
                                        createState(dpPrefix + "WLANUnifi.Wifi_an", {
                                           name: 'Unifi Wifi an', 
                                           role: 'switch',
                                           read:  true, 
                                           write: true,
                                           type: "boolean",
                                           "smartName": {
                                           "de": "02Gäste Wlan an",
                                           "smartType": "SWITCH"
                                        }
                                        });
                                          setStateDelayed(dpPrefix + "WLANUnifi.Wifi_an", false, 300);
                                        
                                        //Datenpunkt Button für Wifi aus erstellen
                                        createState(dpPrefix + "WLANUnifi.Wifi_aus", {
                                           name: 'Unifi Wifi aus', 
                                           role: 'switch',
                                           read:  true, 
                                           write: true,
                                           type: "boolean",
                                           "smartName": {
                                           "de": "03Gäste Wlan aus",
                                           "smartType": "SWITCH"
                                        }
                                        });
                                          setStateDelayed(dpPrefix + "WLANUnifi.Wifi_aus", false, 300);
                                        
                                        if (true) {
                                        createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
                                           name: 'Unifi Wifi Clients Table', 
                                           role: 'string',
                                           read:  true, 
                                           write: true,
                                        });}
                                        
                                        
                                        if (vouchers) {
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
                                           name: 'Unifi Wifi Vouchers_Table', 
                                           role: 'string',
                                           read:  true, 
                                           write: true,
                                        });
                                        
                                        for (var i = 1; i < 21; i++) { 
                                           var x=i.toString();
                                           if (i<10) x="0"+x;
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
                                           name: 'Unifi Voucher_Code'+x, 
                                           role: 'string',
                                           read:  true, 
                                           write: true,
                                           });
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".code"+x, {
                                           name: 'Unifi Voucher_Code_code'+x, 
                                           role: 'string',
                                           read:  true, 
                                           write: true,
                                           });    
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
                                           name: 'Unifi Voucher_Code_erstellt'+x, 
                                           role: 'string',
                                           read:  true, 
                                           write: true,
                                           });
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".dauer", {
                                           name: 'Unifi Voucher_Code_duration'+x, 
                                           role: 'string',
                                           read:  true, 
                                           write: true,
                                           });
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".abgelaufen", {
                                           name: 'Unifi Voucher_Code_expires'+x, 
                                           role: 'string',
                                           read:  true, 
                                           write: true,
                                           });
                                        }}
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                                        if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                        
                                        function dlog(message) {
                                          if(debug)
                                              console.log(message);
                                        }
                                        
                                        async function login() {
                                          return new Promise(async (resolve, reject) => {
                                              let resp = await request.post({
                                                  resolveWithFullResponse: true,
                                                  url: unifi_controller + "/api/login",
                                                  body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                                                  headers: { 'Content-Type': 'application/json' }
                                              }).catch((e) => { dlog("login: reject"), reject(e) });
                                              
                                              if(resp != null) {
                                                  dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                                  if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                                                      let set_cookies = resp.headers["set-cookie"];
                                                      for(i = 0; i < set_cookies.length; i++) {
                                                          let cookie = set_cookies[i];
                                                          cookie = cookie.split(";")[0];
                                                          cookies.push(cookie);
                                                      }
                                                  } else {
                                                      dlog("login: no cookies to set!")
                                                  }
                                                  loggedIn = true;
                                                  resolve();
                                              } else {
                                                  dlog("login: rejected")
                                                  reject("resp = null");
                                              }
                                          });
                                        }
                                        
                                        async function getStatus() {
                                           return new Promise(async (resolve, reject) => {
                                               dlog("nur mal so");
                                               if(!loggedIn) await login().catch((e) => reject(e));
                                               let resp = await request.get({
                                                   url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                                                   headers: { Cookie: cookies.join("; ") }
                                               }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
                                           
                                        dlog("got response " + JSON.stringify(resp));
                                        dlog(typeof resp);
                                        resp = JSON.parse(resp);
                                        dlog(resp.meta);
                                        dlog(resp.meta.rc);
                                               
                                               let wlanOn = resp.data[0].enabled;
                                               dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                               setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                                               if(resp != null && resp.meta && resp.meta.rc == "ok") {
                                                   dlog("Status erfolgreich geholt!");
                                                   dlog(resp);
                                                   let wlanOn = resp.data[0].enabled;
                                                   dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                                   setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                                                   
                                                   resolve(wlanOn);
                                               } else {
                                                   dlog("nicht ok...")
                                                   
                                                   reject(JSON.stringify(resp));
                                               }
                                           });
                                        }
                                        
                                        
                                         async function getClients() {
                                        
                                           
                                           return new Promise(async (resolve, reject) => {
                                               dlog("nur mal so");
                                               if(!loggedIn) await login().catch((e) => reject(e));
                                               let resp = await request.get({
                                                   url: unifi_controller + "/api/s/default/stat/sta/",
                                                   headers: { Cookie: cookies.join("; ") }
                                               }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                          
                                        dlog("got response " + JSON.stringify(resp));
                                        dlog(typeof resp);
                                        dlog("--------------------- " + resp);
                                        resp = JSON.parse(resp);
                                        dlog(resp.meta);
                                        dlog(resp.meta.rc);
                                        dlog(resp.data[2].hostname);
                                        dlog(resp.data.length);
                                        var anzahlClients = resp.data.length;
                                        setState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients);
                                        
                                        
                                        var clientListe = "";
                                        getExistingClients();
                                        
                                        //erstelle aktuelles array
                                        
                                        listeDatenpunkteNew=[];
                                        for (var i = 0; i < resp.data.length; i++) { 
                                           listeDatenpunkteNew[i] = resp.data[i].hostname;}
                                          
                                        
                                        // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
                                        dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
                                        if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
                                        dlog("ClientTable "+writeClientTable.toString());
                                        dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
                                        
                                        
                                        // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
                                        if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
                                        dlog("writeAnwesenheit "+writeAnwesenheit.toString());
                                        dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
                                        
                                        // erstelle htmlclientliste wenn listenDaten verändert  
                                            if ( writeClientTable ) {
                                             for (var i = 0; i < resp.data.length; i++)  {
                                               dlog(resp.data[i].hostname + " --- " + resp.data[i].essid + " --- " + resp.data[i].mac);
                                               clientListe = clientListe.concat("<tr><td>"+resp.data[i].hostname+"&ensp;</td><td>"+resp.data[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].mac+"</td></tr>");
                                               dlog(clientListe);
                                               var ipWandler= resp.data[i].ip;
                                               if (anwesenheit && writeAnwesenheit) {
                                                  createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, {
                                                  name: ipWandler, 
                                                  role: 'boolean',
                                                  read:  true, 
                                                  write: true,
                                                  });
                                               }
                                             
                                             if (anwesenheit && listeDatenpunkteNew.indexOf(resp.data[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
                                               dlog("gefunden"+resp.data[i].hostname);
                                               setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, true, 500);}
                                         } }
                                             
                                         
                                        if (anwesenheit) {
                                        for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
                                        if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
                                            dlog("nicht gefunden"+listeDatenpunkte[b]);
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 500);}}}
                                        
                                        if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl angemeldeteClients:"+resp.data.length+"</p>"));
                                        
                                        dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                                        if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                                        });
                                        
                                        }
                                        
                                        function getExistingClients() {
                                        listeDatenpunkte = [];
                                        
                                        var cacheSelectorState = $("state[state.id=" + dpPrefix + "WLANUnifi.Wifi_Client_States.*]");
                                          cacheSelectorState.each(function (id, c) {
                                            if (!id.includes("undefined")) {
                                             listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
                                        });
                                        }
                                        
                                        
                                        
                                        async function getVouchers() {
                                           return new Promise(async (resolve, reject) => {
                                               dlog("nur mal so");
                                               if(!loggedIn) await login().catch((e) => reject(e));
                                               let resp = await request.get({
                                                   url: unifi_controller + "/api/s/default/stat/voucher",
                                                   headers: { Cookie: cookies.join("; ") }
                                               }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                          
                                        dlog("got response " + JSON.stringify(resp));
                                        dlog(typeof resp);
                                        dlog("--------------------- " + resp);
                                        resp = JSON.parse(resp);
                                        
                                        dlog(resp.meta);
                                        dlog(resp.meta.rc);
                                        dlog(resp.data[1].code);
                                        dlog(resp.data.length);
                                        dlog(JSON.stringify(resp).length.toString());
                                        var laengeMessage=JSON.stringify(resp).length;
                                        if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                        writeFileVar=JSON.stringify(resp).length;
                                        
                                        if (writeFile) {
                                        var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                                        
                                        for (var i = 1; i < 21; i++) { 
                                           var x=i.toString();
                                           if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
                                           
                                        for (var i = 0; i < resp.data.length; i++) { 
                                          var zeit= resp.data[i].create_time*1000
                                          let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                        
                                          clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                                          var y=i+1; 
                                          var yy=y.toString();
                                          if (y<10 )  yy="0"+yy;
                                         
                                          if (i<20  )  {
                                              dlog(zeit1);
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, resp.data[i].code );
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", resp.data[i].duration );
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", resp.data[i].status_expires );
                                              
                                          }}
                                        
                                        
                                        //Datenpunkteäalt löschen
                                        var w = resp.data.length;
                                        for (i = w; i < 20; i++) { 
                                              var y=i+1; 
                                          var yy=y.toString();
                                          if (y<10 )  yy="0"+yy;
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, " na " );
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", " na " );
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", " na " );
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", " na " );
                                        }
                                        }
                                        
                                        if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl Vouchers:"+resp.data.length+"</p>"));}
                                        if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
                                        if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
                                        });
                                        
                                        }
                                        
                                        async function dlogout() {
                                          return new Promise(async (resolve, reject) => {
                                              let resp = await request.get({
                                                  url: unifi_controller + "/dlogout",
                                                  headers: { Cookie: cookies.join("; ") }
                                              }).catch((e) => reject(e));
                                              if(resp != null) {
                                                  dlog("Du bist nun ausgedloggt.");
                                                  dlog(resp);
                                                  resolve();
                                              } else {
                                                  reject("resp = null");
                                              }
                                          });
                                        }
                                        
                                        async function setWifi(enabled) {
                                          return new Promise(async (resolve, reject) => {
                                              dlog("setWifi: start set wifi");
                                              if(!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                              dlog("setWifi: now setting wifi");
                                              let resp = request.post({
                                                  url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi_id,
                                                  body: JSON.stringify({ enabled }),
                                                  headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                              }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
                                              dlog("setWifi: got response")
                                              if(resp != null) {
                                                  dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                                  dlog(resp);
                                                  resolve();
                                              } else {
                                                  dlog("setWifi: rejetced")
                                                  dlog("resp: " + JSON.stringify(resp));
                                                  reject("msg: " + JSON.parse(resp.body).meta.msg);
                                              }
                                          });
                                        }
                                        
                                        
                                        
                                        
                                        async function test() {
                                          dlog("starting test");
                                          await setWifi(false).catch((e) => dlog("reject1: " + e));
                                          dlog("getting status");
                                          let wlan = await getStatus().catch((e) => dlog("reject2: " + e));
                                          console.log("fin")
                                          console.log(wlan);
                                        }
                                        
                                        setInterval(async () => {
                                          await getStatus();
                                           setTimeout(function () {
                                          getClients();
                                               }, 2000);
                                               setTimeout(function () {
                                         if (vouchers) getVouchers();
                                           }, 5000);
                                        }, 20000); // Aktualisiert alle 20 Minuten.
                                        
                                        
                                        on(dpPrefix + "WLANUnifi.Wifi_an", (state) => {
                                           setWifi(true);
                                           setTimeout(function () {
                                               getStatus();
                                               setState(dpPrefix + "WLANUnifi.Wifi_an", false);
                                        }, 10000);
                                        });
                                        on(dpPrefix + "WLANUnifi.Wifi_aus", (state) => {
                                           setWifi(false);
                                           setTimeout(function () {
                                             getStatus();   
                                              setState(dpPrefix + "WLANUnifi.Wifi_aus", false);
                                        }, 12000);
                                        });
                                        
                                        

                                        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

                                        dslraserD D 2 Antworten Letzte Antwort
                                        1
                                        • liv-in-skyL liv-in-sky

                                          moin -

                                          ich habe nochmal getestet und dummen fehler gefunden - sorry

                                          • bitte nur das script von mir benutzen - sonst kann ich keine fehleranalyse machen
                                            wichtig
                                          • bitte alte datenpunkte löschen bevor du das script neu laufen läßt
                                          • der pfad der constante const=dpPrefix muss mit der javascript instanz übereinsimmen, in dem das script läuft
                                            javascript-instanz 0 muss dann const dpPrefix = "javascript.0."; lauten (da lag mein denkfehler)

                                          bitte nochmal testen

                                          const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                                          var fs = require('fs')
                                          const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
                                          const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
                                          let writeFile = true;
                                          let  writeFileVar = 0;
                                          let writeClientTable = true;
                                          let writeAnwesenheit = true;
                                          let listeDatenpunkte = [];
                                          let listeDatenpunkteNew = [];
                                          let listeDatenpunkteAlt = [];
                                          
                                          // Datenpunkte Hauptpfad wählen
                                          const dpPrefix = "javascript.2.";
                                          
                                          //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
                                          let  iqontrol = true;
                                          let  anwesenheit = true; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects löschen
                                          let vouchers = true;
                                          
                                          // Hier Definition iqontrol-Style für Popup
                                          const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                          const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                          let cookies = [];
                                          let loggedIn = false;
                                          let debug = false;
                                          
                                          if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                          if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                          
                                          //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                                          
                                          //Datenpunkt für Wifi Status erstellen
                                          createState(dpPrefix + "WLANUnifi.Wifi_Status", {
                                             name: 'Unifi Wifi Status', 
                                             role: 'boolean',
                                             read:  true, 
                                             write: true,
                                          });
                                          
                                          //Datenpunkt Button für Wifi an erstellen
                                          createState(dpPrefix + "WLANUnifi.Wifi_an", {
                                             name: 'Unifi Wifi an', 
                                             role: 'switch',
                                             read:  true, 
                                             write: true,
                                             type: "boolean",
                                             "smartName": {
                                             "de": "02Gäste Wlan an",
                                             "smartType": "SWITCH"
                                          }
                                          });
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_an", false, 300);
                                          
                                          //Datenpunkt Button für Wifi aus erstellen
                                          createState(dpPrefix + "WLANUnifi.Wifi_aus", {
                                             name: 'Unifi Wifi aus', 
                                             role: 'switch',
                                             read:  true, 
                                             write: true,
                                             type: "boolean",
                                             "smartName": {
                                             "de": "03Gäste Wlan aus",
                                             "smartType": "SWITCH"
                                          }
                                          });
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_aus", false, 300);
                                          
                                          if (true) {
                                          createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
                                             name: 'Unifi Wifi Clients Table', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });}
                                          
                                          
                                          if (vouchers) {
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
                                             name: 'Unifi Wifi Vouchers_Table', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });
                                          
                                          for (var i = 1; i < 21; i++) { 
                                             var x=i.toString();
                                             if (i<10) x="0"+x;
                                            createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
                                             name: 'Unifi Voucher_Code'+x, 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                             });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".code"+x, {
                                             name: 'Unifi Voucher_Code_code'+x, 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                             });    
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
                                             name: 'Unifi Voucher_Code_erstellt'+x, 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                             });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".dauer", {
                                             name: 'Unifi Voucher_Code_duration'+x, 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                             });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".abgelaufen", {
                                             name: 'Unifi Voucher_Code_expires'+x, 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                             });
                                          }}
                                          
                                          createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                                          if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                          
                                          function dlog(message) {
                                            if(debug)
                                                console.log(message);
                                          }
                                          
                                          async function login() {
                                            return new Promise(async (resolve, reject) => {
                                                let resp = await request.post({
                                                    resolveWithFullResponse: true,
                                                    url: unifi_controller + "/api/login",
                                                    body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                                                    headers: { 'Content-Type': 'application/json' }
                                                }).catch((e) => { dlog("login: reject"), reject(e) });
                                                
                                                if(resp != null) {
                                                    dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                                    if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                                                        let set_cookies = resp.headers["set-cookie"];
                                                        for(i = 0; i < set_cookies.length; i++) {
                                                            let cookie = set_cookies[i];
                                                            cookie = cookie.split(";")[0];
                                                            cookies.push(cookie);
                                                        }
                                                    } else {
                                                        dlog("login: no cookies to set!")
                                                    }
                                                    loggedIn = true;
                                                    resolve();
                                                } else {
                                                    dlog("login: rejected")
                                                    reject("resp = null");
                                                }
                                            });
                                          }
                                          
                                          async function getStatus() {
                                             return new Promise(async (resolve, reject) => {
                                                 dlog("nur mal so");
                                                 if(!loggedIn) await login().catch((e) => reject(e));
                                                 let resp = await request.get({
                                                     url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                                                     headers: { Cookie: cookies.join("; ") }
                                                 }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
                                             
                                          dlog("got response " + JSON.stringify(resp));
                                          dlog(typeof resp);
                                          resp = JSON.parse(resp);
                                          dlog(resp.meta);
                                          dlog(resp.meta.rc);
                                                 
                                                 let wlanOn = resp.data[0].enabled;
                                                 dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                                 setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                                                 if(resp != null && resp.meta && resp.meta.rc == "ok") {
                                                     dlog("Status erfolgreich geholt!");
                                                     dlog(resp);
                                                     let wlanOn = resp.data[0].enabled;
                                                     dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                                     setState(dpPrefix + "WLANUnifi.Wifi_Status", wlanOn);
                                                     
                                                     resolve(wlanOn);
                                                 } else {
                                                     dlog("nicht ok...")
                                                     
                                                     reject(JSON.stringify(resp));
                                                 }
                                             });
                                          }
                                          
                                          
                                           async function getClients() {
                                          
                                             
                                             return new Promise(async (resolve, reject) => {
                                                 dlog("nur mal so");
                                                 if(!loggedIn) await login().catch((e) => reject(e));
                                                 let resp = await request.get({
                                                     url: unifi_controller + "/api/s/default/stat/sta/",
                                                     headers: { Cookie: cookies.join("; ") }
                                                 }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                            
                                          dlog("got response " + JSON.stringify(resp));
                                          dlog(typeof resp);
                                          dlog("--------------------- " + resp);
                                          resp = JSON.parse(resp);
                                          dlog(resp.meta);
                                          dlog(resp.meta.rc);
                                          dlog(resp.data[2].hostname);
                                          dlog(resp.data.length);
                                          var anzahlClients = resp.data.length;
                                          setState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients);
                                          
                                          
                                          var clientListe = "";
                                          getExistingClients();
                                          
                                          //erstelle aktuelles array
                                          
                                          listeDatenpunkteNew=[];
                                          for (var i = 0; i < resp.data.length; i++) { 
                                             listeDatenpunkteNew[i] = resp.data[i].hostname;}
                                            
                                          
                                          // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
                                          dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
                                          if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
                                          dlog("ClientTable "+writeClientTable.toString());
                                          dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
                                          
                                          
                                          // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
                                          if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
                                          dlog("writeAnwesenheit "+writeAnwesenheit.toString());
                                          dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
                                          
                                          // erstelle htmlclientliste wenn listenDaten verändert  
                                              if ( writeClientTable ) {
                                               for (var i = 0; i < resp.data.length; i++)  {
                                                 dlog(resp.data[i].hostname + " --- " + resp.data[i].essid + " --- " + resp.data[i].mac);
                                                 clientListe = clientListe.concat("<tr><td>"+resp.data[i].hostname+"&ensp;</td><td>"+resp.data[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].mac+"</td></tr>");
                                                 dlog(clientListe);
                                                 var ipWandler= resp.data[i].ip;
                                                 if (anwesenheit && writeAnwesenheit) {
                                                    createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, {
                                                    name: ipWandler, 
                                                    role: 'boolean',
                                                    read:  true, 
                                                    write: true,
                                                    });
                                                 }
                                               
                                               if (anwesenheit && listeDatenpunkteNew.indexOf(resp.data[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
                                                 dlog("gefunden"+resp.data[i].hostname);
                                                 setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+resp.data[i].hostname, true, 500);}
                                           } }
                                               
                                           
                                          if (anwesenheit) {
                                          for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
                                          if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
                                              dlog("nicht gefunden"+listeDatenpunkte[b]);
                                              setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 500);}}}
                                          
                                          if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl angemeldeteClients:"+resp.data.length+"</p>"));
                                          
                                          dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                                          if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                                          });
                                          
                                          }
                                          
                                          function getExistingClients() {
                                          listeDatenpunkte = [];
                                          
                                          var cacheSelectorState = $("state[state.id=" + dpPrefix + "WLANUnifi.Wifi_Client_States.*]");
                                            cacheSelectorState.each(function (id, c) {
                                              if (!id.includes("undefined")) {
                                               listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
                                          });
                                          }
                                          
                                          
                                          
                                          async function getVouchers() {
                                             return new Promise(async (resolve, reject) => {
                                                 dlog("nur mal so");
                                                 if(!loggedIn) await login().catch((e) => reject(e));
                                                 let resp = await request.get({
                                                     url: unifi_controller + "/api/s/default/stat/voucher",
                                                     headers: { Cookie: cookies.join("; ") }
                                                 }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                            
                                          dlog("got response " + JSON.stringify(resp));
                                          dlog(typeof resp);
                                          dlog("--------------------- " + resp);
                                          resp = JSON.parse(resp);
                                          
                                          dlog(resp.meta);
                                          dlog(resp.meta.rc);
                                          dlog(resp.data[1].code);
                                          dlog(resp.data.length);
                                          dlog(JSON.stringify(resp).length.toString());
                                          var laengeMessage=JSON.stringify(resp).length;
                                          if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                          writeFileVar=JSON.stringify(resp).length;
                                          
                                          if (writeFile) {
                                          var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                                          
                                          for (var i = 1; i < 21; i++) { 
                                             var x=i.toString();
                                             if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
                                             
                                          for (var i = 0; i < resp.data.length; i++) { 
                                            var zeit= resp.data[i].create_time*1000
                                            let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                          
                                            clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                                            var y=i+1; 
                                            var yy=y.toString();
                                            if (y<10 )  yy="0"+yy;
                                           
                                            if (i<20  )  {
                                                dlog(zeit1);
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, resp.data[i].code );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", resp.data[i].duration );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", resp.data[i].status_expires );
                                                
                                            }}
                                          
                                          
                                          //Datenpunkteäalt löschen
                                          var w = resp.data.length;
                                          for (i = w; i < 20; i++) { 
                                                var y=i+1; 
                                            var yy=y.toString();
                                            if (y<10 )  yy="0"+yy;
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, " na " );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", " na " );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", " na " );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", " na " );
                                          }
                                          }
                                          
                                          if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">GeamtAnzahl Vouchers:"+resp.data.length+"</p>"));}
                                          if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
                                          if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
                                          });
                                          
                                          }
                                          
                                          async function dlogout() {
                                            return new Promise(async (resolve, reject) => {
                                                let resp = await request.get({
                                                    url: unifi_controller + "/dlogout",
                                                    headers: { Cookie: cookies.join("; ") }
                                                }).catch((e) => reject(e));
                                                if(resp != null) {
                                                    dlog("Du bist nun ausgedloggt.");
                                                    dlog(resp);
                                                    resolve();
                                                } else {
                                                    reject("resp = null");
                                                }
                                            });
                                          }
                                          
                                          async function setWifi(enabled) {
                                            return new Promise(async (resolve, reject) => {
                                                dlog("setWifi: start set wifi");
                                                if(!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                                dlog("setWifi: now setting wifi");
                                                let resp = request.post({
                                                    url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi_id,
                                                    body: JSON.stringify({ enabled }),
                                                    headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                                }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
                                                dlog("setWifi: got response")
                                                if(resp != null) {
                                                    dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                                    dlog(resp);
                                                    resolve();
                                                } else {
                                                    dlog("setWifi: rejetced")
                                                    dlog("resp: " + JSON.stringify(resp));
                                                    reject("msg: " + JSON.parse(resp.body).meta.msg);
                                                }
                                            });
                                          }
                                          
                                          
                                          
                                          
                                          async function test() {
                                            dlog("starting test");
                                            await setWifi(false).catch((e) => dlog("reject1: " + e));
                                            dlog("getting status");
                                            let wlan = await getStatus().catch((e) => dlog("reject2: " + e));
                                            console.log("fin")
                                            console.log(wlan);
                                          }
                                          
                                          setInterval(async () => {
                                            await getStatus();
                                             setTimeout(function () {
                                            getClients();
                                                 }, 2000);
                                                 setTimeout(function () {
                                           if (vouchers) getVouchers();
                                             }, 5000);
                                          }, 20000); // Aktualisiert alle 20 Minuten.
                                          
                                          
                                          on(dpPrefix + "WLANUnifi.Wifi_an", (state) => {
                                             setWifi(true);
                                             setTimeout(function () {
                                                 getStatus();
                                                 setState(dpPrefix + "WLANUnifi.Wifi_an", false);
                                          }, 10000);
                                          });
                                          on(dpPrefix + "WLANUnifi.Wifi_aus", (state) => {
                                             setWifi(false);
                                             setTimeout(function () {
                                               getStatus();   
                                                setState(dpPrefix + "WLANUnifi.Wifi_aus", false);
                                          }, 12000);
                                          });
                                          
                                          

                                          dslraserD Offline
                                          dslraserD Offline
                                          dslraser
                                          Forum Testing Most Active
                                          schrieb am zuletzt editiert von
                                          #122

                                          @liv-in-sky
                                          so, Feedback.
                                          Es läuft alles "fast alles" wie gewünscht. Eine Sache schaue ich mir gerade an und finde den Fehler nicht.
                                          iQontrol zeigt mir immer eine altes iFrame an und ich weiß noch nicht so genau warum ? Also, ich habe jetzt mal zwei Voucher eingelöst, klappt auch soweit alles, nur die iQontrol Anzeige bleibt auf der "alten Anzeige" (ist noch auf der Anzeige von gestern, also ich hatte 9 Voucher, gestern dann 8 und heute 7) Die restlichen Anzeigen stimmen. Nun habe ich mir mal die Datei gesucht, dort stehen nur die 7 drinn und auch das Datum von heute passt ? Ich weiß nicht welche Datei iQontrol dann aufruft ?
                                          Bildschirmfoto 2019-09-02 um 13.53.36.png

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          878

                                          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