Skip to content
  • 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
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. JavaScript funktioniert nicht wie gewünscht! Bitte Hilfe.

NEWS

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

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

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

JavaScript funktioniert nicht wie gewünscht! Bitte Hilfe.

Scheduled Pinned Locked Moved JavaScript
95 Posts 8 Posters 10.4k Views 3 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.
  • paul53P paul53

    @skorpil
    Versuche es mal mit diesem einen Skript:

    // ########################################################################
    //                           Deklarationen
    // (wenn im Schlafzimmer oder hinter TV geschaltet wird, dann Variable Aussenbeleuchtung schalten)
    // ########################################################################
     
    const IDAussenbeleuchtung = 'hm-rega.0.1620'/*Aussenbeleuchtung*/;
     
    const IDSchlafAussen = 'hm-rpc.0.NEQ0274762.1.STATE'/*Lichtschltr  Schlafzimmer Aussenbeleuchtung 1 STATE*/;
    const IDAlteHaustuer = 'hm-rpc.0.NEQ0133869.1.STATE'/*Lichtsch  alter Eingang STATE*/;
    const IDHaustuerBew = 'hm-rpc.0.SEQ2044883.1.STATE'/*Lichtsch Haustür (Bewe Mldr ) STATE*/;
    const IDHinterTV = 'hm-rpc.0.MEQ0000333.1.STATE'/*Lichtsch Hinter TV Aussenbeleuchtung 1 STATE*/;
    const IDAlterEingangBew = 'hm-rpc.0.JEQ0093945.1.STATE'/*Lichtsch Alter Eingang (BewMeldAuff) STATE*/;
    const IDMuellEimerLicht = 'hm-rpc.0.LEQ0877661.1.STATE'/*MülleimerLicht:1 STATE*/
    const idBewMldrGarten = 'hm-rpc.0.LEQ0657464.1.MOTION'/*Bew Mldr Garten:1 MOTION*/
    const idBewMldrGartenHell = 'hm-rpc.0.LEQ0657464.1.BRIGHTNESS'/*Bew Mldr Garten:1 BRIGHTNESS*/ 
     
     
    // ##################################
    //              Programm
    // ##################################
    
    var timer = null;
    
    function ausschalten() {
        timer = setTimeout(function() {
            setState(IDAussenbeleuchtung, false);
            setState(IDSchlafAussen, false);
            setStateDelayed(IDHinterTV, false, 1000);
            setStateDelayed(IDAlteHaustuer, false, 2000);
            setStateDelayed(IDMuellEimerLicht, false, 3000);
            timer = null;
        }, 120000);
    }
    
    function licht() {
        if(!timer) {
            if(!getState(IDSchlafAussen).val) setState(IDSchlafAussen, true);
            setState(IDAlteHaustuer, true);
            setState(IDHaustuerBew, false);
            if(!getState(IDHinterTV).val) setState(IDHinterTV, true);
            setState(IDAlterEingangBew, false);
            setStateDelayed(IDHaustuerBew, true, 1000);
            setStateDelayed(IDAlterEingangBew, true, 1500);
            setStateDelayed(IDMuellEimerLicht, true, 2000);
            ausschalten();
        }
    }
    
    on(idBewMldrGarten, function (dp) {
        if(dp.state.val && getState(idBewMldrGartenHell).val < 80) {
            if(timer) {
                clearTimeout(timer); // erneute Bewegung erkannt
                ausschalten();
            } else licht();
        }
    });
    on([IDHinterTV, IDSchlafAussen, IDAussenbeleuchtung], function(dp) {
        if(dp.state.val) licht();
    });
    
    S Offline
    S Offline
    skorpil
    wrote on last edited by
    #63

    @paul53 ich bin Dir ja noch eine Antwort schuldig. Dein Programmvorschlag funktioniert tadellos. Dankeschön. Das Lict schaltet so, wie es soll.

    Was aber noch nicht funktioniert ist die pushover Meldung, wenn das Licht geschaltet wird. Das hatte ich bisher in folgendem Script versucht abzubilden:

    // ##################################
    // Deklarationen
    // ##################################
    
    const IDAusloeser ='hm-rega.0.1620'/*Aussenbeleuchtung*/;
    // const IDAnwesend = 'hm-rega.0.39533'/*Anwesend*/;
    const titel = "Aussenbeleuchtung:";
    const sound = 'siren';
    const prio = 1;
    
    // ##################################
    // Programm
    // ##################################
    
    var timer = null;
    on(IDAusloeser, function (dp) {
    
        if(!timer) {
            timer = setTimeout(function() {
                timer = null;
            }, 5000);    
                // if (getState(IDAnwesend).val) {
                    var message = dp.state.val ? 'EIN!' : 'AUS!'; 
                    pushoverSend(message, titel, sound, prio);                                
            //};         
        
        };        
    });
    

    "const IDAusloeser ='hm-rega.0.1620'/Aussenbeleuchtung/;" ist ja eine CCU SV. Ich habe mir überlegt, mit createState eine neue iobroker SV anzulegen, diese dann in Deinen Programmvorschlag einzufügen und darüber das Pushover Script auszulösen. Was meinst Du?

    noch eine Anmerkung: immer, wenn ich glaubte, ein Script richtig "gebaut" zu haben, stelle ich fest, daß ich doch auf dem Holzweg bin. Irgendwie fehlt mir entweder das Programmier-Gen für Java oder mir fehlen die richtigen tools. Ich ärgere mich sehr über mich selbst, weil ich eigentlich nicht permanent Deine/ Eure Hilfe im Forum in Anspruch nehmen möchte. Vor diesem Hintergund: nochmals Danke an alle Helfer!!!

    paul53P 1 Reply Last reply
    0
    • S skorpil

      @paul53 ich bin Dir ja noch eine Antwort schuldig. Dein Programmvorschlag funktioniert tadellos. Dankeschön. Das Lict schaltet so, wie es soll.

      Was aber noch nicht funktioniert ist die pushover Meldung, wenn das Licht geschaltet wird. Das hatte ich bisher in folgendem Script versucht abzubilden:

      // ##################################
      // Deklarationen
      // ##################################
      
      const IDAusloeser ='hm-rega.0.1620'/*Aussenbeleuchtung*/;
      // const IDAnwesend = 'hm-rega.0.39533'/*Anwesend*/;
      const titel = "Aussenbeleuchtung:";
      const sound = 'siren';
      const prio = 1;
      
      // ##################################
      // Programm
      // ##################################
      
      var timer = null;
      on(IDAusloeser, function (dp) {
      
          if(!timer) {
              timer = setTimeout(function() {
                  timer = null;
              }, 5000);    
                  // if (getState(IDAnwesend).val) {
                      var message = dp.state.val ? 'EIN!' : 'AUS!'; 
                      pushoverSend(message, titel, sound, prio);                                
              //};         
          
          };        
      });
      

      "const IDAusloeser ='hm-rega.0.1620'/Aussenbeleuchtung/;" ist ja eine CCU SV. Ich habe mir überlegt, mit createState eine neue iobroker SV anzulegen, diese dann in Deinen Programmvorschlag einzufügen und darüber das Pushover Script auszulösen. Was meinst Du?

      noch eine Anmerkung: immer, wenn ich glaubte, ein Script richtig "gebaut" zu haben, stelle ich fest, daß ich doch auf dem Holzweg bin. Irgendwie fehlt mir entweder das Programmier-Gen für Java oder mir fehlen die richtigen tools. Ich ärgere mich sehr über mich selbst, weil ich eigentlich nicht permanent Deine/ Eure Hilfe im Forum in Anspruch nehmen möchte. Vor diesem Hintergund: nochmals Danke an alle Helfer!!!

      paul53P Offline
      paul53P Offline
      paul53
      wrote on last edited by paul53
      #64

      @skorpil sagte: nicht funktioniert ist die pushover Meldung, wenn das Licht geschaltet wird.

      Ergänze die Funktion licht() um das Einschalten der SV:

      function licht() {
          if(!timer) {
              if(!getState(IDAussenbeleuchtung).val) setState(IDAussenbeleuchtung, true);
              if(!getState(IDSchlafAussen).val) setState(IDSchlafAussen, true);
      

      Beim Ausschalten wird sie bereits berücksichtigt.

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

      S 1 Reply Last reply
      1
      • S Offline
        S Offline
        skorpil
        wrote on last edited by
        #65

        @paul53 sagte in JavaScript funktioniert nicht wie gewünscht! Bitte Hilfe.:

        Ergänze die Funktion licht() um das Einschalten der SV:

        ach so. Wieder habe ich falsch gedacht. Wird kurzfristig getestet, dann gebe ich feedback. Bin derzeit in Österreich.... frohe Ostern

        1 Reply Last reply
        0
        • paul53P paul53

          @skorpil sagte: nicht funktioniert ist die pushover Meldung, wenn das Licht geschaltet wird.

          Ergänze die Funktion licht() um das Einschalten der SV:

          function licht() {
              if(!timer) {
                  if(!getState(IDAussenbeleuchtung).val) setState(IDAussenbeleuchtung, true);
                  if(!getState(IDSchlafAussen).val) setState(IDSchlafAussen, true);
          

          Beim Ausschalten wird sie bereits berücksichtigt.

          S Offline
          S Offline
          skorpil
          wrote on last edited by
          #66

          @paul53 Test erfolgreich! Vielen Dank für die Hilfe!

          1 Reply Last reply
          0
          • S Offline
            S Offline
            skorpil
            wrote on last edited by
            #67

            @paul53 ich habe wieder ein "unlösbares" Problem und bitte um Hilfe:

            Ich habe drei Programme:

            1. Dieses schaltet den Boiler abends um 22:30 aus und morgens um 06:30 eingeschaltet werden
            // ###########################################
            //            Deklarationen
            // ###########################################
            
            const IDZwBoilerKueche = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
            const BoilerSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
            
            // ##################################
            //              Programm
            // ##################################
            
                schedule({hour: 6, minute: 30}, function () {
                //Wird um 06:30 eingeschaltet, wenn der Boilerschalter true;
                if(getState(BoilerSchalter).val == true) { 
                setState(IDZwBoilerKueche, true);
                };
                });
            
                schedule({hour: 22, minute: 30}, function () {
                //Wird um 22:30 AUSgeschaltet, wenn der Boilerschalter true;
                if(getState(BoilerSchalter).val == true) { 
                setState(IDZwBoilerKueche, false);
                };
                });
            
            1. Dieses Programm schaltet die Geräte im Urlaub bzw. wenn Sommer oder Winter ist, wobei nur der Boiler von Interesse ist, denn der schaltet nicht richtig (erkläre ich später):
            // ###########################################
            //         Urlaub und Sommer Schaltungen
            //                Deklarationen
            // ###########################################
            
            const urlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
            const sommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
            
            const IDthermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
            const IDthermDieleTreppenhaus = 'hm-rpc.0.JEQ0552520.2.SETPOINT'/*Thermostat Diele Treppenhaus 1 SETPOINT*/;
            const IDthermEsszimmer = 'hm-rpc.0.JEQ0553158.2.SETPOINT'/*Thermostat Esszimmer 1 SETPOINT*/;
            const IDthermWohnzimmer = 'hm-rpc.0.JEQ0552318.2.SETPOINT'/*Thermostat Wohnzimmer 1 SETPOINT*/;
            
            const IDanwesend = 'hm-rega.0.39533'/*Anwesend*/;
            const IDstaubsauger = 'hm-rega.0.29769'/*Staubsauger ein/aus*/;
            const IDspringbrunnenGanz = 'hm-rega.0.55701'/*SpringBruGanzEinAus*/;
            
            const IDheizStatusBuegelEltern = 'hm-rega.0.13752'/*Heizstatus (Buegel Eltern ges )*/;
            const IDheizStatusBuero = 'hm-rega.0.14236'/*Heizstatus (Buero)*/;
            const IDheizStatusBar = 'hm-rega.0.23436'/*Heizstatus (BAR)*/;
            const IDheizStatusBritta = 'hm-rega.0.14235'/*Heizstatus (Britta)*/;
            const IDheizStatusJoerg = 'hm-rega.0.4107'/*Heizstatus (JOERG)*/;
            const IDheizStatusGaeste = 'hm-rega.0.3388'/*Heizstatus (Gaestetrakt)*/;
            
            const IDheizHauptOben = 'hm-rpc.0.SEQ3263796.1.STATE'/*HeizungsHauptschalter OBEN:1 STATE*/;
            const IDheizHauptUnten = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/;
            
            const IDklimaBuero = 'hm-rpc.0.OEQ1975895.1.STATE'/*Zw Stkr KlimaBuero:1 STATE*/;
            const IDklimaSchaf = 'hm-rpc.0.OEQ1975873.1.STATE'/*ZW Stkr KlimaSchlafzimer:1 STATE*/;
            
            const IDKeyMatic = 'hm-rpc.0.JEQ0466522.1.STATE'/*KeyMatic Haustuere neu STATE*/;
            
            const IDboiler = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
            const ProgrSchalterBoiler = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
            const IDtechiSat = 'hm-rpc.2.CUX2801002.12.STATE'/*TerchniSat Tasmota 184 (HM-LC-Sw1-Pl CUX2801002:12) STATE*/;
            
            // ###########################################
            //            Programm
            // ###########################################
            
                // *********************************************
                // ausführen nur, wenn Urlaub AUS und Sommer AUS
                // *********************************************
            
            on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP
               if(getState(urlaub).val == 0 && getState(sommer).val == 0) {
            
                // Variable zur Einstellung des Thermometers
                var modus = 1; // 1 = AUTO; 2 = CEN
            
                // Modus des Thermometers via global function thermometerSetzen u. Temperatur einstellen
                // Kueche
                thermometerSetzen(IDthermKueche, modus);
                setState(IDthermKueche,22);
            
                // DieleTreppenhaus
                thermometerSetzen(IDthermDieleTreppenhaus, modus);
                setState(IDthermDieleTreppenhaus,19);
            
                // Esszimmer
                thermometerSetzen(IDthermEsszimmer, modus);
                setState(IDthermEsszimmer,22);
            
                // Wohnzimmer
                thermometerSetzen(IDthermWohnzimmer, modus);
                setState(IDthermWohnzimmer,22);
            
                // Anwesend einschalten
                setState(IDanwesend, true);
            
                // Staubsauger ein (0 = ein)
                setState(IDstaubsauger, 0);
            
                // Springbrunnen ein
                setState(IDspringbrunnenGanz, true);
            
                // HeizStati
                setState(IDheizStatusBuegelEltern, 1);
                setState(IDheizStatusBuero, 1);
                setState(IDheizStatusBar, 0);
                setState(IDheizStatusBritta, 0);
                setState(IDheizStatusJoerg, 0);
                setState(IDheizStatusGaeste, 0);
            
                // HeizHauptschalter AUS
                setState(IDheizHauptUnten, true);
                setState(IDheizHauptOben, true);
            
                // Klima AUS
                setState(IDklimaBuero, false);
                setState(IDklimaSchaf, false);
            
                // TechniSat ein
                setState(IDtechiSat, true);
                
               } // Ende IF Urlaub AUS - Sommer AUS
            
                // *********************************************
                // ausführen nur, wenn Urlaub AUS und Sommer EIN
                // *********************************************
            
            if(getState(urlaub).val == 0 && getState(sommer).val == 1) {
            
              setState(IDheizHauptOben, true);
              setState(IDheizHauptUnten, false);
            
              // Anwesend einschalten
                setState(IDanwesend, true);
            
              // Staubsauger ein (0 = ein)
                setState(IDstaubsauger, 0);
            
              // Springbrunnen ein
                setState(IDspringbrunnenGanz, true); 
                
              // Klima AUS
                // setState(IDklimaBuero, true);
                // setState(IDklimaSchaf, true);
            
                // TechniSat ein
                setState(IDtechiSat, true);
            
                
                } // Ende IF Urlaub AUS - Sommer ein
            
            
            
                // *********************************************
                // ausführen nur, wenn Urlaub EIN und Sommer AUS
                // *********************************************
            
            if(getState(urlaub).val == 1 && getState(sommer).val == 0) {
            
            // Variable zur Einstellung des Thermometers
                var modus = 2; // 1 = AUTO; 2 = CEN
            
                // Modus des Thermometers via global function thermometerSetzen u. Temperatur einstellen
                // Kueche
                thermometerSetzen(IDthermKueche, modus);
                setState(IDthermKueche,15);
            
                // DieleTreppenhaus
                thermometerSetzen(IDthermDieleTreppenhaus, modus);
                setState(IDthermDieleTreppenhaus,15);
            
                // Esszimmer
                thermometerSetzen(IDthermEsszimmer, modus);
                setState(IDthermEsszimmer,15);
            
                // Wohnzimmer
                thermometerSetzen(IDthermWohnzimmer, modus);
                setState(IDthermWohnzimmer,15);
            
                // Haustuere verriegeln
                setState(IDKeyMatic, false);
            
                // Boilder Kueche aus
                setState(IDboiler, false);
                setState(ProgrSchalterBoiler, false);
            
                // Anwesend einschalten
                setState(IDanwesend, false);
            
                // Staubsauger AUS (0 = EIN, 1 = AUS)
                setState(IDstaubsauger, 1);
            
                // Springbrunnen AUS
                setState(IDspringbrunnenGanz, false);
            
                 // HeizStati
                setState(IDheizStatusBuegelEltern, 0);
                setState(IDheizStatusBuero, 0);
                setState(IDheizStatusBar, 0);
                setState(IDheizStatusBritta, 0);
                setState(IDheizStatusJoerg, 0);
                setState(IDheizStatusGaeste, 0);
            
                // HeizHauptschalter AUS
                setState(IDheizHauptUnten, false);
                setState(IDheizHauptOben, false);
            
                // Klima AUS
                setState(IDklimaBuero, false);
                setState(IDklimaSchaf, false);
            
                // TechniSat aus
                setState(IDtechiSat, false);
            
                } // Ende IF Urlaub EIN und Sommer AUS, 
            
                // *********************************************
                // ausführen nur, wenn Urlaub EIN und Sommer EIN
                // *********************************************
            
            if(getState(urlaub).val == 1 && getState(sommer).val == 1) {
            
                // HeizHauptschalter AUS
                setState(IDheizHauptUnten, false);
                setState(IDheizHauptOben, false);
            
                // Boilder Kueche aus
                setState(IDboiler, false);
                setState(ProgrSchalterBoiler, false);
            
                 // Anwesend einschalten
                setState(IDanwesend, false);
            
                // Klima AUS
                setState(IDklimaBuero, false);
                setState(IDklimaSchaf, false);
            
                // Staubsauger AUS (0 = EIN, 1 = AUS)
                setState(IDstaubsauger, 1);
            
                // Springbrunnen AUS
                setState(IDspringbrunnenGanz, false);
            
                // Haustuere verriegeln
                setState(IDKeyMatic, false);
            
                // TechniSat aus
                setState(IDtechiSat, false);
            
                } // Ende IF Urlaub EIN und Sommer EIN
            
            
            
            
            }); //Ende ON
            
            
            1. Und dieses schaltet in Abhängigkeit davon, ob der Heizungshauptschalter ein- oder ausgeschaltet ist, den Boiler ein und aus:
            // ###########################################
            //            Deklarationen
            // ###########################################
            
            const IDAnwesend = 'hm-rega.0.39533'/*Anwesend*/;
            const IDBoiler = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
            const IDUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
            const IDHeizungHptUnten = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/
            
            // Datenpunkt erstellen (für andere Scripte);
            createState('BenutzerVariablen.BoilerProgrammSchalter', '', {
                name: 'Boiler AnAus',
                type: 'boolean'
            });
            
            // ProgrSchalter standardmaessig auf true (damit Zeitsteuerung aktiv)
                const ProgrSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
                setState(ProgrSchalter, true);
            
            
            
            // ##################################
            //              Programm
            // ##################################
            
            on({id: IDAnwesend, change: 'ne'}, function () {
                    
                // wenn ABwesend und Urlaub AUS (nur prüfen) , dann Boiler AUS und Zeitsteuerung Boiler AUS;
                if(getState(IDUrlaub).val == 0 && getState(IDAnwesend).val == false && getState(IDHeizungHptUnten).val == true) {    
                setState(IDBoiler,false);
                setState(ProgrSchalter, false);
                };
            
                // wenn ANwesend und Urlaub AUS (nur prüfen) und Boiler Keller ist AUS, dann Boiler EIN Zeitsteuerung Boiler EIN;
                if(getState(IDUrlaub).val == 0  && getState(IDAnwesend).val == true && getState(IDHeizungHptUnten).val == false) {    
                setState(IDBoiler,true);
                setState(ProgrSchalter, true);
                };
            });
            
            1. Zusätzlich gibt es die "Frostschutzüberwachung", die den HeizungsHauptschalter betätigt, wenn es kälter wird als 14 Grad:
            // **************** DEKLARATIONEN **********************
            const IDBarKellerThemp = 'hm-rpc.0.JEQ0553882.1.TEMPERATURE'/*Thermostat Bar Keller 0 TEMPERATURE*/;
            const IDUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
            const IDSommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
            const IDHeizHptKeller = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/;
            var ein = getState(IDHeizHptKeller).val;
            // *****************************************************
            
            // **************** Programm ***************************
            on(IDBarKellerThemp, function (data) {
                if(!getState(IDSommer).val && getState(IDUrlaub).val) {
                    if(data.state.val < 14) ein = true;
                    else if(data.state.val >= 15) ein = false; // Hysterese 1 K
                    if(ein != getState(IDHeizHptKeller).val) setState(IDHeizHptKeller, ein); // Duty cycle!
                }
            });
            
            

            Jetzt war ich in Urlaub. Und leider schaltete des Boiler Programm (1) offenbar den Boiler ein und aus, obwohl ich "Urlaub" gesetzt hatte. Ich tippe darauf, das das passiert, wenn der Frostschutz den HeizungsHauptschalter betätigt.

            Jetzt sehe ich den Wald vor lauter Bäumen nicht mehr. Ziel ist es jedenfalls, dass dass Programm der Zeitsteuerung (1) nur läuft, wenn ich nicht im Urlaub bin.

            Konst Du mal draufschauen?

            paul53P 2 Replies Last reply
            0
            • S skorpil

              @paul53 ich habe wieder ein "unlösbares" Problem und bitte um Hilfe:

              Ich habe drei Programme:

              1. Dieses schaltet den Boiler abends um 22:30 aus und morgens um 06:30 eingeschaltet werden
              // ###########################################
              //            Deklarationen
              // ###########################################
              
              const IDZwBoilerKueche = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
              const BoilerSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
              
              // ##################################
              //              Programm
              // ##################################
              
                  schedule({hour: 6, minute: 30}, function () {
                  //Wird um 06:30 eingeschaltet, wenn der Boilerschalter true;
                  if(getState(BoilerSchalter).val == true) { 
                  setState(IDZwBoilerKueche, true);
                  };
                  });
              
                  schedule({hour: 22, minute: 30}, function () {
                  //Wird um 22:30 AUSgeschaltet, wenn der Boilerschalter true;
                  if(getState(BoilerSchalter).val == true) { 
                  setState(IDZwBoilerKueche, false);
                  };
                  });
              
              1. Dieses Programm schaltet die Geräte im Urlaub bzw. wenn Sommer oder Winter ist, wobei nur der Boiler von Interesse ist, denn der schaltet nicht richtig (erkläre ich später):
              // ###########################################
              //         Urlaub und Sommer Schaltungen
              //                Deklarationen
              // ###########################################
              
              const urlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
              const sommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
              
              const IDthermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
              const IDthermDieleTreppenhaus = 'hm-rpc.0.JEQ0552520.2.SETPOINT'/*Thermostat Diele Treppenhaus 1 SETPOINT*/;
              const IDthermEsszimmer = 'hm-rpc.0.JEQ0553158.2.SETPOINT'/*Thermostat Esszimmer 1 SETPOINT*/;
              const IDthermWohnzimmer = 'hm-rpc.0.JEQ0552318.2.SETPOINT'/*Thermostat Wohnzimmer 1 SETPOINT*/;
              
              const IDanwesend = 'hm-rega.0.39533'/*Anwesend*/;
              const IDstaubsauger = 'hm-rega.0.29769'/*Staubsauger ein/aus*/;
              const IDspringbrunnenGanz = 'hm-rega.0.55701'/*SpringBruGanzEinAus*/;
              
              const IDheizStatusBuegelEltern = 'hm-rega.0.13752'/*Heizstatus (Buegel Eltern ges )*/;
              const IDheizStatusBuero = 'hm-rega.0.14236'/*Heizstatus (Buero)*/;
              const IDheizStatusBar = 'hm-rega.0.23436'/*Heizstatus (BAR)*/;
              const IDheizStatusBritta = 'hm-rega.0.14235'/*Heizstatus (Britta)*/;
              const IDheizStatusJoerg = 'hm-rega.0.4107'/*Heizstatus (JOERG)*/;
              const IDheizStatusGaeste = 'hm-rega.0.3388'/*Heizstatus (Gaestetrakt)*/;
              
              const IDheizHauptOben = 'hm-rpc.0.SEQ3263796.1.STATE'/*HeizungsHauptschalter OBEN:1 STATE*/;
              const IDheizHauptUnten = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/;
              
              const IDklimaBuero = 'hm-rpc.0.OEQ1975895.1.STATE'/*Zw Stkr KlimaBuero:1 STATE*/;
              const IDklimaSchaf = 'hm-rpc.0.OEQ1975873.1.STATE'/*ZW Stkr KlimaSchlafzimer:1 STATE*/;
              
              const IDKeyMatic = 'hm-rpc.0.JEQ0466522.1.STATE'/*KeyMatic Haustuere neu STATE*/;
              
              const IDboiler = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
              const ProgrSchalterBoiler = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
              const IDtechiSat = 'hm-rpc.2.CUX2801002.12.STATE'/*TerchniSat Tasmota 184 (HM-LC-Sw1-Pl CUX2801002:12) STATE*/;
              
              // ###########################################
              //            Programm
              // ###########################################
              
                  // *********************************************
                  // ausführen nur, wenn Urlaub AUS und Sommer AUS
                  // *********************************************
              
              on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP
                 if(getState(urlaub).val == 0 && getState(sommer).val == 0) {
              
                  // Variable zur Einstellung des Thermometers
                  var modus = 1; // 1 = AUTO; 2 = CEN
              
                  // Modus des Thermometers via global function thermometerSetzen u. Temperatur einstellen
                  // Kueche
                  thermometerSetzen(IDthermKueche, modus);
                  setState(IDthermKueche,22);
              
                  // DieleTreppenhaus
                  thermometerSetzen(IDthermDieleTreppenhaus, modus);
                  setState(IDthermDieleTreppenhaus,19);
              
                  // Esszimmer
                  thermometerSetzen(IDthermEsszimmer, modus);
                  setState(IDthermEsszimmer,22);
              
                  // Wohnzimmer
                  thermometerSetzen(IDthermWohnzimmer, modus);
                  setState(IDthermWohnzimmer,22);
              
                  // Anwesend einschalten
                  setState(IDanwesend, true);
              
                  // Staubsauger ein (0 = ein)
                  setState(IDstaubsauger, 0);
              
                  // Springbrunnen ein
                  setState(IDspringbrunnenGanz, true);
              
                  // HeizStati
                  setState(IDheizStatusBuegelEltern, 1);
                  setState(IDheizStatusBuero, 1);
                  setState(IDheizStatusBar, 0);
                  setState(IDheizStatusBritta, 0);
                  setState(IDheizStatusJoerg, 0);
                  setState(IDheizStatusGaeste, 0);
              
                  // HeizHauptschalter AUS
                  setState(IDheizHauptUnten, true);
                  setState(IDheizHauptOben, true);
              
                  // Klima AUS
                  setState(IDklimaBuero, false);
                  setState(IDklimaSchaf, false);
              
                  // TechniSat ein
                  setState(IDtechiSat, true);
                  
                 } // Ende IF Urlaub AUS - Sommer AUS
              
                  // *********************************************
                  // ausführen nur, wenn Urlaub AUS und Sommer EIN
                  // *********************************************
              
              if(getState(urlaub).val == 0 && getState(sommer).val == 1) {
              
                setState(IDheizHauptOben, true);
                setState(IDheizHauptUnten, false);
              
                // Anwesend einschalten
                  setState(IDanwesend, true);
              
                // Staubsauger ein (0 = ein)
                  setState(IDstaubsauger, 0);
              
                // Springbrunnen ein
                  setState(IDspringbrunnenGanz, true); 
                  
                // Klima AUS
                  // setState(IDklimaBuero, true);
                  // setState(IDklimaSchaf, true);
              
                  // TechniSat ein
                  setState(IDtechiSat, true);
              
                  
                  } // Ende IF Urlaub AUS - Sommer ein
              
              
              
                  // *********************************************
                  // ausführen nur, wenn Urlaub EIN und Sommer AUS
                  // *********************************************
              
              if(getState(urlaub).val == 1 && getState(sommer).val == 0) {
              
              // Variable zur Einstellung des Thermometers
                  var modus = 2; // 1 = AUTO; 2 = CEN
              
                  // Modus des Thermometers via global function thermometerSetzen u. Temperatur einstellen
                  // Kueche
                  thermometerSetzen(IDthermKueche, modus);
                  setState(IDthermKueche,15);
              
                  // DieleTreppenhaus
                  thermometerSetzen(IDthermDieleTreppenhaus, modus);
                  setState(IDthermDieleTreppenhaus,15);
              
                  // Esszimmer
                  thermometerSetzen(IDthermEsszimmer, modus);
                  setState(IDthermEsszimmer,15);
              
                  // Wohnzimmer
                  thermometerSetzen(IDthermWohnzimmer, modus);
                  setState(IDthermWohnzimmer,15);
              
                  // Haustuere verriegeln
                  setState(IDKeyMatic, false);
              
                  // Boilder Kueche aus
                  setState(IDboiler, false);
                  setState(ProgrSchalterBoiler, false);
              
                  // Anwesend einschalten
                  setState(IDanwesend, false);
              
                  // Staubsauger AUS (0 = EIN, 1 = AUS)
                  setState(IDstaubsauger, 1);
              
                  // Springbrunnen AUS
                  setState(IDspringbrunnenGanz, false);
              
                   // HeizStati
                  setState(IDheizStatusBuegelEltern, 0);
                  setState(IDheizStatusBuero, 0);
                  setState(IDheizStatusBar, 0);
                  setState(IDheizStatusBritta, 0);
                  setState(IDheizStatusJoerg, 0);
                  setState(IDheizStatusGaeste, 0);
              
                  // HeizHauptschalter AUS
                  setState(IDheizHauptUnten, false);
                  setState(IDheizHauptOben, false);
              
                  // Klima AUS
                  setState(IDklimaBuero, false);
                  setState(IDklimaSchaf, false);
              
                  // TechniSat aus
                  setState(IDtechiSat, false);
              
                  } // Ende IF Urlaub EIN und Sommer AUS, 
              
                  // *********************************************
                  // ausführen nur, wenn Urlaub EIN und Sommer EIN
                  // *********************************************
              
              if(getState(urlaub).val == 1 && getState(sommer).val == 1) {
              
                  // HeizHauptschalter AUS
                  setState(IDheizHauptUnten, false);
                  setState(IDheizHauptOben, false);
              
                  // Boilder Kueche aus
                  setState(IDboiler, false);
                  setState(ProgrSchalterBoiler, false);
              
                   // Anwesend einschalten
                  setState(IDanwesend, false);
              
                  // Klima AUS
                  setState(IDklimaBuero, false);
                  setState(IDklimaSchaf, false);
              
                  // Staubsauger AUS (0 = EIN, 1 = AUS)
                  setState(IDstaubsauger, 1);
              
                  // Springbrunnen AUS
                  setState(IDspringbrunnenGanz, false);
              
                  // Haustuere verriegeln
                  setState(IDKeyMatic, false);
              
                  // TechniSat aus
                  setState(IDtechiSat, false);
              
                  } // Ende IF Urlaub EIN und Sommer EIN
              
              
              
              
              }); //Ende ON
              
              
              1. Und dieses schaltet in Abhängigkeit davon, ob der Heizungshauptschalter ein- oder ausgeschaltet ist, den Boiler ein und aus:
              // ###########################################
              //            Deklarationen
              // ###########################################
              
              const IDAnwesend = 'hm-rega.0.39533'/*Anwesend*/;
              const IDBoiler = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
              const IDUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
              const IDHeizungHptUnten = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/
              
              // Datenpunkt erstellen (für andere Scripte);
              createState('BenutzerVariablen.BoilerProgrammSchalter', '', {
                  name: 'Boiler AnAus',
                  type: 'boolean'
              });
              
              // ProgrSchalter standardmaessig auf true (damit Zeitsteuerung aktiv)
                  const ProgrSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
                  setState(ProgrSchalter, true);
              
              
              
              // ##################################
              //              Programm
              // ##################################
              
              on({id: IDAnwesend, change: 'ne'}, function () {
                      
                  // wenn ABwesend und Urlaub AUS (nur prüfen) , dann Boiler AUS und Zeitsteuerung Boiler AUS;
                  if(getState(IDUrlaub).val == 0 && getState(IDAnwesend).val == false && getState(IDHeizungHptUnten).val == true) {    
                  setState(IDBoiler,false);
                  setState(ProgrSchalter, false);
                  };
              
                  // wenn ANwesend und Urlaub AUS (nur prüfen) und Boiler Keller ist AUS, dann Boiler EIN Zeitsteuerung Boiler EIN;
                  if(getState(IDUrlaub).val == 0  && getState(IDAnwesend).val == true && getState(IDHeizungHptUnten).val == false) {    
                  setState(IDBoiler,true);
                  setState(ProgrSchalter, true);
                  };
              });
              
              1. Zusätzlich gibt es die "Frostschutzüberwachung", die den HeizungsHauptschalter betätigt, wenn es kälter wird als 14 Grad:
              // **************** DEKLARATIONEN **********************
              const IDBarKellerThemp = 'hm-rpc.0.JEQ0553882.1.TEMPERATURE'/*Thermostat Bar Keller 0 TEMPERATURE*/;
              const IDUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
              const IDSommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
              const IDHeizHptKeller = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/;
              var ein = getState(IDHeizHptKeller).val;
              // *****************************************************
              
              // **************** Programm ***************************
              on(IDBarKellerThemp, function (data) {
                  if(!getState(IDSommer).val && getState(IDUrlaub).val) {
                      if(data.state.val < 14) ein = true;
                      else if(data.state.val >= 15) ein = false; // Hysterese 1 K
                      if(ein != getState(IDHeizHptKeller).val) setState(IDHeizHptKeller, ein); // Duty cycle!
                  }
              });
              
              

              Jetzt war ich in Urlaub. Und leider schaltete des Boiler Programm (1) offenbar den Boiler ein und aus, obwohl ich "Urlaub" gesetzt hatte. Ich tippe darauf, das das passiert, wenn der Frostschutz den HeizungsHauptschalter betätigt.

              Jetzt sehe ich den Wald vor lauter Bäumen nicht mehr. Ziel ist es jedenfalls, dass dass Programm der Zeitsteuerung (1) nur läuft, wenn ich nicht im Urlaub bin.

              Konst Du mal draufschauen?

              paul53P Offline
              paul53P Offline
              paul53
              wrote on last edited by paul53
              #68

              @skorpil sagte: draufschauen?

              Man sollte einen Datenpunkt nur in einem Skript schreiben und in diesem Skript alle Abhängigkeiten realisieren.
              Welche Funktion(en) hat der DP "javascript.0.BenutzerVariablen.BoilerProgrammSchalter"?

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              1 Reply Last reply
              0
              • S skorpil

                @paul53 ich habe wieder ein "unlösbares" Problem und bitte um Hilfe:

                Ich habe drei Programme:

                1. Dieses schaltet den Boiler abends um 22:30 aus und morgens um 06:30 eingeschaltet werden
                // ###########################################
                //            Deklarationen
                // ###########################################
                
                const IDZwBoilerKueche = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
                const BoilerSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
                
                // ##################################
                //              Programm
                // ##################################
                
                    schedule({hour: 6, minute: 30}, function () {
                    //Wird um 06:30 eingeschaltet, wenn der Boilerschalter true;
                    if(getState(BoilerSchalter).val == true) { 
                    setState(IDZwBoilerKueche, true);
                    };
                    });
                
                    schedule({hour: 22, minute: 30}, function () {
                    //Wird um 22:30 AUSgeschaltet, wenn der Boilerschalter true;
                    if(getState(BoilerSchalter).val == true) { 
                    setState(IDZwBoilerKueche, false);
                    };
                    });
                
                1. Dieses Programm schaltet die Geräte im Urlaub bzw. wenn Sommer oder Winter ist, wobei nur der Boiler von Interesse ist, denn der schaltet nicht richtig (erkläre ich später):
                // ###########################################
                //         Urlaub und Sommer Schaltungen
                //                Deklarationen
                // ###########################################
                
                const urlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
                const sommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
                
                const IDthermKueche = 'hm-rpc.0.JEQ0553018.2.SETPOINT'/*Thermostat Kueche 1 SETPOINT*/;
                const IDthermDieleTreppenhaus = 'hm-rpc.0.JEQ0552520.2.SETPOINT'/*Thermostat Diele Treppenhaus 1 SETPOINT*/;
                const IDthermEsszimmer = 'hm-rpc.0.JEQ0553158.2.SETPOINT'/*Thermostat Esszimmer 1 SETPOINT*/;
                const IDthermWohnzimmer = 'hm-rpc.0.JEQ0552318.2.SETPOINT'/*Thermostat Wohnzimmer 1 SETPOINT*/;
                
                const IDanwesend = 'hm-rega.0.39533'/*Anwesend*/;
                const IDstaubsauger = 'hm-rega.0.29769'/*Staubsauger ein/aus*/;
                const IDspringbrunnenGanz = 'hm-rega.0.55701'/*SpringBruGanzEinAus*/;
                
                const IDheizStatusBuegelEltern = 'hm-rega.0.13752'/*Heizstatus (Buegel Eltern ges )*/;
                const IDheizStatusBuero = 'hm-rega.0.14236'/*Heizstatus (Buero)*/;
                const IDheizStatusBar = 'hm-rega.0.23436'/*Heizstatus (BAR)*/;
                const IDheizStatusBritta = 'hm-rega.0.14235'/*Heizstatus (Britta)*/;
                const IDheizStatusJoerg = 'hm-rega.0.4107'/*Heizstatus (JOERG)*/;
                const IDheizStatusGaeste = 'hm-rega.0.3388'/*Heizstatus (Gaestetrakt)*/;
                
                const IDheizHauptOben = 'hm-rpc.0.SEQ3263796.1.STATE'/*HeizungsHauptschalter OBEN:1 STATE*/;
                const IDheizHauptUnten = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/;
                
                const IDklimaBuero = 'hm-rpc.0.OEQ1975895.1.STATE'/*Zw Stkr KlimaBuero:1 STATE*/;
                const IDklimaSchaf = 'hm-rpc.0.OEQ1975873.1.STATE'/*ZW Stkr KlimaSchlafzimer:1 STATE*/;
                
                const IDKeyMatic = 'hm-rpc.0.JEQ0466522.1.STATE'/*KeyMatic Haustuere neu STATE*/;
                
                const IDboiler = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
                const ProgrSchalterBoiler = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
                const IDtechiSat = 'hm-rpc.2.CUX2801002.12.STATE'/*TerchniSat Tasmota 184 (HM-LC-Sw1-Pl CUX2801002:12) STATE*/;
                
                // ###########################################
                //            Programm
                // ###########################################
                
                    // *********************************************
                    // ausführen nur, wenn Urlaub AUS und Sommer AUS
                    // *********************************************
                
                on([urlaub, sommer], function () { // triggert bei Wertänderung eines DP
                   if(getState(urlaub).val == 0 && getState(sommer).val == 0) {
                
                    // Variable zur Einstellung des Thermometers
                    var modus = 1; // 1 = AUTO; 2 = CEN
                
                    // Modus des Thermometers via global function thermometerSetzen u. Temperatur einstellen
                    // Kueche
                    thermometerSetzen(IDthermKueche, modus);
                    setState(IDthermKueche,22);
                
                    // DieleTreppenhaus
                    thermometerSetzen(IDthermDieleTreppenhaus, modus);
                    setState(IDthermDieleTreppenhaus,19);
                
                    // Esszimmer
                    thermometerSetzen(IDthermEsszimmer, modus);
                    setState(IDthermEsszimmer,22);
                
                    // Wohnzimmer
                    thermometerSetzen(IDthermWohnzimmer, modus);
                    setState(IDthermWohnzimmer,22);
                
                    // Anwesend einschalten
                    setState(IDanwesend, true);
                
                    // Staubsauger ein (0 = ein)
                    setState(IDstaubsauger, 0);
                
                    // Springbrunnen ein
                    setState(IDspringbrunnenGanz, true);
                
                    // HeizStati
                    setState(IDheizStatusBuegelEltern, 1);
                    setState(IDheizStatusBuero, 1);
                    setState(IDheizStatusBar, 0);
                    setState(IDheizStatusBritta, 0);
                    setState(IDheizStatusJoerg, 0);
                    setState(IDheizStatusGaeste, 0);
                
                    // HeizHauptschalter AUS
                    setState(IDheizHauptUnten, true);
                    setState(IDheizHauptOben, true);
                
                    // Klima AUS
                    setState(IDklimaBuero, false);
                    setState(IDklimaSchaf, false);
                
                    // TechniSat ein
                    setState(IDtechiSat, true);
                    
                   } // Ende IF Urlaub AUS - Sommer AUS
                
                    // *********************************************
                    // ausführen nur, wenn Urlaub AUS und Sommer EIN
                    // *********************************************
                
                if(getState(urlaub).val == 0 && getState(sommer).val == 1) {
                
                  setState(IDheizHauptOben, true);
                  setState(IDheizHauptUnten, false);
                
                  // Anwesend einschalten
                    setState(IDanwesend, true);
                
                  // Staubsauger ein (0 = ein)
                    setState(IDstaubsauger, 0);
                
                  // Springbrunnen ein
                    setState(IDspringbrunnenGanz, true); 
                    
                  // Klima AUS
                    // setState(IDklimaBuero, true);
                    // setState(IDklimaSchaf, true);
                
                    // TechniSat ein
                    setState(IDtechiSat, true);
                
                    
                    } // Ende IF Urlaub AUS - Sommer ein
                
                
                
                    // *********************************************
                    // ausführen nur, wenn Urlaub EIN und Sommer AUS
                    // *********************************************
                
                if(getState(urlaub).val == 1 && getState(sommer).val == 0) {
                
                // Variable zur Einstellung des Thermometers
                    var modus = 2; // 1 = AUTO; 2 = CEN
                
                    // Modus des Thermometers via global function thermometerSetzen u. Temperatur einstellen
                    // Kueche
                    thermometerSetzen(IDthermKueche, modus);
                    setState(IDthermKueche,15);
                
                    // DieleTreppenhaus
                    thermometerSetzen(IDthermDieleTreppenhaus, modus);
                    setState(IDthermDieleTreppenhaus,15);
                
                    // Esszimmer
                    thermometerSetzen(IDthermEsszimmer, modus);
                    setState(IDthermEsszimmer,15);
                
                    // Wohnzimmer
                    thermometerSetzen(IDthermWohnzimmer, modus);
                    setState(IDthermWohnzimmer,15);
                
                    // Haustuere verriegeln
                    setState(IDKeyMatic, false);
                
                    // Boilder Kueche aus
                    setState(IDboiler, false);
                    setState(ProgrSchalterBoiler, false);
                
                    // Anwesend einschalten
                    setState(IDanwesend, false);
                
                    // Staubsauger AUS (0 = EIN, 1 = AUS)
                    setState(IDstaubsauger, 1);
                
                    // Springbrunnen AUS
                    setState(IDspringbrunnenGanz, false);
                
                     // HeizStati
                    setState(IDheizStatusBuegelEltern, 0);
                    setState(IDheizStatusBuero, 0);
                    setState(IDheizStatusBar, 0);
                    setState(IDheizStatusBritta, 0);
                    setState(IDheizStatusJoerg, 0);
                    setState(IDheizStatusGaeste, 0);
                
                    // HeizHauptschalter AUS
                    setState(IDheizHauptUnten, false);
                    setState(IDheizHauptOben, false);
                
                    // Klima AUS
                    setState(IDklimaBuero, false);
                    setState(IDklimaSchaf, false);
                
                    // TechniSat aus
                    setState(IDtechiSat, false);
                
                    } // Ende IF Urlaub EIN und Sommer AUS, 
                
                    // *********************************************
                    // ausführen nur, wenn Urlaub EIN und Sommer EIN
                    // *********************************************
                
                if(getState(urlaub).val == 1 && getState(sommer).val == 1) {
                
                    // HeizHauptschalter AUS
                    setState(IDheizHauptUnten, false);
                    setState(IDheizHauptOben, false);
                
                    // Boilder Kueche aus
                    setState(IDboiler, false);
                    setState(ProgrSchalterBoiler, false);
                
                     // Anwesend einschalten
                    setState(IDanwesend, false);
                
                    // Klima AUS
                    setState(IDklimaBuero, false);
                    setState(IDklimaSchaf, false);
                
                    // Staubsauger AUS (0 = EIN, 1 = AUS)
                    setState(IDstaubsauger, 1);
                
                    // Springbrunnen AUS
                    setState(IDspringbrunnenGanz, false);
                
                    // Haustuere verriegeln
                    setState(IDKeyMatic, false);
                
                    // TechniSat aus
                    setState(IDtechiSat, false);
                
                    } // Ende IF Urlaub EIN und Sommer EIN
                
                
                
                
                }); //Ende ON
                
                
                1. Und dieses schaltet in Abhängigkeit davon, ob der Heizungshauptschalter ein- oder ausgeschaltet ist, den Boiler ein und aus:
                // ###########################################
                //            Deklarationen
                // ###########################################
                
                const IDAnwesend = 'hm-rega.0.39533'/*Anwesend*/;
                const IDBoiler = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
                const IDUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
                const IDHeizungHptUnten = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/
                
                // Datenpunkt erstellen (für andere Scripte);
                createState('BenutzerVariablen.BoilerProgrammSchalter', '', {
                    name: 'Boiler AnAus',
                    type: 'boolean'
                });
                
                // ProgrSchalter standardmaessig auf true (damit Zeitsteuerung aktiv)
                    const ProgrSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
                    setState(ProgrSchalter, true);
                
                
                
                // ##################################
                //              Programm
                // ##################################
                
                on({id: IDAnwesend, change: 'ne'}, function () {
                        
                    // wenn ABwesend und Urlaub AUS (nur prüfen) , dann Boiler AUS und Zeitsteuerung Boiler AUS;
                    if(getState(IDUrlaub).val == 0 && getState(IDAnwesend).val == false && getState(IDHeizungHptUnten).val == true) {    
                    setState(IDBoiler,false);
                    setState(ProgrSchalter, false);
                    };
                
                    // wenn ANwesend und Urlaub AUS (nur prüfen) und Boiler Keller ist AUS, dann Boiler EIN Zeitsteuerung Boiler EIN;
                    if(getState(IDUrlaub).val == 0  && getState(IDAnwesend).val == true && getState(IDHeizungHptUnten).val == false) {    
                    setState(IDBoiler,true);
                    setState(ProgrSchalter, true);
                    };
                });
                
                1. Zusätzlich gibt es die "Frostschutzüberwachung", die den HeizungsHauptschalter betätigt, wenn es kälter wird als 14 Grad:
                // **************** DEKLARATIONEN **********************
                const IDBarKellerThemp = 'hm-rpc.0.JEQ0553882.1.TEMPERATURE'/*Thermostat Bar Keller 0 TEMPERATURE*/;
                const IDUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
                const IDSommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
                const IDHeizHptKeller = 'hm-rpc.0.JEQ0097730.1.STATE'/*HeizungsHauptschalter:1 STATE*/;
                var ein = getState(IDHeizHptKeller).val;
                // *****************************************************
                
                // **************** Programm ***************************
                on(IDBarKellerThemp, function (data) {
                    if(!getState(IDSommer).val && getState(IDUrlaub).val) {
                        if(data.state.val < 14) ein = true;
                        else if(data.state.val >= 15) ein = false; // Hysterese 1 K
                        if(ein != getState(IDHeizHptKeller).val) setState(IDHeizHptKeller, ein); // Duty cycle!
                    }
                });
                
                

                Jetzt war ich in Urlaub. Und leider schaltete des Boiler Programm (1) offenbar den Boiler ein und aus, obwohl ich "Urlaub" gesetzt hatte. Ich tippe darauf, das das passiert, wenn der Frostschutz den HeizungsHauptschalter betätigt.

                Jetzt sehe ich den Wald vor lauter Bäumen nicht mehr. Ziel ist es jedenfalls, dass dass Programm der Zeitsteuerung (1) nur läuft, wenn ich nicht im Urlaub bin.

                Konst Du mal draufschauen?

                paul53P Offline
                paul53P Offline
                paul53
                wrote on last edited by paul53
                #69

                @skorpil sagte: Dieses schaltet den Boiler abends um 22:30 aus und morgens um 06:30 eingeschaltet werden

                Ich würde dieses Skript so erweitern, dass nur noch in diesem Skript der Boiler geschaltet wird:

                // ###########################################
                //            Deklarationen
                // ###########################################
                const IDZwBoilerKueche = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
                const idBoilerSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
                
                // ##################################
                //              Programm
                // ##################################
                var BoilerSchalter = getState(idBoilerSchalter).val;
                
                on(idBoilerSchalter, function(dp) {
                    BoilerSchalter = dp.state.val;
                    let ein = BoilerSchalter && compareTime('6:30', '22:30', 'between');
                    if(ein != getState(IDZwBoilerKueche).val) setState(IDZwBoilerKueche, ein);
                });
                
                schedule({hour: 6, minute: 30}, function () {
                    //Wird um 06:30 eingeschaltet, wenn der Boilerschalter true;
                    if(BoilerSchalter) setState(IDZwBoilerKueche, true);
                });
                 
                schedule({hour: 22, minute: 30}, function () {
                    //Wird um 22:30 AUSgeschaltet, wenn der Boilerschalter true;
                    if(BoilerSchalter) setState(IDZwBoilerKueche, false);
                });
                

                Die weiteren Abhängigkeiten wirken nur noch auf den "Boilerschalter".

                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                S 1 Reply Last reply
                0
                • paul53P paul53

                  @skorpil sagte: Dieses schaltet den Boiler abends um 22:30 aus und morgens um 06:30 eingeschaltet werden

                  Ich würde dieses Skript so erweitern, dass nur noch in diesem Skript der Boiler geschaltet wird:

                  // ###########################################
                  //            Deklarationen
                  // ###########################################
                  const IDZwBoilerKueche = 'hm-rpc.0.LEQ0197823.1.STATE'/*Zw -Stecker Küche:1 STATE*/;
                  const idBoilerSchalter = 'javascript.0.BenutzerVariablen.BoilerProgrammSchalter'/*Boiler AnAus*/;
                  
                  // ##################################
                  //              Programm
                  // ##################################
                  var BoilerSchalter = getState(idBoilerSchalter).val;
                  
                  on(idBoilerSchalter, function(dp) {
                      BoilerSchalter = dp.state.val;
                      let ein = BoilerSchalter && compareTime('6:30', '22:30', 'between');
                      if(ein != getState(IDZwBoilerKueche).val) setState(IDZwBoilerKueche, ein);
                  });
                  
                  schedule({hour: 6, minute: 30}, function () {
                      //Wird um 06:30 eingeschaltet, wenn der Boilerschalter true;
                      if(BoilerSchalter) setState(IDZwBoilerKueche, true);
                  });
                   
                  schedule({hour: 22, minute: 30}, function () {
                      //Wird um 22:30 AUSgeschaltet, wenn der Boilerschalter true;
                      if(BoilerSchalter) setState(IDZwBoilerKueche, false);
                  });
                  

                  Die weiteren Abhängigkeiten wirken nur noch auf den "Boilerschalter".

                  S Offline
                  S Offline
                  skorpil
                  wrote on last edited by
                  #70

                  @paul53 daaaanke. Das war der richtige Tip.

                  1 Reply Last reply
                  0
                  • S Offline
                    S Offline
                    skorpil
                    wrote on last edited by
                    #71

                    @paul53 jetzt haben wir wieder den Salat. Ich benötighe Programmierhilfe bei der Umstellung von request auf httpGet.

                    Ich habe folgendes, beispielhafte Script (und noch einige mehr), die alle request nutzen.

                    // *****************************************
                    //              mp3 abspielen via AAPI
                    //******************************************
                    
                    // *****************************************
                    //               Definitionen
                    // *****************************************
                    
                    // Definition APIclip Wohnzimmer;
                    const idApiClipTerrasse = "http://192.168.X.XXX:5005/Terrasse/clip/Rolladen.mp3/50";
                    const idUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
                    
                    
                    var AufZu = 'hm-rega.0.1792'/*RollAufZu Logik*/;  
                    
                    // Ansage spielen
                    on({id: AufZu, change: 'ne', val: true}, function (data) {
                    if(getState(idUrlaub).val == 0) {
                    try {
                        require("request")(idApiClipTerrasse).on("error", function (e) {console.error(e);});
                            } catch (e) { console.error(e); };
                    };
                    });
                    

                    Der eigentliche Aufruf erfolgt in allen Scripten mit einem Codeschnipsel (den ich mir vor langer Zeit irgendwo heruntergeladen habe):

                    try {
                        require("request")(idApiClipTerrasse).on("error", function (e) {console.error(e);});
                            } catch (e) { console.error(e); };
                    

                    wobei dann jeweils idApiClipTerrasse entsprechend auf eine andere Variable geändert wird.

                    Wie muß der jetzt geändert werden in httpGet? Ich bin mal wieder zu dumm. Danke für die Hilfe.

                    paul53P 1 Reply Last reply
                    0
                    • S skorpil

                      @paul53 jetzt haben wir wieder den Salat. Ich benötighe Programmierhilfe bei der Umstellung von request auf httpGet.

                      Ich habe folgendes, beispielhafte Script (und noch einige mehr), die alle request nutzen.

                      // *****************************************
                      //              mp3 abspielen via AAPI
                      //******************************************
                      
                      // *****************************************
                      //               Definitionen
                      // *****************************************
                      
                      // Definition APIclip Wohnzimmer;
                      const idApiClipTerrasse = "http://192.168.X.XXX:5005/Terrasse/clip/Rolladen.mp3/50";
                      const idUrlaub = 'hm-rega.0.8359'/*URLAUB Hzg  Wohnb  ALLES (Var )*/;
                      
                      
                      var AufZu = 'hm-rega.0.1792'/*RollAufZu Logik*/;  
                      
                      // Ansage spielen
                      on({id: AufZu, change: 'ne', val: true}, function (data) {
                      if(getState(idUrlaub).val == 0) {
                      try {
                          require("request")(idApiClipTerrasse).on("error", function (e) {console.error(e);});
                              } catch (e) { console.error(e); };
                      };
                      });
                      

                      Der eigentliche Aufruf erfolgt in allen Scripten mit einem Codeschnipsel (den ich mir vor langer Zeit irgendwo heruntergeladen habe):

                      try {
                          require("request")(idApiClipTerrasse).on("error", function (e) {console.error(e);});
                              } catch (e) { console.error(e); };
                      

                      wobei dann jeweils idApiClipTerrasse entsprechend auf eine andere Variable geändert wird.

                      Wie muß der jetzt geändert werden in httpGet? Ich bin mal wieder zu dumm. Danke für die Hilfe.

                      paul53P Offline
                      paul53P Offline
                      paul53
                      wrote on last edited by
                      #72

                      @skorpil sagte: Der eigentliche Aufruf erfolgt in allen Scripten mit einem Codeschnipsel (den ich mir vor langer Zeit irgendwo heruntergeladen habe):

                      Das ist der Javascript-Code des request-Blockes (Blockly).

                      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                      Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                      S 1 Reply Last reply
                      0
                      • paul53P paul53

                        @skorpil sagte: Der eigentliche Aufruf erfolgt in allen Scripten mit einem Codeschnipsel (den ich mir vor langer Zeit irgendwo heruntergeladen habe):

                        Das ist der Javascript-Code des request-Blockes (Blockly).

                        S Offline
                        S Offline
                        skorpil
                        wrote on last edited by
                        #73

                        @paul53 aha. Und wie geht das dann mit httpGet? Ich muß ja umstellen

                        paul53P 1 Reply Last reply
                        0
                        • S skorpil

                          @paul53 aha. Und wie geht das dann mit httpGet? Ich muß ja umstellen

                          paul53P Offline
                          paul53P Offline
                          paul53
                          wrote on last edited by
                          #74

                          @skorpil sagte: wie geht das dann mit httpGet?

                          httpGet(idApiClipTerrasse, (error, response) => {
                              if(error) {
                                  console.error(error);
                                  return;
                              }        
                              // nur falls bisher body ausgewertet wurde:
                              const body = response.data;
                              // bestehendes Programm
                          });
                          

                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                          S 2 Replies Last reply
                          1
                          • paul53P paul53

                            @skorpil sagte: wie geht das dann mit httpGet?

                            httpGet(idApiClipTerrasse, (error, response) => {
                                if(error) {
                                    console.error(error);
                                    return;
                                }        
                                // nur falls bisher body ausgewertet wurde:
                                const body = response.data;
                                // bestehendes Programm
                            });
                            
                            S Offline
                            S Offline
                            skorpil
                            wrote on last edited by
                            #75

                            @paul53 vielen Dank.

                            1 Reply Last reply
                            0
                            • paul53P paul53

                              @skorpil sagte: wie geht das dann mit httpGet?

                              httpGet(idApiClipTerrasse, (error, response) => {
                                  if(error) {
                                      console.error(error);
                                      return;
                                  }        
                                  // nur falls bisher body ausgewertet wurde:
                                  const body = response.data;
                                  // bestehendes Programm
                              });
                              
                              S Offline
                              S Offline
                              skorpil
                              wrote on last edited by
                              #76

                              @paul53 brauche ich das try noch?

                              try {
                              httpGet(idApiClipTerrasse, (error, response) => {
                                  if(error) {
                                      console.error(error);
                                      return;
                                  }        
                                  // nur falls bisher body ausgewertet wurde:
                                  const body = response.data;
                                  // bestehendes Programm
                              })} catch (e) { console.error(e);}
                              

                              oder kann das erstzlos wegfallen?

                              paul53P 1 Reply Last reply
                              0
                              • S skorpil

                                @paul53 brauche ich das try noch?

                                try {
                                httpGet(idApiClipTerrasse, (error, response) => {
                                    if(error) {
                                        console.error(error);
                                        return;
                                    }        
                                    // nur falls bisher body ausgewertet wurde:
                                    const body = response.data;
                                    // bestehendes Programm
                                })} catch (e) { console.error(e);}
                                

                                oder kann das erstzlos wegfallen?

                                paul53P Offline
                                paul53P Offline
                                paul53
                                wrote on last edited by
                                #77

                                @skorpil sagte: brauche ich das try noch?

                                Eher nicht. Die Auswertung von error sollte genügen.

                                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                S 1 Reply Last reply
                                1
                                • paul53P paul53

                                  @skorpil sagte: brauche ich das try noch?

                                  Eher nicht. Die Auswertung von error sollte genügen.

                                  S Offline
                                  S Offline
                                  skorpil
                                  wrote on last edited by
                                  #78

                                  @paul53 mit anderen Worten:

                                  try {
                                      require("request")(idApiClipTerrasse).on("error", function (e) {console.error(e);});
                                          } catch (e) { console.error(e); };
                                  

                                  wird ersetzt durch

                                  
                                  httpGet(idApiClipTerrasse, (error, response) => {
                                      if(error) {
                                          console.error(error);
                                          return;
                                      }        
                                      });
                                  

                                  Richtig?

                                  PS: Sorry, dass ich nochmal nachfrage, aber bevor ich jetzt alle Scripte umbaue, sollte ich alles richtig verstanden haben

                                  paul53P 1 Reply Last reply
                                  0
                                  • S skorpil

                                    @paul53 mit anderen Worten:

                                    try {
                                        require("request")(idApiClipTerrasse).on("error", function (e) {console.error(e);});
                                            } catch (e) { console.error(e); };
                                    

                                    wird ersetzt durch

                                    
                                    httpGet(idApiClipTerrasse, (error, response) => {
                                        if(error) {
                                            console.error(error);
                                            return;
                                        }        
                                        });
                                    

                                    Richtig?

                                    PS: Sorry, dass ich nochmal nachfrage, aber bevor ich jetzt alle Scripte umbaue, sollte ich alles richtig verstanden haben

                                    paul53P Offline
                                    paul53P Offline
                                    paul53
                                    wrote on last edited by paul53
                                    #79

                                    @skorpil sagte: Richtig?

                                    Richtig.
                                    Der erste Parameter (idApiClipTerrasse) darf nur eine URL enthalten - kein Objekt.
                                    Siehe Doku

                                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                    S 2 Replies Last reply
                                    0
                                    • paul53P paul53

                                      @skorpil sagte: Richtig?

                                      Richtig.
                                      Der erste Parameter (idApiClipTerrasse) darf nur eine URL enthalten - kein Objekt.
                                      Siehe Doku

                                      S Offline
                                      S Offline
                                      skorpil
                                      wrote on last edited by
                                      #80

                                      @paul53 alles klar. Nochmals ein großes Danke

                                      1 Reply Last reply
                                      0
                                      • paul53P paul53

                                        @skorpil sagte: Richtig?

                                        Richtig.
                                        Der erste Parameter (idApiClipTerrasse) darf nur eine URL enthalten - kein Objekt.
                                        Siehe Doku

                                        S Offline
                                        S Offline
                                        skorpil
                                        wrote on last edited by skorpil
                                        #81

                                        @paul53 sorry, noch zwei Fragen:

                                        1. ich habe dieses Script von request auf httpGet entsprechend Deiner Anleitung umgeschrieben:
                                        // ##################################################################
                                        
                                        //                      Ansage
                                        
                                        // ##################################################################
                                        
                                        
                                        
                                        // ##################################################################
                                        //                      Definitionen
                                        // ##################################################################
                                        
                                        
                                        // Quellen
                                        var idWetter =           "hm-rega.0.29954";
                                        var idTemperatursensor = 'hm-rpc.0.OEQ1296052.1.TEMPERATURE'/*Außentemperatur:1 TEMPERATURE*/
                                        var idAnsageBuero = 'hm-rega.0.4529'/*AnsageAlexaBuero*/;
                                        var idAnsageSchlafzimmer = 'hm-rega.0.4528'/*AnsageAlexaSchlafzimmer*/;
                                        var idAnsageTerrasse = 'hm-rega.0.4626'/*AnsageAlexaTerrasse*/;
                                        var idAnsageKueche = 'hm-rega.0.4625'/*AnsageAlexaKüche*/;
                                        var idAnsageWohnzimmer = 'hm-rega.0.72055'/*AnsageAlexaWohnzimmer*/;
                                        
                                        
                                        
                                        // ##################################################################
                                        //                      Basiswerte ermitteln
                                        // ##################################################################
                                        
                                        
                                        function ermitteleAnsagedatum () {
                                            //Wochentag ermitteln
                                            var d = new Date ();
                                            var w = new Array("Sonntag","Montag","Dienstag","Mittwoch","Donnerstag","Freitag","Samstag");
                                            var wochentag = w[d.getDay()]; 
                                        
                                            //Tagesdatum ermitteln
                                            var tag = d.getDate();
                                        
                                            //Monat ermitteln
                                            var month = new Array("Januar","Februar","März","April","Mai","Juni","Juli","August","September","Oktober","November","Dezember");
                                            var monat = month[d.getMonth()];
                                        
                                            //Jahr ermitteln
                                            var jahr = d.getFullYear();
                                        
                                            //Stunde ermitteln
                                            var stunde = d.getHours();
                                        
                                            //Minute ermitteln
                                            var minute = d.getMinutes();
                                        
                                            //Begrüssung ermitteln
                                            var Begr = " ";
                                            if(stunde<=12){Begr = "Guten Morgen"};
                                            if(stunde>=12 && stunde<=18){Begr = "Guten Tag"};
                                            if(stunde>18){Begr = "Guten Abend"};
                                            
                                            return { // zurückgeben
                                                'Jahr'      : jahr,
                                                'Monat'     : monat,
                                                'Tag'       : tag,
                                                'Wochentag' : wochentag,
                                                'Stunde'    : stunde,
                                                'Minute'    : minute,
                                                'Begr'      : Begr
                                            };
                                        }
                                        
                                        
                                        
                                        function ermitteleWetter () { // Wetterbedingungen
                                            var wetterdaten = getState(idWetter).val;
                                        //    log('Wetter: ' + wetterdaten);
                                            return(wetterdaten);
                                        }
                                        
                                        function ermitteleAnsageTemperatur () {
                                            // Die Außentemperatur ist xx. Das Wetter heute ist xx
                                            // Einfache Temperaturansage mit SayIt.
                                            // Variante 1 mittels splitten der Temperatur, damit die Ansage nicht
                                            // "Es sind 18 Punkt 2 Grad " sagt.
                                        
                                            var temperatursensor = getState(idTemperatursensor).val;
                                            var temp_string = temperatursensor.toString();
                                        //    log('Temp  ' + temp_string);
                                            var temp_array = [];
                                            temp_array = temp_string.split(".");
                                        
                                            // Fange leere Nachkommastellen ab. Das passiert, wenn die Temperatur z. B. 18.0 ist.
                                            // Es wird dann nur "18" gelesen.
                                            if (!temp_array[1]) {
                                                temp_array[1] = "0";
                                        //        log("Die Nach-Kommastelle in temp_array[1] war nicht vorhanden und wird nun fest auf 0 gesetzt.");
                                            }
                                            return{
                                                'Ganzzahl'      : temp_array[0],
                                                'Nachkommazahl' : temp_array[1]
                                            };
                                        }
                                        
                                        on([idAnsageBuero , idAnsageSchlafzimmer , idAnsageKueche , idAnsageTerrasse , idAnsageWohnzimmer], function(dp) {
                                           if(dp.state.val) {
                                        
                                            // ###########################################
                                            //                 ClearQueue
                                            // ###########################################
                                           
                                            // var APIQueueBuero = "http://192.168.0.105:5005/B%C3%BCro%20Ikea/clearqueue";
                                            // var APIQueueSchlafzimmer = "http://192.168.0.105:5005/Schlafzimmer/clearqueue";
                                           
                                            
                                        
                                        // ##################################################################
                                        //                          Basisansage
                                        // ##################################################################
                                        
                                            
                                            var ansagetext = ermitteleAnsagedatum().Begr + ", heute ist " + ermitteleAnsagedatum().Wochentag + " der " + ermitteleAnsagedatum().Tag + "te " + ermitteleAnsagedatum().Monat + ' ' + ermitteleAnsagedatum().Jahr 
                                                    + ". Es ist " + ermitteleAnsagedatum().Stunde + "  Uhr und " + ermitteleAnsagedatum().Minute + "  Minuten." 
                                                    + " Die Aussentemperatur beträgt " + ermitteleAnsageTemperatur().Ganzzahl + "," + ermitteleAnsageTemperatur().Nachkommazahl + " Grad." 
                                                    + " Wetter Bedingungen, " + ermitteleWetter() +" .";
                                                    
                                                    
                                        
                                        
                                        
                                        
                                        // ##################################################################
                                        //      Ansagetext zusammenstellen und in Objekt schreiben
                                        // ##################################################################
                                        
                                        // Info zum Verzeichnis     /home/brs/node-sonos-http-api-master/static/clips/;
                                        // Definitionen MP3;
                                        // herzlichWillkommen.mp3";
                                        // var herz = "herzlichWillkommen.mp3";
                                        // HundeGebell.mp3;
                                        // var hund = "HundeGebell.mp3";
                                        // Rolladen.mp3;
                                        // var roll = "Rolladen.mp3";
                                        
                                        // Definition APIsay Büro Ikea;
                                        var APIsayBuero = "http://192.168.0.105:5005/B%C3%BCro%20Ikea/say/";
                                        
                                        // Definition APIsay Schlafzimmer;
                                        var APIsaySchlafzimmer = "http://192.168.0.105:5005/Schlafzimmer/say/";
                                        
                                        // Definition APIsay Kueche;
                                        var APIsayKueche = "http://192.168.0.105:5005/K%C3%BCche/say/";
                                        
                                        // Definition APIsay Terrasse;
                                        var APIsayTerrasse = "http://192.168.0.105:5005/Terrasse/say/";
                                        
                                        // Definition APIsay Wohnzimmer;
                                        var APIsayWohnzimmer = "http://192.168.0.105:5005/Wohnzimmer/say/";
                                        
                                        var lautstaerke = 50;
                                        
                                        
                                        
                                        // Ansagetext
                                                // Basisansage
                                                var Ansage = ansagetext;
                                                
                                                //Geburtstagsansage
                                                var tempGEBURTSTAGE = "javascript.0.Ansage.GeburtstageHEUTE";
                                                var AnsageGEBURTSTAGE = getState(tempGEBURTSTAGE).val;
                                                
                                                //Muellsansage heute
                                                var tempMUELLheute = "javascript.0.Ansage.MuellHEUTE";
                                                var AnsageMUELLheute = getState(tempMUELLheute).val;
                                                
                                                //Muellsansage Zukunft
                                                var tempMUELLzukunft = "javascript.0.Ansage.MuellZUKUNFT";
                                                var AnsageMUELLzukunft = getState(tempMUELLzukunft).val;
                                        
                                        /*log("Tempansage--------------------->" + tempAnsage);
                                        log("Ansage--------------------->" + Ansage);
                                        
                                        log("tempGEBURTSTAGE--------------------->" + tempGEBURTSTAGE);
                                        log("AnsageGEBURTSTAGE--------------------->" + AnsageGEBURTSTAGE);
                                        
                                        log("tempMUELLheute--------------------->" + tempMUELLheute);
                                        log("AnsageMUELLheute--------------------->" + AnsageMUELLheute);
                                        
                                        log("tempMUELLzukunft--------------------->" + tempMUELLzukunft);
                                        log("AnsageMUELLzukunft--------------------->" + AnsageMUELLzukunft);*/
                                        
                                        
                                        
                                        // ####################################################
                                        // Wenn Geburtstag dann mit ansagen
                                        // ####################################################
                                        
                                            if (AnsageGEBURTSTAGE.length > 2) { // wenn der Inhalt des Objektes "AnsageGEBURTSTAGE" größer als 2 Zeichen lang ist, dann ...
                                                Ansage = Ansage + "Heute haben Geburtstag, " + AnsageGEBURTSTAGE +" .";
                                                //log("Ansage mit Geburtstag--------------------->" + Ansage);
                                            }
                                            
                                           
                                        // ####################################################
                                        // Wenn Müll dann mit ansagen
                                        // ####################################################
                                        
                                            if (AnsageMUELLheute.length > 2) { // wenn der Inhalt des Objektes "AnsageMUELLheute" größer als 2 Zeichen lang ist, dann ...
                                                Ansage = Ansage + "  Achtung, heute ist " + AnsageMUELLheute +" ." + "Bitte an die Strasse stellen" + " !";
                                                //log("Ansage mit Geburtstag und Muell heute--------------------->" + Ansage);
                                            }
                                            
                                        // ####################################################
                                        // Wenn Müll ZUKUNFT, dann mit ansagen
                                        // ####################################################
                                        
                                            if (AnsageMUELLzukunft.length > 2) { // wenn der Inhalt des Objektes "AnsageMUELLzukunft" größer als 2 Zeichen lang ist, dann ...
                                                Ansage = Ansage + "  Achtung, morgen ist " + AnsageMUELLzukunft + " ." + "Bitte MORGEN an die Strasse stellen" + " !";
                                                //log("Ansage mit Geburtstag und Muell heute und morgen--------------------->" + Ansage);
                                            }    
                                        
                                        
                                        
                                        // ####################################################
                                        //                  ANSAGE
                                        // ####################################################
                                           
                                           var idAnsageBueroWert = getState(idAnsageBuero).val;
                                           var idAnsageSchlafzimmerWert = getState(idAnsageSchlafzimmer).val;
                                           var idAnsageKuecheWert = getState(idAnsageKueche).val;
                                           var idAnsageTerrasseWert = getState(idAnsageTerrasse).val;
                                           var idAnsageWohnzimmerWert = getState(idAnsageWohnzimmer).val; 
                                        
                                           log("Buero: " + idAnsageBueroWert);
                                           log("Schlaf: " + idAnsageSchlafzimmerWert);
                                           log("Kueche: " + idAnsageKuecheWert);
                                           log("Terrasse: " + idAnsageTerrasseWert);
                                           log("Wohnzimmer: " + idAnsageWohnzimmerWert);
                                           
                                           if(idAnsageBueroWert) {
                                               
                                            Ansage = APIsayBuero + Ansage + "/" + lautstaerke;
                                              
                                            log("AnsageArbeitszimmer=" + Ansage);
                                            setState(idAnsageBuero,false);
                                         
                                            httpGet(Ansage, (error) => {
                                            if(error) {
                                                console.error(error);
                                                return;
                                            }        
                                            });
                                            
                                            }
                                            // Ende If Büro
                                        
                                            if(idAnsageSchlafzimmerWert) {
                                               
                                            Ansage = APIsaySchlafzimmer + Ansage + "/" + lautstaerke;
                                            
                                            log("AnsageSchlafzimmer=" + Ansage);
                                            setState(idAnsageSchlafzimmer,false);
                                        
                                            httpGet(Ansage, (error) => {
                                            if(error) {
                                                console.error(error);
                                                return;
                                            }        
                                            });
                                            
                                            }
                                            // Ende If Schlafzimmer
                                        
                                        
                                             if(idAnsageKuecheWert) {
                                               
                                            Ansage = APIsayKueche + Ansage + "/" + lautstaerke;
                                            
                                            log("AnsageKuecher=" + Ansage);
                                            setState(idAnsageKueche,false);
                                        
                                            httpGet(Ansage, (error) => {
                                            if(error) {
                                                console.error(error);
                                                return;
                                            }        
                                            });
                                        
                                            }
                                            // Ende If Kueche
                                        
                                        
                                            if(idAnsageTerrasseWert) {
                                               
                                            Ansage = APIsayTerrasse + Ansage + "/" + lautstaerke;
                                            
                                            log("AnsageTerrasse=" + Ansage);
                                            setState(idAnsageTerrasse,false);
                                        
                                            httpGet(Ansage, (error) => {
                                            if(error) {
                                                console.error(error);
                                                return;
                                            }        
                                            });
                                        
                                            }
                                            // Ende If Terrasse
                                        
                                            
                                            if(idAnsageWohnzimmerWert) {
                                        
                                            Ansage = APIsayWohnzimmer + Ansage + "/" + lautstaerke;
                                            
                                            log("AnsageWohnzimmer=" + Ansage);
                                            setState(idAnsageWohnzimmer, false);
                                        
                                            // Definition Zustaende Denon
                                            const idDenonPower = 'denon.0.zoneMain.powerZone'/*Main Zone Power State*/;
                                            const idDenonInput = 'denon.0.zoneMain.selectInput'/*Select input*/;
                                            // const idDenonVolume = 'denon.0.zoneMain.volume'/*Main Volume*/;
                                            // var alterWertVolume = getState(idDenonVolume).val;
                                        
                                            // Check if the Denon adapter is off 
                                        
                                            if (!getState(idDenonPower).val) { 
                                            // Turn on the Denon adapter 
                                            setState(idDenonPower, true);
                                             log("idDenonPower=" + "true");
                                        
                                        
                                            // Set the input to CD
                                            setStateDelayed(idDenonInput, "CD", 2000);
                                                log("idDenonInput=" + "CD");
                                                // setState(idDenonVolume, 50 );
                                            // Play the announcement delayed by 10 seconds using the Sonos API
                                            setTimeout(function() {
                                                log("Ansage wird gespielt");
                                            httpGet(Ansage, (error) => {
                                            if(error) {
                                                console.error(error);
                                                return;
                                            }        
                                            });
                                            }, 6000);
                                        
                                            // Set the input back to TV
                                            setTimeout(function() {
                                            setStateDelayed(idDenonInput, "TV", 2000);
                                            log("idDenonInput auf TV zurueck");
                                            // Volume zurücksetzen
                                            // setState(idDenonVolume, alterWertVolume);
                                            // Turn off the Denon adapter
                                            setStateDelayed(idDenonPower, false, 4000);
                                            log("idDenonPower aus");
                                            }, 30000);
                                        
                                            }; // Ende If ist AN Z.302
                                           
                                            } // Ende If Wohnzimmer Z. 289
                                        
                                            
                                         } // Ende If aus on Ansage Z. 100
                                         
                                        }); // Ende ON Zeile 98
                                        

                                        das läuft auch, aber es gibt diese Fehlermeldung:

                                        script.js.Skripte_aktiviert.Ansage_API_alle_(mit_Sonos_Api)_mit_Wohnzimmer_mit_HttpGet: timeout of 2000ms exceeded
                                        

                                        Die gab es im "alten" Script mit request nicht. Warum? Was ist da falsch?

                                        1. könnte man den Block
                                        httpGet(Ansage, (error) => {
                                            if(error) {
                                                console.error(error);
                                                return;
                                            }        
                                            })
                                        

                                        nicht in eine function, entweder im Script selber oder in "globale Scripte" auslagern? Dann muß ich den nicht immer wieder einfügen. Oder?

                                        Danke!

                                        paul53P 1 Reply Last reply
                                        0
                                        • S skorpil

                                          @paul53 sorry, noch zwei Fragen:

                                          1. ich habe dieses Script von request auf httpGet entsprechend Deiner Anleitung umgeschrieben:
                                          // ##################################################################
                                          
                                          //                      Ansage
                                          
                                          // ##################################################################
                                          
                                          
                                          
                                          // ##################################################################
                                          //                      Definitionen
                                          // ##################################################################
                                          
                                          
                                          // Quellen
                                          var idWetter =           "hm-rega.0.29954";
                                          var idTemperatursensor = 'hm-rpc.0.OEQ1296052.1.TEMPERATURE'/*Außentemperatur:1 TEMPERATURE*/
                                          var idAnsageBuero = 'hm-rega.0.4529'/*AnsageAlexaBuero*/;
                                          var idAnsageSchlafzimmer = 'hm-rega.0.4528'/*AnsageAlexaSchlafzimmer*/;
                                          var idAnsageTerrasse = 'hm-rega.0.4626'/*AnsageAlexaTerrasse*/;
                                          var idAnsageKueche = 'hm-rega.0.4625'/*AnsageAlexaKüche*/;
                                          var idAnsageWohnzimmer = 'hm-rega.0.72055'/*AnsageAlexaWohnzimmer*/;
                                          
                                          
                                          
                                          // ##################################################################
                                          //                      Basiswerte ermitteln
                                          // ##################################################################
                                          
                                          
                                          function ermitteleAnsagedatum () {
                                              //Wochentag ermitteln
                                              var d = new Date ();
                                              var w = new Array("Sonntag","Montag","Dienstag","Mittwoch","Donnerstag","Freitag","Samstag");
                                              var wochentag = w[d.getDay()]; 
                                          
                                              //Tagesdatum ermitteln
                                              var tag = d.getDate();
                                          
                                              //Monat ermitteln
                                              var month = new Array("Januar","Februar","März","April","Mai","Juni","Juli","August","September","Oktober","November","Dezember");
                                              var monat = month[d.getMonth()];
                                          
                                              //Jahr ermitteln
                                              var jahr = d.getFullYear();
                                          
                                              //Stunde ermitteln
                                              var stunde = d.getHours();
                                          
                                              //Minute ermitteln
                                              var minute = d.getMinutes();
                                          
                                              //Begrüssung ermitteln
                                              var Begr = " ";
                                              if(stunde<=12){Begr = "Guten Morgen"};
                                              if(stunde>=12 && stunde<=18){Begr = "Guten Tag"};
                                              if(stunde>18){Begr = "Guten Abend"};
                                              
                                              return { // zurückgeben
                                                  'Jahr'      : jahr,
                                                  'Monat'     : monat,
                                                  'Tag'       : tag,
                                                  'Wochentag' : wochentag,
                                                  'Stunde'    : stunde,
                                                  'Minute'    : minute,
                                                  'Begr'      : Begr
                                              };
                                          }
                                          
                                          
                                          
                                          function ermitteleWetter () { // Wetterbedingungen
                                              var wetterdaten = getState(idWetter).val;
                                          //    log('Wetter: ' + wetterdaten);
                                              return(wetterdaten);
                                          }
                                          
                                          function ermitteleAnsageTemperatur () {
                                              // Die Außentemperatur ist xx. Das Wetter heute ist xx
                                              // Einfache Temperaturansage mit SayIt.
                                              // Variante 1 mittels splitten der Temperatur, damit die Ansage nicht
                                              // "Es sind 18 Punkt 2 Grad " sagt.
                                          
                                              var temperatursensor = getState(idTemperatursensor).val;
                                              var temp_string = temperatursensor.toString();
                                          //    log('Temp  ' + temp_string);
                                              var temp_array = [];
                                              temp_array = temp_string.split(".");
                                          
                                              // Fange leere Nachkommastellen ab. Das passiert, wenn die Temperatur z. B. 18.0 ist.
                                              // Es wird dann nur "18" gelesen.
                                              if (!temp_array[1]) {
                                                  temp_array[1] = "0";
                                          //        log("Die Nach-Kommastelle in temp_array[1] war nicht vorhanden und wird nun fest auf 0 gesetzt.");
                                              }
                                              return{
                                                  'Ganzzahl'      : temp_array[0],
                                                  'Nachkommazahl' : temp_array[1]
                                              };
                                          }
                                          
                                          on([idAnsageBuero , idAnsageSchlafzimmer , idAnsageKueche , idAnsageTerrasse , idAnsageWohnzimmer], function(dp) {
                                             if(dp.state.val) {
                                          
                                              // ###########################################
                                              //                 ClearQueue
                                              // ###########################################
                                             
                                              // var APIQueueBuero = "http://192.168.0.105:5005/B%C3%BCro%20Ikea/clearqueue";
                                              // var APIQueueSchlafzimmer = "http://192.168.0.105:5005/Schlafzimmer/clearqueue";
                                             
                                              
                                          
                                          // ##################################################################
                                          //                          Basisansage
                                          // ##################################################################
                                          
                                              
                                              var ansagetext = ermitteleAnsagedatum().Begr + ", heute ist " + ermitteleAnsagedatum().Wochentag + " der " + ermitteleAnsagedatum().Tag + "te " + ermitteleAnsagedatum().Monat + ' ' + ermitteleAnsagedatum().Jahr 
                                                      + ". Es ist " + ermitteleAnsagedatum().Stunde + "  Uhr und " + ermitteleAnsagedatum().Minute + "  Minuten." 
                                                      + " Die Aussentemperatur beträgt " + ermitteleAnsageTemperatur().Ganzzahl + "," + ermitteleAnsageTemperatur().Nachkommazahl + " Grad." 
                                                      + " Wetter Bedingungen, " + ermitteleWetter() +" .";
                                                      
                                                      
                                          
                                          
                                          
                                          
                                          // ##################################################################
                                          //      Ansagetext zusammenstellen und in Objekt schreiben
                                          // ##################################################################
                                          
                                          // Info zum Verzeichnis     /home/brs/node-sonos-http-api-master/static/clips/;
                                          // Definitionen MP3;
                                          // herzlichWillkommen.mp3";
                                          // var herz = "herzlichWillkommen.mp3";
                                          // HundeGebell.mp3;
                                          // var hund = "HundeGebell.mp3";
                                          // Rolladen.mp3;
                                          // var roll = "Rolladen.mp3";
                                          
                                          // Definition APIsay Büro Ikea;
                                          var APIsayBuero = "http://192.168.0.105:5005/B%C3%BCro%20Ikea/say/";
                                          
                                          // Definition APIsay Schlafzimmer;
                                          var APIsaySchlafzimmer = "http://192.168.0.105:5005/Schlafzimmer/say/";
                                          
                                          // Definition APIsay Kueche;
                                          var APIsayKueche = "http://192.168.0.105:5005/K%C3%BCche/say/";
                                          
                                          // Definition APIsay Terrasse;
                                          var APIsayTerrasse = "http://192.168.0.105:5005/Terrasse/say/";
                                          
                                          // Definition APIsay Wohnzimmer;
                                          var APIsayWohnzimmer = "http://192.168.0.105:5005/Wohnzimmer/say/";
                                          
                                          var lautstaerke = 50;
                                          
                                          
                                          
                                          // Ansagetext
                                                  // Basisansage
                                                  var Ansage = ansagetext;
                                                  
                                                  //Geburtstagsansage
                                                  var tempGEBURTSTAGE = "javascript.0.Ansage.GeburtstageHEUTE";
                                                  var AnsageGEBURTSTAGE = getState(tempGEBURTSTAGE).val;
                                                  
                                                  //Muellsansage heute
                                                  var tempMUELLheute = "javascript.0.Ansage.MuellHEUTE";
                                                  var AnsageMUELLheute = getState(tempMUELLheute).val;
                                                  
                                                  //Muellsansage Zukunft
                                                  var tempMUELLzukunft = "javascript.0.Ansage.MuellZUKUNFT";
                                                  var AnsageMUELLzukunft = getState(tempMUELLzukunft).val;
                                          
                                          /*log("Tempansage--------------------->" + tempAnsage);
                                          log("Ansage--------------------->" + Ansage);
                                          
                                          log("tempGEBURTSTAGE--------------------->" + tempGEBURTSTAGE);
                                          log("AnsageGEBURTSTAGE--------------------->" + AnsageGEBURTSTAGE);
                                          
                                          log("tempMUELLheute--------------------->" + tempMUELLheute);
                                          log("AnsageMUELLheute--------------------->" + AnsageMUELLheute);
                                          
                                          log("tempMUELLzukunft--------------------->" + tempMUELLzukunft);
                                          log("AnsageMUELLzukunft--------------------->" + AnsageMUELLzukunft);*/
                                          
                                          
                                          
                                          // ####################################################
                                          // Wenn Geburtstag dann mit ansagen
                                          // ####################################################
                                          
                                              if (AnsageGEBURTSTAGE.length > 2) { // wenn der Inhalt des Objektes "AnsageGEBURTSTAGE" größer als 2 Zeichen lang ist, dann ...
                                                  Ansage = Ansage + "Heute haben Geburtstag, " + AnsageGEBURTSTAGE +" .";
                                                  //log("Ansage mit Geburtstag--------------------->" + Ansage);
                                              }
                                              
                                             
                                          // ####################################################
                                          // Wenn Müll dann mit ansagen
                                          // ####################################################
                                          
                                              if (AnsageMUELLheute.length > 2) { // wenn der Inhalt des Objektes "AnsageMUELLheute" größer als 2 Zeichen lang ist, dann ...
                                                  Ansage = Ansage + "  Achtung, heute ist " + AnsageMUELLheute +" ." + "Bitte an die Strasse stellen" + " !";
                                                  //log("Ansage mit Geburtstag und Muell heute--------------------->" + Ansage);
                                              }
                                              
                                          // ####################################################
                                          // Wenn Müll ZUKUNFT, dann mit ansagen
                                          // ####################################################
                                          
                                              if (AnsageMUELLzukunft.length > 2) { // wenn der Inhalt des Objektes "AnsageMUELLzukunft" größer als 2 Zeichen lang ist, dann ...
                                                  Ansage = Ansage + "  Achtung, morgen ist " + AnsageMUELLzukunft + " ." + "Bitte MORGEN an die Strasse stellen" + " !";
                                                  //log("Ansage mit Geburtstag und Muell heute und morgen--------------------->" + Ansage);
                                              }    
                                          
                                          
                                          
                                          // ####################################################
                                          //                  ANSAGE
                                          // ####################################################
                                             
                                             var idAnsageBueroWert = getState(idAnsageBuero).val;
                                             var idAnsageSchlafzimmerWert = getState(idAnsageSchlafzimmer).val;
                                             var idAnsageKuecheWert = getState(idAnsageKueche).val;
                                             var idAnsageTerrasseWert = getState(idAnsageTerrasse).val;
                                             var idAnsageWohnzimmerWert = getState(idAnsageWohnzimmer).val; 
                                          
                                             log("Buero: " + idAnsageBueroWert);
                                             log("Schlaf: " + idAnsageSchlafzimmerWert);
                                             log("Kueche: " + idAnsageKuecheWert);
                                             log("Terrasse: " + idAnsageTerrasseWert);
                                             log("Wohnzimmer: " + idAnsageWohnzimmerWert);
                                             
                                             if(idAnsageBueroWert) {
                                                 
                                              Ansage = APIsayBuero + Ansage + "/" + lautstaerke;
                                                
                                              log("AnsageArbeitszimmer=" + Ansage);
                                              setState(idAnsageBuero,false);
                                           
                                              httpGet(Ansage, (error) => {
                                              if(error) {
                                                  console.error(error);
                                                  return;
                                              }        
                                              });
                                              
                                              }
                                              // Ende If Büro
                                          
                                              if(idAnsageSchlafzimmerWert) {
                                                 
                                              Ansage = APIsaySchlafzimmer + Ansage + "/" + lautstaerke;
                                              
                                              log("AnsageSchlafzimmer=" + Ansage);
                                              setState(idAnsageSchlafzimmer,false);
                                          
                                              httpGet(Ansage, (error) => {
                                              if(error) {
                                                  console.error(error);
                                                  return;
                                              }        
                                              });
                                              
                                              }
                                              // Ende If Schlafzimmer
                                          
                                          
                                               if(idAnsageKuecheWert) {
                                                 
                                              Ansage = APIsayKueche + Ansage + "/" + lautstaerke;
                                              
                                              log("AnsageKuecher=" + Ansage);
                                              setState(idAnsageKueche,false);
                                          
                                              httpGet(Ansage, (error) => {
                                              if(error) {
                                                  console.error(error);
                                                  return;
                                              }        
                                              });
                                          
                                              }
                                              // Ende If Kueche
                                          
                                          
                                              if(idAnsageTerrasseWert) {
                                                 
                                              Ansage = APIsayTerrasse + Ansage + "/" + lautstaerke;
                                              
                                              log("AnsageTerrasse=" + Ansage);
                                              setState(idAnsageTerrasse,false);
                                          
                                              httpGet(Ansage, (error) => {
                                              if(error) {
                                                  console.error(error);
                                                  return;
                                              }        
                                              });
                                          
                                              }
                                              // Ende If Terrasse
                                          
                                              
                                              if(idAnsageWohnzimmerWert) {
                                          
                                              Ansage = APIsayWohnzimmer + Ansage + "/" + lautstaerke;
                                              
                                              log("AnsageWohnzimmer=" + Ansage);
                                              setState(idAnsageWohnzimmer, false);
                                          
                                              // Definition Zustaende Denon
                                              const idDenonPower = 'denon.0.zoneMain.powerZone'/*Main Zone Power State*/;
                                              const idDenonInput = 'denon.0.zoneMain.selectInput'/*Select input*/;
                                              // const idDenonVolume = 'denon.0.zoneMain.volume'/*Main Volume*/;
                                              // var alterWertVolume = getState(idDenonVolume).val;
                                          
                                              // Check if the Denon adapter is off 
                                          
                                              if (!getState(idDenonPower).val) { 
                                              // Turn on the Denon adapter 
                                              setState(idDenonPower, true);
                                               log("idDenonPower=" + "true");
                                          
                                          
                                              // Set the input to CD
                                              setStateDelayed(idDenonInput, "CD", 2000);
                                                  log("idDenonInput=" + "CD");
                                                  // setState(idDenonVolume, 50 );
                                              // Play the announcement delayed by 10 seconds using the Sonos API
                                              setTimeout(function() {
                                                  log("Ansage wird gespielt");
                                              httpGet(Ansage, (error) => {
                                              if(error) {
                                                  console.error(error);
                                                  return;
                                              }        
                                              });
                                              }, 6000);
                                          
                                              // Set the input back to TV
                                              setTimeout(function() {
                                              setStateDelayed(idDenonInput, "TV", 2000);
                                              log("idDenonInput auf TV zurueck");
                                              // Volume zurücksetzen
                                              // setState(idDenonVolume, alterWertVolume);
                                              // Turn off the Denon adapter
                                              setStateDelayed(idDenonPower, false, 4000);
                                              log("idDenonPower aus");
                                              }, 30000);
                                          
                                              }; // Ende If ist AN Z.302
                                             
                                              } // Ende If Wohnzimmer Z. 289
                                          
                                              
                                           } // Ende If aus on Ansage Z. 100
                                           
                                          }); // Ende ON Zeile 98
                                          

                                          das läuft auch, aber es gibt diese Fehlermeldung:

                                          script.js.Skripte_aktiviert.Ansage_API_alle_(mit_Sonos_Api)_mit_Wohnzimmer_mit_HttpGet: timeout of 2000ms exceeded
                                          

                                          Die gab es im "alten" Script mit request nicht. Warum? Was ist da falsch?

                                          1. könnte man den Block
                                          httpGet(Ansage, (error) => {
                                              if(error) {
                                                  console.error(error);
                                                  return;
                                              }        
                                              })
                                          

                                          nicht in eine function, entweder im Script selber oder in "globale Scripte" auslagern? Dann muß ich den nicht immer wieder einfügen. Oder?

                                          Danke!

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          wrote on last edited by
                                          #82

                                          @skorpil sagte: es gibt diese Fehlermeldung:

                                          Dann setze den Timeout hoch.

                                          httpGet(Ansage, {timeout: 10000}, (error) => {
                                              if(error) {
                                                  console.error(error);
                                              }        
                                          });
                                          

                                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                          S 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

                                          439

                                          Online

                                          32.4k

                                          Users

                                          81.4k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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