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.4k

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 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
                                        • wendy2702W wendy2702

                                          Danke.

                                          Werde Testen und mich melden.

                                          T Nicht stören
                                          T Nicht stören
                                          ticaki
                                          schrieb am zuletzt editiert von
                                          #36

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

                                          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                                          Spenden

                                          T 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

                                          473

                                          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