Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [gelöst] auf globale Objekt kann nicht zugegriffen werden

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

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

    This topic has been deleted. Only users with topic management privileges can see it.
    • haus-automatisierung
      haus-automatisierung Developer Most Active @Ben1983 last edited by 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?

      Ben1983 1 Reply Last reply Reply Quote 0
      • T
        ticaki Developer @Ben1983 last edited by ticaki

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

        messageToAsync

        ups falsch gelesen

        EDIT aber trotzdem relevant und die Beschreibung/Definition sollte geändert werden.

        function messageToAsync(target: iobJS.MessageTarget | string, data: any, options?: any): Promise<iobJS.MessageCallback | iobJS.MessageCallbackInfo>;
        

        Der {timeout:30000} (zeit is nur ein Beispiel) sollte im Javascript-Adapter zumindest ein default sein oder die Angabe verpflichtend wie jetzt. Ohne timeout kann das an der Stelle hängen bleiben, wie ich schmerzlich feststellen mußt mit einem gleichzeitigen Defekt des Übertemperaturwächters am Boiler.

        haus-automatisierung 1 Reply Last reply Reply Quote 0
        • haus-automatisierung
          haus-automatisierung Developer Most Active @ticaki last edited by

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

          Ohne timeout kann das an der Stelle hängen bleiben, wie ich schmerzlich feststellen mußt

          Habe ich gerade das erste mal von gehört. Gibts dazu schon einen GitHub Issue? Sollte zumindest in der nächsten Version gefixt sein:

          https://github.com/ioBroker/ioBroker.javascript/commit/41e59dfd72f99027a9a303beee8d4d5597826445

          0 klein0r committed to ioBroker/ioBroker.javascript
          messageToAsync was not working without options
          T 1 Reply Last reply Reply Quote 0
          • T
            ticaki Developer @haus-automatisierung last edited by ticaki

            @haus-automatisierung
            Ach mist, nicht das es nicht das gleiche ist. Bei mir ist sendToAsync hängen geblieben. Sorry hab die beiden durcheinandergewürfelt.

            haus-automatisierung 1 Reply Last reply Reply Quote 0
            • haus-automatisierung
              haus-automatisierung Developer Most Active @ticaki last edited by

              @ticaki sendToAsync funktioniert bei mir wunderbar

              T 1 Reply Last reply Reply Quote 0
              • T
                ticaki Developer @haus-automatisierung last edited by

                @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-automatisierung 1 Reply Last reply Reply Quote 0
                • haus-automatisierung
                  haus-automatisierung Developer Most Active @ticaki last edited by

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

                  T 1 Reply Last reply Reply Quote 0
                  • T
                    ticaki Developer @haus-automatisierung last edited by 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

                    ticaki created this issue in ioBroker/ioBroker.javascript

                    closed Missing timeout for sendToAsync() #1436

                    haus-automatisierung 1 Reply Last reply Reply Quote 0
                    • haus-automatisierung
                      haus-automatisierung Developer Most Active @ticaki last edited by 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 1 Reply Last reply Reply Quote 0
                      • T
                        ticaki Developer @haus-automatisierung last edited by 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-automatisierung 1 Reply Last reply Reply Quote 0
                        • haus-automatisierung
                          haus-automatisierung Developer Most Active @ticaki last edited by

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

                          Ben1983 T 2 Replies Last reply Reply Quote 0
                          • Ben1983
                            Ben1983 @haus-automatisierung last edited by

                            @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 Reply Last reply Reply Quote 0
                            • T
                              ticaki Developer @haus-automatisierung last edited by

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

                              1 Reply Last reply Reply Quote 0
                              • T
                                ticaki Developer @Ben1983 last edited by 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 😄

                                Ben1983 1 Reply Last reply Reply Quote 0
                                • Ben1983
                                  Ben1983 @haus-automatisierung last edited by

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

                                  BenAhrdt created this issue in ioBroker/ioBroker.javascript

                                  closed messageToAsync funktionier nicht ohne options (ohne timeout) #1437

                                  1 Reply Last reply Reply Quote 0
                                  • Ben1983
                                    Ben1983 @ticaki last edited by 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 1 Reply Last reply Reply Quote 0
                                    • T
                                      ticaki Developer @Ben1983 last edited by 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.

                                      Ben1983 2 Replies Last reply Reply Quote 0
                                      • Ben1983
                                        Ben1983 @ticaki last edited by

                                        @ticaki ja bei mir auch, aber warum?

                                        T 1 Reply Last reply Reply Quote 0
                                        • Ben1983
                                          Ben1983 @ticaki last edited by

                                          @ticaki selbst so geht es nicht:

                                          const ausgabe = await messageToAsync("Testmessage",{name:"Testname"},{timeout:5000})
                                          log(ausgabe);
                                          
                                          1 Reply Last reply Reply Quote 0
                                          • T
                                            ticaki Developer @Ben1983 last edited by

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

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            426
                                            Online

                                            31.9k
                                            Users

                                            80.2k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            52
                                            1254
                                            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