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.
    • 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
                                  • T
                                    ticaki Developer @Asgothian last edited by

                                    @asgothian sagte in Hilfe bei der Script erstellung:

                                    @t0bit3ch

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

                                    Ich würde empfehlen es so zu lösen:

                                    setIntervall(function() {
                                       axios(config).then(function (response) {... }).catch(function(error) { console.log(error); });
                                     }), 5 * 1000);
                                    

                                    Das hat den Vorteil das die Belastung des Servers zufällig(Zeitpunkt ist nicht fest sondern leitet sich von der Startzeit und Verarbeitungszeit ab.) verteilt wird. Ist aber bei Einzelanwendung eines Skripts wohl wurscht sein.

                                    Ansonsten hab ich die gleichen Bedenken bezüglich der 5 Sekunden wie du.

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

                                      @ticaki
                                      @Asgothian

                                      vielen dank für eure rückmeldung. das script wird nur aktiviert wenn ein alarm ausgelöst wird. dann soll es für 5min. aktiv bleiben und in dieser zeit alle 5 sek. aktualisieren.

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

                                        @ticaki sagte in Hilfe bei der Script erstellung:

                                                                                                                                                                    setIntervall(function() {                                                                                                                                                                               axios(config).then(function (response) {... }).catch(function(error) { console.log(error); });                                                                                                                                                                             }), 5 * 1000);                                            
                                        

                                        Habe es jetzt so geändert, aber er schmeißt mir einen fehler in die log

                                        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
                                        };
                                        
                                        
                                        setIntervall(function() {
                                           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); 
                                               });
                                         }), 5 * 1000);
                                        
                                        error	javascript.0 (6446) script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage compile failed: at script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage:43
                                        
                                        T 1 Reply Last reply Reply Quote 0
                                        • T
                                          ticaki Developer @T0biT3ch last edited by ticaki

                                          @t0bit3ch

                                          Ist eine Klammer zuviel in meinem Beispiel:

                                          setIntervall(function() { axios(config).then(function (response) {... }).catch(function(error) { console.log(error); }); }, 5 * 1000);
                                          

                                          die vor dem , 5

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

                                            @ticaki
                                            jetzt kommt das in die log

                                            error	javascript.0 (6446) script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage: ReferenceError: setIntervall is not defined
                                            error	javascript.0 (6446) at script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage:17:1
                                            error	javascript.0 (6446) at script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage:48:3
                                            
                                            T 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            912
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

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