Navigation

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

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Unifi WLAN Script

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

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

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

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

      DURATION  STATUSEXPIRES

      aber leider das ein-ausschalten check ich nicht

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

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

        @dslraser

        duration = dauer
        statusexpires = ablaufstatus ????

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

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

          statusexpires

          Bildschirmfoto 2019-09-01 um 20.44.04.png

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

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

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

            Die DP werden im Moment aber nicht aktualisiert, oder ?

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

              @dslraser

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

              var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
              
              dslraser 1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @dslraser last edited by

                @dslraser sagte in Unifi WLAN Script:

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

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

                Die DP werden im Moment aber nicht aktualisiert, oder ?

                welche genau ?

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

                  @liv-in-sky
                  Wifi_Client_State

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

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

                    @dslraser

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

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

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

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

                      Bildschirmfoto 2019-09-01 um 21.11.59.png

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

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

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

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

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

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

                          @dslraser

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

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

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

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

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

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

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

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

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

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

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

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

                                  @dslraser sagte in Unifi WLAN Script:

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

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

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

                                  dieser hier funktioniert bei mir

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

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

                                    moin -

                                    ich habe nochmal getestet und dummen fehler gefunden - sorry

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

                                    bitte nochmal testen

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

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

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

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

                                        @dslraser das verstehe ich nun garnicht - könnte das ein cahe problem des browsers sein ? die datei hat ja das aktuelle datum und zeit und du sagst, der inhalt der datei ist auch richtig

                                        schon mal browserwechsel oder pc wechsel gecheckt

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

                                          @liv-in-sky
                                          jetzt passt es plötzlich ? (keine Ahnung warum, ich habe nicht den Browser gewechselt und auch nicht den Cache geleert. Ich habe eben aber mein NAS neu gestartet(update) und nun passt es.) Ich werde es beobachten und sage Bescheid.

                                          1 Reply Last reply Reply Quote 0
                                          • D
                                            darkiop Most Active @liv-in-sky last edited by darkiop

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

                                            der pfad der constante const=dpPrefix muss mit der javascript instanz übereinsimmen, in dem das script läuft
                                            javascript-instanz 0 muss dann const dpPrefix = "javascript.0."; lauten (da lag mein denkfehler)

                                            Das kannst du auch so lösen, dann ist es variabel:

                                            const dpPrefix = 'javascript.' + instance + '.';
                                            

                                            Gruß

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            598
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

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