Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
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

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.3k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.6k

Fehler im script nach Update Adapter

Geplant Angeheftet Gesperrt Verschoben JavaScript
62 Beiträge 6 Kommentatoren 2.7k Aufrufe 6 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • 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 Nicht stören
    T Nicht stören
    ticaki
    schrieb am zuletzt editiert von
    #16

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

    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

    Spenden

    1 Antwort Letzte Antwort
    0
    • wendy2702W Offline
      wendy2702W Offline
      wendy2702
      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
      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 Nicht stören
        T Nicht stören
        ticaki
        schrieb am zuletzt editiert von
        #18

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

        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

        Spenden

        1 Antwort Letzte Antwort
        1
        • wendy2702W Offline
          wendy2702W Offline
          wendy2702
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          0
          • wendy2702W wendy2702

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

            crunchipC Abwesend
            crunchipC Abwesend
            crunchip
            Forum Testing Most Active
            schrieb am zuletzt editiert von
            #20

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

            umgestiegen von Proxmox auf Unraid

            1 Antwort Letzte Antwort
            0
            • wendy2702W Offline
              wendy2702W Offline
              wendy2702
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              0
              • T Nicht stören
                T Nicht stören
                ticaki
                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                1
                • wendy2702W Offline
                  wendy2702W Offline
                  wendy2702
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  0
                  • wendy2702W wendy2702

                    Das liest und hört sich sehr gut an.

                    Danke!

                    T Nicht stören
                    T Nicht stören
                    ticaki
                    schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                    0
                    • wendy2702W Offline
                      wendy2702W Offline
                      wendy2702
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      0
                      • wendy2702W Offline
                        wendy2702W Offline
                        wendy2702
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        0
                        • wendy2702W wendy2702

                          Ich bekomme keine Ansage wenn die Warnungen aufgehoben werden.

                          Klappt das bei euch?

                          T Nicht stören
                          T Nicht stören
                          ticaki
                          schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                          1
                          • wendy2702W Offline
                            wendy2702W Offline
                            wendy2702
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            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 Nicht stören
                              T Nicht stören
                              ticaki
                              schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                              0
                              • wendy2702W Offline
                                wendy2702W Offline
                                wendy2702
                                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                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 Nicht stören
                                  T Nicht stören
                                  ticaki
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  0
                                  • wendy2702W Offline
                                    wendy2702W Offline
                                    wendy2702
                                    schrieb am zuletzt editiert von
                                    #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 Antwort Letzte Antwort
                                    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 Nicht stören
                                      T Nicht stören
                                      ticaki
                                      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                      0
                                      • wendy2702W Offline
                                        wendy2702W Offline
                                        wendy2702
                                        schrieb am zuletzt editiert von
                                        #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 Antworten Letzte Antwort
                                        0
                                        • wendy2702W wendy2702

                                          Danke.

                                          Werde Testen und mich melden.

                                          T Nicht stören
                                          T Nicht stören
                                          ticaki
                                          schrieb am zuletzt editiert von
                                          #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 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          397

                                          Online

                                          32.5k

                                          Benutzer

                                          81.6k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe