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 dslraser

      @liv-in-sky

      hier auch noch Infos die sich vielleicht nutzen lassen

      https://wiki.fhem.de/wiki/PRESENCE

      https://forum.fhem.de/index.php/topic,40287.msg562823.html#msg562823

      1 Reply Last reply Reply Quote 0
      • dslraser
        dslraser Forum Testing Most Active last edited by dslraser

        @liv-in-sky
        zum an/ausschalten des Gäste WLAN über einen Switch (an/aus) habe ich mal den unteren Teil auskommentiert und dafür mal den Wifi_an Switch genommen. Über den Wifi_an kannst Du dann an und ausschalten.

        on({id: 'javascript.0.WLANUnifi.Wifi_an', val: true}, function (obj) {
         var value = obj.state.val;
         var oldValue = obj.oldState.val;
         if (getState("javascript.0.WLANUnifi.Wifi_Status").val == false) {
           setWifi(true);
         } else {
           setWifi(false);
         }
        });
        /*on(dpPrefix + "WLANUnifi.Wifi_an", (state) => {
          setWifi(true);
          setTimeout(function () {
              getStatus();
              setState(dpPrefix + "WLANUnifi.Wifi_an", false);
        }, 10000);
        });
        on(dpPrefix + "WLANUnifi.Wifi_aus", (state) => {
          setWifi(false);
          setTimeout(function () {
            getStatus();   
             setState(dpPrefix + "WLANUnifi.Wifi_aus", false);
        }, 12000);
        });*/
        
        

        Edit:

        on({id: 'javascript.0.WLANUnifi.Wifi_an', change: "ne"}, function (obj) {
         var value = obj.state.val;
         var oldValue = obj.oldState.val;
         if (getState("javascript.0.WLANUnifi.Wifi_an").val == true) {
           setWifi(true);
         } else {
           setWifi(false);
         }
        });
        

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

          @liv-in-sky

          Einen DP entfernt und nur noch einen DP zum an/aus schalten

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

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

            @dslraser ist schon drin

            muss noch ein paar tests macchen dann ist fertig

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

              @dslraser

              das neuste script

              // 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" }
              }
              let wifiDPs = [];
              
              const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
              var fs = require('fs')
              
              const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
              const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
              let writeFile = true;
              let  writeFileVar = 0;
              let writeClientTable = true;
              let writeAnwesenheit = true;
              let listeDatenpunkte = [];
              let listeDatenpunkteNew = [];
              let listeDatenpunkteAlt = [];
              
              // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, inder das script läuft zusammenpassen
              const dpPrefix = "javascript.0.";
              
              // Abfragezyklus definieren
              const abfragezyklus =20000;
              
              //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;
              
              // 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);\">";
              
              
              //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
              
              let cookies = [];
              let loggedIn = false;
              let debug = false;
              
              if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
              if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
              
              
              
              //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: 'state',
                    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,
              });
              
              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);
              }
              //-----------------------------------------LOGIN---------------------------------------------------------------
              async function login() {
                return new Promise(async (resolve, reject) => {
                    let resp = await request.post({
                        resolveWithFullResponse: true,
                        url: unifi_controller + "/api/login",
                        body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                        headers: { 'Content-Type': 'application/json' }
                    }).catch((e) => { dlog("login: reject"), reject(e) });
                    
                    if(resp != null) {
                        dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                        if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                            let set_cookies = resp.headers["set-cookie"];
                            for(i = 0; i < set_cookies.length; i++) {
                                let cookie = set_cookies[i];
                                cookie = cookie.split(";")[0];
                                cookies.push(cookie);
                            }
                        } else {
                            dlog("login: no cookies to set!")
                        }
                        loggedIn = true;
                        resolve();
                    } else {
                        dlog("login: rejected")
                        reject("resp = null");
                    }
                });
              }
              async function dlogout() {
                return new Promise(async (resolve, reject) => {
                    let resp = await request.get({
                        url: unifi_controller + "/dlogout",
                        headers: { Cookie: cookies.join("; ") }
                    }).catch((e) => reject(e));
                    if(resp != null) {
                        dlog("Du bist nun ausgedloggt.");
                        dlog(resp);
                        resolve();
                    } else {
                        reject("resp = null");
                    }
                });
              }
              //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
              //Updatet status vom Wifi
              //wifi: wifi object aus der konstanten wifis
              async function getStatus(wifi) {
                   dlog("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) });
              
                    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 {
                        dlog("nicht ok...")
                        reject(JSON.stringify(resp));
                    }dlog("BIN aus STATUS raus");
                });
                 
              }
              
              //-----------------------------------------GETCLIENTS---------------------------------------------------------------
               async function getClients() {
                  dlog("BIN IN CLIENTS");
                 
                 return new Promise(async (resolve, reject) => {
                     dlog("nur mal so");
                     if(!loggedIn) await login().catch((e) => reject(e));
                     let resp = await request.get({
                         url: unifi_controller + "/api/s/default/stat/sta/",
                         headers: { Cookie: cookies.join("; ") }
                     }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                
              dlog("got response " + JSON.stringify(resp));
              dlog(typeof resp);
              dlog("--------------------- " + resp);
              //resp = JSON.parse(resp);
              
              //Sortierung Daten und Verwandlung Json
              var versuch = [];
              versuch = JSON.parse(resp).data;
              dlog(versuch[2].hostname+versuch[2].mac);
              
              versuch.sort(function(alpha, beta) {
                 if ( alpha.hostname < beta.hostname )
                     return -1;
                 if ( alpha.hostname > beta.hostname )
                     return 1;
                 return 0;
              });
              dlog(versuch.length.toString());
              
              var anzahlClients = versuch.length;
              setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
              
              var clientListe = "";
              await getExistingClients();
              
              //erstelle aktuelles array
              
              listeDatenpunkteNew=[];
              for (var i = 0; i < versuch.length; i++) { 
                 listeDatenpunkteNew[i] = versuch[i].hostname;}
                dlog (listeDatenpunkteNew[3]);
              
              // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
              dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
              if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
              dlog("ClientTable "+writeClientTable.toString());
              dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
              
              
              // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
              if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
              dlog("writeAnwesenheit "+writeAnwesenheit.toString());
              dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
              
              // erstelle htmlclientliste wenn listenDaten verändert  
                  if ( writeClientTable ) {
                   for (var i = 0; i < versuch.length; i++)  {
                     dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                     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);
                     var ipWandler= versuch[i].ip;
                     if (anwesenheit && writeAnwesenheit) {
                        createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, {
                        name: ipWandler, 
                        role: 'boolean',
                        read:  true, 
                        write: true,
                        });
                     }
                   
                   if (anwesenheit && listeDatenpunkteNew.indexOf(versuch[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
                     dlog("gefunden"+versuch[i].hostname);
                     setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, true, 500);}
               } }
                   
               
              if (anwesenheit) {
              for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
              if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
                  dlog("nicht gefunden"+listeDatenpunkte[b]);
                  setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 500);}}}
              
              if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl angemeldeter Geräte:"+versuch.length+"</p>"));
              
              dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
              if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
              dlog("bin raus aus  clients");
              });
              
              }
              
              
              async 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.", "");}
              });
              //for (i = 0; i<listeDatenpunkte.length;i++) {log(listeDatenpunkte[i]);}
              //log(listeDatenpunkte.length.toString());
              dlog("bin raus a existing clients");
              }
              
              //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
              async function getVouchers() {
                   dlog("BIN IN VOUCHERS");
                 return new Promise(async (resolve, reject) => {
                     dlog("nur mal so");
                     if(!loggedIn) await login().catch((e) => reject(e));
                     let resp = await request.get({
                         url: unifi_controller + "/api/s/default/stat/voucher",
                         headers: { Cookie: cookies.join("; ") }
                     }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                
              dlog("got response " + JSON.stringify(resp));
              dlog(typeof resp);
              dlog("--------------------- " + resp);
              resp = JSON.parse(resp);
              
              dlog(resp.meta);
              dlog(resp.meta.rc);
              dlog(resp.data[1].code);
              dlog(resp.data.length);
              dlog(JSON.stringify(resp).length.toString());
              var laengeMessage=JSON.stringify(resp).length;
              if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
              writeFileVar=JSON.stringify(resp).length;
              
              if (writeFile) {
              var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
              
              for (var i = 1; i < 21; i++) { 
                 var x=i.toString();
                 if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
                 
              for (var i = 0; i < resp.data.length; i++) { 
                var zeit= resp.data[i].create_time*1000
                let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
              
                clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                var y=i+1; 
                var yy=y.toString();
                if (y<10 )  yy="0"+yy;
               
                if (i<20  )  {
                    dlog(zeit1);
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, resp.data[i].code );
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", resp.data[i].duration );
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", resp.data[i].status_expires );
                    
                }}
              
              
              //Datenpunkteäalt löschen
              var w = resp.data.length;
              for (i = w; i < 20; i++) { 
                    var y=i+1; 
                var yy=y.toString();
                if (y<10 )  yy="0"+yy;
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, " na " );
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", " na " );
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", " na " );
                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", " na " );
              }
              }
              
              if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl Vouchers:"+resp.data.length+"</p>"));}
              if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
              if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
              dlog("bin raus a existing vouchers");
              });
              
              }
              
              
              //-----------------------------------------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);
                        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])
              });
              
              //-----------------------------------------------MAIN LOOP------------------------------------------------
              setInterval(async () => {
              
                 for(let wifi_name in wifis) {
                 await getStatus(wifis[wifi_name]);}
               
                 if (vouchers)  getVouchers();
                 await getClients();
               
              
                 }, abfragezyklus); // wird oben definiert
              
              
              // Beispiel für
              //setWifi(true, wifis.WLAN_DragoRootGuest);
              
              

              bitte testen - viele änderungen

              werd mir das anwesenheitsspiel noch näher ansehen - aber wenn alles funktioniert sollte das so klappen

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

                @liv-in-sky
                iQontrol im Moment

                Bildschirmfoto 2019-09-03 um 15.38.23.png

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

                  @dslraser falls du es testest bitte vorher datenpunkte löschen

                  gehe jetzt kurz rasenmähen - muss mal vom rechner weg 🙂

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

                    @liv-in-sky

                    neues Script getestet. Es wird alles angelegt.
                    Ich kann keinen Status von den WLAN's sehen, angezeigt wird maximal null (geschaltet werden die WLAN anscheinend trotzdem, habe eben mein Haupt WLAN ausversehen ausgeknipst😖 )

                    Bildschirmfoto 2019-09-03 um 15.54.00.png

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

                      @liv-in-sky

                      jetzt ist es sichtbar (habe einmal das Script neu gestartet, vielleicht kam es aber auch mit dem Aktualisierungsintervall, kann ich nicht genau sagen ?)

                      Bildschirmfoto 2019-09-03 um 16.05.46.png

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

                        @liv-in-sky
                        die Sortierung der Clients in den Objekten klappt fast. Ich habe eine alphabetische Reihenfolge, bis auf alle Amazon ECHO Geräte habe sich dazwischengemogelt, aber alle hintereinander.

                        Bildschirmfoto 2019-09-03 um 16.11.33.png

                        Edit:
                        Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.

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

                          @liv-in-sky
                          läuft alles, super Arbeit !👍
                          In der Client Liste habe ich jetzt auch die IP Adresse😊

                          iQontrol am Mac

                          Bildschirmfoto 2019-09-03 um 16.19.08.png

                          1 Reply Last reply Reply Quote 0
                          • thewhobox
                            thewhobox @dslraser last edited by

                            @dslraser sagte in Unifi WLAN Script:

                            Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.

                            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;
                                });
                            

                            Das sollte das Sortierproblem lösen.

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

                              @liv-in-sky

                              Telegram
                              Screenshot_20190903-164108_Telegram.jpg

                              Meine Frau hatte noch nicht mal an der Tür geklingelt, da kam schon die Nachricht. An meinem Handy habe ich dann auch direkt mal WLAN eingeschaltet.

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

                                @thewhobox sagte in Unifi WLAN Script:

                                @dslraser sagte in Unifi WLAN Script:

                                Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.

                                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;
                                    });
                                

                                Das sollte das Sortierproblem lösen.

                                kenn ich - aber leider geht's nicht - habe ich gestern getestet

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

                                  @liv-in-sky
                                  habe ich eben auch probiert, ging bei mir auch nicht

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

                                    @liv-in-sky Was heißt ging nicht?
                                    Waren immer noch so sortiert?

                                    @dslraser Kannst du mir mal ein Beispiel von 1-2 Amazon Geräten und auch den darunter liegenden geben?
                                    Gern auch per PN.

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

                                      @thewhobox
                                      nein - nach der sortierung wird nicht mehr weitergearbeitet - script steht an dieser stelle - ich lasse anschliessend ein log raus mit der länge des sortierten arrays - das log kommt in der "guten" variante - es kokmmt aber nichts mehr in der lowercase - methode

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

                                        @liv-in-sky
                                        ja, genau so war es bei mir. Es wurden nicht mal mehr die DP angelegt.

                                        @thewhobox
                                        was genau brauchst Du, die Bezeichnung bzw. den Namen der ECHO'S ?

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

                                          @liv-in-sky Kann natürlich sein, dass wenn der hostname undefined ist dass er dann die Biege macht. Da er von undefined ja nicht Lowercase machen kann.

                                          So funktioniert es bei mir:

                                          var sorted = list.sort((a, b) => {
                                              if(a.hostname == undefined || b.hostname == undefined) return;
                                          
                                              let ah = a.hostname.toLowerCase();
                                              let bh = b.hostname.toLowerCase();
                                              if(ah < bh)
                                                  return -1;
                                              else if(ah > bh)
                                                  return 1;
                                              else
                                                  return 0;
                                          });
                                          

                                          Damit landen alle mit Hostname = undefined am unteren Ende der Liste.

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

                                            @thewhobox sagte in Unifi WLAN Script:

                                            undefined

                                            davon habe ich ja einige (hatte ich Dir ja in der PN geschrieben).

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            928
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            13
                                            380
                                            43187
                                            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