Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Hilfe bei der Script erstellung

    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

    Hilfe bei der Script erstellung

    This topic has been deleted. Only users with topic management privileges can see it.
    • OliverIO
      OliverIO @T0biT3ch last edited by

      @t0bit3ch

      super das es letztendlich doch geklappt hat.

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

        @oliverio
        Moin Moin,
        Ich bin zwischendurch noch ein bisschen am probieren den status vom pager abzurufen.
        ich hänge grad wieder bei einem problem. ich lasse mir einen datenpunkt schreiben der so aussieht

        "46b61d10-10c3-11ec-8787-7dd1f95191be"
        

        ich möchte das die " am anfang und ende nicht mit in den datenpunkt geschrieben werden. wie bekomme ich das hin?
        hab schon so einiges probiert, aber nichts hat bisher funktioniert.
        hier mal eins von meinen versuchen

        setState("0_userdata.0.E-Message.E-Message-TrackingID", trid).val.replace('"');
        
        T 1 Reply Last reply Reply Quote 0
        • T
          T0biT3ch @T0biT3ch last edited by

          @t0bit3ch sagte in Hilfe bei der Script erstellung:

          @oliverio
          Moin Moin,
          Ich bin zwischendurch noch ein bisschen am probieren den status vom pager abzurufen.
          ich hänge grad wieder bei einem problem. ich lasse mir einen datenpunkt schreiben der so aussieht

          "46b61d10-10c3-11ec-8787-7dd1f95191be"
          

          ich möchte das die " am anfang und ende nicht mit in den datenpunkt geschrieben werden. wie bekomme ich das hin?
          hab schon so einiges probiert, aber nichts hat bisher funktioniert.
          hier mal eins von meinen versuchen

          setState("0_userdata.0.E-Message.E-Message-TrackingID", trid).val.replace('"');
          

          hab es hinbekommen 😊

          so langsam verstehe ich das JS🙈

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

            @t0bit3ch
            Das gequotete Beispiel sieht aber nicht aus als wenns funktionieren würde. 🙂

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

              @ticaki sagte in Hilfe bei der Script erstellung:

              @t0bit3ch
              Das gequotete Beispiel sieht aber nicht aus als wenns funktionieren würde. 🙂

              hatte das funktionierende beispiel wohl vergessen 😀

              var trid = JSON.stringify(response.data.data.trackingId); 
                          var tridneu = trid.substr(1, trid.length - 2);
                          setState("0_userdata.0.E-Message.E-Message-TrackingID", tridneu);
              
              F 1 Reply Last reply Reply Quote 0
              • F
                fastfoot @T0biT3ch last edited by

                @t0bit3ch sagte in Hilfe bei der Script erstellung:

                @ticaki sagte in Hilfe bei der Script erstellung:

                @t0bit3ch
                Das gequotete Beispiel sieht aber nicht aus als wenns funktionieren würde. 🙂

                hatte das funktionierende beispiel wohl vergessen 😀

                var trid = JSON.stringify(response.data.data.trackingId); 
                            var tridneu = trid.substr(1, trid.length - 2);
                            setState("0_userdata.0.E-Message.E-Message-TrackingID", tridneu);
                

                Eigentor! Du hast dir die Hochkommas selbst reingebastelt, durch das nicht notwendige JSON.stringify(). das hier reicht völlig

                let trid=response.data.data.trackingId;
                setState("0_userdata.0.E-Message.E-Message-TrackingID", trid);
                
                T T 2 Replies Last reply Reply Quote 0
                • T
                  T0biT3ch @fastfoot last edited by

                  @fastfoot
                  Danke für den Tipp. Werde es morgen mal versuchen 😁

                  Man lernt nie aus 🙊

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

                    setState("0_userdata.0.E-Message.E-Message-TrackingID", response.data.data.trackingId);
                    
                    F 1 Reply Last reply Reply Quote 0
                    • F
                      fastfoot @ticaki last edited by

                      @ticaki sagte in Hilfe bei der Script erstellung:

                      setState("0_userdata.0.E-Message.E-Message-TrackingID", response.data.data.trackingId);
                      

                      klar doch, ich halte es aber für einen Anfänger für besser das aufzusplitten. Dadurch ist es besser nachvollziehbar was da passiert. Der kürzeste Code ist halt nicht immer der Beste...

                      T 1 Reply Last reply Reply Quote 0
                      • T
                        T0biT3ch @fastfoot last edited by

                        @fastfoot
                        danke für dein beispiel. was genau macht

                        let trid
                        

                        frage nur um es besser zu verstehen.

                        @ticaki
                        auch dir danke für das beispiel. so hab ich wieder etwas dazu gelern. 😉

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

                          @t0bit3ch
                          Let ist wie var und deklariert eine variable.
                          let wurde mit ES6 (da wurde javascript vom syntax etwas modernisiert) eingeführt und hat leichte abweichungen zu var (speziell zu hoisting und scope behandlung).
                          aber als anfänger kannst du das erst mal genau so wie var verwenden.

                          https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Statements/let

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

                            @oliverio
                            okay danke.
                            den Link werde ich mir übers wochenende mal genauer angucken 🤓

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

                              @OliverIO
                              @ticaki
                              @fastfoot
                              @Homoran

                              Guten Abend Profis,

                              ich benötige nochmal eure hilfe.

                              var axios = require('axios');
                              var trid = "0_userdata.0.E-Message.E-Message-TrackingID";
                              var token = "0_userdata.0.E-Message.E-Message-Token";
                              var data = '';
                              
                              var config = {
                                method: 'get',
                                url: 'https://api.emessage.de/rs/eGetMessages/External/' + getState(trid).val ,
                                headers: { 
                                  'Authorization':  'Bearer ' + getState(token).val,
                                  
                                },
                                data : data
                              };
                              
                              axios(config)
                              .then(function (response) {
                                   
                                     var recipients = JSON.stringify(response.data.data.recipients);
                                     setState("0_userdata.0.E-Message_Response.Recipients", recipients, true);
                                     
                                     
                                
                                
                              })
                              .catch(function (error) {
                                console.log(error);
                              });
                              

                              wie bekomme ich es hin das mir die zurück gelieferten daten sortiert in datenpunkte geschrieben werden?

                              hiermit

                              setState("0_userdata.0.E-Message_Response.Recipients", recipients, true);
                              

                              bekomme ich folgende ausgabe

                              [{"externalRecipient":"2W:123456","identifier":"123456","service":"2wayS","numberOfRecipients":"1","status":[{"answer":"01","answerNo":"1","devices":[{"deviceName":"Testpager","deviceSerial":"S0ABC123456789"}]}]}]
                              

                              brauche es für die weitere verarbeitung so

                              datenpunkt0.wert1 = wert von identifer (123456)
                              datenpunkt0.wert2 = wert von service (2wayS)
                              datenpunkt0.wert3 = wert von answer (01)
                              usw.
                              

                              ich bin am verzweifeln 😭

                              F 1 Reply Last reply Reply Quote 0
                              • F
                                fastfoot @T0biT3ch last edited by

                                @t0bit3ch sagte in Hilfe bei der Script erstellung:

                                ich bin am verzweifeln

                                log(recipients[0].identifier)
                                log(recipients[0].service)
                                log(recipients[0].status[0].answer)
                                
                                
                                T 2 Replies Last reply Reply Quote 0
                                • T
                                  T0biT3ch @fastfoot last edited by

                                  @fastfoot
                                  was haben die [0] zu bedeuten?
                                  Was ist denn der Unterschied zu

                                  JSON.stringify(response.data.data.recipients)
                                  
                                  F 1 Reply Last reply Reply Quote 0
                                  • T
                                    T0biT3ch @fastfoot last edited by

                                    @fastfoot
                                    Werde es morgen mal direkt probieren. 👍

                                    1 Reply Last reply Reply Quote 0
                                    • F
                                      fastfoot @T0biT3ch last edited by

                                      @t0bit3ch sagte in Hilfe bei der Script erstellung:

                                      @fastfoot
                                      was haben die [0] zu bedeuten?
                                      Was ist denn der Unterschied zu

                                      JSON.stringify(response.data.data.recipients)
                                      

                                      in der Antwort sind Arrays enthalten, 0 spricht das erste Element an. Es gibt auch jeweils nur ein Element in Deinem Beispiel

                                      Da ist kein Unterschied, das sind ganz verschiedene Dinge. JSON.stringify() erzeugt aus einem Objekt einen String. mein Beispiel zerlegt das Objekt in seine Einzelteile, weshalb du auch das JSON.stringify() weglassen musst.

                                      Du musst dir die Struktur des JSON(=Ergebnis) mit zB einem Onlineviewer anschauen

                                      var recipients = response.data.data.recipients;
                                      setState(id, recipients[0].identifier);
                                      .
                                      .
                                      .
                                      
                                      T 1 Reply Last reply Reply Quote 0
                                      • T
                                        T0biT3ch @fastfoot last edited by

                                        @fastfoot

                                        danke für die tolle erklärung. hat funktioniert 👍

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

                                          bekommt man es noch hin das, dass script alle 5 sek. überprüft ob sich die werte geändert haben?
                                          habe es jetzt mit blockly gelöst indem ich das script alle 5 sek. aktiviere und deaktiviere, aber das ist nicht die schönste methode.

                                          var axios = require('axios');
                                          var trid = "0_userdata.0.E-Message.E-Message-TrackingID";
                                          var token = "0_userdata.0.E-Message.E-Message-Token";
                                          var data = '';
                                          
                                          var config = {
                                            method: 'get',
                                            url: 'https://api.emessage.de/rs/eGetMessages/External/' + getState(trid).val ,
                                            headers: { 
                                              'Authorization':  'Bearer ' + getState(token).val,
                                              
                                            },
                                            data : data
                                          };
                                          
                                          axios(config)
                                          .then(function (response) {
                                               
                                                 var recipients = response.data.data.recipients;
                                                  setState("0_userdata.0.E-Message_Response.QuittierungCode", recipients[0].status[0].answer, true);
                                                  console.log('Rueckmeldung: ' + recipients[0].status[0].answer)
                                                  //
                                                  setState("0_userdata.0.E-Message_Response.Identifer", recipients[0].identifier, true);
                                                  console.log('PagerRufnummer: ' + recipients[0].identifier)
                                                  //
                                                  setState("0_userdata.0.E-Message_Response.Service", recipients[0].service, true);
                                                  console.log('ServiceTyp: ' + recipients[0].service)
                                                  //
                                                  setState("0_userdata.0.E-Message_Response.PagerName", recipients[0].status[0].devices[0].deviceName, true);
                                                  console.log('PagerName: ' + recipients[0].status[0].devices[0].deviceName)
                                                  //
                                                  setState("0_userdata.0.E-Message_Response.PagerSerial", recipients[0].status[0].devices[0].deviceSerial, true);
                                                  console.log('Seriennummer: ' + recipients[0].status[0].devices[0].deviceSerial)
                                            
                                          })
                                          .catch(function (error) {
                                            console.log(error);
                                          });
                                          
                                          Asgothian 1 Reply Last reply Reply Quote 0
                                          • Asgothian
                                            Asgothian Developer @T0biT3ch last edited by Asgothian

                                            @t0bit3ch

                                            Technisch ganz einfach: Den entscheidenden Aufruf des Skripts in einen Zeitplan kapseln, der alle 5 sekunden aktiv wird.

                                            shedule("*/5 * * * * *", function() {
                                              axios(config).then(function (response) {... }).catch(function(error) { console.log(error); });
                                            });
                                             
                                            

                                            Da wo die ... stehen muss natürlich die der gleiche code stehen wie in dem Beispiel oben.

                                            Allerdings bedeutet das das du alle 5 Sekunden eine externe Abfrage stellst - 17280 pro Tag.

                                            Da solltest du bei dem Provider der API mal nachschauen was es für Grenzen für die Abfrage gibt.

                                            A.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            924
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            6
                                            98
                                            5406
                                            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