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

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

Community Forum

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

NEWS

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

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

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

Unifi WLAN Script

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

    @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
    schrieb am zuletzt editiert von
    #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 Antworten Letzte Antwort
    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
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      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
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          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
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            0
            • liv-in-skyL Offline
              liv-in-skyL Offline
              liv-in-sky
              schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
              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
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                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
                  schrieb am zuletzt editiert von
                  #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 Antworten Letzte Antwort
                  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
                    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                    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 Online
                      D Online
                      darkiop
                      Most Active
                      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                      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
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        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
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          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
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von
                              #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 Antwort Letzte Antwort
                              0
                              • liv-in-skyL liv-in-sky

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

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

                                @liv-in-sky
                                ich habe noch nicht gefragt, weil ich noch rumprobiert habe, mache ich später...

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

                                  @liv-in-sky
                                  ich habe noch nicht gefragt, weil ich noch rumprobiert habe, mache ich später...

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

                                  @dslraser hab mal "im google" nachgesehen - wenn die ein iframe reloaden machen die es mit einem script im htmcode - das möchte ich lieber nicht probieren

                                  frag mal nach, wie das mit dem reload cyclus in iqontrol ist - oder hast du schon mal auf git geschaut, ob jmd ein ähnlich thema hat

                                  es wäre ganz interessant, ob s-borman das gut findet mit den files in dem ordner

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

                                  dslraserD 1 Antwort Letzte Antwort
                                  0
                                  • dslraserD dslraser

                                    @liv-in-sky
                                    ich habe noch nicht gefragt, weil ich noch rumprobiert habe, mache ich später...

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

                                    @dslraser bei mir werden beide files innerhalb küzester zeit aktuell angezeigt - du mußt halt das popup immer wieder öffnen - aber das machst du ja ?

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

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

                                      @dslraser hab mal "im google" nachgesehen - wenn die ein iframe reloaden machen die es mit einem script im htmcode - das möchte ich lieber nicht probieren

                                      frag mal nach, wie das mit dem reload cyclus in iqontrol ist - oder hast du schon mal auf git geschaut, ob jmd ein ähnlich thema hat

                                      es wäre ganz interessant, ob s-borman das gut findet mit den files in dem ordner

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

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

                                      ob s-borman das gut findet mit den files in dem ordner

                                      https://forum.iobroker.net/post/296527

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

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

                                        ob s-borman das gut findet mit den files in dem ordner

                                        https://forum.iobroker.net/post/296527

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

                                        @dslraser wir der uns sicher mitteilen - vielleicht hat er ja eine andere idee das besser zu machen

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

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

                                          @dslraser wir der uns sicher mitteilen - vielleicht hat er ja eine andere idee das besser zu machen

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

                                          @liv-in-sky
                                          bei einem Containerneustart geht es einmal, aber nur dann wird mir die aktuelle Liste angezeigt. (das ist aber keine Lösung)

                                          liv-in-skyL 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          682

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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