Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Skript löst "fälschlicherweise" aus

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Skript löst "fälschlicherweise" aus

    This topic has been deleted. Only users with topic management privileges can see it.
    • David G.
      David G. last edited by

      Hallo,

      ich habe für einen User im Forum folgendes Skript erstellt:

      Screenshot_20230215_153247_Chrome.jpg

      <block xmlns="https://developers.google.com/blockly/xml" type="on" id="p~];J,|S!,qe[mt|t$)5" x="-112" y="413">
       <field name="OID">device-watcher.0.devices.lowBatteryList</field>
       <field name="CONDITION">ne</field>
       <field name="ACK_CONDITION"></field>
       <statement name="STATEMENT">
         <block type="variables_set" id="F0WG:qg=jh)].vE@MWbj">
           <field name="VAR" id="zFO+8neFn:/Dd)5d!s.6">mail</field>
           <value name="VALUE">
             <block type="text" id="|~0BPq)@6,Zjlq,f~kbe">
               <field name="TEXT"></field>
             </block>
           </value>
           <next>
             <block type="variables_set" id="8Mj=.k=w4Vh#}34LgK(O">
               <field name="VAR" id="(m}dH@gw]g]CrCq4X:^O">Liste</field>
               <value name="VALUE">
                 <block type="on_source" id="Pcg:+i.].Vgf~,ld#txs">
                   <field name="ATTR">state.val</field>
                 </block>
               </value>
               <next>
                 <block type="controls_for" id="/=cLxbv-`@bYIN$CMD7+">
                   <field name="VAR" id="zAL$s=)3)j7:~-3:iGd@">j</field>
                   <value name="FROM">
                     <shadow type="math_number" id="*q5ha^YNfiySP0SOv!R)">
                       <field name="NUM">1</field>
                     </shadow>
                   </value>
                   <value name="TO">
                     <shadow type="math_number" id="y8ZF8G)(tXE,sU3~GbEp">
                       <field name="NUM">10</field>
                     </shadow>
                     <block type="lists_length" id="T@~.7HWor{dlX{C=_sGs">
                       <value name="VALUE">
                         <block type="variables_get" id="TnSi!3p:th-ZVk8mU6Lm">
                           <field name="VAR" id="(m}dH@gw]g]CrCq4X:^O">Liste</field>
                         </block>
                       </value>
                     </block>
                   </value>
                   <value name="BY">
                     <shadow type="math_number" id="KVz8pnE{baO44Qvv-X!}">
                       <field name="NUM">1</field>
                     </shadow>
                   </value>
                   <statement name="DO">
                     <block type="variables_set" id="}DI5b);r@3kSD84#Bwq|">
                       <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                       <value name="VALUE">
                         <block type="lists_getIndex" id="oNNM2VfP7U?y`NZOa5w3">
                           <mutation statement="false" at="true"></mutation>
                           <field name="MODE">GET</field>
                           <field name="WHERE">FROM_START</field>
                           <value name="VALUE">
                             <block type="variables_get" id="uL6x#IJi:5{^eHZ%l^^r">
                               <field name="VAR" id="(m}dH@gw]g]CrCq4X:^O">Liste</field>
                             </block>
                           </value>
                           <value name="AT">
                             <block type="variables_get" id="e93ZXe:;1zc^bchT]%gU">
                               <field name="VAR" id="zAL$s=)3)j7:~-3:iGd@">j</field>
                             </block>
                           </value>
                         </block>
                       </value>
                       <next>
                         <block type="variables_set" id="~SU~MbmA,yn3vRS=]Q~M">
                           <field name="VAR" id="f?3n8ZjQFS#}%A8DqW?=">Device</field>
                           <value name="VALUE">
                             <block type="get_attr" id="[zEC?+nZKa~4v!?0^fXP">
                               <value name="PATH">
                                 <shadow type="text" id="X5MvQwB%1RHimz~-3q@N">
                                   <field name="TEXT">Device</field>
                                 </shadow>
                               </value>
                               <value name="OBJECT">
                                 <block type="variables_get" id="pv(FH,1HP0$-(Q@-9#_%">
                                   <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                 </block>
                               </value>
                             </block>
                           </value>
                           <next>
                             <block type="variables_set" id="]F6jOk9c5~qxZ}7[OcMf">
                               <field name="VAR" id="lUcGMpKcT/DK[V2YRn9}">Adapter</field>
                               <value name="VALUE">
                                 <block type="get_attr" id="REoGjmX(cpwi.8G|!~i*">
                                   <value name="PATH">
                                     <shadow type="text" id=";F{CV29~=ysctl_rzrSo">
                                       <field name="TEXT">Adapter</field>
                                     </shadow>
                                   </value>
                                   <value name="OBJECT">
                                     <block type="variables_get" id="#gF@]i-pR:;JIh|3HFa6">
                                       <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                     </block>
                                   </value>
                                 </block>
                               </value>
                               <next>
                                 <block type="variables_set" id="ay@CGCCg{/YI](?k[QN#">
                                   <field name="VAR" id="zFO+8neFn:/Dd)5d!s.6">mail</field>
                                   <value name="VALUE">
                                     <block type="text_join" id="u456i^G:Y)/8}U6~UeOK">
                                       <mutation items="5"></mutation>
                                       <value name="ADD0">
                                         <block type="variables_get" id="U3];}l~(3Ap}oUi.Y!7;">
                                           <field name="VAR" id="zFO+8neFn:/Dd)5d!s.6">mail</field>
                                         </block>
                                       </value>
                                       <value name="ADD1">
                                         <block type="variables_get" id="qX)RYmfz?C:5meq0b1/[">
                                           <field name="VAR" id="lUcGMpKcT/DK[V2YRn9}">Adapter</field>
                                         </block>
                                       </value>
                                       <value name="ADD2">
                                         <block type="text" id="D0B?mt4f;GdF.ag8gU2x">
                                           <field name="TEXT">: </field>
                                         </block>
                                       </value>
                                       <value name="ADD3">
                                         <block type="variables_get" id="C9]6;Ety-V.[!S=+3s[d">
                                           <field name="VAR" id="f?3n8ZjQFS#}%A8DqW?=">Device</field>
                                         </block>
                                       </value>
                                       <value name="ADD4">
                                         <block type="text_newline" id="6H6ER)Si)e-+`UMrGmbg">
                                           <field name="Type">\n</field>
                                         </block>
                                       </value>
                                     </block>
                                   </value>
                                   <next>
                                     <block type="debug" id="jPewu:=,,W[{B[+b8i1M">
                                       <field name="Severity">warn</field>
                                       <value name="TEXT">
                                         <shadow type="text" id="-h/S-HCbO;9C-K9V7zUQ">
                                           <field name="TEXT">test</field>
                                         </shadow>
                                         <block type="variables_get" id="n87aF7!ymZzS!+a+k$3C">
                                           <field name="VAR" id="f?3n8ZjQFS#}%A8DqW?=">Device</field>
                                         </block>
                                       </value>
                                     </block>
                                   </next>
                                 </block>
                               </next>
                             </block>
                           </next>
                         </block>
                       </next>
                     </block>
                   </statement>
                   <next>
                     <block type="email" id="Ts%iYB$79,+SU.kqxKI*">
                       <field name="INSTANCE"></field>
                       <field name="IS_HTML">FALSE</field>
                       <field name="LOG"></field>
                       <value name="TO">
                         <shadow type="text" id="|j@({E{U%*SaGTI$R^?5">
                           <field name="TEXT"></field>
                         </shadow>
                       </value>
                       <value name="TEXT">
                         <shadow type="text" id="9(yqZT-e0[f-L1kzrtXy">
                           <field name="TEXT"></field>
                         </shadow>
                         <block type="text_join" id="Tx^@?dVHe4%bh#,Y[Pw!">
                           <mutation items="3"></mutation>
                           <value name="ADD0">
                             <block type="text" id="lMYQrBXjhc-V{Dt@#$9D">
                               <field name="TEXT">Folgende Geräte haben einen niedrigen Batteriestand:</field>
                             </block>
                           </value>
                           <value name="ADD1">
                             <block type="text_newline" id=":b}{?*41uHGA@e`{RIg{">
                               <field name="Type">\n</field>
                             </block>
                           </value>
                           <value name="ADD2">
                             <block type="variables_get" id="AxXlk;4!d}J][7scn~4@">
                               <field name="VAR" id="zFO+8neFn:/Dd)5d!s.6">mail</field>
                             </block>
                           </value>
                         </block>
                       </value>
                       <value name="SUBJECT">
                         <shadow type="text" id="RiW`G=|5^M/Pd:4)HSKb">
                           <field name="TEXT">Batteriemeldung</field>
                         </shadow>
                       </value>
                     </block>
                   </next>
                 </block>
               </next>
             </block>
           </next>
         </block>
       </statement>
      </block>
      

      Komischerweise löst es bei mir alle 10 Sekunden aus (Aktualisierungsintervall vom Device-Watcher Adapter).

      Wenn ich mir jedoch unter den Objekten anschaue, wann der Datenpunkt zuletzt geändert wurde, sehe ich, dass dies gestern geschehen ist.

      Screenshot_20230215_161253_Chrome.jpg

      Woran kann das liegen? Habe ich noch nie beobachtet sowas.

      Codierknecht 1 Reply Last reply Reply Quote 0
      • Codierknecht
        Codierknecht Developer Most Active @David G. last edited by

        @david-g
        Den Effekt kann ich ebenfalls beobachten.
        Aber das Senden der Mail lässt sich ja recht einfach unterdrücken. Vorschlag:
        28e868db-b7d3-41c5-851a-936b67752db9-grafik.png

        David G. 1 Reply Last reply Reply Quote 0
        • David G.
          David G. @Codierknecht last edited by David G.

          @Codierknecht

          Hast du das Verhalten auch nur in Verbindung mit dem Device-Watcher Adapter oder auch woanders?

          Ich selber nutze das Skript nicht.

          Was bewirkt der Falls Block?
          Da ich keinen boolischen Wert prüfe ist denke alles größer 0 "wahr" oder?

          Dann geht die Mail doch trotzdem so oft raus wenn min 1 Device leer ist?

          Mich würde interessieren, warum der Trigger so oft auslöst. Es liegt ja keine Änderung vor.
          Ist es ein Fehler vom Javascript Adapter, vom iobroker oder vom device Watcher?

          Codierknecht 1 Reply Last reply Reply Quote 0
          • Codierknecht
            Codierknecht Developer Most Active @David G. last edited by

            @david-g
            Gute Frage(n).
            Hab' nur mit Device-Watcher getestet. Aber wenn's bei anderen auch wäre, würden die mir ständig etwas schicken. Und auch beim Device-Watcher ist das seltsam ... bei Geräte-Offline passiert das nicht.
            Bei mir wurde der Trigger auch alle paar Sekunden ausgeführt - obwohl keines der Geräte schwache Batterien hatte. Etwas seltsam, da der Trigger ja auch "wurde geändert" und nicht auf "wurde aktualisiert" sitzt. Und das "Falls" stellt nur sicher, dass zumindest bei 0 Geräten keine Meldung kommt.

            Könnte man jetzt mit 'nem Workaround umgehen.
            Man merkt sich die Geräte in einer Variablen und prüft vor dem Versand der Nachricht, ob der Inhalt sich vom aktuell ermittelten unterscheidet.
            Zum Beispiel alle Devicenamen nacheinander als string in die Variable schreiben.
            Im Trigger macht man das mit den aktuellen Devices nochmal und vergleicht die beiden Variablen.
            Nur wenn die sich unterscheiden, werden die jetzt gefundenen Geräte ich die "Merk"-Variable geschrieben und die Nachricht verschickt.
            Ist aber nur ein rumdoktorn an den Symptomen - eigentlich sollte das (zumindest nach meiner Theorie) gar nicht passieren. Es hat sich ja nicht tatsächlich etwas geändert.

            Mach doch in GitHub ein Issue auf.

            David G. ? 2 Replies Last reply Reply Quote 0
            • David G.
              David G. @Codierknecht last edited by David G.

              @codierknecht

              Die Frage ist, wo ich es auf mache.
              Mit dem dev vom device Watcher @ciddi89 hatte ich schon Kontakt.

              Am ehsten im Javascript Adapter oder?

              paul53 Codierknecht 2 Replies Last reply Reply Quote 0
              • paul53
                paul53 @David G. last edited by

                @david-g sagte: Am ehsten im Javascript Adapter oder?

                Eher nicht. Es muss ein besonderes Verhalten des Datenpunktes des Watcher-Adapters sein. Hat er ein state.expire?

                David G. 1 Reply Last reply Reply Quote 0
                • Codierknecht
                  Codierknecht Developer Most Active @David G. last edited by

                  @david-g
                  Ich hab' noch 'ne andere Idee:
                  Für meine Offline-Warnung triggere ich auf "offlineCount".
                  Wenn sich das ändert, lese ich den Inhalt von "offlineList" und arbeite die ab.

                  Das ließe sich mit wenig Aufwand auf "lowBattery" ummodeln.

                  var active = false;
                  var timeout;
                  
                  on({id: "device-watcher.0.offlineCount", change: "ne"}, async function (obj) {
                  
                      (function () {if (timeout) {clearTimeout(timeout); timeout = null;}})(); // alle laufenden Timer beenden
                  
                      // die eigentliche Prüfung erfolgt erst nach einem Timeout von 60 Sekunden,
                      // damit kurzzeitige Ausfälle nicht gemeldet werden müssen
                      timeout = setTimeout(async function () {
                          var offlineCount = obj.state.val;
                          if (offlineCount > 0) {
                              active = true;
                              var devices = getState("device-watcher.0.offlineList").val;
                              var message = 'ACHTUNG: ' + offlineCount + ' Gerät(e) offline:\n';
                              for (var i = 0; i < devices.length; i++) {
                                  message += devices[i].Device + '\n';
                              }
                          } else {
                              if (active) message = 'Alle Geräte sind online!';
                              active = false;
                          }
                          sendSignalMessage(message, mobileNumber);
                      }, 60000);
                  
                  });
                  
                  1 Reply Last reply Reply Quote 0
                  • David G.
                    David G. @paul53 last edited by

                    @paul53

                    Wie kann ich das prüfen?
                    Sonst müsste @ciddi89 mal nach schauen.

                    1 Reply Last reply Reply Quote 0
                    • ?
                      A Former User @Codierknecht last edited by

                      @codierknecht man sieht schon am Zeitstempel ‚zuletzt geändert‘ das sich da inhaltlich nichts geändert hat sondern nur aktualisiert wurde. Daher sollte der trigger garnicht auslösen. Wäre interessant zu wissen ob es auch bei anderen Datenpunkten der Fall ist oder nur hier. Habt ihr mal den Export blockly für mich damit ich auch mal testen kann?

                      Codierknecht David G. 3 Replies Last reply Reply Quote 0
                      • Codierknecht
                        Codierknecht Developer Most Active @Guest last edited by Codierknecht

                        @ciddi89

                        <xml xmlns="https://developers.google.com/blockly/xml">
                          <variables>
                            <variable id="bhZlx3!hSc?sjp*V4Q`E">liste</variable>
                            <variable id="4)UVHmM{XPXRM28y.|3,">obj</variable>
                          </variables>
                          <block type="on" id="YgiA/=!`3gaZ_y1oWYQO" x="88" y="213">
                            <field name="OID">device-watcher.0.lowBatteryList</field>
                            <field name="CONDITION">ne</field>
                            <field name="ACK_CONDITION"></field>
                            <statement name="STATEMENT">
                              <block type="variables_set" id="shOIp|-,)1QyBw~ccrcx">
                                <field name="VAR" id="bhZlx3!hSc?sjp*V4Q`E">liste</field>
                                <value name="VALUE">
                                  <block type="on_source" id="~4{dPD;LII$3v]wtj)bc">
                                    <field name="ATTR">state.val</field>
                                  </block>
                                </value>
                                <next>
                                  <block type="controls_forEach" id="`1%S^g=$~m-2@5V,2A%A">
                                    <field name="VAR" id="4)UVHmM{XPXRM28y.|3,">obj</field>
                                    <value name="LIST">
                                      <block type="variables_get" id="Hl{8^KvH+5Ds4lf+1u2n">
                                        <field name="VAR" id="bhZlx3!hSc?sjp*V4Q`E">liste</field>
                                      </block>
                                    </value>
                                    <statement name="DO">
                                      <block type="debug" id="~Ut55bl(S:!f-?%BQ=tT">
                                        <field name="Severity">log</field>
                                        <value name="TEXT">
                                          <shadow type="text" id="}7jzalime5-*9Xp:(4ZG">
                                            <field name="TEXT">test</field>
                                          </shadow>
                                          <block type="get_attr" id="2N7H,vR6SLlKD2a8^lYi">
                                            <value name="PATH">
                                              <shadow type="text" id="xn}WN)W^k|V=L)9^Lu47">
                                                <field name="TEXT">Device</field>
                                              </shadow>
                                            </value>
                                            <value name="OBJECT">
                                              <block type="variables_get" id="OPi.o}#]R0i}=KM|Y-Lv">
                                                <field name="VAR" id="4)UVHmM{XPXRM28y.|3,">obj</field>
                                              </block>
                                            </value>
                                          </block>
                                        </value>
                                      </block>
                                    </statement>
                                  </block>
                                </next>
                              </block>
                            </statement>
                          </block>
                        </xml>
                        

                        Edit: Nochmal korrigiert, da noch die Prüfung drin war.

                        1 Reply Last reply Reply Quote 0
                        • David G.
                          David G. @Guest last edited by

                          @ciddi89

                          In meinem Eingangspost.

                          @paul53 hatte noch eine Frage.
                          Kann ich aber nichts mit anfangen.....

                          @paul53 sagte in Skript löst "fälschlicherweise" aus:

                          @david-g sagte: Am ehsten im Javascript Adapter oder?

                          Eher nicht. Es muss ein besonderes Verhalten des Datenpunktes des Watcher-Adapters sein. Hat er ein state.expire?

                          ? 1 Reply Last reply Reply Quote 0
                          • Codierknecht
                            Codierknecht Developer Most Active @Guest last edited by Codierknecht

                            @ciddi89
                            Das ist das Ergebnis:
                            5c2ae882-223a-4cff-a44f-9391afe3e9be-grafik.png

                            Edit: Aktualisierungsintervall des Adapters steht auf 30 Sekunden!

                            paul53 1 Reply Last reply Reply Quote 0
                            • ?
                              A Former User @David G. last edited by

                              @david-g ne hat er nicht. Und alle Datenpunkte werden gleich erstellt. Daher codemäßig ist da kein unterschied.

                              1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 @Codierknecht last edited by

                                @codierknecht sagte: Das ist das Ergebnis:

                                Teste mal mit:

                                on('device-watcher.0.lowBatteryList', function(dp) {
                                    log(dp.oldState);
                                    log(dp.state);
                                });
                                
                                ? Codierknecht 2 Replies Last reply Reply Quote 0
                                • ?
                                  A Former User @paul53 last edited by

                                  @paul53 said in Skript löst "fälschlicherweise" aus:

                                                                                                                                                              on('device-watcher.0.lowBatteryList', function(dp) {                                                                                                                                                                                log(dp.oldState);                                                                                                                                                                                log(dp.state);                                                                                                                                                                            });
                                  
                                  23:42:57.860	info	javascript.0 (544) script.js.Vorlagen.Skript_1: {'val':[{'Device':'Büro Bewegungsmelder','Adapter':'Zigbee2MQTT','Battery':'21%'}],'ts':1676500962641,'ack':true,'lc':1676499209986,'from':'system.adapter.device-watcher.0','q':0,'user':'system.user.admin'}
                                  23:42:57.860	info	javascript.0 (544) script.js.Vorlagen.Skript_1: {'val':[{'Device':'Büro Bewegungsmelder','Adapter':'Zigbee2MQTT','Battery':'21%'}],'ts':1676500977819,'ack':true,'lc':1676499209986,'from':'system.adapter.device-watcher.0','q':0,'user':'system.user.admin'}
                                  
                                  paul53 1 Reply Last reply Reply Quote 0
                                  • paul53
                                    paul53 @Guest last edited by

                                    @ciddi89
                                    Außer ts alles identisch, also hätte nicht getriggert werden dürfen.

                                    ? 1 Reply Last reply Reply Quote 0
                                    • ?
                                      A Former User @paul53 last edited by

                                      @paul53 ja mein reden. Das ist wirklich sehr merkwürdig.

                                      Codierknecht 1 Reply Last reply Reply Quote 0
                                      • David G.
                                        David G. last edited by

                                        Im Admin leuchten bei mir auch alle 10sek 4 Datenpunkte (wo es auch Sinn macht) grün auf.

                                        Der hier betroffene ist nicht bei.

                                        Somit scheint ja "theoretisch" alles zu stimmen.....

                                        1 Reply Last reply Reply Quote 0
                                        • Codierknecht
                                          Codierknecht Developer Most Active @paul53 last edited by

                                          @paul53
                                          Ich hab's gerade mal mit lowBatteryList und auch mit offlineList getestet. Beide Trigger werden passend zum eingestellten Aktualisierungsintervall des Adapters ausgeführt. Und wie bei @ciddi89 ändert sich nur ts.

                                          Triggere ich dagegen auf lowBatteryCount bzw. offlineCount, passiert ... nix. Hier wird der Trigger dann tatsächlich - wie erwartet - nur ausgeführt, wenn sich etwas ändert.

                                          1 Reply Last reply Reply Quote 0
                                          • Codierknecht
                                            Codierknecht Developer Most Active @Guest last edited by Codierknecht

                                            @ciddi89
                                            Was ist denn, wenn Du in writeDatapoints(adptName) aus dem hier:

                                            // list battery low powered
                                            if (this.lowBatteryPoweredCount === 0) {
                                            	// if no device is count, write the JSON List with default value
                                            	this.batteryLowPowered = [{ Device: '--none--', Adapter: '', Battery: '' }];
                                            }
                                            //write JSON list
                                            await this.setStateAsync(`devices.${dpSubFolder}lowBatteryList`, {
                                            	val: JSON.stringify(this.batteryLowPowered),
                                            	ack: true,
                                            });
                                            
                                            

                                            Das hier machst:

                                            // list battery low powered
                                            if (this.lowBatteryPoweredCount === 0) {
                                            	// if no device is count, write the JSON List with default value
                                            	this.batteryLowPowered = [{ Device: '--none--', Adapter: '', Battery: '' }];
                                            } else {
                                              //write JSON list
                                              await this.setStateAsync(`devices.${dpSubFolder}lowBatteryList`, {
                                              	val: JSON.stringify(this.batteryLowPowered),
                                              	ack: true,
                                              });
                                            }
                                            

                                            Das "umgeht" zwar nur das eigentliche Problem, sollte aber helfen.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            860
                                            Online

                                            32.0k
                                            Users

                                            80.5k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            24
                                            563
                                            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