Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Fehler im script nach Update Adapter

    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

    Fehler im script nach Update Adapter

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      ticaki Developer @wendy2702 last edited by ticaki

      @wendy2702 sagte in Fehler im script nach Update Adapter:

      setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);

      ändere:

      setTimeout((sendTo
      

      in

      setTimeout(()=>(sendTo
      

      überall.

      wendy2702 1 Reply Last reply Reply Quote 0
      • wendy2702
        wendy2702 last edited by

        Danke!

        Habe es geändert und werde beobachten.

        1 Reply Last reply Reply Quote 0
        • Latzi
          Latzi last edited by

          Ich bekomme seit heute in unregelmäßigen Abständen folgende Fehlermeldung:

          2020-02-21 20:16:46.642  - error: javascript.0 (1730) script.js.common.Skript_UWZ: TypeError: Cannot read property 'request' of undefined
          2020-02-21 20:16:46.642  - error: javascript.0 (1730)     at Request._callback (script.js.common.Skript_UWZ:223:57)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at self.callback (/opt/iobroker/node_modules/request/request.js:185:22)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at Request.emit (events.js:198:13)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at Timeout._onTimeout (/opt/iobroker/node_modules/request/request.js:852:16)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at ontimeout (timers.js:436:11)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at tryOnTimeout (timers.js:300:5)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at listOnTimeout (timers.js:263:5)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at Timer.processTimers (timers.js:223:10)
          

          Der relevante Teil des Scripts dürfte folgender sein:

          var request = require('request');
          schedule ("* * * * *", function(){
              for (var i=0; i<warncellid.length; i++) {
                      request({  
                          uri: url.replace("XXXAREAXXX",warncellid[i]),
                          method: "GET",
                          timeout: 10000,
                          followRedirect: true,
                          maxRedirects: 10
                      }, function(error, response, body) {
                          // dwmlog("UWZ Error" + error,2);
                          // dwmlog("UWZ Response: " + JSON.stringify(response),4);
                          dwmlog("AREA: "+getAreaFromURI(response.request.uri.href),4);
                          dwmlog("UWZ Body: " + body,4);
                          if (response.statusCode == 200) {
                              processData(getAreaFromURI(response.request.uri.href),body);
                          }
                      });    
              }
          });
          

          Hat jemand eine Idee woran das liegen kann, da das Script schon seit längerer Zeit problemlos lief und ich wissentlich nichts geändert habe.

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

            In der Fehlermeldung steht das

            response
            

            undefiniert ist. Mit einer Abfrage auf undefined kannst du die Funktion verlassen.

            11 if ( response == undefined ) return;
            
            Latzi 1 Reply Last reply Reply Quote 1
            • Latzi
              Latzi @ticaki last edited by

              @ticaki sagte in Fehler im script nach Update Adapter:

              Mit einer Abfrage auf undefined kannst du die Funktion verlassen.

              Das schaut bislang sehr gut aus, vielen Dank 👏

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

                @ticaki sagte in Fehler im script nach Update Adapter:

                @wendy2702 sagte in Fehler im script nach Update Adapter:

                setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);

                ändere:

                setTimeout((sendTo
                

                in

                setTimeout(()=>(sendTo
                

                überall.

                Hi,

                Ich habe zwar keine Fehler mehr im Log aber die Telegramm Nachricht wenn Meldungen aufgehoben wurden sieht jetzt immer so aus:

                „Die Wetterwarnung ´undefined gültig bis undefined´des DWD wurde aufgehoben.“

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

                  @wendy2702
                  Der DWD Adapter gibt in der Stable keine gültigen Werte für begin/end. Ich hab gerade lust und schreibe das Script um 🙂

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

                    Habs etwas getested, aber leider kein Sayit oder pushover zur Verfügung.

                    zusätzlich hab ich noch einen Filter für Höhe und Level eingebaut.

                    /* ************************************************************************* */
                    /*             Script zum Übertragen der DWD-Wetterwarnungen über            */
                    /*             Telegram, Pushover, Home24-Mediaplayer oder SayIt             */
                    /*     mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals)     */
                    /*                    Stand: 130022017    PrinzEisenherz1                    */
                    /*                                                                           */
                    /*     - Fehlerbehebung z.B. 5 gültig bis 5                                  */
                    /*                                                                           */
                    /*                                                                           */
                    /*                                                                           */
                    /*                                                                           */
                    /*                          Variante für 5-warnings                          */
                    /*                                                                           */
                    /* ************************************************************************* */
                    var request = require('request');
                    
                    /* Nachrichten-Dienst festlegen */
                    /* aus=0 ; alle=1 ; Pushover=2 ; Telegram=3 */
                    var pushdienst = 3;         // Auswahl Nachrichtendienst
                    
                    const minlevel = 0 // Warnungen unterhalb dieses Levels nicht senden;
                    const maxhoehe = 1000 // Warnung mit für eine Höhe oberhalb dieses Wertes nicht senden
                    /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                    var idSprachausgabe = false;   // Wenn zusätzlich eine Sprachausgabe erfolgen soll dann auf true
                    var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                    
                    /* Konfiguration Sprachausgabe über SayIt */
                    var idSprachausgabeSayIt = true;   // Wenn zusätzlich eine Sprachausgabe über SayIt erfolgen soll dann auf true
                    var idSayIt = "sayit.0.tts.text";
                    var lautstaerke = 60;
                    
                    /* Trigger für Wetterwarnungen */
                    var idDescription0 = "dwd.0.warning.object";
                    var idDescription1 = "dwd.0.warning1.object";
                    var idDescription2 = "dwd.0.warning2.object";
                    var idDescription3 = "dwd.0.warning3.object";
                    var idDescription4 = "dwd.0.warning4.object";
                    
                    /* Arrays festlegen */
                    var newDescriptions = [5];
                    var oldDescriptions = [5];
                    var newHeadlines = [5];
                    var oldHeadlines = [5];
                    var newBegins = [5];
                    var oldBegins = [5];
                    var newEnds = [5];
                    var oldEnds = [5];
                    var timer = null;
                    /* aktivieren bzw erstmaliges Befüllen der arrays */
                    newDescriptions[0] = '';
                    newDescriptions[1] = '';
                    newDescriptions[2] = '';
                    newDescriptions[3] = '';
                    newDescriptions[4] = '';
                    oldDescriptions[0] = '';
                    oldDescriptions[1] = '';
                    oldDescriptions[2] = '';
                    oldDescriptions[3] = '';
                    oldDescriptions[4] = '';
                    
                    newHeadlines[0] = '';
                    newHeadlines[1] = '';
                    newHeadlines[2] = '';
                    newHeadlines[3] = '';
                    newHeadlines[4] = '';
                    oldHeadlines[0] = '';
                    oldHeadlines[1] = '';
                    oldHeadlines[2] = '';
                    oldHeadlines[3] = '';
                    oldHeadlines[4] = '';
                    
                    newBegins[0] = '';
                    newBegins[1] = '';
                    newBegins[2] = '';
                    newBegins[3] = '';
                    newBegins[4] = '';
                    oldBegins[0] = '';
                    oldBegins[1] = '';
                    oldBegins[2] = '';
                    oldBegins[3] = '';
                    oldBegins[4] = '';
                    
                    newEnds[0] = '';
                    newEnds[1] = '';
                    newEnds[2] = '';
                    newEnds[3] = '';
                    newEnds[4] = '';
                    oldEnds[0] = '';
                    oldEnds[1] = '';
                    oldEnds[2] = '';
                    oldEnds[3] = '';
                    oldEnds[4] = '';
                    
                    function check() {
                      /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
                      if(newDescriptions[0] === "") {
                        MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
                        /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                        if(idSprachausgabe === true){
                          var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                          request(Url);
                        }
                        
                        /* Bereich für Sprachausgabe SayIt im Zeitraum */	  
                        var ENDE= '22:30';                     // Ende immer 22:30h
                        var START;
                        
                        
                        schedule("0 6 * * *", function (){                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist          
                          var date = new Date();
                          var n = date.getDay();
                          var weekend = 0;
                          weekend = (n === 0 || n == 6) ? 1 : 0;
                          
                          if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
                            START = '9:00';  
                          }    
                          else{
                            START = '6:45';
                          }
                          
                        });
                        
                        
                        /* Bereich für Sprachausgabe über SayIt */
                        if(idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
                          setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                        }
                        if ((pushdienst === 3) || (pushdienst === 1) ) {
                          setTimeout(()=>(sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
                        }
                        if ((pushdienst === 2) || (pushdienst === 1) ) {
                          sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                        }
                        
                        /* alle Sicherungen Wetterwarnung löschen */
                        oldHeadlines = newHeadlines.slice();
                        oldDescriptions = newDescriptions.slice();
                        oldBegins = newBegins.slice();
                        oldEnds = newEnds.slice();
                        return;
                      }
                      
                      /* Variablen für Meldungen Text */
                      var MeldungOld = '';
                      var MeldungNew = '';
                      /* Variablen für Meldungen Sprache */
                      var MeldungSpracheDWD = '';
                      var MeldungNewSprache = '';
                      var MeldungOldSprache = '';
                      
                      var headline;
                      var description;
                      var begin;
                      var end;
                      var i;
                      var warn;
                      
                      /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
                      for(i = 0; i < 5; i++) {
                        warn = 'dwd.0.warning';
                        if(i) warn = warn + i;
                        headline = oldHeadlines[i];
                        description = oldDescriptions[i];
                        begin = oldBegins[i];
                        end = oldEnds[i];
                        if(newDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                          MeldungOld = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben';
                          MeldungOldSprache = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben' + '  .  ';
                          if ((pushdienst === 3) || (pushdienst === 1) ) {
                            setTimeout(()=>(sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                          }
                          if ((pushdienst === 2) || (pushdienst === 1) ) {
                            sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                          }
                          /* Verknüpfen aller aufgehobenen Wetterwarnungen */
                          if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
                            MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
                          }
                        }
                      }
                      
                      /* Bereich für 'Neue Amtliche Wetterwarnung' */
                      for(i = 0; i < 5; i++) {
                        warn = 'dwd.0.warning';
                        if(i) warn = warn + i;
                        headline = newHeadlines[i];
                        description = newDescriptions[i];
                        begin = newBegins[i];
                        end = newEnds[i];
                        if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                          MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
                          /* Entfernen °C für Sprachausgabe */
                          var replaceDescription0 = entferneDatenpunkt(description);
                          MeldungNewSprache = headline + " gültig vom " + begin + " Uhr, bis " + end + " Uhr. " + replaceDescription0 + '  .  ';
                          if ((pushdienst === 3) || (pushdienst === 1) ) {
                            setTimeout(()=>(sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                          }
                          if ((pushdienst === 2) || (pushdienst === 1) ) {
                            sendTo("pushover.0", MeldungNew);
                          }
                          /* Verknüpfen aller neuen Warnmeldungen */
                          if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
                            MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
                          }
                        }
                      }
                      /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
                      MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
                      
                      /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                      if((idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
                        var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                        log('Url2 :' + Url2);
                        request(Url2);
                      }
                      /* Bereich für Sprachausgabe über SayIt */
                      if((idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
                        setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                      }
                      
                      /* Neue Werte sichern */
                      oldHeadlines = newHeadlines.slice();
                      oldDescriptions = newDescriptions.slice();
                      oldBegins = newBegins.slice();
                      oldEnds = newEnds.slice();
                    }
                    
                    /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
                    function entferneDatenpunkt(beschreibung) {
                      var rueckgabe;
                      rueckgabe = beschreibung;
                      try {
                        rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
                        rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
                      }
                      catch(e) {}
                      return rueckgabe;
                    }
                    on(idDescription0, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[0] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[0] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[0] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[0] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    
                    on(idDescription1, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[1] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[1] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[1] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[1] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    
                    on(idDescription2, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[2] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[2] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[2] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[2] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    on(idDescription3, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[3] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[3] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[3] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[3] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    on(idDescription4, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[4] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[4] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[4] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[4] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    

                    sigi234 1 Reply Last reply Reply Quote 0
                    • crunchip
                      crunchip Forum Testing Most Active last edited by

                      Mal ne generelle Frage zu dem script, wie bekommt ihr die Wetter warnung per sayit?
                      Eigentlich ist doch die Warnungs-Meldung zu lang, folglich kommt im log ne Meldung

                      .....is to short

                      wendy2702 1 Reply Last reply Reply Quote 0
                      • sigi234
                        sigi234 Forum Testing Most Active @ticaki last edited by

                        @ticaki

                        Cool, kannst du auch email einbauen?

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

                          @sigi234
                          Jo, aber nicht heute 🙂 Hab gerade keine eigenen Ideen, aber lust aufs coden

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

                            @sigi234
                            ok doch noch heute, ist aber nicht weiter getestet.

                            /* ************************************************************************* */
                            /*             Script zum Übertragen der DWD-Wetterwarnungen über            */
                            /*             Telegram, Pushover, Home24-Mediaplayer oder SayIt             */
                            /*     mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals)     */
                            /*                    Stand: 130022017    PrinzEisenherz1                    */
                            /*                                                                           */
                            /*     - Fehlerbehebung z.B. 5 gültig bis 5                                  */
                            /*                                                                           */
                            /*                                                                           */
                            /*                                                                           */
                            /*                                                                           */
                            /*                          Variante für 5-warnings                          */
                            /*                                                                           */
                            /* ************************************************************************* */
                            var request = require('request');
                            
                            /* Nachrichten-Dienst festlegen */
                            /* aus=0 ; alle=1 ; Pushover=2 ; Telegram=3 */
                            var pushdienst = 3;         // Auswahl Nachrichtendienst
                            
                            const senderEmailID = ''; // mit Sender Emailadresse füllen zum aktivieren. email Adapter muß installiert sein
                            const empfaengerEmailID = '';// mit Empfänger Emailadresse füllen zum aktivieren.
                            
                            const minlevel = 0 // Warnungen unterhalb dieses Levels nicht senden;
                            const maxhoehe = 1000 // Warnung mit für eine Höhe oberhalb dieses Wertes nicht senden
                            /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                            var idSprachausgabe = false;   // Wenn zusätzlich eine Sprachausgabe erfolgen soll dann auf true
                            var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                            
                            /* Konfiguration Sprachausgabe über SayIt */
                            var idSprachausgabeSayIt = true;   // Wenn zusätzlich eine Sprachausgabe über SayIt erfolgen soll dann auf true
                            var idSayIt = "sayit.0.tts.text";
                            var lautstaerke = 60;
                            
                            /* Trigger für Wetterwarnungen */
                            var idDescription0 = "dwd.0.warning.object";
                            var idDescription1 = "dwd.0.warning1.object";
                            var idDescription2 = "dwd.0.warning2.object";
                            var idDescription3 = "dwd.0.warning3.object";
                            var idDescription4 = "dwd.0.warning4.object";
                            
                            /* Arrays festlegen */
                            var newDescriptions = [5];
                            var oldDescriptions = [5];
                            var newHeadlines = [5];
                            var oldHeadlines = [5];
                            var newBegins = [5];
                            var oldBegins = [5];
                            var newEnds = [5];
                            var oldEnds = [5];
                            var timer = null;
                            /* aktivieren bzw erstmaliges Befüllen der arrays */
                            newDescriptions[0] = '';
                            newDescriptions[1] = '';
                            newDescriptions[2] = '';
                            newDescriptions[3] = '';
                            newDescriptions[4] = '';
                            oldDescriptions[0] = '';
                            oldDescriptions[1] = '';
                            oldDescriptions[2] = '';
                            oldDescriptions[3] = '';
                            oldDescriptions[4] = '';
                            
                            newHeadlines[0] = '';
                            newHeadlines[1] = '';
                            newHeadlines[2] = '';
                            newHeadlines[3] = '';
                            newHeadlines[4] = '';
                            oldHeadlines[0] = '';
                            oldHeadlines[1] = '';
                            oldHeadlines[2] = '';
                            oldHeadlines[3] = '';
                            oldHeadlines[4] = '';
                            
                            newBegins[0] = '';
                            newBegins[1] = '';
                            newBegins[2] = '';
                            newBegins[3] = '';
                            newBegins[4] = '';
                            oldBegins[0] = '';
                            oldBegins[1] = '';
                            oldBegins[2] = '';
                            oldBegins[3] = '';
                            oldBegins[4] = '';
                            
                            newEnds[0] = '';
                            newEnds[1] = '';
                            newEnds[2] = '';
                            newEnds[3] = '';
                            newEnds[4] = '';
                            oldEnds[0] = '';
                            oldEnds[1] = '';
                            oldEnds[2] = '';
                            oldEnds[3] = '';
                            oldEnds[4] = '';
                            
                            function check() {
                              /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
                              if(newDescriptions[0] === "") {
                                MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
                                /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                                if(idSprachausgabe === true){
                                  var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                                  request(Url);
                                }
                                
                                /* Bereich für Sprachausgabe SayIt im Zeitraum */	  
                                var ENDE= '22:30';                     // Ende immer 22:30h
                                var START;
                                
                                
                                schedule("0 6 * * *", function (){                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist          
                                  var date = new Date();
                                  var n = date.getDay();
                                  var weekend = 0;
                                  weekend = (n === 0 || n == 6) ? 1 : 0;
                                  
                                  if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
                                    START = '9:00';  
                                  }    
                                  else{
                                    START = '6:45';
                                  }
                                  
                                });
                                
                                
                                /* Bereich für Sprachausgabe über SayIt */
                                if(idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
                                  setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                                }
                                if ((pushdienst === 3) || (pushdienst === 1) ) {
                                  setTimeout(()=>(sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
                                }
                                if ((pushdienst === 2) || (pushdienst === 1) ) {
                                  sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                                }
                                if (senderEmailID!= '' && empfaengerEmailID!='' && AllEmailMsg != '') {
                                    sendTo("email", {
                                        from:    senderEmailID,
                                        to:      empfaengerEmailID,
                                        subject: "Wetterentwarnung des DWD(iobroker)",
                                        text:    'Alle Warnmeldungen des DWD wurden aufgehoben'
                                        });
                                }
                                
                                /* alle Sicherungen Wetterwarnung löschen */
                                oldHeadlines = newHeadlines.slice();
                                oldDescriptions = newDescriptions.slice();
                                oldBegins = newBegins.slice();
                                oldEnds = newEnds.slice();
                                return;
                              }
                              
                              /* Variablen für Meldungen Text */
                              var MeldungOld = '';
                              var MeldungNew = '';
                              /* Variablen für Meldungen Sprache */
                              var MeldungSpracheDWD = '';
                              var MeldungNewSprache = '';
                              var MeldungOldSprache = '';
                              var AllEmailMsg = '';
                              
                              var headline;
                              var description;
                              var begin;
                              var end;
                              var i;
                              var warn;
                              
                              /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
                              for(i = 0; i < 5; i++) {
                                warn = 'dwd.0.warning';
                                if(i) warn = warn + i;
                                headline = oldHeadlines[i];
                                description = oldDescriptions[i];
                                begin = oldBegins[i];
                                end = oldEnds[i];
                                if(newDescriptions.indexOf(description) == -1 && description !== '' && description !== undefined) {
                                  MeldungOld = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben';
                                  MeldungOldSprache = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben' + '  .  ';
                                  if ((pushdienst === 3) || (pushdienst === 1) ) {
                                    setTimeout(()=>(sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                                  }
                                  if ((pushdienst === 2) || (pushdienst === 1) ) {
                                    sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                                  }
                                  if (senderEmailID!= '' && empfaengerEmailID!='') {
                                    AllEmailMsg+="Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben"+'\n';
                                  }
                                  /* Verknüpfen aller aufgehobenen Wetterwarnungen */
                                  if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
                                    MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
                                  }
                                }
                              }
                              
                              /* Bereich für 'Neue Amtliche Wetterwarnung' */
                              for(i = 0; i < 5; i++) {
                                warn = 'dwd.0.warning';
                                if(i) warn = warn + i;
                                headline = newHeadlines[i];
                                description = newDescriptions[i];
                                begin = newBegins[i];
                                end = newEnds[i];
                                if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                                  MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
                                  /* Entfernen °C für Sprachausgabe */
                                  var replaceDescription0 = entferneDatenpunkt(description);
                                  MeldungNewSprache = headline + " gültig vom " + begin + " Uhr, bis " + end + " Uhr. " + replaceDescription0 + '  .  ';
                                  if ((pushdienst === 3) || (pushdienst === 1) ) {
                                    setTimeout(()=>(sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                                  }
                                  if ((pushdienst === 2) || (pushdienst === 1) ) {
                                    sendTo("pushover.0", MeldungNew);
                                  }
                                  if (senderEmailID!= '' && empfaengerEmailID!='') {
                                    AllEmailMsg+=MeldungNew+'\n';
                                  }
                                  /* Verknüpfen aller neuen Warnmeldungen */
                                  if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
                                    MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
                                  }
                                }
                              }
                              /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
                              MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
                              
                              /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                              if((idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
                                var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                                log('Url2 :' + Url2);
                                request(Url2);
                              }
                              /* Bereich für Sprachausgabe über SayIt */
                              if((idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
                                setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                              }
                              if (senderEmailID!= '' && empfaengerEmailID!='' && AllEmailMsg != '') {
                                sendTo("email", {
                                    from:    senderEmailID,
                                    to:      empfaengerEmailID,
                                    subject: "Wetterwarnungen des DWD(iobroker)",
                                    text:    AllEmailMsg
                                    });
                              }
                            
                              /* Neue Werte sichern */
                              oldHeadlines = newHeadlines.slice();
                              oldDescriptions = newDescriptions.slice();
                              oldBegins = newBegins.slice();
                              oldEnds = newEnds.slice();
                            }
                            
                            /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
                            function entferneDatenpunkt(beschreibung) {
                              var rueckgabe;
                              rueckgabe = beschreibung;
                              try {
                                rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
                                rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
                              }
                              catch(e) {}
                              return rueckgabe;
                            }
                            on(idDescription0, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[0] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[0] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[0] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[0] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            
                            on(idDescription1, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[1] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[1] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[1] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[1] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            
                            on(idDescription2, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[2] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[2] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[2] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[2] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            on(idDescription3, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[3] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[3] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[3] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[3] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            on(idDescription4, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[4] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[4] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[4] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[4] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            

                            1 Reply Last reply Reply Quote 1
                            • wendy2702
                              wendy2702 @crunchip last edited by

                              @crunchip Hat mit dem Script bei mir immer Problemlos funktioniert.

                              crunchip 1 Reply Last reply Reply Quote 0
                              • wendy2702
                                wendy2702 @ticaki last edited by wendy2702

                                @ticaki sagte in Fehler im script nach Update Adapter:

                                @wendy2702
                                Der DWD Adapter gibt in der Stable keine gültigen Werte für begin/end. Ich hab gerade lust und schreibe das Script um 🙂

                                Hm,

                                komisch. Bis zu der Änderung die du mir vorgeschlagen hattest liefen die Telegramm Nachrichten eigentlich immer mit richtigen Zeitangaben.

                                Aber egal. Ich teste mal dein neues Script.

                                Danke für deine Bemühungen!!!

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

                                  @wendy2702
                                  Merkwürdig. Naja jetzt sollte es wieder gehen.

                                  1 Reply Last reply Reply Quote 0
                                  • wendy2702
                                    wendy2702 last edited by wendy2702

                                    Hi,

                                    habe dein neues Script implementiert. Leider klappt es aber nicht so richtig (kosmetisch)

                                    So sahen Meldungen aus als ich den kleinen error im Log hatte:

                                    Amtliche WARNUNG vor GLÄTTE
                                    gültig vom 21.02.2020 00:08 Uhr bis 21.02.2020 08:00 Uhr
                                    Es muss oberhalb 400 m mit Glätte durch verbreitet überfrierende Nässe sowie geringfügigen Schneefall gerechnet werden.
                                    

                                    So wenn die Meldung aufgehoben wurde:

                                    Die Wetterwarnung 'Amtliche WARNUNG vor STURMBÖEN gültig bis 21.02.2020 00:00' des DWD wurde aufgehoben
                                    

                                    Nach ändern deiner ersten Anweisung dann so:

                                    Die Wetterwarnung 'undefined gültig bis undefined' des DWD wurde aufgehoben
                                    

                                    Jetzt mit dem neuen Script und der aktuellen DWD Adapter version in der auch etwas mit Zeit geändert wurde kommt jetzt das als Nachricht und auch als Ansage:

                                    Amtliche WARNUNG vor WINDBÖEN
                                    gültig vom Tue Feb 25 2020 10:00:00 GMT+0100 (GMT+01:00) Uhr bis Tue Feb 25 2020 19:00:00 GMT+0100 (GMT+01:00) Uhr
                                    Es treten Windböen mit Geschwindigkeiten zwischen 50 km/h (14m/s, 28kn, Bft 7) und 60 km/h (17m/s, 33kn, Bft 7) aus südwestlicher Richtung auf.
                                    

                                    Hierbei ist das "GMT...." gelaber sehr unschön.

                                    Kann man das irgendwie weg bekommen?

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

                                      @wendy2702
                                      Jo, heute abend ändere ich das. 🙂

                                      1 Reply Last reply Reply Quote 1
                                      • wendy2702
                                        wendy2702 last edited by

                                        Danke!

                                        👍

                                        1 Reply Last reply Reply Quote 0
                                        • crunchip
                                          crunchip Forum Testing Most Active @wendy2702 last edited by

                                          @wendy2702 nachdem ich im sayit die Sprache auf AWS Polly gestellt habe, kam nun auch eine Ansage

                                          1 Reply Last reply Reply Quote 0
                                          • wendy2702
                                            wendy2702 last edited by

                                            OK.

                                            Das habe ich schon aktiv seitdem es diese Möglichkeit gibt.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            904
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            6
                                            62
                                            2442
                                            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