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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Blockly
  5. Skript löst "fälschlicherweise" aus

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    21
    1
    923

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

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

Skript löst "fälschlicherweise" aus

Scheduled Pinned Locked Moved Blockly
24 Posts 4 Posters 571 Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • David G.D Offline
    David G.D Offline
    David G.
    wrote on last edited by
    #1

    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.

    Zeigt eure Lovelace-Visualisierung klick
    (Auch ideal um sich Anregungen zu holen)

    Meine Tabellen für eure Visualisierung klick

    CodierknechtC 1 Reply Last reply
    0
    • David G.D David G.

      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.

      CodierknechtC Online
      CodierknechtC Online
      Codierknecht
      Developer Most Active
      wrote on last edited by
      #2

      @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

      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
      HmIP|ZigBee|Tasmota|Unifi
      Zabbix Certified Specialist
      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

      David G.D 1 Reply Last reply
      0
      • CodierknechtC Codierknecht

        @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.D Offline
        David G.D Offline
        David G.
        wrote on last edited by David G.
        #3

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

        Zeigt eure Lovelace-Visualisierung klick
        (Auch ideal um sich Anregungen zu holen)

        Meine Tabellen für eure Visualisierung klick

        CodierknechtC 1 Reply Last reply
        0
        • David G.D 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?

          CodierknechtC Online
          CodierknechtC Online
          Codierknecht
          Developer Most Active
          wrote on last edited by
          #4

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

          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

          Proxmox 9.1.1 LXC|8 GB|Core i7-6700
          HmIP|ZigBee|Tasmota|Unifi
          Zabbix Certified Specialist
          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

          David G.D ? 2 Replies Last reply
          0
          • CodierknechtC Codierknecht

            @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.D Offline
            David G.D Offline
            David G.
            wrote on last edited by David G.
            #5

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

            Zeigt eure Lovelace-Visualisierung klick
            (Auch ideal um sich Anregungen zu holen)

            Meine Tabellen für eure Visualisierung klick

            paul53P CodierknechtC 2 Replies Last reply
            0
            • David G.D 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?

              paul53P Offline
              paul53P Offline
              paul53
              wrote on last edited by
              #6

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

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              David G.D 1 Reply Last reply
              0
              • David G.D 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?

                CodierknechtC Online
                CodierknechtC Online
                Codierknecht
                Developer Most Active
                wrote on last edited by
                #7

                @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);
                
                });
                

                "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                HmIP|ZigBee|Tasmota|Unifi
                Zabbix Certified Specialist
                Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                1 Reply Last reply
                0
                • paul53P paul53

                  @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.D Offline
                  David G.D Offline
                  David G.
                  wrote on last edited by
                  #8

                  @paul53

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

                  Zeigt eure Lovelace-Visualisierung klick
                  (Auch ideal um sich Anregungen zu holen)

                  Meine Tabellen für eure Visualisierung klick

                  1 Reply Last reply
                  0
                  • CodierknechtC Codierknecht

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

                    ? Offline
                    ? Offline
                    A Former User
                    wrote on last edited by
                    #9

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

                    CodierknechtC David G.D 3 Replies Last reply
                    0
                    • ? A Former User

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

                      CodierknechtC Online
                      CodierknechtC Online
                      Codierknecht
                      Developer Most Active
                      wrote on last edited by Codierknecht
                      #10

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

                      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                      HmIP|ZigBee|Tasmota|Unifi
                      Zabbix Certified Specialist
                      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                      1 Reply Last reply
                      0
                      • ? A Former User

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

                        David G.D Offline
                        David G.D Offline
                        David G.
                        wrote on last edited by
                        #11

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

                        Zeigt eure Lovelace-Visualisierung klick
                        (Auch ideal um sich Anregungen zu holen)

                        Meine Tabellen für eure Visualisierung klick

                        ? 1 Reply Last reply
                        0
                        • ? A Former User

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

                          CodierknechtC Online
                          CodierknechtC Online
                          Codierknecht
                          Developer Most Active
                          wrote on last edited by Codierknecht
                          #12

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

                          Edit: Aktualisierungsintervall des Adapters steht auf 30 Sekunden!

                          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                          Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                          HmIP|ZigBee|Tasmota|Unifi
                          Zabbix Certified Specialist
                          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                          paul53P 1 Reply Last reply
                          0
                          • David G.D David G.

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

                            ? Offline
                            ? Offline
                            A Former User
                            wrote on last edited by
                            #13

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

                            1 Reply Last reply
                            0
                            • CodierknechtC Codierknecht

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

                              Edit: Aktualisierungsintervall des Adapters steht auf 30 Sekunden!

                              paul53P Offline
                              paul53P Offline
                              paul53
                              wrote on last edited by
                              #14

                              @codierknecht sagte: Das ist das Ergebnis:

                              Teste mal mit:

                              on('device-watcher.0.lowBatteryList', function(dp) {
                                  log(dp.oldState);
                                  log(dp.state);
                              });
                              

                              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                              ? CodierknechtC 2 Replies Last reply
                              0
                              • paul53P paul53

                                @codierknecht sagte: Das ist das Ergebnis:

                                Teste mal mit:

                                on('device-watcher.0.lowBatteryList', function(dp) {
                                    log(dp.oldState);
                                    log(dp.state);
                                });
                                
                                ? Offline
                                ? Offline
                                A Former User
                                wrote on last edited by
                                #15

                                @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'}
                                
                                paul53P 1 Reply Last reply
                                0
                                • ? A Former User

                                  @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'}
                                  
                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  wrote on last edited by
                                  #16

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

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  ? 1 Reply Last reply
                                  0
                                  • paul53P paul53

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

                                    ? Offline
                                    ? Offline
                                    A Former User
                                    wrote on last edited by
                                    #17

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

                                    CodierknechtC 1 Reply Last reply
                                    0
                                    • David G.D Offline
                                      David G.D Offline
                                      David G.
                                      wrote on last edited by
                                      #18

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

                                      Zeigt eure Lovelace-Visualisierung klick
                                      (Auch ideal um sich Anregungen zu holen)

                                      Meine Tabellen für eure Visualisierung klick

                                      1 Reply Last reply
                                      0
                                      • paul53P paul53

                                        @codierknecht sagte: Das ist das Ergebnis:

                                        Teste mal mit:

                                        on('device-watcher.0.lowBatteryList', function(dp) {
                                            log(dp.oldState);
                                            log(dp.state);
                                        });
                                        
                                        CodierknechtC Online
                                        CodierknechtC Online
                                        Codierknecht
                                        Developer Most Active
                                        wrote on last edited by
                                        #19

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

                                        "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                                        Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                                        HmIP|ZigBee|Tasmota|Unifi
                                        Zabbix Certified Specialist
                                        Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                                        1 Reply Last reply
                                        0
                                        • ? A Former User

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

                                          CodierknechtC Online
                                          CodierknechtC Online
                                          Codierknecht
                                          Developer Most Active
                                          wrote on last edited by Codierknecht
                                          #20

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

                                          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                                          Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                                          HmIP|ZigBee|Tasmota|Unifi
                                          Zabbix Certified Specialist
                                          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                                          ? 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          788

                                          Online

                                          32.5k

                                          Users

                                          81.6k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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