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

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

                                            Bestellte Änderungen eingefügt. 🙂

                                            Hab die Pushdiensteinstellung geändert sollte selbst erklärend sein.
                                            Die Formatierung von Datum/Zeit ist oben im Script und kann angepasst werden.

                                            EDIT: die Pusheinstellungen hab ich geändert, weil mir die Fehlermeldungen wegen fehlendem SayIt auf den Keks gingen 🙂

                                            /* ************************************************************************* */
                                            /*             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 */
                                            /* Konstanten nicht verändern */
                                            const TELEGRAM = 1; 
                                            const PUSHOVER = 2;
                                            const EMAIL = 4;
                                            const SAYIT = 8;
                                            var pushdienst=0; 
                                            //pushdienst+= TELEGRAM;          // Auskommentieren zum aktivieren
                                            //pushdienst+= PUSHOVER;          // Auskommentieren zum aktivieren
                                            //pushdienst+= EMAIL;             // Auskommentieren zum aktivieren
                                            //pushdienst+= SAYIT;             // Auskommentieren zum aktivieren
                                            
                                            
                                            var senderEmailID = ""; // mit Sender Emailadresse füllen. email Adapter muß installiert sein
                                            var empfaengerEmailID = "";// mit Empfänger Emailadresse füllen.
                                            
                                            // Filter einstellungen
                                            const minlevel = 0 // Warnungen gleich oder unterhalb dieses Levels nicht senden;
                                            const maxhoehe = 1000 // Warnung für eine Höhe oberhalb dieses Wertes nicht senden
                                            
                                            //Formatierungsstring für Datum/Zeit Alternative "TT.MM.YYYY SS:mm"
                                            const formatierungString = "TT.MM.YY SS:mm";
                                            
                                            
                                            /* 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((pushdienst & SAYIT)!=0 && 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((pushdienst & SAYIT)!=0 && idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
                                                  setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                                                }
                                                if ((pushdienst & TELEGRAM)!=0 ) {
                                                  setTimeout(()=>(sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
                                                }
                                                if ((pushdienst & PUSHOVER)!=0 ) {
                                                  sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                                                }
                                                if ((pushdienst & EMAIL)!=0 && senderEmailID != '' && empfaengerEmailID !='') {
                                                  sendEmail('Wetterentwarnung des DWD(iobroker)','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 & TELEGRAM)!=0) {
                                                    setTimeout(()=>(sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                                                  }
                                                  if ((pushdienst & PUSHOVER)!=0) {
                                                    sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                                                  }
                                                  if ((pushdienst & EMAiL)!=0 && 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 & TELEGRAM)!=0) {
                                                    setTimeout(()=>(sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                                                  }
                                                  if ((pushdienst & PUSHOVER)!=0) {
                                                    sendTo("pushover.0", MeldungNew);
                                                  }
                                                  if ((pushdienst & EMAIL)!=0 && 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((pushdienst & SAYIT)!=0 && (idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
                                                var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                                                log('Url2 :' + Url2);
                                                request(Url2);
                                              }
                                              /* Bereich für Sprachausgabe über SayIt */
                                              if((pushdienst & SAYIT)!=0 && (idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
                                                setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                                              }
                                              if ((pushdienst & EMAIL)!=0 && senderEmailID != '' && empfaengerEmailID != '' && AllEmailMsg != '') {
                                                sendEmail("Wetterwarnungen des DWD(iobroker)",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 ? '' : getFormatDate(new Date(warn.start));
                                              newEnds[0] = warn.end === undefined ? '' : getFormatDate(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 ? '' : getFormatDate(new Date(warn.start));
                                              newEnds[1] = warn.end === undefined ? '' : getFormatDate(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 ? '' : getFormatDate(new Date(warn.start));
                                              newEnds[2] = warn.end === undefined ? '' : getFormatDate(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 ? '' : getFormatDate(new Date(warn.start));
                                              newEnds[3] = warn.end === undefined ? '' : getFormatDate(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 ? '' : getFormatDate(new Date(warn.start));
                                              newEnds[4] = warn.end === undefined ? '' : getFormatDate(new Date(warn.end));
                                              if(timer) clearTimeout(timer);
                                              timer = setTimeout(check, 7000);
                                            });
                                            
                                            function getFormatDate(a) {
                                              if (!a) return '';
                                              return formatDate(a.getTime(), formatierungString);
                                            }
                                            
                                            function sendEmail(topic, msg) {
                                              if (senderEmailID=='') {
                                                log('senderEmailID ist nicht definiert!','warn');
                                                return;
                                              }
                                              if (empfaengerEmailID=='') {
                                                log('empfaengerEmailID ist nicht definiert!','warn');
                                                return;
                                              }
                                              sendTo("email", {
                                                from:    senderEmailID,
                                                to:      empfaengerEmailID,
                                                subject: topic,
                                                text:    msg
                                              });
                                            }
                                            
                                            
                                            

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            896
                                            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