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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Entwicklung
  4. `getForeignStateAsync()` liefert nur `ack: false`

NEWS

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

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

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

`getForeignStateAsync()` liefert nur `ack: false`

Geplant Angeheftet Gesperrt Verschoben Entwicklung
12 Beiträge 5 Kommentatoren 909 Aufrufe 4 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • LoredoL Offline
    LoredoL Offline
    Loredo
    Developer
    schrieb am zuletzt editiert von
    #1

    Hallo,

    bei der Entwicklung des Residents Adapters ist mir aufgefallen, dass die Funktion adapter.getForeignStateAsync() offenbar ein Objekt zurückliefert, bei dem ack immer false ist, obwohl mir z.B. im Admin Adapter angezeigt wird, dass der Datenpunkt zuvor mit ack: true geschrieben wurde. Auch wenn ich den Datenpunkt über den Admin Adapter selbst mit gesetztem ACK Flag geschrieben habe, liefert adapter.getForeignStateAsync() bei der Abfrage des Datenpunktes trotzdem ein ack: false.

    Weiß jemand, woran das liegen könnte?

    VG,
    —Julian

    M haus-automatisierungH L 3 Antworten Letzte Antwort
    0
    • LoredoL Loredo

      Hallo,

      bei der Entwicklung des Residents Adapters ist mir aufgefallen, dass die Funktion adapter.getForeignStateAsync() offenbar ein Objekt zurückliefert, bei dem ack immer false ist, obwohl mir z.B. im Admin Adapter angezeigt wird, dass der Datenpunkt zuvor mit ack: true geschrieben wurde. Auch wenn ich den Datenpunkt über den Admin Adapter selbst mit gesetztem ACK Flag geschrieben habe, liefert adapter.getForeignStateAsync() bei der Abfrage des Datenpunktes trotzdem ein ack: false.

      Weiß jemand, woran das liegen könnte?

      VG,
      —Julian

      M Offline
      M Offline
      Marty56
      schrieb am zuletzt editiert von Marty56
      #2

      @Loredo

      Das ist bei allen Async Funktionen so.
      Ich habe dazu schon vor einigen Wochen ein Issue im Javascript Adapter erstellt und dort auch den BugFix gepostet. Aber es wurde noch nicht eingearbeitet.

      Mit dem Bug sind alle mit Async erweiterten Funktionen im js-controller nicht verwendbar.

      HW:NUC (16 GB Ram)
      OS: Debian Bullseye, Promox V7, node v16.x npm 8.19.3

      LoredoL haus-automatisierungH 2 Antworten Letzte Antwort
      1
      • M Marty56

        @Loredo

        Das ist bei allen Async Funktionen so.
        Ich habe dazu schon vor einigen Wochen ein Issue im Javascript Adapter erstellt und dort auch den BugFix gepostet. Aber es wurde noch nicht eingearbeitet.

        Mit dem Bug sind alle mit Async erweiterten Funktionen im js-controller nicht verwendbar.

        LoredoL Offline
        LoredoL Offline
        Loredo
        Developer
        schrieb am zuletzt editiert von
        #3

        @marty56 Danke! Dann hab ich zumindest keine Tomaten auf den Augen 🙂

        Magst du das von dir erwähnten Issue auf GitHub hier querverlinken? Konnte gerade nichts finden.

        1 Antwort Letzte Antwort
        0
        • LoredoL Loredo

          Hallo,

          bei der Entwicklung des Residents Adapters ist mir aufgefallen, dass die Funktion adapter.getForeignStateAsync() offenbar ein Objekt zurückliefert, bei dem ack immer false ist, obwohl mir z.B. im Admin Adapter angezeigt wird, dass der Datenpunkt zuvor mit ack: true geschrieben wurde. Auch wenn ich den Datenpunkt über den Admin Adapter selbst mit gesetztem ACK Flag geschrieben habe, liefert adapter.getForeignStateAsync() bei der Abfrage des Datenpunktes trotzdem ein ack: false.

          Weiß jemand, woran das liegen könnte?

          VG,
          —Julian

          haus-automatisierungH Offline
          haus-automatisierungH Offline
          haus-automatisierung
          Developer Most Active
          schrieb am zuletzt editiert von haus-automatisierung
          #4

          @loredo sagte in `getForeignStateAsync()` liefert nur `ack: false`:

          liefert adapter.getForeignStateAsync() bei der Abfrage des Datenpunktes trotzdem ein ack: false.

          Das kann ich mir gar nicht vorstellen - das wäre doch längst aufgefallen? Hast Du mal Beispiel-Code dafür?

          EDIT: Gerade getestet und funktioniert.

          const testState = await this.getForeignStateAsync('0_userdata.0.test');
          this.log.error(`Der Wert lautet: ${testState.val} und ack ist ${testState.ack}`);
          

          Ausgabe:

          2023-01-09 16:25:11.731  - error: lametric.0 (1130) Der Wert lautet: 17 und ack ist true
          

          🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
          🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
          📚 Meine inoffizielle ioBroker Dokumentation

          1 Antwort Letzte Antwort
          0
          • M Marty56

            @Loredo

            Das ist bei allen Async Funktionen so.
            Ich habe dazu schon vor einigen Wochen ein Issue im Javascript Adapter erstellt und dort auch den BugFix gepostet. Aber es wurde noch nicht eingearbeitet.

            Mit dem Bug sind alle mit Async erweiterten Funktionen im js-controller nicht verwendbar.

            haus-automatisierungH Offline
            haus-automatisierungH Offline
            haus-automatisierung
            Developer Most Active
            schrieb am zuletzt editiert von
            #5

            @marty56 sagte in `getForeignStateAsync()` liefert nur `ack: false`:

            ein Issue im Javascript Adapter erstellt und dort auch den BugFix gepostet

            Das hat ja nichts mit dem Thema hier zu tun, oder? Du redest vom JavaScript-Adapter, aber @Loredo von den Funktionen in der adapter.js für die Adapter-Entwicklung.

            Meinst Du das hier? https://github.com/ioBroker/ioBroker.javascript/issues/1198

            🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
            🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
            📚 Meine inoffizielle ioBroker Dokumentation

            M 1 Antwort Letzte Antwort
            0
            • haus-automatisierungH haus-automatisierung

              @marty56 sagte in `getForeignStateAsync()` liefert nur `ack: false`:

              ein Issue im Javascript Adapter erstellt und dort auch den BugFix gepostet

              Das hat ja nichts mit dem Thema hier zu tun, oder? Du redest vom JavaScript-Adapter, aber @Loredo von den Funktionen in der adapter.js für die Adapter-Entwicklung.

              Meinst Du das hier? https://github.com/ioBroker/ioBroker.javascript/issues/1198

              M Offline
              M Offline
              Marty56
              schrieb am zuletzt editiert von
              #6

              @haus-automatisierung Genau. Ich bin aber noch nicht dazu gekommen, die GitHub Version zu testen. Komme auch in dieser Woche nicht dazu.

              HW:NUC (16 GB Ram)
              OS: Debian Bullseye, Promox V7, node v16.x npm 8.19.3

              haus-automatisierungH 1 Antwort Letzte Antwort
              0
              • M Marty56

                @haus-automatisierung Genau. Ich bin aber noch nicht dazu gekommen, die GitHub Version zu testen. Komme auch in dieser Woche nicht dazu.

                haus-automatisierungH Offline
                haus-automatisierungH Offline
                haus-automatisierung
                Developer Most Active
                schrieb am zuletzt editiert von
                #7

                @marty56 Ok, aber das hat ja nichts mit dem Thema hier zu tun 🙂

                🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                📚 Meine inoffizielle ioBroker Dokumentation

                1 Antwort Letzte Antwort
                1
                • LoredoL Loredo

                  Hallo,

                  bei der Entwicklung des Residents Adapters ist mir aufgefallen, dass die Funktion adapter.getForeignStateAsync() offenbar ein Objekt zurückliefert, bei dem ack immer false ist, obwohl mir z.B. im Admin Adapter angezeigt wird, dass der Datenpunkt zuvor mit ack: true geschrieben wurde. Auch wenn ich den Datenpunkt über den Admin Adapter selbst mit gesetztem ACK Flag geschrieben habe, liefert adapter.getForeignStateAsync() bei der Abfrage des Datenpunktes trotzdem ein ack: false.

                  Weiß jemand, woran das liegen könnte?

                  VG,
                  —Julian

                  L Offline
                  L Offline
                  Lucky_ESA
                  Developer Most Active
                  schrieb am zuletzt editiert von
                  #8

                  @loredo Kann ich nicht bestätigen.

                              await this.getForeignStateAsync("admin.0.info.connected")
                                  .then(async obj => {
                                      this.log.debug("obj: " + JSON.stringify(obj));
                                  })
                                  .catch(e => this.log.debug("error: " + JSON.stringify(e)));
                  

                  Liefert:

                  
                  2023-01-09 18:45:54.149  - debug: e2-openwebif.0 (2050187) obj: {"val":"[2]admin, admin","ack":true,"ts":1673280014401,"q":0,"from":"system.adapter.admin.0","user":"system.user.admin","lc":1673280014401}
                  

                  Gruß//Lucky

                  GaspodeG 1 Antwort Letzte Antwort
                  0
                  • L Lucky_ESA

                    @loredo Kann ich nicht bestätigen.

                                await this.getForeignStateAsync("admin.0.info.connected")
                                    .then(async obj => {
                                        this.log.debug("obj: " + JSON.stringify(obj));
                                    })
                                    .catch(e => this.log.debug("error: " + JSON.stringify(e)));
                    

                    Liefert:

                    
                    2023-01-09 18:45:54.149  - debug: e2-openwebif.0 (2050187) obj: {"val":"[2]admin, admin","ack":true,"ts":1673280014401,"q":0,"from":"system.adapter.admin.0","user":"system.user.admin","lc":1673280014401}
                    

                    Gruß//Lucky

                    GaspodeG Offline
                    GaspodeG Offline
                    Gaspode
                    schrieb am zuletzt editiert von Gaspode
                    #9

                    @lucky_esa said in `getForeignStateAsync()` liefert nur `ack: false`:

                    @loredo Kann ich nicht bestätigen.

                    Ich auch nicht, d.h. getForeignStateAsync liefert hier auch ack=true, wenn ack=true ist.

                    Davon abgesehen (und sorry für OT und wenn ich dumm frage, bin noch ziemlicher Neuling in der JavaScript Entwicklung):
                    Macht es Sinn, await und then zu mischen?

                    L 1 Antwort Letzte Antwort
                    0
                    • GaspodeG Gaspode

                      @lucky_esa said in `getForeignStateAsync()` liefert nur `ack: false`:

                      @loredo Kann ich nicht bestätigen.

                      Ich auch nicht, d.h. getForeignStateAsync liefert hier auch ack=true, wenn ack=true ist.

                      Davon abgesehen (und sorry für OT und wenn ich dumm frage, bin noch ziemlicher Neuling in der JavaScript Entwicklung):
                      Macht es Sinn, await und then zu mischen?

                      L Offline
                      L Offline
                      Lucky_ESA
                      Developer Most Active
                      schrieb am zuletzt editiert von
                      #10

                      @gaspode

                      Macht es Sinn, await und then zu mischen?

                      Kommt darauf an was du vor hast.

                          await this.getForeignObjectAsync("system.config")
                              .then(async obj => {
                                  this.log.info("obj: " + JSON.stringify(obj));
                              })
                              .catch(e => this.log.info("obj: " + JSON.stringify(e)));
                          this.log.info("Ist getForeignObjectAsync schon fertig?");
                      

                      Ohne await

                      2023-01-09 20:19:44.314  - info: e2-openwebif.0 (2062921) Ist getForeignObjectAsync schon fertig?
                      2023-01-09 20:19:44.338  - info: e2-openwebif.0 (2062921) obj: {"_id":"system.config","type":"config","common":{"name":{"en":"System configuration","de":"Systemkonfiguration","ru":"Конфигурация системы","pt":"Configuração do sistema","nl":"Systeem configuratie","fr":"Configuration du système","it":"Configurazione di sistema","es":"Configuración del sistema","pl":"Konfiguracja systemu","zh-cn":"系统配置"},"city":"Berlin","country":"Germany","longitude":13.28,"latitude":52.5,"language":"de","tempUnit":"°C","currency":"€","dontDelete":true,"dateFormat":"DD.MM.YYYY","isFloatComma":true,"licenseConfirmed":true,"ts":1670753654203}
                      

                      Mit await

                      2023-01-09 20:25:47.703  - info: e2-openwebif.0 (2063727) obj: {"_id":"system.config","type":"config","common":{"name":{"en":"System configuration","de":"Systemkonfiguration","ru":"Конфигурация системы","pt":"Configuração do sistema","nl":"Systeem configuratie","fr":"Configuration du système","it":"Configurazione di sistema","es":"Configuración del sistema","pl":"Konfiguracja systemu","zh-cn":"系统配置"},"city":"Berlin","country":"Germany","longitude":13.28,"latitude":52.5,"language":"de","tempUnit":"°C","currency":"€","dontDelete":true,"dateFormat":"DD.MM.YYYY","isFloatComma":true,"licenseConfirmed":true,"ts":1670753654203}
                      2023-01-09 20:25:47.706  - info: e2-openwebif.0 (2063727) Ist getForeignObjectAsync schon fertig?
                      

                      Gruß//Lucky

                      1 Antwort Letzte Antwort
                      0
                      • LoredoL Offline
                        LoredoL Offline
                        Loredo
                        Developer
                        schrieb am zuletzt editiert von Loredo
                        #11

                        Ich denke, wenn Marty56 sich hier vertan hat, dann können wir das für den Moment auch zu den Akten legen. Den genauen Fall kriege ich nach so vielen Tagen nicht mehr ad-hoc rekonstruiert. Da hätte ich mir eine direktere Rückmeldung gewünscht 😉

                        Aber trotzdem danke an alle, die jetzt noch reagiert und auch mit zeitlichem Aufwand getestet haben!

                        1 Antwort Letzte Antwort
                        0
                        • GaspodeG Offline
                          GaspodeG Offline
                          Gaspode
                          schrieb am zuletzt editiert von
                          #12

                          @Lucky_ESA
                          Sorry nochmal für OT

                          Ja, das ist mir schon klar. Ich hatte await und then als zwei Alternativen verstanden, um das Gleiche zu erreichen. Deshalb hat es mich jetzt gewundert, dass du beides mischst.

                          Ich würde entweder

                          try {
                              const obj = await this.getForeignStateAsync("admin.0.info.connected");
                              this.log.debug("obj: " + JSON.stringify(obj));
                          catch (e) {
                              this.log.debug("error: " + JSON.stringify(e));
                          }
                          

                          oder

                          this.getForeignStateAsync("admin.0.info.connected")
                               .then(async obj => {
                                   this.log.debug("obj: " + JSON.stringify(obj));
                               })
                               .catch(e => this.log.debug("error: " + JSON.stringify(e)));
                          
                          

                          erwarten. Die Mischung aus beidem ist mir bisher nicht über den Weg gelaufen.

                          1 Antwort Letzte Antwort
                          0
                          Antworten
                          • In einem neuen Thema antworten
                          Anmelden zum Antworten
                          • Älteste zuerst
                          • Neuste zuerst
                          • Meiste Stimmen


                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          361

                          Online

                          32.4k

                          Benutzer

                          81.4k

                          Themen

                          1.3m

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

                          • Du hast noch kein Konto? Registrieren

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