NEWS
Unifi Steuern ohne Adapter (Script,SSH)
-
bei mir sieht das so aus
javascript.0 2024-06-02 07:30:18.729 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Logout erfolgreich. javascript.0 2024-06-02 07:30:18.680 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Logout bei UniFi... javascript.0 2024-06-02 07:30:18.680 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Neuester Voucher: [{"duration":12223,"qos_overwrite":false,"note":"newne222wnew","code":"3709308106","for_hotspot":false,"create_time":1717306218,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"665c036aa29b27114a1acdf3","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":123,"qos_overwrite":false,"note":"testthis","code":"8764054636","for_hotspot":false,"create_time":1717306218,"quota":0,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"665c036aa29b27114a1acdf1","admin_name":"e","used":0,"status":"VALID_MULTI","status_expires":0}] javascript.0 2024-06-02 07:30:18.652 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Hole den neuesten Voucher... javascript.0 2024-06-02 07:30:18.652 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Voucher erstellt: [{"create_time":1717306218}] javascript.0 2024-06-02 07:30:18.630 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Trigger aktiviert, erstelle neuen Voucher... javascript.0 2024-06-02 07:30:18.630 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Login erfolgreich: true javascript.0 2024-06-02 07:30:18.288 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Versuche, mich bei UniFi anzumelden... javascript.0 2024-06-02 07:30:18.288 info script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten-draexler: Trigger-Datenpunkt geändert: true
-
@adnim schon mal die javascript instanz neugestartet
-
ja habe ich und auch die info gesehen das "node-unifi" installiert wird.
javascript.0 2024-06-02 08:16:31.172 error script.js.common.unifivoucher: ERROR: TypeError: Cannot read properties of undefined (reading '0') javascript.0 2024-06-02 08:16:31.172 error script.js.common.unifivoucher: Fehler beim Logout: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-02 08:16:31.149 error script.js.common.unifivoucher: ERROR: Error: getaddrinfo ENOTFOUND unifi admin.0 2024-06-02 08:16:22.436 info <== Disconnect system.user.admin from 192.165.175.19 javascript javascript.0 2024-06-02 08:16:17.914 info script.js.common.unifivoucher: registered 1 subscription, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
-
@adnim poste mal dein script
-
@adnim ohne login daten
-
// V0.1 initialer release // V0.2 Fixed Login/Logout, THX to liv-in-sky. Changed Log output // V0.3 moved logout, THX to liv-in-sky. const Unifi = require('node-unifi'); // Konfiguration const config = { hostname: "192.165.175.201", port: '8443', // 443 UDM Pro, 8443 für andere Controller username: 'hotspot-manager', password: 'xxxx', sslverify: false }; // Erstelle die benötigten Datenpunkte für die Voucher-Konfiguration createState("0_userdata.0.Unifi.Voucher.config.minutes", 123, { type: 'number', name: 'minutes', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.config.count", 1, { type: 'number', name: 'count', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.config.quota", 0, { type: 'number', name: 'quota', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.config.note", "testthis", { type: 'string', name: 'note', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.config.up", null, { type: 'number', name: 'up', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.config.down", null, { type: 'number', name: 'down', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.config.megabytes", null, { type: 'number', name: 'megabytes', read: true, write: true }); // Erstelle die benötigten Datenpunkte für die Voucher-Daten createState("0_userdata.0.Unifi.Voucher.data.latestJson", "{}", { type: 'string', name: 'latestJson', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.code", "", { type: 'string', name: 'code', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.duration", 0, { type: 'number', name: 'duration', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.qos_overwrite", false, { type: 'boolean', name: 'qos_overwrite', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.note", "", { type: 'string', name: 'note', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.for_hotspot", false, { type: 'boolean', name: 'for_hotspot', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.create_time", 0, { type: 'number', name: 'create_time', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.quota", 0, { type: 'number', name: 'quota', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.site_id", "", { type: 'string', name: 'site_id', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.admin_name", "", { type: 'string', name: 'admin_name', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.used", 0, { type: 'number', name: 'used', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.status", "", { type: 'string', name: 'status', read: true, write: true }); createState("0_userdata.0.Unifi.Voucher.data.status_expires", 0, { type: 'number', name: 'status_expires', read: true, write: true }); // Erstelle den Datenpunkt für den Trigger createState("0_userdata.0.Unifi.Voucher.trigger", false, { type: 'boolean', name: 'trigger', read: true, write: true }); let lastVoucherCreateTime = 0; // Speichert die create_time des letzten erstellten Vouchers // Reagiere auf Änderungen des Datenpunkts "trigger" on({ id: '0_userdata.0.Unifi.Voucher.trigger', change: 'ne', val: true }, async (obj) => { console.debug('Trigger-Datenpunkt geändert: ' + obj.state.val); console.debug('Versuche, mich bei UniFi anzumelden...'); const unifi = new Unifi.Controller({ hostname: config.hostname, port: config.port, sslverify: config.sslverify }); await unifi.login(config.username, config.password) .then(loginData => { console.debug('Login erfolgreich: ' + JSON.stringify(loginData)); }) .catch(error => { console.error('ERROR: ' + error); }); try { // Lese die Konfigurationswerte aus den Datenpunkten const minutes = getState("0_userdata.0.Unifi.Voucher.config.minutes").val; const count = getState("0_userdata.0.Unifi.Voucher.config.count").val; const quota = getState("0_userdata.0.Unifi.Voucher.config.quota").val; const note = getState("0_userdata.0.Unifi.Voucher.config.note").val; const up = getState("0_userdata.0.Unifi.Voucher.config.up").val; const down = getState("0_userdata.0.Unifi.Voucher.config.down").val; const megabytes = getState("0_userdata.0.Unifi.Voucher.config.megabytes").val; // Erzeuge einen neuen Voucher console.debug('Trigger aktiviert, erstelle neuen Voucher...'); const clientVoucher = await unifi.createVouchers( minutes, count, quota, note, up, down, megabytes ).catch(async error => { console.debug('Fehler beim Anlegen: ' + error); console.debug('Logout bei UniFi...'); await unifi.logout().then(() => { console.debug('Logout erfolgreich.'); }).catch(error => { console.error('Fehler beim Logout: ' + error); }); setState('0_userdata.0.Unifi.Voucher.trigger', false); }); console.debug('Voucher erstellt: ' + JSON.stringify(clientVoucher)); // Erfasse die create_time des erstellten Vouchers const newVoucherCreateTime = clientVoucher[0].create_time; // Hole nur den neuesten Voucher basierend auf create_time console.debug('Hole den neuesten Voucher...'); const myVoucher = await unifi.getVouchers(newVoucherCreateTime); console.debug("Neuester Voucher: " + JSON.stringify(myVoucher)); console.debug('Logout bei UniFi...'); await unifi.logout().then(() => { console.debug('Logout erfolgreich.'); }).catch(error => { console.error('Fehler beim Logout: ' + error); }); // Schreibe die Voucher-Daten in den Datenpunkt "latestJson" console.debug('Schreibe Voucher-Daten in den Datenpunkt "latestJson"...'); setState('0_userdata.0.Unifi.Voucher.data.latestJson', JSON.stringify(myVoucher)); // Extrahiere die Werte aus dem Voucher-Objekt und setze die Datenpunkte const voucher = myVoucher[0]; setState('0_userdata.0.Unifi.Voucher.data.code', voucher.code); setState('0_userdata.0.Unifi.Voucher.data.duration', voucher.duration); setState('0_userdata.0.Unifi.Voucher.data.qos_overwrite', voucher.qos_overwrite); setState('0_userdata.0.Unifi.Voucher.data.note', voucher.note); setState('0_userdata.0.Unifi.Voucher.data.for_hotspot', voucher.for_hotspot); setState('0_userdata.0.Unifi.Voucher.data.create_time', voucher.create_time); setState('0_userdata.0.Unifi.Voucher.data.quota', voucher.quota); setState('0_userdata.0.Unifi.Voucher.data.site_id', voucher.site_id); setState('0_userdata.0.Unifi.Voucher.data.admin_name', voucher.admin_name); setState('0_userdata.0.Unifi.Voucher.data.used', voucher.used); setState('0_userdata.0.Unifi.Voucher.data.status', voucher.status); setState('0_userdata.0.Unifi.Voucher.data.status_expires', voucher.status_expires); // Setze den Trigger wieder auf false console.debug('Setze den Trigger wieder auf false...'); setState('0_userdata.0.Unifi.Voucher.trigger', false); } catch (error) { console.error('ERROR: ' + error); } });
ist hier irgendwo noch ein Unifi- unifi Typo drin?
-
@adnim wäre es ein problem, mal den iob server neuzustarten
ich möchte sicherstellen, das absolut keine alten programmteile irgendwo im system sind
es kommt ja nicht in den trigger - wann kommt der fehler ? beim speichern des scriptes oder beim ersten trigger
-
@liv-in-sky
Kommt bei manueller Änderung des Triggers.Habe die VM gerade neu gestartet, gleiche Fehlermeldung.
Bei mir ist die Aktuelle Beta des JS Controllers drauf evtl. liegts daran, ein Downgrade kann ich aber erst später versuchen
-
@adnim habe ich auch 5.0.19 und auch node 20
irgendwie kann ich bei diesen fehlern nicht richtig nachvollziehen, an welcher stelle das script aussteigt - wenn getriggert wird, ist ja erstmal ein log - das kommt garnicht ?
dann müßte es ja schon vorher was passieren - hast du node-unifi im setting der javascript instanz drin ?
-
kannst du mal dieses kleine script testen
const Unifi = require('node-unifi'); const unifi22 = new Unifi.Controller({hostname:"192.168.168.xxx",port:'8443', sslverify: false}); async function main() { try { // LOGIN const loginData = await unifi22 .login('x', 'xxxxxx'); console.log('login: ' + loginData); const myVouchers = await unifi22 .getVouchers(); console.log("vouchers: "+ JSON.stringify(myVouchers)) // LOGOUT const logoutData = await unifi22 .logout(); console.log('logout: ' + JSON.stringify(logoutData)); } catch (error) { console.log('ERROR: ' + error); } } main();
zeile 3 und 8 anpassen
-
@liv-in-sky sagte in Adapter: ioBroker.unifi:
hast du node-unifi im setting der javascript instanz drin ?
@Adnim ich frage, da es irgenein thema gab mit älteren javascript adaptern - ich habe die neuste latest (8.4.2) installiert, ansonsten konnte ich es nicht eingeben in der instanz
-
@liv-in-sky sagte in Adapter: ioBroker.unifi:
@adnim habe ich auch 5.0.19 und auch node 20
ja genauso ist es hier auch
irgendwie kann ich bei diesen fehlern nicht richtig nachvollziehen, an welcher stelle das script aussteigt - wenn getriggert wird, ist ja erstmal ein log - das kommt garnicht ?
nee mehr kommt nicht
dann müßte es ja schon vorher was passieren - hast du node-unifi im setting der javascript instanz drin ?
ja , mache es mal raus und wieder rein
mit dem kleinen skript sieht das so aus im log
javascript.0 2024-06-02 08:54:51.441 info Stopping script script.js.common.unifitest javascript.0 2024-06-02 08:54:45.918 info script.js.common.unifitest: ERROR: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-02 08:54:45.915 info script.js.common.unifitest: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions javascript.0 2024-06-02 08:54:45.897 info Start JavaScript script.js.common.unifitest (Javascript/js)
edit: nee auch node-unifi raus und Instanz speichern Neu starten und wieder rein machen ändert bei beiden Skripten nichts
-
@liv-in-sky sagte in Adapter: ioBroker.unifi:
@Adnim ich frage, da es irgenein thema gab mit älteren javascript adaptern - ich habe die neuste latest (8.4.2) installiert, ansonsten konnte ich es nicht eingeben in der instanz
Version 8.4.2 node: v20.14.0, js-controller: 5.0.19
-
@adnim schaut echt nach einem problem mit der node-unifi aus - kannst du sie im filesystem finden bzw mal iob stop, iob fix aufrufen
scheint vom adapter zu kommen /opt/iobroker/node-modules/node-unifi
müßte zusatzmodul sein : /opt/iobroker/node-modules/iobroker.javascript/node-unifi -
könntest du uns evtl helfen - wir versuchen einer verbindung zum unifi-controller herzustellen - bei mir gibt das kein problem - 2 user haben aber eines
node-unifi ist als zusätzliches module drin (obwohl auch der unifi adapter das modul installiert hatdieses script soll laufen: https://forum.iobroker.net/post/1165996
const Unifi = require('node-unifi'); const unifi22 = new Unifi.Controller({hostname:"192.168.168.xxx",port:'8443', sslverify: false}); async function main() { try { // LOGIN const loginData = await unifi22 .login('x', 'xxxxxx'); console.log('login: ' + loginData); const myVouchers = await unifi22 .getVouchers(); console.log("vouchers: "+ JSON.stringify(myVouchers)) // LOGOUT const logoutData = await unifi22 .logout(); console.log('logout: ' + JSON.stringify(logoutData)); } catch (error) { console.log('ERROR: ' + error); } } main();
hier der fehler - mit dem ich einfach nix anfangen kann https://forum.iobroker.net/post/1166000
javascript.0 2024-06-02 08:54:51.441 info Stopping script script.js.common.unifitest javascript.0 2024-06-02 08:54:45.918 info script.js.common.unifitest: ERROR: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-02 08:54:45.915 info script.js.common.unifitest: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions javascript.0 2024-06-02 08:54:45.897 info Start JavaScript script.js.common.unifitest (Javascript/js)
der fehler kommt, wenn man den trigger setzt - aber das erste log im trigger kommt schon nicht - irgendeine idee ?
-
@liv-in-sky
ja das Modul ist im File System zu sehen. Den fixer hab ich mal laufen lassen ändert aber nichts an den Fehlermeldungen. -
@liv-in-sky Kann ich mir frühestens morgen Vormittag ansehen
-
ich hatte das script die log meldungen auf debug gestellt. wenn die kommen sollen den js adapter auf debug stellen. Man könnte ja die letzte nehmen wenn es mit i.O durchgelaufen ist als info aber mir waren es so zu viele.
Wifi Operator ist die Admin Rolle im Unifi User Managment.
Dazu habe ich mal die Readme angepasst. -
@kmxak sagte in Adapter: ioBroker.unifi:
ch hatte das script die log meldungen auf debug gestellt. wenn die kommen sollen den js adapter auf debug stellen.
javascript.0 2024-06-02 09:47:45.323 error script.js.common.unifivoucher: ERROR: TypeError: Cannot read properties of undefined (reading '0') javascript.0 2024-06-02 09:47:45.323 debug script.js.common.unifivoucher: Voucher erstellt: undefined javascript.0 2024-06-02 09:47:45.323 error script.js.common.unifivoucher: Fehler beim Logout: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-02 09:47:45.316 debug script.js.common.unifivoucher: Logout bei UniFi... javascript.0 2024-06-02 09:47:45.316 debug script.js.common.unifivoucher: Fehler beim Anlegen: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-02 09:47:45.303 debug script.js.common.unifivoucher: Trigger aktiviert, erstelle neuen Voucher... javascript.0 2024-06-02 09:47:45.303 error script.js.common.unifivoucher: ERROR: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-02 09:47:45.234 debug script.js.common.unifivoucher: Versuche, mich bei UniFi anzumelden... javascript.0 2024-06-02 09:47:45.234 debug script.js.common.unifivoucher: Trigger-Datenpunkt geändert: true
-
für mich deutet das
javascript.0 2024-06-02 08:54:45.918 info script.js.common.unifitest: ERROR: Error: getaddrinfo ENOTFOUND unifi
auf ein verbindungsproblem hin.
IP und Passwort sowie port richtig eingegeben? Bzw kann der Unifi Adapter falls installiert drauf zugreifen?