Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Unifi WLAN Script

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    Unifi WLAN Script

    This topic has been deleted. Only users with topic management privileges can see it.
    • dslraser
      dslraser Forum Testing Most Active @liv-in-sky last edited by

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

      @dslraser kann man vielleicht im controller noch was einstellen - irgendein update interval

      ich habe mich mal durchgeklickt im Controller. Das einzige was ich gefunden habe (war auch im 20 Minuten Rhythmus). Das habe ich jetzt mal deaktiviert.

      Bildschirmfoto 2019-09-10 um 18.58.46.png

      1 Reply Last reply Reply Quote 0
      • dslraser
        dslraser Forum Testing Most Active @liv-in-sky last edited by

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

        habe gerade meinen ersten voucher mit dem script erzeugt ! ist das für dich auch interessant

        was muß ich dazu machen ?

        liv-in-sky 2 Replies Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @dslraser last edited by

          @dslraser bin noch am finetuning - sollte bald kommen

          1 Reply Last reply Reply Quote 0
          • liv-in-sky
            liv-in-sky @dslraser last edited by

            @dslraser @Chaot

            hier mit create voucher

            bitte datenpunkte löschen und js-instanz !

            es gibt einen neuen datenpunkt unter vouchercodes - A_New_Voucher

            darin müssen die 3 mit "must be set" gesetzt werden - anschliessend der datenpunkt "Create" mit true beschrieben - dann wird voucher erstellt (notiz datenpunkt ist noch inaktiv)

            Image 8.png

            dslraser 2 Replies Last reply Reply Quote 0
            • dslraser
              dslraser Forum Testing Most Active @liv-in-sky last edited by dslraser

              @liv-in-sky
              fehlt nur das Script

              liv-in-sky 1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @dslraser last edited by

                @dslraser

                sorry - kopiert war es - nur das paste war vergessen

                script wieder ab der def der wifi constanten

                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";
                
                
                
                
                // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, inder das script läuft zusammenpassen
                const dpPrefix = "javascript.2.";
                
                //Pause bei Umschalten der WLANnetze, damit Netzanmeldungen wieder normal
                const clientPauseConst = 200000;    //1000 bedeutet 1 Sekunde -  das braucht Zeit !!!
                
                // Abfragezyklus definieren
                const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
                const abfageoffset = 15000; // zu schnelle Abmeldungen können hier eingestellt weren - > erhöhen (15000 = 15 sek.)
                
                //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 "von hand" löschen
                let vouchers = true;
                //let aliasname=false; //benutzt alias namen im controller hinterlegt anstatt hostname - VORSICHT kein ALIAS definiert - keine Anzeige dess Clients
                
                // 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);\">";
                const format3 = "<table style=\"color:#848484; font-family:Helvetica;\">";
                
                //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                let cookies = [];
                let loggedIn = false;
                let debug = false;
                let mylogs = false;
                let clientPause = false;
                let clientPauseVal;
                let wifiDPs = [];
                let realname="hostname";
                let respv;
                let respc;
                let respw;
                let resph;
                let statusarr=[];
                let versuch;
                let listeDatenpunkte = [];
                let lastChange=[];
                let testerrc=false;
                let testerrl=false;
                let testerrv=false;
                let testerrs=false;
                let testerrh=false;
                let firstTime=0;
                let mybodyVouchers;
                var wifiLength=0;
                     for(let wifi_name in wifis) {      
                   wifiLength++; }
                
                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")); 
                //if (aliasname) realname="name";
                
                
                //Erstelle Datenpunkte für die WLANs automatisch
                for(let wifi_name in wifis) {
                
                    wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].name);
                   
                   createState(dpPrefix + "WLANUnifi."+ wifi_name, {
                      name: wifis[wifi_name].desc,
                      role: 'switch',
                      read: true,
                      write: true,
                      type: "boolean",
                      smartName: {
                          de: wifis[wifi_name].smart,
                          smartType: "SWITCH"
                      } });}
                
                
                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,
                });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create", false,  {
                   name: ' A_New_Voucher_Create', 
                   role: 'switch',
                   type: 'boolean',
                   read:  true, 
                   write: true,
                });
                
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set",{
                   name: ' A_New_Voucher_Dauer', 
                   role: 'string',
                   read:  true, 
                   write: true,
                });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set",{
                   name: ' A_New_Voucher_MultiUse', 
                   role: 'string',
                   read:  true, 
                   write: true,
                });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set",{
                   name: ' A_New_Voucher_Anzahl', 
                   role: 'string',
                   read:  true, 
                   write: true,
                });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "",{
                   name: ' A_New_Voucher_Notiz', 
                   role: 'string',
                   read:  true, 
                   write: true,
                });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "",{
                   name: ' A_New_Voucher_Uplaod', 
                   role: 'string',
                   read:  true, 
                   write: true,
                });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "",{
                   name: ' A_New_Voucher_Download', 
                   role: 'string',
                   read:  true, 
                   write: true,
                });
                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", {
                   name: ' A_New_Voucher_Mb_Begrenzung', 
                   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);
                }
                function mylog(message) {
                  if(mylogs)
                      console.log(message);
                }
                
                
                
                
                
                //-----------------------------------------LOGIN---------------------------------------------------------------
                async function login() {
                  return new Promise(async (resolve, reject) => {
                      cookies=[];
                      let respl = 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) => { log("login: reject"), reject(e);  loggedIn =false;return respl=[];});
                      
                      if(respl != null) {
                          mylog("login: login war erfolgreich! " + ((respl.headers && respl.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                          if(respl.headers && respl.headers.hasOwnProperty("set-cookie")) {
                              let set_cookies = respl.headers["set-cookie"];
                              for(i = 0; i < set_cookies.length; i++) {
                                  let cookie = set_cookies[i];
                                  //log(set_cookies[i]);
                                  cookie = cookie.split(";")[0];
                                  cookies.push(cookie);
                              }
                          } else {
                              log("login: no cookies to set!")
                          }
                          loggedIn = true;
                                
                          resolve();
                      } else {
                          log("login: rejected")
                            loggedIn = false;
                          reject("respl = null");
                      }
                  });
                }
                
                 //-----------------------------------------LOGOUT---------------------------------------------------------------  
                async function logout() {
                   log("BIN IN LOGOUT");
                  return new Promise(async (resolve, reject) => {
                      let respo = await request.get({
                          url: unifi_controller + "/logout",
                          headers: { Cookie: cookies.join("; ") }
                      }).catch((e) => { log("logout fehler" + e)/*reject(e)*/ ;return testerrl=true;} );
                      if (!testerrl) {
                      if(respo != null) {
                          log("Du bist nun ausgedloggt.");
                          dlog(respo);
                          log("BIN raus aus LOGOUT");
                           loggedIn = true;          
                          resolve();
                         
                      } else {
                          reject("resp = null");
                      }
                      } else {log("reject weil resplogin ist 00"); log("BIN raus aus LOGOUT"); reject();}
                      log("BIN raus aus LOGOUT");
                  });
                }
                //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
                //Updatet status vom Wifi
                //wifi: wifi object aus der konstanten wifis
                function getStatus(wifi) {
                     mylog("BIN IN STATUS");
                  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)*/ return testerrs=true; });
                    if (!testerrs) {
                      dlog("got response " + JSON.stringify(resp));
                      resp = JSON.parse(resp);
                
                      let wlanOn = resp.data[0].enabled;
                      dlog("WLAN " + wifi.name + " ist: " + (wlanOn ? "an" : "aus"));
                
                      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"));
                          setStateDelayed(dpPrefix + "WLANUnifi." + wifi.name, wlanOn, 200);
                       
                          resolve(wlanOn);
                      } else {
                          log("nicht ok... getStatusWifi")
                          reject(JSON.stringify(resp));
                      }
                      } else {mylog("reject weil respslogin ist 00"); mylog("BIN raus aus LOGOUT"); reject();}
                      mylog("BIN aus STATUS raus");
                  });
                   
                }
                
                //-----------------------------------------GETCLIENTS---------------------------------------------------------------
                async function getClients() {
                    mylog("BIN IN getclients");
                   
                   return new Promise(async (resolve, reject) => {
                       dlog("getclient nur mal so" + loggedIn);
                      if(!loggedIn) await login().catch((e) => reject(e));
                        respc = await request.get({
                           url: unifi_controller + "/api/s/default/stat/sta",
                           headers: { Cookie: cookies.join("; ") }
                       }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrc=true; }); 
                        
                  if (!testerrc) {     
                dlog("got respconse nach log in getclient " + JSON.stringify(respc));
                dlog(typeof respc);
                dlog("--------------------- " + respc);
                //respc = JSON.parse(respc);
                
                //Sortierung Daten und Verwandlung Json
                
                var unfiltered = [];
                unfiltered = JSON.parse(respc).data;
                dlog(unfiltered[2].hostname + unfiltered[2].mac);
                versuch = [];
                for(var index in unfiltered) {
                   let device = unfiltered[index];
                   if(device.hostname !== undefined && device.essid !== undefined)
                       versuch.push(device);
                }
                versuch.sort(function (alpha, beta) {
                   if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase())
                       return -1;
                   if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase())
                       return 1;
                   return 0;
                });
                
                resolve();
                  } else {log("reject weil respc 00"); reject() } mylog("bin raus aus  getclients");
                }); //new promise
                
                } //getclientend
                //-----------------------------------------workCLIENTS---------------------------------------------------------------
                 function workClients() {
                    mylog("BIN IN workclients");
                    dlog("got respconse " + JSON.stringify(respc));
                    dlog(typeof respc);
                    dlog("--------------------- " + respc);
                
                let writeFile = true;
                let  writeFileVar = 0;
                let writeClientTable = true;
                let writeAnwesenheit = true;
                
                var anzahlClients = versuch.length;
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                
                var clientListe = "";
                getExistingClients();
                
                
                mylog("Status1");
                
                var listeDatenpunkteNew=[];                                                        //erstelle aktuelles array von controller daten
                for (var i = 0; i < versuch.length; i++) { 
                   listeDatenpunkteNew[i] = versuch[i].hostname;}
                  dlog (listeDatenpunkteNew[3]);
                
                // sind clients von controller in verzeichnisliste ? 
                 for (var z = 0; z < listeDatenpunkteNew.length; z++) 
                  {
                           if ( listeDatenpunkte.indexOf(listeDatenpunkteNew[z]) == -1 ){   //ist controller-client existent nicht in verzeichnis-list
                                  mylog("Datenpunktanlegen" + listeDatenpunkteNew[z] +"index:"+ listeDatenpunkte.indexOf(listeDatenpunkteNew[z]).toString());
                                  var ipWandler= versuch[z].ip;
                                  var data = dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname;
                                  createState(data, true, {
                                  name: ipWandler, 
                                  role: 'boolean',
                                  read:  true, 
                                  write: true,
                                 }, function() {mylog("created");
                                  });
                                  //setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+ versuch[z].hostname, true);
                
                               //  {setState(data, true);
                                  mylog("Datenpunktanlegen fertig" + listeDatenpunkteNew[z] + listeDatenpunkte[z]) ;
                              } else {dlog("ist in verzeichnis"+ listeDatenpunkteNew[z] );}
                 }
                
                mylog("Status2");
                
                //sind datenpunkte noch in controller vorhanden
                 if (anwesenheit) {
                 for (var z = 0; z < listeDatenpunkte.length; z++)  {
                           if ( listeDatenpunkteNew.indexOf(listeDatenpunkte[z]) == -1 ){        //ist datenpunkt-verzeihnis existent und nicht in controller liste
                               if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z]).val) {          // setze datenpunkt auf false - nur wenn true war
                                     setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z], false, 500);
                                     mylog("Datenpunkt ist falsch zu setzen"+listeDatenpunkte[z]);}
                              } else {dlog("ist noch im controller" + listeDatenpunkte[z]);}
                
                              
                 } }  
                
                mylog("Status3"); 
                
                // setze datenpunkte nach last_seen_by_uap - ausnahme: controller-clients sind nicht mehr connectet aber in vereichnis 
                
                let lastChangeList;
                if (anwesenheit) {
                timeout = setTimeout(function () {  //wegen createstate und zu schnelles setstate
                
                
                
                for (var z = 0; z < listeDatenpunkteNew.length; z++)  {
                
                   var tester = parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000);
                   dlog(tester.toString() + "laenge : " +listeDatenpunkteNew.length);
                   if (parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) > abfragezyklus+abfageoffset && getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val) {
                       setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, false, 100);
                       mylog("abgesetzt: " +listeDatenpunkteNew[z] + " um " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                       if (lastChange.length>=10) lastChange.shift()
                       lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>out</td><td>&ensp;&ensp;vor: "+tester/1000+" Sek</td></tr>");
                          mylog(lastChange[0]);
                    
                   }
                   if (parseFloat((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) < abfragezyklus && !getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val || getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val ==null ) {
                       setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, true, 100);
                       mylog("gesetzt" +listeDatenpunkteNew[z]+" " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                       if (lastChange.length>=10) lastChange.shift()
                       lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>in</td><td>&ensp;&ensp;vor: " + tester/1000+" Sek</td></tr>");
                   }  
                }
                
                
                
                mylog("Status4");
                // erstelle htmlclientliste wenn listenDaten verändert  
                    
                     for (var i = 0; i < versuch.length; i++)  {
                       dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                       if  (parseInt((new Date().getTime())) - (versuch[i]._last_seen_by_uap*1000) < abfragezyklus+15000) {                      
                       clientListe = clientListe.concat("<tr><td>"+versuch[i].hostname+"&ensp;</td><td>"+versuch[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+versuch[i].ip+"</td></tr>");
                       dlog(clientListe);}  
                       else {anzahlClients=anzahlClients-1;}
                       }
                     setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);   //korrigiert
                
                mylog("Status5");
                
                if (iqontrol && anwesenheit ) {
                   
                   lastChangeList=format3;
                   for (var g = lastChange.length-1; g >= 0 ; g--)  {
                       lastChangeList=lastChangeList.concat(lastChange[g]/*+"</table>"*/); 
                       lastChangeList.concat(lastChange[g]+"</table>");
                      }
                
                   fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:#01A9DB; font-family:Helvetica;\">Geamtanzahl angemeldeter Clients:"+anzahlClients+"</p><p style=\"color:#848484; font-family:Helvetica;\">Letzter Wechsel im Netzwerk:</br>"+lastChangeList+"</p>"));
                   //if (lastChange.length>10) lastChange=[];
                }
                dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                if (true) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                mylog("bin raus aus  workclients");
                
                }, 2500);}
                
                
                } //workclientend
                
                //-----------------------------------------EXISTING CLIENTS---------------------------------------------------------------
                function getExistingClients() {
                   dlog("BIN IN EXISTING CLIENTS");
                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.", "");}
                });
                
                dlog("bin raus a existing clients");
                }
                
                
                //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
                async function getVouchers() {
                    if (vouchers)  {
                     mylog("BIN IN getvouchers");
                   return new Promise(async (resolve, reject) => {
                       dlog("nur mal so");
                       if(!loggedIn) await login().catch((e) => reject(e));
                        respv = await request.get({
                           url: unifi_controller + "/api/s/default/stat/voucher",
                           headers: { Cookie: cookies.join("; ") }
                       }).catch((e) => { dlog("getStatus reject " + e); /*reject(e)*/ return testerrv=true; });  
                  if (!testerrv) {
                dlog("got response " + JSON.stringify(respv));
                dlog(typeof respv);
                dlog("--------------------- " + respv);
                resolve("done");
                  } else {log("reject weil respv ist 00"); reject();}
                mylog("bin raus a GET vouchers");
                });
                }}
                
                
                //-----------------------------------------WORK--VOUCHERS---------------------------------------------------------------
                function workVouchers() {
                   if (vouchers)  {
                 //  mylog("BIN IN  workvouchers");
                   dlog("got response " + JSON.stringify(respv));
                   dlog(typeof respv);
                   dlog("--------------------- " + respv);
                respv = JSON.parse(respv);
                
                   dlog("--------------------- " + respv);
                dlog(respv.meta);
                dlog(respv.meta.rc);
                dlog(respv.data[1].code);
                dlog(respv.data.length);
                dlog(JSON.stringify(respv).length.toString());
                var writeFile;
                var laengeMessage=JSON.stringify(respv).length;
                if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                var writeFileVar=JSON.stringify(respv).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 < respv.data.length; i++) { 
                  var zeit= respv.data[i].create_time*1000
                  let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                
                  clientListe = clientListe.concat("<tr><td>"+respv.data[i].duration+"&ensp;</td><td>"+respv.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+respv.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, respv.data[i].code );
                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", respv.data[i].duration );
                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", respv.data[i].status_expires );
                      
                  }}
                }
                
                //Datenpunkteäalt löschen
                var w = respv.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:"+respv.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", respv.data.length);
                //mylog("BIN RAUS AUS  workvouchers");
                
                }
                //-----------------------------------------GET--Health---------------------------------------------------------------
                async function getHealth() {
                    if (vouchers)  {
                     mylog("BIN IN gethealth");
                   return new Promise(async (resolve, reject) => {
                       dlog("nur mal so");
                       if(!loggedIn) await login().catch((e) => reject(e));
                        resph = await request.get({
                           url: unifi_controller + "/api/s/default/stat/health",
                           headers: { Cookie: cookies.join("; ") }
                       }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrh=true; });  
                  if (!testerrv) {
                dlog("got response " + JSON.stringify(resph));
                dlog(typeof resph);
                dlog("--------------------- " + resph);
                resolve("done");
                  } else {log("reject weil resph ist 00"); reject();}
                mylog("bin raus a GET health");
                });
                }}
                
                //-----------------------------------------SET WIFIS - WIFI EIN-AUSSCHALTEN----------------------------------------------
                //Wifi an-/ausschalten
                //enabled: true = anschalten; false = ausschalten
                //wifi: wifi object aus der konstanten wifis
                async function setWifi(enabled, wifi) {
                  return new Promise(async (resolve, reject) => {
                      dlog("setWifi: start set Wifi_haupt");
                      if (!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                      dlog("setWifi: now setting Wifi_haupt");
                      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);
                                  // getclient()  Pause für umschalten
                
                          if (firstTime>=wifiLength) {       
                          clientPause = true;
                          clientPauseVal=parseInt((new Date().getTime())); 
                          }
                       
                          setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                          resolve();
                      } else {
                          dlog("setWifi: rejetced")
                          dlog("resp: " + JSON.stringify(resp));
                          reject("msg: " + JSON.parse(resp.body).meta.msg);
                      }
                  });
                }
                
                //-----------------------------------------CREATE VOUCHERS----------------------------------------------
                //Wifi an-/ausschalten
                //enabled: true = anschalten; false = ausschalten
                //wifi: wifi object aus der konstanten wifis
                async function createVoucher (mybody) {
                
                 //var mybody = {cmd:'create-voucher',expire:120,n:1,quota:5,note:"ist im test",up:10,down:10,MBytes:""};
                
                  
                
                  mylog(JSON.stringify( mybody ));
                  return new Promise(async (resolve, reject) => {
                      mylog("createVoucher in aktion");
                      if (!loggedIn) { mylog("need to login"); await login().catch((e) => reject(e)); }
                      mylog("do it !");
                      let respcv = request.post({
                          url: unifi_controller + "/api/s/default/cmd/hotspot/" ,
                          body: JSON.stringify( mybody ),
                          // body: mybody,
                          headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                      }).catch((e) => { mylog("setWifi: rejected: " + e); reject(e) });
                      mylog("setWifi: got response")
                     // log("------------: "+respcv);
                  /*    if (resp != null) {
                          dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                          dlog(resp);
                                  // getclient()  Pause für umschalten
                
                     
                       
                          setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                          resolve();
                      } else {
                          dlog("setWifi: rejetced")
                          dlog("resp: " + JSON.stringify(resp));
                          reject("msg: " + JSON.parse(resp.body).meta.msg);
                      }*/
                  });
                }
                
                //-----------------------------------------------SCHALTER------------------------------------------------
                on({id: wifiDPs, ack: false, change: "ne"}, function (obj) { 
                 var value = obj.state.val;
                 var dp2 = obj.name
                 setWifi(value, wifis[dp2]);
                 dlog(wifis[dp2])
                 if (firstTime<wifiLength+1) firstTime++;
                 
                 
                          
                });
                
                on({id:  dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",  val: true}, function (obj) { 
                var mybodyVouchers;
                var expire_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer").val;
                var n_var      = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl").val ;
                var quota_var  = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse").val ;
                var note_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz").val;
                var up_var     = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload").val ;
                var down_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download").val;
                var MBytes_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung").val ;
                
                 if (expire_var !="must be set" && n_var!="must be set" && quota_var!="must be set" ) {
                
                  
                 
                  /*   mybodyVouchers = {cmd:'create-voucher',expire:expire_var,   
                                                       n:n_var, 
                                                       quota:quota_var,
                                                       note:note_var,
                                                       up:up_var, 
                                                       down:down_var,  
                                                       MBytes:MBytes_var };*/
                
                var x = "{cmd:'create-voucher',expire:"+expire_var+", n:"+n_var+", quota:"+quota_var+","
                
                //if (note_var != "")   x= x.concat("up:\'"+note_var+"\',")
                if (up_var != "")     x= x.concat("up:"+up_var+",")
                if (down_var != "")   x= x.concat("down:"+down_var+",")                                                        
                if (MBytes_var != "") x= x.concat("MBytes:"+MBytes_var+",") 
                
                 x=x.substr(0, x.length-1);
                 x=x.concat("}");
                 //log (x);
                 eval('var mybodyVouchers='+x);
                
                                                                  
                    createVoucher(mybodyVouchers);
                
                } else {log("FEHLER IN createVoucher","error")}
                
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",false, 4000);
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set" , 2000);
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set", 2000);
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set", 2000);
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "", 2000);
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "", 2000);
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "", 2000);
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", 2000);
                });
                
                
                let scriptCounter=0;
                let alarmSwitch =false;
                let alarmCounter =0;
                
                //-----------------------------------------------MAIN LOOP------------------------------------------------
                setInterval(async () => {
                
                    scriptCounter++
                    mylog("-----------------------SCRIPTCOUNTER------------------ ist : " + scriptCounter );
                    mylog(loggedIn.toString())
                        
                    await login().catch(alarm1)  
                
                   mylog("------------------------------------------------Werte Alarme: " + testerrl + " - " + testerrc+ " - " +testerrv + " - "+testerrs);
                
                if (loggedIn) {
                    if (alarmCounter > 5) {log("Unifi Sript funktioniert wieder - Verbindung wieder hergestellt","error");}
                    if (alarmCounter > 0) {alarmCounter=0; }
                    
                    await getClients().catch(alarm3)  ;
                    await getVouchers().catch(alarm4);
                    await getHealth().catch(alarm7);
                    if ( !testerrl && !testerrc && !testerrv && !testerrs  ) {
                           workVouchers();
                           workClients();}
                  
                           
                   for(let wifi_name in wifis) {
                       
                       await getStatus(wifis[wifi_name]).catch(alarm6)}   
                
                }   else { alarmCounter++; 
                          if (alarmCounter > 5) {log("Unifi Sript hat 'Problem mit Einloggen - Prüfe Unifi Controller, Port, Einlog-Daten","error");
                                                 if  (!testerrv) log("evtl. Vouchers deaktivieren","warn");}}
                
                                                 
                  if (clientPause) {
                        var interim=parseInt(new Date().getTime());
                        log("Unifi Script ist in Pause wegen WLAN Umschalteung- bis: " + formatDate(clientPauseVal + clientPauseConst, "SS:mm:ss"),"warn");
                        if (interim - clientPauseVal > clientPauseConst) {clientPause=false;log("Unifi Script hat Pause beendet" );}  }
                
                          
                 testerrc=false;
                     testerrv=false;
                      testerrs=false;
                       testerrl=false;
                        testerrc=false;
                         testerrh=false;
                
                
                
                   }, abfragezyklus); // wird oben definiert
                
                function alarm7() {log("Im Unifi Script stimmte etwas nicht - Alarm7 - Health","warn");               loggedIn=false; testerrh=false;cookies=[];}   
                function alarm6() {log("Im Unifi Script stimmte etwas nicht - Alarm6 - Statusabfrage","warn");        loggedIn=false; testerrs=false;cookies=[];}    
                function alarm5() {log("Im Unifi Script stimmte etwas nicht - Alarm5 - logout","warn");               loggedIn=false; testerrl=false;cookies=[];}    
                function alarm4() {log("Im Unifi Script stimmte etwas nicht - Alarm4 - getVouchers-Login","warn");    loggedIn=false; testerrv=false;cookies=[];}
                function alarm3() {log("Im Unifi Script stimmte etwas nicht - Alarm3 - getClient-Login","warn");      loggedIn=false; testerrc=false;cookies=[];}
                function alarm1() {log("Im Unifi Script stimmte etwas nicht - Alarm1 - Login fehlgeschlagen","warn"); loggedIn=false; ;alarmSwitch=true }
                
                
                
                // Beispiel für
                //setWifi(true, wifis.WLAN_DragonGuest);
                
                

                Chaot 1 Reply Last reply Reply Quote 0
                • Chaot
                  Chaot @liv-in-sky last edited by

                  @liv-in-sky
                  Eine Bitte hätte ich:
                  Ich kann leider den aktuellen "Kopf" des Scripts nirgendwo finden. Der ist hier irgendwo in den Beiträgen verstreut.
                  Mei Script scheit etwas älter zu sein. Wenn ich deinen Scriptteil anhänge habe ich ewig viele Fehlermeldungen.

                  Könntest du eventuell nochmal das ganze Script posten?

                  liv-in-sky 1 Reply Last reply Reply Quote 0
                  • dslraser
                    dslraser Forum Testing Most Active @liv-in-sky last edited by

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

                    darin müssen die 3 mit "must be set" gesetzt werden

                    das habe ich nicht verstanden, was muß da rein ?

                    liv-in-sky 2 Replies Last reply Reply Quote 0
                    • liv-in-sky
                      liv-in-sky @Chaot last edited by

                      @Chaot sagte in Unifi WLAN Script:

                      @liv-in-sky
                      Eine Bitte hätte ich:
                      Ich kann leider den aktuellen "Kopf" des Scripts nirgendwo finden. Der ist hier irgendwo in den Beiträgen verstreut.
                      Mei Script scheit etwas älter zu sein. Wenn ich deinen Scriptteil anhänge habe ich ewig viele Fehlermeldungen.

                      Könntest du eventuell nochmal das ganze Script posten?

                      bin nicht am rechner mit dem script

                      hier der kopf

                      
                      // September 2019 @liv-in-sky durch viel vorarbeit von @thewhobox (api verbindung)
                      
                      // Definition Login
                      const unifi_username = "x";
                      const unifi_password = "xxxxxx";
                      const unifi_controller = "https://192.xxx.xxx.xxx:8443";
                      
                      
                      // DEFINITION der zu anzeigenden Netzwerke am besten bis auf id und smart alle gleich setzen: beispiel:
                      
                      const wifis = {
                      "WLAN_Dragon1": { name: "WLAN_Dragon1", id: "yyyyyyyyyyyyyyyyyyyyy", desc: "WLAN_Dragon1", smart: "WLAN_Dragon1" } ,
                      "WLAN_DragonGuest": { name: "WLAN_DragonGuest", id: "yyyyyyyyyyyyyyyyyyyy", desc: "WLAN_DragonGuest", smart: "WLAN_DragonGuest" }
                      }
                      
                      
                      

                      1 Reply Last reply Reply Quote 1
                      • liv-in-sky
                        liv-in-sky @dslraser last edited by

                        @dslraser hast du die voucher-sache schon im controller eingerichtet ?

                        dslraser 2 Replies Last reply Reply Quote 0
                        • dslraser
                          dslraser Forum Testing Most Active @liv-in-sky last edited by

                          @liv-in-sky
                          ja, ich nutze Voucher, oder was meinst Du ?

                          1 Reply Last reply Reply Quote 0
                          • dslraser
                            dslraser Forum Testing Most Active @liv-in-sky last edited by dslraser

                            @liv-in-sky
                            da muß doch was rein ?
                            Anzahl z.B. 1
                            Dauer z.B. 8h
                            MultiUse ???

                            Bildschirmfoto 2019-09-10 um 23.11.28.png

                            Das steht da, aber mit diesen Begriffen geht es nicht
                            Bildschirmfoto 2019-09-10 um 23.15.09.png

                            1 Reply Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @dslraser last edited by liv-in-sky

                              @dslraser sagte in Unifi WLAN Script:

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

                              darin müssen die 3 mit "must be set" gesetzt werden

                              das habe ich nicht verstanden, was muß da rein ?

                              die dauer in minuten z.b. 120 , die anzahl der vouchers und multiuse 0=immer wieder 1, ist nur einmal und jede andere zahl für n-mal also 5 für 5 mal

                              eigentlich klar, dass du das nicht wissen kannst - steht ja nirgends

                              upload und download in kbyte - mb_begrenzung in MByte - ohne einheiten

                              dslraser 1 Reply Last reply Reply Quote 0
                              • dslraser
                                dslraser Forum Testing Most Active @liv-in-sky last edited by

                                @liv-in-sky 👍 👍 👍

                                funktioniert. (in iQontol werden sie auch geschrieben)

                                Bildschirmfoto 2019-09-10 um 23.18.05.png

                                liv-in-sky 1 Reply Last reply Reply Quote 0
                                • liv-in-sky
                                  liv-in-sky @dslraser last edited by

                                  @dslraser

                                  die variable heißt: realname - darin steht dann bei aliasname ==true der wert "name" und bei false "hostname"

                                  jetzt müßte an der stelle wo hostname im script steht die variable hin - dann würde das ausgetauscht (auch das sortieren)

                                  ist nur die frage, wie ich diesen variablen inhalt selbst als variable nutze - muss ich noch rausfinden

                                  hier mal das aktuelle script: und wie immer datenpunkte löschen und instanz ändern

                                  
                                  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";
                                  
                                  
                                  
                                  
                                  // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, ind er das script läuft zusammenpassen
                                  const dpPrefix = "javascript.2.";
                                  
                                  //Pause bei Umschalten der WLANnetze, damit Netzanmeldungen der clients wieder normal
                                  const clientPauseConst = 200000;    //1000 bedeutet 1 Sekunde -  das braucht Zeit !!!
                                  
                                  // Abfragezyklus definieren
                                  const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
                                  const abfageoffset = 15000; // zu schnelle Abmeldungen können hier eingestellt weren - > erhöhen (15000 = 15 sek.)
                                  
                                  //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 "von hand" löschen
                                  let vouchers = true;
                                  let health = true;  // Angaben zum Systemstatus - die Healtdaten werden nur alle 5 Abfragezyklen geholt
                                  let aliasname=false; //benutzt alias namen im controller hinterlegt anstatt hostname - VORSICHT kein ALIAS definiert - keine Anzeige dess Clients
                                  
                                  // 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);\">";
                                  const format3 = "<table style=\"color:#848484; font-family:Helvetica;\">";
                                  
                                  //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                                  let cookies = [];
                                  let loggedIn = false;
                                  let debug = false;
                                  let mylogs = false;
                                  let clientPause = false;
                                  let clientPauseVal;
                                  let wifiDPs = [];
                                  let realname="hostname";
                                  let respv;
                                  let respc;
                                  let respw;
                                  let resph;
                                  let respgv;
                                  let statusarr=[];
                                  let versuch;
                                  let listeDatenpunkte = [];
                                  let lastChange=[];
                                  let testerrc=false;
                                  let testerrl=false;
                                  let testerrv=false;
                                  let testerrs=false;
                                  let testerrh=false;
                                  let testerrcv=false;
                                  let testerrws=false;
                                  var scriptCounter=0;
                                  let alarmSwitch =false;
                                  let alarmCounter =0;
                                  let firstTime=0;
                                  let mybodyVouchers;
                                  var wifiLength=0;
                                       for(let wifi_name in wifis) {      
                                     wifiLength++; }
                                  
                                  
                                  if (aliasname) realname=name;
                                  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")); 
                                  //if (aliasname) realname="name";
                                  
                                  
                                  //Erstelle Datenpunkte für die WLANs automatisch
                                  for(let wifi_name in wifis) {
                                  
                                      wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].name);
                                     
                                     createState(dpPrefix + "WLANUnifi."+ wifi_name, {
                                        name: wifis[wifi_name].desc,
                                        role: 'switch',
                                        read: true,
                                        write: true,
                                        type: "boolean",
                                        smartName: {
                                            de: wifis[wifi_name].smart,
                                            smartType: "SWITCH"
                                        } });}
                                  
                                  
                                  
                                  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,
                                  });
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create", false,  {
                                     name: ' A_New_Voucher_Create', 
                                     role: 'switch',
                                     type: 'boolean',
                                     read:  true, 
                                     write: true,
                                  });
                                  
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set",{
                                     name: ' A_New_Voucher_Dauer', 
                                     role: 'string',
                                     read:  true, 
                                     write: true,
                                  });
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set",{
                                     name: ' A_New_Voucher_MultiUse', 
                                     role: 'string',
                                     read:  true, 
                                     write: true,
                                  });
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set",{
                                     name: ' A_New_Voucher_Anzahl', 
                                     role: 'string',
                                     read:  true, 
                                     write: true,
                                  });
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "",{
                                     name: ' A_New_Voucher_Notiz', 
                                     role: 'string',
                                     read:  true, 
                                     write: true,
                                  });
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "",{
                                     name: ' A_New_Voucher_Uplaod', 
                                     role: 'string',
                                     read:  true, 
                                     write: true,
                                  });
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "",{
                                     name: ' A_New_Voucher_Download', 
                                     role: 'string',
                                     read:  true, 
                                     write: true,
                                  });
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", {
                                     name: ' A_New_Voucher_Mb_Begrenzung', 
                                     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 });
                                  
                                  if (health) {createState(dpPrefix + "WLANUnifi.Health.WLAN.Status", { name: 'Health_Status', desc: 'Health_Status', type: 'string', unit: '',  role: '',read: true, write: true }); 
                                              createState(dpPrefix + "WLANUnifi.Health.WLAN.Users", { name: 'Health_Users', desc: 'Health_Users', type: 'number', unit: '', min: '0', max: '1000', role: '',read: true, write: true }); 
                                              createState(dpPrefix + "WLANUnifi.Health.WLAN.Guests", { name: 'Health_Guests', desc: 'Health_Guests', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                              createState(dpPrefix + "WLANUnifi.Health.WLAN.TXBytes", { name: 'Health_TXBytes', desc: 'Health_TXBytes', type: 'number', unit: '', min: '0', max: '9999999', role: '',read: true, write: true });
                                              createState(dpPrefix + "WLANUnifi.Health.WLAN.RXBytes", { name: 'Health_RXBytes', desc: 'Health_RXBytes', type: 'number', unit: '', min: '0', max: '9999999', role: '',read: true, write: true }); 
                                              createState(dpPrefix + "WLANUnifi.Health.WLAN.Adopted", { name: 'Health_Adopted', desc: 'Health_Adopted', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                                              createState(dpPrefix + "WLANUnifi.Health.WLAN.Disabled", { name: 'Health_Disabled', desc: 'Health_Disabled', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                              createState(dpPrefix + "WLANUnifi.Health.WLAN.Disconnected", { name: 'Health_Disconnected', desc: 'Health_Disconnected', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });   }
                                  
                                  
                                  function dlog(message) {
                                    if(debug)
                                        console.log(message);
                                  }
                                  function mylog(message) {
                                    if(mylogs)
                                        console.log(message);
                                  }
                                  
                                  
                                  
                                  
                                  
                                  //-----------------------------------------LOGIN---------------------------------------------------------------
                                  async function login() {
                                    return new Promise(async (resolve, reject) => {
                                        cookies=[];
                                        let respl = 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) => { log("login: reject"), reject(e);  loggedIn =false;return respl=[];});
                                        
                                        if(respl != null) {
                                            mylog("login: login war erfolgreich! " + ((respl.headers && respl.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                            if(respl.headers && respl.headers.hasOwnProperty("set-cookie")) {
                                                let set_cookies = respl.headers["set-cookie"];
                                                for(i = 0; i < set_cookies.length; i++) {
                                                    let cookie = set_cookies[i];
                                                    //log(set_cookies[i]);
                                                    cookie = cookie.split(";")[0];
                                                    cookies.push(cookie);
                                                }
                                            } else {
                                                log("login: no cookies to set!")
                                            }
                                            loggedIn = true;
                                                  
                                            resolve();
                                        } else {
                                            log("login: rejected")
                                              loggedIn = false;
                                            reject("respl = null");
                                        }
                                    });
                                  }
                                  
                                   //-----------------------------------------LOGOUT---------------------------------------------------------------  
                                  async function logout() {
                                     log("BIN IN LOGOUT");
                                    return new Promise(async (resolve, reject) => {
                                        let respo = await request.get({
                                            url: unifi_controller + "/logout",
                                            headers: { Cookie: cookies.join("; ") }
                                        }).catch((e) => { log("logout fehler" + e)/*reject(e)*/ ;return testerrl=true;} );
                                        if (!testerrl) {
                                        if(respo != null) {
                                            log("Du bist nun ausgedloggt.");
                                            dlog(respo);
                                            log("BIN raus aus LOGOUT");
                                             loggedIn = true;          
                                            resolve();
                                           
                                        } else {
                                            reject("resp = null");
                                        }
                                        } else {log("reject weil resplogin ist 00"); log("BIN raus aus LOGOUT"); reject();}
                                        log("BIN raus aus LOGOUT");
                                    });
                                  }
                                  //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
                                  //Updatet status vom Wifi
                                  //wifi: wifi object aus der konstanten wifis
                                  function getStatus(wifi) {
                                       mylog("BIN IN STATUS");
                                    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)*/ return testerrs=true; });
                                      if (!testerrs) {
                                        dlog("got response " + JSON.stringify(resp));
                                        resp = JSON.parse(resp);
                                  
                                        let wlanOn = resp.data[0].enabled;
                                        dlog("WLAN " + wifi.name + " ist: " + (wlanOn ? "an" : "aus"));
                                  
                                        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"));
                                            setStateDelayed(dpPrefix + "WLANUnifi." + wifi.name, wlanOn, 200);
                                         
                                            resolve(wlanOn);
                                        } else {
                                            log("nicht ok... getStatusWifi")
                                            reject(JSON.stringify(resp));
                                        }
                                        } else {mylog("reject weil respslogin ist 00"); mylog("BIN raus aus LOGOUT"); reject();}
                                        mylog("BIN aus STATUS raus");
                                    });
                                     
                                  }
                                  
                                  //-----------------------------------------GETCLIENTS---------------------------------------------------------------
                                  async function getClients() {
                                      mylog("BIN IN getclients");
                                     
                                     return new Promise(async (resolve, reject) => {
                                         dlog("getclient nur mal so" + loggedIn);
                                        if(!loggedIn) await login().catch((e) => reject(e));
                                          respc = await request.get({
                                             url: unifi_controller + "/api/s/default/stat/sta",
                                             headers: { Cookie: cookies.join("; ") }
                                         }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrc=true; }); 
                                          
                                    if (!testerrc) {     
                                  dlog("got respconse nach log in getclient " + JSON.stringify(respc));
                                  dlog(typeof respc);
                                  dlog("--------------------- " + respc);
                                  //respc = JSON.parse(respc);
                                  
                                  //Sortierung Daten und Verwandlung Json
                                  
                                  var unfiltered = [];
                                  unfiltered = JSON.parse(respc).data;
                                  dlog(unfiltered[2].hostname + unfiltered[2].mac);
                                  versuch = [];
                                  for(var index in unfiltered) {
                                     let device = unfiltered[index];
                                     if(device.hostname !== undefined && device.essid !== undefined)
                                         versuch.push(device);
                                  }
                                  versuch.sort(function (alpha, beta) {
                                     if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase())
                                         return -1;
                                     if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase())
                                         return 1;
                                     return 0;
                                  });
                                  
                                  resolve();
                                    } else {log("reject weil respc 00"); reject() } mylog("bin raus aus  getclients");
                                  }); //new promise
                                  
                                  } //getclientend
                                  //-----------------------------------------workCLIENTS---------------------------------------------------------------
                                   function workClients() {
                                      mylog("BIN IN workclients");
                                      dlog("got respconse " + JSON.stringify(respc));
                                      dlog(typeof respc);
                                      dlog("--------------------- " + respc);
                                  
                                  let writeFile = true;
                                  let  writeFileVar = 0;
                                  let writeClientTable = true;
                                  let writeAnwesenheit = true;
                                  
                                  var anzahlClients = versuch.length;
                                  setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                                  
                                  var clientListe = "";
                                  getExistingClients();
                                  
                                  
                                  mylog("Status1");
                                  
                                  var listeDatenpunkteNew=[];                                                        //erstelle aktuelles array von controller daten
                                  for (var i = 0; i < versuch.length; i++) { 
                                     listeDatenpunkteNew[i] = versuch[i].hostname;}
                                    dlog (listeDatenpunkteNew[3]);
                                  
                                  // sind clients von controller in verzeichnisliste ? 
                                   for (var z = 0; z < listeDatenpunkteNew.length; z++) 
                                    {
                                             if ( listeDatenpunkte.indexOf(listeDatenpunkteNew[z]) == -1 ){   //ist controller-client existent nicht in verzeichnis-list
                                                    mylog("Datenpunktanlegen" + listeDatenpunkteNew[z] +"index:"+ listeDatenpunkte.indexOf(listeDatenpunkteNew[z]).toString());
                                                    var ipWandler= versuch[z].ip;
                                                    var data = dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname;
                                                    createState(data, true, {
                                                    name: ipWandler, 
                                                    role: 'boolean',
                                                    read:  true, 
                                                    write: true,
                                                   }, function() {mylog("created");
                                                    });
                                                    //setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+ versuch[z].hostname, true);
                                  
                                                 //  {setState(data, true);
                                                    mylog("Datenpunktanlegen fertig" + listeDatenpunkteNew[z] + listeDatenpunkte[z]) ;
                                                } else {dlog("ist in verzeichnis"+ listeDatenpunkteNew[z] );}
                                   }
                                  
                                  mylog("Status2");
                                  
                                  //sind datenpunkte noch in controller vorhanden
                                   if (anwesenheit) {
                                   for (var z = 0; z < listeDatenpunkte.length; z++)  {
                                             if ( listeDatenpunkteNew.indexOf(listeDatenpunkte[z]) == -1 ){        //ist datenpunkt-verzeihnis existent und nicht in controller liste
                                                 if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z]).val) {          // setze datenpunkt auf false - nur wenn true war
                                                       setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z], false, 500);
                                                       mylog("Datenpunkt ist falsch zu setzen"+listeDatenpunkte[z]);}
                                                } else {dlog("ist noch im controller" + listeDatenpunkte[z]);}
                                  
                                                
                                   } }  
                                  
                                  mylog("Status3"); 
                                  
                                  // setze datenpunkte nach last_seen_by_uap - ausnahme: controller-clients sind nicht mehr connectet aber in vereichnis 
                                  
                                  let lastChangeList;
                                  if (anwesenheit) {
                                  timeout = setTimeout(function () {  //wegen createstate und zu schnelles setstate
                                  
                                  
                                  
                                  for (var z = 0; z < listeDatenpunkteNew.length; z++)  {
                                  
                                     var tester = parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000);
                                     dlog(tester.toString() + "laenge : " +listeDatenpunkteNew.length);
                                     if (parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) > abfragezyklus+abfageoffset && getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val) {
                                         setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, false, 100);
                                         mylog("abgesetzt: " +listeDatenpunkteNew[z] + " um " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                                         if (lastChange.length>=10) lastChange.shift()
                                         lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>out</td><td>&ensp;&ensp;vor: "+tester/1000+" Sek</td></tr>");
                                            mylog(lastChange[0]);
                                      
                                     }
                                     if (parseFloat((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) < abfragezyklus && !getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val || getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val ==null ) {
                                         setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, true, 100);
                                         mylog("gesetzt" +listeDatenpunkteNew[z]+" " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                                         if (lastChange.length>=10) lastChange.shift()
                                         lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>in</td><td>&ensp;&ensp;vor: " + tester/1000+" Sek</td></tr>");
                                     }  
                                  }
                                  
                                  
                                  
                                  mylog("Status4");
                                  // erstelle htmlclientliste wenn listenDaten verändert  
                                      
                                       for (var i = 0; i < versuch.length; i++)  {
                                         dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                                         if  (parseInt((new Date().getTime())) - (versuch[i]._last_seen_by_uap*1000) < abfragezyklus+15000) {                      
                                         clientListe = clientListe.concat("<tr><td>"+versuch[i].hostname+"&ensp;</td><td>"+versuch[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+versuch[i].ip+"</td></tr>");
                                         dlog(clientListe);}  
                                         else {anzahlClients=anzahlClients-1;}
                                         }
                                       setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);   //korrigiert
                                  
                                  mylog("Status5");
                                  
                                  if (iqontrol && anwesenheit ) {
                                     
                                     lastChangeList=format3;
                                     for (var g = lastChange.length-1; g >= 0 ; g--)  {
                                         lastChangeList=lastChangeList.concat(lastChange[g]/*+"</table>"*/); 
                                         lastChangeList.concat(lastChange[g]+"</table>");
                                        }
                                  
                                     fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:#01A9DB; font-family:Helvetica;\">Geamtanzahl angemeldeter Clients:"+anzahlClients+"</p><p style=\"color:#848484; font-family:Helvetica;\">Letzter Wechsel im Netzwerk:</br>"+lastChangeList+"</p>"));
                                     //if (lastChange.length>10) lastChange=[];
                                  }
                                  dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                                  if (true) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                                  mylog("bin raus aus  workclients");
                                  
                                  }, 2500);}
                                  
                                  
                                  } //workclientend
                                  
                                  //-----------------------------------------EXISTING CLIENTS---------------------------------------------------------------
                                  function getExistingClients() {
                                     dlog("BIN IN EXISTING CLIENTS");
                                  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.", "");}
                                  });
                                  
                                  dlog("bin raus a existing clients");
                                  }
                                  
                                  
                                  //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
                                  async function getVouchers() {
                                      if (vouchers)  {
                                       mylog("BIN IN getvouchers");
                                     return new Promise(async (resolve, reject) => {
                                         dlog("nur mal so");
                                         if(!loggedIn) await login().catch((e) => reject(e));
                                          respv = await request.get({
                                             url: unifi_controller + "/api/s/default/stat/voucher",
                                             headers: { Cookie: cookies.join("; ") }
                                         }).catch((e) => { dlog("getStatus reject " + e); /*reject(e)*/ return testerrv=true; });  
                                    if (!testerrv) {
                                  dlog("got response " + JSON.stringify(respv));
                                  dlog(typeof respv);
                                  dlog("--------------------- " + respv);
                                  resolve("done");
                                    } else {log("reject weil respv ist 00"); reject();}
                                  mylog("bin raus a GET vouchers");
                                  });
                                  }}
                                  
                                  //-----------------------------------------WORK--VOUCHERS---------------------------------------------------------------
                                  function workVouchers() {
                                     if (vouchers)  {
                                   //  mylog("BIN IN  workvouchers");
                                     dlog("got response " + JSON.stringify(respv));
                                     dlog(typeof respv);
                                     dlog("--------------------- " + respv);
                                  respv = JSON.parse(respv);
                                  
                                     dlog("--------------------- " + respv);
                                  dlog(respv.meta);
                                  dlog(respv.meta.rc);
                                  dlog(respv.data[1].code);
                                  dlog(respv.data.length);
                                  dlog(JSON.stringify(respv).length.toString());
                                  var writeFile;
                                  var laengeMessage=JSON.stringify(respv).length;
                                  if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                  var writeFileVar=JSON.stringify(respv).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 < respv.data.length; i++) { 
                                    var zeit= respv.data[i].create_time*1000
                                    let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                  
                                    clientListe = clientListe.concat("<tr><td>"+respv.data[i].duration+"&ensp;</td><td>"+respv.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+respv.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, respv.data[i].code );
                                        setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                        setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", respv.data[i].duration );
                                        setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", respv.data[i].status_expires );
                                        
                                    }}
                                  }
                                  
                                  //Datenpunkteäalt löschen
                                  var w = respv.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:"+respv.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", respv.data.length);
                                  //mylog("BIN RAUS AUS  workvouchers");
                                  
                                  }
                                  //-----------------------------------------GET--Health---------------------------------------------------------------
                                  async function getHealth() {
                                      if (vouchers)  {
                                       mylog("BIN IN gethealth");
                                     return new Promise(async (resolve, reject) => {
                                         dlog("nur mal so");
                                         if(!loggedIn) await login().catch((e) => reject(e));
                                          resph = await request.get({
                                             url: unifi_controller + "/api/s/default/stat/health",
                                             headers: { Cookie: cookies.join("; ") }
                                         }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrh=true; });  
                                    if (!testerrh) {
                                  dlog("got response " + JSON.stringify(resph));
                                  dlog(typeof resph);
                                  mylog("--------------------- " + resph);
                                  resolve("done");
                                    } else {log("reject weil resph ist 00"); reject();}
                                  mylog("bin raus a GET health");
                                  });
                                  }}
                                  //-----------------------------------------WORK--HEALTH---------------------------------------------------------------
                                  function workHealth() {
                                     
                                     mylog("BIN IN  workhealth");
                                     dlog("got response " + JSON.stringify(resph));
                                     dlog(typeof resph);
                                     dlog("--------------------- " + resph);
                                     resph=resph.replace(/-r/g, "_r")
                                     resph = JSON.parse(resph);
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.Status",resph.data[0].status );
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.Users",resph.data[0].num_user);
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.Guests",resph.data[0].num_guest );
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.TXBytes",resph.data[0].tx_bytes_r );
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.RXBytes",resph.data[0].rx_bytes_r );
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.Adopted",resph.data[0].num_adopted );
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.Disabled",resph.data[0].num_disabled );
                                     setState(dpPrefix + "WLANUnifi.Health.WLAN.Disconnected",resph.data[0].num_disconnected );
                                  
                                     mylog("bin raus a work health");
                                  }
                                  //-----------------------------------------SET WIFIS - WIFI EIN-AUSSCHALTEN----------------------------------------------
                                  //Wifi an-/ausschalten
                                  //enabled: true = anschalten; false = ausschalten
                                  //wifi: wifi object aus der konstanten wifis
                                  async function setWifi(enabled, wifi) {
                                    if (!clientPause) {
                                    return new Promise(async (resolve, reject) => {
                                        dlog("setWifi: start set Wifi_haupt");
                                        if (!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                        dlog("setWifi: now setting Wifi_haupt");
                                        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)*/ return testerrws=true; });
                                        dlog("setWifi: got response")
                                  
                                        if (resp != null) {
                                            dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                            dlog(resp);
                                                    // getclient()  Pause für umschalten
                                  
                                            if (firstTime>=wifiLength) {       
                                            clientPause = true;
                                            clientPauseVal=parseInt((new Date().getTime())); 
                                            }
                                         
                                            setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                                            resolve();
                                        } else {
                                            dlog("setWifi: rejetced")
                                            dlog("resp: " + JSON.stringify(resp));
                                            reject("msg: " + JSON.parse(resp.body).meta.msg);}
                                        
                                    });
                                  } else { log("WLAN wird gerade umgeschaltet"); }
                                  }
                                  
                                  //-----------------------------------------CREATE VOUCHERS----------------------------------------------
                                  //Wifi an-/ausschalten
                                  //enabled: true = anschalten; false = ausschalten
                                  //wifi: wifi object aus der konstanten wifis
                                  async function createVoucher (mybody) {
                                  
                                    mylog(JSON.stringify( mybody ));
                                    return new Promise(async (resolve, reject) => {
                                        log("createVoucher in aktion");
                                        if (!loggedIn) { mylog("need to login"); await login().catch((e) => reject(e)); }
                                        mylog("do it !");
                                        let respcv = request.post({
                                            url: unifi_controller + "/api/s/default/cmd/hotspot/" ,
                                            body: JSON.stringify( mybody ),
                                            // body: mybody,
                                            headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                        }).catch((e) => { log("setWifi: rejected: " + e);  /*reject(e)*/ return testerrcv=true; });
                                        log("setWifi: got response")
                                        log("------------: "+respcv);
                                  
                                    });
                                  }
                                  
                                  //-----------------------------------------------SCHALTER------------------------------------------------
                                  on({id: wifiDPs, ack: false, change: "ne"}, function (obj) { 
                                   var value = obj.state.val;
                                   var dp2 = obj.name
                                   setWifi(value, wifis[dp2]);
                                   dlog(wifis[dp2])
                                   if (firstTime<wifiLength+1) firstTime++;
                                   
                                   
                                            
                                  });
                                  //-----------------------------------------------SCHALTER Create Voucher------------------------------------------------
                                  on({id:  dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",  val: true}, function (obj) { 
                                    var mybodyVouchers;
                                    var expire_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer").val;
                                    var n_var      = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl").val ;
                                    var quota_var  = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse").val ;
                                    var note_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz").val;
                                    var up_var     = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload").val ;
                                    var down_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download").val;
                                    var MBytes_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung").val ;
                                  
                                      if (expire_var !="must be set" && n_var!="must be set" && quota_var!="must be set" &&  !clientPause)  {
                                  
                                    
                                      //   Orginal JSON Daten
                                      /*   mybodyVouchers = {cmd:'create-voucher',expire:expire_var,   
                                                                         n:n_var, 
                                                                         quota:quota_var,
                                                                         note:note_var,
                                                                         up:up_var, 
                                                                         down:down_var,  
                                                                         MBytes:MBytes_var };*/
                                  
                                       var x = "{cmd:'create-voucher',expire:"+expire_var+", n:"+n_var+", quota:"+quota_var+","
                                  
                                         if (note_var != "")   x= x.concat('note:\"'+note_var+'\",')
                                         if (up_var != "")     x= x.concat("up:"+up_var+",")
                                         if (down_var != "")   x= x.concat("down:"+down_var+",")                                                        
                                         if (MBytes_var != "") x= x.concat("MBytes:"+MBytes_var+",")  
                                  
                                       x=x.substr(0, x.length-1);
                                       x=x.concat("}");
                                       log (x);
                                       eval('var mybodyVouchers='+x);
                                       log(mybodyVouchers);
                                                                                    
                                       createVoucher(mybodyVouchers);
                                  
                                     } else {log("FEHLER IN createVoucher - sind die 'must be set' Werte gesetzt?","error")}
                                  
                                    setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",false, 4000);
                                    //setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set" , 2000);
                                    //setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set", 2000);
                                    //setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set", 2000);
                                    setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "", 2000);
                                    setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "", 2000);
                                    setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "", 2000);
                                    setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", 2000);
                                  });
                                  
                                  
                                  //-----------------------------------------------MAIN LOOP------------------------------------------------
                                  setInterval(async () => {
                                  
                                      scriptCounter++
                                      mylog("-----------------------SCRIPTCOUNTER------------------ ist : " + scriptCounter );
                                      mylog(loggedIn.toString())
                                          
                                      await login().catch(alarm1)  
                                  
                                     log("------------------------------------------------Werte Alarme: " + testerrl + " - " + testerrc+ " - " +testerrv + " - "+testerrs + " - "+testerrh);
                                  
                                  if (loggedIn) {
                                      if (alarmCounter > 5) {log("Unifi Sript funktioniert wieder - Verbindung wieder hergestellt","error");}
                                      if (alarmCounter > 0) {alarmCounter=0; }
                                      
                                      await getClients().catch(alarm3)  ;
                                      if (vouchers) await getVouchers().catch(alarm4);
                                      if (health)   await getHealth().catch(alarm7);
                                      if ( !testerrl && !testerrc && !testerrv && !testerrs && !testerrh ) {
                                             workVouchers();
                                             workClients();
                                             if (health && scriptCounter==5) {scriptCounter=0;workHealth();}
                                             }
                                    
                                             
                                     for(let wifi_name in wifis) {
                                         
                                         await getStatus(wifis[wifi_name]).catch(alarm6)}   
                                  
                                  }   else { alarmCounter++; 
                                            if (alarmCounter > 5) {log("Unifi Sript hat 'Problem mit Einloggen - Prüfe Unifi Controller, Port, Einlog-Daten","error");
                                                                   if  (!testerrv) log("evtl. Vouchers deaktivieren","warn");}}
                                  
                                                                   
                                    if (clientPause) {
                                          var interim=parseInt(new Date().getTime());
                                          log("Unifi Script ist in Pause wegen WLAN Umschalteung- bis: " + formatDate(clientPauseVal + clientPauseConst, "SS:mm:ss"),"warn");
                                          if (interim - clientPauseVal > clientPauseConst) {clientPause=false;log("Unifi Script hat Pause beendet" );}  }
                                  
                                            
                                   testerrc=false;
                                       testerrv=false;
                                        testerrs=false;
                                         testerrl=false;
                                          testerrc=false;
                                           testerrh=false;
                                  
                                  
                                  
                                     }, abfragezyklus); // wird oben definiert
                                  
                                  function alarm12() {log("Im Unifi Script stimmte etwas nicht - Alarm12 - Create Voucher","warn");     loggedIn=false; testerrcv=false;cookies=[];}   
                                  function alarm11() {log("Im Unifi Script stimmte etwas nicht - Alarm11 - WLAN schalten","warn");      loggedIn=false; testerrws=false;cookies=[];} 
                                  
                                  function alarm7() {log("Im Unifi Script stimmte etwas nicht - Alarm7 - Health","warn");               loggedIn=false; testerrh=false;cookies=[];}   
                                  function alarm6() {log("Im Unifi Script stimmte etwas nicht - Alarm6 - Statusabfrage","warn");        loggedIn=false; testerrs=false;cookies=[];}    
                                  function alarm5() {log("Im Unifi Script stimmte etwas nicht - Alarm5 - logout","warn");               loggedIn=false; testerrl=false;cookies=[];}    
                                  function alarm4() {log("Im Unifi Script stimmte etwas nicht - Alarm4 - getVouchers-Login","warn");    loggedIn=false; testerrv=false;cookies=[];}
                                  function alarm3() {log("Im Unifi Script stimmte etwas nicht - Alarm3 - getClient-Login","warn");      loggedIn=false; testerrc=false;cookies=[];}
                                  function alarm1() {log("Im Unifi Script stimmte etwas nicht - Alarm1 - Login fehlgeschlagen","warn"); loggedIn=false; ;alarmSwitch=true }
                                  
                                  
                                  
                                  // Beispiel für
                                  //setWifi(true, wifis.WLAN_DragonGuest);
                                  

                                  dslraser 2 Replies Last reply Reply Quote 0
                                  • dslraser
                                    dslraser Forum Testing Most Active @liv-in-sky last edited by

                                    @liv-in-sky
                                    ist in dem Script schon was geändert, oder soll ich selbst was austauschen ?

                                    1 Reply Last reply Reply Quote 0
                                    • dslraser
                                      dslraser Forum Testing Most Active @liv-in-sky last edited by

                                      @liv-in-sky
                                      eine Sache wäre vielleicht doch noch ganz interessant ?!?
                                      Es wäre ganz schön zu sehen an welchem AP welches Gerät gerade angemeldet ist, der Controller gibt das eigentlich her.
                                      Kannst Du ohne riesen Aufwand die Clientlisten (auch die für iQontrol) damit erweitern ?

                                      liv-in-sky 2 Replies Last reply Reply Quote 0
                                      • Chaot
                                        Chaot last edited by

                                        Bei mir werden zwar die Datenpunkte geschrieben, aber nicht gefüllt.
                                        Was habe ich da falsch eingestellt?

                                        // September 2019 @liv-in-sky durch viel vorarbeit von @thewhobox (api verbindung)
                                        
                                         
                                        
                                        // Definition Login
                                        
                                        const unifi_username = "Username";
                                        
                                        const unifi_password = "Passwort";
                                        
                                        const unifi_controller = "https://192.168.xxx.xxx:8443";
                                         
                                        
                                         
                                        
                                        // DEFINITION der zu anzeigenden Netzwerke am besten bis auf id und smart alle gleich setzen: beispiel:
                                        
                                        const wifis = {
                                        
                                         "Stxxx": { name: "Stxxx", id: "xxxxx275010c07fcc103", desc: "Stxxx", smart: "Stxxx" } ,
                                        
                                         "Gast": { name: "Gast", id: "xxxxx0275010c07fcc10c", desc: "Gast", smart: "Gast" }
                                        
                                        }
                                        
                                        
                                        
                                        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";
                                        
                                         
                                        
                                        // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, inder das script läuft zusammenpassen
                                        
                                        const dpPrefix = "javascript.0.";
                                        
                                         
                                        
                                        //Pause bei Umschalten der WLANnetze, damit Netzanmeldungen wieder normal
                                        
                                        const clientPauseConst = 200000;    //1000 bedeutet 1 Sekunde -  das braucht Zeit !!!
                                        
                                         
                                        
                                        // Abfragezyklus definieren
                                        
                                        const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
                                        
                                        const abfageoffset = 15000; // zu schnelle Abmeldungen können hier eingestellt weren - > erhöhen (15000 = 15 sek.)
                                        
                                         
                                        
                                        //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 "von hand" löschen
                                        
                                        let vouchers = true;
                                        
                                        //let aliasname=false; //benutzt alias namen im controller hinterlegt anstatt hostname - VORSICHT kein ALIAS definiert - keine Anzeige dess Clients
                                        
                                         
                                        
                                        // 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);\">";
                                        
                                        const format3 = "<table style=\"color:#848484; font-family:Helvetica;\">";
                                        
                                         
                                        
                                        //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                                        
                                        let cookies = [];
                                        
                                        let loggedIn = false;
                                        
                                        let debug = false;
                                        
                                        let mylogs = false;
                                        
                                        let clientPause = false;
                                        
                                        let clientPauseVal;
                                        
                                        let wifiDPs = [];
                                        
                                        let realname="hostname";
                                        
                                        let respv;
                                        
                                        let respc;
                                        
                                        let respw;
                                        
                                        let resph;
                                        
                                        let statusarr=[];
                                        
                                        let versuch;
                                        
                                        let listeDatenpunkte = [];
                                        
                                        let lastChange=[];
                                        
                                        let testerrc=false;
                                        
                                        let testerrl=false;
                                        
                                        let testerrv=false;
                                        
                                        let testerrs=false;
                                        
                                        let testerrh=false;
                                        
                                        let firstTime=0;
                                        
                                        let mybodyVouchers;
                                        
                                        var wifiLength=0;
                                        
                                             for(let wifi_name in wifis) {      
                                        
                                           wifiLength++; }
                                        
                                         
                                        
                                        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")); 
                                        
                                        //if (aliasname) realname="name";
                                        
                                         
                                        
                                         
                                        
                                        //Erstelle Datenpunkte für die WLANs automatisch
                                        
                                        for(let wifi_name in wifis) {
                                        
                                         
                                        
                                            wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].name);
                                        
                                           
                                        
                                           createState(dpPrefix + "WLANUnifi."+ wifi_name, {
                                        
                                              name: wifis[wifi_name].desc,
                                        
                                              role: 'switch',
                                        
                                              read: true,
                                        
                                              write: true,
                                        
                                              type: "boolean",
                                        
                                              smartName: {
                                        
                                                  de: wifis[wifi_name].smart,
                                        
                                                  smartType: "SWITCH"
                                        
                                              } });}
                                        
                                         
                                        
                                         
                                        
                                        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,
                                        
                                        });
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create", false,  {
                                        
                                           name: ' A_New_Voucher_Create', 
                                        
                                           role: 'switch',
                                        
                                           type: 'boolean',
                                        
                                           read:  true, 
                                        
                                           write: true,
                                        
                                        });
                                        
                                         
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set",{
                                        
                                           name: ' A_New_Voucher_Dauer', 
                                        
                                           role: 'string',
                                        
                                           read:  true, 
                                        
                                           write: true,
                                        
                                        });
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set",{
                                        
                                           name: ' A_New_Voucher_MultiUse', 
                                        
                                           role: 'string',
                                        
                                           read:  true, 
                                        
                                           write: true,
                                        
                                        });
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set",{
                                        
                                           name: ' A_New_Voucher_Anzahl', 
                                        
                                           role: 'string',
                                        
                                           read:  true, 
                                        
                                           write: true,
                                        
                                        });
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "",{
                                        
                                           name: ' A_New_Voucher_Notiz', 
                                        
                                           role: 'string',
                                        
                                           read:  true, 
                                        
                                           write: true,
                                        
                                        });
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "",{
                                        
                                           name: ' A_New_Voucher_Uplaod', 
                                        
                                           role: 'string',
                                        
                                           read:  true, 
                                        
                                           write: true,
                                        
                                        });
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "",{
                                        
                                           name: ' A_New_Voucher_Download', 
                                        
                                           role: 'string',
                                        
                                           read:  true, 
                                        
                                           write: true,
                                        
                                        });
                                        
                                        createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", {
                                        
                                           name: ' A_New_Voucher_Mb_Begrenzung', 
                                        
                                           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);
                                        
                                        }
                                        
                                        function mylog(message) {
                                        
                                          if(mylogs)
                                        
                                              console.log(message);
                                        
                                        }
                                        
                                         
                                        
                                         
                                        
                                         
                                        
                                         
                                        
                                         
                                        
                                        //-----------------------------------------LOGIN---------------------------------------------------------------
                                        
                                        async function login() {
                                        
                                          return new Promise(async (resolve, reject) => {
                                        
                                              cookies=[];
                                        
                                              let respl = 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) => { log("login: reject"), reject(e);  loggedIn =false;return respl=[];});
                                        
                                              
                                        
                                              if(respl != null) {
                                        
                                                  mylog("login: login war erfolgreich! " + ((respl.headers && respl.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                        
                                                  if(respl.headers && respl.headers.hasOwnProperty("set-cookie")) {
                                        
                                                      let set_cookies = respl.headers["set-cookie"];
                                        
                                                      for(i = 0; i < set_cookies.length; i++) {
                                        
                                                          let cookie = set_cookies[i];
                                        
                                                          //log(set_cookies[i]);
                                        
                                                          cookie = cookie.split(";")[0];
                                        
                                                          cookies.push(cookie);
                                        
                                                      }
                                        
                                                  } else {
                                        
                                                      log("login: no cookies to set!")
                                        
                                                  }
                                        
                                                  loggedIn = true;
                                        
                                                        
                                        
                                                  resolve();
                                        
                                              } else {
                                        
                                                  log("login: rejected")
                                        
                                                    loggedIn = false;
                                        
                                                  reject("respl = null");
                                        
                                              }
                                        
                                          });
                                        
                                        }
                                        
                                         
                                        
                                         //-----------------------------------------LOGOUT---------------------------------------------------------------  
                                        
                                        async function logout() {
                                        
                                           log("BIN IN LOGOUT");
                                        
                                          return new Promise(async (resolve, reject) => {
                                        
                                              let respo = await request.get({
                                        
                                                  url: unifi_controller + "/logout",
                                        
                                                  headers: { Cookie: cookies.join("; ") }
                                        
                                              }).catch((e) => { log("logout fehler" + e)/*reject(e)*/ ;return testerrl=true;} );
                                        
                                              if (!testerrl) {
                                        
                                              if(respo != null) {
                                        
                                                  log("Du bist nun ausgedloggt.");
                                        
                                                  dlog(respo);
                                        
                                                  log("BIN raus aus LOGOUT");
                                        
                                                   loggedIn = true;          
                                        
                                                  resolve();
                                        
                                                 
                                        
                                              } else {
                                        
                                                  reject("resp = null");
                                        
                                              }
                                        
                                              } else {log("reject weil resplogin ist 00"); log("BIN raus aus LOGOUT"); reject();}
                                        
                                              log("BIN raus aus LOGOUT");
                                        
                                          });
                                        
                                        }
                                        
                                        //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
                                        
                                        //Updatet status vom Wifi
                                        
                                        //wifi: wifi object aus der konstanten wifis
                                        
                                        function getStatus(wifi) {
                                        
                                             mylog("BIN IN STATUS");
                                        
                                          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)*/ return testerrs=true; });
                                        
                                            if (!testerrs) {
                                        
                                              dlog("got response " + JSON.stringify(resp));
                                        
                                              resp = JSON.parse(resp);
                                        
                                         
                                        
                                              let wlanOn = resp.data[0].enabled;
                                        
                                              dlog("WLAN " + wifi.name + " ist: " + (wlanOn ? "an" : "aus"));
                                        
                                         
                                        
                                              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"));
                                        
                                                  setStateDelayed(dpPrefix + "WLANUnifi." + wifi.name, wlanOn, 200);
                                        
                                               
                                        
                                                  resolve(wlanOn);
                                        
                                              } else {
                                        
                                                  log("nicht ok... getStatusWifi")
                                        
                                                  reject(JSON.stringify(resp));
                                        
                                              }
                                        
                                              } else {mylog("reject weil respslogin ist 00"); mylog("BIN raus aus LOGOUT"); reject();}
                                        
                                              mylog("BIN aus STATUS raus");
                                        
                                          });
                                        
                                           
                                        
                                        }
                                        
                                         
                                        
                                        //-----------------------------------------GETCLIENTS---------------------------------------------------------------
                                        
                                        async function getClients() {
                                        
                                            mylog("BIN IN getclients");
                                        
                                           
                                        
                                           return new Promise(async (resolve, reject) => {
                                        
                                               dlog("getclient nur mal so" + loggedIn);
                                        
                                              if(!loggedIn) await login().catch((e) => reject(e));
                                        
                                                respc = await request.get({
                                        
                                                   url: unifi_controller + "/api/s/default/stat/sta",
                                        
                                                   headers: { Cookie: cookies.join("; ") }
                                        
                                               }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrc=true; }); 
                                        
                                                
                                        
                                          if (!testerrc) {     
                                        
                                        dlog("got respconse nach log in getclient " + JSON.stringify(respc));
                                        
                                        dlog(typeof respc);
                                        
                                        dlog("--------------------- " + respc);
                                        
                                        //respc = JSON.parse(respc);
                                        
                                         
                                        
                                        //Sortierung Daten und Verwandlung Json
                                        
                                         
                                        
                                        var unfiltered = [];
                                        
                                        unfiltered = JSON.parse(respc).data;
                                        
                                        dlog(unfiltered[2].hostname + unfiltered[2].mac);
                                        
                                        versuch = [];
                                        
                                        for(var index in unfiltered) {
                                        
                                           let device = unfiltered[index];
                                        
                                           if(device.hostname !== undefined && device.essid !== undefined)
                                        
                                               versuch.push(device);
                                        
                                        }
                                        
                                        versuch.sort(function (alpha, beta) {
                                        
                                           if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase())
                                        
                                               return -1;
                                        
                                           if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase())
                                        
                                               return 1;
                                        
                                           return 0;
                                        
                                        });
                                        
                                         
                                        
                                        resolve();
                                        
                                          } else {log("reject weil respc 00"); reject() } mylog("bin raus aus  getclients");
                                        
                                        }); //new promise
                                        
                                         
                                        
                                        } //getclientend
                                        
                                        //-----------------------------------------workCLIENTS---------------------------------------------------------------
                                        
                                         function workClients() {
                                        
                                            mylog("BIN IN workclients");
                                        
                                            dlog("got respconse " + JSON.stringify(respc));
                                        
                                            dlog(typeof respc);
                                        
                                            dlog("--------------------- " + respc);
                                        
                                         
                                        
                                        let writeFile = true;
                                        
                                        let  writeFileVar = 0;
                                        
                                        let writeClientTable = true;
                                        
                                        let writeAnwesenheit = true;
                                        
                                         
                                        
                                        var anzahlClients = versuch.length;
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                                        
                                         
                                        
                                        var clientListe = "";
                                        
                                        getExistingClients();
                                        
                                         
                                        
                                         
                                        
                                        mylog("Status1");
                                        
                                         
                                        
                                        var listeDatenpunkteNew=[];                                                        //erstelle aktuelles array von controller daten
                                        
                                        for (var i = 0; i < versuch.length; i++) { 
                                        
                                           listeDatenpunkteNew[i] = versuch[i].hostname;}
                                        
                                          dlog (listeDatenpunkteNew[3]);
                                        
                                         
                                        
                                        // sind clients von controller in verzeichnisliste ? 
                                        
                                         for (var z = 0; z < listeDatenpunkteNew.length; z++) 
                                        
                                          {
                                        
                                                   if ( listeDatenpunkte.indexOf(listeDatenpunkteNew[z]) == -1 ){   //ist controller-client existent nicht in verzeichnis-list
                                        
                                                          mylog("Datenpunktanlegen" + listeDatenpunkteNew[z] +"index:"+ listeDatenpunkte.indexOf(listeDatenpunkteNew[z]).toString());
                                        
                                                          var ipWandler= versuch[z].ip;
                                        
                                                          var data = dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname;
                                        
                                                          createState(data, true, {
                                        
                                                          name: ipWandler, 
                                        
                                                          role: 'boolean',
                                        
                                                          read:  true, 
                                        
                                                          write: true,
                                        
                                                         }, function() {mylog("created");
                                        
                                                          });
                                        
                                                          //setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+ versuch[z].hostname, true);
                                        
                                         
                                        
                                                       //  {setState(data, true);
                                        
                                                          mylog("Datenpunktanlegen fertig" + listeDatenpunkteNew[z] + listeDatenpunkte[z]) ;
                                        
                                                      } else {dlog("ist in verzeichnis"+ listeDatenpunkteNew[z] );}
                                        
                                         }
                                        
                                         
                                        
                                        mylog("Status2");
                                        
                                         
                                        
                                        //sind datenpunkte noch in controller vorhanden
                                        
                                         if (anwesenheit) {
                                        
                                         for (var z = 0; z < listeDatenpunkte.length; z++)  {
                                        
                                                   if ( listeDatenpunkteNew.indexOf(listeDatenpunkte[z]) == -1 ){        //ist datenpunkt-verzeihnis existent und nicht in controller liste
                                        
                                                       if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z]).val) {          // setze datenpunkt auf false - nur wenn true war
                                        
                                                             setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z], false, 500);
                                        
                                                             mylog("Datenpunkt ist falsch zu setzen"+listeDatenpunkte[z]);}
                                        
                                                      } else {dlog("ist noch im controller" + listeDatenpunkte[z]);}
                                        
                                         
                                        
                                                      
                                        
                                         } }  
                                        
                                         
                                        
                                        mylog("Status3"); 
                                        
                                         
                                        
                                        // setze datenpunkte nach last_seen_by_uap - ausnahme: controller-clients sind nicht mehr connectet aber in vereichnis 
                                        
                                         
                                        
                                        let lastChangeList;
                                        
                                        if (anwesenheit) {
                                        
                                        timeout = setTimeout(function () {  //wegen createstate und zu schnelles setstate
                                        
                                         
                                        
                                         
                                        
                                         
                                        
                                        for (var z = 0; z < listeDatenpunkteNew.length; z++)  {
                                        
                                         
                                        
                                           var tester = parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000);
                                        
                                           dlog(tester.toString() + "laenge : " +listeDatenpunkteNew.length);
                                        
                                           if (parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) > abfragezyklus+abfageoffset && getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val) {
                                        
                                               setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, false, 100);
                                        
                                               mylog("abgesetzt: " +listeDatenpunkteNew[z] + " um " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                                        
                                               if (lastChange.length>=10) lastChange.shift()
                                        
                                               lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>out</td><td>&ensp;&ensp;vor: "+tester/1000+" Sek</td></tr>");
                                        
                                                  mylog(lastChange[0]);
                                        
                                            
                                        
                                           }
                                        
                                           if (parseFloat((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) < abfragezyklus && !getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val || getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val ==null ) {
                                        
                                               setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, true, 100);
                                        
                                               mylog("gesetzt" +listeDatenpunkteNew[z]+" " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                                        
                                               if (lastChange.length>=10) lastChange.shift()
                                        
                                               lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>in</td><td>&ensp;&ensp;vor: " + tester/1000+" Sek</td></tr>");
                                        
                                           }  
                                        
                                        }
                                        
                                         
                                        
                                         
                                        
                                         
                                        
                                        mylog("Status4");
                                        
                                        // erstelle htmlclientliste wenn listenDaten verändert  
                                        
                                            
                                        
                                             for (var i = 0; i < versuch.length; i++)  {
                                        
                                               dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                                        
                                               if  (parseInt((new Date().getTime())) - (versuch[i]._last_seen_by_uap*1000) < abfragezyklus+15000) {                      
                                        
                                               clientListe = clientListe.concat("<tr><td>"+versuch[i].hostname+"&ensp;</td><td>"+versuch[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+versuch[i].ip+"</td></tr>");
                                        
                                               dlog(clientListe);}  
                                        
                                               else {anzahlClients=anzahlClients-1;}
                                        
                                               }
                                        
                                             setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);   //korrigiert
                                        
                                         
                                        
                                        mylog("Status5");
                                        
                                         
                                        
                                        if (iqontrol && anwesenheit ) {
                                        
                                           
                                        
                                           lastChangeList=format3;
                                        
                                           for (var g = lastChange.length-1; g >= 0 ; g--)  {
                                        
                                               lastChangeList=lastChangeList.concat(lastChange[g]/*+"</table>"*/); 
                                        
                                               lastChangeList.concat(lastChange[g]+"</table>");
                                        
                                              }
                                        
                                         
                                        
                                           fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:#01A9DB; font-family:Helvetica;\">Geamtanzahl angemeldeter Clients:"+anzahlClients+"</p><p style=\"color:#848484; font-family:Helvetica;\">Letzter Wechsel im Netzwerk:</br>"+lastChangeList+"</p>"));
                                        
                                           //if (lastChange.length>10) lastChange=[];
                                        
                                        }
                                        
                                        dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                                        
                                        if (true) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                                        
                                        mylog("bin raus aus  workclients");
                                        
                                         
                                        
                                        }, 2500);}
                                        
                                         
                                        
                                         
                                        
                                        } //workclientend
                                        
                                         
                                        
                                        //-----------------------------------------EXISTING CLIENTS---------------------------------------------------------------
                                        
                                        function getExistingClients() {
                                        
                                           dlog("BIN IN EXISTING CLIENTS");
                                        
                                        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.", "");}
                                        
                                        });
                                        
                                         
                                        
                                        dlog("bin raus a existing clients");
                                        
                                        }
                                        
                                         
                                        
                                         
                                        
                                        //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
                                        
                                        async function getVouchers() {
                                        
                                            if (vouchers)  {
                                        
                                             mylog("BIN IN getvouchers");
                                        
                                           return new Promise(async (resolve, reject) => {
                                        
                                               dlog("nur mal so");
                                        
                                               if(!loggedIn) await login().catch((e) => reject(e));
                                        
                                                respv = await request.get({
                                        
                                                   url: unifi_controller + "/api/s/default/stat/voucher",
                                        
                                                   headers: { Cookie: cookies.join("; ") }
                                        
                                               }).catch((e) => { dlog("getStatus reject " + e); /*reject(e)*/ return testerrv=true; });  
                                        
                                          if (!testerrv) {
                                        
                                        dlog("got response " + JSON.stringify(respv));
                                        
                                        dlog(typeof respv);
                                        
                                        dlog("--------------------- " + respv);
                                        
                                        resolve("done");
                                        
                                          } else {log("reject weil respv ist 00"); reject();}
                                        
                                        mylog("bin raus a GET vouchers");
                                        
                                        });
                                        
                                        }}
                                        
                                         
                                        
                                         
                                        
                                        //-----------------------------------------WORK--VOUCHERS---------------------------------------------------------------
                                        
                                        function workVouchers() {
                                        
                                           if (vouchers)  {
                                        
                                         //  mylog("BIN IN  workvouchers");
                                        
                                           dlog("got response " + JSON.stringify(respv));
                                        
                                           dlog(typeof respv);
                                        
                                           dlog("--------------------- " + respv);
                                        
                                        respv = JSON.parse(respv);
                                        
                                         
                                        
                                           dlog("--------------------- " + respv);
                                        
                                        dlog(respv.meta);
                                        
                                        dlog(respv.meta.rc);
                                        
                                        dlog(respv.data[1].code);
                                        
                                        dlog(respv.data.length);
                                        
                                        dlog(JSON.stringify(respv).length.toString());
                                        
                                        var writeFile;
                                        
                                        var laengeMessage=JSON.stringify(respv).length;
                                        
                                        if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                        
                                        var writeFileVar=JSON.stringify(respv).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 < respv.data.length; i++) { 
                                        
                                          var zeit= respv.data[i].create_time*1000
                                        
                                          let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                        
                                         
                                        
                                          clientListe = clientListe.concat("<tr><td>"+respv.data[i].duration+"&ensp;</td><td>"+respv.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+respv.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, respv.data[i].code );
                                        
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                        
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", respv.data[i].duration );
                                        
                                              setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", respv.data[i].status_expires );
                                        
                                              
                                        
                                          }}
                                        
                                        }
                                        
                                         
                                        
                                        //Datenpunkteäalt löschen
                                        
                                        var w = respv.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:"+respv.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", respv.data.length);
                                        
                                        //mylog("BIN RAUS AUS  workvouchers");
                                        
                                         
                                        
                                        }
                                        
                                        //-----------------------------------------GET--Health---------------------------------------------------------------
                                        
                                        async function getHealth() {
                                        
                                            if (vouchers)  {
                                        
                                             mylog("BIN IN gethealth");
                                        
                                           return new Promise(async (resolve, reject) => {
                                        
                                               dlog("nur mal so");
                                        
                                               if(!loggedIn) await login().catch((e) => reject(e));
                                        
                                                resph = await request.get({
                                        
                                                   url: unifi_controller + "/api/s/default/stat/health",
                                        
                                                   headers: { Cookie: cookies.join("; ") }
                                        
                                               }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrh=true; });  
                                        
                                          if (!testerrv) {
                                        
                                        dlog("got response " + JSON.stringify(resph));
                                        
                                        dlog(typeof resph);
                                        
                                        dlog("--------------------- " + resph);
                                        
                                        resolve("done");
                                        
                                          } else {log("reject weil resph ist 00"); reject();}
                                        
                                        mylog("bin raus a GET health");
                                        
                                        });
                                        
                                        }}
                                        
                                         
                                        
                                        //-----------------------------------------SET WIFIS - WIFI EIN-AUSSCHALTEN----------------------------------------------
                                        
                                        //Wifi an-/ausschalten
                                        
                                        //enabled: true = anschalten; false = ausschalten
                                        
                                        //wifi: wifi object aus der konstanten wifis
                                        
                                        async function setWifi(enabled, wifi) {
                                        
                                          return new Promise(async (resolve, reject) => {
                                        
                                              dlog("setWifi: start set Wifi_haupt");
                                        
                                              if (!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                        
                                              dlog("setWifi: now setting Wifi_haupt");
                                        
                                              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);
                                        
                                                          // getclient()  Pause für umschalten
                                        
                                         
                                        
                                                  if (firstTime>=wifiLength) {       
                                        
                                                  clientPause = true;
                                        
                                                  clientPauseVal=parseInt((new Date().getTime())); 
                                        
                                                  }
                                        
                                               
                                        
                                                  setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                                        
                                                  resolve();
                                        
                                              } else {
                                        
                                                  dlog("setWifi: rejetced")
                                        
                                                  dlog("resp: " + JSON.stringify(resp));
                                        
                                                  reject("msg: " + JSON.parse(resp.body).meta.msg);
                                        
                                              }
                                        
                                          });
                                        
                                        }
                                        
                                         
                                        
                                        //-----------------------------------------CREATE VOUCHERS----------------------------------------------
                                        
                                        //Wifi an-/ausschalten
                                        
                                        //enabled: true = anschalten; false = ausschalten
                                        
                                        //wifi: wifi object aus der konstanten wifis
                                        
                                        async function createVoucher (mybody) {
                                        
                                         
                                        
                                         //var mybody = {cmd:'create-voucher',expire:120,n:1,quota:5,note:"ist im test",up:10,down:10,MBytes:""};
                                        
                                         
                                        
                                          
                                        
                                         
                                        
                                          mylog(JSON.stringify( mybody ));
                                        
                                          return new Promise(async (resolve, reject) => {
                                        
                                              mylog("createVoucher in aktion");
                                        
                                              if (!loggedIn) { mylog("need to login"); await login().catch((e) => reject(e)); }
                                        
                                              mylog("do it !");
                                        
                                              let respcv = request.post({
                                        
                                                  url: unifi_controller + "/api/s/default/cmd/hotspot/" ,
                                        
                                                  body: JSON.stringify( mybody ),
                                        
                                                  // body: mybody,
                                        
                                                  headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                        
                                              }).catch((e) => { mylog("setWifi: rejected: " + e); reject(e) });
                                        
                                              mylog("setWifi: got response")
                                        
                                             // log("------------: "+respcv);
                                        
                                          /*    if (resp != null) {
                                        
                                                  dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                        
                                                  dlog(resp);
                                        
                                                          // getclient()  Pause für umschalten
                                        
                                        {1}
                                        
                                             
                                        
                                               
                                        
                                                  setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                                        
                                                  resolve();
                                        
                                              } else {
                                        
                                                  dlog("setWifi: rejetced")
                                        
                                                  dlog("resp: " + JSON.stringify(resp));
                                        
                                                  reject("msg: " + JSON.parse(resp.body).meta.msg);
                                        
                                              }*/
                                        
                                          });
                                        
                                        }
                                        
                                         
                                        
                                        //-----------------------------------------------SCHALTER------------------------------------------------
                                        
                                        on({id: wifiDPs, ack: false, change: "ne"}, function (obj) { 
                                        
                                         var value = obj.state.val;
                                        
                                         var dp2 = obj.name
                                        
                                         setWifi(value, wifis[dp2]);
                                        
                                         dlog(wifis[dp2])
                                        
                                         if (firstTime<wifiLength+1) firstTime++;
                                        
                                         
                                        
                                         
                                        
                                                  
                                        
                                        });
                                        
                                         
                                        
                                        on({id:  dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",  val: true}, function (obj) { 
                                        
                                        var mybodyVouchers;
                                        
                                        var expire_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer").val;
                                        
                                        var n_var      = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl").val ;
                                        
                                        var quota_var  = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse").val ;
                                        
                                        var note_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz").val;
                                        
                                        var up_var     = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload").val ;
                                        
                                        var down_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download").val;
                                        
                                        var MBytes_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung").val ;
                                        
                                         
                                        
                                         if (expire_var !="must be set" && n_var!="must be set" && quota_var!="must be set" ) {
                                        
                                         
                                        
                                          
                                        
                                         
                                        
                                          /*   mybodyVouchers = {cmd:'create-voucher',expire:expire_var,   
                                        
                                                                               n:n_var, 
                                        
                                                                               quota:quota_var,
                                        
                                                                               note:note_var,
                                        
                                                                               up:up_var, 
                                        
                                                                               down:down_var,  
                                        
                                                                               MBytes:MBytes_var };*/
                                        
                                         
                                        
                                        var x = "{cmd:'create-voucher',expire:"+expire_var+", n:"+n_var+", quota:"+quota_var+","
                                        
                                         
                                        
                                        //if (note_var != "")   x= x.concat("up:\'"+note_var+"\',")
                                        
                                        if (up_var != "")     x= x.concat("up:"+up_var+",")
                                        
                                        if (down_var != "")   x= x.concat("down:"+down_var+",")                                                        
                                        
                                        if (MBytes_var != "") x= x.concat("MBytes:"+MBytes_var+",") 
                                        
                                         
                                        
                                         x=x.substr(0, x.length-1);
                                        
                                         x=x.concat("}");
                                        
                                         //log (x);
                                        
                                         eval('var mybodyVouchers='+x);
                                        
                                         
                                        
                                                                                          
                                        
                                            createVoucher(mybodyVouchers);
                                        
                                         
                                        
                                        } else {log("FEHLER IN createVoucher","error")}
                                        
                                         
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",false, 4000);
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set" , 2000);
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set", 2000);
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set", 2000);
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "", 2000);
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "", 2000);
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "", 2000);
                                        
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", 2000);
                                        
                                        });
                                        
                                         
                                        
                                         
                                        
                                        let scriptCounter=0;
                                        
                                        let alarmSwitch =false;
                                        
                                        let alarmCounter =0;
                                        
                                         
                                        
                                        //-----------------------------------------------MAIN LOOP------------------------------------------------
                                        
                                        setInterval(async () => {
                                        
                                         
                                        
                                            scriptCounter++
                                        
                                            mylog("-----------------------SCRIPTCOUNTER------------------ ist : " + scriptCounter );
                                        
                                            mylog(loggedIn.toString())
                                        
                                                
                                        
                                            await login().catch(alarm1)  
                                        
                                         
                                        
                                           mylog("------------------------------------------------Werte Alarme: " + testerrl + " - " + testerrc+ " - " +testerrv + " - "+testerrs);
                                        
                                         
                                        
                                        if (loggedIn) {
                                        
                                            if (alarmCounter > 5) {log("Unifi Sript funktioniert wieder - Verbindung wieder hergestellt","error");}
                                        
                                            if (alarmCounter > 0) {alarmCounter=0; }
                                        
                                            
                                        
                                            await getClients().catch(alarm3)  ;
                                        
                                            await getVouchers().catch(alarm4);
                                        
                                            await getHealth().catch(alarm7);
                                        
                                            if ( !testerrl && !testerrc && !testerrv && !testerrs  ) {
                                        
                                                   workVouchers();
                                        
                                                   workClients();}
                                        
                                          
                                        
                                                   
                                        
                                           for(let wifi_name in wifis) {
                                        
                                               
                                        
                                               await getStatus(wifis[wifi_name]).catch(alarm6)}   
                                        
                                         
                                        
                                        }   else { alarmCounter++; 
                                        
                                                  if (alarmCounter > 5) {log("Unifi Sript hat 'Problem mit Einloggen - Prüfe Unifi Controller, Port, Einlog-Daten","error");
                                        
                                                                         if  (!testerrv) log("evtl. Vouchers deaktivieren","warn");}}
                                        
                                         
                                        
                                                                         
                                        
                                          if (clientPause) {
                                        
                                                var interim=parseInt(new Date().getTime());
                                        
                                                log("Unifi Script ist in Pause wegen WLAN Umschalteung- bis: " + formatDate(clientPauseVal + clientPauseConst, "SS:mm:ss"),"warn");
                                        
                                                if (interim - clientPauseVal > clientPauseConst) {clientPause=false;log("Unifi Script hat Pause beendet" );}  }
                                        
                                         
                                        
                                                  
                                        
                                         testerrc=false;
                                        
                                             testerrv=false;
                                        
                                              testerrs=false;
                                        
                                               testerrl=false;
                                        
                                                testerrc=false;
                                        
                                                 testerrh=false;
                                        
                                         
                                        
                                         
                                        
                                         
                                        
                                           }, abfragezyklus); // wird oben definiert
                                        
                                         
                                        
                                        function alarm7() {log("Im Unifi Script stimmte etwas nicht - Alarm7 - Health","warn");               loggedIn=false; testerrh=false;cookies=[];}   
                                        
                                        function alarm6() {log("Im Unifi Script stimmte etwas nicht - Alarm6 - Statusabfrage","warn");        loggedIn=false; testerrs=false;cookies=[];}    
                                        
                                        function alarm5() {log("Im Unifi Script stimmte etwas nicht - Alarm5 - logout","warn");               loggedIn=false; testerrl=false;cookies=[];}    
                                        
                                        function alarm4() {log("Im Unifi Script stimmte etwas nicht - Alarm4 - getVouchers-Login","warn");    loggedIn=false; testerrv=false;cookies=[];}
                                        
                                        function alarm3() {log("Im Unifi Script stimmte etwas nicht - Alarm3 - getClient-Login","warn");      loggedIn=false; testerrc=false;cookies=[];}
                                        
                                        function alarm1() {log("Im Unifi Script stimmte etwas nicht - Alarm1 - Login fehlgeschlagen","warn"); loggedIn=false; ;alarmSwitch=true }
                                        
                                         
                                        
                                         
                                        
                                         
                                        
                                        // Beispiel für
                                        
                                        //setWifi(true, wifis.WLAN_DragonGuest);
                                        
                                         
                                        
                                        
                                        liv-in-sky 1 Reply Last reply Reply Quote 1
                                        • liv-in-sky
                                          liv-in-sky @Chaot last edited by liv-in-sky

                                          @Chaot ich gehe davon aus, dass du das script selbst nicht verändert hast und die portadresse des unifi controller ist standard
                                          die instanz hast du ja geändert auf javascript.0 - das script läuft auch darunter!

                                          • wird garnichts geschrieben ?

                                          • wenn sich das script nicht verbindet, müßte im log etwas stehen - ist sonst fast zu wenig info zum helfen - habe es gerade nochmal getestet - z.b falscher port oder login namen erzeugt sofort eine warnung im log

                                          • setze iqontrol, anwesenheit und vouchers auf false - zum test

                                          du hast ein anderes format - und doppelt so viele zeilen wie das orginal - ich weiß nicht, ob das ein problem sein kann

                                          script stoppen

                                          • alle datenpunkte löschen
                                            alles bei dir ersetzen (mit dem neuen script - am post-ende) ab "const request .........." nach der definition der netzwerke - dann wieder die javascript instanz auf 0 einstellen

                                          hier das aktuellste script - wenn du einen raspberry oder etwas anderes langsames hast, könntet du den (wert in deinem script) in zeile 937 mal auf 3500 setzen

                                          hier das aktuelle script

                                          
                                          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";
                                          
                                          
                                          
                                          
                                          // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, ind er das script läuft zusammenpassen
                                          const dpPrefix = "javascript.2.";
                                          
                                          //Pause bei Umschalten der WLANnetze, damit Netzanmeldungen der clients wieder normal
                                          const clientPauseConst = 200000;    //1000 bedeutet 1 Sekunde -  das braucht Zeit !!!
                                          
                                          // Abfragezyklus definieren
                                          const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
                                          const abfageoffset = 15000; // zu schnelle Abmeldungen können hier eingestellt weren - > erhöhen (15000 = 15 sek.)
                                          
                                          //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 "von hand" löschen
                                          let vouchers = true;
                                          let health = true;  // Angaben zum Systemstatus - die Healtdaten werden nur alle 5 Abfragezyklen geholt
                                          let aliasname=false; //benutzt alias namen im controller hinterlegt anstatt hostname - VORSICHT kein ALIAS definiert - keine Anzeige dess Clients
                                          
                                          // 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);\">";
                                          const format3 = "<table style=\"color:#848484; font-family:Helvetica;\">";
                                          
                                          //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                                          let cookies = [];
                                          let loggedIn = false;
                                          let debug = false;
                                          let mylogs = false;
                                          let clientPause = false;
                                          let clientPauseVal;
                                          let wifiDPs = [];
                                          let realname="hostname";
                                          let respv;
                                          let respc;
                                          let respw;
                                          let resph;
                                          let respgv;
                                          let statusarr=[];
                                          let versuch;
                                          let listeDatenpunkte = [];
                                          let lastChange=[];
                                          let testerrc=false;
                                          let testerrl=false;
                                          let testerrv=false;
                                          let testerrs=false;
                                          let testerrh=false;
                                          let testerrcv=false;
                                          let testerrws=false;
                                          var scriptCounter=0;
                                          let alarmSwitch =false;
                                          let alarmCounter =0;
                                          let firstTime=0;
                                          let mybodyVouchers;
                                          var wifiLength=0;
                                               for(let wifi_name in wifis) {      
                                             wifiLength++; }
                                          
                                          
                                          if (aliasname) realname=name;
                                          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")); 
                                          //if (aliasname) realname="name";
                                          
                                          
                                          //Erstelle Datenpunkte für die WLANs automatisch
                                          for(let wifi_name in wifis) {
                                          
                                              wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].name);
                                             
                                             createState(dpPrefix + "WLANUnifi."+ wifi_name, {
                                                name: wifis[wifi_name].desc,
                                                role: 'switch',
                                                read: true,
                                                write: true,
                                                type: "boolean",
                                                smartName: {
                                                    de: wifis[wifi_name].smart,
                                                    smartType: "SWITCH"
                                                } });}
                                          
                                          
                                          
                                          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,
                                          });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create", false,  {
                                             name: ' A_New_Voucher_Create', 
                                             role: 'switch',
                                             type: 'boolean',
                                             read:  true, 
                                             write: true,
                                          });
                                          
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set",{
                                             name: ' A_New_Voucher_Dauer', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set",{
                                             name: ' A_New_Voucher_MultiUse', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set",{
                                             name: ' A_New_Voucher_Anzahl', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "",{
                                             name: ' A_New_Voucher_Notiz', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "",{
                                             name: ' A_New_Voucher_Uplaod', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "",{
                                             name: ' A_New_Voucher_Download', 
                                             role: 'string',
                                             read:  true, 
                                             write: true,
                                          });
                                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", {
                                             name: ' A_New_Voucher_Mb_Begrenzung', 
                                             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 });
                                          
                                          if (health) {createState(dpPrefix + "WLANUnifi.Health.WLAN.Status", { name: 'Health_Status', desc: 'Health_Status', type: 'string', unit: '',  role: '',read: true, write: true }); 
                                                      createState(dpPrefix + "WLANUnifi.Health.WLAN.Users", { name: 'Health_Users', desc: 'Health_Users', type: 'number', unit: '', min: '0', max: '1000', role: '',read: true, write: true }); 
                                                      createState(dpPrefix + "WLANUnifi.Health.WLAN.Guests", { name: 'Health_Guests', desc: 'Health_Guests', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                                      createState(dpPrefix + "WLANUnifi.Health.WLAN.TXBytes", { name: 'Health_TXBytes', desc: 'Health_TXBytes', type: 'number', unit: '', min: '0', max: '9999999', role: '',read: true, write: true });
                                                      createState(dpPrefix + "WLANUnifi.Health.WLAN.RXBytes", { name: 'Health_RXBytes', desc: 'Health_RXBytes', type: 'number', unit: '', min: '0', max: '9999999', role: '',read: true, write: true }); 
                                                      createState(dpPrefix + "WLANUnifi.Health.WLAN.Adopted", { name: 'Health_Adopted', desc: 'Health_Adopted', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                                                      createState(dpPrefix + "WLANUnifi.Health.WLAN.Disabled", { name: 'Health_Disabled', desc: 'Health_Disabled', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                                      createState(dpPrefix + "WLANUnifi.Health.WLAN.Disconnected", { name: 'Health_Disconnected', desc: 'Health_Disconnected', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });   }
                                          
                                          
                                          function dlog(message) {
                                            if(debug)
                                                console.log(message);
                                          }
                                          function mylog(message) {
                                            if(mylogs)
                                                console.log(message);
                                          }
                                          
                                          
                                          
                                          
                                          
                                          //-----------------------------------------LOGIN---------------------------------------------------------------
                                          async function login() {
                                            return new Promise(async (resolve, reject) => {
                                                cookies=[];
                                                let respl = 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) => { log("login: reject"), reject(e);  loggedIn =false;return respl=[];});
                                                
                                                if(respl != null) {
                                                    mylog("login: login war erfolgreich! " + ((respl.headers && respl.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                                    if(respl.headers && respl.headers.hasOwnProperty("set-cookie")) {
                                                        let set_cookies = respl.headers["set-cookie"];
                                                        for(i = 0; i < set_cookies.length; i++) {
                                                            let cookie = set_cookies[i];
                                                            //log(set_cookies[i]);
                                                            cookie = cookie.split(";")[0];
                                                            cookies.push(cookie);
                                                        }
                                                    } else {
                                                        log("login: no cookies to set!")
                                                    }
                                                    loggedIn = true;
                                                          
                                                    resolve();
                                                } else {
                                                    log("login: rejected")
                                                      loggedIn = false;
                                                    reject("respl = null");
                                                }
                                            });
                                          }
                                          
                                           //-----------------------------------------LOGOUT---------------------------------------------------------------  
                                          async function logout() {
                                             log("BIN IN LOGOUT");
                                            return new Promise(async (resolve, reject) => {
                                                let respo = await request.get({
                                                    url: unifi_controller + "/logout",
                                                    headers: { Cookie: cookies.join("; ") }
                                                }).catch((e) => { log("logout fehler" + e)/*reject(e)*/ ;return testerrl=true;} );
                                                if (!testerrl) {
                                                if(respo != null) {
                                                    log("Du bist nun ausgedloggt.");
                                                    dlog(respo);
                                                    log("BIN raus aus LOGOUT");
                                                     loggedIn = true;          
                                                    resolve();
                                                   
                                                } else {
                                                    reject("resp = null");
                                                }
                                                } else {log("reject weil resplogin ist 00"); log("BIN raus aus LOGOUT"); reject();}
                                                log("BIN raus aus LOGOUT");
                                            });
                                          }
                                          //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
                                          //Updatet status vom Wifi
                                          //wifi: wifi object aus der konstanten wifis
                                          function getStatus(wifi) {
                                               mylog("BIN IN STATUS");
                                            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)*/ return testerrs=true; });
                                              if (!testerrs) {
                                                dlog("got response " + JSON.stringify(resp));
                                                resp = JSON.parse(resp);
                                          
                                                let wlanOn = resp.data[0].enabled;
                                                dlog("WLAN " + wifi.name + " ist: " + (wlanOn ? "an" : "aus"));
                                          
                                                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"));
                                                    setStateDelayed(dpPrefix + "WLANUnifi." + wifi.name, wlanOn, 200);
                                                 
                                                    resolve(wlanOn);
                                                } else {
                                                    log("nicht ok... getStatusWifi")
                                                    reject(JSON.stringify(resp));
                                                }
                                                } else {mylog("reject weil respslogin ist 00"); mylog("BIN raus aus LOGOUT"); reject();}
                                                mylog("BIN aus STATUS raus");
                                            });
                                             
                                          }
                                          
                                          //-----------------------------------------GETCLIENTS---------------------------------------------------------------
                                          async function getClients() {
                                              mylog("BIN IN getclients");
                                             
                                             return new Promise(async (resolve, reject) => {
                                                 dlog("getclient nur mal so" + loggedIn);
                                                if(!loggedIn) await login().catch((e) => reject(e));
                                                  respc = await request.get({
                                                     url: unifi_controller + "/api/s/default/stat/sta",
                                                     headers: { Cookie: cookies.join("; ") }
                                                 }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrc=true; }); 
                                                  
                                            if (!testerrc) {     
                                          dlog("got respconse nach log in getclient " + JSON.stringify(respc));
                                          dlog(typeof respc);
                                          dlog("--------------------- " + respc);
                                          //respc = JSON.parse(respc);
                                          
                                          //Sortierung Daten und Verwandlung Json
                                          
                                          var unfiltered = [];
                                          unfiltered = JSON.parse(respc).data;
                                          dlog(unfiltered[2].hostname + unfiltered[2].mac);
                                          versuch = [];
                                          for(var index in unfiltered) {
                                             let device = unfiltered[index];
                                             if(device.hostname !== undefined && device.essid !== undefined)
                                                 versuch.push(device);
                                          }
                                          versuch.sort(function (alpha, beta) {
                                             if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase())
                                                 return -1;
                                             if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase())
                                                 return 1;
                                             return 0;
                                          });
                                          
                                          resolve();
                                            } else {log("reject weil respc 00"); reject() } mylog("bin raus aus  getclients");
                                          }); //new promise
                                          
                                          } //getclientend
                                          //-----------------------------------------workCLIENTS---------------------------------------------------------------
                                           function workClients() {
                                              mylog("BIN IN workclients");
                                              dlog("got respconse " + JSON.stringify(respc));
                                              dlog(typeof respc);
                                              dlog("--------------------- " + respc);
                                          
                                          let writeFile = true;
                                          let  writeFileVar = 0;
                                          let writeClientTable = true;
                                          let writeAnwesenheit = true;
                                          
                                          var anzahlClients = versuch.length;
                                          setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                                          
                                          var clientListe = "";
                                          getExistingClients();
                                          
                                          
                                          mylog("Status1");
                                          
                                          var listeDatenpunkteNew=[];                                                        //erstelle aktuelles array von controller daten
                                          for (var i = 0; i < versuch.length; i++) { 
                                             listeDatenpunkteNew[i] = versuch[i].hostname;}
                                            dlog (listeDatenpunkteNew[3]);
                                          
                                          // sind clients von controller in verzeichnisliste ? 
                                           for (var z = 0; z < listeDatenpunkteNew.length; z++) 
                                            {
                                                     if ( listeDatenpunkte.indexOf(listeDatenpunkteNew[z]) == -1 ){   //ist controller-client existent nicht in verzeichnis-list
                                                            mylog("Datenpunktanlegen" + listeDatenpunkteNew[z] +"index:"+ listeDatenpunkte.indexOf(listeDatenpunkteNew[z]).toString());
                                                            var ipWandler= versuch[z].ip;
                                                            var data = dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname;
                                                            createState(data, true, {
                                                            name: ipWandler, 
                                                            role: 'boolean',
                                                            read:  true, 
                                                            write: true,
                                                           }, function() {mylog("created");
                                                            });
                                                            //setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+ versuch[z].hostname, true);
                                          
                                                         //  {setState(data, true);
                                                            mylog("Datenpunktanlegen fertig" + listeDatenpunkteNew[z] + listeDatenpunkte[z]) ;
                                                        } else {dlog("ist in verzeichnis"+ listeDatenpunkteNew[z] );}
                                           }
                                          
                                          mylog("Status2");
                                          
                                          //sind datenpunkte noch in controller vorhanden
                                           if (anwesenheit) {
                                           for (var z = 0; z < listeDatenpunkte.length; z++)  {
                                                     if ( listeDatenpunkteNew.indexOf(listeDatenpunkte[z]) == -1 ){        //ist datenpunkt-verzeihnis existent und nicht in controller liste
                                                         if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z]).val) {          // setze datenpunkt auf false - nur wenn true war
                                                               setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[z], false, 500);
                                                               mylog("Datenpunkt ist falsch zu setzen"+listeDatenpunkte[z]);}
                                                        } else {dlog("ist noch im controller" + listeDatenpunkte[z]);}
                                          
                                                        
                                           } }  
                                          
                                          mylog("Status3"); 
                                          
                                          // setze datenpunkte nach last_seen_by_uap - ausnahme: controller-clients sind nicht mehr connectet aber in vereichnis 
                                          
                                          let lastChangeList;
                                          if (anwesenheit) {
                                          timeout = setTimeout(function () {  //wegen createstate und zu schnelles setstate
                                          
                                          
                                          
                                          for (var z = 0; z < listeDatenpunkteNew.length; z++)  {
                                          
                                             var tester = parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000);
                                             dlog(tester.toString() + "laenge : " +listeDatenpunkteNew.length);
                                             if (parseInt((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) > abfragezyklus+abfageoffset && getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val) {
                                                 setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, false, 100);
                                                 mylog("abgesetzt: " +listeDatenpunkteNew[z] + " um " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                                                 if (lastChange.length>=10) lastChange.shift()
                                                 lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>out</td><td>&ensp;&ensp;vor: "+tester/1000+" Sek</td></tr>");
                                                    mylog(lastChange[0]);
                                              
                                             }
                                             if (parseFloat((new Date().getTime())) - (versuch[z]._last_seen_by_uap*1000) < abfragezyklus && !getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val || getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname).val ==null ) {
                                                 setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[z].hostname, true, 100);
                                                 mylog("gesetzt" +listeDatenpunkteNew[z]+" " +formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss") + " Uhr");
                                                 if (lastChange.length>=10) lastChange.shift()
                                                 lastChange.push("<tr><td>"+listeDatenpunkteNew[z]+"&ensp;&ensp;</td><td>"+formatDate(getDateObject((parseFloat((new Date().getTime())) - tester)), "SS:mm:ss")+"&ensp;&ensp;&ensp;&ensp;</td><td>in</td><td>&ensp;&ensp;vor: " + tester/1000+" Sek</td></tr>");
                                             }  
                                          }
                                          
                                          
                                          
                                          mylog("Status4");
                                          // erstelle htmlclientliste wenn listenDaten verändert  
                                              
                                               for (var i = 0; i < versuch.length; i++)  {
                                                 dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                                                 if  (parseInt((new Date().getTime())) - (versuch[i]._last_seen_by_uap*1000) < abfragezyklus+15000) {                      
                                                 clientListe = clientListe.concat("<tr><td>"+versuch[i].hostname+"&ensp;</td><td>"+versuch[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+versuch[i].ip+"</td></tr>");
                                                 dlog(clientListe);}  
                                                 else {anzahlClients=anzahlClients-1;}
                                                 }
                                               setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);   //korrigiert
                                          
                                          mylog("Status5");
                                          
                                          if (iqontrol && anwesenheit ) {
                                             
                                             lastChangeList=format3;
                                             for (var g = lastChange.length-1; g >= 0 ; g--)  {
                                                 lastChangeList=lastChangeList.concat(lastChange[g]/*+"</table>"*/); 
                                                 lastChangeList.concat(lastChange[g]+"</table>");
                                                }
                                          
                                             fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:#01A9DB; font-family:Helvetica;\">Geamtanzahl angemeldeter Clients:"+anzahlClients+"</p><p style=\"color:#848484; font-family:Helvetica;\">Letzter Wechsel im Netzwerk:</br>"+lastChangeList+"</p>"));
                                             //if (lastChange.length>10) lastChange=[];
                                          }
                                          dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                                          if (true) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                                          mylog("bin raus aus  workclients");
                                          
                                          }, 2500);}
                                          
                                          
                                          } //workclientend
                                          
                                          //-----------------------------------------EXISTING CLIENTS---------------------------------------------------------------
                                          function getExistingClients() {
                                             dlog("BIN IN EXISTING CLIENTS");
                                          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.", "");}
                                          });
                                          
                                          dlog("bin raus a existing clients");
                                          }
                                          
                                          
                                          //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
                                          async function getVouchers() {
                                              if (vouchers)  {
                                               mylog("BIN IN getvouchers");
                                             return new Promise(async (resolve, reject) => {
                                                 dlog("nur mal so");
                                                 if(!loggedIn) await login().catch((e) => reject(e));
                                                  respv = await request.get({
                                                     url: unifi_controller + "/api/s/default/stat/voucher",
                                                     headers: { Cookie: cookies.join("; ") }
                                                 }).catch((e) => { dlog("getStatus reject " + e); /*reject(e)*/ return testerrv=true; });  
                                            if (!testerrv) {
                                          dlog("got response " + JSON.stringify(respv));
                                          dlog(typeof respv);
                                          dlog("--------------------- " + respv);
                                          resolve("done");
                                            } else {log("reject weil respv ist 00"); reject();}
                                          mylog("bin raus a GET vouchers");
                                          });
                                          }}
                                          
                                          //-----------------------------------------WORK--VOUCHERS---------------------------------------------------------------
                                          function workVouchers() {
                                             if (vouchers)  {
                                           //  mylog("BIN IN  workvouchers");
                                             dlog("got response " + JSON.stringify(respv));
                                             dlog(typeof respv);
                                             dlog("--------------------- " + respv);
                                          respv = JSON.parse(respv);
                                          
                                             dlog("--------------------- " + respv);
                                          dlog(respv.meta);
                                          dlog(respv.meta.rc);
                                          dlog(respv.data[1].code);
                                          dlog(respv.data.length);
                                          dlog(JSON.stringify(respv).length.toString());
                                          var writeFile;
                                          var laengeMessage=JSON.stringify(respv).length;
                                          if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                          var writeFileVar=JSON.stringify(respv).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 < respv.data.length; i++) { 
                                            var zeit= respv.data[i].create_time*1000
                                            let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                          
                                            clientListe = clientListe.concat("<tr><td>"+respv.data[i].duration+"&ensp;</td><td>"+respv.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+respv.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, respv.data[i].code );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", respv.data[i].duration );
                                                setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", respv.data[i].status_expires );
                                                
                                            }}
                                          }
                                          
                                          //Datenpunkteäalt löschen
                                          var w = respv.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:"+respv.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", respv.data.length);
                                          //mylog("BIN RAUS AUS  workvouchers");
                                          
                                          }
                                          //-----------------------------------------GET--Health---------------------------------------------------------------
                                          async function getHealth() {
                                              if (vouchers)  {
                                               mylog("BIN IN gethealth");
                                             return new Promise(async (resolve, reject) => {
                                                 dlog("nur mal so");
                                                 if(!loggedIn) await login().catch((e) => reject(e));
                                                  resph = await request.get({
                                                     url: unifi_controller + "/api/s/default/stat/health",
                                                     headers: { Cookie: cookies.join("; ") }
                                                 }).catch((e) => { log("getStatus reject " + e); /*reject(e)*/ return testerrh=true; });  
                                            if (!testerrh) {
                                          dlog("got response " + JSON.stringify(resph));
                                          dlog(typeof resph);
                                          mylog("--------------------- " + resph);
                                          resolve("done");
                                            } else {log("reject weil resph ist 00"); reject();}
                                          mylog("bin raus a GET health");
                                          });
                                          }}
                                          //-----------------------------------------WORK--HEALTH---------------------------------------------------------------
                                          function workHealth() {
                                             
                                             mylog("BIN IN  workhealth");
                                             dlog("got response " + JSON.stringify(resph));
                                             dlog(typeof resph);
                                             dlog("--------------------- " + resph);
                                             resph=resph.replace(/-r/g, "_r")
                                             resph = JSON.parse(resph);
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.Status",resph.data[0].status );
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.Users",resph.data[0].num_user);
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.Guests",resph.data[0].num_guest );
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.TXBytes",resph.data[0].tx_bytes_r );
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.RXBytes",resph.data[0].rx_bytes_r );
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.Adopted",resph.data[0].num_adopted );
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.Disabled",resph.data[0].num_disabled );
                                             setState(dpPrefix + "WLANUnifi.Health.WLAN.Disconnected",resph.data[0].num_disconnected );
                                          
                                             mylog("bin raus a work health");
                                          }
                                          //-----------------------------------------SET WIFIS - WIFI EIN-AUSSCHALTEN----------------------------------------------
                                          //Wifi an-/ausschalten
                                          //enabled: true = anschalten; false = ausschalten
                                          //wifi: wifi object aus der konstanten wifis
                                          async function setWifi(enabled, wifi) {
                                            if (!clientPause) {
                                            return new Promise(async (resolve, reject) => {
                                                dlog("setWifi: start set Wifi_haupt");
                                                if (!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                                dlog("setWifi: now setting Wifi_haupt");
                                                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)*/ return testerrws=true; });
                                                dlog("setWifi: got response")
                                          
                                                if (resp != null) {
                                                    dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                                    dlog(resp);
                                                            // getclient()  Pause für umschalten
                                          
                                                    if (firstTime>=wifiLength) {       
                                                    clientPause = true;
                                                    clientPauseVal=parseInt((new Date().getTime())); 
                                                    }
                                                 
                                                    setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                                                    resolve();
                                                } else {
                                                    dlog("setWifi: rejetced")
                                                    dlog("resp: " + JSON.stringify(resp));
                                                    reject("msg: " + JSON.parse(resp.body).meta.msg);}
                                                
                                            });
                                          } else { log("WLAN wird gerade umgeschaltet"); }
                                          }
                                          
                                          //-----------------------------------------CREATE VOUCHERS----------------------------------------------
                                          //Wifi an-/ausschalten
                                          //enabled: true = anschalten; false = ausschalten
                                          //wifi: wifi object aus der konstanten wifis
                                          async function createVoucher (mybody) {
                                          
                                            mylog(JSON.stringify( mybody ));
                                            return new Promise(async (resolve, reject) => {
                                                log("createVoucher in aktion");
                                                if (!loggedIn) { mylog("need to login"); await login().catch((e) => reject(e)); }
                                                mylog("do it !");
                                                let respcv = request.post({
                                                    url: unifi_controller + "/api/s/default/cmd/hotspot/" ,
                                                    body: JSON.stringify( mybody ),
                                                    // body: mybody,
                                                    headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                                }).catch((e) => { log("setWifi: rejected: " + e);  /*reject(e)*/ return testerrcv=true; });
                                                log("setWifi: got response")
                                                log("------------: "+respcv);
                                          
                                            });
                                          }
                                          
                                          //-----------------------------------------------SCHALTER------------------------------------------------
                                          on({id: wifiDPs, ack: false, change: "ne"}, function (obj) { 
                                           var value = obj.state.val;
                                           var dp2 = obj.name
                                           setWifi(value, wifis[dp2]);
                                           dlog(wifis[dp2])
                                           if (firstTime<wifiLength+1) firstTime++;
                                           
                                           
                                                    
                                          });
                                          //-----------------------------------------------SCHALTER Create Voucher------------------------------------------------
                                          on({id:  dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",  val: true}, function (obj) { 
                                            var mybodyVouchers;
                                            var expire_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer").val;
                                            var n_var      = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl").val ;
                                            var quota_var  = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse").val ;
                                            var note_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz").val;
                                            var up_var     = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload").val ;
                                            var down_var   = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download").val;
                                            var MBytes_var = getState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung").val ;
                                          
                                              if (expire_var !="must be set" && n_var!="must be set" && quota_var!="must be set" &&  !clientPause)  {
                                          
                                            
                                              //   Orginal JSON Daten
                                              /*   mybodyVouchers = {cmd:'create-voucher',expire:expire_var,   
                                                                                 n:n_var, 
                                                                                 quota:quota_var,
                                                                                 note:note_var,
                                                                                 up:up_var, 
                                                                                 down:down_var,  
                                                                                 MBytes:MBytes_var };*/
                                          
                                               var x = "{cmd:'create-voucher',expire:"+expire_var+", n:"+n_var+", quota:"+quota_var+","
                                          
                                                 if (note_var != "")   x= x.concat('note:\"'+note_var+'\",')
                                                 if (up_var != "")     x= x.concat("up:"+up_var+",")
                                                 if (down_var != "")   x= x.concat("down:"+down_var+",")                                                        
                                                 if (MBytes_var != "") x= x.concat("MBytes:"+MBytes_var+",")  
                                          
                                               x=x.substr(0, x.length-1);
                                               x=x.concat("}");
                                               log (x);
                                               eval('var mybodyVouchers='+x);
                                               log(mybodyVouchers);
                                                                                            
                                               createVoucher(mybodyVouchers);
                                          
                                             } else {log("FEHLER IN createVoucher - sind die 'must be set' Werte gesetzt?","error")}
                                          
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Create",false, 4000);
                                            //setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Dauer", "must be set" , 2000);
                                            //setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Anzahl", "must be set", 2000);
                                            //setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.MultiUse", "must be set", 2000);
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Notiz", "", 2000);
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Upload", "", 2000);
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Download", "", 2000);
                                            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.A_New_Voucher.Mb_Begrenzung", "", 2000);
                                          });
                                          
                                          
                                          //-----------------------------------------------MAIN LOOP------------------------------------------------
                                          setInterval(async () => {
                                          
                                              scriptCounter++
                                              mylog("-----------------------SCRIPTCOUNTER------------------ ist : " + scriptCounter );
                                              mylog(loggedIn.toString())
                                                  
                                              await login().catch(alarm1)  
                                          
                                            // log("------------------------------------------------Werte Alarme: " + testerrl + " - " + testerrc+ " - " +testerrv + " - "+testerrs + " - "+testerrh);
                                          
                                          if (loggedIn) {
                                              if (alarmCounter > 5) {log("Unifi Sript funktioniert wieder - Verbindung wieder hergestellt","error");}
                                              if (alarmCounter > 0) {alarmCounter=0; }
                                              
                                              await getClients().catch(alarm3)  ;
                                              if (vouchers) await getVouchers().catch(alarm4);
                                              if (health)   await getHealth().catch(alarm7);
                                              if ( !testerrl && !testerrc && !testerrv && !testerrs && !testerrh ) {
                                                     workVouchers();
                                                     workClients();
                                                     if (health && scriptCounter==5) {scriptCounter=0;workHealth();}
                                                     }
                                            
                                                     
                                             for(let wifi_name in wifis) {
                                                 
                                                 await getStatus(wifis[wifi_name]).catch(alarm6)}   
                                          
                                          }   else { alarmCounter++; 
                                                    if (alarmCounter > 5) {log("Unifi Sript hat 'Problem mit Einloggen - Prüfe Unifi Controller, Port, Einlog-Daten","error");
                                                                           if  (!testerrv) log("evtl. Vouchers deaktivieren","warn");}}
                                          
                                                                           
                                            if (clientPause) {
                                                  var interim=parseInt(new Date().getTime());
                                                  log("Unifi Script ist in Pause wegen WLAN Umschalteung- bis: " + formatDate(clientPauseVal + clientPauseConst, "SS:mm:ss"),"warn");
                                                  if (interim - clientPauseVal > clientPauseConst) {clientPause=false;log("Unifi Script hat Pause beendet" );}  }
                                          
                                                    
                                           testerrc=false;
                                               testerrv=false;
                                                testerrs=false;
                                                 testerrl=false;
                                                  testerrc=false;
                                                   testerrh=false;
                                          
                                          
                                          
                                             }, abfragezyklus); // wird oben definiert
                                          
                                          function alarm12() {log("Im Unifi Script stimmte etwas nicht - Alarm12 - Create Voucher","warn");     loggedIn=false; testerrcv=false;cookies=[];}   
                                          function alarm11() {log("Im Unifi Script stimmte etwas nicht - Alarm11 - WLAN schalten","warn");      loggedIn=false; testerrws=false;cookies=[];} 
                                          
                                          function alarm7() {log("Im Unifi Script stimmte etwas nicht - Alarm7 - Health","warn");               loggedIn=false; testerrh=false;cookies=[];}   
                                          function alarm6() {log("Im Unifi Script stimmte etwas nicht - Alarm6 - Statusabfrage","warn");        loggedIn=false; testerrs=false;cookies=[];}    
                                          function alarm5() {log("Im Unifi Script stimmte etwas nicht - Alarm5 - logout","warn");               loggedIn=false; testerrl=false;cookies=[];}    
                                          function alarm4() {log("Im Unifi Script stimmte etwas nicht - Alarm4 - getVouchers-Login","warn");    loggedIn=false; testerrv=false;cookies=[];}
                                          function alarm3() {log("Im Unifi Script stimmte etwas nicht - Alarm3 - getClient-Login","warn");      loggedIn=false; testerrc=false;cookies=[];}
                                          function alarm1() {log("Im Unifi Script stimmte etwas nicht - Alarm1 - Login fehlgeschlagen","warn"); loggedIn=false; ;alarmSwitch=true }
                                          
                                          
                                          
                                          // Beispiel für
                                          //setWifi(true, wifis.WLAN_DragonGuest);
                                          
                                          

                                          Chaot 1 Reply Last reply Reply Quote 0
                                          • liv-in-sky
                                            liv-in-sky @dslraser last edited by

                                            @dslraser

                                            die lösung habe ich bekommen (name-hostname) - die umsetzung muss auf morgen warten

                                            dslraser 1 Reply Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            847
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            13
                                            380
                                            42742
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo