Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Entwicklung
    4. Frage zu subscribeForeignStates() -> ack

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Frage zu subscribeForeignStates() -> ack

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

      Hi,

      ich programmiere gerade 3 Stunden am Stück an einem Adapter und hab gerade eine "Logik-Blockade" 😁

      Mit subscribeForeignStates() überwache ich Datenpunkte von Bewegungsmeldern, Schaltern, etc.
      Die Adapter-Funktion onStateChange() wird ausgeführt, sobald sich der State ändert.

      Soweit, so gut.
      Jetzt kommt es zu meiner Frage bezüglich "Acknowledge", also ack.
      Sobald Bewegungsmelder ausschlägt, ein Wandschalter gedrückt wird, oder ein User in javascript.0.machWas den Datenpunkt-Wert ändert, soll was ausgelöst werden in onStateChange().

      Reicht da ack=false, oder muss ich auch ack=true abfangen, bzw. beides?

      AlCalzone 1 Reply Last reply Reply Quote 0
      • Mic
        Mic Developer last edited by

        Anyone?

        Danke.

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

          ich frag beides ab

          
          onStateChange(id, state) {
          ...
          ...
          ...
          
          if (state && !state.ack) {
          
          ...
          ..
          
          
          Mic 1 Reply Last reply Reply Quote 0
          • Mic
            Mic Developer @arteck last edited by Mic

            @arteck sagte in Frage zu subscribeForeignStates() -> ack:

            if (state && !state.ack) {

            Danke für deine Antwort 🙂

            Aber lt. deinem Code-Beispiel

            if (state && !state.ack) {
            

            ist ack ausgeschlossen (durch && !...im Ausdruck).
            In meinen bisherigen Adaptern mache ich das auch so, aber nur bei den Adapter-eigenen States.

            Was aber, wenn sich ein fremder State ändert, lieber auf ack=false, oder ack=true reagieren, oder in meinem zukünftigen Adapter sogar als Option für jeden Datenpunkt anbieten? 🤔
            Evtl. wäre tatsächlich als Option nicht schlecht, da nicht alle JS-Scripts "true" zurückgeben, etc. 🤔 ☺

            arteck 1 Reply Last reply Reply Quote 0
            • arteck
              arteck Developer Most Active @Mic last edited by

              @Mic es ist nicht ausgeschlossen sonder als eine verneinte "und Anweisung"

              also wenn (state && state.ack == false)

              1 Reply Last reply Reply Quote 0
              • Mic
                Mic Developer last edited by

                Hey @arteck 🙂
                Jetzt verwirrst du mich noch mehr 😉 mit deinem

                ich frag beides ab

                Also das hier:

                if (state && !state.ack) {

                if (state) prüft ja das State-Objekt auf truthly: All values are truthy unless they are defined as falsy (i.e., except for false, 0, -0, 0n, "", null, undefined, and NaN).

                Dann wird geprüft (durch &&) :
                if (!state.ack). Wenn kein acknowledge, dann geht es ins else bzw. in die leere...

                arteck 1 Reply Last reply Reply Quote 0
                • arteck
                  arteck Developer Most Active @Mic last edited by

                  @Mic

                  jo genau so... wie du es beschreibst...

                  aber das sind eigene States.. bei fremden .. hmm gute frage..

                  1 Reply Last reply Reply Quote 1
                  • AlCalzone
                    AlCalzone Developer @Mic last edited by

                    @Mic sagte in Frage zu subscribeForeignStates() -> ack:

                    Sobald Bewegungsmelder ausschlägt, ein Wandschalter gedrückt wird, oder ein User in javascript.0.machWas den Datenpunkt-Wert ändert, soll was ausgelöst werden in onStateChange().
                    Reicht da ack=false, oder muss ich auch ack=true abfangen, bzw. beides?

                    Bei anderen Adaptern solltest du davon ausgehen, dass die States erst "gültig" bzw. bestätigt sind, wenn ack: true.

                    States mit ack: false zu setzen, ist eine Aufforderung an den dazugehörigen Adapter (oder Skript), diese Änderung zu verarbeiten.

                    Mic 1 Reply Last reply Reply Quote 1
                    • Mic
                      Mic Developer @AlCalzone last edited by

                      Danke @AlCalzone

                      Evtl. wäre es sinnvoll, im Adapter eine Option anbieten, bei User-Datenpunkten unterhalb javascript.x und 0_userdata.0 auch auf ack:false zu reagieren... 🤔 Also grad wenn user-eigene Scripts das nicht so sauber machen... Mal sehen 🙂

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

                        Der Beitrag ist zwar schon alt, aber vielleicht kommt ja nochmal jemand her und fragt sich zu dem Thema.

                        Ich frage alle states auf ACK true ab, außer die eigenen und die von Javascript und Userdata - also startsWith.

                        mcm1957 1 Reply Last reply Reply Quote 0
                        • mcm1957
                          mcm1957 @SKB last edited by mcm1957

                          @skb said in Frage zu subscribeForeignStates() -> ack:

                          Der Beitrag ist zwar schon alt, aber vielleicht kommt ja nochmal jemand her und fragt sich zu dem Thema.

                          Ich frage alle states auf ACK true ab, außer die von Javascript und Userdata - also startsWith.

                          Das wäre aber fehlerhaft wenn es sich um Adaptercode handelt.

                          Adaptercode sollte / darf bei eigenen States NUR auf externe Writes ('state writeable') mit ACK=FALSE reagieren. Alles andere kann man zwar programmieren ist aber einer Verletzung der ioBroker Philosophie.

                          Oder zusammengefasst:

                          • eigene States des Adapters

                            • die von externen Quellen beschrieben werden (= Input):
                              nur state changes mit ack=false sind zu beachten
                            • die selbst vom Adaptercode beschrieben werden (= eher seltener Sonderfall dass der Code diese Änderungen per subscribe überwacht):
                              ack je nach dahinetrstehender Logik beliebig zu beachten
                          • States eines anderen Adapters
                            normalerweise sind hier nur state changes mit ack=true zu beachten, d.h. der fremde Adapter hat einen bestätigten Wert geschrieben. Alternativen sind je nach Logik denkbar

                          • States im 0_user_0 Bereich
                            wären prinzipiell analog zu fremden States zu betrachten. Die meisten Adapter ignorieren hier allerdings das ack Flag aus Komfortgründen für die User.

                          Siehe auch: https://forum.iobroker.net/topic/61876/bestätigt-acknowledged-flag-bedeutung-ein-mysterium

                          Zitat aus obigem Beitrag:

                          Jeder Adapter sollte jegliche Wertänderungen mit ack=true einfach ignorieren und nichts tun! Falls er es doch tut ist es ein Sonderfall oder ein Bug im Adapter

                          SKB 1 Reply Last reply Reply Quote 1
                          • SKB
                            SKB Developer Most Active @mcm1957 last edited by

                            @mcm1957 wieso fehlerhaft?

                            Viele User schreiben ihre Skripts oder Blockly nicht sauber und haben demnach kein ACK true mit dabei.

                            Daher reagiere ich in den Fällen nicht drauf, was so absolut ok ist!

                            Eigene states des Adapters bearbeite ich auch mit ACK false, da der Adapter ja damit etwas tun soll und diesen dann bestätigt.

                            mcm1957 1 Reply Last reply Reply Quote 0
                            • mcm1957
                              mcm1957 @SKB last edited by mcm1957

                              @skb

                              Wenn der User mit ACK=TRUE in einen State deines Adapters schreibt um zB. eine Einstellung zu ändern, dann ist dieser Schreibvorgang zu ignorieren. Siehe auch Apollon77s Beitrag. Alles andere ist (von etwaigen Sonderfällen mal abgesehen) schlicht und einfach falsch.

                              Wenn die States eines fremden Adapters überwachst um z.B. Werte die ein anderer Adapter schreibt zu verarbeiten, dann solltest du nur Werte mit ack = true beachten.

                              Viele User schreiben ihre Skripts oder Blockly nicht sauber und haben demnach kein ACK true mit dabei.

                              Daher reagiere ich in den Fällen nicht drauf, was so absolut ok ist!

                              Wenn es sich um eigene States deines Adapter handelt dann ist das ja OK. Du darfst ja eben NUR mit ack=false regieren! Wenn es sich um fremde States handelt, solltes du ack=false eher ignorieren.

                              Nur weil User das das ack Flag falsch verwenden und zB. Einstellungen mit ack=true schrieben ist das noch kein Grund dass sich ein Adapter falsch verhält.

                              In jedem fall fehlt in obiger Aussage um welcghe States (die deines Adapters, welche in 0:userdate_0, etc.) es sich handelt.

                              SKB 1 Reply Last reply Reply Quote 0
                              • SKB
                                SKB Developer Most Active @mcm1957 last edited by

                                @mcm1957 entspricht ja nicht meiner Aussage!

                                Eigene Adapter states werden nur mit ACK false beachtet, bei Javascript und userdatata beachte ich beides! Andere Adapter nur mit ACK true.

                                So, wie es richtig ist!

                                mcm1957 1 Reply Last reply Reply Quote 0
                                • mcm1957
                                  mcm1957 @SKB last edited by mcm1957

                                  @skb said in Frage zu subscribeForeignStates() -> ack:

                                  @mcm1957 entspricht ja nicht meiner Aussage!

                                  Eigene Adapter states werden nur mit ACK false beachtet, bei Javascript und userdatata beachte ich beides! Andere Adapter nur mit ACK true.

                                  So, wie es richtig ist!

                                  Das ist vollkommen RICHTIG

                                  In deinem ersten Beitrag fehlte nur ursprünglich das "eigenen" und damit entstand der Eindruck dass du Schreibvorgänge auf die eigenen States mit ack=true erwartest. Und das wäre falsch. Nach deiner obigen Korrektur ist es nun OK.

                                  SKB 1 Reply Last reply Reply Quote 1
                                  • SKB
                                    SKB Developer Most Active @mcm1957 last edited by

                                    @mcm1957 mehr sagte ich ja oben auch nicht 😉

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

                                    Support us

                                    ioBroker
                                    Community Adapters
                                    Donate

                                    607
                                    Online

                                    31.6k
                                    Users

                                    79.6k
                                    Topics

                                    1.3m
                                    Posts

                                    adapter entwicklung subscribeforeignstates
                                    5
                                    16
                                    859
                                    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