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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

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

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

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

JavaScript funktioniert nicht wie gewünscht! Bitte Hilfe.

Geplant Angeheftet Gesperrt Verschoben JavaScript
95 Beiträge 8 Kommentatoren 10.4k Aufrufe 3 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • 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
    schrieb am zuletzt editiert von
    #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 Antwort Letzte Antwort
    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
      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
      1
      • S Offline
        S Offline
        skorpil
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von
          #66

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

          1 Antwort Letzte Antwort
          0
          • S Offline
            S Offline
            skorpil
            schrieb am zuletzt editiert von
            #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 Antworten Letzte Antwort
            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
              schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                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
                  schrieb am zuletzt editiert von
                  #70

                  @paul53 daaaanke. Das war der richtige Tip.

                  1 Antwort Letzte Antwort
                  0
                  • S Offline
                    S Offline
                    skorpil
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    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
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      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
                        schrieb am zuletzt editiert von
                        #73

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

                        paul53P 1 Antwort Letzte Antwort
                        0
                        • S skorpil

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

                          paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von
                          #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 Antworten Letzte Antwort
                          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
                            schrieb am zuletzt editiert von
                            #75

                            @paul53 vielen Dank.

                            1 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von
                              #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 Antwort Letzte Antwort
                              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
                                schrieb am zuletzt editiert von
                                #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 Antwort Letzte Antwort
                                1
                                • paul53P paul53

                                  @skorpil sagte: brauche ich das try noch?

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

                                  S Offline
                                  S Offline
                                  skorpil
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  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
                                    schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
                                    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
                                      schrieb am zuletzt editiert von
                                      #80

                                      @paul53 alles klar. Nochmals ein großes Danke

                                      1 Antwort Letzte Antwort
                                      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
                                        schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                        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
                                          schrieb am zuletzt editiert von
                                          #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 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          242

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe