Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Unifi Steuern ohne Adapter (Script,SSH)

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Unifi Steuern ohne Adapter (Script,SSH)

    This topic has been deleted. Only users with topic management privileges can see it.
    • liv-in-sky
      liv-in-sky @kmxak last edited by

      @kmxak
      das weiß ich nicht 😞 war einfach da - wie sieht es bei dir aus

      kmxak 1 Reply Last reply Reply Quote 0
      • kmxak
        kmxak Most Active @liv-in-sky last edited by

        @liv-in-sky sagte in Adapter: ioBroker.unifi:

        @kmxak

        bei mir sind wohl noch alte vouchers im system

        mit diesem script sehe ich sie und könnte sie dann in der vis anzeigen ode rüber telegram versenden ...

        
        
        const Unifi = require('node-unifi');
        
        const unifi = new Unifi.Controller({hostname:"192.168.178.1xx",port:'8443', sslverify: false});
        
        (async () => {
         try {
           // LOGIN
           const loginData = await unifi.login('user', 'passw!');
           console.log('login: ' + loginData);
          
        
        
          const switchmac="b4:fb:e4:f3:96:63"
           // Get data from a specific unifi device based on MAC address
           const deviceData = await unifi.getAccessDevices(switchmac);
           // Console.log('getAccessDevices: ' + JSON.stringify(deviceData));
        
           // Get device id
           const deviceId = deviceData[0]._id;
           console.log('deviceId: ' + deviceId + ' ip: ' + deviceData[0].ip);
        
        // GET SITE STATS
          // const sites = await unifi.getSitesStats();
          // console.log('getSitesStats: ' + sites[0].name + ':' + sites.length);
          // console.log(JSON.stringify(sites));
        
           // GET SITE SYSINFO
          // const sysinfo = await unifi.getSiteSysinfo();
          // console.log('getSiteSysinfo: ' + sysinfo.length);
           //console.log(JSON.stringify(sysinfo));
        
           // GET CLIENT DEVICES
         //  const clientData = await unifi.getClientDevices();
          // console.log('getClientDevices: ' + clientData.length);
          // console.log(JSON.stringify(clientData));
        
           // GET ALL USERS EVER CONNECTED
           //const usersData = await unifi.getAllUsers();
           //console.log('getAllUsers: ' + usersData.length);
           //console.log(JSON.stringify(usersData));
        
        //   const clientVoucher = await unifi.createVouchers(123,1,0,"testthis");
        
           const myVouchers = await unifi.getVouchers();
           console.log("vouchers: "+ JSON.stringify(myVouchers))
        
           // LOGOUT
           const logoutData = await unifi.logout();
           console.log('logout: ' + JSON.stringify(logoutData));
         } catch (error) {
           console.log('ERROR: ' + error);
         }
        })();
        
        log(getObject('system.host.iobroker59').native.os.platform)
        
        
        
        

        log:

        script.js.MYSTUFF.ALLERLEI.AAAUNIFI.unifi-wlan-schalten3: vouchers: [{"duration":123,"qos_overwrite":false,"note":"testthis","code":"6566218181","for_hotspot":false,"create_time":1717058841,"quota":0,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"66583d19108fed3b1dc7283c","admin_name":"e","used":0,"status":"VALID_MULTI","status_expires":0},{"duration":123,"qos_overwrite":false,"note":"testthis","code":"7113118220","for_hotspot":false,"create_time":1717058021,"quota":0,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"665839e5108fed3b1dc72722","admin_name":"e","used":0,"status":"VALID_MULTI","status_expires":0},{"duration":123,"qos_overwrite":false,"note":"testthis","code":"4515536233","for_hotspot":false,"create_time":1717057059,"quota":0,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"66583623108fed3b1dc725f0","admin_name":"e","used":0,"status":"VALID_MULTI","status_expires":0},{"duration":5760,"qos_overwrite":false,"note":null,"code":"8241421156","for_hotspot":false,"create_time":1650354689,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"625e6a0197578402ac2db67c","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":5760,"qos_overwrite":false,"note":null,"code":"7446834263","for_hotspot":false,"create_time":1650354689,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"625e6a0197578402ac2db67b","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":525600,"qos_overwrite":false,"note":null,"code":"7358319725","for_hotspot":false,"create_time":1650354660,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"625e69e497578402ac2db679","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"2729460620","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f7096","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"1795017450","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f7095","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"2281225310","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f7094","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"0356279115","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f7093","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"3544056744","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f7092","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"6426769406","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f7091","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"2298091277","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f7090","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"8878654311","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f708f","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"6946187591","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f708e","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0},{"duration":1440,"qos_overwrite":false,"note":null,"code":"0579279641","for_hotspot":false,"create_time":1627921177,"quota":1,"site_id":"5cadc7f53b6a3967dd7e5369","_id":"61081b1997578402177f708d","admin_name":"e","used":0,"status":"VALID_ONE","status_expires":0}]
        
        

        im log ist der erste eintrag ein test mit 123... - wurde wohl angelegt - damit funktioniert es wohl

        dazu müsste ich erstmal den login fixen. ich habe ja noch andere sachen da laufen die können sich verbinden. auch der protect adapter kann sich verbinden... mal sehen wenn ich mal zeit habe ... lege es auf den haufen mit todo 😬

        1 Reply Last reply Reply Quote 0
        • kmxak
          kmxak Most Active @liv-in-sky last edited by

          @liv-in-sky sagte in Adapter: ioBroker.unifi:

          @kmxak
          das weiß ich nicht 😞 war einfach da - wie sieht es bei dir aus

          sorry mein fehler war mit dem browser nicht eingeloggt.

          1 Reply Last reply Reply Quote 0
          • kmxak
            kmxak Most Active last edited by kmxak

            ah, jetzt geht es... falscher port 🤦

            bekomme aber nur:

            javascript.0	11:50:46.998	info	script.js.User.Unifi.Unifi_Node: login: true
            javascript.0	11:50:47.064	info	script.js.User.Unifi.Unifi_Node: vouchers: [object Object],[object Object],[object Object],[object Object],[object Object]
            javascript.0	11:50:47.084	info	script.js.User.Unifi.Unifi_Node: logout: {"success":true}
            

            der hier funzt nicht mit deinem aus dem code geht es

            console.log("vouchers: "+ myVouchers)
            
            liv-in-sky 1 Reply Last reply Reply Quote 0
            • liv-in-sky
              liv-in-sky @kmxak last edited by

              @kmxak sagte in Adapter: ioBroker.unifi:

              die info mit dem port dazu müsste ich ja den code ändern.

              kannst du ja machen - die datei unifi.js liegt ja im verzeichnis vom iobroker

              Image 060.png

              auf eigene verantwortung

              1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @kmxak last edited by

                @kmxak sagte in Adapter: ioBroker.unifi:

                console.log("vouchers: "+ myVouchers)

                mein fehler

                so muss es heißen

                console.log("vouchers: "+ JSON.stringify(myVouchers))
                
                1 Reply Last reply Reply Quote 0
                • kmxak
                  kmxak Most Active last edited by

                  ja danke damit ging es und es funktioniert.

                  Damit kann ich ja weiterarbeiten.

                  Neuschwansteini 1 Reply Last reply Reply Quote 1
                  • Neuschwansteini
                    Neuschwansteini @kmxak last edited by

                    @kmxak @liv-in-sky

                    👍 👍
                    hab gerade mal mit euch getestet, funktioniert hier auch, guter Ansatz, vielleicht bekommt man damit noch mehr gebacken.. aber die Vouchers funktionieren schonmal, brauch ich zwar nicht.. aber man weiss ja nie..

                    1 Reply Last reply Reply Quote 1
                    • liv-in-sky
                      liv-in-sky last edited by

                      es gibt auch ein beispiel, wie man einen poe prot abschaltet

                      https://github.com/jens-maus/node-unifi/blob/master/examples/poe-switch-onoff.js

                      Neuschwansteini 1 Reply Last reply Reply Quote 1
                      • Neuschwansteini
                        Neuschwansteini @liv-in-sky last edited by

                        @liv-in-sky sagte in Adapter: ioBroker.unifi:

                        es gibt auch ein beispiel, wie man einen poe prot abschaltet

                        https://github.com/jens-maus/node-unifi/blob/master/examples/poe-switch-onoff.js

                        POE schalten kann der Adapter ja... einen ganzen Port disablen aber wohl nicht..

                        liv-in-sky 1 Reply Last reply Reply Quote 0
                        • liv-in-sky
                          liv-in-sky @Neuschwansteini last edited by

                          @ilovegym

                          hab ich gelesen - aber evtl kann man daraus ableiten, wie man einen port blockiert oder disabled oder sowas

                          draexler 1 Reply Last reply Reply Quote 0
                          • draexler
                            draexler @liv-in-sky last edited by

                            @liv-in-sky Habe mich jetzt mal kurz eingelesen. Der ioBroker Adapter baut ja genau auf diesen "node-unifi" auf. Kannst du Voucher erstellen? Die Abfrage ob es welche gibt funktioniert ja noch im Adapter... Nur die Anforderung nicht. Kann gerade nicht testen weil ich unterwegs bin und nur auf dem Handy schreiben kann 😞

                            liv-in-sky 1 Reply Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @draexler last edited by

                              @draexler nee - -beim anlegen über adapter kommt eine fehlermeldung im log

                              draexler 1 Reply Last reply Reply Quote 0
                              • draexler
                                draexler @liv-in-sky last edited by

                                @liv-in-sky bekommst du über beide wege die Meldung? Also Adapter ODER/UND Javascript Instanz?

                                liv-in-sky 1 Reply Last reply Reply Quote 0
                                • liv-in-sky
                                  liv-in-sky @draexler last edited by

                                  @draexler fehler nur bei adapter beim anlegen von vouchers

                                  1 Reply Last reply Reply Quote 0
                                  • A
                                    andr3 @Meister Mopper last edited by

                                    @meister-mopper und im Adapter trage ich dann die UDM-PRO IP aber KENEN Port ein? (Irgendwo hier so gelesen), Benutzername und Passwort vom lokalen User?
                                    Der Adapter startet dann, schaltet sogar auf grün, steuern kann ich via Objektebaum leider trotzdem nichts.

                                    Absurderweise startet der Adapter auch ohne Fehlermeldungen, wenn ich einen falschen Namen/falsches Passwort angebe.

                                    draexler 1 Reply Last reply Reply Quote 0
                                    • draexler
                                      draexler @andr3 last edited by

                                      Wollte es jetzt auch mal ausprobieren. Scheitere aber schon bei dem Grundskript....
                                      Wo muss den bei der IP, Port, Benutzername, Passwort die Hockklammern etc. weg und wo müsse welche hin? Nicht das hier schon das Problem liegt....

                                      
                                      
                                      const Unifi = require('node-unifi');
                                      
                                      const unifi = new Unifi.Controller({hostname:"192.168.168.5",port:'8443', sslverify: false});
                                      
                                      (async () => {
                                       try {
                                         // LOGIN
                                         const loginData = await unifi.login('unifi-iobroker', '34523452345!');
                                         console.log('login: ' + loginData);
                                      
                                      //   const clientVoucher = await unifi.createVouchers(123,1,0,"testthis");
                                      
                                         // LOGOUT
                                         const logoutData = await unifi.logout();
                                         console.log('logout: ' + JSON.stringify(logoutData));
                                       } catch (error) {
                                         console.log('ERROR: ' + error);
                                       }
                                      })();
                                      
                                      log(getObject('system.host.iobroker59').native.os.platform)
                                      
                                      

                                      Im log steht nur:

                                      javascript.0	07:53:19.785	info	Start JavaScript script.js.common.Netzwerk.Voucher_erstellen (Javascript/js)
                                      javascript.0	07:53:19.804	warn	script.js.common.Netzwerk.Voucher_erstellen: Object "system.host.iobroker59" does not exist
                                      javascript.0	07:53:19.807	error	script.js.common.Netzwerk.Voucher_erstellen: TypeError: Cannot read properties of null (reading 'native')
                                      javascript.0	07:53:19.807	error	at script.js.common.Netzwerk.Voucher_erstellen:24:40
                                      javascript.0	07:53:19.807	error	at script.js.common.Netzwerk.Voucher_erstellen:33:3
                                      javascript.0	07:53:20.635	info	script.js.common.Netzwerk.Voucher_erstellen: ERROR: AxiosError: Request failed with status code 400
                                      javascript.0	07:53:23.368	info	Stopping script script.js.common.Netzwerk.Voucher_erstellen
                                      
                                      Neuschwansteini liv-in-sky A 3 Replies Last reply Reply Quote 0
                                      • Neuschwansteini
                                        Neuschwansteini @draexler last edited by

                                        @draexler

                                        zwei Sachen fallen mir auf:

                                        1. wenn du ne UDM Pro hast, mach aus dem Port 8443 nur 443
                                        2. in dem Script heisst der iobroker Host "iobroker59" - musste ich bei mir auf iobroker aendern, meiner heisst halt einfach nur iobroker..

                                        Probiers mal aus!
                                        🙂

                                        draexler 1 Reply Last reply Reply Quote 0
                                        • draexler
                                          draexler @Neuschwansteini last edited by

                                          @ilovegym Merce 🙂 Es war nur das Problem mit iobroker59. Das Basisscript läuft.
                                          Frage an alle: Gibts irgendeine Möglichkeit das PW nicht im Klartext anzuzeigen?

                                          1 Reply Last reply Reply Quote 0
                                          • liv-in-sky
                                            liv-in-sky @draexler last edited by liv-in-sky

                                            @draexler sagte in Adapter: ioBroker.unifi:

                                            log(getObject('system.host.iobroker59').native.os.platform)

                                            diese zeile (letzte) bitte löschen - war ein test für ganz was anderes und gehört nicht ins script - sorry

                                            draexler 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            476
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            16
                                            152
                                            10929
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo