NEWS
Adapter: ioBroker.unifi
-
@pix:Kannst du die dahinterstehenden Homematic Variablen mal erklären?
[…]
Ich habe versucht, das in ioBroker Javascript Adapter nachzubauen, aber es klappt noch nicht ganz. `
Das liegt vermutlich daran das du nie hm_pdetect (https://homematic-forum.de/forum/viewto … 7t#p204194) auf der CCU verwendet hast. Das ganze funktioniert dort nämlich äquivalent. Im Grunde brauchst du folgende Systemvariablen auf der CCU.
Systemvariablen mit exakt diesen Namen + Einstellungen:
Anwesenheit - Boolean mit Werten true=anwesend, false=abwesend (normal in CCU bereits vorhanden) Anwesenheit.Nutzer – Boolean mit Werten true=anwesend, false=abwesend Anwesenheit.list - enum Liste aller Anwesenheitskombinationen Anwesenheit.string - Zeichenkette Anwesenheit.Gast - Boolean mit Werten true=anwesend, false=abwesend
Systemvariablen für jeden Nutzer mit NAME = Nutzername
Anwesenheit.NAME - Boolean mit Werten true=anwesend, false=abwesend
D.h. wenn man nun zwei Nutzer "John" und "Jane" hat würde man die folgenden zwei boolean Systemvariablen mit den beiden Werten true=anwesend, false=abwesend auf der CCU brauchen:
Anwesenheit.John Anwesenheit.Jane
In dem Skript den ich gepostet habe muss dann noch die enum_list variable eben mit der Enum Liste der Systemvariable "Anwesenheit.list" abgeglichen werden und im Grunde alle Kombinationen haben die man für die Anwesenheit aller Nutzer + Gast theoretisch zur verfügung hat. Bei zwei Nutzern sieht das dann eben wie folgt aus:
/* Enum list of all combinations of users+guest */ var enum_list = []; enum_list[0] = "Niemand"; enum_list[1] = "Nutzer1"; enum_list[2] = "Nutzer2"; enum_list[3] = "Nutzer1,Nutzer2"; enum_list[4] = "Gast"; enum_list[5] = "Nutzer1,Gast"; enum_list[6] = "Nutzer2,Gast"; enum_list[7] = "Nutzer1,Nutzer2,Gast"
D.h. für 2 Nutzer hat man 8 Kombinationen wie der wert von Anwesenheit.string dann z.B. aussehen kann. Genau diese Kombinationen muss man dann auch in der Anwesenheit.list CCU Systemvariablen eben mit Semikolon getrennt eingeben.
Hoffe das macht es etwas klarer.
-
wenn Du den AP „manuell“ konfiguriert hast, ist er beim Controller unbekannt und kann daher auch vom Adapter nicht ausgelesen werden, usw. `
wenn ich das richtig verstehe, dann muss der controller staendig laufen. Das ist bei meinem Win PC nicht der Fall.
Dann kommt nur meine debian installation in Frage.
Ich müsste also alles zurücksetzen und mit der DEBIAN Installation neu beginnen. `
Für die die nicht extra ein neues Debian aufsetzen wollen oder auf Unabhängigkeit des Unifi-Controllers setzen möchte kann auch einfach auf den "Unifi-CloudKey" setzen (https://www.ubnt.com/unifi/unifi-cloud-key/). Das ist im Grunde ein kleines Embedded Device auf dem ein minimaoistisches Linux drauf läuft und dann eben die Controller Firmware. Das hat zwar "Cloud" im Namen, aber die Cloud-Funktion muss man ja nicht einsetzen. Ich habe selbst den Unifi-CloudKey und bin da sehr mit zufrieden (zumal er einfach via PoE an einen UniFi-Switch angeschlossen werden kann).
-
Ich habe aktuell 2 Pis im Einsatz. Einen für Raspberrymatic und einen für IoBroker. Könnte ich den Unifi Adapter jetzt noch zusätzlich auf den Pi mit Iobroker installieren (habe hier ein fertiges Image genommen) oder benötige ich einen dritten Pi?
Da hier viel anwesend sind die mit Wlan / Internet sich aus kennen, ich konnte über die Suche keinen Adapter für Telekom Router finden sondern nur einen Fritzbox Adapter. Dabei würde ich behaupten, dass die Speedport Router auch sehr weit verbreitet sind. Gibt es hier eine Lösung Daten aus zu lesen?
Aktuell sieht meine Konfig so aus. Unifi AP im Erdgeschoss, Speedport Smart im Obergeschoss und Unifi AP im Dachgeschoss.
-
Ob der Pi für iobroker und UniFi-Controller ausreicht, wage ich zu bezweifeln. Er hat ganz schön was zu tun (Statistiken, usw.).
Wenn ich am Sonntag aus dem Urlaub zurück bin, schaue ich mir die Systemlast meines Controllers mal an.
Gruß,
Eric
Von unterwegs getippert
-
Da hier viel anwesend sind die mit Wlan / Internet sich aus kennen, ich konnte über die Suche keinen Adapter für Telekom Router finden sondern nur einen Fritzbox Adapter. Dabei würde ich behaupten, dass die Speedport Router auch sehr weit verbreitet sind. Gibt es hier eine Lösung Daten aus zu lesen? `
Es gibt ein Script dazu. Die Suche sollte was dazu liefern. -
Hallo Jens,
kannst du mir nochmal helfen?
Ich komme nicht richtig klar mit dm Script.
/* define actual user devices here */ var user_devices = []; user_devices['98:10:E8:BE:DE:A7'] = 'Klaus'; user_devices['B8:53:AC:14:A1:B4'] = 'Hans; user_devices['B6:53:AC:18:A4:B4'] = 'Peter; /* define here devices that you 'know', thus should * be ignored */ var known_devices=[ "AA:BB:CC:DD:EE:FF", "AA:BB:CC:DD:EE:FF", "AA:BB:CC:DD:EE:FF"]; /* Enum list of all combinations of users+guest */ var enum_list = []; enum_list[0] = "Nobody"; enum_list[1] = "Klaus"; enum_list[2] = "Hans"; enum_list[3] = "Peter"; enum_list[4] = "Klaus,Hans,Peter"; enum_list[5] = "Guest"; enum_list[6] = "Klaus,Hans,Peter,Guest"; enum_list[7] = "Hans,Guest"; enum_list[8] = "Klaus,Hans,Peter,Guest"; enum_list[9] = "Peter,Guest"; enum_list[10] = "Klaus,Hans,Peter,Guest"; /* Path to system variables on CCU */ var sysvar_prefix= "Anwesenheit"; var sysvar_user = "hm-rega.0.14029"/*Anwesenheit.Nutzer*/; var sysvar_guest = "hm-rega.0.14030"/*Anwesenheit.Gast*/; var sysvar_str = "hm-rega.0.14032"/*Anwesenheit.string*/; var sysvar_list = "hm-rega.0.20454"/*Anwesenheit.list*/;
Wie muss die list Variable auf der CCu aussehen?
Dann wird mir immer der Gast mit angezeigt obwohl ich kein Gastnetzwerk eingerichtet habe.
Was mache ich denn verkehrt?
-
Kann es sein, das Dir die beiden Zeilen
enum_list[3] = "Peter"; enum_list[3] = "Klaus,Hans,Peter";
in die Quere kommen?
Du hast erst nur „Peter“ an die 4. Stelle der Liste und dann nochmal „Klaus,Hans,Peter“.
Somit müsste dann immer „Klaus,Hans,Peter“ kommen, auch wenn nur Peter da ist.
Gruß,
Eric
Von unterwegs getippert
-
Ups da hatte ich einen Fehler. Habe noch eine dritte Person hinzugefügt für diese Frage.
Hatte nur zwei angelegt mit denen es aber nicht wie gewünscht funktioniert.
dachte mir lieber gleich 3 machen bevor wir das hier mit zwei klären und ich dann die nächste Frage stellen muss.
-
Klappt es denn jetzt wie gewünscht?
Gruß,
Eric
Von unterwegs getippert
-
Nein. Mir wird immer der Gast mit angezeigt.
Und in der Wertevariable list auf der CCu, da weiss ich nicht was ich da bei der Wertebezeichnung eintragen soll?
-
Da bin ich erst mal raus, da ich das Script nicht einsetzte für die Anwesenheitserkennung.
Gruß,
Eric
Von unterwegs getippert
-
Hallo,
ich bekam immer einen oder mehrere Gast/Gäste angezeigt, solange ich nicht alle Geräte (Mac-Adressen) unter "Knowing device" eingetragen hatte.
Gruß
Rolf
-
Ja das war ein super Tipp. Damit konnte ich meinen Gast schon eliminieren.
Ich habe bei mir die Variable Anwesenheit_Wlan (global presence @ home) auf der CCU angelegt.
Ist es möglich das ich die schalten kann?
/* Path to system variables on CCU */ var sysvar_prefix= "Anwesenheit_Wlan";
Ich habe die anderen Variablen der prefix Bezeichnung angepasst und da funktioniert das gut.
also Anwesenheit_Nutzer usw.
-
Ob der Pi für iobroker und UniFi-Controller ausreicht, wage ich zu bezweifeln. Er hat ganz schön was zu tun (Statistiken, usw.).
Wenn ich am Sonntag aus dem Urlaub zurück bin, schaue ich mir die Systemlast meines Controllers mal an.
Gruß,
Eric
Von unterwegs getippert `
Hast du mal getestet was der unifi controller so an Systemlast macht?Habe mir dazu gar keine Gedanken gemacht und erstmal nichts festgestellt, außer RAM-Verbrauch.
Bei mir läuft der unifi-controller mit auf dem brix wo auch ioBroker läuft.
-
Hallo,
ich nutze den Controller auf einem separaten Server. Keine Probleme mit der Last.
Das Skript funktioniert und liefert die richtigen Namen. Nutze nur keine CCU, sondern ioBroker als Ziel.
Allerdings bekomme ich täglich um 0200 eine Fehlermeldung und die jS-Adapterinstanz startet neu. Habt ihr das auch?
Kann leider das log nicht hier posten, da von unterwegs in Tapatalk getippt.
Pix
-
Ich habe mich mal an einer Anwesenheitsmeldung/Erkennung mit Blockly probiert und dafuer den last_seen state genommen. Allerdings nicht die Unixzeit daraus sondern nur als Trigger.
Ist das so in Ordnung oder ist der Ansatz aus irgendwelchen Gruenden sch…? Es scheint soweit zu funktionieren.
3803_chrome_2017-10-18_15-09-59.png -
Weil ich selber APs von Unifi einsetze interessiert mich der Adapter sehr. Erst einmal ein großes Lob für die Arbeit. Gibte es auch einen Screen wo man eine Visualisierung im VIS sehen kann?
Ich stelle mir eine Übersicht aller SSID inklusive der gerade angemeldeten Geräte vor. Wäre so etwas umsetzbar?
-
Hallo,
@pix:Hallo,
Allerdings bekomme ich täglich um 0200 eine Fehlermeldung und die jS-Adapterinstanz startet neu. Habt ihr das auch?
Kann leider das log nicht hier posten, da von unterwegs in Tapatalk getippt.
Pix `
ich zitiere mich selbst und hole das Thema erneut hoch:
Habe Punkt 0200 jede Nacht diesen Fehler im Log:
`2017-10-30 02:00:03.774 - [31merror[39m: unifi.0 uncaught exception: Cannot read property 'map' of undefined 2017-10-30 02:00:03.782 - [31merror[39m: unifi.0 TypeError: Cannot read property 'map' of undefined 2017-10-30 02:00:03.855 - [31merror[39m: Caught by controller[0]: [TypeError: Cannot read property 'map' of undefined] 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[1]: 2017-10-30 02:00:03.775 - unifi.0 uncaught exception: Cannot read property 'map' of undefined 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: 2017-10-30 02:00:03.782 - unifi.0 TypeError: Cannot read property 'map' of undefined 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at /Users/pix/Documents/iobroker/node_modules/iobroker.unifi/main.js:471:28 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at /Users/pix/Documents/iobroker/node_modules/node-unifi/unifi.js:1411:13 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at /Users/pix/Documents/iobroker/node_modules/node-unifi/node_modules/async/dist/async.js:906:16 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at next (/Users/pix/Documents/iobroker/node_modules/node-unifi/node_modules/async/dist/async.js:5198:18) 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at Request._callback (/Users/pix/Documents/iobroker/node_modules/node-unifi/unifi.js:1399:27) 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at Request.self.callback (/Users/pix/Documents/iobroker/node_modules/request/request.js:188:22) 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at emitTwo (events.js:87:13) 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at Request.emit (events.js:172:7) 2017-10-30 02:00:03.856 - [31merror[39m: Caught by controller[2]: at Request. <anonymous>(/Users/pix/Documents/iobroker/node_modules/request/request.js:1171:10) 2017-10-30 02:00:03.857 - [31merror[39m: Caught by controller[2]: at emitOne (events.js:77:13) 2017-10-30 02:00:03.857 - [31merror[39m: Caught by controller[2]: at Request.emit (events.js:169:7) 2017-10-30 02:00:03.857 - [31merror[39m: host.MacMini.local instance system.adapter.unifi.0 terminated with code 0 (OK)[/code]</anonymous>` Woher kann das kommen? Der Controller wird doch standardmäßig nicht neugestartet. Ebenso nicht die Hotspots, oder? Gruß Pix
-
Ich hab ähnliches Problem.
host.orangepiplus2e 2017-11-03 07:53:54.537 error instance system.adapter.unifi.0 terminated with code 0 (OK) Caught 2017-11-03 07:53:54.537 error by controller[1]: at emitOne (events.js:101:20) Caught 2017-11-03 07:53:54.536 error by controller[1]: at TLSSocket.socketCloseListener (_http_client.js:286:9) Caught 2017-11-03 07:53:54.536 error by controller[1]: at ClientRequest.emit (events.js:188:7) Caught 2017-11-03 07:53:54.536 error by controller[1]: at emitOne (events.js:96:13) Caught 2017-11-03 07:53:54.535 error by controller[1]: at Request.onRequestError (/opt/iobroker/node_modules/request/request.js:884:8) Caught 2017-11-03 07:53:54.535 error by controller[1]: at Request.emit (events.js:188:7) Caught 2017-11-03 07:53:54.535 error by controller[1]: at emitOne (events.js:101:20) Caught 2017-11-03 07:53:54.534 error by controller[1]: at Request. (/opt/iobroker/node_modules/iobroker.unifi/node_modules/node-unifi/unifi.js:1099:11) Caught 2017-11-03 07:53:54.534 error by controller[1]: at next (/opt/iobroker/node_modules/iobroker.unifi/node_modules/node-unifi/node_modules/async/dist/async.js:5171:25) Caught 2017-11-03 07:53:54.534 error by controller[1]: at /opt/iobroker/node_modules/iobroker.unifi/node_modules/node-unifi/node_modules/async/dist/async.js:903:32 Caught 2017-11-03 07:53:54.533 error by controller[1]: Error: Callback was already called. Caught 2017-11-03 07:53:54.533 error by controller[0]: at emitOne (events.js:96:13) Caught 2017-11-03 07:53:54.533 error by controller[0]: at TLSSocket.socketErrorListener (_http_client.js:310:9) Caught 2017-11-03 07:53:54.532 error by controller[0]: at ClientRequest.emit (events.js:188:7) Caught 2017-11-03 07:53:54.532 error by controller[0]: at emitOne (events.js:96:13) Caught 2017-11-03 07:53:54.532 error by controller[0]: at Request.onRequestError (/opt/iobroker/node_modules/request/request.js:884:8) Caught 2017-11-03 07:53:54.531 error by controller[0]: at Request.emit (events.js:188:7) Caught 2017-11-03 07:53:54.531 error by controller[0]: at emitOne (events.js:101:20) Caught 2017-11-03 07:53:54.531 error by controller[0]: at Request. (/opt/iobroker/node_modules/iobroker.unifi/node_modules/node-unifi/unifi.js:1099:11) Caught 2017-11-03 07:53:54.530 error by controller[0]: at next (/opt/iobroker/node_modules/iobroker.unifi/node_modules/node-unifi/node_modules/async/dist/async.js:5171:25) Caught 2017-11-03 07:53:54.527 error by controller[0]: at /opt/iobroker/node_modules/iobroker.unifi/node_modules/node-unifi/node_modules/async/dist/async.js:903:32 Caught 2017-11-03 07:53:54.512 error by controller[0]: Error: Callback was already called.
-
Hi,
ich möchte auch gerne die An-Abwesenheits steuerung über den Unifi Adapter machen.
Installiert ist alles und die Daten kommen beim IOBroker an.
Nun möchte ich den last_seen Zeitstempel nutzen und wenn dieser upgedatet wird, dann bin ich anwesend und wenn nicht, dann abwesend.
Variable auf der CCU2 ist angelegt, wir aber leider nicht gefüllt
Ich bekomme das in Blockly irgendwie nicht hin…
Kann mir da bitte jemand unter die Arme greifen..
4009_bildschirmfoto_2017-11-10_um_13.21.16.png