NEWS
[Major Update] UniFi Adapter v0.5.0
-
@liv-in-sky sagte in [Major Update] UniFi Adapter v0.5.0:
habe keinen switch zum testen - aber evtl ist das was für dich
Ich habe mir das mal angeschaut.
Es funktioniert soweit wenn ich per ssh im IOBroker dieses Scriptmit
./cam_aus_an <IP-SWITCH> on 20 oder ./cam_aus_an <IP-SWITCH> off 20
starte.
Aber wie führe ich diese dann im IOBroker aus? Möchte gerne per VIS die Kameras an-/ausschalten.
Ich habe es mit sshexec versucht, da ich damit schon meine Synologys herunter fahre. Das mit den Synologys funktioniert auch soweit.
var SSH = require('simple-ssh'); var ssh = new SSH({ host: 'IP Synology', port: 22, user: 'synologyuser', pass: 'synologypass' }); setStateDelayed("javascript.0.scriptEnabled.Controlling.An-Aus.NAS1-Shutdown"/*javascript.0.scriptEnabled.Controlling.An-Aus.NAS1-Shutdown*/, false, 5000, false); sendTo("telegram.0", "send", { text: 'NAS aus', user: 'Frank' }); ssh.exec('echo "synologypass"|sudo -S shutdown -h now').start();
Das ganze habe ich nun so mit den Kameras versucht.
var SSH = require('simple-ssh'); var ssh = new SSH({ host: 'IP IOBroker', port: 22, user: 'iobrokeruser', pass: 'iobrokerpass' }); sendTo("telegram.0", "send", { text: 'Kameras aus', user: 'Frank' }); ssh.exec('echo "iobrokerpass"|sudo ./opt/iobroker/iobroker-data/scripte_ssh/cam_aus_an 192.168.222.2 off 20').start();
Die Telegram Meldung kommt auch an, aber der Port wird nicht geschaltet.
Ich habe es auch versucht ohne das große Script oben mit
ssh admin@IP-Switch '(echo "enable" ; echo "configure" ; echo "interface 0/8" ; echo "poe opmode auto" ; echo "exit" ; echo "exit"; echo "exit" ) | telnet localhost 23 ; exit;'
Funktioniert direkt per ssh im IOBroker auch. Nur nicht aus Javascript heraus.
Jemand eine Idee wo mein Denkfehler ist? -
@maniac habe dir eine chatnachricht gesendet
was ich noch nicht ganz verstehe : das funktionierende bash script liegt auf dem iobroker server - damit du das aufrufen kannst, braucht es eigentlich nur einen exec() befehl -am besten mal testen ob der exec - allein funktioniert - evtl gibt es da noch rechte themen aber prinzipiell sollte es so laufen - das bashscript baut ja die ssh verbindung auf - daher brauchen wir nur dieses script mit exec() aufrufen
dann legst du dir einen eigenen datenpunkt an - logic - der in der vis zur verfügung gestellt wird
object id in diesem blockly musst du mit deinem eigenen datenpunkt "füttern"
das ganze sollte funktionieren, wenn du eine console auf iobroker öffnest und dort in die console
./cam_aus_an <IP-SWITCH> on 20 oder ./cam_aus_an <IP-SWITCH> off 20
einen der beiden befehle ausführen kannst - wenn das funktioniert, sollte der exec befehl im blockly funktionieren
-
Funktioniert nicht. Bekomme im IOBroker Terminal Adapter den Fehler.
-
hast du wie hier beschrieben, https://nerdig.es/usw-poe-per-script-steuern/ , dass mit dem ssh-key gemacht ? irgendwie ist der key nicht bekannt. wir haben kein homeassistant sonder iobroker - sollte aber theoretisch genau so funktionieren
das bashscript muss natürlich in der iobroker console ausführbar sein
das hier muss als iobroker user im terminal ausgeführt werden - es gibt einen terminal adapter für iobroker- das terminal kannst du dann über den admin aufrufen und darin das beschriebene vorgehen ausprobieren
-
@maniac sagte in [Major Update] UniFi Adapter v0.5.0:
Moin zusammen.
Ich nutze den Adapter schon eine Weile um meine WLANs per VIS ein-/auszuschalten. Das geht ja über den DP:
unifi.0.default.wlans.NAMEWLAN.enabled
und funktioniert einwandfrei bisher.
Ich habe mir gerade ein Gäste WLAN erstellt. Sobald ich dieses deaktiviere wird auch mein normales WLAN abgeschaltet und es dauert etwas bis dieses wieder verfügbar ist.
Hast du auch dieses Verhalten? -
https://forum.iobroker.net/post/493077
ich denke, daher arbeitet man bei unifi mit den vouchers - da muss nix neugestartet werden
-
@liv-in-sky Danke für den Link. Da hab ich wohl zu schnell über die nachfolgenden Beiträge drüber gelesen.
Ja das mit den Vouchers ist dann auch mein Plan B. -
@liv-in-sky sagte in [Major Update] UniFi Adapter v0.5.0:
hast du wie hier beschrieben, https://nerdig.es/usw-poe-per-script-steuern/ , dass mit dem ssh-key gemacht ? irgendwie ist der key nicht bekannt. wir haben kein homeassistant sonder iobroker - sollte aber theoretisch genau so funktionieren
Ja, habe ich direkt per ssh auf dem iobroker gemacht. Mit welchem Nutzer muss das denn gemacht werden?
Ich habe es mit meinem Anmeldenamen gemacht.das bashscript muss natürlich in der iobroker console ausführbar sein
das hier muss als iobroker user im terminal ausgeführt werden - es gibt einen terminal adapter für iobroker- das terminal kannst du dann über den admin aufrufen und darin das beschriebene vorgehen ausprobieren
Da bekomme ich nur
-
@Feuersturm sagte in [Major Update] UniFi Adapter v0.5.0:
Ich habe mir gerade ein Gäste WLAN erstellt. Sobald ich dieses deaktiviere wird auch mein normales WLAN abgeschaltet und es dauert etwas bis dieses wieder verfügbar ist.
Hast du auch dieses Verhalten?Ja, das ist dummerweise ein normales Verhalten bei Unifi.
-
@maniac sudo -u iobroker ssh ....
-
@liv-in-sky sagte in [Major Update] UniFi Adapter v0.5.0:
@maniac sudo -u iobroker ssh ....
Ja, na klar.
Aber so ganz richtig verhält sich das Terminal nicht. Hat etwas gedauert bis der Key erstellt wurde, da manchmal keine Ausgabe erfolgte, bzw. nachdem ich den cam Befehl eingegeben hatte kam nochmal das mit der passphrase.
Den Key habe ich jetzt aber im Controller drin, aber trotzdem geht es nicht.
-
Kann ich mich irgendwie als user iobroker am System anmelden? Also direkt per ssh am IOBroker Server?
mit su iobroker geht es nicht.
Das würde das probieren etwas einfacher machen. -
@maniac deshalb den terminal adapter - das nutzt den iobrker user - sonst geht das nicht, weil iobroker als service user genutzt wird und wir kein passwort dafür haben
-
@liv-in-sky sagte in [Major Update] UniFi Adapter v0.5.0:
@maniac deshalb den terminal adapter - das nutzt den iobrker user - sonst geht das nicht, weil iobroker als service user genutzt wird und wir kein passwort dafür haben
Das funktioniert aber leider nicht so richtig.
Wenn ich den Key erstelle, kommt mal die Frage wohin, mal nicht. Dann kommt einmal Passwortvergabe, manchmal auch nicht. Die zweite Kontrollpasswortvergabe kommt gar nicht anscheinend.
Wenn ich den Befehl 4-5 Mal in die Konsole eingebe, kommt plötzlich die zweite Passwortbestätigung und dann manchmal auch die Meldung Key wurde erstellt. Da muss was schiefgehen.
-
sorry ich bin mit diesen key sachen auch nicht so sicher - hatte meist mit passwort gearbeitet - dazu müßten wir das bashscript ändern - was wenig sinn macht - leider kann ich das ganze auch nicht nachstellen bei mir
ich kann dir nur anbieten am WE oder heute spätnachmittag mal zusammen darauf zu schauen , würden wir schon irgendwie mit google hinbekommen
evtl muss man sich den iobroker user im switch einrichten und das ganze dann anstatt mit admin@... mit iobroker@... machen - müßte man ausprobieren
-
Danke für das Angebot, würde ich gerne machen, bin aber am WE jetzt unterwegs.
Ich würde evtl. später nochmal darauf zurückkommen wenn es dann noch nicht läuft.Ich habe jetzt jedenfalls nochmal per Snapshot beide Systeme zurück gesetzt und komplett neu gemacht.
Den Key - wieder mit den Problemen- im Web Terminal erstellt, der liegt direkt unter opt/iobroker. Kann das richtig sein?
Geht noch nicht. Ich gebe noch nicht auf...
-
Ich habe gerade einmal die Zugriffssteuerung für mein Gäste W-Lan über Vouchers aktiviert und konnt den Zugriffscode über die Webmaske auch erfolgreich generieren und auf meinem Handy verwenden.
Wenn ich in der ioBroker Adminoberfläche für die Objekte den Button für den Datenpunkt unifi.0.default.vouchers.create_vouchers betätige bekomme ich folgenden Fehler im Log:unifi.0 2020-09-25 22:37:29.880 error at Request.emit (events.js:315:20) unifi.0 2020-09-25 22:37:29.880 error at Request.<anonymous> (/opt/iobroker/node_modules/request/request.js:1154:10) unifi.0 2020-09-25 22:37:29.880 error at Request.EventEmitter.emit (domain.js:483:12) unifi.0 2020-09-25 22:37:29.880 error at Request.emit (events.js:315:20) unifi.0 2020-09-25 22:37:29.880 error at Request.self.callback (/opt/iobroker/node_modules/request/request.js:185:22) unifi.0 2020-09-25 22:37:29.880 error at Request._callback (/opt/iobroker/node_modules/node-unifi/unifi.js:2844:13) unifi.0 2020-09-25 22:37:29.880 error at next (/opt/iobroker/node_modules/node-unifi/node_modules/async/dist/async.js:4450:29) unifi.0 2020-09-25 22:37:29.880 error at /opt/iobroker/node_modules/node-unifi/node_modules/async/dist/async.js:321:20 unifi.0 2020-09-25 22:37:29.880 error at /opt/iobroker/node_modules/node-unifi/unifi.js:2858:11 unifi.0 2020-09-25 22:37:29.880 error at cb (/opt/iobroker/node_modules/iobroker.unifi/main.js:1111:28) unifi.0 2020-09-25 22:37:29.880 error (26712) error: api.err.IncorrectNumberRange, stack: Error: api.err.IncorrectNumberRange
Ich verwende die folgenden Versionen:
Unifi Controller: 5.13.32 (Build: atag_5.13.32_13646)
Unifi Adapter: 5.0.8Muss ich noch irgendwas besonderes im Unifi Controller einstellen, damit die Codes erzeugt werden können?
In ioBroker sehen in der Unifi Instanz die Einstellungen wie folgt aus:
-
@liv-in-sky sagte in [Major Update] UniFi Adapter v0.5.0:
@maniac habe dir eine chatnachricht gesendet
das ganze sollte funktionieren, wenn du eine console auf iobroker öffnest und dort in die console
./cam_aus_an <IP-SWITCH> on 20 oder ./cam_aus_an <IP-SWITCH> off 20
einen der beiden befehle ausführen kannst - wenn das funktioniert, sollte der exec befehl im blockly funktionieren
Ich bin einen Schritt weiter.
Im Terminal Adapter kann ich das Script nun starten und der Port wird geschaltet.Der entscheidende Hinweis kommt von hier
Im speziellen habe ich das Script temporär angepasst, indem ich den Aufruf mit diesem Code erweitert habe.
ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no adminuser@xxx.xxx.xxx.xxx
Die ganze Zeile sah dann so aus.
ssh -o UserKnownHostsFile=/dev/null -o StrictHostKeyChecking=no admin@$1 '(echo "enable" ; echo "configure" ; echo "interface 0/'$3'" ; echo "poe opmode auto" ; echo "exit" ; echo "exit"; echo "exit" ) |
Danach wurde auch die KnownHosts Datei im /home/iobroker/.ssh angelegt.
Dann habe ich das Script wieder in den Ursprungszustand zurück gesetzt und nun funktioniert es im Terminal Adapter.Wenn ich allerdings das Blockly triggere, bekomme ich im Log einen Fehler.
Im Javascript Adapter habe ich das "exec" erlaubt.28.9.2020, 10:25:00.126 [error]: javascript.0 (1090) script.js.Kameras.Bewegung: exec: sudo bash /opt/iobroker/cam.sh 192.168.222.2 off 20
Passt hier der Aufruf im Blockly noch nicht?
sudo bash /opt/iobroker/cam.sh 192.168.222.2 off 20
-
@maniac - klasse, dass du schon weiter bist
WICHTIGER HINWEIS https://forum.iobroker.net/post/496428 - bessere Lösung - nicht "bash" frei geben sondern pfad zum script selbst
spontan : kontrolliere mal das sudoers file
nano /etc/sudoers.d/iobroker
da steht kein bash drin - daher ein eigenes file anlegen - bei mir
vielleicht ist damit was zu machen
du kannst auch versuchen das log im exec-blockly zu aktivieren - vielleicht steht da mehr
und der klassiker - im setting des javascriptadapters muss exec ausführen erlaubt sein
WICHTIGER HINWEIS https://forum.iobroker.net/post/496428 - bessere Lösung
-
@maniac
ach ja
hatte gestern erst etwas gemacht - da brauchte ich bash garnicht - siehe post darüber - das blockly