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.
    • 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
            • T
              T0biT3ch @T0biT3ch last edited by

              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 🤔

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

                  @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 Reply Last reply Reply Quote 0
                  • T
                    T0biT3ch last edited by 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ß

                    Homoran OliverIO 2 Replies Last reply Reply Quote 0
                    • Homoran
                      Homoran Global Moderator Administrators @T0biT3ch last edited by

                      @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

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

                        @t0bit3ch sagte in Hilfe bei der Script erstellung:

                        api.emessage.de

                        @Homoran ja hat es.

                        @T0biT3ch
                        Die Fehlermeldung ist etwas uneinheitlich

                        1. Fehlermeldung 401 bedeutet eigentlich Unauthorized
                          https://developer.mozilla.org/de/docs/Web/HTTP/Status/401
                          Stimmen deine Anmeldeparameter?

                        2. Weiterhin steht aber auch ERR_BAD_REQUEST (was auch der Fehlercode 400 sein kann)
                          Der steht dafür das der Server die Anfrage nicht verarbeiten kann, was auf eine evtl API-Änderung hinweisen kann

                        3. als messageText steht auch "keine Aktive Meldung"
                          Was ja als normale Rückmeldung zu werten wäre.

                        Kannst du mal 1+2 Überprüfen ob es da Änderungen gab?

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

                          @oliverio

                          zu 1. Ja die Anmeldeparameter Stimmen, habe alles mit dem Programm Postman überprüft.

                          zu 2. Ich denke die API Parameter sind noch korrekt da ich Sie grad in Postman getestet habe und Sie heute Vormittag vor dem Update auch noch Funktioniert haben.

                          zu 3. der Text "keine Aktive Meldung" wir nach jedem Senden einer Alarmmeldung Automatisch in den Datenpunkt geschrieben und dient nur als Dummy

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

                            @t0bit3ch
                            und mit postman kannst du dich anmelden, den token abholen
                            und auch die daten abrufen?

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

                              @oliverio

                              ja damit funktioniert es

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

                                @oliverio
                                Es wurde an den Programmen nichts verändert oder an den Einstellungen vom ioBroker. Es lief alles wunderbar und nach dem Update habe ich mich gewundert das kein Alarm mehr gesendet wird. habe auch versucht den JavaScript Adapter auf eine vorherige Version zurück zu setzen, aber ohne erfolg.

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

                                  @t0bit3ch

                                  dann muss es noch ein unterschied zwischen deinen aufbereiteten daten und den vom postman geben.
                                  kann ich aber schlecht vergleichen

                                  der abruf des tokens funktionier?
                                  dann kann man den ersten teil schon mal abhaken.

                                  für den 2.Teil jede einzelne Information prüfen, ob sie in der richtigen form in das objekt wandert. am besten das objekt vor absenden einmal ausgeben. also das hier

                                  {
                                          "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,
                                              }
                                   
                                      }
                                  

                                  und dann auch mit den daten vom postman vergleichen, ob das genau identisch aufgebaut ist.
                                  nicht das in der message zeichen enthalten sind die nicht erlaubt sind
                                  oder nicht escapete Anführungsstriche

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

                                    @oliverio

                                    hatte es nochmal im ioBroker mit diesen Scripten probiert

                                    var axios = require('axios');
                                    var data = JSON.stringify({
                                      "username": "USERNAME",
                                      "password": "PASSWORD"
                                    });
                                     
                                    var config = {
                                      method: 'post',
                                      url: 'https://api.emessage.de/auth/login',
                                      headers: { 
                                        'Authorization': 'Basic Og==', 
                                        'Content-Type': 'application/json'
                                      },
                                      data : data
                                    };
                                     
                                    axios(config)
                                    .then(function (response) {
                                      console.log(JSON.stringify(response.data));
                                    })
                                    .catch(function (error) {
                                      console.log(error);
                                    });
                                    
                                    
                                    var axios = require('axios');
                                    var data = JSON.stringify({
                                      "messageText": "Testnachricht",
                                      "recipients": [
                                        {
                                          "serviceName": "eCityruf",
                                          "identifier": "********"
                                        }
                                      ]
                                    });
                                     
                                    var config = {
                                      method: 'post',
                                      url: 'https://api.emessage.de/rs/eSendMessages',
                                      headers: { 
                                        'Authorization': 'Bearer hgöfhogsioghösibnovdjuös<opriheourhweidjmanspkf<gob vuodsöahgbfdosuib0dsifohw84u0ü93rhfouisjhbgnvsoifedsökgpfingüer4984utißqü+äowfmägjhipoqehwfüouasdhgousgjohugurhgjiwehfgiwhfwquhbdcasukojgbhikgögloadfjasfghitiu<fbghkjybgvidfgdhfhgkjhlkzthgtzjklioölzfkdtjrhgstgfzhjui.k,mnjhbgvfadeshgjm', 
                                        'Content-Type': 'application/json'
                                      },
                                      data : data
                                    };
                                     
                                    axios(config)
                                    .then(function (response) {
                                      console.log(JSON.stringify(response.data));
                                    })
                                    .catch(function (error) {
                                      console.log(error);
                                    });
                                     
                                    

                                    und damit hat es funktioniert. Ich kann in meinem Script keinen unterschied feststellen

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

                                      @oliverio

                                      Hatte jetzt nochmal dieses Script genommen

                                      const axios = require('axios');
                                       
                                      function auth() {
                                       
                                          axios.post('https://api.emessage.de/auth/login',{
                                              username: 'USERNAME',
                                              password: 'PASSWORD'
                                          },{
                                              headers: {
                                                  'Authorization': 'Basic Og==',
                                                  'Content-Type': 'application/json',
                                              }
                                          }).then(function (response) {
                                              if (response.status==200) {
                                                  var token = response.data.data.jwt;
                                                  sendMessage(token)
                                              }
                                          })
                                          .catch(function (error) {
                                              console.log(error);
                                          });
                                          
                                      }
                                       
                                      function sendMessage(token) {
                                          axios.post('https://api.emessage.de/rs/eSendMessages',{
                                              "messageText": "Testnachricht",
                                              "recipients": [
                                                  {
                                                  "serviceName": "eCityruf",
                                                  "identifier": "********"
                                                  }
                                              ]
                                          },{
                                                  headers: {
                                                      'Content-Type': 'application/json',
                                                      'Authorization': 'Bearer ' + token,
                                                  }
                                          
                                          })
                                          .catch(function (error) {
                                              console.log(error);
                                          });
                                       }
                                       
                                      auth();
                                      
                                      

                                      und bekomme diese Log

                                      javascript.0 (4430) script.js.Alarmierung_Pager_via_Wago.Pager_ausloesen.Test: {'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':93},'method':'post','url':'https://api.emessage.de/rs/eSendMessages','data':'{\'messageText\':\'Testnachricht\',\'recipients\':[{\'serviceName\':\'2wayS\',\'identifier\':\'*****\'}]}'},'code':'ERR_BAD_REQUEST','status':401}
                                      

                                      und der Pager bleibt still

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

                                        @t0bit3ch
                                        der unterschied ist, das du einmal das token fest vorgegeben hast und beim anderen life abfragst

                                        dann stimmt an der abfrage des tokens oder dem einfügen des tokens etwas nicht

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

                                          @t0bit3ch

                                          und beim ersten wird data als JSON.stringify hinzugefügt

                                          Beim 2. direkt als Objekt.
                                          mach da auch mal ein stringify drum rum

                                          beim 2. sind auch noch header dabei, beim ersten nicht

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

                                            @oliverio

                                            aber in diesem Script wird der Token doch in keinem Datenpunkt hinterlegt oder?

                                            const axios = require('axios');
                                             
                                            function auth() {
                                             
                                                axios.post('https://api.emessage.de/auth/login',{
                                                    username: 'USERNAME',
                                                    password: 'PASSWORD'
                                                },{
                                                    headers: {
                                                        'Authorization': 'Basic Og==',
                                                        'Content-Type': 'application/json',
                                                    }
                                                }).then(function (response) {
                                                    if (response.status==200) {
                                                        var token = response.data.data.jwt;
                                                        sendMessage(token)
                                                    }
                                                })
                                                .catch(function (error) {
                                                    console.log(error);
                                                });
                                                
                                            }
                                             
                                            function sendMessage(token) {
                                                axios.post('https://api.emessage.de/rs/eSendMessages',{
                                                    "messageText": "Testnachricht",
                                                    "recipients": [
                                                        {
                                                        "serviceName": "eCityruf",
                                                        "identifier": "********"
                                                        }
                                                    ]
                                                },{
                                                        headers: {
                                                            'Content-Type': 'application/json',
                                                            'Authorization': 'Bearer ' + token,
                                                        }
                                                
                                                })
                                                .catch(function (error) {
                                                    console.log(error);
                                                });
                                             }
                                             
                                            auth();
                                             
                                            
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            718
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

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