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

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

Community Forum

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

NEWS

  • 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

Scheduled Pinned Locked Moved JavaScript
380 Posts 13 Posters 57.4k Views 13 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • liv-in-skyL Offline
    liv-in-skyL Offline
    liv-in-sky
    wrote on last edited by liv-in-sky
    #121

    moin -

    ich habe nochmal getestet und dummen fehler gefunden - sorry

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

    bitte nochmal testen

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

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

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

      moin -

      ich habe nochmal getestet und dummen fehler gefunden - sorry

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

      bitte nochmal testen

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

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

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

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

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

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

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

        schon mal browserwechsel oder pc wechsel gecheckt

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

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

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

          schon mal browserwechsel oder pc wechsel gecheckt

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

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

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

            moin -

            ich habe nochmal getestet und dummen fehler gefunden - sorry

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

            bitte nochmal testen

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

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

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

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

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

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

            Gruß

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

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

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

              schon mal browserwechsel oder pc wechsel gecheckt

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

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

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

              schon mal browserwechsel oder pc wechsel gecheckt

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

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

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

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

                schon mal browserwechsel oder pc wechsel gecheckt

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

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

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

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

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

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

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

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

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

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

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

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

                    hat der iqontrol erschaffer etwas gesagt ?

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

                    dslraserD 1 Reply Last reply
                    0
                    • 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
                      wrote on last edited by
                      #130

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

                      liv-in-skyL 2 Replies Last reply
                      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
                        wrote on last edited by
                        #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 Reply Last reply
                        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
                          wrote on last edited by
                          #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 Reply Last reply
                          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
                            wrote on last edited by
                            #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 Reply Last reply
                            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
                              wrote on last edited by
                              #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 Reply Last reply
                              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
                                wrote on last edited by
                                #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 Reply Last reply
                                0
                                • dslraserD dslraser

                                  @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 Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  wrote on last edited by
                                  #136

                                  @dslraser ich könnte im script einbauen, dass es nach dem schreiben des files auch den docker-container neustartet 👿

                                  werden eigentlich die clients im iqontrol file upgedatet ? und sind sichtbar

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

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

                                    @dslraser ich könnte im script einbauen, dass es nach dem schreiben des files auch den docker-container neustartet 👿

                                    werden eigentlich die clients im iqontrol file upgedatet ? und sind sichtbar

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

                                    @liv-in-sky
                                    kann ich noch gar nicht sagen, angezeigt wird mir ne Liste, aber da steht dann ja keine Anzahl gesamt und die Ausgabe ist noch nicht so ganz "schön", aber da wäre ich noch drauf zurück gekommen.

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

                                      @dslraser ich könnte im script einbauen, dass es nach dem schreiben des files auch den docker-container neustartet 👿

                                      werden eigentlich die clients im iqontrol file upgedatet ? und sind sichtbar

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

                                      @liv-in-sky
                                      bei mir steht in dieser Liste das Gerät selbst, dann das Netzt(wobei bei manchen auch undefined steht) und als letztes die Mac Adresse, die bräuchte ich gar nicht, dafür lieber die IP Adresse.

                                      1 Reply Last reply
                                      0
                                      • dslraserD dslraser

                                        @liv-in-sky
                                        kann ich noch gar nicht sagen, angezeigt wird mir ne Liste, aber da steht dann ja keine Anzahl gesamt und die Ausgabe ist noch nicht so ganz "schön", aber da wäre ich noch drauf zurück gekommen.

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

                                        @dslraser sagte in Unifi WLAN Script:

                                        @liv-in-sky
                                        kann ich noch gar nicht sagen, angezeigt wird mir ne Liste, aber da steht dann ja keine Anzahl gesamt und die Ausgabe ist noch nicht so ganz "schön", aber da wäre ich noch drauf zurück gekommen.

                                        es sollte eine anzahl gesamt drinstehen im iqontrol file - ganz unten evt. scrollen

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

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

                                          @dslraser sagte in Unifi WLAN Script:

                                          @liv-in-sky
                                          kann ich noch gar nicht sagen, angezeigt wird mir ne Liste, aber da steht dann ja keine Anzahl gesamt und die Ausgabe ist noch nicht so ganz "schön", aber da wäre ich noch drauf zurück gekommen.

                                          es sollte eine anzahl gesamt drinstehen im iqontrol file - ganz unten evt. scrollen

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

                                          @liv-in-sky
                                          scrollen auf dem Handy funktioniert nicht wirklich.

                                          liv-in-skyL 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          741

                                          Online

                                          32.4k

                                          Users

                                          81.5k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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