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.7k

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.
  • s.bormannS s.bormann

    @Hiltex sagte in Unifi WLAN Script:

    Vielleicht ist dem einen oder anderen schonmal aufgefallen, dass Bilder, die in VIS einmal benutzt wurden und später nochmal verändert werden, trotzdem wie das ursprüngliche Bild angezeigt werden?
    Ich glaube, dass nicht iQontrol der Schuldige ist, sondern irgend ein Caching-System von ioBroker.

    Hallo,
    habe mal kurz quergelesen - coole Idee, wir ihr das ganze hier umgesetzt habt!
    Ich denke, @Hiltex hat Recht, ich vermute ebenfalls, dass das an dem cache vom iobroker liegt. iQontrol selbst cached die Dateien nicht.

    Man kann den Cache aber deaktivieren (habe ich schon ewig gemacht ohne negative Auswirkungen zu spüren):

    In der Datei (Pfade stimmen für Linux)

    \opt\iobroker\iobroker-data\iobroker.json

    die Option "noFileCache" auf true stellen und iobroker (nicht nur den Admin, sondern den kompletten Controller) neu starten.

    Ich hoffe, dass es so klappt!

    VG!

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

    @s-bormann sagte in Unifi WLAN Script:

    In der Datei (Pfade stimmen für Linux)
    \opt\iobroker\iobroker-data\iobroker.json
    die Option "noFileCache" auf true stellen und iobroker (nicht nur den Admin, sondern den kompletten Controller) neu starten.

    @liv-in-sky
    @Hiltex
    Das klappt, die Listen sind jetzt sofort aktuell.:+1:

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

      @s-bormann sagte in Unifi WLAN Script:

      In der Datei (Pfade stimmen für Linux)
      \opt\iobroker\iobroker-data\iobroker.json
      die Option "noFileCache" auf true stellen und iobroker (nicht nur den Admin, sondern den kompletten Controller) neu starten.

      @liv-in-sky
      @Hiltex
      Das klappt, die Listen sind jetzt sofort aktuell.:+1:

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

      @dslraser klasse - hab nachgesehen - war bei mir aktiviert !
      @dslraser - habe folgendes noch hinzugefüg - alphabetische sortierung der clientliste, mehrere netzwerke, jetzt fehlt nur noch das ein und auschalten der netzwerke - mal sehen ob ich heute eine lösung finde

      anderes thema: was etwas nervt ist die lange wartezeit bei der abmeldung der wlangeräte - hat da jemand eine idee-
      oder gibt es ein setting im unificontroller dafür - manchmal scheint ein refresh der controller webseite schon zu helfen - kann man sowas irgendwie simulieren ?

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

      HiltexH dslraserD 2 Antworten Letzte Antwort
      0
      • liv-in-skyL liv-in-sky

        @dslraser klasse - hab nachgesehen - war bei mir aktiviert !
        @dslraser - habe folgendes noch hinzugefüg - alphabetische sortierung der clientliste, mehrere netzwerke, jetzt fehlt nur noch das ein und auschalten der netzwerke - mal sehen ob ich heute eine lösung finde

        anderes thema: was etwas nervt ist die lange wartezeit bei der abmeldung der wlangeräte - hat da jemand eine idee-
        oder gibt es ein setting im unificontroller dafür - manchmal scheint ein refresh der controller webseite schon zu helfen - kann man sowas irgendwie simulieren ?

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

        @liv-in-sky man kann im Controller einstellen, dass Geräte mit schlechtem Empfang automatisch getrennt werden. Vielleicht wäre das eine Lösung?
        Hab ich selber aber noch nicht ausprobiert.

        Alternativ, wenn nur Android-Geräte eingesetzt werden, könnte man die per Script vielleicht anpingen. Wenn sie nicht antworten trennen oder „wiederverbinden“, sofern man per API da dran kommt

        Blog: indibit.de

        1 Antwort Letzte Antwort
        0
        • dslraserD Offline
          dslraserD Offline
          dslraser
          Forum Testing Most Active
          schrieb am zuletzt editiert von
          #152

          @liv-in-sky
          vielleicht noch etwas Kosmetik....(hier könnten noch Leerzeichen rein)

          Bildschirmfoto 2019-09-03 um 10.54.35.png

          Bildschirmfoto 2019-09-03 um 10.54.48.png

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

            @dslraser klasse - hab nachgesehen - war bei mir aktiviert !
            @dslraser - habe folgendes noch hinzugefüg - alphabetische sortierung der clientliste, mehrere netzwerke, jetzt fehlt nur noch das ein und auschalten der netzwerke - mal sehen ob ich heute eine lösung finde

            anderes thema: was etwas nervt ist die lange wartezeit bei der abmeldung der wlangeräte - hat da jemand eine idee-
            oder gibt es ein setting im unificontroller dafür - manchmal scheint ein refresh der controller webseite schon zu helfen - kann man sowas irgendwie simulieren ?

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

            @liv-in-sky
            @s-bormann
            ich habe das iframe bei mir mal so in iQontrol eingebunden, sieht etwas besser auf dem Handy aus. (gesucht habe ich eigentlich nach responsive, aber da bin ich mir nicht sicher ob das in der geschriebenen Datei geht, oder im iQontrol Adapter selbst)

            <iframe width="100% "height="100% "frameborder="0" src="htmlclients.html"></iframe
            
            liv-in-skyL 2 Antworten Letzte Antwort
            1
            • dslraserD dslraser

              @liv-in-sky
              @s-bormann
              ich habe das iframe bei mir mal so in iQontrol eingebunden, sieht etwas besser auf dem Handy aus. (gesucht habe ich eigentlich nach responsive, aber da bin ich mir nicht sicher ob das in der geschriebenen Datei geht, oder im iQontrol Adapter selbst)

              <iframe width="100% "height="100% "frameborder="0" src="htmlclients.html"></iframe
              
              liv-in-skyL Offline
              liv-in-skyL Offline
              liv-in-sky
              schrieb am zuletzt editiert von
              #154

              @dslraser sagte in Unifi WLAN Script:

              <iframe width="100% "height="100% "frameborder="0" src="htmlclients.html"></iframe

              ja cool - im querfomat perfect !

              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
                @s-bormann
                ich habe das iframe bei mir mal so in iQontrol eingebunden, sieht etwas besser auf dem Handy aus. (gesucht habe ich eigentlich nach responsive, aber da bin ich mir nicht sicher ob das in der geschriebenen Datei geht, oder im iQontrol Adapter selbst)

                <iframe width="100% "height="100% "frameborder="0" src="htmlclients.html"></iframe
                
                liv-in-skyL Offline
                liv-in-skyL Offline
                liv-in-sky
                schrieb am zuletzt editiert von
                #155

                @dslraser

                die neue version ist bald fertig ! 🔥

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

                  @dslraser sagte in Unifi WLAN Script:

                  <iframe width="100% "height="100% "frameborder="0" src="htmlclients.html"></iframe

                  ja cool - im querfomat perfect !

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

                  @liv-in-sky

                  hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script

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

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

                    @liv-in-sky

                    hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script

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

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

                    @dslraser sagte in Unifi WLAN Script:

                    @liv-in-sky

                    hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script

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

                    wird näher untersucht !!!

                    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 sagte in Unifi WLAN Script:

                      @liv-in-sky

                      hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script

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

                      wird näher untersucht !!!

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

                      @liv-in-sky

                      hier auch noch Infos die sich vielleicht nutzen lassen

                      https://wiki.fhem.de/wiki/PRESENCE

                      https://forum.fhem.de/index.php/topic,40287.msg562823.html#msg562823

                      1 Antwort Letzte Antwort
                      0
                      • dslraserD Offline
                        dslraserD Offline
                        dslraser
                        Forum Testing Most Active
                        schrieb am zuletzt editiert von dslraser
                        #159

                        @liv-in-sky
                        zum an/ausschalten des Gäste WLAN über einen Switch (an/aus) habe ich mal den unteren Teil auskommentiert und dafür mal den Wifi_an Switch genommen. Über den Wifi_an kannst Du dann an und ausschalten.

                        on({id: 'javascript.0.WLANUnifi.Wifi_an', val: true}, function (obj) {
                         var value = obj.state.val;
                         var oldValue = obj.oldState.val;
                         if (getState("javascript.0.WLANUnifi.Wifi_Status").val == false) {
                           setWifi(true);
                         } else {
                           setWifi(false);
                         }
                        });
                        /*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);
                        });*/
                        
                        

                        Edit:

                        on({id: 'javascript.0.WLANUnifi.Wifi_an', change: "ne"}, function (obj) {
                         var value = obj.state.val;
                         var oldValue = obj.oldState.val;
                         if (getState("javascript.0.WLANUnifi.Wifi_an").val == true) {
                           setWifi(true);
                         } else {
                           setWifi(false);
                         }
                        });
                        

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

                          @dslraser sagte in Unifi WLAN Script:

                          @liv-in-sky

                          hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script

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

                          wird näher untersucht !!!

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

                          @liv-in-sky

                          Einen DP entfernt und nur noch einen DP zum an/aus schalten

                          const unifi_username = "xxx";
                          const unifi_password = "xxx";
                          const unifi_controller = "https://192.168.xxx.xxx:xxxx";
                          const wifi_id = "xxxxxxxxxxx";
                          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.0.";
                          
                          //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 Schalter für Wifi an-aus erstellen
                          createState(dpPrefix + "WLANUnifi.Wifi_an_aus",true, {
                            name: 'Unifi Wifi an_aus', 
                            role: 'switch',
                            read:  true, 
                            write: true,
                            type: "boolean",
                            "smartName": {
                            "de": "Gäste Wifi",
                            "smartType": "SWITCH"
                          }
                          });
                          
                          if (true) {
                          createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
                            name: 'Unifi Wifi Clients Table', 
                            role: 'string',
                            read:  true, 
                            write: true,
                          });}
                          
                          if (vouchers) {
                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
                            name: 'Unifi Wifi Vouchers_Table', 
                            role: 'string',
                            read:  true, 
                            write: true,
                          });
                          
                          for (var i = 1; i < 21; i++) { 
                            var x=i.toString();
                            if (i<10) x="0"+x;
                           createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
                            name: 'Unifi Voucher_Code'+x, 
                            role: 'string',
                            read:  true, 
                            write: true,
                            });
                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".code"+x, {
                            name: 'Unifi Voucher_Code_code'+x, 
                            role: 'string',
                            read:  true, 
                            write: true,
                            });    
                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
                            name: 'Unifi Voucher_Code_erstellt'+x, 
                            role: 'string',
                            read:  true, 
                            write: true,
                            });
                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".dauer", {
                            name: 'Unifi Voucher_Code_duration'+x, 
                            role: 'string',
                            read:  true, 
                            write: true,
                            });
                          createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".abgelaufen", {
                            name: 'Unifi Voucher_Code_expires'+x, 
                            role: 'string',
                            read:  true, 
                            write: true,
                            });
                          }}
                          
                          createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                          if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                          
                          function dlog(message) {
                           if(debug)
                               console.log(message);
                          }
                          
                          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({id: dpPrefix + 'WLANUnifi.Wifi_an_aus', change: "ne"}, function (obj) {
                          var value = obj.state.val;
                          var oldValue = obj.oldState.val;
                          if (getState(dpPrefix + 'WLANUnifi.Wifi_an_aus').val == true) {
                            setWifi(true);
                          } else {
                            setWifi(false);
                          }
                          });
                          
                          
                          /*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);
                          });*/
                          
                          
                          

                          1 Antwort Letzte Antwort
                          0
                          • dslraserD dslraser

                            @liv-in-sky
                            zum an/ausschalten des Gäste WLAN über einen Switch (an/aus) habe ich mal den unteren Teil auskommentiert und dafür mal den Wifi_an Switch genommen. Über den Wifi_an kannst Du dann an und ausschalten.

                            on({id: 'javascript.0.WLANUnifi.Wifi_an', val: true}, function (obj) {
                             var value = obj.state.val;
                             var oldValue = obj.oldState.val;
                             if (getState("javascript.0.WLANUnifi.Wifi_Status").val == false) {
                               setWifi(true);
                             } else {
                               setWifi(false);
                             }
                            });
                            /*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);
                            });*/
                            
                            

                            Edit:

                            on({id: 'javascript.0.WLANUnifi.Wifi_an', change: "ne"}, function (obj) {
                             var value = obj.state.val;
                             var oldValue = obj.oldState.val;
                             if (getState("javascript.0.WLANUnifi.Wifi_an").val == true) {
                               setWifi(true);
                             } else {
                               setWifi(false);
                             }
                            });
                            

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

                            @dslraser ist schon drin

                            muss noch ein paar tests macchen dann ist fertig

                            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 Offline
                              liv-in-skyL Offline
                              liv-in-sky
                              schrieb am zuletzt editiert von liv-in-sky
                              #162

                              @dslraser

                              das neuste script

                              // September 2019 @liv-in-sky durch viel vorarbeit von @thewhobox (api verbindung)
                              
                              // Definition Login
                              const unifi_username = "x";
                              const unifi_password = "xxxxxx!";
                              const unifi_controller = "https://192.xxx.xxx.xxx:8443";
                              
                              
                              // DEFINITION der zu anzeigenden Netzwerke am besten bis auf id und smart alle gleich setzen: beispiel:
                              const wifis = {
                                "WLAN_Dragon1": { name: "WLAN_Dragon1", id: "yyyyyyyyyyyyyyyyyyyyy", desc: "WLAN_Dragon1", smart: "WLAN_Dragon1" } ,
                                "WLAN_DragonGuest": { name: "WLAN_DragonGuest", id: "yyyyyyyyyyyyyyyyyyyy", desc: "WLAN_DragonGuest", smart: "WLAN_DragonGuest" }
                              }
                              let wifiDPs = [];
                              
                              const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                              var fs = require('fs')
                              
                              const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
                              const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
                              let writeFile = true;
                              let  writeFileVar = 0;
                              let writeClientTable = true;
                              let writeAnwesenheit = true;
                              let listeDatenpunkte = [];
                              let listeDatenpunkteNew = [];
                              let listeDatenpunkteAlt = [];
                              
                              // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, inder das script läuft zusammenpassen
                              const dpPrefix = "javascript.0.";
                              
                              // Abfragezyklus definieren
                              const abfragezyklus =20000;
                              
                              //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
                              let  iqontrol = true;
                              let  anwesenheit = true; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects "von hand" löschen
                              let vouchers = true;
                              
                              // Hier Definition iqontrol-Style für Popup
                              const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                              const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                              
                              
                              //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                              
                              let cookies = [];
                              let loggedIn = false;
                              let debug = false;
                              
                              if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                              if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                              
                              
                              
                              //Erstelle Datenpunkte für die WLANs automatisch
                              for(let wifi_name in wifis) {
                              
                                  wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].name);
                                 
                                 createState(dpPrefix + "WLANUnifi."+ wifi_name, {
                                    name: wifis[wifi_name].desc,
                                    role: 'state',
                                    read: true,
                                    write: true,
                                    type: "boolean",
                                    smartName: {
                                        de: wifis[wifi_name].smart,
                                        smartType: "SWITCH"
                                    } });}
                              
                              
                              if (true) {
                              createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
                                 name: 'Unifi Wifi Clients Table', 
                                 role: 'string',
                                 read:  true, 
                                 write: true,
                              });}
                              
                              
                              if (vouchers) {
                              createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
                                 name: 'Unifi Wifi Vouchers_Table', 
                                 role: 'string',
                                 read:  true, 
                                 write: true,
                              });
                              
                              for (var i = 1; i < 21; i++) { 
                                 var x=i.toString();
                                 if (i<10) x="0"+x;
                                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
                                 name: 'Unifi Voucher_Code'+x, 
                                 role: 'string',
                                 read:  true, 
                                 write: true,
                                 });
                              createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".code"+x, {
                                 name: 'Unifi Voucher_Code_code'+x, 
                                 role: 'string',
                                 read:  true, 
                                 write: true,
                                 });    
                              createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
                                 name: 'Unifi Voucher_Code_erstellt'+x, 
                                 role: 'string',
                                 read:  true, 
                                 write: true,
                                 });
                              createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".dauer", {
                                 name: 'Unifi Voucher_Code_duration'+x, 
                                 role: 'string',
                                 read:  true, 
                                 write: true,
                                 });
                              createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".abgelaufen", {
                                 name: 'Unifi Voucher_Code_expires'+x, 
                                 role: 'string',
                                 read:  true, 
                                 write: true,
                                 });
                              }}
                              
                              createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                              if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                              
                              function dlog(message) {
                                if(debug)
                                    console.log(message);
                              }
                              //-----------------------------------------LOGIN---------------------------------------------------------------
                              async function login() {
                                return new Promise(async (resolve, reject) => {
                                    let resp = await request.post({
                                        resolveWithFullResponse: true,
                                        url: unifi_controller + "/api/login",
                                        body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                                        headers: { 'Content-Type': 'application/json' }
                                    }).catch((e) => { dlog("login: reject"), reject(e) });
                                    
                                    if(resp != null) {
                                        dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                        if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                                            let set_cookies = resp.headers["set-cookie"];
                                            for(i = 0; i < set_cookies.length; i++) {
                                                let cookie = set_cookies[i];
                                                cookie = cookie.split(";")[0];
                                                cookies.push(cookie);
                                            }
                                        } else {
                                            dlog("login: no cookies to set!")
                                        }
                                        loggedIn = true;
                                        resolve();
                                    } else {
                                        dlog("login: rejected")
                                        reject("resp = null");
                                    }
                                });
                              }
                              async function dlogout() {
                                return new Promise(async (resolve, reject) => {
                                    let resp = await request.get({
                                        url: unifi_controller + "/dlogout",
                                        headers: { Cookie: cookies.join("; ") }
                                    }).catch((e) => reject(e));
                                    if(resp != null) {
                                        dlog("Du bist nun ausgedloggt.");
                                        dlog(resp);
                                        resolve();
                                    } else {
                                        reject("resp = null");
                                    }
                                });
                              }
                              //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
                              //Updatet status vom Wifi
                              //wifi: wifi object aus der konstanten wifis
                              async function getStatus(wifi) {
                                   dlog("BIN IN STATUS");
                                return new Promise(async (resolve, reject) => {
                                    dlog("nur mal so");
                                    if (!loggedIn) await login().catch((e) => reject(e));
                                    let resp = await request.get({
                                        url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi.id,
                                        headers: { Cookie: cookies.join("; ") }
                                    }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
                              
                                    dlog("got response " + JSON.stringify(resp));
                                    resp = JSON.parse(resp);
                              
                                    let wlanOn = resp.data[0].enabled;
                                    dlog("WLAN " + wifi.name + " ist: " + (wlanOn ? "an" : "aus"));
                              
                                    if (resp != null && resp.meta && resp.meta.rc == "ok") {
                                        dlog("Status erfolgreich geholt!");
                                        dlog(resp);
                                        let wlanOn = resp.data[0].enabled;
                                        dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                        setStateDelayed(dpPrefix + "WLANUnifi." + wifi.name, wlanOn, 200);
                                     
                                        resolve(wlanOn);
                                    } else {
                                        dlog("nicht ok...")
                                        reject(JSON.stringify(resp));
                                    }dlog("BIN aus STATUS raus");
                                });
                                 
                              }
                              
                              //-----------------------------------------GETCLIENTS---------------------------------------------------------------
                               async function getClients() {
                                  dlog("BIN IN CLIENTS");
                                 
                                 return new Promise(async (resolve, reject) => {
                                     dlog("nur mal so");
                                     if(!loggedIn) await login().catch((e) => reject(e));
                                     let resp = await request.get({
                                         url: unifi_controller + "/api/s/default/stat/sta/",
                                         headers: { Cookie: cookies.join("; ") }
                                     }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                
                              dlog("got response " + JSON.stringify(resp));
                              dlog(typeof resp);
                              dlog("--------------------- " + resp);
                              //resp = JSON.parse(resp);
                              
                              //Sortierung Daten und Verwandlung Json
                              var versuch = [];
                              versuch = JSON.parse(resp).data;
                              dlog(versuch[2].hostname+versuch[2].mac);
                              
                              versuch.sort(function(alpha, beta) {
                                 if ( alpha.hostname < beta.hostname )
                                     return -1;
                                 if ( alpha.hostname > beta.hostname )
                                     return 1;
                                 return 0;
                              });
                              dlog(versuch.length.toString());
                              
                              var anzahlClients = versuch.length;
                              setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                              
                              var clientListe = "";
                              await getExistingClients();
                              
                              //erstelle aktuelles array
                              
                              listeDatenpunkteNew=[];
                              for (var i = 0; i < versuch.length; i++) { 
                                 listeDatenpunkteNew[i] = versuch[i].hostname;}
                                dlog (listeDatenpunkteNew[3]);
                              
                              // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
                              dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
                              if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
                              dlog("ClientTable "+writeClientTable.toString());
                              dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
                              
                              
                              // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
                              if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
                              dlog("writeAnwesenheit "+writeAnwesenheit.toString());
                              dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
                              
                              // erstelle htmlclientliste wenn listenDaten verändert  
                                  if ( writeClientTable ) {
                                   for (var i = 0; i < versuch.length; i++)  {
                                     dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                                     clientListe = clientListe.concat("<tr><td>"+versuch[i].hostname+"&ensp;</td><td>"+versuch[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+versuch[i].ip+"</td></tr>");
                                     dlog(clientListe);
                                     var ipWandler= versuch[i].ip;
                                     if (anwesenheit && writeAnwesenheit) {
                                        createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, {
                                        name: ipWandler, 
                                        role: 'boolean',
                                        read:  true, 
                                        write: true,
                                        });
                                     }
                                   
                                   if (anwesenheit && listeDatenpunkteNew.indexOf(versuch[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
                                     dlog("gefunden"+versuch[i].hostname);
                                     setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, true, 500);}
                               } }
                                   
                               
                              if (anwesenheit) {
                              for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
                              if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
                                  dlog("nicht gefunden"+listeDatenpunkte[b]);
                                  setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 500);}}}
                              
                              if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl angemeldeter Geräte:"+versuch.length+"</p>"));
                              
                              dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                              if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                              dlog("bin raus aus  clients");
                              });
                              
                              }
                              
                              
                              async function getExistingClients() {
                                 dlog("BIN IN EXISTING CLIENTS");
                              listeDatenpunkte = [];
                              var cacheSelectorState = $("state[state.id=" + dpPrefix + "WLANUnifi.Wifi_Client_States.*]");
                                cacheSelectorState.each(function (id, c) {
                                  if (!id.includes("undefined")) {
                                   listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
                              });
                              //for (i = 0; i<listeDatenpunkte.length;i++) {log(listeDatenpunkte[i]);}
                              //log(listeDatenpunkte.length.toString());
                              dlog("bin raus a existing clients");
                              }
                              
                              //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
                              async function getVouchers() {
                                   dlog("BIN IN VOUCHERS");
                                 return new Promise(async (resolve, reject) => {
                                     dlog("nur mal so");
                                     if(!loggedIn) await login().catch((e) => reject(e));
                                     let resp = await request.get({
                                         url: unifi_controller + "/api/s/default/stat/voucher",
                                         headers: { Cookie: cookies.join("; ") }
                                     }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                
                              dlog("got response " + JSON.stringify(resp));
                              dlog(typeof resp);
                              dlog("--------------------- " + resp);
                              resp = JSON.parse(resp);
                              
                              dlog(resp.meta);
                              dlog(resp.meta.rc);
                              dlog(resp.data[1].code);
                              dlog(resp.data.length);
                              dlog(JSON.stringify(resp).length.toString());
                              var laengeMessage=JSON.stringify(resp).length;
                              if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                              writeFileVar=JSON.stringify(resp).length;
                              
                              if (writeFile) {
                              var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                              
                              for (var i = 1; i < 21; i++) { 
                                 var x=i.toString();
                                 if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
                                 
                              for (var i = 0; i < resp.data.length; i++) { 
                                var zeit= resp.data[i].create_time*1000
                                let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                              
                                clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                                var y=i+1; 
                                var yy=y.toString();
                                if (y<10 )  yy="0"+yy;
                               
                                if (i<20  )  {
                                    dlog(zeit1);
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, resp.data[i].code );
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", resp.data[i].duration );
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", resp.data[i].status_expires );
                                    
                                }}
                              
                              
                              //Datenpunkteäalt löschen
                              var w = resp.data.length;
                              for (i = w; i < 20; i++) { 
                                    var y=i+1; 
                                var yy=y.toString();
                                if (y<10 )  yy="0"+yy;
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, " na " );
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", " na " );
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", " na " );
                                    setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", " na " );
                              }
                              }
                              
                              if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl Vouchers:"+resp.data.length+"</p>"));}
                              if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
                              if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
                              dlog("bin raus a existing vouchers");
                              });
                              
                              }
                              
                              
                              //-----------------------------------------SET WIFIS - WIFI EIN-AUSSCHALTEN----------------------------------------------
                              //Wifi an-/ausschalten
                              //enabled: true = anschalten; false = ausschalten
                              //wifi: wifi object aus der konstanten wifis
                              async function setWifi(enabled, wifi) {
                                return new Promise(async (resolve, reject) => {
                                    dlog("setWifi: start set Wifi_haupt");
                                    if (!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                    dlog("setWifi: now setting Wifi_haupt");
                                    let resp = request.post({
                                        url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi.id,
                                        body: JSON.stringify({ enabled }),
                                        headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                    }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
                                    dlog("setWifi: got response")
                              
                                    if (resp != null) {
                                        dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                        dlog(resp);
                                        setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                                        resolve();
                                    } else {
                                        dlog("setWifi: rejetced")
                                        dlog("resp: " + JSON.stringify(resp));
                                        reject("msg: " + JSON.parse(resp.body).meta.msg);
                                    }
                                });
                              }
                              
                              
                              
                              //-----------------------------------------------SCHALTER------------------------------------------------
                              on({id: wifiDPs, ack: false, change: "ne"}, function (obj) { 
                               var value = obj.state.val;
                               var dp2 = obj.name
                               setWifi(value, wifis[dp2]);
                               dlog(wifis[dp2])
                              });
                              
                              //-----------------------------------------------MAIN LOOP------------------------------------------------
                              setInterval(async () => {
                              
                                 for(let wifi_name in wifis) {
                                 await getStatus(wifis[wifi_name]);}
                               
                                 if (vouchers)  getVouchers();
                                 await getClients();
                               
                              
                                 }, abfragezyklus); // wird oben definiert
                              
                              
                              // Beispiel für
                              //setWifi(true, wifis.WLAN_DragoRootGuest);
                              
                              

                              bitte testen - viele änderungen

                              werd mir das anwesenheitsspiel noch näher ansehen - aber wenn alles funktioniert sollte das so klappen

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

                                @dslraser

                                das neuste script

                                // September 2019 @liv-in-sky durch viel vorarbeit von @thewhobox (api verbindung)
                                
                                // Definition Login
                                const unifi_username = "x";
                                const unifi_password = "xxxxxx!";
                                const unifi_controller = "https://192.xxx.xxx.xxx:8443";
                                
                                
                                // DEFINITION der zu anzeigenden Netzwerke am besten bis auf id und smart alle gleich setzen: beispiel:
                                const wifis = {
                                  "WLAN_Dragon1": { name: "WLAN_Dragon1", id: "yyyyyyyyyyyyyyyyyyyyy", desc: "WLAN_Dragon1", smart: "WLAN_Dragon1" } ,
                                  "WLAN_DragonGuest": { name: "WLAN_DragonGuest", id: "yyyyyyyyyyyyyyyyyyyy", desc: "WLAN_DragonGuest", smart: "WLAN_DragonGuest" }
                                }
                                let wifiDPs = [];
                                
                                const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                                var fs = require('fs')
                                
                                const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
                                const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
                                let writeFile = true;
                                let  writeFileVar = 0;
                                let writeClientTable = true;
                                let writeAnwesenheit = true;
                                let listeDatenpunkte = [];
                                let listeDatenpunkteNew = [];
                                let listeDatenpunkteAlt = [];
                                
                                // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, inder das script läuft zusammenpassen
                                const dpPrefix = "javascript.0.";
                                
                                // Abfragezyklus definieren
                                const abfragezyklus =20000;
                                
                                //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
                                let  iqontrol = true;
                                let  anwesenheit = true; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects "von hand" löschen
                                let vouchers = true;
                                
                                // Hier Definition iqontrol-Style für Popup
                                const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                
                                
                                //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                                
                                let cookies = [];
                                let loggedIn = false;
                                let debug = false;
                                
                                if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                
                                
                                
                                //Erstelle Datenpunkte für die WLANs automatisch
                                for(let wifi_name in wifis) {
                                
                                    wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].name);
                                   
                                   createState(dpPrefix + "WLANUnifi."+ wifi_name, {
                                      name: wifis[wifi_name].desc,
                                      role: 'state',
                                      read: true,
                                      write: true,
                                      type: "boolean",
                                      smartName: {
                                          de: wifis[wifi_name].smart,
                                          smartType: "SWITCH"
                                      } });}
                                
                                
                                if (true) {
                                createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
                                   name: 'Unifi Wifi Clients Table', 
                                   role: 'string',
                                   read:  true, 
                                   write: true,
                                });}
                                
                                
                                if (vouchers) {
                                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
                                   name: 'Unifi Wifi Vouchers_Table', 
                                   role: 'string',
                                   read:  true, 
                                   write: true,
                                });
                                
                                for (var i = 1; i < 21; i++) { 
                                   var x=i.toString();
                                   if (i<10) x="0"+x;
                                  createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
                                   name: 'Unifi Voucher_Code'+x, 
                                   role: 'string',
                                   read:  true, 
                                   write: true,
                                   });
                                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".code"+x, {
                                   name: 'Unifi Voucher_Code_code'+x, 
                                   role: 'string',
                                   read:  true, 
                                   write: true,
                                   });    
                                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
                                   name: 'Unifi Voucher_Code_erstellt'+x, 
                                   role: 'string',
                                   read:  true, 
                                   write: true,
                                   });
                                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".dauer", {
                                   name: 'Unifi Voucher_Code_duration'+x, 
                                   role: 'string',
                                   read:  true, 
                                   write: true,
                                   });
                                createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".abgelaufen", {
                                   name: 'Unifi Voucher_Code_expires'+x, 
                                   role: 'string',
                                   read:  true, 
                                   write: true,
                                   });
                                }}
                                
                                createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                                if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                
                                function dlog(message) {
                                  if(debug)
                                      console.log(message);
                                }
                                //-----------------------------------------LOGIN---------------------------------------------------------------
                                async function login() {
                                  return new Promise(async (resolve, reject) => {
                                      let resp = await request.post({
                                          resolveWithFullResponse: true,
                                          url: unifi_controller + "/api/login",
                                          body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                                          headers: { 'Content-Type': 'application/json' }
                                      }).catch((e) => { dlog("login: reject"), reject(e) });
                                      
                                      if(resp != null) {
                                          dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                          if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                                              let set_cookies = resp.headers["set-cookie"];
                                              for(i = 0; i < set_cookies.length; i++) {
                                                  let cookie = set_cookies[i];
                                                  cookie = cookie.split(";")[0];
                                                  cookies.push(cookie);
                                              }
                                          } else {
                                              dlog("login: no cookies to set!")
                                          }
                                          loggedIn = true;
                                          resolve();
                                      } else {
                                          dlog("login: rejected")
                                          reject("resp = null");
                                      }
                                  });
                                }
                                async function dlogout() {
                                  return new Promise(async (resolve, reject) => {
                                      let resp = await request.get({
                                          url: unifi_controller + "/dlogout",
                                          headers: { Cookie: cookies.join("; ") }
                                      }).catch((e) => reject(e));
                                      if(resp != null) {
                                          dlog("Du bist nun ausgedloggt.");
                                          dlog(resp);
                                          resolve();
                                      } else {
                                          reject("resp = null");
                                      }
                                  });
                                }
                                //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
                                //Updatet status vom Wifi
                                //wifi: wifi object aus der konstanten wifis
                                async function getStatus(wifi) {
                                     dlog("BIN IN STATUS");
                                  return new Promise(async (resolve, reject) => {
                                      dlog("nur mal so");
                                      if (!loggedIn) await login().catch((e) => reject(e));
                                      let resp = await request.get({
                                          url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi.id,
                                          headers: { Cookie: cookies.join("; ") }
                                      }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
                                
                                      dlog("got response " + JSON.stringify(resp));
                                      resp = JSON.parse(resp);
                                
                                      let wlanOn = resp.data[0].enabled;
                                      dlog("WLAN " + wifi.name + " ist: " + (wlanOn ? "an" : "aus"));
                                
                                      if (resp != null && resp.meta && resp.meta.rc == "ok") {
                                          dlog("Status erfolgreich geholt!");
                                          dlog(resp);
                                          let wlanOn = resp.data[0].enabled;
                                          dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                          setStateDelayed(dpPrefix + "WLANUnifi." + wifi.name, wlanOn, 200);
                                       
                                          resolve(wlanOn);
                                      } else {
                                          dlog("nicht ok...")
                                          reject(JSON.stringify(resp));
                                      }dlog("BIN aus STATUS raus");
                                  });
                                   
                                }
                                
                                //-----------------------------------------GETCLIENTS---------------------------------------------------------------
                                 async function getClients() {
                                    dlog("BIN IN CLIENTS");
                                   
                                   return new Promise(async (resolve, reject) => {
                                       dlog("nur mal so");
                                       if(!loggedIn) await login().catch((e) => reject(e));
                                       let resp = await request.get({
                                           url: unifi_controller + "/api/s/default/stat/sta/",
                                           headers: { Cookie: cookies.join("; ") }
                                       }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                  
                                dlog("got response " + JSON.stringify(resp));
                                dlog(typeof resp);
                                dlog("--------------------- " + resp);
                                //resp = JSON.parse(resp);
                                
                                //Sortierung Daten und Verwandlung Json
                                var versuch = [];
                                versuch = JSON.parse(resp).data;
                                dlog(versuch[2].hostname+versuch[2].mac);
                                
                                versuch.sort(function(alpha, beta) {
                                   if ( alpha.hostname < beta.hostname )
                                       return -1;
                                   if ( alpha.hostname > beta.hostname )
                                       return 1;
                                   return 0;
                                });
                                dlog(versuch.length.toString());
                                
                                var anzahlClients = versuch.length;
                                setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                                
                                var clientListe = "";
                                await getExistingClients();
                                
                                //erstelle aktuelles array
                                
                                listeDatenpunkteNew=[];
                                for (var i = 0; i < versuch.length; i++) { 
                                   listeDatenpunkteNew[i] = versuch[i].hostname;}
                                  dlog (listeDatenpunkteNew[3]);
                                
                                // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
                                dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
                                if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
                                dlog("ClientTable "+writeClientTable.toString());
                                dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
                                
                                
                                // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
                                if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
                                dlog("writeAnwesenheit "+writeAnwesenheit.toString());
                                dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
                                
                                // erstelle htmlclientliste wenn listenDaten verändert  
                                    if ( writeClientTable ) {
                                     for (var i = 0; i < versuch.length; i++)  {
                                       dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                                       clientListe = clientListe.concat("<tr><td>"+versuch[i].hostname+"&ensp;</td><td>"+versuch[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+versuch[i].ip+"</td></tr>");
                                       dlog(clientListe);
                                       var ipWandler= versuch[i].ip;
                                       if (anwesenheit && writeAnwesenheit) {
                                          createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, {
                                          name: ipWandler, 
                                          role: 'boolean',
                                          read:  true, 
                                          write: true,
                                          });
                                       }
                                     
                                     if (anwesenheit && listeDatenpunkteNew.indexOf(versuch[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
                                       dlog("gefunden"+versuch[i].hostname);
                                       setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, true, 500);}
                                 } }
                                     
                                 
                                if (anwesenheit) {
                                for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
                                if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
                                    dlog("nicht gefunden"+listeDatenpunkte[b]);
                                    setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 500);}}}
                                
                                if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl angemeldeter Geräte:"+versuch.length+"</p>"));
                                
                                dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                                if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                                dlog("bin raus aus  clients");
                                });
                                
                                }
                                
                                
                                async function getExistingClients() {
                                   dlog("BIN IN EXISTING CLIENTS");
                                listeDatenpunkte = [];
                                var cacheSelectorState = $("state[state.id=" + dpPrefix + "WLANUnifi.Wifi_Client_States.*]");
                                  cacheSelectorState.each(function (id, c) {
                                    if (!id.includes("undefined")) {
                                     listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
                                });
                                //for (i = 0; i<listeDatenpunkte.length;i++) {log(listeDatenpunkte[i]);}
                                //log(listeDatenpunkte.length.toString());
                                dlog("bin raus a existing clients");
                                }
                                
                                //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
                                async function getVouchers() {
                                     dlog("BIN IN VOUCHERS");
                                   return new Promise(async (resolve, reject) => {
                                       dlog("nur mal so");
                                       if(!loggedIn) await login().catch((e) => reject(e));
                                       let resp = await request.get({
                                           url: unifi_controller + "/api/s/default/stat/voucher",
                                           headers: { Cookie: cookies.join("; ") }
                                       }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                  
                                dlog("got response " + JSON.stringify(resp));
                                dlog(typeof resp);
                                dlog("--------------------- " + resp);
                                resp = JSON.parse(resp);
                                
                                dlog(resp.meta);
                                dlog(resp.meta.rc);
                                dlog(resp.data[1].code);
                                dlog(resp.data.length);
                                dlog(JSON.stringify(resp).length.toString());
                                var laengeMessage=JSON.stringify(resp).length;
                                if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                writeFileVar=JSON.stringify(resp).length;
                                
                                if (writeFile) {
                                var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                                
                                for (var i = 1; i < 21; i++) { 
                                   var x=i.toString();
                                   if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
                                   
                                for (var i = 0; i < resp.data.length; i++) { 
                                  var zeit= resp.data[i].create_time*1000
                                  let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                
                                  clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                                  var y=i+1; 
                                  var yy=y.toString();
                                  if (y<10 )  yy="0"+yy;
                                 
                                  if (i<20  )  {
                                      dlog(zeit1);
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, resp.data[i].code );
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", resp.data[i].duration );
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", resp.data[i].status_expires );
                                      
                                  }}
                                
                                
                                //Datenpunkteäalt löschen
                                var w = resp.data.length;
                                for (i = w; i < 20; i++) { 
                                      var y=i+1; 
                                  var yy=y.toString();
                                  if (y<10 )  yy="0"+yy;
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, " na " );
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", " na " );
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", " na " );
                                      setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", " na " );
                                }
                                }
                                
                                if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl Vouchers:"+resp.data.length+"</p>"));}
                                if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
                                if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
                                dlog("bin raus a existing vouchers");
                                });
                                
                                }
                                
                                
                                //-----------------------------------------SET WIFIS - WIFI EIN-AUSSCHALTEN----------------------------------------------
                                //Wifi an-/ausschalten
                                //enabled: true = anschalten; false = ausschalten
                                //wifi: wifi object aus der konstanten wifis
                                async function setWifi(enabled, wifi) {
                                  return new Promise(async (resolve, reject) => {
                                      dlog("setWifi: start set Wifi_haupt");
                                      if (!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                      dlog("setWifi: now setting Wifi_haupt");
                                      let resp = request.post({
                                          url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi.id,
                                          body: JSON.stringify({ enabled }),
                                          headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                      }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
                                      dlog("setWifi: got response")
                                
                                      if (resp != null) {
                                          dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                          dlog(resp);
                                          setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                                          resolve();
                                      } else {
                                          dlog("setWifi: rejetced")
                                          dlog("resp: " + JSON.stringify(resp));
                                          reject("msg: " + JSON.parse(resp.body).meta.msg);
                                      }
                                  });
                                }
                                
                                
                                
                                //-----------------------------------------------SCHALTER------------------------------------------------
                                on({id: wifiDPs, ack: false, change: "ne"}, function (obj) { 
                                 var value = obj.state.val;
                                 var dp2 = obj.name
                                 setWifi(value, wifis[dp2]);
                                 dlog(wifis[dp2])
                                });
                                
                                //-----------------------------------------------MAIN LOOP------------------------------------------------
                                setInterval(async () => {
                                
                                   for(let wifi_name in wifis) {
                                   await getStatus(wifis[wifi_name]);}
                                 
                                   if (vouchers)  getVouchers();
                                   await getClients();
                                 
                                
                                   }, abfragezyklus); // wird oben definiert
                                
                                
                                // Beispiel für
                                //setWifi(true, wifis.WLAN_DragoRootGuest);
                                
                                

                                bitte testen - viele änderungen

                                werd mir das anwesenheitsspiel noch näher ansehen - aber wenn alles funktioniert sollte das so klappen

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

                                @liv-in-sky
                                iQontrol im Moment

                                Bildschirmfoto 2019-09-03 um 15.38.23.png

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

                                  @liv-in-sky
                                  iQontrol im Moment

                                  Bildschirmfoto 2019-09-03 um 15.38.23.png

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

                                  @dslraser falls du es testest bitte vorher datenpunkte löschen

                                  gehe jetzt kurz rasenmähen - muss mal vom rechner weg :-)

                                  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 S 4 Antworten Letzte Antwort
                                  0
                                  • liv-in-skyL liv-in-sky

                                    @dslraser

                                    das neuste script

                                    // September 2019 @liv-in-sky durch viel vorarbeit von @thewhobox (api verbindung)
                                    
                                    // Definition Login
                                    const unifi_username = "x";
                                    const unifi_password = "xxxxxx!";
                                    const unifi_controller = "https://192.xxx.xxx.xxx:8443";
                                    
                                    
                                    // DEFINITION der zu anzeigenden Netzwerke am besten bis auf id und smart alle gleich setzen: beispiel:
                                    const wifis = {
                                      "WLAN_Dragon1": { name: "WLAN_Dragon1", id: "yyyyyyyyyyyyyyyyyyyyy", desc: "WLAN_Dragon1", smart: "WLAN_Dragon1" } ,
                                      "WLAN_DragonGuest": { name: "WLAN_DragonGuest", id: "yyyyyyyyyyyyyyyyyyyy", desc: "WLAN_DragonGuest", smart: "WLAN_DragonGuest" }
                                    }
                                    let wifiDPs = [];
                                    
                                    const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                                    var fs = require('fs')
                                    
                                    const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
                                    const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
                                    let writeFile = true;
                                    let  writeFileVar = 0;
                                    let writeClientTable = true;
                                    let writeAnwesenheit = true;
                                    let listeDatenpunkte = [];
                                    let listeDatenpunkteNew = [];
                                    let listeDatenpunkteAlt = [];
                                    
                                    // Datenpunkte Hauptpfad wählen - WICHTIG muss mit der javascript instanz, inder das script läuft zusammenpassen
                                    const dpPrefix = "javascript.0.";
                                    
                                    // Abfragezyklus definieren
                                    const abfragezyklus =20000;
                                    
                                    //HIER Einstellungen : EIN-AUSSCHALTEN Vouchers, iqontrol-Datei erstellen, anwesenheitskontrolle-clientpflege
                                    let  iqontrol = true;
                                    let  anwesenheit = true; // beim setzen von true auf false die verzeichnisstruktur unter iobroker-objects "von hand" löschen
                                    let vouchers = true;
                                    
                                    // Hier Definition iqontrol-Style für Popup
                                    const format = "<!DOCTYPE html><html><head><title>Voucher</title></head><body><table style=\"color:black;text-align:center; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                    const format2 = "<!DOCTYPE html><html><head><title>Clients</title></head><body><table style=\"color:black; font-family:Helvetica;background-image: linear-gradient(42deg,transparent, lightblue);\">";
                                    
                                    
                                    //-----------------AB HIER NICHTS MEHR ÄNDERN------------------------
                                    
                                    let cookies = [];
                                    let loggedIn = false;
                                    let debug = false;
                                    
                                    if ( !anwesenheit) fs.writeFileSync(datei2,("variable anwesenheit und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                    if ( !vouchers) fs.writeFileSync(datei,("variable vouchers und/oder iqontrol ist nicht im unifiscript aktiviert - auf true setzen")); 
                                    
                                    
                                    
                                    //Erstelle Datenpunkte für die WLANs automatisch
                                    for(let wifi_name in wifis) {
                                    
                                        wifiDPs.push(dpPrefix + "WLANUnifi." + wifis[wifi_name].name);
                                       
                                       createState(dpPrefix + "WLANUnifi."+ wifi_name, {
                                          name: wifis[wifi_name].desc,
                                          role: 'state',
                                          read: true,
                                          write: true,
                                          type: "boolean",
                                          smartName: {
                                              de: wifis[wifi_name].smart,
                                              smartType: "SWITCH"
                                          } });}
                                    
                                    
                                    if (true) {
                                    createState(dpPrefix + "WLANUnifi.Wifi_Clients", {
                                       name: 'Unifi Wifi Clients Table', 
                                       role: 'string',
                                       read:  true, 
                                       write: true,
                                    });}
                                    
                                    
                                    if (vouchers) {
                                    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers", {
                                       name: 'Unifi Wifi Vouchers_Table', 
                                       role: 'string',
                                       read:  true, 
                                       write: true,
                                    });
                                    
                                    for (var i = 1; i < 21; i++) { 
                                       var x=i.toString();
                                       if (i<10) x="0"+x;
                                      createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x, {
                                       name: 'Unifi Voucher_Code'+x, 
                                       role: 'string',
                                       read:  true, 
                                       write: true,
                                       });
                                    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".code"+x, {
                                       name: 'Unifi Voucher_Code_code'+x, 
                                       role: 'string',
                                       read:  true, 
                                       write: true,
                                       });    
                                    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".erstellt", {
                                       name: 'Unifi Voucher_Code_erstellt'+x, 
                                       role: 'string',
                                       read:  true, 
                                       write: true,
                                       });
                                    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".dauer", {
                                       name: 'Unifi Voucher_Code_duration'+x, 
                                       role: 'string',
                                       read:  true, 
                                       write: true,
                                       });
                                    createState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+x+".abgelaufen", {
                                       name: 'Unifi Voucher_Code_expires'+x, 
                                       role: 'string',
                                       read:  true, 
                                       write: true,
                                       });
                                    }}
                                    
                                    createState(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",  { name: 'Wifi_Clients_Anzahl', desc: 'Wifi_Clients_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true });
                                    if (vouchers) createState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", { name: 'Wifi_Vouchers_Anzahl', desc: 'Wifi_Vouchers_Anzahl', type: 'number', unit: '', min: '0', max: '100', role: '',read: true, write: true }); 
                                    
                                    function dlog(message) {
                                      if(debug)
                                          console.log(message);
                                    }
                                    //-----------------------------------------LOGIN---------------------------------------------------------------
                                    async function login() {
                                      return new Promise(async (resolve, reject) => {
                                          let resp = await request.post({
                                              resolveWithFullResponse: true,
                                              url: unifi_controller + "/api/login",
                                              body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                                              headers: { 'Content-Type': 'application/json' }
                                          }).catch((e) => { dlog("login: reject"), reject(e) });
                                          
                                          if(resp != null) {
                                              dlog("login: login war erfolgreich! " + ((resp.headers && resp.headers.hasOwnProperty("set-cookie")) ? "Mit Cookies":"Ohne Cookies"));
                                              if(resp.headers && resp.headers.hasOwnProperty("set-cookie")) {
                                                  let set_cookies = resp.headers["set-cookie"];
                                                  for(i = 0; i < set_cookies.length; i++) {
                                                      let cookie = set_cookies[i];
                                                      cookie = cookie.split(";")[0];
                                                      cookies.push(cookie);
                                                  }
                                              } else {
                                                  dlog("login: no cookies to set!")
                                              }
                                              loggedIn = true;
                                              resolve();
                                          } else {
                                              dlog("login: rejected")
                                              reject("resp = null");
                                          }
                                      });
                                    }
                                    async function dlogout() {
                                      return new Promise(async (resolve, reject) => {
                                          let resp = await request.get({
                                              url: unifi_controller + "/dlogout",
                                              headers: { Cookie: cookies.join("; ") }
                                          }).catch((e) => reject(e));
                                          if(resp != null) {
                                              dlog("Du bist nun ausgedloggt.");
                                              dlog(resp);
                                              resolve();
                                          } else {
                                              reject("resp = null");
                                          }
                                      });
                                    }
                                    //-----------------------------------------STATUS   WIFI  ---------------------------------------------------------
                                    //Updatet status vom Wifi
                                    //wifi: wifi object aus der konstanten wifis
                                    async function getStatus(wifi) {
                                         dlog("BIN IN STATUS");
                                      return new Promise(async (resolve, reject) => {
                                          dlog("nur mal so");
                                          if (!loggedIn) await login().catch((e) => reject(e));
                                          let resp = await request.get({
                                              url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi.id,
                                              headers: { Cookie: cookies.join("; ") }
                                          }).catch((e) => { dlog("getStatus reject " + e); reject(e) });
                                    
                                          dlog("got response " + JSON.stringify(resp));
                                          resp = JSON.parse(resp);
                                    
                                          let wlanOn = resp.data[0].enabled;
                                          dlog("WLAN " + wifi.name + " ist: " + (wlanOn ? "an" : "aus"));
                                    
                                          if (resp != null && resp.meta && resp.meta.rc == "ok") {
                                              dlog("Status erfolgreich geholt!");
                                              dlog(resp);
                                              let wlanOn = resp.data[0].enabled;
                                              dlog("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                              setStateDelayed(dpPrefix + "WLANUnifi." + wifi.name, wlanOn, 200);
                                           
                                              resolve(wlanOn);
                                          } else {
                                              dlog("nicht ok...")
                                              reject(JSON.stringify(resp));
                                          }dlog("BIN aus STATUS raus");
                                      });
                                       
                                    }
                                    
                                    //-----------------------------------------GETCLIENTS---------------------------------------------------------------
                                     async function getClients() {
                                        dlog("BIN IN CLIENTS");
                                       
                                       return new Promise(async (resolve, reject) => {
                                           dlog("nur mal so");
                                           if(!loggedIn) await login().catch((e) => reject(e));
                                           let resp = await request.get({
                                               url: unifi_controller + "/api/s/default/stat/sta/",
                                               headers: { Cookie: cookies.join("; ") }
                                           }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                      
                                    dlog("got response " + JSON.stringify(resp));
                                    dlog(typeof resp);
                                    dlog("--------------------- " + resp);
                                    //resp = JSON.parse(resp);
                                    
                                    //Sortierung Daten und Verwandlung Json
                                    var versuch = [];
                                    versuch = JSON.parse(resp).data;
                                    dlog(versuch[2].hostname+versuch[2].mac);
                                    
                                    versuch.sort(function(alpha, beta) {
                                       if ( alpha.hostname < beta.hostname )
                                           return -1;
                                       if ( alpha.hostname > beta.hostname )
                                           return 1;
                                       return 0;
                                    });
                                    dlog(versuch.length.toString());
                                    
                                    var anzahlClients = versuch.length;
                                    setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Clients_Anzahl",anzahlClients,100);
                                    
                                    var clientListe = "";
                                    await getExistingClients();
                                    
                                    //erstelle aktuelles array
                                    
                                    listeDatenpunkteNew=[];
                                    for (var i = 0; i < versuch.length; i++) { 
                                       listeDatenpunkteNew[i] = versuch[i].hostname;}
                                      dlog (listeDatenpunkteNew[3]);
                                    
                                    // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?  
                                    dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length); 
                                    if  (listeDatenpunkteNew.length == listeDatenpunkteAlt.length) {writeClientTable = false;} else {writeClientTable=true;listeDatenpunkteAlt=[];listeDatenpunkteAlt=listeDatenpunkteNew.concat();}   
                                    dlog("ClientTable "+writeClientTable.toString());
                                    dlog("ClientTable "+listeDatenpunkteNew.length + " - " + listeDatenpunkteAlt.length);
                                    
                                    
                                    // gibt es unterschiedliche Daten - bezug listeDatenpunkte anwesenheit?
                                    if (anwesenheit && listeDatenpunkteNew.length==listeDatenpunkte.length) {writeAnwesenheit = false;} else {writeAnwesenheit=true}
                                    dlog("writeAnwesenheit "+writeAnwesenheit.toString());
                                    dlog("writeAnwesenheit "+listeDatenpunkteNew.length + " - " + listeDatenpunkte.length);
                                    
                                    // erstelle htmlclientliste wenn listenDaten verändert  
                                        if ( writeClientTable ) {
                                         for (var i = 0; i < versuch.length; i++)  {
                                           dlog(versuch[i].hostname + " --- " + versuch[i].essid + " --- " + versuch[i].ip);
                                           clientListe = clientListe.concat("<tr><td>"+versuch[i].hostname+"&ensp;</td><td>"+versuch[i].essid+"&ensp;&ensp;&ensp;&ensp;</td><td>"+versuch[i].ip+"</td></tr>");
                                           dlog(clientListe);
                                           var ipWandler= versuch[i].ip;
                                           if (anwesenheit && writeAnwesenheit) {
                                              createState(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, {
                                              name: ipWandler, 
                                              role: 'boolean',
                                              read:  true, 
                                              write: true,
                                              });
                                           }
                                         
                                         if (anwesenheit && listeDatenpunkteNew.indexOf(versuch[i].hostname)>-1) { //ist hostname in neuer liste und verzeichnisstruktur  -> true (anwesend)
                                           dlog("gefunden"+versuch[i].hostname);
                                           setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+versuch[i].hostname, true, 500);}
                                     } }
                                         
                                     
                                    if (anwesenheit) {
                                    for (var b = 0; b < listeDatenpunkte.length-1; b++) { //  ist hostname in verzeichnis struktur und nicht in neuer liste -> false (abwesend)
                                    if (listeDatenpunkteNew.indexOf(listeDatenpunkte[b])==-1) {
                                        dlog("nicht gefunden"+listeDatenpunkte[b]);
                                        setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Client_States."+listeDatenpunkte[b], false, 500);}}}
                                    
                                    if (iqontrol && anwesenheit && writeClientTable) fs.writeFileSync(datei2, format2+clientListe.concat("</table><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl angemeldeter Geräte:"+versuch.length+"</p>"));
                                    
                                    dlog("ClientFile schreibt! "+iqontrol.toString()+writeClientTable.toString());
                                    if (writeClientTable) setState(dpPrefix + "WLANUnifi.Wifi_Clients", "<table>"+clientListe.concat("</table>")); //schreibe client table
                                    dlog("bin raus aus  clients");
                                    });
                                    
                                    }
                                    
                                    
                                    async function getExistingClients() {
                                       dlog("BIN IN EXISTING CLIENTS");
                                    listeDatenpunkte = [];
                                    var cacheSelectorState = $("state[state.id=" + dpPrefix + "WLANUnifi.Wifi_Client_States.*]");
                                      cacheSelectorState.each(function (id, c) {
                                        if (!id.includes("undefined")) {
                                         listeDatenpunkte[c] = id.replace(dpPrefix + "WLANUnifi.Wifi_Client_States.", "");}
                                    });
                                    //for (i = 0; i<listeDatenpunkte.length;i++) {log(listeDatenpunkte[i]);}
                                    //log(listeDatenpunkte.length.toString());
                                    dlog("bin raus a existing clients");
                                    }
                                    
                                    //-----------------------------------------GET--VOUCHERS---------------------------------------------------------------
                                    async function getVouchers() {
                                         dlog("BIN IN VOUCHERS");
                                       return new Promise(async (resolve, reject) => {
                                           dlog("nur mal so");
                                           if(!loggedIn) await login().catch((e) => reject(e));
                                           let resp = await request.get({
                                               url: unifi_controller + "/api/s/default/stat/voucher",
                                               headers: { Cookie: cookies.join("; ") }
                                           }).catch((e) => { dlog("getStatus reject " + e); reject(e) });  
                                      
                                    dlog("got response " + JSON.stringify(resp));
                                    dlog(typeof resp);
                                    dlog("--------------------- " + resp);
                                    resp = JSON.parse(resp);
                                    
                                    dlog(resp.meta);
                                    dlog(resp.meta.rc);
                                    dlog(resp.data[1].code);
                                    dlog(resp.data.length);
                                    dlog(JSON.stringify(resp).length.toString());
                                    var laengeMessage=JSON.stringify(resp).length;
                                    if (laengeMessage==writeFileVar) {writeFile = false;} else {writeFile=true}
                                    writeFileVar=JSON.stringify(resp).length;
                                    
                                    if (writeFile) {
                                    var clientListe = "<tr><td>DAUER&ensp;</td><td>STATUS-ABGELAUFEN&ensp;&ensp;&ensp;&ensp;</td><td>CODE</td>&ensp;&ensp;</td><td>ERSTELLT</td></tr> ";
                                    
                                    for (var i = 1; i < 21; i++) { 
                                       var x=i.toString();
                                       if ( i < 10) { var yyy="0"+x;} else {yyy=x}; setStateDelayed(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yyy, "", 100);}
                                       
                                    for (var i = 0; i < resp.data.length; i++) { 
                                      var zeit= resp.data[i].create_time*1000
                                      let zeit1 =  formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm").toString();
                                    
                                      clientListe = clientListe.concat("<tr><td>"+resp.data[i].duration+"&ensp;</td><td>"+resp.data[i].status_expires+"&ensp;&ensp;&ensp;&ensp;</td><td>"+resp.data[i].code+"&ensp;&ensp;</td><td>" +zeit1 + "</td></tr>");
                                      var y=i+1; 
                                      var yy=y.toString();
                                      if (y<10 )  yy="0"+yy;
                                     
                                      if (i<20  )  {
                                          dlog(zeit1);
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, resp.data[i].code );
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", zeit1 );
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", resp.data[i].duration );
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", resp.data[i].status_expires );
                                          
                                      }}
                                    
                                    
                                    //Datenpunkteäalt löschen
                                    var w = resp.data.length;
                                    for (i = w; i < 20; i++) { 
                                          var y=i+1; 
                                      var yy=y.toString();
                                      if (y<10 )  yy="0"+yy;
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".code"+yy, " na " );
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".erstellt", " na " );
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".dauer", " na " );
                                          setState(dpPrefix + "WLANUnifi.Wifi_Vouchers-CODES.CODE"+yy+".abgelaufen", " na " );
                                    }
                                    }
                                    
                                    if (iqontrol && writeFile) {fs.writeFileSync(datei, format + clientListe.concat("</table></style></body></html><p style=\"color:blue; font-family:Helvetica;\">Geamtanzahl Vouchers:"+resp.data.length+"</p>"));}
                                    if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers", "<table>"+clientListe.concat("</table></style></body></html>"));
                                    if (writeFile) setState(dpPrefix + "WLANUnifi.Wifi_Vouchers_Anzahl", resp.data.length);
                                    dlog("bin raus a existing vouchers");
                                    });
                                    
                                    }
                                    
                                    
                                    //-----------------------------------------SET WIFIS - WIFI EIN-AUSSCHALTEN----------------------------------------------
                                    //Wifi an-/ausschalten
                                    //enabled: true = anschalten; false = ausschalten
                                    //wifi: wifi object aus der konstanten wifis
                                    async function setWifi(enabled, wifi) {
                                      return new Promise(async (resolve, reject) => {
                                          dlog("setWifi: start set Wifi_haupt");
                                          if (!loggedIn) { dlog("need to login"); await login().catch((e) => reject(e)); }
                                          dlog("setWifi: now setting Wifi_haupt");
                                          let resp = request.post({
                                              url: unifi_controller + "/api/s/default/upd/wlanconf/" + wifi.id,
                                              body: JSON.stringify({ enabled }),
                                              headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                          }).catch((e) => { dlog("setWifi: rejected: " + e); reject(e) });
                                          dlog("setWifi: got response")
                                    
                                          if (resp != null) {
                                              dlog("setWifi: Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                              dlog(resp);
                                              setState(dpPrefix + "WLANUnifi." + wifi.name, enabled, enabled);
                                              resolve();
                                          } else {
                                              dlog("setWifi: rejetced")
                                              dlog("resp: " + JSON.stringify(resp));
                                              reject("msg: " + JSON.parse(resp.body).meta.msg);
                                          }
                                      });
                                    }
                                    
                                    
                                    
                                    //-----------------------------------------------SCHALTER------------------------------------------------
                                    on({id: wifiDPs, ack: false, change: "ne"}, function (obj) { 
                                     var value = obj.state.val;
                                     var dp2 = obj.name
                                     setWifi(value, wifis[dp2]);
                                     dlog(wifis[dp2])
                                    });
                                    
                                    //-----------------------------------------------MAIN LOOP------------------------------------------------
                                    setInterval(async () => {
                                    
                                       for(let wifi_name in wifis) {
                                       await getStatus(wifis[wifi_name]);}
                                     
                                       if (vouchers)  getVouchers();
                                       await getClients();
                                     
                                    
                                       }, abfragezyklus); // wird oben definiert
                                    
                                    
                                    // Beispiel für
                                    //setWifi(true, wifis.WLAN_DragoRootGuest);
                                    
                                    

                                    bitte testen - viele änderungen

                                    werd mir das anwesenheitsspiel noch näher ansehen - aber wenn alles funktioniert sollte das so klappen

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

                                    @liv-in-sky

                                    neues Script getestet. Es wird alles angelegt.
                                    Ich kann keinen Status von den WLAN's sehen, angezeigt wird maximal null (geschaltet werden die WLAN anscheinend trotzdem, habe eben mein Haupt WLAN ausversehen ausgeknipst:confounded: )

                                    Bildschirmfoto 2019-09-03 um 15.54.00.png

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

                                      @dslraser falls du es testest bitte vorher datenpunkte löschen

                                      gehe jetzt kurz rasenmähen - muss mal vom rechner weg :-)

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

                                      @liv-in-sky

                                      jetzt ist es sichtbar (habe einmal das Script neu gestartet, vielleicht kam es aber auch mit dem Aktualisierungsintervall, kann ich nicht genau sagen ?)

                                      Bildschirmfoto 2019-09-03 um 16.05.46.png

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

                                        @dslraser falls du es testest bitte vorher datenpunkte löschen

                                        gehe jetzt kurz rasenmähen - muss mal vom rechner weg :-)

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

                                        @liv-in-sky
                                        die Sortierung der Clients in den Objekten klappt fast. Ich habe eine alphabetische Reihenfolge, bis auf alle Amazon ECHO Geräte habe sich dazwischengemogelt, aber alle hintereinander.

                                        Bildschirmfoto 2019-09-03 um 16.11.33.png

                                        Edit:
                                        Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.

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

                                          @dslraser falls du es testest bitte vorher datenpunkte löschen

                                          gehe jetzt kurz rasenmähen - muss mal vom rechner weg :-)

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

                                          @liv-in-sky
                                          läuft alles, super Arbeit !:+1:
                                          In der Client Liste habe ich jetzt auch die IP Adresse:blush:

                                          iQontrol am Mac

                                          Bildschirmfoto 2019-09-03 um 16.19.08.png

                                          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

                                          752

                                          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