NEWS
[Major Update] UniFi Adapter v0.5.0
-
@crunchip sagte in [Major Update] UniFi Adapter v0.5.0:
@lobomau achso, ja wenn man ein USG integriert hat, sieht man die Verbindung, client---USG, wenn client nicht mehr mit dem AP/Wlan verbunden ist.
Was du aber siehst, ist der DP. Im Adapter.
In dem Moment steht dein Datenpunkt .is-wired auf true
Hat im Endeffekt den gleichen Zweck. Wlan Gerät ist nicht mehr im Wlan.Genau richtig. bei mir werden die DP is_online auch nicht aktualisiert.
Datenpunkt .is-wired auf true---> trifft natürlich zu. Bei einem handy mag ich das verstehen aber wenn man mal einen Laptop wired dran hat und mal per Wlan sieht die Sache anders aus wenn man wissen möchte ob "online" oder eben nicht.Besteht nicht die Möglichkeit den DP is_online "richtig" abzufragen? Ist das echt nicht so einfach? (muss so blöd fragen, kenne mich da nicht aus)
-
Hätte noch eine Frage zu Databindings. Kann es sein das sich bei meinen Widgets nicht mehr die Farbe ändert weil im Databinding die MAC (wegen den Doppelpunkten) vorhanden ist?
Beim Skript funktionieren meine Bindings (da sind allerdings die Aliasnamen im Object, also ohne doppelpunkte)
-
@mikiline said in [Major Update] UniFi Adapter v0.5.0:
Datenpunkt .is-wired auf true---> trifft natürlich zu. Bei einem handy mag ich das verstehen aber wenn man mal einen Laptop wired dran hat und mal per Wlan sieht die Sache anders aus wenn man wissen möchte ob "online" oder eben nicht.
Der DP
is_wired
wird 1:1 aus dem UniFi Controller übernommen. Warum der Controller das so macht kann Dir nur Ubiquity erklären. Für mich ist das ein Bug.Besteht nicht die Möglichkeit den DP is_online "richtig" abzufragen? Ist das echt nicht so einfach? (muss so blöd fragen, kenne mich da nicht aus)
Der UniFi Controller gibt immer nur die Clients aus, die gerade online sind oder vor kurzem noch online waren. Das Problem dabei sind die Clients, die vor kurzem noch online waren, weil es hier eine deutliche Verzögerung gibt. Der Adapter (genau wie das Script) muss also berechnen, ob ein Client online ist.
Bei mir funktioniert diese Berechnung ausgezeichnet. Da es bei anderen User nicht funktioniert, gilt es herauszufinden woran das liegt.
-
@TDCroPower und @Iccube und @mikiline und @lobomau
Ich habe gerade auf GitHub eine Änderung hochgeladen. Könnt Ihr bitte den Adapter einmal von GitHub aktualisieren? Die Versionsnummer ändert sich dabei nicht, aber die Konfigurationsseite wurde überarbeitet. Es könnte sein, dass Ihr den Adapter neu konfigurieren müsst. Ich bin gespannt auf Euer Feedback.https://github.com/iobroker-community-adapters/ioBroker.unifi
-
-
@braindead alles klar, wird gemacht
-
@braindead
Ich probiere jetzt mal (Blockly ist aus---nur Telegram Schraubenschlüssel is_online eingestellt)Sollte die Überschrift dort sein ?
-
@braindead bin auch schon dabei ^^
-
also bisher schaut es bei mir gut aus. hab nen Offset von 60 Sekunden gewählt. Habe aber auch den einfachsten Aufbau (nur einen AP-AC-L R).
Den einen doppelten false-Eintrag konnte ich nicht noch einmal nachstellen.
-
@dslraser das steht bei mir richtig
aber wieder alle clients filtern -
@crunchip bei mir stehts auch falsch da O.o
-
@crunchip und @dslraser und @Kueppert
Die Überschrift war copy&paste und wurde mittlerweile auf GitHub korrigiert. Wenn ihr vor dem GitHub Update installiert habt, dann ist sie falsch, ansonsten richtig.Zum Verständnis: Das Offset wird auf das Abfrageinterval addiert. 60 Sekunden Abfrageinterval + 30 Sekunden Offset könnte also eine sehr gute Einstellung sein.
-
@braindead ah, ok, dann ändere ich mal runter auf 30 Sek.
UPDATE: mit offset 30 Sek. läufts auch prima bei mir. Die Zustellung vom Telegram via Schraubenschlüssel funktioniert auch auf dem Datenpunkt "is_online".
-
@braindead ich hatte testweise 90 eingetragen, folge...dauerte einige Minuten bis sich der DP ändert, probiere mal mit 30
-
@braindead sagte in [Major Update] UniFi Adapter v0.5.0:
Zum Verständnis: Das Offset wird auf das Abfrageinterval addiert. 60 Sekunden Abfrageinterval + 30 Sekunden Offset könnte also eine sehr gute Einstellung sein.
Erster Test:
Ich bin jetzt mit 60/30 einmal vom Wohnzimmer in den Keller. Dabei habe ich in der Unifi App das Handy beobachtet. Es wechselte auf dem Weg in den Keller vom AP Wohnzimmer zum Schlafzimmer, dann auf Gästezimmer und zum Schluss auf den AP Keller. Es kam keine Offline Meldung.
WLAN am Handy nun mal ausgestellt und es kam brav die Meldung, genauso beim wieder anschalten.Zum einfachen probieren nur die Verzögerung in meinem Blockly auf 0 gestellt.
60 Sekunden Abfrageinterval + 30 Sekunden Offset könnte also eine sehr gute Einstellung sein.
Das scheint mir auch so
-
@braindead danke fürs silent update, der DP is_online wird jetzt mit true gefüllt aber nicht aktualisiert wenn ich den Client aus dem Netz nehme...
-
sieht bis jetzt ganz gut aus mit 30 sec
@Kueppert sagte in [Major Update] UniFi Adapter v0.5.0:
Telegram via Schraubenschlüssel funktioniert
auch mit Emoji
das script was ich zum Vergleich laufen habe, funktioniert aber irgendwie jetzt nicht mehr
function checkUAP () { for (var i=0; i<wificlients.devices.length; i++) { // UAP abfragen var lchange = getState("unifi.0.default.clients." + wificlients.devices[i].mac + ".uptime_by_uap").lc; var uap_anwesenheit = (lchange - ((new Date().getTime()) - 60000) < 0 === true) ? false : true; if (logging) log('Gerät ' + wificlients.devices[i].geraet + ' von ' + wificlients.devices[i].nutzer + ' ist ' + uap_anwesenheit); // Datenpunkt verzögert beschreiben var idUAP = "javascript." + instance + ".Anwesend.UAP." + wificlients.devices[i].nutzer; setStateDelayed(idUAP, uap_anwesenheit, 1000); } }
-
@crunchip sagte in [Major Update] UniFi Adapter v0.5.0:
auch mit Emoji
Ja, habe ich auch schon gemacht, aber, wie stellt man da ein das nur z.B. ich, also ein bestimmter User, diese Meldung bekommt ? Geht das irgendwie über/mit dem Schraubenschlüssel ?
-
@dslraser ich habe dafür zwei Instanzen laufen
-
@crunchip
müßte das dann nicht 60000 + Offset sein (also 90000)?
(Aber ich habe davon wenig Ahnung, nur eine Vermutung.)var uap_anwesenheit = (lchange - ((new Date().getTime()) - 60000) < 0 === true) ? false : true;