Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Adapter: ioBroker.unifi

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.0k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.0k

Adapter: ioBroker.unifi

Adapter: ioBroker.unifi

Scheduled Pinned Locked Moved ioBroker Allgemein
unifi
1.0k Posts 172 Posters 392.5k Views 93 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • dslraserD dslraser

    @liv-in-sky
    @thewhobox
    das aus aus dem Log unterm Script

    26.8.2019, 18:16:40.833	[info ]: javascript.0 Start javascript script.js.Heiko.Unifi.unifi_wifi
    26.8.2019, 18:16:40.833	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: registered 0 subscriptions and 0 schedules
    26.8.2019, 18:16:41.126	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: Login war erfolgreich!
    26.8.2019, 18:16:41.149	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: Status erfolgreich geholt!
    26.8.2019, 18:16:41.149	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: {'statusCode':401,'body':'{\'meta\':{\'rc\':\'error\',\'msg\':\'api.err.LoginRequired\'},\'data\':[]}','headers':{'cache-control':'private','expires':'Thu, 01 Jan 1970 00:00:00 GMT','vary':'Origin','access-control-allow-credentials':'true','access-control-expose-headers':'Access-Control-Allow-Origin,Access-Control-Allow-Credentials','x-frame-options':'DENY','content-type':'application/json;charset=UTF-8','content-length':'63','date':'Mon, 26 Aug 2019 16:16:41 GMT','connection':'close'},'request':{'uri':{'protocol':'https:','slashes':true,'auth':null,'host':'192.168.180.110:8443','port':'8443','hostname':'192.168.180.110','hash':null,'search':null,'query':null,'pathname':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','path':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','href':'https://192.168.180.110:8443/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5'},'method':'GET','headers':{}}}
    26.8.2019, 18:16:41.149	[error]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: SyntaxError: Unexpected token o in JSON at position 1
    26.8.2019, 18:16:41.149	[error]: javascript.0     at Request.request.get [as _callback] (script.js.Heiko.Unifi.unifi_wifi:29:31)
    
    thewhoboxT Offline
    thewhoboxT Offline
    thewhobox
    wrote on last edited by
    #324

    @dslraser Okay, dann speichert er leider den Login cookie nicht automatisch. Muss ich mir heute Abend nochmal anschauen

    Meine Adapter: emby | discovery
    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    1 Reply Last reply
    0
    • dslraserD dslraser

      @liv-in-sky
      @thewhobox
      das aus aus dem Log unterm Script

      26.8.2019, 18:16:40.833	[info ]: javascript.0 Start javascript script.js.Heiko.Unifi.unifi_wifi
      26.8.2019, 18:16:40.833	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: registered 0 subscriptions and 0 schedules
      26.8.2019, 18:16:41.126	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: Login war erfolgreich!
      26.8.2019, 18:16:41.149	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: Status erfolgreich geholt!
      26.8.2019, 18:16:41.149	[info ]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: {'statusCode':401,'body':'{\'meta\':{\'rc\':\'error\',\'msg\':\'api.err.LoginRequired\'},\'data\':[]}','headers':{'cache-control':'private','expires':'Thu, 01 Jan 1970 00:00:00 GMT','vary':'Origin','access-control-allow-credentials':'true','access-control-expose-headers':'Access-Control-Allow-Origin,Access-Control-Allow-Credentials','x-frame-options':'DENY','content-type':'application/json;charset=UTF-8','content-length':'63','date':'Mon, 26 Aug 2019 16:16:41 GMT','connection':'close'},'request':{'uri':{'protocol':'https:','slashes':true,'auth':null,'host':'192.168.180.110:8443','port':'8443','hostname':'192.168.180.110','hash':null,'search':null,'query':null,'pathname':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','path':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','href':'https://192.168.180.110:8443/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5'},'method':'GET','headers':{}}}
      26.8.2019, 18:16:41.149	[error]: javascript.0 script.js.Heiko.Unifi.unifi_wifi: SyntaxError: Unexpected token o in JSON at position 1
      26.8.2019, 18:16:41.149	[error]: javascript.0     at Request.request.get [as _callback] (script.js.Heiko.Unifi.unifi_wifi:29:31)
      
      thewhoboxT Offline
      thewhoboxT Offline
      thewhobox
      wrote on last edited by
      #325

      @dslraser @liv-in-sky Könnte einer von euch mal nach "Login erfolgreich" folgende Zeilen einfügen?

      console.log('HEADERS: ' + JSON.stringify(resp.headers));
      onsole.log('Cookies: ' + resp.getHeader("Set-Cookie"));
      

      Meine Adapter: emby | discovery
      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

      liv-in-skyL 1 Reply Last reply
      0
      • thewhoboxT thewhobox

        @dslraser @liv-in-sky Könnte einer von euch mal nach "Login erfolgreich" folgende Zeilen einfügen?

        console.log('HEADERS: ' + JSON.stringify(resp.headers));
        onsole.log('Cookies: ' + resp.getHeader("Set-Cookie"));
        
        liv-in-skyL Offline
        liv-in-skyL Offline
        liv-in-sky
        wrote on last edited by
        #326

        moin @thewhobox

        Image 5.png

        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

        thewhoboxT 1 Reply Last reply
        0
        • liv-in-skyL liv-in-sky

          moin @thewhobox

          Image 5.png

          thewhoboxT Offline
          thewhoboxT Offline
          thewhobox
          wrote on last edited by thewhobox
          #327

          @liv-in-sky Moin. Danke fürs ausprobieren. Hier nochmal das angepasste Script für die cookies.
          Edit: Siehe unten

          Meine Adapter: emby | discovery
          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

          liv-in-skyL dslraserD 2 Replies Last reply
          1
          • thewhoboxT thewhobox

            @liv-in-sky Moin. Danke fürs ausprobieren. Hier nochmal das angepasste Script für die cookies.
            Edit: Siehe unten

            liv-in-skyL Offline
            liv-in-skyL Offline
            liv-in-sky
            wrote on last edited by
            #328

            @thewhobox - danke fürs programmieren

            jetzt kommt der erste fehler wieder 😞

            bei "const request = require('request');"

            10:08:00.824	info	javascript.2 Stop script script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1
            10:08:01.924	info	javascript.2 Start javascript script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1
            10:08:01.924	info	javascript.2 script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1: registered 0 subscriptions and 0 schedules
            10:08:01.941	info	javascript.2 script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1: Login Fehler! Error: self signed certificate
            10:08:03.833	info	javascript.2 Stop script script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1
            

            bei "const request = require('request').defaults({ rejectUnauthorized: false });"
            Image 6.png

            nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

            thewhoboxT 1 Reply Last reply
            0
            • thewhoboxT thewhobox

              @liv-in-sky Moin. Danke fürs ausprobieren. Hier nochmal das angepasste Script für die cookies.
              Edit: Siehe unten

              dslraserD Offline
              dslraserD Offline
              dslraser
              Forum Testing Most Active
              wrote on last edited by
              #329

              @thewhobox sagte in Adapter: ioBroker.unifi:

              let cookies = [];
              bei mir auch

              10:15:42.843	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: Login war erfolgreich!
              10:15:42.843	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: Cookies: ["unifises=GyZZk8h1ERsg5Kn9AeYyD2sL5Lcduutx","csrf_token=dKB4b1jFoeScvPlh97hKMywEdt1oUdBI"]
              10:15:42.893	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: Status erfolgreich geholt!
              10:15:42.893	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: {'statusCode':200,'body':'{\'meta\':{\'rc\':\'ok\'},\'data\':[{\'_id\':\'5d3c5be0bc96040011365fe5\',\'enabled\':true,\'security\':\'open\',\'wep_idx\':1,\'wpa_mode\':\'wpa2\',\'wpa_enc\':\'ccmp\',\'usergroup_id\':\'5d3b2323bc9604001132d2c5\',\'dtim_mode\':\'default\',\'dtim_ng\':1,\'dtim_na\':1,\'minrate_ng_enabled\':false,\'minrate_ng_advertising_rates\':false,\'minrate_ng_data_rate_kbps\':1000,\'minrate_ng_cck_rates_enabled\':true,\'minrate_na_enabled\':false,\'minrate_na_advertising_rates\':false,\'minrate_na_data_rate_kbps\':6000,\'mac_filter_enabled\':false,\'mac_filter_policy\':\'allow\',\'mac_filter_list\':[],\'bc_filter_enabled\':false,\'bc_filter_list\':[],\'group_rekey\':3600,\'name\':\'Hübis Gäste\',\'is_guest\':true,\'x_passphrase\':\'dashieristprivat\',\'wlangroup_id\':\'5d3b2323bc9604001132d2c6\',\'schedule\':[],\'minrate_ng_mgmt_rate_kbps\':1000,\'minrate_na_mgmt_rate_kbps\':6000,\'minrate_ng_beacon_rate_kbps\':1000,\'minrate_na_beacon_rate_kbps\':6000,\'site_id\':\'5d3b231abc9604001132d2b8\',\'x_iapp_key\':\'0613db2263d118bc9e21936a202a964e\',\'fast_roaming_enabled\':false,\'no2ghz_oui\':true}]}','headers':{'cache-control':'private','expires':'Thu, 01 Jan 1970 00:00:00 GMT','vary':'Origin,Accept-Encoding','access-control-allow-credentials':'true','access-control-expose-headers':'Access-Control-Allow-Origin,Access-Control-Allow-Credentials','x-frame-options':'DENY','content-type':'application/json;charset=UTF-8','content-length':'1000','date':'Tue, 27 Aug 2019 08:15:42 GMT','connection':'close'},'request':{'uri':{'protocol':'https:','slashes':true,'auth':null,'host':'192.168.180.110:8443','port':'8443','hostname':'192.168.180.110','hash':null,'search':null,'query':null,'pathname':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','path':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','href':'https://192.168.180.110:8443/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5'},'method':'GET','headers':{'Cookie':'unifises=GyZZk8h1ERsg5Kn9AeYyD2sL5Lcduutx; csrf_token=dKB4b1jFoeScvPlh97hKMywEdt1oUdBI'}}}
              10:15:42.893	error	javascript.0 script.js.Heiko.Unifi.unifi_wifi: SyntaxError: Unexpected token o in JSON at position 1
              10:15:42.893	error	javascript.0 at Request.request.get [as _callback] (script.js.Heiko.Unifi.unifi_wifi:39:31)
              
              1 Reply Last reply
              0
              • liv-in-skyL liv-in-sky

                @thewhobox - danke fürs programmieren

                jetzt kommt der erste fehler wieder 😞

                bei "const request = require('request');"

                10:08:00.824	info	javascript.2 Stop script script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1
                10:08:01.924	info	javascript.2 Start javascript script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1
                10:08:01.924	info	javascript.2 script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1: registered 0 subscriptions and 0 schedules
                10:08:01.941	info	javascript.2 script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1: Login Fehler! Error: self signed certificate
                10:08:03.833	info	javascript.2 Stop script script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1
                

                bei "const request = require('request').defaults({ rejectUnauthorized: false });"
                Image 6.png

                thewhoboxT Offline
                thewhoboxT Offline
                thewhobox
                wrote on last edited by
                #330

                @liv-in-sky Ja hast recht. Hab den teil vergessen zu ändern.
                Hab das Skript oben angepasst. einfach mal das JSON.parse weg lassen.

                Meine Adapter: emby | discovery
                Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                1 Reply Last reply
                0
                • dslraserD Offline
                  dslraserD Offline
                  dslraser
                  Forum Testing Most Active
                  wrote on last edited by
                  #331

                  @thewhobox
                  @liv-in-sky

                  Unexpected token o in JSON at position 1
                  
                  

                  Ich habe keine Ahnung davon, aber wenn ich google dazu befrage, dann kommt Sinngemäß oft die Antwort, das es schon ein Objekt ist und man es direkt verwenden kann und nicht parsen braucht ?

                  Danke für die Mühe.

                  thewhoboxT 1 Reply Last reply
                  0
                  • dslraserD dslraser

                    @thewhobox
                    @liv-in-sky

                    Unexpected token o in JSON at position 1
                    
                    

                    Ich habe keine Ahnung davon, aber wenn ich google dazu befrage, dann kommt Sinngemäß oft die Antwort, das es schon ein Objekt ist und man es direkt verwenden kann und nicht parsen braucht ?

                    Danke für die Mühe.

                    thewhoboxT Offline
                    thewhoboxT Offline
                    thewhobox
                    wrote on last edited by
                    #332

                    @dslraser Ja das stimmt. Hab das Skript oben angepasst.

                    Meine Adapter: emby | discovery
                    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                    liv-in-skyL 1 Reply Last reply
                    0
                    • thewhoboxT thewhobox

                      @dslraser Ja das stimmt. Hab das Skript oben angepasst.

                      liv-in-skyL Offline
                      liv-in-skyL Offline
                      liv-in-sky
                      wrote on last edited by liv-in-sky
                      #333

                      @thewhobox cool - läuft

                      könntest du das ein und ausschalten auch noch für uns machen 🙂 🙂

                      	javascript.2 script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1: WLAN ist: an
                      

                      nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                      thewhoboxT 2 Replies Last reply
                      0
                      • liv-in-skyL liv-in-sky

                        @thewhobox cool - läuft

                        könntest du das ein und ausschalten auch noch für uns machen 🙂 🙂

                        	javascript.2 script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1: WLAN ist: an
                        
                        thewhoboxT Offline
                        thewhoboxT Offline
                        thewhobox
                        wrote on last edited by
                        #334

                        @liv-in-sky okay super 🙂 Kann ich später machen.

                        Meine Adapter: emby | discovery
                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                        dslraserD liv-in-skyL 2 Replies Last reply
                        2
                        • thewhoboxT thewhobox

                          @liv-in-sky okay super 🙂 Kann ich später machen.

                          dslraserD Offline
                          dslraserD Offline
                          dslraser
                          Forum Testing Most Active
                          wrote on last edited by
                          #335

                          @thewhobox
                          klappt 👍 👍 👍

                          10:33:43.645	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: Login war erfolgreich!
                          10:33:43.645	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: Cookies: ["unifises=JA7z7GVM4cnOB6sZnqkcjBFBFpFzJw5S","csrf_token=GcAjwdvcY6hc58t6E4gLi4X3X7g490mn"]
                          10:33:43.689	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: Status erfolgreich geholt!
                          10:33:43.690	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: {'statusCode':200,'body':'{\'meta\':{\'rc\':\'ok\'},\'data\':[{\'_id\':\'5d3c5be0bc96040011365fe5\',\'enabled\':true,\'security\':\'open\',\'wep_idx\':1,\'wpa_mode\':\'wpa2\',\'wpa_enc\':\'ccmp\',\'usergroup_id\':\'5d3b2323bc9604001132d2c5\',\'dtim_mode\':\'default\',\'dtim_ng\':1,\'dtim_na\':1,\'minrate_ng_enabled\':false,\'minrate_ng_advertising_rates\':false,\'minrate_ng_data_rate_kbps\':1000,\'minrate_ng_cck_rates_enabled\':true,\'minrate_na_enabled\':false,\'minrate_na_advertising_rates\':false,\'minrate_na_data_rate_kbps\':6000,\'mac_filter_enabled\':false,\'mac_filter_policy\':\'allow\',\'mac_filter_list\':[],\'bc_filter_enabled\':false,\'bc_filter_list\':[],\'group_rekey\':3600,\'name\':\'Hübis Gäste\',\'is_guest\':true,\'x_passphrase\':\'dashieristprivat\',\'wlangroup_id\':\'5d3b2323bc9604001132d2c6\',\'schedule\':[],\'minrate_ng_mgmt_rate_kbps\':1000,\'minrate_na_mgmt_rate_kbps\':6000,\'minrate_ng_beacon_rate_kbps\':1000,\'minrate_na_beacon_rate_kbps\':6000,\'site_id\':\'5d3b231abc9604001132d2b8\',\'x_iapp_key\':\'0613db2263d118bc9e21936a202a964e\',\'fast_roaming_enabled\':false,\'no2ghz_oui\':true}]}','headers':{'cache-control':'private','expires':'Thu, 01 Jan 1970 00:00:00 GMT','vary':'Origin,Accept-Encoding','access-control-allow-credentials':'true','access-control-expose-headers':'Access-Control-Allow-Origin,Access-Control-Allow-Credentials','x-frame-options':'DENY','content-type':'application/json;charset=UTF-8','content-length':'1000','date':'Tue, 27 Aug 2019 08:33:43 GMT','connection':'close'},'request':{'uri':{'protocol':'https:','slashes':true,'auth':null,'host':'192.168.180.110:8443','port':'8443','hostname':'192.168.180.110','hash':null,'search':null,'query':null,'pathname':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','path':'/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5','href':'https://192.168.180.110:8443/api/s/default/rest/wlanconf/5d3c5be0bc96040011365fe5'},'method':'GET','headers':{'Cookie':'unifises=JA7z7GVM4cnOB6sZnqkcjBFBFpFzJw5S; csrf_token=GcAjwdvcY6hc58t6E4gLi4X3X7g490mn'}}}
                          10:33:43.690	info	javascript.0 script.js.Heiko.Unifi.unifi_wifi: WLAN ist: an
                          
                          1 Reply Last reply
                          0
                          • thewhoboxT thewhobox

                            @liv-in-sky okay super 🙂 Kann ich später machen.

                            liv-in-skyL Offline
                            liv-in-skyL Offline
                            liv-in-sky
                            wrote on last edited by
                            #336

                            @thewhobox noch ne frage:
                            kann ich die function getStatus auch dafür benutzen (ohne header) , um mit dem simpleapi adapter eines anderen iobroker zu kommunizieren ?

                            nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                            thewhoboxT 1 Reply Last reply
                            0
                            • liv-in-skyL liv-in-sky

                              @thewhobox noch ne frage:
                              kann ich die function getStatus auch dafür benutzen (ohne header) , um mit dem simpleapi adapter eines anderen iobroker zu kommunizieren ?

                              thewhoboxT Offline
                              thewhoboxT Offline
                              thewhobox
                              wrote on last edited by
                              #337

                              @liv-in-sky Jain, da die Funktion nur auf die spezielle zurückgabe vom Unifi Controller angepasst ist.
                              Du musst das im Callback anpassen und die Header weglassen.
                              Vereinfacht geht:

                              request.get("http://192.168.0.xxx/get/system.adapter.admin.0.alive", (err, resp) => {
                                  if(!err) {
                                      let state = JSON.parse(resp);
                                      console.log("State hat den Wert: " + state.val);
                                  } else {
                                      console.log("Es trat ein Fehler auf: " + err);
                                  }
                              })
                              

                              Meine Adapter: emby | discovery
                              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                              liv-in-skyL 1 Reply Last reply
                              1
                              • thewhoboxT thewhobox

                                @liv-in-sky Jain, da die Funktion nur auf die spezielle zurückgabe vom Unifi Controller angepasst ist.
                                Du musst das im Callback anpassen und die Header weglassen.
                                Vereinfacht geht:

                                request.get("http://192.168.0.xxx/get/system.adapter.admin.0.alive", (err, resp) => {
                                    if(!err) {
                                        let state = JSON.parse(resp);
                                        console.log("State hat den Wert: " + state.val);
                                    } else {
                                        console.log("Es trat ein Fehler auf: " + err);
                                    }
                                })
                                
                                liv-in-skyL Offline
                                liv-in-skyL Offline
                                liv-in-sky
                                wrote on last edited by
                                #338

                                @thewhobox danke dir - werd das mal testen

                                nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                1 Reply Last reply
                                0
                                • liv-in-skyL liv-in-sky

                                  @thewhobox cool - läuft

                                  könntest du das ein und ausschalten auch noch für uns machen 🙂 🙂

                                  	javascript.2 script.js.Armin_Schalter.ALLERLEI.UnifiWLAN1: WLAN ist: an
                                  
                                  thewhoboxT Offline
                                  thewhoboxT Offline
                                  thewhobox
                                  wrote on last edited by thewhobox
                                  #339

                                  @liv-in-sky So, hier auch noch mit ein und ausschalten. Änderungen sind:

                                  • Bei Aufruf von getStatus oder setWifi wird automatisch vorher eingeloggt.
                                  • Es gibt nun auch ein logout
                                  • Über setWifi(true/false) kann das WLAN ein/aus geschaltet werden.
                                  const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                                  const unifi_username = "user";
                                  const unifi_password = "pass";
                                  const unifi_controller = "https://192.168.x.xx:xxxx";
                                  const wifi_id = "dsa4fsda6g46fdsg984";
                                  let cookies = [];
                                  let loggedIn = false;
                                  
                                  async function login() {
                                      return new Promise(async (resolve, reject) => {
                                          let resp = await request.post({
                                              url: unifi_controller + "/api/login",
                                              body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                                              headers: { 'Content-Type': 'application/json' }
                                          }).catch((e) => reject(e));
                                  
                                          if(resp != null) {
                                              console.log("Login war erfolgreich!");
                                              let set_cookies = resp.headers["set-cookie"];
                                              for(i = 0; i < set_cookies.length; i++) {
                                                  let cookie = set_cookies[i];
                                                  cookie = cookie.split(";")[0];
                                                  cookies.push(cookie);
                                              }
                                              console.log("Cookies: " + JSON.stringify(cookies));
                                              loggedIn = true;
                                              resolve();
                                          } else {
                                              reject("resp = null");
                                          }
                                      });
                                  }
                                  
                                  async function getStatus() {
                                      return new Promise(async (resolve, reject) => {
                                          if(!loggedIn) await login().catch((e) => reject(e));
                                          let resp = await request.get({
                                              url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                                              headers: { Cookie: cookies.join("; ") }
                                          }).catch((e) => reject(e));
                                      
                                          if(resp != null && resp.statusCode == 200) {
                                              console.log("Status erfolgreich geholt!");
                                              console.log(resp);
                                              let status = JSON.parse(resp);
                                              let wlanOn = status.data[0].enabled;
                                              console.log("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                              resolve(wlanOn);
                                          } else {
                                              reject(JSON.parse(resp.body).meta.msg);
                                          }
                                      });
                                  }
                                  
                                  async function logout() {
                                      return new Promise(async (resolve, reject) => {
                                          if(!loggedIn) await login().catch((e) => reject(e));
                                          let resp = await request.get({
                                              url: unifi_controller + "/logout",
                                              headers: { Cookie: cookies.join("; ") }
                                          }).catch((e) => reject(e));
                                          if(resp != null) {
                                              console.log("Du bist nun ausgeloggt.");
                                              console.log(resp);
                                              resolve();
                                          } else {
                                              reject("resp = null");
                                          }
                                      });
                                  }
                                  
                                  async function setWifi(enabled) {
                                      return new Promise(async (resolve, reject) => {
                                          if(!loggedIn) await login().catch((e) => reject(e));
                                          let resp = request.post({
                                              url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                                              body: JSON.stringify({ _id: "", enabled }),
                                              headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                          }).catch((e) => reject(e));
                                          
                                          if(resp != null && resp.statusCode == 200) {
                                              console.log("Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                              console.log(resp);
                                              resolve();
                                          } else {
                                              reject(JSON.parse(resp.body).meta.msg);
                                          }
                                      });
                                  }
                                  

                                  Aufruf über:

                                  async function test() {
                                      await setWifi(true).catch((e) => console.log("Es trat ein Fehler auf: " + e));
                                      let isWlanOn = await getStatus();
                                  }
                                  test();
                                  

                                  Meine Adapter: emby | discovery
                                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                  liv-in-skyL 1 Reply Last reply
                                  1
                                  • thewhoboxT thewhobox

                                    @liv-in-sky So, hier auch noch mit ein und ausschalten. Änderungen sind:

                                    • Bei Aufruf von getStatus oder setWifi wird automatisch vorher eingeloggt.
                                    • Es gibt nun auch ein logout
                                    • Über setWifi(true/false) kann das WLAN ein/aus geschaltet werden.
                                    const request = require('request-promise-native').defaults({ rejectUnauthorized: false });
                                    const unifi_username = "user";
                                    const unifi_password = "pass";
                                    const unifi_controller = "https://192.168.x.xx:xxxx";
                                    const wifi_id = "dsa4fsda6g46fdsg984";
                                    let cookies = [];
                                    let loggedIn = false;
                                    
                                    async function login() {
                                        return new Promise(async (resolve, reject) => {
                                            let resp = await request.post({
                                                url: unifi_controller + "/api/login",
                                                body: JSON.stringify({ username: unifi_username, password: unifi_password }),
                                                headers: { 'Content-Type': 'application/json' }
                                            }).catch((e) => reject(e));
                                    
                                            if(resp != null) {
                                                console.log("Login war erfolgreich!");
                                                let set_cookies = resp.headers["set-cookie"];
                                                for(i = 0; i < set_cookies.length; i++) {
                                                    let cookie = set_cookies[i];
                                                    cookie = cookie.split(";")[0];
                                                    cookies.push(cookie);
                                                }
                                                console.log("Cookies: " + JSON.stringify(cookies));
                                                loggedIn = true;
                                                resolve();
                                            } else {
                                                reject("resp = null");
                                            }
                                        });
                                    }
                                    
                                    async function getStatus() {
                                        return new Promise(async (resolve, reject) => {
                                            if(!loggedIn) await login().catch((e) => reject(e));
                                            let resp = await request.get({
                                                url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                                                headers: { Cookie: cookies.join("; ") }
                                            }).catch((e) => reject(e));
                                        
                                            if(resp != null && resp.statusCode == 200) {
                                                console.log("Status erfolgreich geholt!");
                                                console.log(resp);
                                                let status = JSON.parse(resp);
                                                let wlanOn = status.data[0].enabled;
                                                console.log("WLAN ist: " + (wlanOn ? "an" : "aus"));
                                                resolve(wlanOn);
                                            } else {
                                                reject(JSON.parse(resp.body).meta.msg);
                                            }
                                        });
                                    }
                                    
                                    async function logout() {
                                        return new Promise(async (resolve, reject) => {
                                            if(!loggedIn) await login().catch((e) => reject(e));
                                            let resp = await request.get({
                                                url: unifi_controller + "/logout",
                                                headers: { Cookie: cookies.join("; ") }
                                            }).catch((e) => reject(e));
                                            if(resp != null) {
                                                console.log("Du bist nun ausgeloggt.");
                                                console.log(resp);
                                                resolve();
                                            } else {
                                                reject("resp = null");
                                            }
                                        });
                                    }
                                    
                                    async function setWifi(enabled) {
                                        return new Promise(async (resolve, reject) => {
                                            if(!loggedIn) await login().catch((e) => reject(e));
                                            let resp = request.post({
                                                url: unifi_controller + "/api/s/default/rest/wlanconf/" + wifi_id,
                                                body: JSON.stringify({ _id: "", enabled }),
                                                headers: { 'Content-Type': 'application/json', Cookie: cookies.join("; ") }
                                            }).catch((e) => reject(e));
                                            
                                            if(resp != null && resp.statusCode == 200) {
                                                console.log("Wifi wurde erfolgreich " + (enabled ? "eingeschaltet" : "ausgeschaltet"));
                                                console.log(resp);
                                                resolve();
                                            } else {
                                                reject(JSON.parse(resp.body).meta.msg);
                                            }
                                        });
                                    }
                                    

                                    Aufruf über:

                                    async function test() {
                                        await setWifi(true).catch((e) => console.log("Es trat ein Fehler auf: " + e));
                                        let isWlanOn = await getStatus();
                                    }
                                    test();
                                    
                                    liv-in-skyL Offline
                                    liv-in-skyL Offline
                                    liv-in-sky
                                    wrote on last edited by
                                    #340

                                    @thewhobox also wenn ich dich richtig verstehe

                                    kann ich mit setWifi(true) einschalten bzw setWifi(false) ausschalten - dass funktioniert aber nicht

                                    Image 11.png

                                    Image 10.png

                                    es wird nicht geschalten obwohl die meldung es sagt

                                    oder mach ich was falsch ?

                                    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                    thewhoboxT 1 Reply Last reply
                                    0
                                    • liv-in-skyL liv-in-sky

                                      @thewhobox also wenn ich dich richtig verstehe

                                      kann ich mit setWifi(true) einschalten bzw setWifi(false) ausschalten - dass funktioniert aber nicht

                                      Image 11.png

                                      Image 10.png

                                      es wird nicht geschalten obwohl die meldung es sagt

                                      oder mach ich was falsch ?

                                      thewhoboxT Offline
                                      thewhoboxT Offline
                                      thewhobox
                                      wrote on last edited by thewhobox
                                      #341

                                      @liv-in-sky Ah okay. Nein liegt nicht an dir. ich hab vergessen, dass das alles ja gar nicht synchron abläuft.
                                      Ich hab den Code oben angepasst.
                                      Achtung! Jetzt wird das Modul request-promise-native benötigt.
                                      Beachte! Die Funktionen sind nun asynchron! Heißt um danach den Status abfragen zu können musst du es in eine ebenfalls asynchrone Funktion machen und mit await auf die beendigung warten.

                                      asynch function test() {
                                          await setWifi(true);
                                          let isWlanOn = await getStatus();
                                      }
                                      

                                      Meine Adapter: emby | discovery
                                      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                      liv-in-skyL 1 Reply Last reply
                                      0
                                      • thewhoboxT thewhobox

                                        @liv-in-sky Ah okay. Nein liegt nicht an dir. ich hab vergessen, dass das alles ja gar nicht synchron abläuft.
                                        Ich hab den Code oben angepasst.
                                        Achtung! Jetzt wird das Modul request-promise-native benötigt.
                                        Beachte! Die Funktionen sind nun asynchron! Heißt um danach den Status abfragen zu können musst du es in eine ebenfalls asynchrone Funktion machen und mit await auf die beendigung warten.

                                        asynch function test() {
                                            await setWifi(true);
                                            let isWlanOn = await getStatus();
                                        }
                                        
                                        liv-in-skyL Offline
                                        liv-in-skyL Offline
                                        liv-in-sky
                                        wrote on last edited by
                                        #342

                                        @thewhobox da stimmt was nicht mit dem upgedaten file

                                        nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                        thewhoboxT 1 Reply Last reply
                                        0
                                        • liv-in-skyL liv-in-sky

                                          @thewhobox da stimmt was nicht mit dem upgedaten file

                                          thewhoboxT Offline
                                          thewhoboxT Offline
                                          thewhobox
                                          wrote on last edited by
                                          #343

                                          @liv-in-sky Habs korrigiert.

                                          Meine Adapter: emby | discovery
                                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                          liv-in-skyL 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

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

                                          643

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe