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.
    • wendy2702
      wendy2702 last edited by

      Hi,

      mir ist heute aufgefallen das ich seit irgendeinem Javascript Adapter diesen Log Eintrag von einem Script bekomme:

      error	(24015) script.js.common.Ansagen.Ansage_Telegramm_DWD_5_Warnungen: Invalid callback for setTimeout! - undefined
      
      

      Da ich kein Javascript experte bin fehlt mir die Ahnung was im Script geändert werden muss/sollte. Kann mir wer helfen?

      Hier das Script:

      /* ************************************************************************* */
      /*             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
      
      /* 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.description";
         var idDescription1 = "dwd.0.warning1.description";
         var idDescription2 = "dwd.0.warning2.description";
         var idDescription3 = "dwd.0.warning3.description";
         var idDescription4 = "dwd.0.warning4.description";
         
      /* 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) {
         newDescriptions[0] = dp.state.val;
         var warn = 'dwd.0.warning';
           setTimeout(function() {
              newHeadlines[0] = getState(warn + '.headline').val;
              newBegins[0] = getState(warn + '.begin').val;
              newEnds[0] = getState(warn + '.end').val;
             }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      
      on(idDescription1, function(dp) {
         newDescriptions[1] = dp.state.val;
         var warn = 'dwd.0.warning1';
           setTimeout(function() {
              newHeadlines[1] = getState(warn + '.headline').val;
              newBegins[1] = getState(warn + '.begin').val;
              newEnds[1] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      
      on(idDescription2, function(dp) {
         newDescriptions[2] = dp.state.val;
         var warn = 'dwd.0.warning2';
           setTimeout(function() {
              newHeadlines[2] = getState(warn + '.headline').val;
              newBegins[2] = getState(warn + '.begin').val;
              newEnds[2] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      on(idDescription3, function(dp) {
         newDescriptions[3] = dp.state.val;
         var warn = 'dwd.0.warning3';
           setTimeout(function() {
              newHeadlines[3] = getState(warn + '.headline').val;
              newBegins[3] = getState(warn + '.begin').val;
              newEnds[3] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      on(idDescription4, function(dp) {
         newDescriptions[4] = dp.state.val;
         var warn = 'dwd.0.warning4';
           setTimeout(function() {
              newHeadlines[4] = getState(warn + '.headline').val;
              newBegins[4] = getState(warn + '.begin').val;
              newEnds[4] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      
      

      T 1 Reply Last reply Reply Quote 0
      • 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
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            888
                                            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