NEWS
Unifi Steuern ohne Adapter (Script,SSH)
-
@liv-in-sky so ist aktualisiert
-
@kmxak Ich versuche gerade dein Skript in Betrieb zu nehmen.
Das hier hab ich gemacht:
node-unifi Paket installiert im Javascript AdapterMuss ich für diesen Schritt
UniFi Controller mit API-Zugriff sowie ein Wifi Operator Account
noch etwas im Unifi Controller aktivieren? Was ist der Wifi Operator Account?Wenn ich das Skript starte kommt folgendes im Log:
javascript.0 2024-06-01 22:52:52.807 error script.js.Skripte.Netzwerk.Unifi_vouchers_generieren: ERROR: TypeError: Cannot read properties of undefined (reading '0') javascript.0 2024-06-01 22:52:52.803 error script.js.Skripte.Netzwerk.Unifi_vouchers_generieren: Fehler beim Logout: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-01 22:52:52.689 error script.js.Skripte.Netzwerk.Unifi_vouchers_generieren: ERROR: Error: getaddrinfo ENOTFOUND unifi javascript.0 2024-06-01 22:52:44.165 info script.js.Skripte.Netzwerk.Unifi_vouchers_generieren: registered 1 subscription, 0 schedules, 0 messages, 0 logs and 0 file subscriptions javascript.0 2024-06-01 22:52:44.116 info Start JavaScript script.js.Skripte.Netzwerk.Unifi_vouchers_generieren (Javascript/js)
-
@feuersturm sagte in Adapter: ioBroker.unifi:
Was ist der Wifi Operator Account
den kann man unter Administratoren anlegen im Unifi Portal .
Es kommt aber bei meinem Versuch hier die gleichen Fehlermeldungen wie bei dir.
-
@feuersturm hast du dir die neuste version von github runtergeladen ?
-
@liv-in-sky ja ich hab gestern Abend den v03 Stand von GitHub verwendet.
Den Hotspot Manager hatte ich auch noch gefunden und auch angelegt aber der Fehler bleibt. -
poste bitte das ganze log vom script - kopiert von der admin-log-seite
-
@liv-in-sky
mehr log gibt es bei mir da nicht -
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