Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Fehler im script nach Update Adapter

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.4k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

Fehler im script nach Update Adapter

Scheduled Pinned Locked Moved JavaScript
62 Posts 6 Posters 3.0k Views 6 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • wendy2702W Online
    wendy2702W Online
    wendy2702
    wrote on last edited by wendy2702
    #17

    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?

    Bitte keine Fragen per PN, die gehören ins Forum!

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

    T 1 Reply Last reply
    0
    • wendy2702W 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 Do not disturb
      T Do not disturb
      ticaki
      wrote on last edited by
      #18

      @wendy2702
      Jo, heute abend ändere ich das. :)

      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

      Spenden

      1 Reply Last reply
      1
      • wendy2702W Online
        wendy2702W Online
        wendy2702
        wrote on last edited by
        #19

        Danke!

        :+1:

        Bitte keine Fragen per PN, die gehören ins Forum!

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

        1 Reply Last reply
        0
        • wendy2702W wendy2702

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

          crunchipC Away
          crunchipC Away
          crunchip
          Forum Testing Most Active
          wrote on last edited by
          #20

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

          umgestiegen von Proxmox auf Unraid

          1 Reply Last reply
          0
          • wendy2702W Online
            wendy2702W Online
            wendy2702
            wrote on last edited by
            #21

            OK.

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

            Bitte keine Fragen per PN, die gehören ins Forum!

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

            1 Reply Last reply
            0
            • T Do not disturb
              T Do not disturb
              ticaki
              wrote on last edited by ticaki
              #22

              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
                });
              }
              
              
              

              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

              Spenden

              1 Reply Last reply
              1
              • wendy2702W Online
                wendy2702W Online
                wendy2702
                wrote on last edited by
                #23

                Das liest und hört sich sehr gut an.

                Danke!

                Bitte keine Fragen per PN, die gehören ins Forum!

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

                T 1 Reply Last reply
                0
                • wendy2702W wendy2702

                  Das liest und hört sich sehr gut an.

                  Danke!

                  T Do not disturb
                  T Do not disturb
                  ticaki
                  wrote on last edited by ticaki
                  #24

                  @wendy2702
                  Ich sehe gerade das ich Home24 und SayIt in einen Topf geworfen habe. Man kann nur beides aktivieren oder deaktivieren. Macht das was?

                  //Version 5
                  /* ************************************************************************* */
                  /*             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;
                  const HOMETWO = 16;
                  var pushdienst=0; 
                  //pushdienst+= TELEGRAM;          // Auskommentieren zum aktivieren
                  //pushdienst+= PUSHOVER;          // Auskommentieren zum aktivieren
                  //pushdienst+= EMAIL;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                  //pushdienst+= SAYIT;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                  //pushdienst+= HOMETWO;           // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                  
                  // Filtereinstellungen
                  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";
                  
                  /* Einstellungen zur Emailbenachrichtigung*/
                  var senderEmailID = ""; // mit Sender Emailadresse füllen. email Adapter muß installiert sein
                  var empfaengerEmailID = "";// mit Empfänger Emailadresse füllen.
                  
                  /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                  var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                  
                  /* Konfiguration Sprachausgabe über SayIt */
                  var idSayIt = "sayit.0.tts.text";
                  var lautstaerke = 60;
                  
                  /* Keine Anpassungen ab hier, außer du weißt was du tuest */
                  var idSprachausgabe = ((pushdienst & HOMETWO) !=0);   
                  var idSprachausgabeSayIt = ((pushdienst & SAYIT) !=0);  
                  
                  /* 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 & HOMETWO)!=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 & HOMETWO)!=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
                    });
                  }
                  
                  
                  
                  

                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                  Spenden

                  1 Reply Last reply
                  0
                  • wendy2702W Online
                    wendy2702W Online
                    wendy2702
                    wrote on last edited by
                    #25

                    Für mich kein Problem

                    Bitte keine Fragen per PN, die gehören ins Forum!

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

                    1 Reply Last reply
                    0
                    • wendy2702W Online
                      wendy2702W Online
                      wendy2702
                      wrote on last edited by
                      #26

                      Ich bekomme keine Ansage wenn die Warnungen aufgehoben werden.

                      Klappt das bei euch?

                      Bitte keine Fragen per PN, die gehören ins Forum!

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

                      T 1 Reply Last reply
                      0
                      • wendy2702W wendy2702

                        Ich bekomme keine Ansage wenn die Warnungen aufgehoben werden.

                        Klappt das bei euch?

                        T Do not disturb
                        T Do not disturb
                        ticaki
                        wrote on last edited by ticaki
                        #27

                        @wendy2702
                        Meinst du damit generell keine Ansage oder nur wenn alle Aufgehoben wurden? Ich erweitere das um Alexa und teste es/benutze es.

                        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                        Spenden

                        1 Reply Last reply
                        1
                        • wendy2702W Online
                          wendy2702W Online
                          wendy2702
                          wrote on last edited by
                          #28

                          Wenn ich das mal mit meine Telegramm Nachrichten vergleiche ist es etwas merkwürdig:

                          Gestern diese Warnungen bekommen und eine das Aufgehoben wurde:

                          3e76152e-9098-439f-b8d6-bbb5d1f578bd-image.png

                          Heute dann das:

                          9ea3768c-983f-4a26-a5b5-a821c02b864c-image.png

                          181fb152-8a98-456c-991e-1a0933fde5b2-image.png

                          ba00bcd9-70a7-4fd0-8159-41a1771f49cb-image.png

                          Die Meldung Aufgehoben ist immer gleich, ohne Ansage und ohne das dazwischen eine neue Meldung kam.

                          Bitte keine Fragen per PN, die gehören ins Forum!

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

                          T 1 Reply Last reply
                          0
                          • wendy2702W wendy2702

                            Wenn ich das mal mit meine Telegramm Nachrichten vergleiche ist es etwas merkwürdig:

                            Gestern diese Warnungen bekommen und eine das Aufgehoben wurde:

                            3e76152e-9098-439f-b8d6-bbb5d1f578bd-image.png

                            Heute dann das:

                            9ea3768c-983f-4a26-a5b5-a821c02b864c-image.png

                            181fb152-8a98-456c-991e-1a0933fde5b2-image.png

                            ba00bcd9-70a7-4fd0-8159-41a1771f49cb-image.png

                            Die Meldung Aufgehoben ist immer gleich, ohne Ansage und ohne das dazwischen eine neue Meldung kam.

                            T Do not disturb
                            T Do not disturb
                            ticaki
                            wrote on last edited by ticaki
                            #29

                            @wendy2702
                            Das ist sehr merkwürdig. Ich sehe im Script keinen Grund für dieses Verhalten. Ich aktivere das mal bei mir und beobachte es. Wobei mein Neustart morgens um 5 sich aktuell nicht mit dem Skript verträgt.

                            Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                            Spenden

                            1 Reply Last reply
                            0
                            • wendy2702W Online
                              wendy2702W Online
                              wendy2702
                              wrote on last edited by wendy2702
                              #30

                              Ich habe aber auch um 18:20Uhr eine Warnmeldung bekommen, allerdings keine Ansage und keine Telegram Nachricht.

                              0a1ac88d-8622-4171-9f76-14b99a34cb4f-image.png

                              Machen Vielleicht die Zeitstempel ein Problem?

                              Bitte keine Fragen per PN, die gehören ins Forum!

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

                              T 1 Reply Last reply
                              0
                              • wendy2702W wendy2702

                                Ich habe aber auch um 18:20Uhr eine Warnmeldung bekommen, allerdings keine Ansage und keine Telegram Nachricht.

                                0a1ac88d-8622-4171-9f76-14b99a34cb4f-image.png

                                Machen Vielleicht die Zeitstempel ein Problem?

                                T Do not disturb
                                T Do not disturb
                                ticaki
                                wrote on last edited by
                                #31

                                @wendy2702
                                Ne, ich hole die Information jetzt aus .object. Hab aber nichts an der Verwaltung dieser Daten geändert. Ich schaue später mal richtig rein.

                                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                Spenden

                                1 Reply Last reply
                                0
                                • wendy2702W Online
                                  wendy2702W Online
                                  wendy2702
                                  wrote on last edited by
                                  #32

                                  Gerade kommt eine Änderung der Warnungen: Sieht in den Objekten jetzt so aus:

                                  92a9e19c-b125-4e0b-8464-b45e7bd82cc5-image.png

                                  In Telegram so:

                                  15924645-2ed9-44ab-9ce7-f67568131d29-image.png

                                  Im Log das:

                                  javascript.0	2020-02-26 20:00:09.030	error	(25370) at Timer.processTimers (timers.js:223:10)
                                  javascript.0	2020-02-26 20:00:09.030	error	(25370) at listOnTimeout (timers.js:263:5)
                                  javascript.0	2020-02-26 20:00:09.030	error	(25370) at tryOnTimeout (timers.js:300:5)
                                  javascript.0	2020-02-26 20:00:09.030	error	(25370) at ontimeout (timers.js:438:13)
                                  javascript.0	2020-02-26 20:00:09.030	error	(25370) at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2076:34)
                                  javascript.0	2020-02-26 20:00:09.030	error	(25370) at Object.check (script.js.common.Ansagen.Ansage_Telegramm_DWD_5_Warnungen:199:25)
                                  javascript.0	2020-02-26 20:00:09.030	error	(25370) Error in callback: ReferenceError: EMAiL is not defined
                                  

                                  Vielleicht liegt es der nicht definierten Mail ?

                                  Bitte keine Fragen per PN, die gehören ins Forum!

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

                                  T 1 Reply Last reply
                                  0
                                  • wendy2702W wendy2702

                                    Gerade kommt eine Änderung der Warnungen: Sieht in den Objekten jetzt so aus:

                                    92a9e19c-b125-4e0b-8464-b45e7bd82cc5-image.png

                                    In Telegram so:

                                    15924645-2ed9-44ab-9ce7-f67568131d29-image.png

                                    Im Log das:

                                    javascript.0	2020-02-26 20:00:09.030	error	(25370) at Timer.processTimers (timers.js:223:10)
                                    javascript.0	2020-02-26 20:00:09.030	error	(25370) at listOnTimeout (timers.js:263:5)
                                    javascript.0	2020-02-26 20:00:09.030	error	(25370) at tryOnTimeout (timers.js:300:5)
                                    javascript.0	2020-02-26 20:00:09.030	error	(25370) at ontimeout (timers.js:438:13)
                                    javascript.0	2020-02-26 20:00:09.030	error	(25370) at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2076:34)
                                    javascript.0	2020-02-26 20:00:09.030	error	(25370) at Object.check (script.js.common.Ansagen.Ansage_Telegramm_DWD_5_Warnungen:199:25)
                                    javascript.0	2020-02-26 20:00:09.030	error	(25370) Error in callback: ReferenceError: EMAiL is not defined
                                    

                                    Vielleicht liegt es der nicht definierten Mail ?

                                    T Do not disturb
                                    T Do not disturb
                                    ticaki
                                    wrote on last edited by ticaki
                                    #33

                                    @wendy2702
                                    Rechtschreibfehler. Korrigiert!

                                    //Version 6
                                    /* ************************************************************************* */
                                    /*             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;
                                    const HOMETWO = 16;
                                    var pushdienst=0; 
                                    //pushdienst+= TELEGRAM;          // Auskommentieren zum aktivieren
                                    //pushdienst+= PUSHOVER;          // Auskommentieren zum aktivieren
                                    //pushdienst+= EMAIL;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                                    //pushdienst+= SAYIT;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                                    //pushdienst+= HOMETWO;           // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                                     
                                    // Filtereinstellungen
                                    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";
                                     
                                    /* Einstellungen zur Emailbenachrichtigung*/
                                    var senderEmailID = ""; // mit Sender Emailadresse füllen. email Adapter muß installiert sein
                                    var empfaengerEmailID = "";// mit Empfänger Emailadresse füllen.
                                     
                                    /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                                    var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                                     
                                    /* Konfiguration Sprachausgabe über SayIt */
                                    var idSayIt = "sayit.0.tts.text";
                                    var lautstaerke = 60;
                                     
                                    /* Keine Anpassungen ab hier, außer du weißt was du tuest */
                                    var idSprachausgabe = ((pushdienst & HOMETWO) !=0);   
                                    var idSprachausgabeSayIt = ((pushdienst & SAYIT) !=0);  
                                     
                                    /* 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 & HOMETWO)!=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 & HOMETWO)!=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
                                      });
                                    }
                                     
                                    

                                    Ich glaube nicht, dass es daran liegt. Kann sein :)

                                    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                    Spenden

                                    1 Reply Last reply
                                    0
                                    • wendy2702W Online
                                      wendy2702W Online
                                      wendy2702
                                      wrote on last edited by
                                      #34

                                      Danke.

                                      Werde Testen und mich melden.

                                      Bitte keine Fragen per PN, die gehören ins Forum!

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

                                      T 2 Replies Last reply
                                      0
                                      • wendy2702W wendy2702

                                        Danke.

                                        Werde Testen und mich melden.

                                        T Do not disturb
                                        T Do not disturb
                                        ticaki
                                        wrote on last edited by
                                        #35

                                        @wendy2702
                                        Ich hab bei mir noch eine neustart sichere Version laufen, die stelle ich, wenn sie bis morgen abend sauber läuft, online.

                                        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                        Spenden

                                        1 Reply Last reply
                                        0
                                        • wendy2702W wendy2702

                                          Danke.

                                          Werde Testen und mich melden.

                                          T Do not disturb
                                          T Do not disturb
                                          ticaki
                                          wrote on last edited by
                                          #36

                                          @wendy2702
                                          Hatte heute morgen noch einen Fehler, aber seit dem läufts.

                                          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                          Spenden

                                          T 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          650

                                          Online

                                          32.7k

                                          Users

                                          82.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe