Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

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

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    16
    1
    1.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    912

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

Unifi WLAN Script

Scheduled Pinned Locked Moved JavaScript
380 Posts 13 Posters 61.1k Views 13 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • dslraserD dslraser

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

    statusexpires

    Bildschirmfoto 2019-09-01 um 20.44.04.png

    liv-in-skyL Offline
    liv-in-skyL Offline
    liv-in-sky
    wrote on last edited by
    #110

    @dslraser

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

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

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

    dslraserD 1 Reply Last reply
    0
    • dslraserD dslraser

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

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

      Die DP werden im Moment aber nicht aktualisiert, oder ?

      liv-in-skyL Offline
      liv-in-skyL Offline
      liv-in-sky
      wrote on last edited by
      #111

      @dslraser sagte in Unifi WLAN Script:

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

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

      Die DP werden im Moment aber nicht aktualisiert, oder ?

      welche genau ?

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

      dslraserD 1 Reply Last reply
      0
      • liv-in-skyL liv-in-sky

        @dslraser sagte in Unifi WLAN Script:

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

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

        Die DP werden im Moment aber nicht aktualisiert, oder ?

        welche genau ?

        dslraserD Offline
        dslraserD Offline
        dslraser
        Forum Testing Most Active
        wrote on last edited by
        #112

        @liv-in-sky
        Wifi_Client_State

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

        liv-in-skyL 1 Reply Last reply
        0
        • dslraserD dslraser

          @liv-in-sky
          Wifi_Client_State

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

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          wrote on last edited by
          #113

          @dslraser

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

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

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

          dslraserD 1 Reply Last reply
          0
          • liv-in-skyL liv-in-sky

            @dslraser

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

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

            dslraserD Offline
            dslraserD Offline
            dslraser
            Forum Testing Most Active
            wrote on last edited by
            #114

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

            Bildschirmfoto 2019-09-01 um 21.11.59.png

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

            1 Reply Last reply
            0
            • liv-in-skyL liv-in-sky

              @dslraser

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

              var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
              
              dslraserD Offline
              dslraserD Offline
              dslraser
              Forum Testing Most Active
              wrote on last edited by dslraser
              #115

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

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

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

              liv-in-skyL 1 Reply Last reply
              0
              • dslraserD dslraser

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

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

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

                liv-in-skyL Offline
                liv-in-skyL Offline
                liv-in-sky
                wrote on last edited by
                #116

                @dslraser

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

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

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

                dslraserD 3 Replies Last reply
                0
                • liv-in-skyL liv-in-sky

                  @dslraser

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

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

                  dslraserD Offline
                  dslraserD Offline
                  dslraser
                  Forum Testing Most Active
                  wrote on last edited by
                  #117

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

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

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

                  1 Reply Last reply
                  0
                  • liv-in-skyL liv-in-sky

                    @dslraser

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

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

                    dslraserD Offline
                    dslraserD Offline
                    dslraser
                    Forum Testing Most Active
                    wrote on last edited by
                    #118

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

                    1 Reply Last reply
                    0
                    • liv-in-skyL liv-in-sky

                      @dslraser

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

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

                      dslraserD Offline
                      dslraserD Offline
                      dslraser
                      Forum Testing Most Active
                      wrote on last edited by
                      #119

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

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

                      dslraserD 1 Reply Last reply
                      0
                      • dslraserD dslraser

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

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

                        dslraserD Offline
                        dslraserD Offline
                        dslraser
                        Forum Testing Most Active
                        wrote on last edited by
                        #120

                        @dslraser sagte in Unifi WLAN Script:

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

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

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

                        dieser hier funktioniert bei mir

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

                        1 Reply Last reply
                        0
                        • liv-in-skyL Offline
                          liv-in-skyL Offline
                          liv-in-sky
                          wrote on last edited by liv-in-sky
                          #121

                          moin -

                          ich habe nochmal getestet und dummen fehler gefunden - sorry

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

                          bitte nochmal testen

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

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

                          dslraserD D 2 Replies Last reply
                          1
                          • liv-in-skyL liv-in-sky

                            moin -

                            ich habe nochmal getestet und dummen fehler gefunden - sorry

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

                            bitte nochmal testen

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

                            dslraserD Offline
                            dslraserD Offline
                            dslraser
                            Forum Testing Most Active
                            wrote on last edited by
                            #122

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

                            liv-in-skyL 1 Reply Last reply
                            0
                            • dslraserD dslraser

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

                              liv-in-skyL Offline
                              liv-in-skyL Offline
                              liv-in-sky
                              wrote on last edited by
                              #123

                              @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

                              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 2 Replies Last reply
                              0
                              • liv-in-skyL liv-in-sky

                                @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

                                dslraserD Offline
                                dslraserD Offline
                                dslraser
                                Forum Testing Most Active
                                wrote on last edited by dslraser
                                #124

                                @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
                                0
                                • liv-in-skyL liv-in-sky

                                  moin -

                                  ich habe nochmal getestet und dummen fehler gefunden - sorry

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

                                  bitte nochmal testen

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

                                  D Offline
                                  D Offline
                                  darkiop
                                  Most Active
                                  wrote on last edited by darkiop
                                  #125

                                  @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ß

                                  Proxmox-ioBroker-Redis-HA Doku: https://forum.iobroker.net/topic/47478/dokumentation-einer-proxmox-iobroker-redis-ha-umgebung

                                  1 Reply Last reply
                                  1
                                  • liv-in-skyL liv-in-sky

                                    @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

                                    dslraserD Offline
                                    dslraserD Offline
                                    dslraser
                                    Forum Testing Most Active
                                    wrote on last edited by
                                    #126

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

                                    @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

                                    Das mit iQontrol verstehe ich nicht ! Ich habe jetzt verschiedene Browser und Rechner/iPad/Handy usw. benutzt und probiert. Es wird nicht die aktuelle Voucher Liste angezeigt. In allen Datenpunkten passt es, nur die Anzeige mit iQontrol nicht. In der geschriebenen Datei ist ebenfalls der richtige Inhalt drinn. Ich habe eine neue Liste mit 20 Vouchern erstellt, angezeigt werden mir aber 7 aus der alten Liste. Cache habe ich auch schon gelöscht....
                                    Irgendwie scheint iQontol die alte Datei zwischen zu speichern ? Ich frage mal bei @s-bormann nach...

                                    liv-in-skyL 1 Reply Last reply
                                    0
                                    • dslraserD dslraser

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

                                      @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

                                      Das mit iQontrol verstehe ich nicht ! Ich habe jetzt verschiedene Browser und Rechner/iPad/Handy usw. benutzt und probiert. Es wird nicht die aktuelle Voucher Liste angezeigt. In allen Datenpunkten passt es, nur die Anzeige mit iQontrol nicht. In der geschriebenen Datei ist ebenfalls der richtige Inhalt drinn. Ich habe eine neue Liste mit 20 Vouchern erstellt, angezeigt werden mir aber 7 aus der alten Liste. Cache habe ich auch schon gelöscht....
                                      Irgendwie scheint iQontol die alte Datei zwischen zu speichern ? Ich frage mal bei @s-bormann nach...

                                      liv-in-skyL Offline
                                      liv-in-skyL Offline
                                      liv-in-sky
                                      wrote on last edited by
                                      #127

                                      @dslraser dieses problem habe ich nicht - nutzt du windows als iobroker?

                                      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 Reply Last reply
                                      0
                                      • liv-in-skyL liv-in-sky

                                        @dslraser dieses problem habe ich nicht - nutzt du windows als iobroker?

                                        dslraserD Offline
                                        dslraserD Offline
                                        dslraser
                                        Forum Testing Most Active
                                        wrote on last edited by
                                        #128

                                        @liv-in-sky
                                        nein, Synology NAS und ioBroker im Docker. Ich habe eben mal den ganzen Container neu gestartet, dann ist die Anzeige wieder richtig. Berechtigungsproblem ? Nur was mich wundert, der Inhalt der Datei, die auf dem NAS liegt hat ja den richtigen Inhalt.

                                        liv-in-skyL 1 Reply Last reply
                                        0
                                        • dslraserD dslraser

                                          @liv-in-sky
                                          nein, Synology NAS und ioBroker im Docker. Ich habe eben mal den ganzen Container neu gestartet, dann ist die Anzeige wieder richtig. Berechtigungsproblem ? Nur was mich wundert, der Inhalt der Datei, die auf dem NAS liegt hat ja den richtigen Inhalt.

                                          liv-in-skyL Offline
                                          liv-in-skyL Offline
                                          liv-in-sky
                                          wrote on last edited by
                                          #129

                                          @dslraser berechtigung glaube ich nicht - es liegt ja im iobroker ordner und du kannst es ja sehen das upgedatete file

                                          hat der iqontrol erschaffer etwas gesagt ?

                                          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 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          687

                                          Online

                                          32.6k

                                          Users

                                          82.2k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe