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

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Unifi WLAN Script 2 mit Anwesenheitskontrolle

    This topic has been deleted. Only users with topic management privileges can see it.
    • dslraser
      dslraser Forum Testing Most Active @liv-in-sky last edited by dslraser

      @liv-in-sky

      das war jetzt mit 80000, gleich kurz nacheinander

      Screenshot_20190917-181548_Chrome.jpg

      Screenshot_20190917-181625_Chrome.jpg

      und da fehlt dann immer ein AP

      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:

        @dslraser ist das nur mit den echo geräten ? an einem bestimmten ap ?

        ist der im keller (ap) über lan verbunden

        Nein, sind immer andere Geräte.
        Wohnzimmer ist LAN und die anderen Beiden sind WLAN (und das sind genau die...Wohnzimmer hat bisher noch nicht gefehlt)

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

          @dslraser also ob das mit dem script zusammenhängt ? ich glaube eher es geht um das setting zwischen den aps und dem controller - ich hole nur die daten vom controller und verarbeite das - was siehst du im controller ?

          um im log die info online zu sehen, wenn sich ein gerät abmeldet wegen der uap

          kannst du im script folgendes machen - ist unter status3 in der getClients() funktion - damit kannst du dann das log beobachten und gleichzeitig im controller nachschauen, was da zu sehen ist
          Image 5.png

          die erste zeile das my weg vor mylog(..)
          und die zweite zeile einfügen

          dann siehst du direkt online den wert für uap und das gerät - ist nicht die lösung aber vielleicht kannst du es gebrauchen

          das log beendest du indem du log(..) in mylog(..) änderst und das skript sicherst

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

            @liv-in-sky
            dann sehe ich genau das was in iQontrol auch steht, aber die Geräte sind definitiv online und angemeldet ???
            Ich verstehe es auch noch nicht..

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

              @dslraser - wie sind die betriebszeiten im controller für diese geräte ? sind die kurz oder wie alle anderen

              Image 7.png

              dslraser 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:

                sind die kurz oder wie alle anderen

                ca 5h, also alle länger (vor 5h Neustart von so einigen Geräten)

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

                  @dslraser vielleicht sind die daten für einen bestimmten zeitraum nicht vorhanden - weils es ja immer der keller ap ist - ist dies der fall, würde das script auch sofort auf false setzen - unabhängig von der uap -

                  wäre dies der fall, kannst du mal dieses log ansehen -beobachten

                  Image 8.png

                  einfach das my bei mylog wieder entfernen

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

                    @liv-in-sky
                    mache ich nachher (jetzt ist Abendessen)
                    Es ist immer mal Keller oder Schlafzimmer (beider per WLAN angebunden)

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

                      @dslraser falls das problem darin liegt - hier eine testversion - ist nur der teil, der eretzt werden muss

                      setzte problemWLAN auf true und countFalseSetting ertmal auf 2 lassen - wenn immer noch problem, dann mal countFalseSetting mit 3 probieren - diese version setzt bei fehlenden daten erst nach 2 durchläufen auf false - vielleicht funktioniert das

                      ist nicht getestet, da ich das nicht so einfach nachstellen kann - wenn es klappt mach ich das in s nächste update rein

                      unifi-main-scrip-WLANproblemt.txt

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

                        @liv-in-sky

                        ich habe mir jetzt Netzwerkprobleme eingehandelt, die muß ich erstmal lösen. (Ich habe einige Einstellungen im Controller und im USG probiert)
                        Ich melde mich wieder........

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

                          @liv-in-sky
                          kannst Du bitte einmal das komplette "geänderte" Script posten (nicht nur den geänderten Teil)
                          Irgendwie ist jetzt was doppelt und an anderen Stellen oder eine andere Struktur drinn.

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

                            @dslraser das ganze script

                            ganzes-script-mit problemWLAN.txt

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

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

                              ganzes-script-mit problemWLAN.txt

                              das schmeisst beim ersten Start einen Fehler und bleibt dann stehen

                              2:09:29.425	error	javascript.0 at Object.<anonymous> (script.js.Heiko.16Unifi.Unifi-Test:887:82)
                              

                              irgendwo hier

                              Bildschirmfoto 2019-09-17 um 22.10.49.png

                              wahrscheinlich weil die Liste noch gar nicht da ist

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

                                @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 .....

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

                                  @liv-in-sky ich wollte eigentlich dein Script als Anwesenheitserkennung mit nutzen (parallel habe ich noch ein anderes Script dafür laufen)
                                  Habe allerdings etwas Probleme damit, der Datenpunkt meines Smartphones, wechselt ständig von true/false und umgekehrt, obwohl das Phone immer eingebucht ist. Habe auch schon die Zeiten höher gesetzt, ohne Erfolg.
                                  Ich probiere mal das neue Script.

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

                                    @coyote moin hast du mal das neue script installiert und das probiert, was ch gerade eben geschrieben hatte

                                    setzte "problemWLAN" auf true und countFalseSetting ertmal auf 2 lassen - ist neu dazugekommen

                                    welche abfragezykus und abfrageoffset nutzt du im moment ?

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

                                      @liv-in-sky ich habe jetzt mal deine Standartwerte drin stehen lassen und den Rest so gesetzt wie du gesagt hast im neuen Script. Ich beobachte es mal.

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

                                        Verhält sich irgendwie seltsam, Clientanzahl 14, paar Sekunden später 0, wieder paar Sekunden später 11, dann wieder 3.
                                        Ich erhöhe mal noch die Abfragezeit

                                        EDIT: Abfragezyklus 60 Sekunden, Offset 35 Sekunden

                                        Damit sieht es schon ganz gut aus

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

                                          @coyote scheint der fehler zu sein, denn ich vermute

                                          das bekommst du eigentlich mit dem neuen setting punkt weg :

                                          "problemWLAN" auf true setzen

                                          wenn plötzlich viele clients auf false gehen, hat das nichts mehr mit dem abfrageoffset zu tun, sondern aus einem mir unbekannten grund, werden vom controller die daten für diese clients nicht übermittelt obwohl sie eingelogt sind. siehe bitte auch nächsten post

                                          1 Reply Last reply Reply Quote 0
                                          • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            719
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

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