- ioBroker Community Home
- Deutsch
- Skripten / Logik
- JavaScript
- Unifi WLAN Script
NEWS
Unifi WLAN Script
-
@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 findeanderes 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 ?@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-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@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
-
@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"></iframedie 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
-
@dslraser sagte in Unifi WLAN Script:
<iframe width="100% "height="100% "frameborder="0" src="htmlclients.html"></iframe
ja cool - im querfomat perfect !
hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script
-
hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script
@dslraser sagte in Unifi WLAN Script:
hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script
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
-
@dslraser sagte in Unifi WLAN Script:
hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script
wird näher untersucht !!!
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
-
@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); } }); -
@dslraser sagte in Unifi WLAN Script:
hier noch was zur Anwesenheitserkennung. Der Ansatz ist auch ganz interessant. Vielleicht bekommt man diesen Wert auch ins Script
wird näher untersucht !!!
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+" </td><td>"+resp.data[i].essid+"    </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 </td><td>STATUS-ABGELAUFEN    </td><td>CODE</td>  </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+" </td><td>"+resp.data[i].status_expires+"    </td><td>"+resp.data[i].code+"  </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); });*/ -
@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); } });@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
-
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+" </td><td>"+versuch[i].essid+"    </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 </td><td>STATUS-ABGELAUFEN    </td><td>CODE</td>  </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+" </td><td>"+resp.data[i].status_expires+"    </td><td>"+resp.data[i].code+"  </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
-
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+" </td><td>"+versuch[i].essid+"    </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 </td><td>STATUS-ABGELAUFEN    </td><td>CODE</td>  </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+" </td><td>"+resp.data[i].status_expires+"    </td><td>"+resp.data[i].code+"  </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
@liv-in-sky
iQontrol im Moment
-
@liv-in-sky
iQontrol im Moment
@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
-
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+" </td><td>"+versuch[i].essid+"    </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 </td><td>STATUS-ABGELAUFEN    </td><td>CODE</td>  </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+" </td><td>"+resp.data[i].status_expires+"    </td><td>"+resp.data[i].code+"  </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
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: )
-
@dslraser falls du es testest bitte vorher datenpunkte löschen
gehe jetzt kurz rasenmähen - muss mal vom rechner weg :-)
jetzt ist es sichtbar (habe einmal das Script neu gestartet, vielleicht kam es aber auch mit dem Aktualisierungsintervall, kann ich nicht genau sagen ?)

-
@dslraser falls du es testest bitte vorher datenpunkte löschen
gehe jetzt kurz rasenmähen - muss mal vom rechner weg :-)
@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.
Edit:
Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht. -
@dslraser falls du es testest bitte vorher datenpunkte löschen
gehe jetzt kurz rasenmähen - muss mal vom rechner weg :-)
@liv-in-sky
läuft alles, super Arbeit !:+1:
In der Client Liste habe ich jetzt auch die IP Adresse:blush:iQontrol am Mac

-
@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.
Edit:
Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.@dslraser sagte in Unifi WLAN Script:
Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.
versuch.sort(function (alpha, beta) { if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase()) return -1; if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase()) return 1; return 0; });Das sollte das Sortierproblem lösen.
-
Telegram

Meine Frau hatte noch nicht mal an der Tür geklingelt, da kam schon die Nachricht. An meinem Handy habe ich dann auch direkt mal WLAN eingeschaltet.
-
@dslraser sagte in Unifi WLAN Script:
Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.
versuch.sort(function (alpha, beta) { if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase()) return -1; if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase()) return 1; return 0; });Das sollte das Sortierproblem lösen.
@thewhobox sagte in Unifi WLAN Script:
@dslraser sagte in Unifi WLAN Script:
Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.
versuch.sort(function (alpha, beta) { if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase()) return -1; if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase()) return 1; return 0; });Das sollte das Sortierproblem lösen.
kenn ich - aber leider geht's nicht - habe ich gestern getestet
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
-
@thewhobox sagte in Unifi WLAN Script:
@dslraser sagte in Unifi WLAN Script:
Gerade gesehen, die Amazon Geräte fangen alle mit einem kleinen Buchstaben an, wahrscheinlich passt die Sortierung deshalb irgendwie nicht.
versuch.sort(function (alpha, beta) { if (alpha.hostname.toLowerCase() < beta.hostname.toLowerCase()) return -1; if (alpha.hostname.toLowerCase() > beta.hostname.toLowerCase()) return 1; return 0; });Das sollte das Sortierproblem lösen.
kenn ich - aber leider geht's nicht - habe ich gestern getestet
@liv-in-sky
habe ich eben auch probiert, ging bei mir auch nicht