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
    16
    1
    1.7k

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.1k

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 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 Offline
    T Offline
    ticaki
    wrote on last edited by
    #16

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

    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

    Spenden

    1 Reply Last reply
    0
    • 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 Offline
        T Offline
        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 Offline
                T Offline
                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 Offline
                    T Offline
                    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 Offline
                          T Offline
                          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 Offline
                              T Offline
                              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 Offline
                                  T Offline
                                  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 Offline
                                      T Offline
                                      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 Offline
                                          T Offline
                                          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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          576

                                          Online

                                          32.6k

                                          Users

                                          82.1k

                                          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