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.
    • Ben1983
      Ben1983 @haus-automatisierung last edited by

      @haus-automatisierung OK, danke

      Ich bekomme nur bei der messageTo den log geschrieben, was ist denn beim SendTo falsch?

      
      messageTo("Testmessage",{name:"Testname"},(callbackdata)=>{
          log(JSON.stringify(callbackdata));   
      });
      
      sendTo("javascript.0",'toScript', {
              script: 'script.js.x_testskripte._a_Mesagetest', 
              message: 'Testmessage', 
              data: {
                  flag: true
              },function(res){
                  log(JSON.stringify(res));
              } 
      });
      
      onMessage("Testmessage",(messagedata,callback) =>{
          const myData = {input: messagedata,
                          output:{name:"Test"}};
          callback(myData)
      });
      

      Ps. die funktionieren NUR mit callback,oder?
      Also mit return kann man nichts zurückgeben, dass man das Ergebnis einer Funktion in einer Zeile direkt zuweisen kann.
      Oder?

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

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

        Also mit return kann man nichts zurückgeben, dass man das Ergebnis einer Funktion in einer Zeile direkt zuweisen kann.

        Na Du kannst doch mit sendToAsync und await arbeiten. Ganz normal mit Promises halt.

        https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#sendtoasync

        Oder halt messageToAsync:

        https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#messagetoasync

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

          @haus-automatisierung AH ok... hatte mir mal etwas drum rum gebaut, weil damals ein fehler im sendToAsynch war... weiß leider nicht mehr was 😞

          async function mySendToAsync(_adapter, cmd, msg) {
              return new Promise((resolve, reject) => {
                  sendTo(_adapter, cmd, msg, res => {
                      if (!res || res.error) {
                          reject(res ? res.error : new Error('Unknown error'));
                      } else {
                          resolve(res);
                      }
                  });
              });
          }
          

          also kann man auch normal jetzt das messageToAsynch benutzen, oder wie?

          Trotzdem macht er irgendwie meinen Callback nicht, ob wohl ich den aufrufe. (im sendTo)

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

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

            also kann man auch normal jetzt das messageToAsynch benutzen, oder wie?

            Hatte ich doch schon geschrieben, dass die beiden Funktionen praktisch identisch sind. Siehe Code. messageTo hat halt eine etwas andere Signatur und braucht weniger Infos. Siehe Doku.

            Ich hatte das hier gefixt: https://github.com/ioBroker/ioBroker.javascript/pull/1343

            Einfach die aktuellste Stable version nehmen dann passts.

            klein0r created this issue in ioBroker/ioBroker.javascript

            closed Blockly improvements, messageToAsync, documentation #1343

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

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

              Schade,dass es nicht geht. Dann bekomme ich halt lauter Fehlermeldungen und weiß nicht, ob es wirklich Fehler sind.

              du könntest, zumindest temporär, die zeilen in dem das objekt aufgebaut wird in dein skript kopieren. dann funktioniert auch die vervollständigung.
              wenn dann alles getestet ist und es funktioniert, dann entfernst du die zeilen wieder und die zeilen aus global wirken.

              das einmalige definieren in global ist vor allem dann gut, wenn du regelmäßig das objekt in seiner definition erweiterst und du dir arbeit sparen willst. dadurch werden fehler reduziert.

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

                @haus-automatisierung OK. Cool.

                Könntest DU mir freundlicherweise noch sagen, warum ich hier keinen Log der Daten im Callback bekomme?
                Ich finde es nicht. Aufruf wird geloggt

                sendTo("javascript.0",'toScript', {
                        script: 'script.js.x_testskripte._a_Mesagetest', 
                        message: 'Testmessage', 
                        data: {
                            flag: true
                        },function(res){
                            log(JSON.stringify(res));
                        } 
                });
                
                onMessage("Testmessage",(messagedata,callback) =>{
                    const myData = {input: messagedata,
                                    output:{name:"Test"}};
                    callback(myData)
                    log("Aufruf ");
                });
                
                haus-automatisierung 1 Reply Last reply Reply Quote 0
                • haus-automatisierung
                  haus-automatisierung Developer Most Active @Ben1983 last edited by haus-automatisierung

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

                  Könntest DU mir freundlicherweise noch sagen, warum ich hier keinen Log der Daten im Callback bekomme?

                  Deine Klammern sind falsch. Die Function ist teil des Msg-Objektes und nicht als separater Parameter definiert. Wenn Du den Code schöner formatieren würdest, siehst Du das auch auf einen Blick 🙂

                  So gehts:

                  sendTo(
                      'javascript.0',
                      'toScript',
                      {
                          script: 'script.js.test.playground', 
                          message: 'Testmessage', 
                          data: {
                              flag: true
                          }
                      },
                      (res) => {
                          console.log(JSON.stringify(res));
                      }
                  );
                  
                  onMessage('Testmessage', (messagedata, callback) => {
                      console.log('Aufruf');
                      const myData = {
                          input: messagedata,
                          output: {
                              name: 'Test'
                          }
                      };
                  
                      callback(myData);
                  });
                  
                  Ben1983 1 Reply Last reply Reply Quote 0
                  • Ben1983
                    Ben1983 @haus-automatisierung last edited by Ben1983

                    @haus-automatisierung OK. Danke

                    Beim Verwendet von messageToAsynch tritt dieser Fehler auf:

                    messageToAsync("Testmessage",{name:"Testname"});
                    
                    	javascript.0 (20591) script.js.x_testskripte._a_Mesagetest: TypeError: Cannot read properties of undefined (reading 'timeout')
                    
                    haus-automatisierung T 2 Replies Last reply Reply Quote 0
                    • paul53
                      paul53 @Ben1983 last edited by

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

                      Ben1983 1 Reply Last reply Reply Quote 0
                      • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            747
                                            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