Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Unifi WLAN Script 2 mit Anwesenheitskontrolle

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    Unifi WLAN Script 2 mit Anwesenheitskontrolle

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

      habe mal ein kleines analyse blockly gemacht -:

      es wird bei allen clients , die auf false gehen getriggert und zeigt sie im log an - (als warning) - die version des javascript-adapters muss größer als 4.1.12 sein, da sonst das blockly nicht importiert werden kann.

      bei zu vielen clients, die gleichzeitig auf false gehen muss der punkt/variable "problemWLAN" auf true gesetzt werden

      blockly script zum download - hier muss die instanz, in der das unifi script läuft bzw. wo die datenpunkte liegen eingegeben werden (bei den pfeilen)

      <block xmlns="http://www.w3.org/1999/xhtml" type="on_ext" id="ce.n5V*r/z;dp^fkkvC2" x="-1137" y="-613">
       <mutation items="1"></mutation>
       <field name="CONDITION">ne</field>
       <field name="ACK_CONDITION"></field>
       <value name="OID0">
         <shadow type="field_oid" id="!h,u;ltVdz78tG8oL7,U">
           <field name="oid">default</field>
         </shadow>
         <block type="selector" id="SxVqA[czH|8s5L)q9/(]">
           <field name="TEXT">state[id='javascript.2.WLANUnifi.Wifi_Client_States.*']</field>
         </block>
       </value>
       <statement name="STATEMENT">
         <block type="comment" id="Dwx%2Z_Q){[J?[h??tEg">
           <field name="COMMENT">für umschalten von true auf false</field>
           <next>
             <block type="controls_forEach" id="([/#z6r;#I$$D_y,H9*D">
               <field name="VAR" id="^HoH-k20pa^?@DB/xeM3" variabletype="">i</field>
               <value name="LIST">
                 <block type="selector" id="sR}f`bRg,(Zhx|uVrXyW">
                   <field name="TEXT">state[id='javascript.2.WLANUnifi.Wifi_Client_States.*']</field>
                 </block>
               </value>
               <statement name="DO">
                 <block type="controls_if" id="V!OF]VApI$$z_#{njxZm">
                   <value name="IF0">
                     <block type="logic_operation" id="a{n+kypj2v4y+x-t6~v?" inline="false">
                       <field name="OP">AND</field>
                       <value name="A">
                         <block type="logic_compare" id="h5r*Odo:0-**p_o72gIA">
                           <field name="OP">EQ</field>
                           <value name="A">
                             <block type="get_value_var" id="MchNhUyS%^ne]yXjdUk9">
                               <field name="ATTR">val</field>
                               <value name="OID">
                                 <shadow type="text" id="$ZuV9.Z`zK=rA!Q/EU}U">
                                   <field name="TEXT"></field>
                                 </shadow>
                                 <block type="variables_get" id="XZu1I6f=IL2xH3Q[ezAq">
                                   <field name="VAR" id="^HoH-k20pa^?@DB/xeM3" variabletype="">i</field>
                                 </block>
                               </value>
                             </block>
                           </value>
                           <value name="B">
                             <block type="logic_boolean" id="9rpzV0;=TJj?oyRi?V$W">
                               <field name="BOOL">FALSE</field>
                             </block>
                           </value>
                         </block>
                       </value>
                       <value name="B">
                         <block type="logic_compare" id="e1(UaFO;@)-%m_zY(:C]">
                           <field name="OP">LT</field>
                           <value name="A">
                             <block type="math_arithmetic" id="yet)l!*(=|$9p-k^C@bD">
                               <field name="OP">MINUS</field>
                               <value name="A">
                                 <shadow type="math_number" id="L[+]Ru)025H_(1E)q([!">
                                   <field name="NUM">1</field>
                                 </shadow>
                                 <block type="time_get" id="cHIcHsV^}y^SN{fQlj*C">
                                   <mutation format="false" language="false"></mutation>
                                   <field name="OPTION">object</field>
                                 </block>
                               </value>
                               <value name="B">
                                 <shadow type="math_number" id="[q:ASesDitQ[Bw%yB-#:">
                                   <field name="NUM">1</field>
                                 </shadow>
                                 <block type="get_value_var" id="3p6n[,y+-W,Dbrs-b{t0">
                                   <field name="ATTR">lc</field>
                                   <value name="OID">
                                     <shadow type="text" id="$ZuV9.Z`zK=rA!Q/EU}U">
                                       <field name="TEXT"></field>
                                     </shadow>
                                     <block type="variables_get" id="Y7`;FE#=J:SO$L;BHtC/">
                                       <field name="VAR" id="^HoH-k20pa^?@DB/xeM3" variabletype="">i</field>
                                     </block>
                                   </value>
                                 </block>
                               </value>
                             </block>
                           </value>
                           <value name="B">
                             <block type="math_number" id="3gxc(PJ5aM``I2C9Eh=D">
                               <field name="NUM">3000</field>
                             </block>
                           </value>
                         </block>
                       </value>
                     </block>
                   </value>
                   <statement name="DO0">
                     <block type="debug" id="B$A}u)1wjXW%P!kzKkL`">
                       <field name="Severity">warn</field>
                       <value name="TEXT">
                         <shadow type="text" id="V4J^|!u%Y_g:#8p!Q5)*">
                           <field name="TEXT">test</field>
                         </shadow>
                         <block type="text_join" id="nRs9ge34N=4lR|!=xs_(">
                           <mutation items="4"></mutation>
                           <value name="ADD0">
                             <block type="text" id="`tD-nC,vQcJk@thaHH4p">
                               <field name="TEXT">Wert von  :  </field>
                             </block>
                           </value>
                           <value name="ADD1">
                             <block type="variables_get" id="^?]8I,v|W46Vdqm1e9.H">
                               <field name="VAR" id="^HoH-k20pa^?@DB/xeM3" variabletype="">i</field>
                             </block>
                           </value>
                           <value name="ADD2">
                             <block type="text" id="X.oX530/]eJ/%OX4p}2J">
                               <field name="TEXT"> ist :----------------------------------</field>
                             </block>
                           </value>
                           <value name="ADD3">
                             <block type="get_value_var" id="*l%y+oTXoU,.0!ydd)CD">
                               <field name="ATTR">val</field>
                               <value name="OID">
                                 <shadow type="text" id="$ZuV9.Z`zK=rA!Q/EU}U">
                                   <field name="TEXT"></field>
                                 </shadow>
                                 <block type="variables_get" id="]%RvRcW(Fkpk}S?^/rA8">
                                   <field name="VAR" id="^HoH-k20pa^?@DB/xeM3" variabletype="">i</field>
                                 </block>
                               </value>
                             </block>
                           </value>
                         </block>
                       </value>
                     </block>
                   </statement>
                 </block>
               </statement>
             </block>
           </next>
         </block>
       </statement>
      </block>
      

      Image 1.png

      erklärung:

      der unifi controller hat keinen zustand für angemeldetew clients - ist ein client nicht angemeldet, sind auch keine daten vorhanden - der controller hat keinen true/false zustand. der controller hält den client noch für ca 5 min aktiv, bevor er ihn ganz aus seiner datenbank löscht

      im script wird also bei 2 triggern auf false gesetzt:

      • wenn der last_seen_by_uap (wann wurde das gerät zum letzten mal gesehen) größer "abfragezyklus+abfrageoffset" ist
        oder
      • wenn es keine daten mehr über den client gibt

      bei einzelnen clients , die probleme machen mit einem zu schnellen false, kann dies über denabfrageoffset geregelt werden
      bei mehreren clients, die gleichzeitig auf false gehen muss "problemWLAN" aktiviert werden, denn es stimmt (wahrscheinlich) etwas bei dem update der clientdaten vom uap zum controller nicht

      es gibt auch noch einen schalter im controller: unter einstellungen (im controller-admin) - unter benutzerinterface
      habe ich 1 minute eingestellt

      Image 2.png

      • meine eigene werte sind: abfragezyklus=20000 und der abfrageoffset ist 15000 (1sek = 1000) - den punkt/einstellung "problemWLAN" nutze ich nicht (=> false) - mit dieser einstellung habe ich keinerlei probleme - aber die netzwerke und clients sind bei jedem verschieden und können mit diesen variablen eingestellt werden.
      dslraser 1 Reply Last reply Reply Quote 0
      • coyote
        coyote Most Active last edited by

        @liv-in-sky nochmal kurze Rückmeldung von mir. Ich habe jetzt den Abfragezyklus auf 30sec gestellt, Offset auf 15sec gelassen und problemWLAN= false
        Damit sieht es momentan recht gut aus, ich werde dass über den Tag mal im Auge behalten.

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

          @coyote rückmeldung in ein paar tagen wäre klasse

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

            @liv-in-sky irgendwie wird die Liste in iqontrol nicht aktualisiert, die ist immer noch von gestern 🤔
            Was mache ich denn falsch?

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

              @coyote wenn iqontrol auf true ist ( ? ) kannst du nicht viel falsch machen

              wird bei einem update des scripts mit false umgeschrieben

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

                @liv-in-sky ja klar, ist es. Komisch. Wo wird denn die Datei hingeschrieben? Dann schau ich mal

                liv-in-sky 2 Replies Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @coyote last edited by

                  @coyote

                  const datei = "/opt/iobroker/iobroker-data/files/iqontrol/htmlvoucher.html";
                  const datei2 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlclients.html";
                  const datei3 = "/opt/iobroker/iobroker-data/files/iqontrol/htmlinfo.html";
                  
                  coyote 1 Reply Last reply Reply Quote 0
                  • coyote
                    coyote Most Active @liv-in-sky last edited by

                    @liv-in-sky ja, hatte sie gerade schon gefunden. Geändert wird sie wohl laut Zeitstempel der Datei, aber der Zugriff von iqontrol erfolgt wohl nicht 🤔

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

                      @coyote

                      die dateien und datenpunkte werden nur bei scripts start und bei änderungen geschrieben - ich habe versucht, nur daten zu ändern, wenn auch notwendig

                      soweit ich mich erinnere, hat auch @dslraser irgendwas mit cache eingestellt - ich such es mal im alten threat

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

                        @coyote schau mal da - https://forum.iobroker.net/post/296673

                        ist bei dir das forum jetzt auch in englisch (z.b. beschriftung der buttons)

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

                          @liv-in-sky aha ok, habe ich jetzt mal umgestellt, werde dann mal noch neustarten und schauen ob es funktioniert.
                          Ähm nö, alles noch auf deutsch

                          1 Reply Last reply Reply Quote 1
                          • dslraser
                            dslraser Forum Testing Most Active @liv-in-sky last edited by

                            @liv-in-sky sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                            @dslraser das problem - so wie ich den trigger für das löschen von vouchers mit iqontrol programmiert habe, wird beim ersten aufruf ohne existierende datenpunkte (hatte ich nicht getestet) beim datenpunkt erstellen auch gleich mal der trigger gesetzt - und dann kommt fehler

                            ist behoben und du kannst das script aus dem ersten post benutzen - ist gefixt und das WLAN problem ist auch schon drin - mal sehen ob es was bringt mi deinen beiden ap's

                            setzte problemWLAN auf true und countFalseSetting ertmal auf 2 lassen .....

                            Jetzt ist irgendwie der Wurm drinn...
                            Ich habe das neue Script von oben genommen. Alle Optionen auf true gesetzt (beim ersten mal alles auf true). Es wurden Datenpunkte angelegt, aber die Clients DP werden gar nicht angelegt. Danach passiert nichts mehr, es kommen auch keine Daten rein. Alle Intervalle habe ich auf standard gelassen...?

                            Danach alles gelöscht und das gleiche probiert, bis auf den neuen DP auf false, gleiches Ergebnis wie oben beschrieben. (also wie alles auf true)

                            liv-in-sky 2 Replies Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @dslraser last edited by

                              @dslraser sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                              @liv-in-sky sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                              @dslraser das problem - so wie ich den trigger für das löschen von vouchers mit iqontrol programmiert habe, w....

                              habe nochmal getestet und zuvor datenpunkte gelöscht- funktioniert bei mir - habe es in den ersten post nochmal geladen, nicht das beim kopieren ein fehler passiert ist

                              hast du deine settings im controller wieder hinbekommen?

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

                                @dslraser wenn es weiter probleme geben sollte, kann es nicht schaden dia javascript instanz mal neuzustarten

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

                                  @liv-in-sky sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                                  habe nochmal getestet und zuvor datenpunkte gelöscht- funktioniert bei mir - habe es in den ersten post nochmal geladen, nicht das beim kopieren ein fehler passiert ist

                                  das hier war vorhin nicht drinn, aber das war es trotzdem nicht

                                  //Vordefinierte Vouchers f¸r  one-click-create - wird hier etwas ge‰ndert BITTE DATENPUNKT (Vouchers_StandardList) L÷SCHEN vor Scriptstart!!!!
                                  //BITTE alle Werte eingeben - f¸r nichtbenutzte wie up-, doen-oad und nmb_begrenzung eine 0 eintragen
                                  // Pflichteintr‰ge sind dauer, anzahl, multiuse und notiz !!!
                                  const standardVouchers = {"120Min" : {dauer: 120, anzahl: 1, multiuse: 1, upload: 0, download:0, mb_begrenzung: 0, notiz:"test mit leeren werten"}, 
                                                            "vierStunden" : {dauer: 240, anzahl: 2, multiuse: 1, upload: 0, download:200, mb_begrenzung: 500, notiz:"dauer 99"}}
                                  
                                  

                                  Es ist wieder das ! (schon wieder drauf reingefallen, das hattest Du schon mal raus)

                                  const unifi_password = "passwort!";
                                  

                                  Jetzt werde ich das mal laufen lassen und beobachten.

                                  hast du deine settings im controller wieder hinbekommen?

                                  ja, alles gut

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

                                    @liv-in-sky sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                                    habe mal ein kleines analyse blockly gemacht -:
                                    es wird bei allen clients , die auf false gehen getriggert und zeigt sie im log an - (als warning)
                                    bei zu vielen clients, die gleichzeitig auf false gehen muss der punkt/variable "problemWLAN" auf true gesetzt werden
                                    blockly script zum download - hier muss die instanz, in der das unifi script läuft bzw. wo die datenpunkte liegen eingegeben werden (bei den pfeilen)
                                    Spoiler

                                    Nur als Hinweis, ich war auf stable im JS Adapter 4.1.12, da ist der Selector noch nicht drinn. Ich hatte den aber schon mal drinn, bin aber letztens auf stable zurück, daher wußte ich das es den jetzt für Blockly gibt.
                                    Mit 4.1.12 läßt sich dann das Blockly nicht importieren.

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

                                      @dslraser sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                                      @liv-in-sky sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                                      habe nochmal getestet und zuvor datenpunkte gelöscht- funktioniert bei mir - habe es in den ersten post nochmal geladen, nicht das beim kopieren ein fehler passiert ist

                                      das hier war vorhin nicht drinn, aber das war es trotzdem nicht
                                      .........

                                      keine ahnung wo sich das wieder reingeschlichen hat - die neue constante, die dir aufgefallen ist, ist zum anlegen von vouchers gedacht über iqontrol - die constante standardVouchers definiert diese und mit iqontrol kannst du dann eines auswählen - man kann so viele anlegen, wie man will

                                      also eine iqontrol kachel mit wert anlegen - auch hier gilt, nach der benutzung der kachel muss der browser aktualisiert werden - zusätzliche infos stehen im script - auch wenn du es nicht benutzt - lass die konstante so wie sie ist - bei fehlender konstante oder fehlenden inhalten kann es sonst zu fehlern kommen - man kann das auch direkt im object tab aufrufen

                                      Image 3.png

                                      Image 4.png

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

                                        @dslraser sagte in Unifi WLAN Script 2 mit Anwesenheitskontrolle:

                                        Nur als Hinweis, ich war auf stable im JS Adapter 4.1.12, da ist der Selector noch nicht drinn. Ich hatte den aber schon mal drinn, bin aber letztens auf stable zurück, daher wußte ich das es den jetzt für Blockly gibt.
                                        Mit 4.1.12 läßt sich dann das Blockly nicht importieren.

                                        danke dafür - hab es im post dazugefügt

                                        1 Reply Last reply Reply Quote 0
                                        • W
                                          web4wasch last edited by

                                          Hallo liv-in-sky,

                                          danke für das tolle Skript!👍

                                          Habe bei mir zwei AP's eingebunden, bekomme aber nur vom Lite die Daten in "infoAP"...
                                          Mein AP-Pro wird nicht angezeigt. Ordner zwar vorhanden, aber keine Daten (IP etc.)?

                                          Habe ich etwas falsch gemacht?

                                          Danke für die Rückmeldung. Ansonsten kommt alles sauber rein...😊

                                          W 1 Reply Last reply Reply Quote 0
                                          • W
                                            web4wasch @web4wasch last edited by

                                            @web4wasch

                                            hier mal ein snap!unifi.PNG

                                            liv-in-sky 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            983
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript monitoring
                                            46
                                            1358
                                            338532
                                            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