Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Unifi WLAN Script 2 mit Anwesenheitskontrolle

NEWS

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

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

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

Unifi WLAN Script 2 mit Anwesenheitskontrolle

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascriptmonitoring
1.4k Beiträge 46 Kommentatoren 478.2k Aufrufe 51 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • coyoteC Offline
    coyoteC Offline
    coyote
    Most Active
    schrieb am zuletzt editiert von coyote
    #54

    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-skyL 1 Antwort Letzte Antwort
    0
    • coyoteC 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-skyL Offline
      liv-in-skyL Offline
      liv-in-sky
      schrieb am zuletzt editiert von
      #55

      @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

      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 Antwort Letzte Antwort
      0
      • liv-in-skyL Offline
        liv-in-skyL Offline
        liv-in-sky
        schrieb am zuletzt editiert von liv-in-sky
        #56

        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.

        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

        dslraserD 1 Antwort Letzte Antwort
        0
        • coyoteC Offline
          coyoteC Offline
          coyote
          Most Active
          schrieb am zuletzt editiert von
          #57

          @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-skyL 1 Antwort Letzte Antwort
          0
          • coyoteC coyote

            @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-skyL Offline
            liv-in-skyL Offline
            liv-in-sky
            schrieb am zuletzt editiert von liv-in-sky
            #58

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

            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

            coyoteC 1 Antwort Letzte Antwort
            0
            • liv-in-skyL liv-in-sky

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

              coyoteC Offline
              coyoteC Offline
              coyote
              Most Active
              schrieb am zuletzt editiert von
              #59

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

              liv-in-skyL 1 Antwort Letzte Antwort
              0
              • coyoteC coyote

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

                liv-in-skyL Offline
                liv-in-skyL Offline
                liv-in-sky
                schrieb am zuletzt editiert von liv-in-sky
                #60

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

                wird bei einem update des scripts mit false umgeschrieben

                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

                coyoteC 1 Antwort Letzte Antwort
                0
                • liv-in-skyL liv-in-sky

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

                  wird bei einem update des scripts mit false umgeschrieben

                  coyoteC Offline
                  coyoteC Offline
                  coyote
                  Most Active
                  schrieb am zuletzt editiert von
                  #61

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

                  liv-in-skyL 2 Antworten Letzte Antwort
                  0
                  • coyoteC coyote

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

                    liv-in-skyL Offline
                    liv-in-skyL Offline
                    liv-in-sky
                    schrieb am zuletzt editiert von
                    #62

                    @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";
                    

                    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

                    coyoteC 1 Antwort Letzte Antwort
                    0
                    • liv-in-skyL liv-in-sky

                      @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";
                      
                      coyoteC Offline
                      coyoteC Offline
                      coyote
                      Most Active
                      schrieb am zuletzt editiert von
                      #63

                      @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 :thinking_face:

                      liv-in-skyL 1 Antwort Letzte Antwort
                      0
                      • coyoteC coyote

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

                        liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        schrieb am zuletzt editiert von
                        #64

                        @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

                        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 Antwort Letzte Antwort
                        0
                        • coyoteC coyote

                          @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 :thinking_face:

                          liv-in-skyL Offline
                          liv-in-skyL Offline
                          liv-in-sky
                          schrieb am zuletzt editiert von
                          #65

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

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

                          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

                          coyoteC 1 Antwort Letzte Antwort
                          0
                          • liv-in-skyL liv-in-sky

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

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

                            coyoteC Offline
                            coyoteC Offline
                            coyote
                            Most Active
                            schrieb am zuletzt editiert von
                            #66

                            @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 Antwort Letzte Antwort
                            1
                            • liv-in-skyL liv-in-sky

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

                              dslraserD Offline
                              dslraserD Offline
                              dslraser
                              Forum Testing Most Active
                              schrieb am zuletzt editiert von
                              #67

                              @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-skyL 2 Antworten Letzte Antwort
                              0
                              • dslraserD dslraser

                                @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-skyL Offline
                                liv-in-skyL Offline
                                liv-in-sky
                                schrieb am zuletzt editiert von
                                #68

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

                                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

                                dslraserD 1 Antwort Letzte Antwort
                                0
                                • dslraserD dslraser

                                  @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-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  schrieb am zuletzt editiert von
                                  #69

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

                                  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 Antwort Letzte Antwort
                                  0
                                  • liv-in-skyL liv-in-sky

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

                                    dslraserD Offline
                                    dslraserD Offline
                                    dslraser
                                    Forum Testing Most Active
                                    schrieb am zuletzt editiert von
                                    #70

                                    @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-skyL 1 Antwort Letzte Antwort
                                    0
                                    • liv-in-skyL 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.
                                      dslraserD Offline
                                      dslraserD Offline
                                      dslraser
                                      Forum Testing Most Active
                                      schrieb am zuletzt editiert von
                                      #71

                                      @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-skyL 1 Antwort Letzte Antwort
                                      0
                                      • dslraserD dslraser

                                        @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-skyL Offline
                                        liv-in-skyL Offline
                                        liv-in-sky
                                        schrieb am zuletzt editiert von
                                        #72

                                        @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

                                        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 Antwort Letzte Antwort
                                        0
                                        • dslraserD dslraser

                                          @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-skyL Offline
                                          liv-in-skyL Offline
                                          liv-in-sky
                                          schrieb am zuletzt editiert von
                                          #73

                                          @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

                                          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 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          570

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe