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

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

Community Forum

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

NEWS

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

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

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

Unifi WLAN Script

Geplant Angeheftet Gesperrt Verschoben JavaScript
380 Beiträge 13 Kommentatoren 57.4k Aufrufe 13 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • dslraserD dslraser

    @thewhobox sagte in Unifi WLAN Script:

    @dslraser Gibt es eine änderung, wenn du anerkannt auf true stellst?

    probiere ich mal aus.

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

    @dslraser ich vermute ; wenn ich mir die zeiten ansehe, sind das tatsächliche an und abmeldungen und keine scriptfehler

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

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

      @dslraser ich vermute ; wenn ich mir die zeiten ansehe, sind das tatsächliche an und abmeldungen und keine scriptfehler

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

      @liv-in-sky
      wie gasagt, mein Handy macht das so nicht, nicht eine Meldung heute Nacht und WLAN ist an, an meinem Handy.

      liv-in-skyL 2 Antworten Letzte Antwort
      0
      • dslraserD dslraser

        @liv-in-sky
        wie gasagt, mein Handy macht das so nicht, nicht eine Meldung heute Nacht und WLAN ist an, an meinem Handy.

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

        @dslraser ja , weil das android das nur so macht, wie bei mir, wenn ein tool installiert ist oder sowas wie tasker

        leider weiß ich nichts über iphone aber vielleicht gibt es da eine einstellung im wifi bereich

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

        1 Antwort Letzte Antwort
        0
        • dslraserD dslraser

          @liv-in-sky
          wie gasagt, mein Handy macht das so nicht, nicht eine Meldung heute Nacht und WLAN ist an, an meinem Handy.

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

          @dslraser hätte wieder eine neue version (zum testen)

          • sortierung im lowercase modus ist integriert
          • diesmal sollte der abmeldevorgang schneller sichtbar werden - innerhalb ca. 30 sek.
            dazu muß die zu überwachenden geräte aber extra eintragen werden unter konstante fastLane

          // 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" }
          }
          
          
          //Überwachte Geräte beim Abschalten - Beispiele überschreiben!
          const fastLane = {
             "Galaxy-S9": { name: "Galaxy-S9"} ,
             "GalaxyTabS2": { name: "GalaxyTabS2"},
             "ESP_C75826" : {name: "ESP_C75826"}
          }
          
          let wifiDPs = [];
          let fastLaneDPs = [];
          let fastLaneDPsAlt=[];
          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.2.";
          
          // Abfragezyklus definieren
          const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
          
          //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")); 
          
          //fastlane reset 
           for(var fastLane_member in fastLane) {
                    
           fastLaneDPsAlt.push(0); }
          
          //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 unfiltered = [];
          unfiltered = JSON.parse(resp).data;
          dlog(unfiltered[2].hostname + unfiltered[2].mac);
          let 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;
          });
          
          dlog(versuch[2].hostname);
          dlog(versuch.length.toString());
          
          
          var anzahlClients = versuch.length;
          setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
          
          var clientListe = "";
          getExistingClients();
          
          //erstelle aktuelles array
          fastLaneDPs = [];
          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);
          getFastLaneClients(versuch);
          
          
          // 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");
          });
          
          }
          
          //-----------------------------------------EXISTING 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.", "");}
          });
          
          dlog("bin raus a existing clients");
          }
          //-----------------------------------------FAASTLANE---------------------------------------------------------------
          async function getFastLaneClients(versuchx) {
             dlog("BIN IN FASTLANE");
             if (anwesenheit){
             
                
             var laenge = versuchx.length;
                for (var z = 0; z < laenge; z++)  {
                     for(var fastLane_member in fastLane) {
                        if (fastLane[fastLane_member].name==versuchx[z].hostname){
                           fastLaneDPs.push(versuchx[z]._last_seen_by_uap); 
                          
                          if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) > abfragezyklus+15000 ) {
                              if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)  setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, false);
                              dlog("abgesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name );
                              }
                            if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) < abfragezyklus+15000 ) {
                               if (!getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)   setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, true);
                              dlog("gesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name);
                              }   
                        
                            }   
                      }
                  } 
          
              } dlog(fastLaneDPs.length.toString()); dlog("bin raus aus fastlane");
             
          }
          
          
          //-----------------------------------------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_DragonGuest);
          
          

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

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

            @dslraser hätte wieder eine neue version (zum testen)

            • sortierung im lowercase modus ist integriert
            • diesmal sollte der abmeldevorgang schneller sichtbar werden - innerhalb ca. 30 sek.
              dazu muß die zu überwachenden geräte aber extra eintragen werden unter konstante fastLane

            // 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" }
            }
            
            
            //Überwachte Geräte beim Abschalten - Beispiele überschreiben!
            const fastLane = {
               "Galaxy-S9": { name: "Galaxy-S9"} ,
               "GalaxyTabS2": { name: "GalaxyTabS2"},
               "ESP_C75826" : {name: "ESP_C75826"}
            }
            
            let wifiDPs = [];
            let fastLaneDPs = [];
            let fastLaneDPsAlt=[];
            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.2.";
            
            // Abfragezyklus definieren
            const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
            
            //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")); 
            
            //fastlane reset 
             for(var fastLane_member in fastLane) {
                      
             fastLaneDPsAlt.push(0); }
            
            //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 unfiltered = [];
            unfiltered = JSON.parse(resp).data;
            dlog(unfiltered[2].hostname + unfiltered[2].mac);
            let 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;
            });
            
            dlog(versuch[2].hostname);
            dlog(versuch.length.toString());
            
            
            var anzahlClients = versuch.length;
            setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
            
            var clientListe = "";
            getExistingClients();
            
            //erstelle aktuelles array
            fastLaneDPs = [];
            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);
            getFastLaneClients(versuch);
            
            
            // 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");
            });
            
            }
            
            //-----------------------------------------EXISTING 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.", "");}
            });
            
            dlog("bin raus a existing clients");
            }
            //-----------------------------------------FAASTLANE---------------------------------------------------------------
            async function getFastLaneClients(versuchx) {
               dlog("BIN IN FASTLANE");
               if (anwesenheit){
               
                  
               var laenge = versuchx.length;
                  for (var z = 0; z < laenge; z++)  {
                       for(var fastLane_member in fastLane) {
                          if (fastLane[fastLane_member].name==versuchx[z].hostname){
                             fastLaneDPs.push(versuchx[z]._last_seen_by_uap); 
                            
                            if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) > abfragezyklus+15000 ) {
                                if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)  setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, false);
                                dlog("abgesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name );
                                }
                              if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) < abfragezyklus+15000 ) {
                                 if (!getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)   setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, true);
                                dlog("gesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name);
                                }   
                          
                              }   
                        }
                    } 
            
                } dlog(fastLaneDPs.length.toString()); dlog("bin raus aus fastlane");
               
            }
            
            
            //-----------------------------------------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_DragonGuest);
            
            

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

            @liv-in-sky
            probiere ich nachher sofort, ich bin noch unterwegs.

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

              @dslraser hätte wieder eine neue version (zum testen)

              • sortierung im lowercase modus ist integriert
              • diesmal sollte der abmeldevorgang schneller sichtbar werden - innerhalb ca. 30 sek.
                dazu muß die zu überwachenden geräte aber extra eintragen werden unter konstante fastLane

              // 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" }
              }
              
              
              //Überwachte Geräte beim Abschalten - Beispiele überschreiben!
              const fastLane = {
                 "Galaxy-S9": { name: "Galaxy-S9"} ,
                 "GalaxyTabS2": { name: "GalaxyTabS2"},
                 "ESP_C75826" : {name: "ESP_C75826"}
              }
              
              let wifiDPs = [];
              let fastLaneDPs = [];
              let fastLaneDPsAlt=[];
              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.2.";
              
              // Abfragezyklus definieren
              const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
              
              //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")); 
              
              //fastlane reset 
               for(var fastLane_member in fastLane) {
                        
               fastLaneDPsAlt.push(0); }
              
              //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 unfiltered = [];
              unfiltered = JSON.parse(resp).data;
              dlog(unfiltered[2].hostname + unfiltered[2].mac);
              let 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;
              });
              
              dlog(versuch[2].hostname);
              dlog(versuch.length.toString());
              
              
              var anzahlClients = versuch.length;
              setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
              
              var clientListe = "";
              getExistingClients();
              
              //erstelle aktuelles array
              fastLaneDPs = [];
              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);
              getFastLaneClients(versuch);
              
              
              // 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");
              });
              
              }
              
              //-----------------------------------------EXISTING 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.", "");}
              });
              
              dlog("bin raus a existing clients");
              }
              //-----------------------------------------FAASTLANE---------------------------------------------------------------
              async function getFastLaneClients(versuchx) {
                 dlog("BIN IN FASTLANE");
                 if (anwesenheit){
                 
                    
                 var laenge = versuchx.length;
                    for (var z = 0; z < laenge; z++)  {
                         for(var fastLane_member in fastLane) {
                            if (fastLane[fastLane_member].name==versuchx[z].hostname){
                               fastLaneDPs.push(versuchx[z]._last_seen_by_uap); 
                              
                              if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) > abfragezyklus+15000 ) {
                                  if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)  setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, false);
                                  dlog("abgesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name );
                                  }
                                if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) < abfragezyklus+15000 ) {
                                   if (!getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)   setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, true);
                                  dlog("gesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name);
                                  }   
                            
                                }   
                          }
                      } 
              
                  } dlog(fastLaneDPs.length.toString()); dlog("bin raus aus fastlane");
                 
              }
              
              
              //-----------------------------------------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_DragonGuest);
              
              

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

              @liv-in-sky

              Vorschlag:
              Das das Script ja mehr oder weniger Final ist und es fast ausschließlich von Dir und @thewhobox ist, mach nochmal einen eigenen Thread auf als [Vorlage] und stelle das aktuelle Script immer in den ersten Beitrag. Das ist für die Nachwelt sicher einfacher zu finden.

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

                @dslraser hätte wieder eine neue version (zum testen)

                • sortierung im lowercase modus ist integriert
                • diesmal sollte der abmeldevorgang schneller sichtbar werden - innerhalb ca. 30 sek.
                  dazu muß die zu überwachenden geräte aber extra eintragen werden unter konstante fastLane

                // 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" }
                }
                
                
                //Überwachte Geräte beim Abschalten - Beispiele überschreiben!
                const fastLane = {
                   "Galaxy-S9": { name: "Galaxy-S9"} ,
                   "GalaxyTabS2": { name: "GalaxyTabS2"},
                   "ESP_C75826" : {name: "ESP_C75826"}
                }
                
                let wifiDPs = [];
                let fastLaneDPs = [];
                let fastLaneDPsAlt=[];
                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.2.";
                
                // Abfragezyklus definieren
                const abfragezyklus =20000; // es ist nicht zu empfehlen unter 20000 (20 sekunden) zu gehen
                
                //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")); 
                
                //fastlane reset 
                 for(var fastLane_member in fastLane) {
                          
                 fastLaneDPsAlt.push(0); }
                
                //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 unfiltered = [];
                unfiltered = JSON.parse(resp).data;
                dlog(unfiltered[2].hostname + unfiltered[2].mac);
                let 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;
                });
                
                dlog(versuch[2].hostname);
                dlog(versuch.length.toString());
                
                
                var anzahlClients = versuch.length;
                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                
                var clientListe = "";
                getExistingClients();
                
                //erstelle aktuelles array
                fastLaneDPs = [];
                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);
                getFastLaneClients(versuch);
                
                
                // 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");
                });
                
                }
                
                //-----------------------------------------EXISTING 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.", "");}
                });
                
                dlog("bin raus a existing clients");
                }
                //-----------------------------------------FAASTLANE---------------------------------------------------------------
                async function getFastLaneClients(versuchx) {
                   dlog("BIN IN FASTLANE");
                   if (anwesenheit){
                   
                      
                   var laenge = versuchx.length;
                      for (var z = 0; z < laenge; z++)  {
                           for(var fastLane_member in fastLane) {
                              if (fastLane[fastLane_member].name==versuchx[z].hostname){
                                 fastLaneDPs.push(versuchx[z]._last_seen_by_uap); 
                                
                                if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) > abfragezyklus+15000 ) {
                                    if (getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)  setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, false);
                                    dlog("abgesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name );
                                    }
                                  if (parseFloat((new Date().getTime())) - (versuchx[z]._last_seen_by_uap*1000) < abfragezyklus+15000 ) {
                                     if (!getState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname).val)   setState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuchx[z].hostname, true);
                                    dlog("gesetzt" +versuchx[z].hostname+fastLane[fastLane_member].name);
                                    }   
                              
                                  }   
                            }
                        } 
                
                    } dlog(fastLaneDPs.length.toString()); dlog("bin raus aus fastlane");
                   
                }
                
                
                //-----------------------------------------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_DragonGuest);
                
                

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

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

                sortierung im lowercase modus ist integriert

                Bei mir sind die amazon Geräte mitten drinn

                Bildschirmfoto 2019-09-04 um 15.31.25.png

                liv-in-skyL thewhoboxT 3 Antworten Letzte Antwort
                0
                • dslraserD dslraser

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

                  sortierung im lowercase modus ist integriert

                  Bei mir sind die amazon Geräte mitten drinn

                  Bildschirmfoto 2019-09-04 um 15.31.25.png

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

                  @dslraser diese sotierung ist iobroker abhängig (da datenpunkte) - meine sortierung geht nur in der table ansicht und in der iqontrol-ansicht

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

                  1 Antwort Letzte Antwort
                  0
                  • dslraserD dslraser

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

                    sortierung im lowercase modus ist integriert

                    Bei mir sind die amazon Geräte mitten drinn

                    Bildschirmfoto 2019-09-04 um 15.31.25.png

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

                    @dslraser thema iphone: - wann meldet sich apple im netz an und ab:

                    Image 1.png

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

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

                      @dslraser thema iphone: - wann meldet sich apple im netz an und ab:

                      Image 1.png

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

                      @liv-in-sky
                      irgendwann im standby meldet es sich kurz ab und wie Du im Telegram siehst auch wieder an.

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

                        @liv-in-sky
                        irgendwann im standby meldet es sich kurz ab und wie Du im Telegram siehst auch wieder an.

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

                        @dslraser ja ein apple problem - auf diesem weg scheint die anwesenheitskontrolle nicht zu funktionieren mit iphone - kannst du höchstens mit einem zusätzliche script abfangen

                        wie es scheint, meldet es sich immer nur für ein paar minuten ab - das könntest du prüfen

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

                        HiltexH 1 Antwort Letzte Antwort
                        0
                        • dslraserD dslraser

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

                          sortierung im lowercase modus ist integriert

                          Bei mir sind die amazon Geräte mitten drinn

                          Bildschirmfoto 2019-09-04 um 15.31.25.png

                          thewhoboxT Offline
                          thewhoboxT Offline
                          thewhobox
                          schrieb am zuletzt editiert von
                          #203

                          @dslraser Man könnte den Namen für die Datenpunkte auch lowerCase erzwingen. Dann wären sie korrekt geordnet.
                          @liv-in-sky

                          Meine Adapter: emby | discovery
                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                          liv-in-skyL 1 Antwort Letzte Antwort
                          0
                          • thewhoboxT thewhobox

                            @dslraser Man könnte den Namen für die Datenpunkte auch lowerCase erzwingen. Dann wären sie korrekt geordnet.
                            @liv-in-sky

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

                            @thewhobox dann stimmen die tatsächlichen netzwerknamen nicht mit den datenpunkten überein - find ich nicht gut

                            andere frage - mir ist ein- bzw. aufgefallen , dass ich keine richtige fehlerstruktur habe - falls mal der controller nicht da ist oder die falsche adresse eingegeben wird - hast du eine idee dazu - am besten den loggedIn datenpunkt abfragen bevor alle anderen funktionen aufgerufen werden

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

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

                              @thewhobox dann stimmen die tatsächlichen netzwerknamen nicht mit den datenpunkten überein - find ich nicht gut

                              andere frage - mir ist ein- bzw. aufgefallen , dass ich keine richtige fehlerstruktur habe - falls mal der controller nicht da ist oder die falsche adresse eingegeben wird - hast du eine idee dazu - am besten den loggedIn datenpunkt abfragen bevor alle anderen funktionen aufgerufen werden

                              thewhoboxT Offline
                              thewhoboxT Offline
                              thewhobox
                              schrieb am zuletzt editiert von
                              #205

                              @liv-in-sky Du kannst den richtigen namen ja bei common.name angeben.

                              Hmm man könnte vor jeder Gruppenabfrage mal eine Testabfrage machen, wenn das fehl schlägt -> Meldung im Log.

                              Ich muss sagen, ich verstehe einige deiner Variablen nicht.
                              Was hat fastLaneDPsAlt für eine Funktion? Im Code füllst du es einfach mit 0en

                              Meine Adapter: emby | discovery
                              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                              liv-in-skyL 3 Antworten Letzte Antwort
                              0
                              • thewhoboxT thewhobox

                                @liv-in-sky Du kannst den richtigen namen ja bei common.name angeben.

                                Hmm man könnte vor jeder Gruppenabfrage mal eine Testabfrage machen, wenn das fehl schlägt -> Meldung im Log.

                                Ich muss sagen, ich verstehe einige deiner Variablen nicht.
                                Was hat fastLaneDPsAlt für eine Funktion? Im Code füllst du es einfach mit 0en

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

                                @thewhobox hat keine funktion - wollte das alles anders lösen - ist überbleibsel - wird gelöscht

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

                                1 Antwort Letzte Antwort
                                0
                                • thewhoboxT thewhobox

                                  @liv-in-sky Du kannst den richtigen namen ja bei common.name angeben.

                                  Hmm man könnte vor jeder Gruppenabfrage mal eine Testabfrage machen, wenn das fehl schlägt -> Meldung im Log.

                                  Ich muss sagen, ich verstehe einige deiner Variablen nicht.
                                  Was hat fastLaneDPsAlt für eine Funktion? Im Code füllst du es einfach mit 0en

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

                                  @thewhobox wenn noch was auffällt - bitte mitteilen

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

                                  1 Antwort Letzte Antwort
                                  0
                                  • thewhoboxT thewhobox

                                    @liv-in-sky Du kannst den richtigen namen ja bei common.name angeben.

                                    Hmm man könnte vor jeder Gruppenabfrage mal eine Testabfrage machen, wenn das fehl schlägt -> Meldung im Log.

                                    Ich muss sagen, ich verstehe einige deiner Variablen nicht.
                                    Was hat fastLaneDPsAlt für eine Funktion? Im Code füllst du es einfach mit 0en

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

                                    @thewhobox sagte in Unifi WLAN Script:

                                    @liv-in-sky Du kannst den richtigen namen ja bei common.name angeben.

                                    Hmm man könnte vor jeder Gruppenabfrage mal eine Testabfrage machen, wenn das fehl schlägt -> Meldung im Log.

                                    Ich muss sagen, ich verstehe einige deiner Variablen nicht.
                                    Was hat fastLaneDPsAlt für eine Funktion? Im Code füllst du es einfach mit 0en

                                    also das login aufrufen - klappt es nicht - die gruppenabfrage auslassen - richtig ?

                                    fällt dir noch ein, was sonst noch geprüft werden sollte

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

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

                                      @dslraser ja ein apple problem - auf diesem weg scheint die anwesenheitskontrolle nicht zu funktionieren mit iphone - kannst du höchstens mit einem zusätzliche script abfangen

                                      wie es scheint, meldet es sich immer nur für ein paar minuten ab - das könntest du prüfen

                                      HiltexH Offline
                                      HiltexH Offline
                                      Hiltex
                                      schrieb am zuletzt editiert von
                                      #209

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

                                      @dslraser ja ein apple problem - auf diesem weg scheint die anwesenheitskontrolle nicht zu funktionieren mit iphone - kannst du höchstens mit einem zusätzliche script abfangen

                                      wie es scheint, meldet es sich immer nur für ein paar minuten ab - das könntest du prüfen

                                      Das ist ein Apple-Problem per se. Die Anwesenheitserkennung über UniFi ist die einzige Variante, die bei einem iPhone wirklich sehr gut funktioniert - zumindest grundsätzlich. Das Verhalten mit dem An- und Abmelden hatte ich auch schonmal. Ein Neustart des Telefons hat geholfen.

                                      Blog: indibit.de

                                      dslraserD 1 Antwort Letzte Antwort
                                      0
                                      • HiltexH Hiltex

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

                                        @dslraser ja ein apple problem - auf diesem weg scheint die anwesenheitskontrolle nicht zu funktionieren mit iphone - kannst du höchstens mit einem zusätzliche script abfangen

                                        wie es scheint, meldet es sich immer nur für ein paar minuten ab - das könntest du prüfen

                                        Das ist ein Apple-Problem per se. Die Anwesenheitserkennung über UniFi ist die einzige Variante, die bei einem iPhone wirklich sehr gut funktioniert - zumindest grundsätzlich. Das Verhalten mit dem An- und Abmelden hatte ich auch schonmal. Ein Neustart des Telefons hat geholfen.

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

                                        @Hiltex sagte in Unifi WLAN Script:

                                        Ein Neustart des Telefons hat geholfen.

                                        Jetzt mit dem letzten Script und nach dem Handyneustart läuft es Amok...
                                        Die google Suche hat auch so einiges zum Thema Apple ausgespuckt. Das scheint ja ein bekanntes Problem zu sein.
                                        Ist nicht so tragisch, ich nutze zur Anwesenheit etwas anderes...

                                        Screenshot_20190904-171632_Telegram.jpg

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

                                          @Hiltex sagte in Unifi WLAN Script:

                                          Ein Neustart des Telefons hat geholfen.

                                          Jetzt mit dem letzten Script und nach dem Handyneustart läuft es Amok...
                                          Die google Suche hat auch so einiges zum Thema Apple ausgespuckt. Das scheint ja ein bekanntes Problem zu sein.
                                          Ist nicht so tragisch, ich nutze zur Anwesenheit etwas anderes...

                                          Screenshot_20190904-171632_Telegram.jpg

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

                                          @dslraser mit dem neuen script wird natürlich öfter geprüft - wenn da das last-seen-by-uap durch das handy verückt spielt - kommen natürlich maßig nachrichten

                                          mit android oder anderen geräten funktioniert es aber hoffentlich ???

                                          das kann man auch nicht mehr mit einem externen script abfangen

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

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          842

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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