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. Hilfe bei der Script erstellung

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.7k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.2k

Hilfe bei der Script erstellung

Geplant Angeheftet Gesperrt Verschoben JavaScript
98 Beiträge 6 Kommentatoren 8.6k Aufrufe 5 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 T0biT3ch

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

    OliverIOO Offline
    OliverIOO Offline
    OliverIO
    schrieb am zuletzt editiert von OliverIO
    #59

    @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

    Meine Adapter und Widgets
    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
    Links im Profil

    T 1 Antwort Letzte Antwort
    0
    • OliverIOO 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 Offline
      T Offline
      T0biT3ch
      schrieb am zuletzt editiert von
      #60

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

      T 1 Antwort Letzte Antwort
      0
      • T T0biT3ch

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

        T Offline
        T Offline
        T0biT3ch
        schrieb am zuletzt editiert von
        #61

        @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 :sob:

        F 1 Antwort Letzte Antwort
        0
        • T T0biT3ch

          @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 :sob:

          F Offline
          F Offline
          fastfoot
          schrieb am zuletzt editiert von
          #62

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

          iobroker läuft unter Docker auf QNAP TS-451+
          SkriptRecovery: https://forum.iobroker.net/post/930558

          T 2 Antworten Letzte Antwort
          0
          • F fastfoot

            @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 Offline
            T Offline
            T0biT3ch
            schrieb am zuletzt editiert von
            #63

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

            JSON.stringify(response.data.data.recipients)
            
            F 1 Antwort Letzte Antwort
            0
            • F fastfoot

              @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 Offline
              T Offline
              T0biT3ch
              schrieb am zuletzt editiert von
              #64

              @fastfoot
              Werde es morgen mal direkt probieren. 👍

              1 Antwort Letzte Antwort
              0
              • T T0biT3ch

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

                JSON.stringify(response.data.data.recipients)
                
                F Offline
                F Offline
                fastfoot
                schrieb am zuletzt editiert von
                #65

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

                iobroker läuft unter Docker auf QNAP TS-451+
                SkriptRecovery: https://forum.iobroker.net/post/930558

                T 1 Antwort Letzte Antwort
                0
                • F fastfoot

                  @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 Offline
                  T Offline
                  T0biT3ch
                  schrieb am zuletzt editiert von
                  #66

                  @fastfoot

                  danke für die tolle erklärung. hat funktioniert :+1:

                  T 1 Antwort Letzte Antwort
                  0
                  • T T0biT3ch

                    @fastfoot

                    danke für die tolle erklärung. hat funktioniert :+1:

                    T Offline
                    T Offline
                    T0biT3ch
                    schrieb am zuletzt editiert von
                    #67

                    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);
                    });
                    
                    AsgothianA 1 Antwort Letzte Antwort
                    0
                    • T T0biT3ch

                      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);
                      });
                      
                      AsgothianA Offline
                      AsgothianA Offline
                      Asgothian
                      Developer
                      schrieb am zuletzt editiert von Asgothian
                      #68

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

                      ioBroker auf RPi4 - Hardware soweit wie möglich via Zigbee.
                      "Shit don't work" ist keine Fehlermeldung, sondern ein Fluch.

                      T 1 Antwort Letzte Antwort
                      0
                      • AsgothianA 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 Offline
                        T Offline
                        ticaki
                        schrieb am zuletzt editiert von
                        #69

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

                        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                        Spenden

                        T 2 Antworten Letzte Antwort
                        0
                        • T ticaki

                          @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 Offline
                          T Offline
                          T0biT3ch
                          schrieb am zuletzt editiert von
                          #70

                          @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 Antwort Letzte Antwort
                          0
                          • T ticaki

                            @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 Offline
                            T Offline
                            T0biT3ch
                            schrieb am zuletzt editiert von
                            #71

                            @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 Antwort Letzte Antwort
                            0
                            • T T0biT3ch

                              @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 Offline
                              T Offline
                              ticaki
                              schrieb am zuletzt editiert von ticaki
                              #72

                              @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

                              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                              Spenden

                              T 1 Antwort Letzte Antwort
                              0
                              • T 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 Offline
                                T Offline
                                T0biT3ch
                                schrieb am zuletzt editiert von
                                #73

                                @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 Antwort Letzte Antwort
                                0
                                • T T0biT3ch

                                  @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 Offline
                                  T Offline
                                  T0biT3ch
                                  schrieb am zuletzt editiert von
                                  #74

                                  wenn ich es so mache

                                  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
                                  };
                                  
                                  
                                  shedule("*/5 * * * * *", 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); 
                                         });
                                  

                                  kommt in der log

                                  error	javascript.0 (6446) script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage compile failed: at script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage:48
                                  

                                  aber der code hat ja keine 48 zeilen :thinking_face:

                                  T 1 Antwort Letzte Antwort
                                  0
                                  • T T0biT3ch

                                    wenn ich es so mache

                                    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
                                    };
                                    
                                    
                                    shedule("*/5 * * * * *", 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); 
                                           });
                                    

                                    kommt in der log

                                    error	javascript.0 (6446) script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage compile failed: at script.js.Pager_Alarmierung.Funktion05_2wayS_Status_abfrage:48
                                    

                                    aber der code hat ja keine 48 zeilen :thinking_face:

                                    T Offline
                                    T Offline
                                    ticaki
                                    schrieb am zuletzt editiert von ticaki
                                    #75

                                    @t0bit3ch
                                    Du müsstest zumindest kleine Syntaxfehler selbst beheben. shedule - ein Schreibfehler es ist schedule und bei meinem Beispiel setIntervall ist setInterval ebenfalls ein Schreibfehler der ohne Editor halt mal vorkommt. Die sind meist unterstrichen, was nicht heißt das alles unterstrichene ein Fehler ist.

                                    in deinem Beispiel code fehlt auch ein weiteres:

                                    });
                                    

                                    am Ende
                                    hier siehst du die ioBroker Funktionen: https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md

                                    Außerdem hat der Adapter zumindest bei mir den Bug das er mir die letzten 3-5 Zeilen nicht anzeigt und ich erstmal ganz ans ende mit den Cursortasten gehe und ein paar Leerzeilen einfüge.

                                    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                    Spenden

                                    T 1 Antwort Letzte Antwort
                                    0
                                    • T ticaki

                                      @t0bit3ch
                                      Du müsstest zumindest kleine Syntaxfehler selbst beheben. shedule - ein Schreibfehler es ist schedule und bei meinem Beispiel setIntervall ist setInterval ebenfalls ein Schreibfehler der ohne Editor halt mal vorkommt. Die sind meist unterstrichen, was nicht heißt das alles unterstrichene ein Fehler ist.

                                      in deinem Beispiel code fehlt auch ein weiteres:

                                      });
                                      

                                      am Ende
                                      hier siehst du die ioBroker Funktionen: https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md

                                      Außerdem hat der Adapter zumindest bei mir den Bug das er mir die letzten 3-5 Zeilen nicht anzeigt und ich erstmal ganz ans ende mit den Cursortasten gehe und ein paar Leerzeilen einfüge.

                                      T Offline
                                      T Offline
                                      T0biT3ch
                                      schrieb am zuletzt editiert von
                                      #76

                                      @ticaki
                                      sorry für die späte rückmeldung. erstmal danke für deine hilfe, leider bin ich mit dem javascript noch nicht so ganz vertraut.
                                      habe mir übers wochenende aber schon einiges an lektüre durchgelesen. jetzt wo ich den tip mit den schreibfehler bekommen habe hatte ich gesehen das es im code unterstrichen war. hab ich wohl vor lauter code übersehen.

                                      habe den code jetzt mit

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

                                      am laufen.

                                      vielen dank euch nochmal für die unterstützung, ihr seid klasse. :+1:

                                      1 Antwort Letzte Antwort
                                      0
                                      • T Offline
                                        T Offline
                                        T0biT3ch
                                        schrieb am zuletzt editiert von T0biT3ch
                                        #77

                                        @OliverIO @ticaki @fastfoot

                                        Guten Abend Profis,
                                        Ich habe folgendes Problem welches schnellstmöglich gelöst werden muss da ich leider keine Alarme mehr bekomme.
                                        Heute hat mein ioBroker ein Update gemacht und jetzt läuft meine Alarmierung nicht mehr.

                                        hier mein bis heute vor dem Update funktionierendes Skript

                                        const axios = require('axios');
                                        
                                        var alarmmeldung_ml = "0_userdata.0.Alarmmeldungen.Alarmierungstext_Variable";
                                        
                                        
                                        console.log(getState("0_userdata.0.E-Message_Data.E-Message-TrackingID").val);
                                        
                                        function auth() {
                                         
                                            axios.post('https://api.emessage.de/auth/login',{
                                                username: '******',         //* E*Message Benutzername */ 
                                                password: '*******'   //* E*Message Kennwort */ 
                                            },{
                                                headers: {
                                                    'Authorization': 'Basic Og==',
                                                    'Content-Type': 'application/json',
                                                }
                                            }).then(function (response) {
                                                if (response.status==200) {
                                                    var token = response.data.data.jwt;
                                                    setState("0_userdata.0.E-Message_Data.E-Message-Token", response.data.data.jwt, true);
                                                    sendMessage(token)
                                                }
                                            })
                                            .catch(function (error) {
                                                console.log(error);
                                            });
                                            
                                        }
                                         
                                        function sendMessage(token) {
                                            axios.post('https://api.emessage.de/rs/eSendMessages',{
                                                "messageText": getState(alarmmeldung_ml).val,     //* Pocsag Nachricht an Pager */ //* bei mir durch einen Datenpunkt ersetzt */
                                                "recipients": [
                                                    {
                                                    "serviceName": "2wayS",  //* Alarmierungstyp */ //* eCityruf - eBos - 2wayS */ eCityruf */
                                                    "identifier": "******"     //* E*Message Funkrufnummer */
                                                    }
                                                ]
                                            },{
                                                    headers: {
                                                        'Content-Type': 'application/json',
                                                        'Authorization': 'Bearer ' + token,
                                                    }
                                        
                                            }).then(function (response) {
                                                if (response.status==200) {
                                                    setState("0_userdata.0.E-Message_Data.E-Message-TrackingID", response.data.data.trackingId, true);
                                                    //
                                                    var recipients = JSON.stringify(response.data.data.recipients);
                                                    setState("0_userdata.0.E-Message_Data.E-Message-Recipients", recipients, true);
                                                    //
                                                    console.log (JSON.stringify(response.data.data));  //(tridneu);
                                                    createEventlog("Alarmierung :" , getState(alarmmeldung_ml).val);
                                                    //
                                                    //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);
                                                }
                                        
                                            })
                                            .catch(function (error) {
                                                console.log(error);
                                            });
                                         }
                                         
                                        auth();
                                        

                                        nach dem Update kommt folgender fehler in der Log

                                        javascript.0 (4430) script.js.Alarmierung_Pager_via_Wago.Pager_ausloesen.Pager_ausloesen: {'message':'Request failed with status code 401','name':'AxiosError','config':{'transitional':{'silentJSONParsing':true,'forcedJSONParsing':true,'clarifyTimeoutError':false},'transformRequest':[null],'transformResponse':[null],'timeout':0,'xsrfCookieName':'XSRF-TOKEN','xsrfHeaderName':'X-XSRF-TOKEN','maxContentLength':-1,'maxBodyLength':-1,'env':{},'headers':{'Accept':'application/json, text/plain, */*','Content-Type':'application/json','User-Agent':'axios/0.27.2','Content-Length':100},'method':'post','url':'https://api.emessage.de/rs/eSendMessages','data':'{\'messageText\':\'keine Aktive Meldung\',\'recipients\':[{\'serviceName\':\'2wayS\',\'identifier\':\'******\'}]}'},'code':'ERR_BAD_REQUEST','status':401}
                                        

                                        Ich hoffe Ihr könnt mir bei dem Problem behilflich sein.

                                        Gruß

                                        HomoranH OliverIOO 2 Antworten Letzte Antwort
                                        0
                                        • T T0biT3ch

                                          @OliverIO @ticaki @fastfoot

                                          Guten Abend Profis,
                                          Ich habe folgendes Problem welches schnellstmöglich gelöst werden muss da ich leider keine Alarme mehr bekomme.
                                          Heute hat mein ioBroker ein Update gemacht und jetzt läuft meine Alarmierung nicht mehr.

                                          hier mein bis heute vor dem Update funktionierendes Skript

                                          const axios = require('axios');
                                          
                                          var alarmmeldung_ml = "0_userdata.0.Alarmmeldungen.Alarmierungstext_Variable";
                                          
                                          
                                          console.log(getState("0_userdata.0.E-Message_Data.E-Message-TrackingID").val);
                                          
                                          function auth() {
                                           
                                              axios.post('https://api.emessage.de/auth/login',{
                                                  username: '******',         //* E*Message Benutzername */ 
                                                  password: '*******'   //* E*Message Kennwort */ 
                                              },{
                                                  headers: {
                                                      'Authorization': 'Basic Og==',
                                                      'Content-Type': 'application/json',
                                                  }
                                              }).then(function (response) {
                                                  if (response.status==200) {
                                                      var token = response.data.data.jwt;
                                                      setState("0_userdata.0.E-Message_Data.E-Message-Token", response.data.data.jwt, true);
                                                      sendMessage(token)
                                                  }
                                              })
                                              .catch(function (error) {
                                                  console.log(error);
                                              });
                                              
                                          }
                                           
                                          function sendMessage(token) {
                                              axios.post('https://api.emessage.de/rs/eSendMessages',{
                                                  "messageText": getState(alarmmeldung_ml).val,     //* Pocsag Nachricht an Pager */ //* bei mir durch einen Datenpunkt ersetzt */
                                                  "recipients": [
                                                      {
                                                      "serviceName": "2wayS",  //* Alarmierungstyp */ //* eCityruf - eBos - 2wayS */ eCityruf */
                                                      "identifier": "******"     //* E*Message Funkrufnummer */
                                                      }
                                                  ]
                                              },{
                                                      headers: {
                                                          'Content-Type': 'application/json',
                                                          'Authorization': 'Bearer ' + token,
                                                      }
                                          
                                              }).then(function (response) {
                                                  if (response.status==200) {
                                                      setState("0_userdata.0.E-Message_Data.E-Message-TrackingID", response.data.data.trackingId, true);
                                                      //
                                                      var recipients = JSON.stringify(response.data.data.recipients);
                                                      setState("0_userdata.0.E-Message_Data.E-Message-Recipients", recipients, true);
                                                      //
                                                      console.log (JSON.stringify(response.data.data));  //(tridneu);
                                                      createEventlog("Alarmierung :" , getState(alarmmeldung_ml).val);
                                                      //
                                                      //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);
                                                  }
                                          
                                              })
                                              .catch(function (error) {
                                                  console.log(error);
                                              });
                                           }
                                           
                                          auth();
                                          

                                          nach dem Update kommt folgender fehler in der Log

                                          javascript.0 (4430) script.js.Alarmierung_Pager_via_Wago.Pager_ausloesen.Pager_ausloesen: {'message':'Request failed with status code 401','name':'AxiosError','config':{'transitional':{'silentJSONParsing':true,'forcedJSONParsing':true,'clarifyTimeoutError':false},'transformRequest':[null],'transformResponse':[null],'timeout':0,'xsrfCookieName':'XSRF-TOKEN','xsrfHeaderName':'X-XSRF-TOKEN','maxContentLength':-1,'maxBodyLength':-1,'env':{},'headers':{'Accept':'application/json, text/plain, */*','Content-Type':'application/json','User-Agent':'axios/0.27.2','Content-Length':100},'method':'post','url':'https://api.emessage.de/rs/eSendMessages','data':'{\'messageText\':\'keine Aktive Meldung\',\'recipients\':[{\'serviceName\':\'2wayS\',\'identifier\':\'******\'}]}'},'code':'ERR_BAD_REQUEST','status':401}
                                          

                                          Ich hoffe Ihr könnt mir bei dem Problem behilflich sein.

                                          Gruß

                                          HomoranH Nicht stören
                                          HomoranH Nicht stören
                                          Homoran
                                          Global Moderator Administrators
                                          schrieb am zuletzt editiert von
                                          #78

                                          @t0bit3ch hat das irgendwas mit dem bisherigen Thread zu tun?
                                          wenn nein, bitte neuen Thread mit allen notwendigen Informationen aufmachen

                                          https://forum.iobroker.net/topic/51555/hinweise-für-gute-forenbeiträge/1

                                          kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                          der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                          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

                                          612

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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