Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Fehler im script nach Update Adapter

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.6k

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

Fehler im script nach Update Adapter

Scheduled Pinned Locked Moved JavaScript
62 Posts 6 Posters 3.0k Views 6 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • T ticaki

    Änderungen ab dem ersten Posting:

    • Alexa hinzugefügt
    • Email hinzugefügt
    • Sprachausgabe Datum geändert auf Tag, Monatsname, Stunde, Minute
    • Filter für maximale Höhe
    • Filter für minimales Gefahrenlevel
    • Konfigurationsumgestaltung
    • Daten werden aus Json (.object) gewonnen und nicht über die einzelnen States
    • Startzeit für Sprachausgabe Normal + Wochenende in den Konfigurationsabschnitt verlegt.
    • Variable Anzahl an DWD Warnungen keine Konfiguration nötig.
    • Handlungsanweisungen ausgeben, wenn verfügbar. (ungetestet) (Email & Sprache)

    Fehlerbehebung:

    • Ausgelassene Nachrichten (telegram)
    • undefinied in Zeitanzeigen (telegram)
    • alle unnützen Timeouts rausgeworfen
    • der Fehler der im ersten Post genannt wurde
    • nach einem Restart wird erkannt ob Warnungen aufgehoben wurden.
    • V8 request definition ist nicht mehr nötig
    • V8 nach einem Restart wurden aufgehoben Nachrichten für gefilterte Warnungen ausgegeben
    • V8 Zeileneinsprung korrigiert (kosmetisch Code)
    • V9 Alle Warnungen aufgehoben wurde versendet, wenn der erste Eintrag gefiltert wurde.
    • V9 von/bis Zeiten für Sprachausgabe so gestaltet, dass ich es nachvollziehen kann.
    • V10 States auf Existenz überprüfen

    Bekannte Fehler:

    • wenn während einem Restart neue Warnungen veröffentlicht werden, werden diese mal ausgegeben und mal nicht. Oder Präziser: Wenn der DWD nach einem Neustart aktualisiert bevor das Script initialisiert wurde, werden die Warnungen als "alte" Warnungen erkannt und ignoriert.

    ToDo:

    //Version 10
    //nachbearbeitet von ticaki
    /* ************************************************************************* */
    /*             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                          */
    /*                                                                           */
    /* ************************************************************************* */
    
    /* Nachrichten-Dienst festlegen */
    /* Konstanten nicht verändern */
    const TELEGRAM = 1; 
    const PUSHOVER = 2;
    const EMAIL = 4;
    const SAYIT = 8;
    const HOMETWO = 16;
    const ALEXA = 32;
    var pushdienst=0; 
    /* Konstanten Ende */
    
    /* Konfiguration der zu nutzenden Ausgabe um //pushdienst+= PUSHOVER; zu aktivieren, bitte die // enfernen, also pushdienst+= PUSHOVER; */
    //pushdienst+= TELEGRAM;          // Auskommentieren zum aktivieren
    //pushdienst+= PUSHOVER;          // Auskommentieren zum aktivieren
    //pushdienst+= EMAIL;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
    //pushdienst+= SAYIT;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
    //pushdienst+= HOMETWO;           // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
    //pushdienst+= ALEXA;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
    
    // Filtereinstellungen
    const minlevel = 0 // Warnungen gleich oder unterhalb dieses Levels nicht senden;
    const maxhoehe = 1000 // Warnung für eine Höhe oberhalb dieses Wertes nicht senden
    
    //Formatierungsstring für Datum/Zeit Alternative "TT.MM.YYYY SS:mm" KEINE Anpassung nötig
    const formatierungString = "TT.MM.YYYY SS:mm";
    
    /* Einstellungen zur Emailbenachrichtigung*/
    var senderEmailID = ""; // mit Sender Emailadresse füllen. email Adapter muß installiert sein
    var empfaengerEmailID = "";// mit Empfänger Emailadresse füllen.
    
    /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
    var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
    
    /* Konfiguration Sprachausgabe über SayIt */
    var idSayIt = "sayit.0.tts.text";
    var lautstaerke = 60;
    
    //Konfiguration Sprachausgabe über Alexa
    var idAlexaSerial ='';
    var idAlexa = 'alexa2.0.Echo-Devices.'+idAlexaSerial+'.Commands.announcement';
    
    const startTimeSpeak = '6:45';
    const startTimeSpeakWeekend = '9:00';
    
    
    /* Keine Anpassungen ab hier, außer du weißt was du tuest */ 
    /* Arrays festlegen */
    var newDescriptions = [9];
    var oldDescriptions = [9];
    var newHeadlines = [9];
    var oldHeadlines = [9];
    var newBegins = [9];
    var oldBegins = [9];
    var newEnds = [9];
    var oldEnds = [9];
    var newInstruction = [9];
    var timer = null;
    /* erstmaliges Befüllen der arrays */
    for (let a=0;a<newDescriptions.length;a++) {
        var id = "dwd.0.warning";
        if (a!=0) id+=a.toString();
        id+='.object';
        var warn = {};
        if (existsState(id)) warn = getState(id).val;
        warn = convertJsonDWD(warn);
        newDescriptions[a] = '';
        oldDescriptions[a] = warn.description;
        newHeadlines[a] = '';
        oldHeadlines[a] = warn.headline;
        newBegins[a] = '';
        oldBegins[a] = warn.start;
        newEnds[a] = '';
        oldEnds[a] = warn.end;
    }
    
    // Zeitsteuerung für SayIt & Alexa
    var START = '9:00';
    setWeekend()
    schedule("0 6 * * *", setWeekend);                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist
    
    function setWeekend()
    {
    	let date = new Date();
    	let n = date.getDay();
    	let weekend = 0;
    	weekend = (n === 0 || n == 6) ? 1 : 0;
    	
    	if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
    		START = startTimeSpeakWeekend;
    	}
    	else{
    		START = startTimeSpeak;
    	}
    }
    
    function check() {
    	/* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
    	if(newDescriptions.findIndex(function(a){return (a).toString() != '';})==-1) {
    		MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
    		/* Bereich für Sprachausgabe über Home24-Mediaplayer */
    		if((pushdienst & HOMETWO)!=0 ){
    			var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
    			request(Url);
    		}
    		
    		/* Bereich für Sprachausgabe SayIt & ALexa im Zeitraum */
    		var ENDE= '22:30';                     // Ende immer 22:30h          
    		
    		/* Bereich für Sprachausgabe über SayIt & Alexa */
    		if (compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
    			if ((pushdienst & SAYIT)!=0) setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
    			if ((pushdienst & ALEXA)!=0) setState(idAlexa, MeldungSpracheDWD);
    		}
    		if ((pushdienst & TELEGRAM)!=0 ) {
    			sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
    		}
    		if ((pushdienst & PUSHOVER)!=0 ) {
    			sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
    		}
    		if ((pushdienst & EMAIL)!=0 && senderEmailID != '' && empfaengerEmailID !='') {
    			sendEmail('Wetterentwarnung des DWD(iobroker)','Alle Warnmeldungen des DWD wurden aufgehoben');
    		}
    		
    		/* alle Sicherungen Wetterwarnung löschen */
    		oldHeadlines = newHeadlines.slice();
    		oldDescriptions = newDescriptions.slice();
    		oldBegins = newBegins.slice();
    		oldEnds = newEnds.slice();
    		return;
    	}
    	
    	/* Variablen für Meldungen Text */
    	var MeldungOld = '';
    	var MeldungNew = '';
    	/* Variablen für Meldungen Sprache */
    	var MeldungSpracheDWD = '';
    	var MeldungNewSprache = '';
    	var MeldungOldSprache = '';
    	var AllEmailMsg = '';
    	
    	var headline;
    	var description;
    	var begin;
    	var end;
    	var i;
    	var warn;
    	
    	/* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
    	for(i = 0; i < newDescriptions.length; 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 ' + getFormatDateSpeak(oldEnds[i]) + ' Uhr wurde aufgehoben' + '  .  ';
    			if ((pushdienst & TELEGRAM)!=0) {
    				sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
    			}
    			if ((pushdienst & PUSHOVER)!=0) {
    				sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
    			}
    			if ((pushdienst & EMAIL)!=0 && senderEmailID!= '' && empfaengerEmailID!='') {
    				AllEmailMsg+="Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben"+'\n';
    			}
    			/* Verknüpfen aller aufgehobenen Wetterwarnungen */
    			if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
    				MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
    			}
    		}
    	}
    	
    	/* Bereich für 'Neue Amtliche Wetterwarnung' */
    	for(i = 0; i < newDescriptions.length; i++) {
    		warn = 'dwd.0.warning';
    		if(i) warn = warn + i;
    		headline = newHeadlines[i];
    		description = newDescriptions[i];
    		begin = newBegins[i];
    		end = newEnds[i];
            var instruction = newInstruction[i];
    		if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
    			MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
                if (instruction!='') MeldungNew+='\nHandlungsanweisungen: '+instruction;
    			/* Entfernen °C für Sprachausgabe */
    			var replaceDescription0 = entferneDatenpunkt(description);
    			MeldungNewSprache = headline + " gültig vom " + getFormatDateSpeak(begin) + " Uhr, bis " + getFormatDateSpeak(end) + " Uhr. " + replaceDescription0 + '  .  ';
                if (instruction!='') MeldungNewSprache+='Handlungsanweisungen: '+instruction;
    			if ((pushdienst & TELEGRAM)!=0) {
    				sendTo ("telegram.0", MeldungNew);
    			}
    			if ((pushdienst & PUSHOVER)!=0) {
    				sendTo("pushover.0", MeldungNew);
    			}
    			if ((pushdienst & EMAIL)!=0 && senderEmailID!= '' && empfaengerEmailID!='') {
    				AllEmailMsg+=MeldungNew+'\n\n';
    			}
    			/* Verknüpfen aller neuen Warnmeldungen */
    			if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
    				MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
    			}
    		}
    	}
    	/* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
    	MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
    	
    	/* Bereich für Sprachausgabe über Home24-Mediaplayer */
    	if((pushdienst & HOMETWO)!=0 && (MeldungSpracheDWD !== "")){
    		var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
    		log('Url2 :' + Url2);
    		request(Url2);
    	}
    	/* Bereich für Sprachausgabe über SayIt */
    	if ((MeldungSpracheDWD !== "")){
    		if ((pushdienst & SAYIT)!=0) setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
    		if ((pushdienst & ALEXA)!=0) setState(idAlexa, MeldungSpracheDWD);
    		
    	}
    	if ((pushdienst & EMAIL)!=0 && senderEmailID != '' && empfaengerEmailID != '' && AllEmailMsg != '') {
    		sendEmail("Wetterwarnungen des DWD(iobroker)",AllEmailMsg);
    	}
    	
    	/* Neue Werte sichern */
    	oldHeadlines = newHeadlines.slice();
    	oldDescriptions = newDescriptions.slice();
    	oldBegins = newBegins.slice();
    	oldEnds = newEnds.slice();
    }
    
    /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
    function entferneDatenpunkt(beschreibung) {
    	var rueckgabe;
    	rueckgabe = beschreibung;
    	try {
    		rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
    		rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
    	}
    	catch(e) {}
    	return rueckgabe;
    }
    
    on(/^dwd\.0\..*\.object$/, function(dp) {
        let i = getIdIndex(dp.id);
    	var warn = null;
    	if (dp.state.val != '') warn = JSON.parse(dp.state.val);
    	warn = convertJsonDWD(warn);
    	newDescriptions[i] = warn.description ;
    	newHeadlines[i] = warn.headline;
    	newBegins[i] = warn.start;
    	newEnds[i] = warn.end;
        newInstruction[i] = warn.instruction;
    	if(timer) clearTimeout(timer);
    	timer = setTimeout(check, 7000);
    });
    
    function convertJsonDWD(warn) {
    	warn = (!warn || warn === ''? {} : warn);
    	if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
    	var a = warn.description === undefined ? '' : warn.description;
    	var b = warn.headline === undefined ? '' : warn.headline;
    	var c = warn.start === undefined ? '' : getFormatDate(new Date(warn.start));
    	var d = warn.end === undefined ? '' : getFormatDate(new Date(warn.end));
        var e = warn.instruction === undefined ? '' : warn.instruction;
    	return {"description":a,"headline":b,"start":c,"end":d,"instruction":e};
    }
    
    function getIdIndex(a) {
        a = a.split('.');
        if (a[2].length == 7) return 0
        return a[2][7];
    }
    function getFormatDate(a) {
    	if (!a || a === '') return '';
    	return formatDate(a.getTime(), formatierungString);
    }
    // @PARAM Rückgabe von getFormatDate
    function getFormatDateSpeak(a) {
    	if (!a || a === '') return '';
    	var b = a.split('.');
    	var m = '';
    	switch (b[1]) {
    		case '01': m='Januar';break;
    		case '02': m='Februar';break;
    		case '03': m='März';break;
    		case '04': m='April';break;
    		case '05': m='Mai';break;
    		case '06': m='Juni';break;
    		case '07': m='Juli';break;
    		case '08': m='August';break;
    		case '09': m='September';break;
    		case '10': m='Oktober';break;
    		case '11': m='November';break;
    		case '12': m='Dezember';break;
    		default: m='';
    	}
    	b[1]=m; // setze Monatsname
    	// entferne Jahr
    	var c = b[2].split(' ');
    	c[0]='';
    	b[2] = c.join(' ');
    	return b.join(' ');
    }
    
    function sendEmail(topic, msg) {
    	if (senderEmailID=='') {
    		log('senderEmailID ist nicht definiert!','warn');
    		return;
    	}
    	if (empfaengerEmailID=='') {
    		log('empfaengerEmailID ist nicht definiert!','warn');
    		return;
    	}
    	sendTo("email", {
    		from:    senderEmailID,
    		to:      empfaengerEmailID,
    		subject: topic,
    		text:    msg
    	});
    }
    
    

    crunchipC Away
    crunchipC Away
    crunchip
    Forum Testing Most Active
    wrote on last edited by crunchip
    #53

    @ticaki Lautstärke für Alexa wäre noch cool, oder kann man das irgendwie im script setzen?
    aktuell gibt es noch Probleme, das hin und wieder die Meldung angesagt wird...."Achtung" und das wars
    im log

    sayit.0	2020-02-27 19:16:11.864	info	(3084) saying: Achtung .
    

    liegt aber eventuell daran

    host.IoBroker	2020-02-27 19:00:19.964	info	instance system.adapter.dwd.0 terminated with code 0 (NO_ERROR)
    dwd.0	2020-02-27 19:00:18.928	error	(13715) Empty or invalid JSON: Cannot parse JSON file.
    

    umgestiegen von Proxmox auf Unraid

    T 1 Reply Last reply
    0
    • sigi234S sigi234

      @ticaki

      Hallo, ab wann und wie löst das Skript aus?

      Bei mir kommt:

      javascript.0	2020-02-27 19:13:43.642	error	(20424) at Timer.processTimers (timers.js:223:10)
      javascript.0	2020-02-27 19:13:43.642	error	(20424) at listOnTimeout (timers.js:263:5)
      javascript.0	2020-02-27 19:13:43.642	error	(20424) at tryOnTimeout (timers.js:300:5)
      javascript.0	2020-02-27 19:13:43.642	error	(20424) at ontimeout (timers.js:438:13)
      javascript.0	2020-02-27 19:13:43.642	error	(20424) at Timeout._onTimeout (C:\Program Files\iobroker\Test\node_modules\iobroker.javascript\lib\sandbox.js:2076:34)
      javascript.0	2020-02-27 19:13:43.642	error	(20424) at Object.check (script.js.Alexa.Ansage_DWD:116:21)
      javascript.0	2020-02-27 19:13:43.642	error	(20424) at Array.findIndex (<anonymous>:null:null)
      javascript.0	2020-02-27 19:13:43.642	error	(20424) at script.js.Alexa.Ansage_DWD:116:54
      javascript.0	2020-02-27 19:13:43.641	error	(20424) Error in callback: TypeError: Cannot read property 'toString' of undefined
      
      T Do not disturb
      T Do not disturb
      ticaki
      wrote on last edited by
      #54

      @crunchip sagte in Fehler im script nach Update Adapter:

      @ticaki Lautstärke für Alexa wäre noch cool, oder kann man das irgendwie im script setzen?

      Ich schreibs auf die todo :)

      @sigi234 sagte in Fehler im script nach Update Adapter:

      @ticaki

      Hallo, ab wann und wie löst das Skript aus?

      Mein Javascript-Adapter verhält sich da anders. ich mach das .toString() weg.

      Das Script löst bei jeder Veränderung der warning*.object mit Verzögerung einen Check aus.

      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

      Spenden

      sigi234S 1 Reply Last reply
      0
      • T ticaki

        @crunchip sagte in Fehler im script nach Update Adapter:

        @ticaki Lautstärke für Alexa wäre noch cool, oder kann man das irgendwie im script setzen?

        Ich schreibs auf die todo :)

        @sigi234 sagte in Fehler im script nach Update Adapter:

        @ticaki

        Hallo, ab wann und wie löst das Skript aus?

        Mein Javascript-Adapter verhält sich da anders. ich mach das .toString() weg.

        Das Script löst bei jeder Veränderung der warning*.object mit Verzögerung einen Check aus.

        sigi234S Online
        sigi234S Online
        sigi234
        Forum Testing Most Active
        wrote on last edited by
        #55

        @ticaki sagte in Fehler im script nach Update Adapter:

        Das Script löst bei jeder Veränderung der warning*.object mit Verzögerung einen Check aus.

        Ok, wäre es nicht möglich eine Ansage auf einen DP auszulösen?

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

        T 1 Reply Last reply
        0
        • sigi234S sigi234

          @ticaki sagte in Fehler im script nach Update Adapter:

          Das Script löst bei jeder Veränderung der warning*.object mit Verzögerung einen Check aus.

          Ok, wäre es nicht möglich eine Ansage auf einen DP auszulösen?

          T Do not disturb
          T Do not disturb
          ticaki
          wrote on last edited by
          #56

          @sigi234
          Ja ist möglich. Was stellst du dir darunter vor? Keine Automatik oder nur einen Option zum zusätzlichen auslösen?

          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

          Spenden

          sigi234S 1 Reply Last reply
          0
          • T ticaki

            @sigi234
            Ja ist möglich. Was stellst du dir darunter vor? Keine Automatik oder nur einen Option zum zusätzlichen auslösen?

            sigi234S Online
            sigi234S Online
            sigi234
            Forum Testing Most Active
            wrote on last edited by sigi234
            #57

            @ticaki sagte in Fehler im script nach Update Adapter:

            oder nur einen Option zum zusätzlichen auslösen?

            Ja würde genügen.

            Oder:

            Option im Skript :

            • Automatikmodus an/aus

            • DP zur manuellen Auslösung
              Dann kann ich via Aelxa fragen ob es eine Warnung gibt

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

            1 Reply Last reply
            0
            • crunchipC crunchip

              @ticaki Lautstärke für Alexa wäre noch cool, oder kann man das irgendwie im script setzen?
              aktuell gibt es noch Probleme, das hin und wieder die Meldung angesagt wird...."Achtung" und das wars
              im log

              sayit.0	2020-02-27 19:16:11.864	info	(3084) saying: Achtung .
              

              liegt aber eventuell daran

              host.IoBroker	2020-02-27 19:00:19.964	info	instance system.adapter.dwd.0 terminated with code 0 (NO_ERROR)
              dwd.0	2020-02-27 19:00:18.928	error	(13715) Empty or invalid JSON: Cannot parse JSON file.
              
              T Do not disturb
              T Do not disturb
              ticaki
              wrote on last edited by
              #58

              @crunchip sagte in Fehler im script nach Update Adapter:

              @ticaki Lautstärke für Alexa wäre noch cool, oder kann man das irgendwie im script setzen?
              aktuell gibt es noch Probleme, das hin und wieder die Meldung angesagt wird...."Achtung" und das wars
              im log

              sayit.0	2020-02-27 19:16:11.864	info	(3084) saying: Achtung .
              

              im code sieht das so aus:

              MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
              

              Echt keine Ahnung wieso da nur ein Achtung . bei dir ankommt...

              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

              Spenden

              1 Reply Last reply
              0
              • T Do not disturb
                T Do not disturb
                ticaki
                wrote on last edited by ticaki
                #59

                Achtung: beim allerersten Start bitte starten, anhalten, starten, damit die States erstellt werden.

                Änderungen ab dem ersten Posting:

                • Alexa hinzugefügt
                • Email hinzugefügt
                • Sprachausgabe Datum geändert auf Tag, Monatsname, Stunde, Minute
                • Filter für maximale Höhe
                • Filter für minimales Gefahrenlevel
                • Konfigurationsumgestaltung
                • Daten werden aus Json (.object) gewonnen und nicht über die einzelnen States
                • Startzeit für Sprachausgabe Normal + Wochenende in den Konfigurationsabschnitt verlegt.
                • Variable Anzahl an DWD Warnungen keine Konfiguration nötig.
                • Handlungsanweisungen ausgeben, wenn verfügbar. (ungetestet) (Email & Sprache)
                • über States einmaliger Nachrichtenversand. Nur über konfigurierte Schienen möglich.
                • Automatik ausschaltbar
                • Lautstärkeeinstellung für Alexa

                Fehlerbehebung:

                • Ausgelassene Nachrichten (telegram)
                • undefinied in Zeitanzeigen (telegram)
                • alle unnützen Timeouts rausgeworfen
                • der Fehler der im ersten Post genannt wurde
                • nach einem Restart wird erkannt ob Warnungen aufgehoben wurden.
                • V8 request definition ist nicht mehr nötig
                • V8 nach einem Restart wurden aufgehoben Nachrichten für gefilterte Warnungen ausgegeben
                • V8 Zeileneinsprung korrigiert (kosmetisch Code)
                • V9 Alle Warnungen aufgehoben wurde versendet, wenn der erste Eintrag gefiltert wurde.
                • V9 von/bis Zeiten für Sprachausgabe so gestaltet, dass ich es nachvollziehen kann.
                • V10 States auf Existenz überprüfen
                • V11 toString() Fehler behoben

                Bekannte Fehler:

                • wenn während einem Restart neue Warnungen veröffentlicht werden, werden diese mal ausgegeben und mal nicht. Oder Präziser: Wenn der DWD nach einem Neustart aktualisiert bevor das Script initialisiert wurde, werden die Warnungen als "alte" Warnungen erkannt und ignoriert.
                • möglich dass server restart nicht so läuft wie gedacht

                ToDo:

                • State der die gleichen Nachrichten enthält wie sie über Telegramm/Pushover verschickt werden um Blockly zu unterstützen

                //Version 11.2
                //nachbearbeitet von ticaki
                /* ************************************************************************* */
                /*             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                          */
                /*                                                                           */
                /* ************************************************************************* */
                
                /* Nachrichten-Dienst festlegen */
                /* Konstanten nicht verändern */
                var konstanten = [{"name":'telegram',"value":1},{"name":'pushover',"value":2},{"name":'email',"value":4},{"name":'sayit',"value":8},{"name":'home24',"value":16},{"name":'alexa',"value":32}];
                const TELEGRAM = konstanten[0].value; 
                const PUSHOVER = konstanten[1].value;
                const EMAIL = konstanten[2].value;
                const SAYIT = konstanten[3].value;
                const HOMETWO = konstanten[4].value;
                const ALEXA = konstanten[5].value;
                var pushdienst=0; 
                /* Konstanten Ende */
                
                /* Konfiguration der zu nutzenden Ausgabe um //pushdienst+= PUSHOVER; zu aktivieren, bitte die // enfernen, also pushdienst+= PUSHOVER; */
                //pushdienst+= TELEGRAM;          // Auskommentieren zum aktivieren
                //pushdienst+= PUSHOVER;          // Auskommentieren zum aktivieren
                //pushdienst+= EMAIL;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                //pushdienst+= SAYIT;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                //pushdienst+= HOMETWO;           // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                //pushdienst+= ALEXA;             // Auskommentieren zum aktivieren. Einstellungen nicht vergessen
                
                //StatePfad um Mitteilungen auszulösen darunter werden jeweils Punkte für jede Ausgabemöglichkeit erstellt.
                var onClickMessageState = 'javascript.0.DWD_Script.Commands.'; // abschließender Punkt . nicht vergessen
                
                // Filtereinstellungen
                const minlevel = 0 // Warnungen gleich oder unterhalb dieses Levels nicht senden;
                const maxhoehe = 410 // Warnung für eine Höhe oberhalb dieses Wertes nicht senden
                
                //Formatierungsstring für Datum/Zeit Alternative "TT.MM.YYYY SS:mm" KEINE Anpassung nötig
                const formatierungString = "TT.MM.YYYY SS:mm";
                
                /* Einstellungen zur Emailbenachrichtigung*/
                var senderEmailID = ""; // mit Sender Emailadresse füllen. email Adapter muß installiert sein
                var empfaengerEmailID = "";// mit Empfänger Emailadresse füllen.
                
                /* Konfiguration Sprachausgabe über Home24-Mediaplayer */
                var idMediaplayer = "192.168.178.68:50000"; // Eingabe IP-Adresse incl. Port für Home24-Mediaplayer
                
                /* Konfiguration Sprachausgabe über SayIt */
                var idSayIt = "sayit.0.tts.text";
                var lautstaerke = 60;
                
                //Konfiguration Sprachausgabe über Alexa
                var idAlexaSerial =''; // die reine Seriennummer des Echos
                var alexaVolumen = 40; // Lautstärke 0-100 (denke ich :) )
                
                // Sprachausgabe Zeiten
                const startTimeSpeak = '6:45';// Zeiten mo-fr ab der Sprachausgaben ok sind.
                const startTimeSpeakWeekend = '9:00';// sa + so
                
                // Automatikmodus auschalten
                var autoMode = true;
                /* Keine Anpassungen ab hier, außer du weißt was du tuest */ 
                var idAlexa = 'alexa2.0.Echo-Devices.'+idAlexaSerial+'.Commands.announcement';
                var idAlexaVolumen = 'alexa2.0.Echo-Devices.'+idAlexaSerial+'.Commands.speak-volume';
                
                /* Arrays festlegen */
                var newDescriptions = [9];
                var oldDescriptions = [9];
                var newHeadlines = [9];
                var oldHeadlines = [9];
                var newBegins = [9];
                var oldBegins = [9];
                var newEnds = [9];
                var oldEnds = [9];
                var newInstruction = [9];
                var timer = null;
                /* erstmaliges Befüllen der arrays */
                for (let a=0;a<newDescriptions.length;a++) {
                    var id = "dwd.0.warning";
                    if (a!=0) id+=a.toString();
                    id+='.object';
                    var warn = {};
                    if (existsState(id)) warn = getState(id).val;
                    warn = convertJsonDWD(warn);
                    newDescriptions[a] = warn.description;
                    oldDescriptions[a] = warn.description;
                    newHeadlines[a] = warn.headline;;
                    oldHeadlines[a] = warn.headline;
                    newBegins[a] = warn.start;
                    oldBegins[a] = warn.start;
                    newEnds[a] = warn.end;
                    oldEnds[a] = warn.end;
                }
                
                // Nachrichtenversand per Click States erzeugen und subscript 
                for (var a=0;a<konstanten.length;a++){
                    if (!existsState(onClickMessageState+konstanten[a].name)) {
                        createState(onClickMessageState+konstanten[a].name,false, {
                            read: true, 
                            write: true, 
                            desc: "Beschreibung", 
                            type: "boolean", 
                            def: false
                        });
                    }
                    if (existsState(onClickMessageState+konstanten[a].name)){
                        subscribe({id: onClickMessageState+konstanten[a].name},function(obj){
                            if (!obj.state.val) return;
                            setState(obj.id,false,true);       
                            let b = obj.id.split('.');
                            let d = konstanten.findIndex(function(c){return (c.name===b[b.length-1]);})
                            if (d == -1) {log('Fehler. State nicht in Konstanten enthalten','error'); return;}
                            if ((pushdienst & konstanten[d].value) == 0) return;
                            let oldPushdienst = pushdienst;
                            pushdienst = konstanten[d].value*1;
                            let tempHeadlines = oldHeadlines.slice();
                            let tempDescriptions = oldDescriptions.slice();
                            let tempBegins = oldBegins.slice();
                            let tempEnds = oldEnds.slice();
                            for (let i=0;i<oldDescriptions.length;i++) {
                                oldHeadlines[i] = '';
                                oldDescriptions[i] = '';
                                oldBegins[i] = '';
                                oldEnds[i] = '';
                            }
                            check();
                            pushdienst = oldPushdienst
                            oldHeadlines = tempHeadlines.slice();
                            oldDescriptions = tempDescriptions.slice();
                            oldBegins = tempBegins.slice();
                            oldEnds = tempEnds.slice(); 
                        })
                    }
                }
                
                // Zeitsteuerung für SayIt & Alexa
                var START = '9:00';
                setWeekend()
                schedule("0 6 * * *", setWeekend);                                  //ausgelöst jeden Tag um 6h morgens; prüft, ob Wochenende ist
                
                function setWeekend()
                {
                    let date = new Date();
                    let n = date.getDay();
                    let weekend = 0;
                    weekend = (n === 0 || n == 6) ? 1 : 0;
                    
                    if(weekend == 1){                     // wenn Wochenende, dann setze Start auf 9h, sonst 6:45h
                        START = startTimeSpeakWeekend;
                    }
                    else{
                        START = startTimeSpeak;
                    }
                }
                
                function check() {
                    /* Bereich für 'Alle Wetterwarnungen wurden aufgehoben' */
                    if(newDescriptions.findIndex(function(a){return (Boolean(a));})==-1) {
                        MeldungSpracheDWD = 'Achtung' + '  .  ' + 'Alle Warnmeldungen des DWD wurden aufgehoben';
                        /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                        if((pushdienst & HOMETWO)!=0 ){
                            var Url = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                            request(Url);
                        }
                        
                        /* Bereich für Sprachausgabe SayIt & ALexa im Zeitraum */
                        var ENDE= '22:30';                     // Ende immer 22:30h          
                        
                        /* Bereich für Sprachausgabe über SayIt & Alexa */
                        if (compareTime(START, ENDE, 'between')){                  // Ansage über Sayit nur im definierten Zeitbereich
                            if ((pushdienst & SAYIT)!=0) setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                            if ((pushdienst & ALEXA)!=0) {
                                setState(idAlexaVolumen, alexaVolumen);
                                setState(idAlexa, MeldungSpracheDWD);
                            }
                        }
                        if ((pushdienst & TELEGRAM)!=0 ) {
                            sendTo ("telegram.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                        }
                        if ((pushdienst & PUSHOVER)!=0 ) {
                            sendTo("pushover.0", 'Alle Warnmeldungen des DWD wurden aufgehoben');
                        }
                        if ((pushdienst & EMAIL)!=0 && senderEmailID != '' && empfaengerEmailID !='') {
                            sendEmail('Wetterentwarnung des DWD(iobroker)','Alle Warnmeldungen des DWD wurden aufgehoben');
                        }
                        
                        /* alle Sicherungen Wetterwarnung löschen */
                        oldHeadlines = newHeadlines.slice();
                        oldDescriptions = newDescriptions.slice();
                        oldBegins = newBegins.slice();
                        oldEnds = newEnds.slice();
                        return;
                    }
                    
                    /* Variablen für Meldungen Text */
                    var MeldungOld = '';
                    var MeldungNew = '';
                    /* Variablen für Meldungen Sprache */
                    var MeldungSpracheDWD = '';
                    var MeldungNewSprache = '';
                    var MeldungOldSprache = '';
                    var AllEmailMsg = '';
                    
                    var headline;
                    var description;
                    var begin;
                    var end;
                    var i;
                    var warn;
                    
                    /* Bereich für 'Wetterwarnung gültig bis wurde aufgehoben' */
                    for(i = 0; i < newDescriptions.length; 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 ' + getFormatDateSpeak(oldEnds[i]) + ' Uhr wurde aufgehoben' + '  .  ';
                            if ((pushdienst & TELEGRAM)!=0) {
                                sendTo ("telegram.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                            }
                            if ((pushdienst & PUSHOVER)!=0) {
                                sendTo("pushover.0", "Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben");
                            }
                            if ((pushdienst & EMAIL)!=0 && senderEmailID!= '' && empfaengerEmailID!='') {
                                AllEmailMsg+="Die Wetterwarnung " +"'"+ oldHeadlines[i] + " gültig bis " + oldEnds[i] + "'" + " des DWD wurde aufgehoben"+'\n';
                            }
                            /* Verknüpfen aller aufgehobenen Wetterwarnungen */
                            if(MeldungOldSprache !== "" && MeldungOldSprache !== undefined){
                                MeldungSpracheDWD = MeldungSpracheDWD + MeldungOldSprache;
                            }
                        }
                    }
                    
                    /* Bereich für 'Neue Amtliche Wetterwarnung' */
                    for(i = 0; i < newDescriptions.length; i++) {
                        warn = 'dwd.0.warning';
                        if(i) warn = warn + i;
                        headline = newHeadlines[i];
                        description = newDescriptions[i];
                        begin = newBegins[i];
                        end = newEnds[i];
                        var instruction = newInstruction[i];
                        if(oldDescriptions.indexOf(description) == -1 && description !== "" && description !== undefined) {
                            MeldungNew = headline + "\ngültig vom " + begin + " Uhr bis " + end + " Uhr\n" + description;
                            if (instruction!='') MeldungNew+='\nHandlungsanweisungen: '+instruction;
                            /* Entfernen °C für Sprachausgabe */
                            var replaceDescription0 = entferneDatenpunkt(description);
                            MeldungNewSprache = headline + " gültig vom " + getFormatDateSpeak(begin) + " Uhr, bis " + getFormatDateSpeak(end) + " Uhr. " + replaceDescription0 + '  .  ';
                            if (instruction!='') MeldungNewSprache+='Handlungsanweisungen: '+instruction;
                            if ((pushdienst & TELEGRAM)!=0) {
                                sendTo ("telegram.0", MeldungNew);
                            }
                            if ((pushdienst & PUSHOVER)!=0) {
                                sendTo("pushover.0", MeldungNew);
                            }
                            if ((pushdienst & EMAIL)!=0 && senderEmailID!= '' && empfaengerEmailID!='') {
                                AllEmailMsg+=MeldungNew+'\n\n';
                            }
                            /* Verknüpfen aller neuen Warnmeldungen */
                            if(MeldungNewSprache !== "" && MeldungNewSprache !== undefined){
                                MeldungSpracheDWD = MeldungSpracheDWD + MeldungNewSprache;
                            }
                        }
                    }
                    /* Verknüpfen aller neuen und abgelaufenen Warnmeldungen */
                    MeldungSpracheDWD = 'Achtung   .  ' + MeldungSpracheDWD;
                    
                    /* Bereich für Sprachausgabe über Home24-Mediaplayer */
                    if((pushdienst & HOMETWO)!=0 && (MeldungSpracheDWD !== "")){
                        var Url2 = "http://" + idMediaplayer + "/track=4fachgong.mp3|tts=" + MeldungSpracheDWD;
                        log('Url2 :' + Url2);
                        request(Url2);
                    }
                    /* Bereich für Sprachausgabe über SayIt */
                    if ((MeldungSpracheDWD !== "")){
                        if ((pushdienst & SAYIT)!=0) setState(idSayIt, lautstaerke + ";" + MeldungSpracheDWD);
                        if ((pushdienst & ALEXA)!=0) {
                            setState(idAlexaVolumen, alexaVolumen);
                            setState(idAlexa, MeldungSpracheDWD);
                        }        
                    }
                    if ((pushdienst & EMAIL)!=0 && senderEmailID != '' && empfaengerEmailID != '' && AllEmailMsg != '') {
                        sendEmail("Wetterwarnungen des DWD(iobroker)",AllEmailMsg);
                    }
                    
                    /* Neue Werte sichern */
                    oldHeadlines = newHeadlines.slice();
                    oldDescriptions = newDescriptions.slice();
                    oldBegins = newBegins.slice();
                    oldEnds = newEnds.slice();
                }
                
                /* Entfernt "°C" aus Sprachmeldung und ersetzt es durch "Grad" */
                function entferneDatenpunkt(beschreibung) {
                    var rueckgabe;
                    rueckgabe = beschreibung;
                    try {
                        rueckgabe = rueckgabe.replace(/\°C/g, "Grad");
                        rueckgabe = rueckgabe.replace(/\km\/h/g, "Kilometer pro Stunde");
                    }
                    catch(e) {}
                    return rueckgabe;
                }
                
                on(/^dwd\.0\..*\.object$/, function(dp) {
                    let i = getIdIndex(dp.id);
                    var warn = null;
                    if (dp.state.val != '') warn = JSON.parse(dp.state.val);
                    warn = convertJsonDWD(warn);
                    newDescriptions[i] = warn.description ;
                    newHeadlines[i] = warn.headline;
                    newBegins[i] = warn.start;
                    newEnds[i] = warn.end;
                    newInstruction[i] = warn.instruction;
                    if(timer) clearTimeout(timer);
                    if (autoMode) timer = setTimeout(check, 7000);
                });
                
                function convertJsonDWD(warn) {
                    warn = (!warn || warn === ''? {} : warn);
                    if (warn != {} && (warn.altitudeStart>maxhoehe || warn.level <= minlevel)) warn = {};
                    var a = warn.description === undefined ? '' : warn.description;
                    var b = warn.headline === undefined ? '' : warn.headline;
                    var c = warn.start === undefined ? '' : getFormatDate(new Date(warn.start));
                    var d = warn.end === undefined ? '' : getFormatDate(new Date(warn.end));
                    var e = warn.instruction === undefined ? '' : warn.instruction;
                    return {"description":a,"headline":b,"start":c,"end":d,"instruction":e};
                }
                
                function getIdIndex(a) {
                    a = a.split('.');
                    if (a[2].length == 7) return 0
                    return a[2][7];
                }
                function getFormatDate(a) {
                    if (!a || a === '') return '';
                    return formatDate(a.getTime(), formatierungString);
                }
                // @PARAM Rückgabe von getFormatDate
                function getFormatDateSpeak(a) {
                    if (!a || a === '') return '';
                    var b = a.split('.');
                    var m = '';
                    switch (b[1]) {
                        case '01': m='Januar';break;
                        case '02': m='Februar';break;
                        case '03': m='März';break;
                        case '04': m='April';break;
                        case '05': m='Mai';break;
                        case '06': m='Juni';break;
                        case '07': m='Juli';break;
                        case '08': m='August';break;
                        case '09': m='September';break;
                        case '10': m='Oktober';break;
                        case '11': m='November';break;
                        case '12': m='Dezember';break;
                        default: m='';
                    }
                    b[1]=m; // setze Monatsname
                    // entferne Jahr
                    var c = b[2].split(' ');
                    c[0]='';
                    b[2] = c.join(' ');
                    return b.join(' ');
                }
                
                function sendEmail(topic, msg) {
                    if (senderEmailID=='') {
                        log('senderEmailID ist nicht definiert!','warn');
                        return;
                    }
                    if (empfaengerEmailID=='') {
                        log('empfaengerEmailID ist nicht definiert!','warn');
                        return;
                    }
                    sendTo("email", {
                        from:    senderEmailID,
                        to:      empfaengerEmailID,
                        subject: topic,
                        text:    msg
                    });
                }
                

                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                Spenden

                1 Reply Last reply
                0
                • T Do not disturb
                  T Do not disturb
                  ticaki
                  wrote on last edited by
                  #60

                  Soll ich nicht ein eigenen Topic für dieses Script auf machen und im ersten Posting die aktuelle Version vorhalten?

                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                  Spenden

                  sigi234S 1 Reply Last reply
                  1
                  • T ticaki

                    Soll ich nicht ein eigenen Topic für dieses Script auf machen und im ersten Posting die aktuelle Version vorhalten?

                    sigi234S Online
                    sigi234S Online
                    sigi234
                    Forum Testing Most Active
                    wrote on last edited by
                    #61

                    @ticaki sagte in Fehler im script nach Update Adapter:

                    Soll ich nicht ein eigenen Topic für dieses Script auf machen und im ersten Posting die aktuelle Version vorhalten?

                    JA

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

                    1 Reply Last reply
                    0
                    • T Do not disturb
                      T Do not disturb
                      ticaki
                      wrote on last edited by
                      #62

                      Hier gehts weiter

                      Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                      Spenden

                      1 Reply Last reply
                      0
                      Reply
                      • Reply as topic
                      Log in to reply
                      • Oldest to Newest
                      • Newest to Oldest
                      • Most Votes


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      695

                      Online

                      32.7k

                      Users

                      82.4k

                      Topics

                      1.3m

                      Posts
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2025
                      logo
                      • Login

                      • Don't have an account? Register

                      • Login or register to search.
                      • First post
                        Last post
                      0
                      • Home
                      • Recent
                      • Tags
                      • Unread 0
                      • Categories
                      • Unreplied
                      • Popular
                      • GitHub
                      • Docu
                      • Hilfe