Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. DWD Warnung als Telegramm

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    DWD Warnung als Telegramm

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      tempestas last edited by

      Das fügst du einfach da ein, wo bislang dieses hier Stand:

      /* Bereich für Sprachausgabe über SayIt */
            if(idSprachausgabeSayIt === true){
               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');
            }
      
      
      1 Reply Last reply Reply Quote 0
      • wendy2702
        wendy2702 last edited by

        Danke für die schnelle Antwort.

        Wenn ich das Einfüge bekomme ich diesen Fehler:

        999_ansage_time_range.jpg

        Mirko

        1 Reply Last reply Reply Quote 0
        • T
          tempestas last edited by

          Hab ne Klammer vergessen bzw falsch gesetzt. Bin leider nicht so kompetent wie andere hier und im Forum sehe ich noch zu wenig beim tippern.

          so sollte es gehen:

          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');
                }
          
          
          1 Reply Last reply Reply Quote 0
          • wendy2702
            wendy2702 last edited by

            @tempestas:

            Hab ne Klammer vergessen bzw falsch gesetzt. Bin leider nicht so kompetent wie andere hier und im Forum sehe ich noch zu wenig beim tippern.

            so sollte es gehen: `

            Naja…"nicht so kompetent".... ich bekomme das überhaupt nicht hin und werde das wohl in diesem Leben auch nicht mehr lernen...

            Habe es eingefügt und jetzt gibt es keine Fehlermeldung.

            Werde das jetzt mal ein paar Nächte Testen und schauen was passiert.

            Danke für deine Arbeit

            Mirko

            1 Reply Last reply Reply Quote 0
            • T
              tempestas last edited by

              Hallo zusammen,

              ich habe das Skript von PrinzEisenherz etwas abgewandelt, da es mich kolossal genervt hat, gefühlt im Minutentakt mit unbedeutenden Meldungen vollgeballert zu werden durch den DWD.

              Hier im Norden weht nunmal ab und zu eine steife Brise, da gerate ich aber nicht in Panik.

              Ich hab also das Skript etwas ergänzt, damit man via VIS einstellen kann, ab welcher Stufe gewarnt werden soll. Da ich das ganze für mich angepasst habe, sind pushover, sayit und home24 nicht mehr enthalten, aber das kann man ja schnell wieder einpflegen.

              Daneben habe ich die Arrays am Anfang etwas "aufgeräumt", aber eventuell habe ich da auch schlicht einen Grund für die Art der Vorgehensweise nicht verstanden, kann sehr gut sein.

              So scheint es jedenfalls (auch) zu funktionieren

              ! ```
              `/* ************************************************************************* /
              /
              Script zum Übertragen der DWD-Wetterwarnungen über /
              /
              Telegram, Pushover, Home24-Mediaplayer oder SayIt /
              /
              mit freundlicher Unterstützung von Paul53 (Tausend Dank nochmals) /
              /
              Stand: 13022017 PrinzEisenherz1 /
              /
              /
              /
              - Fehlerbehebung z.B. 3 gültig bis 3 /
              /
              /
              /
              /
              /
              http://forum.iobroker.net/viewtopic.php?f=21&t=4451&start=40 /
              /
              Skript verkürzt tempestas, /
              /
              kein sayit, pushover, media24, /
              /
              telegram aktivierbar via vis /
              /
              Level, ab dem gewarnt wird einstellbar via VIS /
              /
              Variante für 3-warnings /
              /
              /
              /
              ************************************************************************* /
              ! createState('DWD.Telegram', false, {
              read: true,
              write: true,
              name: "DWD Warnungen per Telegram senden?",
              type: "boolean",
              def: false
              });
              ! createState('DWD.SeverityTrigger', 1, {
              read: true,
              write: true,
              name: "DWD Warnungen ab welchem Lvl",
              type: "number"
              });
              ! var request = require('request');
              ! var debug = false;
              ! var idTelegramAktiv = "javascript.0.DWD.Telegram";
              var idSeverityTrigger = "javascript.0.DWD.SeverityTrigger";
              ! var telegram;
              ! /
              Trigger für Wetterwarnungen /
              var idDescription0 = "dwd.0.warning.description";
              var idDescription1 = "dwd.0.warning1.description";
              var idDescription2 = "dwd.0.warning2.description";
              ! /
              Arrays festlegen */
              var newDescriptions = [];
              var oldDescriptions = [];
              var newHeadlines = [];
              var oldHeadlines = [];
              var newBegins = [];
              var oldBegins = [];
              var newEnds = [];
              var oldEnds = [];
              var newSeverity = [];
              var oldSeverity = [];
              var timer = null;

              ! /* ###### BEGINN CHECK FUNKTION ############## */

              function check(){

              telegram = getState(idTelegramAktiv).val;
              

              /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' --> DEAKTIVIERT; NERVT */

              ! if(newDescriptions[0] === "") {
              ! /* alle Sicherungen Wetterwarnung löschen */
              oldHeadlines = newHeadlines.slice();
              oldDescriptions = newDescriptions.slice();
              oldBegins = newBegins.slice();
              oldEnds = newEnds.slice();
              oldSeverity =newSeverity.slice();
              return;

              }               
              

              /* ENDE Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */

              ! /* Variablen für Meldungen Text /
              var MeldungOld = '';
              var MeldungNew = '';
              ! var headline;
              var description;
              var begin;
              var end;
              var i;
              var warn;
              var severity;
              ! /
              START Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */

              for(i = 0; i < 3; i++) {
              
                warn = 'dwd.0.warning';
              

              ! if(i) warn = warn + i; // also dwd.0.warning1, warning2....

                headline = oldHeadlines[i];
                description = oldDescriptions[i];
                begin = oldBegins[i];
                end = oldEnds[i];
                severity = oldSeverity[i];
              
                  if(debug) log("Severity Pfad alte Warnungen: " +warn+'.severity' +". Der Warnlevel war: "+severity);      
              
                   if(newDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                      MeldungOld = headline +'\nStufe '+severity+ '\ngültig bis ' + end + ' Uhr wurde aufgehoben';
              
                          if(telegram && ( severity >= getState(idSeverityTrigger).val) ) {            //wird nur geschickt, sofern Telegram an ist und Schwerelevel größer gleich definiert
                              setTimeout((sendTo ("telegram.0", MeldungOld)), 3 * 1000);
                          }
                          else if(debug) log("Stufe ist "+severity +' für Telegram benötigt ist Stufe '+getState(idSeverityTrigger).val);
                   }
                }
              

              ! /* START Bereich für 'Neue Amtliche Wetterwarnung' */
              ! for(i = 0; i < 3; i++) {

                warn = 'dwd.0.warning';
              
                if(i) warn = warn + i;                        // also dwd.0.warning1, warning2....
              
                headline = newHeadlines[i];
                description = newDescriptions[i];
                begin = newBegins[i];
                end = newEnds[i];
                severity = newSeverity[i];
              
                  if(debug) log("Severity Pfad neue Wetterwarnung: " +warn+'.severity' +". Der aktuelle Warnlevel ist: "+severity);      
              
                   if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                      MeldungNew = headline +'\nStufe '+severity+ "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
              
                          if(telegram && ( severity >= getState(idSeverityTrigger).val) ) {            //   wird nur geschickt, sofern Telegram an ist und Schwerelevel definiert
                            setTimeout((sendTo ("telegram.0", MeldungNew)), 3 * 1000);
                          }
                          else if(debug) log("Stufe ist "+severity +' für Telegram benötigt ist Stufe '+getState(idSeverityTrigger).val);
                   } 
                }
                if(debug) log("Neue Headlines: "+newHeadlines );
              

              ! /* Neue Werte sichern */
              oldHeadlines = newHeadlines.slice();
              oldDescriptions = newDescriptions.slice();
              oldBegins = newBegins.slice();
              oldEnds = newEnds.slice();
              oldSeverity = newSeverity.slice();

              if(debug) log("Als alte Headlines wurde gesichert: "+oldHeadlines);
              

              }

              ! /* ############# ENDE CHECK FUNKTION ###################### */
              ! 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;
              newSeverity[0] =getState(warn +'.severity').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;
              newSeverity[1] =getState(warn +'.severity').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;
              newSeverity[2] =getState(warn +'.severity').val;
              }, 3000);
              if(timer) clearTimeout(timer);
              timer = setTimeout(check, 7000);
              });` [/i][/i][/i][/i][/i][/i][/i][/i][/i][/i]

              1 Reply Last reply Reply Quote 0
              • D
                doctorultra last edited by

                Ich bekomme mit den Script von @Prinzeisenherz1 immer den folgenden Fehler.

                Ich nutze die Version 1.12.

                ! telegram.0 2018-03-22 19:08:54.103 error at WS. (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:268:10)
                ! telegram.0 2018-03-22 19:08:54.103 error at Socket.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:451:14)
                ! telegram.0 2018-03-22 19:08:54.103 error at Socket.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20)
                ! telegram.0 2018-03-22 19:08:54.103 error at Socket. (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                ! telegram.0 2018-03-22 19:08:54.103 error at Manager.ondata (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:322:16)
                ! telegram.0 2018-03-22 19:08:54.103 error at Decoder.add (/opt/iobroker/node_modules/socket.io-parser/index.js:246:12)
                ! telegram.0 2018-03-22 19:08:54.103 error at Decoder.Emitter.emit (/opt/iobroker/node_modules/component-emitter/index.js:134:20)
                ! telegram.0 2018-03-22 19:08:54.103 error at Decoder. (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                ! telegram.0 2018-03-22 19:08:54.103 error at Manager.ondecoded (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:332:8)
                ! telegram.0 2018-03-22 19:08:54.103 error at Manager.Emitter.emit (/opt/iobroker/node_modules/socket.io-client/node_modules/component-emitter/index.js:133:20)
                ! telegram.0 2018-03-22 19:08:54.103 error at Manager. (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                ! telegram.0 2018-03-22 19:08:54.103 error at Socket.onpacket (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:228:12)
                ! telegram.0 2018-03-22 19:08:54.103 error at Socket.onevent (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:270:10)
                ! telegram.0 2018-03-22 19:08:54.103 error at Socket.Emitter.emit (/opt/iobroker/node_modules/socket.io-client/node_modules/component-emitter/index.js:133:20)
                ! telegram.0 2018-03-22 19:08:54.103 error at Socket. (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInMemClient.js:48:30)
                ! telegram.0 2018-03-22 19:08:54.103 error at Object.change (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:3395:34)
                ! telegram.0 2018-03-22 19:08:54.103 error at Adapter.emit (events.js:188:7)
                ! telegram.0 2018-03-22 19:08:54.103 error at emitOne (events.js:96:13)
                ! telegram.0 2018-03-22 19:08:54.103 error at Adapter. (/opt/iobroker/node_modules/iobroker.telegram/main.js:45:14)
                ! telegram.0 2018-03-22 19:08:54.103 error at processMessage (/opt/iobroker/node_modules/iobroker.telegram/main.js:642:33)
                ! telegram.0 2018-03-22 19:08:54.103 error at sendMessage (/opt/iobroker/node_modules/iobroker.telegram/main.js:508:22)
                ! telegram.0 2018-03-22 19:08:54.103 error at _sendMessageHelper (/opt/iobroker/node_modules/iobroker.telegram/main.js:180:13)
                ! telegram.0 2018-03-22 19:08:54.103 error TypeError: Cannot read property 'chatId' of undefined
                ! telegram.0 2018-03-22 19:08:54.102 error message messagebox.system.adapter.telegram.0 [object Object] Cannot read property 'chatId' of undefined
                ! telegram.0 2018-03-22 19:08:54.101 error at WS. (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:268:10)
                ! telegram.0 2018-03-22 19:08:54.101 error at Socket.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:451:14)
                ! telegram.0 2018-03-22 19:08:54.101 error at Socket.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20)
                ! telegram.0 2018-03-22 19:08:54.101 error at Socket. (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                ! telegram.0 2018-03-22 19:08:54.101 error at Manager.ondata (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:322:16)
                ! telegram.0 2018-03-22 19:08:54.101 error at Decoder.add (/opt/iobroker/node_modules/socket.io-parser/index.js:246:12)
                ! telegram.0 2018-03-22 19:08:54.101 error at Decoder.Emitter.emit (/opt/iobroker/node_modules/component-emitter/index.js:134:20)
                ! telegram.0 2018-03-22 19:08:54.101 error at Decoder. (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                ! telegram.0 2018-03-22 19:08:54.101 error at Manager.ondecoded (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:332:8)
                ! telegram.0 2018-03-22 19:08:54.101 error at Manager.Emitter.emit (/opt/iobroker/node_modules/socket.io-client/node_modules/component-emitter/index.js:133:20)
                ! telegram.0 2018-03-22 19:08:54.101 error at Manager. (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                ! telegram.0 2018-03-22 19:08:54.101 error at Socket.onpacket (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:228:12)
                ! telegram.0 2018-03-22 19:08:54.101 error at Socket.onevent (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:270:10)
                ! telegram.0 2018-03-22 19:08:54.101 error at Socket.Emitter.emit (/opt/iobroker/node_modules/socket.io-client/node_modules/component-emitter/index.js:133:20)
                ! telegram.0 2018-03-22 19:08:54.101 error at Socket. (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInMemClient.js:48:30)
                ! telegram.0 2018-03-22 19:08:54.101 error at Object.change (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:3395:34)
                ! telegram.0 2018-03-22 19:08:54.101 error at Adapter.emit (events.js:188:7)
                ! telegram.0 2018-03-22 19:08:54.101 error at emitOne (events.js:96:13)
                ! telegram.0 2018-03-22 19:08:54.101 error at Adapter. (/opt/iobroker/node_modules/iobroker.telegram/main.js:45:14)
                ! telegram.0 2018-03-22 19:08:54.101 error at processMessage (/opt/iobroker/node_modules/iobroker.telegram/main.js:642:33)
                ! telegram.0 2018-03-22 19:08:54.101 error at sendMessage (/opt/iobroker/node_modules/iobroker.telegram/main.js:508:22)
                ! telegram.0 2018-03-22 19:08:54.101 error at _sendMessageHelper (/opt/iobroker/node_modules/iobroker.telegram/main.js:180:13)
                ! telegram.0 2018-03-22 19:08:54.101 error TypeError: Cannot read property 'chatId' of undefined
                ! telegram.0 2018-03-22 19:08:54.099 error message messagebox.system.adapter.telegram.0 [object Object] Cannot read property 'chatId' of undefined

                1 Reply Last reply Reply Quote 0
                • D
                  doctorultra last edited by

                  Ich habe eine logische Frage, wenn ich mir die Werte unter Object ansehen, da steht immer was bei den Warnings drin, wieso liefert er aber dennoch bei manchen, bei den abgelaufenen Warnings keine Wert zurück wenn ich mit getState("dwd.0.warning.headline").val; arbeite?

                  1 Reply Last reply Reply Quote 0
                  • A
                    adarof last edited by

                    Hallo

                    Das Script arbeitete bis vor kurzem super bei mir - hat das schon jemand überarbeitet für die "neuen" Timestampdarstellungsprobleme?

                    Gruss

                    wendy2702 1 Reply Last reply Reply Quote 0
                    • wendy2702
                      wendy2702 @adarof last edited by

                      @adarof Guckst du hier:

                      https://forum.iobroker.net/topic/30616/script-dwd-uwz-nina-warnungen-als-push-sprachnachrichten?page=1

                      1 Reply Last reply Reply Quote 0
                      • A
                        adarof last edited by

                        Uhha ... Danke für die Info. 🙂

                        Das sieht umfassender aus ... das muss ich erstmal überblicken.

                        1 Reply Last reply Reply Quote 0
                        • First post
                          Last post

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        785
                        Online

                        31.7k
                        Users

                        79.9k
                        Topics

                        1.3m
                        Posts

                        16
                        67
                        10354
                        Loading More Posts
                        • Oldest to Newest
                        • Newest to Oldest
                        • Most Votes
                        Reply
                        • Reply as topic
                        Log in to reply
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                        The ioBroker Community 2014-2023
                        logo