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

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

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

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 Online
    wendy2702W Online
    wendy2702
    schrieb am zuletzt editiert von
    #1

    Hi,

    mir ist heute aufgefallen das ich seit irgendeinem Javascript Adapter diesen Log Eintrag von einem Script bekomme:

    error	(24015) script.js.common.Ansagen.Ansage_Telegramm_DWD_5_Warnungen: Invalid callback for setTimeout! - undefined
    
    

    Da ich kein Javascript experte bin fehlt mir die Ahnung was im Script geändert werden muss/sollte. Kann mir wer helfen?

    Hier das Script:

    /* ************************************************************************* */
    /*             Script zum Übertragen der DWD-Wetterwarnungen über            */
    /*             Telegram, Pushover, Home24-Mediaplayer oder SayIt             */
    /*     mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals)     */
    /*                    Stand: 130022017    PrinzEisenherz1                    */
    /*                                                                           */
    /*     - Fehlerbehebung z.B. 5 gültig bis 5                                  */
    /*                                                                           */
    /*                                                                           */
    /*                                                                           */
    /*                                                                           */
    /*                          Variante für 5-warnings                          */
    /*                                                                           */
    /* ************************************************************************* */
    
       var request = require('request');
    
      /* Nachrichten-Dienst festlegen */
    /* aus=0 ; alle=1 ; Pushover=2 ; Telegram=3 */
       var pushdienst = 3;         // Auswahl Nachrichtendienst
    
    /* 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.description";
       var idDescription1 = "dwd.0.warning1.description";
       var idDescription2 = "dwd.0.warning2.description";
       var idDescription3 = "dwd.0.warning3.description";
       var idDescription4 = "dwd.0.warning4.description";
       
    /* Arrays festlegen */
       var newDescriptions = [5];
       var oldDescriptions = [5];
       var newHeadlines = [5];
       var oldHeadlines = [5];
       var newBegins = [5];
       var oldBegins = [5];
       var newEnds = [5];
       var oldEnds = [5];
       var timer = null;
    /* aktivieren bzw erstmaliges Befüllen der arrays */
       newDescriptions[0] = '';
       newDescriptions[1] = '';
       newDescriptions[2] = '';
       newDescriptions[3] = '';
       newDescriptions[4] = '';
       oldDescriptions[0] = '';
       oldDescriptions[1] = '';
       oldDescriptions[2] = '';
       oldDescriptions[3] = '';
       oldDescriptions[4] = '';
    
       newHeadlines[0] = '';
       newHeadlines[1] = '';
       newHeadlines[2] = '';
       newHeadlines[3] = '';
       newHeadlines[4] = '';
       oldHeadlines[0] = '';
       oldHeadlines[1] = '';
       oldHeadlines[2] = '';
       oldHeadlines[3] = '';
       oldHeadlines[4] = '';
    
       newBegins[0] = '';
       newBegins[1] = '';
       newBegins[2] = '';
       newBegins[3] = '';
       newBegins[4] = '';
       oldBegins[0] = '';
       oldBegins[1] = '';
       oldBegins[2] = '';
       oldBegins[3] = '';
       oldBegins[4] = '';
    
       newEnds[0] = '';
       newEnds[1] = '';
       newEnds[2] = '';
       newEnds[3] = '';
       newEnds[4] = '';
       oldEnds[0] = '';
       oldEnds[1] = '';
       oldEnds[2] = '';
       oldEnds[3] = '';
       oldEnds[4] = '';
    
    function check() {
    /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
       if(newDescriptions[0] === "") {
      MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
    /* Bereich für Sprachausgabe über Home24-Mediaplayer */
         if(idSprachausgabe === true){
            var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
            request(Url);
         }
         
    /* Bereich für Sprachausgabe SayIt im Zeitraum */	  
    var ENDE= '22:30';                     // Ende immer 22:30h
    var START;
    
    
    schedule("0 6 * * *", function (){                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist          
       var date = new Date();
       var n = date.getDay();
       var weekend = 0;
       weekend = (n === 0 || n == 6) ? 1 : 0;
      
       if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
          START = '9:00';  
          }    
          else{
             START = '6:45';
             }
         
    });
    
    
    /* Bereich für Sprachausgabe über SayIt */
         if(idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
            setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
         }
         if ((pushdienst === 3) || (pushdienst === 1) ) {
            setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
         }
         if ((pushdienst === 2) || (pushdienst === 1) ) {
            sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
         }
         
    /* alle Sicherungen Wetterwarnung löschen */
           oldHeadlines = newHeadlines.slice();
           oldDescriptions = newDescriptions.slice();
           oldBegins = newBegins.slice();
           oldEnds = newEnds.slice();
           return;
       }
    
    /* Variablen für Meldungen Text */
       var MeldungOld = '';
       var MeldungNew = '';
    /* Variablen für Meldungen Sprache */
       var MeldungSpracheDWD = '';
       var MeldungNewSprache = '';
       var MeldungOldSprache = '';
    
       var headline;
       var description;
       var begin;
       var end;
       var i;
       var warn;
    
    /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
       for(i = 0; i < 5; i++) {
         warn = 'dwd.0.warning';
         if(i) warn = warn + i;
         headline = oldHeadlines[i];
         description = oldDescriptions[i];
         begin = oldBegins[i];
         end = oldEnds[i];
            if(newDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
               MeldungOld = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben';
               MeldungOldSprache = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben' + '  .  ';
                  if ((pushdienst === 3) || (pushdienst === 1) ) {
                     setTimeout((sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                  }
                  if ((pushdienst === 2) || (pushdienst === 1) ) {
                     sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                  }
    /* Verknüpfen aller aufgehobenen Wetterwarnungen */
            if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
               MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
            }
         }
      }
    
    /* Bereich für 'Neue Amtliche Wetterwarnung' */
       for(i = 0; i < 5; i++) {
         warn = 'dwd.0.warning';
         if(i) warn = warn + i;
         headline = newHeadlines[i];
         description = newDescriptions[i];
         begin = newBegins[i];
         end = newEnds[i];
            if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
               MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
    /* Entfernen °C für Sprachausgabe */
               var replaceDescription0 = entferneDatenpunkt(description);
               MeldungNewSprache = headline + " gültig vom " + begin + " Uhr, bis " + end + " Uhr. " + replaceDescription0 + '  .  ';
                  if ((pushdienst === 3) || (pushdienst === 1) ) {
                     setTimeout((sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                  }
                  if ((pushdienst === 2) || (pushdienst === 1) ) {
                     sendTo("pushover.0", MeldungNew);
                  }
    /* Verknüpfen aller neuen Warnmeldungen */
            if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
               MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
            }
         }
      }
    /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
         MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
    
    /* Bereich für Sprachausgabe über Home24-Mediaplayer */
       if((idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
          var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
           log('Url2 :' + Url2);
           request(Url2);
    }
    /* Bereich für Sprachausgabe über SayIt */
       if((idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
           setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
    }
    
    /* Neue Werte sichern */
       oldHeadlines = newHeadlines.slice();
       oldDescriptions = newDescriptions.slice();
       oldBegins = newBegins.slice();
       oldEnds = newEnds.slice();
    }
    
    /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
    function entferneDatenpunkt(beschreibung) {
       var rueckgabe;
       rueckgabe = beschreibung;
       try {
           rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
           rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
           }
       catch(e) {}
       return rueckgabe;
    }
    on(idDescription0, function(dp) {
       newDescriptions[0] = dp.state.val;
       var warn = 'dwd.0.warning';
         setTimeout(function() {
            newHeadlines[0] = getState(warn + '.headline').val;
            newBegins[0] = getState(warn + '.begin').val;
            newEnds[0] = getState(warn + '.end').val;
           }, 3000);
       if(timer) clearTimeout(timer);
       timer = setTimeout(check, 7000);
    });
    
    on(idDescription1, function(dp) {
       newDescriptions[1] = dp.state.val;
       var warn = 'dwd.0.warning1';
         setTimeout(function() {
            newHeadlines[1] = getState(warn + '.headline').val;
            newBegins[1] = getState(warn + '.begin').val;
            newEnds[1] = getState(warn + '.end').val;
         }, 3000);
       if(timer) clearTimeout(timer);
       timer = setTimeout(check, 7000);
    });
    
    on(idDescription2, function(dp) {
       newDescriptions[2] = dp.state.val;
       var warn = 'dwd.0.warning2';
         setTimeout(function() {
            newHeadlines[2] = getState(warn + '.headline').val;
            newBegins[2] = getState(warn + '.begin').val;
            newEnds[2] = getState(warn + '.end').val;
         }, 3000);
       if(timer) clearTimeout(timer);
       timer = setTimeout(check, 7000);
    });
    on(idDescription3, function(dp) {
       newDescriptions[3] = dp.state.val;
       var warn = 'dwd.0.warning3';
         setTimeout(function() {
            newHeadlines[3] = getState(warn + '.headline').val;
            newBegins[3] = getState(warn + '.begin').val;
            newEnds[3] = getState(warn + '.end').val;
         }, 3000);
       if(timer) clearTimeout(timer);
       timer = setTimeout(check, 7000);
    });
    on(idDescription4, function(dp) {
       newDescriptions[4] = dp.state.val;
       var warn = 'dwd.0.warning4';
         setTimeout(function() {
            newHeadlines[4] = getState(warn + '.headline').val;
            newBegins[4] = getState(warn + '.begin').val;
            newEnds[4] = getState(warn + '.end').val;
         }, 3000);
       if(timer) clearTimeout(timer);
       timer = setTimeout(check, 7000);
    });
    
    

    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,

      mir ist heute aufgefallen das ich seit irgendeinem Javascript Adapter diesen Log Eintrag von einem Script bekomme:

      error	(24015) script.js.common.Ansagen.Ansage_Telegramm_DWD_5_Warnungen: Invalid callback for setTimeout! - undefined
      
      

      Da ich kein Javascript experte bin fehlt mir die Ahnung was im Script geändert werden muss/sollte. Kann mir wer helfen?

      Hier das Script:

      /* ************************************************************************* */
      /*             Script zum Übertragen der DWD-Wetterwarnungen über            */
      /*             Telegram, Pushover, Home24-Mediaplayer oder SayIt             */
      /*     mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals)     */
      /*                    Stand: 130022017    PrinzEisenherz1                    */
      /*                                                                           */
      /*     - Fehlerbehebung z.B. 5 gültig bis 5                                  */
      /*                                                                           */
      /*                                                                           */
      /*                                                                           */
      /*                                                                           */
      /*                          Variante für 5-warnings                          */
      /*                                                                           */
      /* ************************************************************************* */
      
         var request = require('request');
      
        /* Nachrichten-Dienst festlegen */
      /* aus=0 ; alle=1 ; Pushover=2 ; Telegram=3 */
         var pushdienst = 3;         // Auswahl Nachrichtendienst
      
      /* 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.description";
         var idDescription1 = "dwd.0.warning1.description";
         var idDescription2 = "dwd.0.warning2.description";
         var idDescription3 = "dwd.0.warning3.description";
         var idDescription4 = "dwd.0.warning4.description";
         
      /* Arrays festlegen */
         var newDescriptions = [5];
         var oldDescriptions = [5];
         var newHeadlines = [5];
         var oldHeadlines = [5];
         var newBegins = [5];
         var oldBegins = [5];
         var newEnds = [5];
         var oldEnds = [5];
         var timer = null;
      /* aktivieren bzw erstmaliges Befüllen der arrays */
         newDescriptions[0] = '';
         newDescriptions[1] = '';
         newDescriptions[2] = '';
         newDescriptions[3] = '';
         newDescriptions[4] = '';
         oldDescriptions[0] = '';
         oldDescriptions[1] = '';
         oldDescriptions[2] = '';
         oldDescriptions[3] = '';
         oldDescriptions[4] = '';
      
         newHeadlines[0] = '';
         newHeadlines[1] = '';
         newHeadlines[2] = '';
         newHeadlines[3] = '';
         newHeadlines[4] = '';
         oldHeadlines[0] = '';
         oldHeadlines[1] = '';
         oldHeadlines[2] = '';
         oldHeadlines[3] = '';
         oldHeadlines[4] = '';
      
         newBegins[0] = '';
         newBegins[1] = '';
         newBegins[2] = '';
         newBegins[3] = '';
         newBegins[4] = '';
         oldBegins[0] = '';
         oldBegins[1] = '';
         oldBegins[2] = '';
         oldBegins[3] = '';
         oldBegins[4] = '';
      
         newEnds[0] = '';
         newEnds[1] = '';
         newEnds[2] = '';
         newEnds[3] = '';
         newEnds[4] = '';
         oldEnds[0] = '';
         oldEnds[1] = '';
         oldEnds[2] = '';
         oldEnds[3] = '';
         oldEnds[4] = '';
      
      function check() {
      /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
         if(newDescriptions[0] === "") {
        MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
      /* Bereich für Sprachausgabe über Home24-Mediaplayer */
           if(idSprachausgabe === true){
              var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
              request(Url);
           }
           
      /* Bereich für Sprachausgabe SayIt im Zeitraum */	  
      var ENDE= '22:30';                     // Ende immer 22:30h
      var START;
      
      
      schedule("0 6 * * *", function (){                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist          
         var date = new Date();
         var n = date.getDay();
         var weekend = 0;
         weekend = (n === 0 || n == 6) ? 1 : 0;
        
         if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
            START = '9:00';  
            }    
            else{
               START = '6:45';
               }
           
      });
      
      
      /* Bereich für Sprachausgabe über SayIt */
           if(idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
              setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
           }
           if ((pushdienst === 3) || (pushdienst === 1) ) {
              setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
           }
           if ((pushdienst === 2) || (pushdienst === 1) ) {
              sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
           }
           
      /* alle Sicherungen Wetterwarnung löschen */
             oldHeadlines = newHeadlines.slice();
             oldDescriptions = newDescriptions.slice();
             oldBegins = newBegins.slice();
             oldEnds = newEnds.slice();
             return;
         }
      
      /* Variablen für Meldungen Text */
         var MeldungOld = '';
         var MeldungNew = '';
      /* Variablen für Meldungen Sprache */
         var MeldungSpracheDWD = '';
         var MeldungNewSprache = '';
         var MeldungOldSprache = '';
      
         var headline;
         var description;
         var begin;
         var end;
         var i;
         var warn;
      
      /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
         for(i = 0; i < 5; i++) {
           warn = 'dwd.0.warning';
           if(i) warn = warn + i;
           headline = oldHeadlines[i];
           description = oldDescriptions[i];
           begin = oldBegins[i];
           end = oldEnds[i];
              if(newDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                 MeldungOld = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben';
                 MeldungOldSprache = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben' + '  .  ';
                    if ((pushdienst === 3) || (pushdienst === 1) ) {
                       setTimeout((sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                    }
                    if ((pushdienst === 2) || (pushdienst === 1) ) {
                       sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                    }
      /* Verknüpfen aller aufgehobenen Wetterwarnungen */
              if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
                 MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
              }
           }
        }
      
      /* Bereich für 'Neue Amtliche Wetterwarnung' */
         for(i = 0; i < 5; i++) {
           warn = 'dwd.0.warning';
           if(i) warn = warn + i;
           headline = newHeadlines[i];
           description = newDescriptions[i];
           begin = newBegins[i];
           end = newEnds[i];
              if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                 MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
      /* Entfernen °C für Sprachausgabe */
                 var replaceDescription0 = entferneDatenpunkt(description);
                 MeldungNewSprache = headline + " gültig vom " + begin + " Uhr, bis " + end + " Uhr. " + replaceDescription0 + '  .  ';
                    if ((pushdienst === 3) || (pushdienst === 1) ) {
                       setTimeout((sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                    }
                    if ((pushdienst === 2) || (pushdienst === 1) ) {
                       sendTo("pushover.0", MeldungNew);
                    }
      /* Verknüpfen aller neuen Warnmeldungen */
              if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
                 MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
              }
           }
        }
      /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
           MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
      
      /* Bereich für Sprachausgabe über Home24-Mediaplayer */
         if((idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
            var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
             log('Url2 :' + Url2);
             request(Url2);
      }
      /* Bereich für Sprachausgabe über SayIt */
         if((idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
             setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
      }
      
      /* Neue Werte sichern */
         oldHeadlines = newHeadlines.slice();
         oldDescriptions = newDescriptions.slice();
         oldBegins = newBegins.slice();
         oldEnds = newEnds.slice();
      }
      
      /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
      function entferneDatenpunkt(beschreibung) {
         var rueckgabe;
         rueckgabe = beschreibung;
         try {
             rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
             rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
             }
         catch(e) {}
         return rueckgabe;
      }
      on(idDescription0, function(dp) {
         newDescriptions[0] = dp.state.val;
         var warn = 'dwd.0.warning';
           setTimeout(function() {
              newHeadlines[0] = getState(warn + '.headline').val;
              newBegins[0] = getState(warn + '.begin').val;
              newEnds[0] = getState(warn + '.end').val;
             }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      
      on(idDescription1, function(dp) {
         newDescriptions[1] = dp.state.val;
         var warn = 'dwd.0.warning1';
           setTimeout(function() {
              newHeadlines[1] = getState(warn + '.headline').val;
              newBegins[1] = getState(warn + '.begin').val;
              newEnds[1] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      
      on(idDescription2, function(dp) {
         newDescriptions[2] = dp.state.val;
         var warn = 'dwd.0.warning2';
           setTimeout(function() {
              newHeadlines[2] = getState(warn + '.headline').val;
              newBegins[2] = getState(warn + '.begin').val;
              newEnds[2] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      on(idDescription3, function(dp) {
         newDescriptions[3] = dp.state.val;
         var warn = 'dwd.0.warning3';
           setTimeout(function() {
              newHeadlines[3] = getState(warn + '.headline').val;
              newBegins[3] = getState(warn + '.begin').val;
              newEnds[3] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      on(idDescription4, function(dp) {
         newDescriptions[4] = dp.state.val;
         var warn = 'dwd.0.warning4';
           setTimeout(function() {
              newHeadlines[4] = getState(warn + '.headline').val;
              newBegins[4] = getState(warn + '.begin').val;
              newEnds[4] = getState(warn + '.end').val;
           }, 3000);
         if(timer) clearTimeout(timer);
         timer = setTimeout(check, 7000);
      });
      
      

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

      @wendy2702 sagte in Fehler im script nach Update Adapter:

      setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);

      ändere:

      setTimeout((sendTo
      

      in

      setTimeout(()=>(sendTo
      

      überall.

      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

      Spenden

      wendy2702W 1 Antwort Letzte Antwort
      0
      • wendy2702W Online
        wendy2702W Online
        wendy2702
        schrieb am zuletzt editiert von
        #3

        Danke!

        Habe es geändert und werde beobachten.

        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
        • LatziL Online
          LatziL Online
          Latzi
          schrieb am zuletzt editiert von
          #4

          Ich bekomme seit heute in unregelmäßigen Abständen folgende Fehlermeldung:

          2020-02-21 20:16:46.642  - error: javascript.0 (1730) script.js.common.Skript_UWZ: TypeError: Cannot read property 'request' of undefined
          2020-02-21 20:16:46.642  - error: javascript.0 (1730)     at Request._callback (script.js.common.Skript_UWZ:223:57)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at self.callback (/opt/iobroker/node_modules/request/request.js:185:22)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at Request.emit (events.js:198:13)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at Timeout._onTimeout (/opt/iobroker/node_modules/request/request.js:852:16)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at ontimeout (timers.js:436:11)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at tryOnTimeout (timers.js:300:5)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at listOnTimeout (timers.js:263:5)
          2020-02-21 20:16:46.643  - error: javascript.0 (1730)     at Timer.processTimers (timers.js:223:10)
          

          Der relevante Teil des Scripts dürfte folgender sein:

          var request = require('request');
          schedule ("* * * * *", function(){
              for (var i=0; i<warncellid.length; i++) {
                      request({  
                          uri: url.replace("XXXAREAXXX",warncellid[i]),
                          method: "GET",
                          timeout: 10000,
                          followRedirect: true,
                          maxRedirects: 10
                      }, function(error, response, body) {
                          // dwmlog("UWZ Error" + error,2);
                          // dwmlog("UWZ Response: " + JSON.stringify(response),4);
                          dwmlog("AREA: "+getAreaFromURI(response.request.uri.href),4);
                          dwmlog("UWZ Body: " + body,4);
                          if (response.statusCode == 200) {
                              processData(getAreaFromURI(response.request.uri.href),body);
                          }
                      });    
              }
          });
          

          Hat jemand eine Idee woran das liegen kann, da das Script schon seit längerer Zeit problemlos lief und ich wissentlich nichts geändert habe.

          1 Antwort Letzte Antwort
          0
          • T Nicht stören
            T Nicht stören
            ticaki
            schrieb am zuletzt editiert von
            #5

            In der Fehlermeldung steht das

            response
            

            undefiniert ist. Mit einer Abfrage auf undefined kannst du die Funktion verlassen.

            11 if ( response == undefined ) return;
            

            Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

            Spenden

            LatziL 1 Antwort Letzte Antwort
            1
            • T ticaki

              In der Fehlermeldung steht das

              response
              

              undefiniert ist. Mit einer Abfrage auf undefined kannst du die Funktion verlassen.

              11 if ( response == undefined ) return;
              
              LatziL Online
              LatziL Online
              Latzi
              schrieb am zuletzt editiert von
              #6

              @ticaki sagte in Fehler im script nach Update Adapter:

              Mit einer Abfrage auf undefined kannst du die Funktion verlassen.

              Das schaut bislang sehr gut aus, vielen Dank :clap:

              1 Antwort Letzte Antwort
              0
              • T ticaki

                @wendy2702 sagte in Fehler im script nach Update Adapter:

                setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);

                ändere:

                setTimeout((sendTo
                

                in

                setTimeout(()=>(sendTo
                

                überall.

                wendy2702W Online
                wendy2702W Online
                wendy2702
                schrieb am zuletzt editiert von
                #7

                @ticaki sagte in Fehler im script nach Update Adapter:

                @wendy2702 sagte in Fehler im script nach Update Adapter:

                setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);

                ändere:

                setTimeout((sendTo
                

                in

                setTimeout(()=>(sendTo
                

                überall.

                Hi,

                Ich habe zwar keine Fehler mehr im Log aber die Telegramm Nachricht wenn Meldungen aufgehoben wurden sieht jetzt immer so aus:

                „Die Wetterwarnung ´undefined gültig bis undefined´des DWD wurde aufgehoben.“

                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

                  @ticaki sagte in Fehler im script nach Update Adapter:

                  @wendy2702 sagte in Fehler im script nach Update Adapter:

                  setTimeout((sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);

                  ändere:

                  setTimeout((sendTo
                  

                  in

                  setTimeout(()=>(sendTo
                  

                  überall.

                  Hi,

                  Ich habe zwar keine Fehler mehr im Log aber die Telegramm Nachricht wenn Meldungen aufgehoben wurden sieht jetzt immer so aus:

                  „Die Wetterwarnung ´undefined gültig bis undefined´des DWD wurde aufgehoben.“

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

                  @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 :)

                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                  Spenden

                  wendy2702W 1 Antwort Letzte Antwort
                  0
                  • T Nicht stören
                    T Nicht stören
                    ticaki
                    schrieb am zuletzt editiert von ticaki
                    #9

                    Habs etwas getested, aber leider kein Sayit oder pushover zur Verfügung.

                    zusätzlich hab ich noch einen Filter für Höhe und Level eingebaut.

                    /* ************************************************************************* */
                    /*             Script zum Übertragen der DWD-Wetterwarnungen über            */
                    /*             Telegram, Pushover, Home24-Mediaplayer oder SayIt             */
                    /*     mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals)     */
                    /*                    Stand: 130022017    PrinzEisenherz1                    */
                    /*                                                                           */
                    /*     - Fehlerbehebung z.B. 5 gültig bis 5                                  */
                    /*                                                                           */
                    /*                                                                           */
                    /*                                                                           */
                    /*                                                                           */
                    /*                          Variante für 5-warnings                          */
                    /*                                                                           */
                    /* ************************************************************************* */
                    var request = require('request');
                    
                    /* Nachrichten-Dienst festlegen */
                    /* aus=0 ; alle=1 ; Pushover=2 ; Telegram=3 */
                    var pushdienst = 3;         // Auswahl Nachrichtendienst
                    
                    const minlevel = 0 // Warnungen unterhalb dieses Levels nicht senden;
                    const maxhoehe = 1000 // Warnung mit für eine Höhe oberhalb dieses Wertes nicht senden
                    /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                    var idSprachausgabe = false;   // Wenn zusätzlich eine Sprachausgabe erfolgen soll dann auf true
                    var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                    
                    /* Konfiguration Sprachausgabe über SayIt */
                    var idSprachausgabeSayIt = true;   // Wenn zusätzlich eine Sprachausgabe über SayIt erfolgen soll dann auf true
                    var idSayIt = "sayit.0.tts.text";
                    var lautstaerke = 60;
                    
                    /* Trigger für Wetterwarnungen */
                    var idDescription0 = "dwd.0.warning.object";
                    var idDescription1 = "dwd.0.warning1.object";
                    var idDescription2 = "dwd.0.warning2.object";
                    var idDescription3 = "dwd.0.warning3.object";
                    var idDescription4 = "dwd.0.warning4.object";
                    
                    /* Arrays festlegen */
                    var newDescriptions = [5];
                    var oldDescriptions = [5];
                    var newHeadlines = [5];
                    var oldHeadlines = [5];
                    var newBegins = [5];
                    var oldBegins = [5];
                    var newEnds = [5];
                    var oldEnds = [5];
                    var timer = null;
                    /* aktivieren bzw erstmaliges Befüllen der arrays */
                    newDescriptions[0] = '';
                    newDescriptions[1] = '';
                    newDescriptions[2] = '';
                    newDescriptions[3] = '';
                    newDescriptions[4] = '';
                    oldDescriptions[0] = '';
                    oldDescriptions[1] = '';
                    oldDescriptions[2] = '';
                    oldDescriptions[3] = '';
                    oldDescriptions[4] = '';
                    
                    newHeadlines[0] = '';
                    newHeadlines[1] = '';
                    newHeadlines[2] = '';
                    newHeadlines[3] = '';
                    newHeadlines[4] = '';
                    oldHeadlines[0] = '';
                    oldHeadlines[1] = '';
                    oldHeadlines[2] = '';
                    oldHeadlines[3] = '';
                    oldHeadlines[4] = '';
                    
                    newBegins[0] = '';
                    newBegins[1] = '';
                    newBegins[2] = '';
                    newBegins[3] = '';
                    newBegins[4] = '';
                    oldBegins[0] = '';
                    oldBegins[1] = '';
                    oldBegins[2] = '';
                    oldBegins[3] = '';
                    oldBegins[4] = '';
                    
                    newEnds[0] = '';
                    newEnds[1] = '';
                    newEnds[2] = '';
                    newEnds[3] = '';
                    newEnds[4] = '';
                    oldEnds[0] = '';
                    oldEnds[1] = '';
                    oldEnds[2] = '';
                    oldEnds[3] = '';
                    oldEnds[4] = '';
                    
                    function check() {
                      /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
                      if(newDescriptions[0] === "") {
                        MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
                        /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                        if(idSprachausgabe === true){
                          var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                          request(Url);
                        }
                        
                        /* Bereich für Sprachausgabe SayIt im Zeitraum */	  
                        var ENDE= '22:30';                     // Ende immer 22:30h
                        var START;
                        
                        
                        schedule("0 6 * * *", function (){                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist          
                          var date = new Date();
                          var n = date.getDay();
                          var weekend = 0;
                          weekend = (n === 0 || n == 6) ? 1 : 0;
                          
                          if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
                            START = '9:00';  
                          }    
                          else{
                            START = '6:45';
                          }
                          
                        });
                        
                        
                        /* Bereich für Sprachausgabe über SayIt */
                        if(idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
                          setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                        }
                        if ((pushdienst === 3) || (pushdienst === 1) ) {
                          setTimeout(()=>(sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
                        }
                        if ((pushdienst === 2) || (pushdienst === 1) ) {
                          sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                        }
                        
                        /* alle Sicherungen Wetterwarnung löschen */
                        oldHeadlines = newHeadlines.slice();
                        oldDescriptions = newDescriptions.slice();
                        oldBegins = newBegins.slice();
                        oldEnds = newEnds.slice();
                        return;
                      }
                      
                      /* Variablen für Meldungen Text */
                      var MeldungOld = '';
                      var MeldungNew = '';
                      /* Variablen für Meldungen Sprache */
                      var MeldungSpracheDWD = '';
                      var MeldungNewSprache = '';
                      var MeldungOldSprache = '';
                      
                      var headline;
                      var description;
                      var begin;
                      var end;
                      var i;
                      var warn;
                      
                      /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
                      for(i = 0; i < 5; i++) {
                        warn = 'dwd.0.warning';
                        if(i) warn = warn + i;
                        headline = oldHeadlines[i];
                        description = oldDescriptions[i];
                        begin = oldBegins[i];
                        end = oldEnds[i];
                        if(newDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                          MeldungOld = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben';
                          MeldungOldSprache = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben' + '  .  ';
                          if ((pushdienst === 3) || (pushdienst === 1) ) {
                            setTimeout(()=>(sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                          }
                          if ((pushdienst === 2) || (pushdienst === 1) ) {
                            sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                          }
                          /* Verknüpfen aller aufgehobenen Wetterwarnungen */
                          if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
                            MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
                          }
                        }
                      }
                      
                      /* Bereich für 'Neue Amtliche Wetterwarnung' */
                      for(i = 0; i < 5; i++) {
                        warn = 'dwd.0.warning';
                        if(i) warn = warn + i;
                        headline = newHeadlines[i];
                        description = newDescriptions[i];
                        begin = newBegins[i];
                        end = newEnds[i];
                        if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                          MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
                          /* Entfernen °C für Sprachausgabe */
                          var replaceDescription0 = entferneDatenpunkt(description);
                          MeldungNewSprache = headline + " gültig vom " + begin + " Uhr, bis " + end + " Uhr. " + replaceDescription0 + '  .  ';
                          if ((pushdienst === 3) || (pushdienst === 1) ) {
                            setTimeout(()=>(sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                          }
                          if ((pushdienst === 2) || (pushdienst === 1) ) {
                            sendTo("pushover.0", MeldungNew);
                          }
                          /* Verknüpfen aller neuen Warnmeldungen */
                          if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
                            MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
                          }
                        }
                      }
                      /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
                      MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
                      
                      /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                      if((idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
                        var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                        log('Url2 :' + Url2);
                        request(Url2);
                      }
                      /* Bereich für Sprachausgabe über SayIt */
                      if((idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
                        setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                      }
                      
                      /* Neue Werte sichern */
                      oldHeadlines = newHeadlines.slice();
                      oldDescriptions = newDescriptions.slice();
                      oldBegins = newBegins.slice();
                      oldEnds = newEnds.slice();
                    }
                    
                    /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
                    function entferneDatenpunkt(beschreibung) {
                      var rueckgabe;
                      rueckgabe = beschreibung;
                      try {
                        rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
                        rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
                      }
                      catch(e) {}
                      return rueckgabe;
                    }
                    on(idDescription0, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[0] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[0] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[0] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[0] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    
                    on(idDescription1, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[1] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[1] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[1] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[1] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    
                    on(idDescription2, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[2] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[2] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[2] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[2] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    on(idDescription3, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[3] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[3] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[3] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[3] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    on(idDescription4, function(dp) {
                      var warn = null;
                      if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                      warn = (!warn ? {} : warn);
                      if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                      newDescriptions[4] = warn.description === undefined ? '' : warn.description;
                      newHeadlines[4] = warn.headline === undefined ? '' : warn.headline;
                      newBegins[4] = warn.start === undefined ? '' : new Date(warn.start);
                      newEnds[4] = warn.end === undefined ? '' : new Date(warn.end);
                      if(timer) clearTimeout(timer);
                      timer = setTimeout(check, 7000);
                    });
                    

                    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                    Spenden

                    sigi234S 1 Antwort Letzte Antwort
                    0
                    • crunchipC Abwesend
                      crunchipC Abwesend
                      crunchip
                      Forum Testing Most Active
                      schrieb am zuletzt editiert von
                      #10

                      Mal ne generelle Frage zu dem script, wie bekommt ihr die Wetter warnung per sayit?
                      Eigentlich ist doch die Warnungs-Meldung zu lang, folglich kommt im log ne Meldung

                      .....is to short

                      umgestiegen von Proxmox auf Unraid

                      wendy2702W 1 Antwort Letzte Antwort
                      0
                      • T ticaki

                        Habs etwas getested, aber leider kein Sayit oder pushover zur Verfügung.

                        zusätzlich hab ich noch einen Filter für Höhe und Level eingebaut.

                        /* ************************************************************************* */
                        /*             Script zum Übertragen der DWD-Wetterwarnungen über            */
                        /*             Telegram, Pushover, Home24-Mediaplayer oder SayIt             */
                        /*     mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals)     */
                        /*                    Stand: 130022017    PrinzEisenherz1                    */
                        /*                                                                           */
                        /*     - Fehlerbehebung z.B. 5 gültig bis 5                                  */
                        /*                                                                           */
                        /*                                                                           */
                        /*                                                                           */
                        /*                                                                           */
                        /*                          Variante für 5-warnings                          */
                        /*                                                                           */
                        /* ************************************************************************* */
                        var request = require('request');
                        
                        /* Nachrichten-Dienst festlegen */
                        /* aus=0 ; alle=1 ; Pushover=2 ; Telegram=3 */
                        var pushdienst = 3;         // Auswahl Nachrichtendienst
                        
                        const minlevel = 0 // Warnungen unterhalb dieses Levels nicht senden;
                        const maxhoehe = 1000 // Warnung mit für eine Höhe oberhalb dieses Wertes nicht senden
                        /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                        var idSprachausgabe = false;   // Wenn zusätzlich eine Sprachausgabe erfolgen soll dann auf true
                        var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                        
                        /* Konfiguration Sprachausgabe über SayIt */
                        var idSprachausgabeSayIt = true;   // Wenn zusätzlich eine Sprachausgabe über SayIt erfolgen soll dann auf true
                        var idSayIt = "sayit.0.tts.text";
                        var lautstaerke = 60;
                        
                        /* Trigger für Wetterwarnungen */
                        var idDescription0 = "dwd.0.warning.object";
                        var idDescription1 = "dwd.0.warning1.object";
                        var idDescription2 = "dwd.0.warning2.object";
                        var idDescription3 = "dwd.0.warning3.object";
                        var idDescription4 = "dwd.0.warning4.object";
                        
                        /* Arrays festlegen */
                        var newDescriptions = [5];
                        var oldDescriptions = [5];
                        var newHeadlines = [5];
                        var oldHeadlines = [5];
                        var newBegins = [5];
                        var oldBegins = [5];
                        var newEnds = [5];
                        var oldEnds = [5];
                        var timer = null;
                        /* aktivieren bzw erstmaliges Befüllen der arrays */
                        newDescriptions[0] = '';
                        newDescriptions[1] = '';
                        newDescriptions[2] = '';
                        newDescriptions[3] = '';
                        newDescriptions[4] = '';
                        oldDescriptions[0] = '';
                        oldDescriptions[1] = '';
                        oldDescriptions[2] = '';
                        oldDescriptions[3] = '';
                        oldDescriptions[4] = '';
                        
                        newHeadlines[0] = '';
                        newHeadlines[1] = '';
                        newHeadlines[2] = '';
                        newHeadlines[3] = '';
                        newHeadlines[4] = '';
                        oldHeadlines[0] = '';
                        oldHeadlines[1] = '';
                        oldHeadlines[2] = '';
                        oldHeadlines[3] = '';
                        oldHeadlines[4] = '';
                        
                        newBegins[0] = '';
                        newBegins[1] = '';
                        newBegins[2] = '';
                        newBegins[3] = '';
                        newBegins[4] = '';
                        oldBegins[0] = '';
                        oldBegins[1] = '';
                        oldBegins[2] = '';
                        oldBegins[3] = '';
                        oldBegins[4] = '';
                        
                        newEnds[0] = '';
                        newEnds[1] = '';
                        newEnds[2] = '';
                        newEnds[3] = '';
                        newEnds[4] = '';
                        oldEnds[0] = '';
                        oldEnds[1] = '';
                        oldEnds[2] = '';
                        oldEnds[3] = '';
                        oldEnds[4] = '';
                        
                        function check() {
                          /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
                          if(newDescriptions[0] === "") {
                            MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
                            /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                            if(idSprachausgabe === true){
                              var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                              request(Url);
                            }
                            
                            /* Bereich für Sprachausgabe SayIt im Zeitraum */	  
                            var ENDE= '22:30';                     // Ende immer 22:30h
                            var START;
                            
                            
                            schedule("0 6 * * *", function (){                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist          
                              var date = new Date();
                              var n = date.getDay();
                              var weekend = 0;
                              weekend = (n === 0 || n == 6) ? 1 : 0;
                              
                              if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
                                START = '9:00';  
                              }    
                              else{
                                START = '6:45';
                              }
                              
                            });
                            
                            
                            /* Bereich für Sprachausgabe über SayIt */
                            if(idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
                              setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                            }
                            if ((pushdienst === 3) || (pushdienst === 1) ) {
                              setTimeout(()=>(sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
                            }
                            if ((pushdienst === 2) || (pushdienst === 1) ) {
                              sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                            }
                            
                            /* alle Sicherungen Wetterwarnung löschen */
                            oldHeadlines = newHeadlines.slice();
                            oldDescriptions = newDescriptions.slice();
                            oldBegins = newBegins.slice();
                            oldEnds = newEnds.slice();
                            return;
                          }
                          
                          /* Variablen für Meldungen Text */
                          var MeldungOld = '';
                          var MeldungNew = '';
                          /* Variablen für Meldungen Sprache */
                          var MeldungSpracheDWD = '';
                          var MeldungNewSprache = '';
                          var MeldungOldSprache = '';
                          
                          var headline;
                          var description;
                          var begin;
                          var end;
                          var i;
                          var warn;
                          
                          /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
                          for(i = 0; i < 5; i++) {
                            warn = 'dwd.0.warning';
                            if(i) warn = warn + i;
                            headline = oldHeadlines[i];
                            description = oldDescriptions[i];
                            begin = oldBegins[i];
                            end = oldEnds[i];
                            if(newDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                              MeldungOld = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben';
                              MeldungOldSprache = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben' + '  .  ';
                              if ((pushdienst === 3) || (pushdienst === 1) ) {
                                setTimeout(()=>(sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                              }
                              if ((pushdienst === 2) || (pushdienst === 1) ) {
                                sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                              }
                              /* Verknüpfen aller aufgehobenen Wetterwarnungen */
                              if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
                                MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
                              }
                            }
                          }
                          
                          /* Bereich für 'Neue Amtliche Wetterwarnung' */
                          for(i = 0; i < 5; i++) {
                            warn = 'dwd.0.warning';
                            if(i) warn = warn + i;
                            headline = newHeadlines[i];
                            description = newDescriptions[i];
                            begin = newBegins[i];
                            end = newEnds[i];
                            if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                              MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
                              /* Entfernen °C für Sprachausgabe */
                              var replaceDescription0 = entferneDatenpunkt(description);
                              MeldungNewSprache = headline + " gültig vom " + begin + " Uhr, bis " + end + " Uhr. " + replaceDescription0 + '  .  ';
                              if ((pushdienst === 3) || (pushdienst === 1) ) {
                                setTimeout(()=>(sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                              }
                              if ((pushdienst === 2) || (pushdienst === 1) ) {
                                sendTo("pushover.0", MeldungNew);
                              }
                              /* Verknüpfen aller neuen Warnmeldungen */
                              if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
                                MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
                              }
                            }
                          }
                          /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
                          MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
                          
                          /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                          if((idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
                            var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                            log('Url2 :' + Url2);
                            request(Url2);
                          }
                          /* Bereich für Sprachausgabe über SayIt */
                          if((idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
                            setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                          }
                          
                          /* Neue Werte sichern */
                          oldHeadlines = newHeadlines.slice();
                          oldDescriptions = newDescriptions.slice();
                          oldBegins = newBegins.slice();
                          oldEnds = newEnds.slice();
                        }
                        
                        /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
                        function entferneDatenpunkt(beschreibung) {
                          var rueckgabe;
                          rueckgabe = beschreibung;
                          try {
                            rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
                            rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
                          }
                          catch(e) {}
                          return rueckgabe;
                        }
                        on(idDescription0, function(dp) {
                          var warn = null;
                          if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                          warn = (!warn ? {} : warn);
                          if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                          newDescriptions[0] = warn.description === undefined ? '' : warn.description;
                          newHeadlines[0] = warn.headline === undefined ? '' : warn.headline;
                          newBegins[0] = warn.start === undefined ? '' : new Date(warn.start);
                          newEnds[0] = warn.end === undefined ? '' : new Date(warn.end);
                          if(timer) clearTimeout(timer);
                          timer = setTimeout(check, 7000);
                        });
                        
                        on(idDescription1, function(dp) {
                          var warn = null;
                          if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                          warn = (!warn ? {} : warn);
                          if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                          newDescriptions[1] = warn.description === undefined ? '' : warn.description;
                          newHeadlines[1] = warn.headline === undefined ? '' : warn.headline;
                          newBegins[1] = warn.start === undefined ? '' : new Date(warn.start);
                          newEnds[1] = warn.end === undefined ? '' : new Date(warn.end);
                          if(timer) clearTimeout(timer);
                          timer = setTimeout(check, 7000);
                        });
                        
                        on(idDescription2, function(dp) {
                          var warn = null;
                          if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                          warn = (!warn ? {} : warn);
                          if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                          newDescriptions[2] = warn.description === undefined ? '' : warn.description;
                          newHeadlines[2] = warn.headline === undefined ? '' : warn.headline;
                          newBegins[2] = warn.start === undefined ? '' : new Date(warn.start);
                          newEnds[2] = warn.end === undefined ? '' : new Date(warn.end);
                          if(timer) clearTimeout(timer);
                          timer = setTimeout(check, 7000);
                        });
                        on(idDescription3, function(dp) {
                          var warn = null;
                          if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                          warn = (!warn ? {} : warn);
                          if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                          newDescriptions[3] = warn.description === undefined ? '' : warn.description;
                          newHeadlines[3] = warn.headline === undefined ? '' : warn.headline;
                          newBegins[3] = warn.start === undefined ? '' : new Date(warn.start);
                          newEnds[3] = warn.end === undefined ? '' : new Date(warn.end);
                          if(timer) clearTimeout(timer);
                          timer = setTimeout(check, 7000);
                        });
                        on(idDescription4, function(dp) {
                          var warn = null;
                          if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                          warn = (!warn ? {} : warn);
                          if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                          newDescriptions[4] = warn.description === undefined ? '' : warn.description;
                          newHeadlines[4] = warn.headline === undefined ? '' : warn.headline;
                          newBegins[4] = warn.start === undefined ? '' : new Date(warn.start);
                          newEnds[4] = warn.end === undefined ? '' : new Date(warn.end);
                          if(timer) clearTimeout(timer);
                          timer = setTimeout(check, 7000);
                        });
                        

                        sigi234S Online
                        sigi234S Online
                        sigi234
                        Forum Testing Most Active
                        schrieb am zuletzt editiert von
                        #11

                        @ticaki

                        Cool, kannst du auch email einbauen?

                        Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                        Immer Daten sichern!

                        T 2 Antworten Letzte Antwort
                        0
                        • sigi234S sigi234

                          @ticaki

                          Cool, kannst du auch email einbauen?

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

                          @sigi234
                          Jo, aber nicht heute :) Hab gerade keine eigenen Ideen, aber lust aufs coden

                          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                          Spenden

                          1 Antwort Letzte Antwort
                          0
                          • sigi234S sigi234

                            @ticaki

                            Cool, kannst du auch email einbauen?

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

                            @sigi234
                            ok doch noch heute, ist aber nicht weiter getestet.

                            /* ************************************************************************* */
                            /*             Script zum Übertragen der DWD-Wetterwarnungen über            */
                            /*             Telegram, Pushover, Home24-Mediaplayer oder SayIt             */
                            /*     mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals)     */
                            /*                    Stand: 130022017    PrinzEisenherz1                    */
                            /*                                                                           */
                            /*     - Fehlerbehebung z.B. 5 gültig bis 5                                  */
                            /*                                                                           */
                            /*                                                                           */
                            /*                                                                           */
                            /*                                                                           */
                            /*                          Variante für 5-warnings                          */
                            /*                                                                           */
                            /* ************************************************************************* */
                            var request = require('request');
                            
                            /* Nachrichten-Dienst festlegen */
                            /* aus=0 ; alle=1 ; Pushover=2 ; Telegram=3 */
                            var pushdienst = 3;         // Auswahl Nachrichtendienst
                            
                            const senderEmailID = ''; // mit Sender Emailadresse füllen zum aktivieren. email Adapter muß installiert sein
                            const empfaengerEmailID = '';// mit Empfänger Emailadresse füllen zum aktivieren.
                            
                            const minlevel = 0 // Warnungen unterhalb dieses Levels nicht senden;
                            const maxhoehe = 1000 // Warnung mit für eine Höhe oberhalb dieses Wertes nicht senden
                            /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                            var idSprachausgabe = false;   // Wenn zusätzlich eine Sprachausgabe erfolgen soll dann auf true
                            var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                            
                            /* Konfiguration Sprachausgabe über SayIt */
                            var idSprachausgabeSayIt = true;   // Wenn zusätzlich eine Sprachausgabe über SayIt erfolgen soll dann auf true
                            var idSayIt = "sayit.0.tts.text";
                            var lautstaerke = 60;
                            
                            /* Trigger für Wetterwarnungen */
                            var idDescription0 = "dwd.0.warning.object";
                            var idDescription1 = "dwd.0.warning1.object";
                            var idDescription2 = "dwd.0.warning2.object";
                            var idDescription3 = "dwd.0.warning3.object";
                            var idDescription4 = "dwd.0.warning4.object";
                            
                            /* Arrays festlegen */
                            var newDescriptions = [5];
                            var oldDescriptions = [5];
                            var newHeadlines = [5];
                            var oldHeadlines = [5];
                            var newBegins = [5];
                            var oldBegins = [5];
                            var newEnds = [5];
                            var oldEnds = [5];
                            var timer = null;
                            /* aktivieren bzw erstmaliges Befüllen der arrays */
                            newDescriptions[0] = '';
                            newDescriptions[1] = '';
                            newDescriptions[2] = '';
                            newDescriptions[3] = '';
                            newDescriptions[4] = '';
                            oldDescriptions[0] = '';
                            oldDescriptions[1] = '';
                            oldDescriptions[2] = '';
                            oldDescriptions[3] = '';
                            oldDescriptions[4] = '';
                            
                            newHeadlines[0] = '';
                            newHeadlines[1] = '';
                            newHeadlines[2] = '';
                            newHeadlines[3] = '';
                            newHeadlines[4] = '';
                            oldHeadlines[0] = '';
                            oldHeadlines[1] = '';
                            oldHeadlines[2] = '';
                            oldHeadlines[3] = '';
                            oldHeadlines[4] = '';
                            
                            newBegins[0] = '';
                            newBegins[1] = '';
                            newBegins[2] = '';
                            newBegins[3] = '';
                            newBegins[4] = '';
                            oldBegins[0] = '';
                            oldBegins[1] = '';
                            oldBegins[2] = '';
                            oldBegins[3] = '';
                            oldBegins[4] = '';
                            
                            newEnds[0] = '';
                            newEnds[1] = '';
                            newEnds[2] = '';
                            newEnds[3] = '';
                            newEnds[4] = '';
                            oldEnds[0] = '';
                            oldEnds[1] = '';
                            oldEnds[2] = '';
                            oldEnds[3] = '';
                            oldEnds[4] = '';
                            
                            function check() {
                              /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
                              if(newDescriptions[0] === "") {
                                MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
                                /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                                if(idSprachausgabe === true){
                                  var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                                  request(Url);
                                }
                                
                                /* Bereich für Sprachausgabe SayIt im Zeitraum */	  
                                var ENDE= '22:30';                     // Ende immer 22:30h
                                var START;
                                
                                
                                schedule("0 6 * * *", function (){                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist          
                                  var date = new Date();
                                  var n = date.getDay();
                                  var weekend = 0;
                                  weekend = (n === 0 || n == 6) ? 1 : 0;
                                  
                                  if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
                                    START = '9:00';  
                                  }    
                                  else{
                                    START = '6:45';
                                  }
                                  
                                });
                                
                                
                                /* Bereich für Sprachausgabe über SayIt */
                                if(idSprachausgabeSayIt === true && compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
                                  setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                                }
                                if ((pushdienst === 3) || (pushdienst === 1) ) {
                                  setTimeout(()=>(sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben')), 3 * 1000);
                                }
                                if ((pushdienst === 2) || (pushdienst === 1) ) {
                                  sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                                }
                                if (senderEmailID!= '' && empfaengerEmailID!='' && AllEmailMsg != '') {
                                    sendTo("email", {
                                        from:    senderEmailID,
                                        to:      empfaengerEmailID,
                                        subject: "Wetterentwarnung des DWD(iobroker)",
                                        text:    'Alle Warnmeldungen des DWD wurden aufgehoben'
                                        });
                                }
                                
                                /* alle Sicherungen Wetterwarnung löschen */
                                oldHeadlines = newHeadlines.slice();
                                oldDescriptions = newDescriptions.slice();
                                oldBegins = newBegins.slice();
                                oldEnds = newEnds.slice();
                                return;
                              }
                              
                              /* Variablen für Meldungen Text */
                              var MeldungOld = '';
                              var MeldungNew = '';
                              /* Variablen für Meldungen Sprache */
                              var MeldungSpracheDWD = '';
                              var MeldungNewSprache = '';
                              var MeldungOldSprache = '';
                              var AllEmailMsg = '';
                              
                              var headline;
                              var description;
                              var begin;
                              var end;
                              var i;
                              var warn;
                              
                              /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
                              for(i = 0; i < 5; i++) {
                                warn = 'dwd.0.warning';
                                if(i) warn = warn + i;
                                headline = oldHeadlines[i];
                                description = oldDescriptions[i];
                                begin = oldBegins[i];
                                end = oldEnds[i];
                                if(newDescriptions.indexOf(description) == -1 && description !== '' && description !== undefined) {
                                  MeldungOld = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben';
                                  MeldungOldSprache = oldHeadlines[i] + ' gültig bis ' + oldEnds[i] + ' Uhr wurde aufgehoben' + '  .  ';
                                  if ((pushdienst === 3) || (pushdienst === 1) ) {
                                    setTimeout(()=>(sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben")), 3 * 1000);
                                  }
                                  if ((pushdienst === 2) || (pushdienst === 1) ) {
                                    sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                                  }
                                  if (senderEmailID!= '' && empfaengerEmailID!='') {
                                    AllEmailMsg+="Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben"+'\n';
                                  }
                                  /* Verknüpfen aller aufgehobenen Wetterwarnungen */
                                  if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
                                    MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
                                  }
                                }
                              }
                              
                              /* Bereich für 'Neue Amtliche Wetterwarnung' */
                              for(i = 0; i < 5; i++) {
                                warn = 'dwd.0.warning';
                                if(i) warn = warn + i;
                                headline = newHeadlines[i];
                                description = newDescriptions[i];
                                begin = newBegins[i];
                                end = newEnds[i];
                                if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                                  MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
                                  /* Entfernen °C für Sprachausgabe */
                                  var replaceDescription0 = entferneDatenpunkt(description);
                                  MeldungNewSprache = headline + " gültig vom " + begin + " Uhr, bis " + end + " Uhr. " + replaceDescription0 + '  .  ';
                                  if ((pushdienst === 3) || (pushdienst === 1) ) {
                                    setTimeout(()=>(sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                                  }
                                  if ((pushdienst === 2) || (pushdienst === 1) ) {
                                    sendTo("pushover.0", MeldungNew);
                                  }
                                  if (senderEmailID!= '' && empfaengerEmailID!='') {
                                    AllEmailMsg+=MeldungNew+'\n';
                                  }
                                  /* Verknüpfen aller neuen Warnmeldungen */
                                  if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
                                    MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
                                  }
                                }
                              }
                              /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
                              MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
                              
                              /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                              if((idSprachausgabe === true) && (MeldungSpracheDWD !== "")){
                                var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                                log('Url2 :' + Url2);
                                request(Url2);
                              }
                              /* Bereich für Sprachausgabe über SayIt */
                              if((idSprachausgabeSayIt === true) && (MeldungSpracheDWD !== "")){
                                setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                              }
                              if (senderEmailID!= '' && empfaengerEmailID!='' && AllEmailMsg != '') {
                                sendTo("email", {
                                    from:    senderEmailID,
                                    to:      empfaengerEmailID,
                                    subject: "Wetterwarnungen des DWD(iobroker)",
                                    text:    AllEmailMsg
                                    });
                              }
                            
                              /* Neue Werte sichern */
                              oldHeadlines = newHeadlines.slice();
                              oldDescriptions = newDescriptions.slice();
                              oldBegins = newBegins.slice();
                              oldEnds = newEnds.slice();
                            }
                            
                            /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
                            function entferneDatenpunkt(beschreibung) {
                              var rueckgabe;
                              rueckgabe = beschreibung;
                              try {
                                rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
                                rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
                              }
                              catch(e) {}
                              return rueckgabe;
                            }
                            on(idDescription0, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[0] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[0] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[0] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[0] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            
                            on(idDescription1, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[1] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[1] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[1] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[1] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            
                            on(idDescription2, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[2] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[2] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[2] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[2] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            on(idDescription3, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[3] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[3] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[3] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[3] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            on(idDescription4, function(dp) {
                              var warn = null;
                              if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                              warn = (!warn ? {} : warn);
                              if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                              newDescriptions[4] = warn.description === undefined ? '' : warn.description;
                              newHeadlines[4] = warn.headline === undefined ? '' : warn.headline;
                              newBegins[4] = warn.start === undefined ? '' : new Date(warn.start);
                              newEnds[4] = warn.end === undefined ? '' : new Date(warn.end);
                              if(timer) clearTimeout(timer);
                              timer = setTimeout(check, 7000);
                            });
                            

                            Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                            Spenden

                            1 Antwort Letzte Antwort
                            1
                            • crunchipC crunchip

                              Mal ne generelle Frage zu dem script, wie bekommt ihr die Wetter warnung per sayit?
                              Eigentlich ist doch die Warnungs-Meldung zu lang, folglich kommt im log ne Meldung

                              .....is to short

                              wendy2702W Online
                              wendy2702W Online
                              wendy2702
                              schrieb am zuletzt editiert von
                              #14

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

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

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

                              crunchipC 1 Antwort Letzte Antwort
                              0
                              • T ticaki

                                @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 :)

                                wendy2702W Online
                                wendy2702W Online
                                wendy2702
                                schrieb am zuletzt editiert von wendy2702
                                #15

                                @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!!!

                                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

                                  @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 Online
                                    wendy2702W Online
                                    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 Online
                                        wendy2702W Online
                                        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
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          463

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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