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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [gelöst] auf globale Objekt kann nicht zugegriffen werden

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.2k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    946

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

[gelöst] auf globale Objekt kann nicht zugegriffen werden

Geplant Angeheftet Gesperrt Verschoben JavaScript
52 Beiträge 5 Kommentatoren 1.4k Aufrufe 3 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.
  • T ticaki

    @haus-automatisierung sagte in auf globale Objekt kann nicht zugegriffen werden:

    @ticaki sendToAsync funktioniert bei mir wunderbar

    Stoppe den Zieladapter und nutzte dann "sendToAsync" ohne timeout.

    haus-automatisierungH Online
    haus-automatisierungH Online
    haus-automatisierung
    Developer Most Active
    schrieb am zuletzt editiert von
    #27

    @ticaki Bei sendToAsync gibts keinen Timeout - eventuell ist das auch dein Problem? :)

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

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

      @ticaki Bei sendToAsync gibts keinen Timeout - eventuell ist das auch dein Problem? :)

      T Nicht stören
      T Nicht stören
      ticaki
      schrieb am zuletzt editiert von ticaki
      #28

      @haus-automatisierung sagte in auf globale Objekt kann nicht zugegriffen werden:

      @ticaki Bei sendToAsync gibts keinen Timeout - eventuell ist das auch dein Problem? :)

      Das ist ja noch schlimmer, ist mir garnicht aufgefallen, dass das nicht durchgereicht wird. Ohne Temperaturwächter setzte ich kein sendToAsync mehr für Warmwassererhitzung ein.

      Beide SendtoAsync bleiben hängen, wenn telegram ausgeschaltet ist.

      test1()
      test2()
      async function test1() {
          await sendToAsync("telegram", "send", {user: 'Tim', text: 'Test1'});
          log('test1');
      }
      async function test2() {
          await sendToAsync("telegram", "send", {user: 'Tim', text: 'Test2'}, { timeout: 1000 });
          log('test2');
      }
      

      Das hier in meinem Adapter jedoch nicht:

      await this.adapter.sendToAsync(this.options.adapter, 'send', opt, { timeout: 2000 })
      

      https://github.com/ioBroker/ioBroker.javascript/issues/1436

      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

      Spenden

      haus-automatisierungH 1 Antwort Letzte Antwort
      0
      • T ticaki

        @haus-automatisierung sagte in auf globale Objekt kann nicht zugegriffen werden:

        @ticaki Bei sendToAsync gibts keinen Timeout - eventuell ist das auch dein Problem? :)

        Das ist ja noch schlimmer, ist mir garnicht aufgefallen, dass das nicht durchgereicht wird. Ohne Temperaturwächter setzte ich kein sendToAsync mehr für Warmwassererhitzung ein.

        Beide SendtoAsync bleiben hängen, wenn telegram ausgeschaltet ist.

        test1()
        test2()
        async function test1() {
            await sendToAsync("telegram", "send", {user: 'Tim', text: 'Test1'});
            log('test1');
        }
        async function test2() {
            await sendToAsync("telegram", "send", {user: 'Tim', text: 'Test2'}, { timeout: 1000 });
            log('test2');
        }
        

        Das hier in meinem Adapter jedoch nicht:

        await this.adapter.sendToAsync(this.options.adapter, 'send', opt, { timeout: 2000 })
        

        https://github.com/ioBroker/ioBroker.javascript/issues/1436

        haus-automatisierungH Online
        haus-automatisierungH Online
        haus-automatisierung
        Developer Most Active
        schrieb am zuletzt editiert von haus-automatisierung
        #29

        Die Funktion hat nur 3 Parameter, alle weiteren werden ignoriert:

        https://github.com/ioBroker/ioBroker.javascript/blob/41e59dfd72f99027a9a303beee8d4d5597826445/lib/sandbox.js#L2702

        @ticaki sagte in auf globale Objekt kann nicht zugegriffen werden:

        Das hier in meinem Adapter jedoch nicht:

        Im der Adapter-Klasse gibt es noch einen weiteren, richtig:

        https://github.com/ioBroker/ioBroker.js-controller/blob/0b01593055f5ebb61c1a9939a2a962b7b53f7344/packages/adapter/src/lib/adapter/adapter.ts#L7106

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

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

          Die Funktion hat nur 3 Parameter, alle weiteren werden ignoriert:

          https://github.com/ioBroker/ioBroker.javascript/blob/41e59dfd72f99027a9a303beee8d4d5597826445/lib/sandbox.js#L2702

          @ticaki sagte in auf globale Objekt kann nicht zugegriffen werden:

          Das hier in meinem Adapter jedoch nicht:

          Im der Adapter-Klasse gibt es noch einen weiteren, richtig:

          https://github.com/ioBroker/ioBroker.js-controller/blob/0b01593055f5ebb61c1a9939a2a962b7b53f7344/packages/adapter/src/lib/adapter/adapter.ts#L7106

          T Nicht stören
          T Nicht stören
          ticaki
          schrieb am zuletzt editiert von ticaki
          #30

          @haus-automatisierung
          Um wieder etwas on topic zu werden.

          Der timeout sollte(geht halt aktuell nur bei messageToAsync) bei beiden ToAsync gesetzt werden, wenn diese mit await genutzt werden, den wenn der Callback wegen gestopptem Skript/Adapter nicht beantwortet wird, bleibt das Skript an der Stelle stehen.

          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

          Spenden

          haus-automatisierungH 1 Antwort Letzte Antwort
          0
          • T ticaki

            @haus-automatisierung
            Um wieder etwas on topic zu werden.

            Der timeout sollte(geht halt aktuell nur bei messageToAsync) bei beiden ToAsync gesetzt werden, wenn diese mit await genutzt werden, den wenn der Callback wegen gestopptem Skript/Adapter nicht beantwortet wird, bleibt das Skript an der Stelle stehen.

            haus-automatisierungH Online
            haus-automatisierungH Online
            haus-automatisierung
            Developer Most Active
            schrieb am zuletzt editiert von
            #31

            @ticaki Logisch, ist bis dato nur scheinbar niemandem aufgefallen (bzw. wurde nicht gemeldet)

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

            Ben1983B T 2 Antworten Letzte Antwort
            0
            • haus-automatisierungH haus-automatisierung

              @ticaki Logisch, ist bis dato nur scheinbar niemandem aufgefallen (bzw. wurde nicht gemeldet)

              Ben1983B Offline
              Ben1983B Offline
              Ben1983
              schrieb am zuletzt editiert von
              #32

              @haus-automatisierung irgendwie will es heute nicht...

              wieso bekomme ich jetzt keinen Log?

              log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
              
              onMessage("Testmessage",(messagedata,callback) =>{
                  const myData = {input: messagedata,
                                  output:{name:"Test"}};
                  callback(myData)
              });
              
              T 1 Antwort Letzte Antwort
              0
              • haus-automatisierungH haus-automatisierung

                @ticaki Logisch, ist bis dato nur scheinbar niemandem aufgefallen (bzw. wurde nicht gemeldet)

                T Nicht stören
                T Nicht stören
                ticaki
                schrieb am zuletzt editiert von
                #33

                @haus-automatisierung
                Wäre mir wohl so auch nicht klar gewesen aber erste habe ich wegen hängendem sendToAsync im Adapter erfahren dass es da keinen default timeout gibt. Und 2 Tage später fliegen die Leitungen von meinem Boiler und 4 Stunden vorher haben die Logeinträge meines Warmwasserskripts geendet. Da war der Zusammenhang nicht schwer herzustellen. Mist nur das die Überhitzungssicherheitsschaltung zu alt/ kaputt war. Naja, war zum Glück nur ne Riesensauerei.

                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                Spenden

                1 Antwort Letzte Antwort
                0
                • Ben1983B Ben1983

                  @haus-automatisierung irgendwie will es heute nicht...

                  wieso bekomme ich jetzt keinen Log?

                  log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
                  
                  onMessage("Testmessage",(messagedata,callback) =>{
                      const myData = {input: messagedata,
                                      output:{name:"Test"}};
                      callback(myData)
                  });
                  
                  T Nicht stören
                  T Nicht stören
                  ticaki
                  schrieb am zuletzt editiert von ticaki
                  #34

                  @ben1983

                  Das await müsste bei dir eigentlich als Fehler markiert sein.

                  test()
                  
                  async function test() {
                      log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:10000})));
                  }
                   
                  onMessage("Testmessage",(messagedata,callback) =>{
                      const myData = {input: messagedata,
                                      output:{name:"Test"}};
                      callback(myData)
                  });
                  

                  Ach und mit abgestürzter Javascriptinstanze gibts keine logs :D

                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                  Spenden

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

                    @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                    Beim Verwendet von messageToAsynch tritt dieser Fehler auf:

                    Ist wohl nen Bug wenn die Options fehlen. So gehts:

                    const res = await messageToAsync('Testmessage', { flag: true }, { timeout: 5000 });
                    console.log(JSON.stringify(res));
                    

                    Machst einen GitHub Issue?

                    Ben1983B Offline
                    Ben1983B Offline
                    Ben1983
                    schrieb am zuletzt editiert von
                    #35

                    @haus-automatisierung erledigt:
                    https://github.com/ioBroker/ioBroker.javascript/issues/1437

                    1 Antwort Letzte Antwort
                    0
                    • T ticaki

                      @ben1983

                      Das await müsste bei dir eigentlich als Fehler markiert sein.

                      test()
                      
                      async function test() {
                          log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:10000})));
                      }
                       
                      onMessage("Testmessage",(messagedata,callback) =>{
                          const myData = {input: messagedata,
                                          output:{name:"Test"}};
                          callback(myData)
                      });
                      

                      Ach und mit abgestürzter Javascriptinstanze gibts keine logs :D

                      Ben1983B Offline
                      Ben1983B Offline
                      Ben1983
                      schrieb am zuletzt editiert von Ben1983
                      #36

                      @ticaki ok und woran liegt es?
                      Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
                      Woran liegt jetzt der Fehler?
                      Habe ich was übersehen?

                      @haus-automatisierung kannst Du mir sagen, warum es nicht geht?

                      bei deinem Beispeil:

                      const res = await messageToAsync('Testmessage', { flag: true }, { timeout: 5000 });
                      console.log(JSON.stringify(res));
                      

                      meckert er bei mir genauso das await an.

                      T 1 Antwort Letzte Antwort
                      0
                      • Ben1983B Ben1983

                        @ticaki ok und woran liegt es?
                        Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
                        Woran liegt jetzt der Fehler?
                        Habe ich was übersehen?

                        @haus-automatisierung kannst Du mir sagen, warum es nicht geht?

                        bei deinem Beispeil:

                        const res = await messageToAsync('Testmessage', { flag: true }, { timeout: 5000 });
                        console.log(JSON.stringify(res));
                        

                        meckert er bei mir genauso das await an.

                        T Nicht stören
                        T Nicht stören
                        ticaki
                        schrieb am zuletzt editiert von ticaki
                        #37

                        @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                        @ticaki ok und woran liegt es?
                        Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
                        Woran liegt jetzt der Fehler?
                        Habe ich was übersehen?

                        Bei mir stürzt die Javascript-Instanz ab, wenn ich deinen Code ausführe.

                        Bildschirmfoto 2023-11-06 um 13.31.45.png

                        EDIT:
                        Du darfst await nur innerhalb einer Funktion benutzen, die mit async markiert ist.

                        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                        Spenden

                        Ben1983B 2 Antworten Letzte Antwort
                        0
                        • T ticaki

                          @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                          @ticaki ok und woran liegt es?
                          Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
                          Woran liegt jetzt der Fehler?
                          Habe ich was übersehen?

                          Bei mir stürzt die Javascript-Instanz ab, wenn ich deinen Code ausführe.

                          Bildschirmfoto 2023-11-06 um 13.31.45.png

                          EDIT:
                          Du darfst await nur innerhalb einer Funktion benutzen, die mit async markiert ist.

                          Ben1983B Offline
                          Ben1983B Offline
                          Ben1983
                          schrieb am zuletzt editiert von
                          #38

                          @ticaki ja bei mir auch, aber warum?

                          T 1 Antwort Letzte Antwort
                          0
                          • T ticaki

                            @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                            @ticaki ok und woran liegt es?
                            Es wird der Toplevel angeckert... die war aber schon länger so undmachte eigentlich keine Probleme.
                            Woran liegt jetzt der Fehler?
                            Habe ich was übersehen?

                            Bei mir stürzt die Javascript-Instanz ab, wenn ich deinen Code ausführe.

                            Bildschirmfoto 2023-11-06 um 13.31.45.png

                            EDIT:
                            Du darfst await nur innerhalb einer Funktion benutzen, die mit async markiert ist.

                            Ben1983B Offline
                            Ben1983B Offline
                            Ben1983
                            schrieb am zuletzt editiert von
                            #39

                            @ticaki selbst so geht es nicht:

                            const ausgabe = await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})
                            log(ausgabe);
                            
                            1 Antwort Letzte Antwort
                            0
                            • Ben1983B Ben1983

                              @ticaki ja bei mir auch, aber warum?

                              T Nicht stören
                              T Nicht stören
                              ticaki
                              schrieb am zuletzt editiert von
                              #40

                              @ben1983 sagte in auf globale Objekt kann nicht zugegriffen werden:

                              @ticaki ja bei mir auch, aber warum?

                              Hab ich doch oben geschrieben? Await setzt async voraus. Du kannst nur in einem asynchron laufenden Programmteil warten. Sonst würde ja der ganze Javascript-Adapter warten oder ist es der ganze Iobroker :)

                              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                              Spenden

                              1 Antwort Letzte Antwort
                              0
                              • Ben1983B Offline
                                Ben1983B Offline
                                Ben1983
                                schrieb am zuletzt editiert von Ben1983
                                #41

                                @ticaki OK. jetzt weiß ich was Du meinst.
                                Ich muss also um das ausführen zu können quasi so ein Konstrukt erstellen:

                                async function myDummy(){
                                    log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
                                }
                                myDummy();
                                onMessage("Testmessage",(messagedata,callback) =>{
                                    const myData = {input: messagedata,
                                                    output:{name:"Test"}};
                                    callback(myData)
                                });
                                

                                @haus-automatisierung dann könnte ich ja nirgends in bspw. einem on(.... eine await messageToAsync nutzen, um gewisse Rückmeldungen zu bekommen.
                                ist ja nicht innerhalb einer async funktion

                                T 1 Antwort Letzte Antwort
                                0
                                • paul53P paul53

                                  @ben1983 sagte: "Besser" das Objekt nur dazu definieren, wo es gebraucht wird?

                                  Ja. Die Gruppe "global" verwendet man für häufig verwendete eigene Funktionen.
                                  Mit globalen Objektdefinitionen müllt man sich den RAM der Javascript-Instanz zu, da sie in jedem nicht globalen Skript kompiliert werden.

                                  Ben1983B Offline
                                  Ben1983B Offline
                                  Ben1983
                                  schrieb am zuletzt editiert von
                                  #42

                                  @paul53 Ich nutze es aktuell hauptsächlich um ids in eine Variable zu speichern und dann komplett in allen skripten darauf zugreifen zu können.
                                  Wenn sich sonst was ändert, müsste ich überall die id nachziehen. deshalb war es so gedacht.
                                  Oder gibts ne andere bessere Lösung?

                                  paul53P 1 Antwort Letzte Antwort
                                  0
                                  • Ben1983B Ben1983

                                    @paul53 Ich nutze es aktuell hauptsächlich um ids in eine Variable zu speichern und dann komplett in allen skripten darauf zugreifen zu können.
                                    Wenn sich sonst was ändert, müsste ich überall die id nachziehen. deshalb war es so gedacht.
                                    Oder gibts ne andere bessere Lösung?

                                    paul53P Offline
                                    paul53P Offline
                                    paul53
                                    schrieb am zuletzt editiert von
                                    #43

                                    @ben1983 sagte: Wenn sich sonst was ändert, müsste ich überall die id nachziehen.

                                    Dafür sind eigentlich Alias-DP gedacht, damit man man nur an einer Stelle bei Veränderungen anpassen muss.

                                    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

                                    Ben1983B 1 Antwort Letzte Antwort
                                    0
                                    • Ben1983B Ben1983

                                      @ticaki OK. jetzt weiß ich was Du meinst.
                                      Ich muss also um das ausführen zu können quasi so ein Konstrukt erstellen:

                                      async function myDummy(){
                                          log(JSON.stringify( await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})));
                                      }
                                      myDummy();
                                      onMessage("Testmessage",(messagedata,callback) =>{
                                          const myData = {input: messagedata,
                                                          output:{name:"Test"}};
                                          callback(myData)
                                      });
                                      

                                      @haus-automatisierung dann könnte ich ja nirgends in bspw. einem on(.... eine await messageToAsync nutzen, um gewisse Rückmeldungen zu bekommen.
                                      ist ja nicht innerhalb einer async funktion

                                      T Nicht stören
                                      T Nicht stören
                                      ticaki
                                      schrieb am zuletzt editiert von
                                      #44

                                      @ben1983

                                      Ja kannst du so nennen. Meine neueren Skripts sehen im Aufbau immer so aus:

                                      const DEBUG = false
                                      const cState = 'hier die id vom datenpunkt'
                                      
                                      var globaleVariable = 'irgendwas'
                                      
                                      async function main() {
                                          // hier gehts los
                                      }
                                      
                                      log('blabla started! und dann irgendwelche sinnvollen Daten die man wissen will')
                                      main()
                                      // hier kommt nix mehr
                                      

                                      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                      Spenden

                                      1 Antwort Letzte Antwort
                                      0
                                      • paul53P paul53

                                        @ben1983 sagte: Wenn sich sonst was ändert, müsste ich überall die id nachziehen.

                                        Dafür sind eigentlich Alias-DP gedacht, damit man man nur an einer Stelle bei Veränderungen anpassen muss.

                                        Ben1983B Offline
                                        Ben1983B Offline
                                        Ben1983
                                        schrieb am zuletzt editiert von
                                        #45

                                        @paul53 genau. und ich habe die Alias ids den variablen zugewiesen.

                                        Fand es vom Code her schöner, nicht überall die id als string ein zu tragen. Oder?
                                        Eventuell wirklich an den Anfang vom Skript, wo man sie benötigt.
                                        Das wäre ja noch so ein machbarer mittelweg, oder wie siehst Du das?

                                        paul53P 1 Antwort Letzte Antwort
                                        0
                                        • Ben1983B Ben1983

                                          @paul53 genau. und ich habe die Alias ids den variablen zugewiesen.

                                          Fand es vom Code her schöner, nicht überall die id als string ein zu tragen. Oder?
                                          Eventuell wirklich an den Anfang vom Skript, wo man sie benötigt.
                                          Das wäre ja noch so ein machbarer mittelweg, oder wie siehst Du das?

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          schrieb am zuletzt editiert von
                                          #46

                                          @ben1983 sagte: Eventuell wirklich an den Anfang vom Skript, wo man sie benötigt.

                                          So mache ich es.

                                          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

                                          Ben1983B 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

                                          677

                                          Online

                                          32.6k

                                          Benutzer

                                          82.2k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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