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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. JavaScript funktioniert nicht wie gewünscht! Bitte Hilfe.

NEWS

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

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

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

JavaScript funktioniert nicht wie gewünscht! Bitte Hilfe.

Scheduled Pinned Locked Moved JavaScript
95 Posts 8 Posters 10.3k Views 3 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • paul53P paul53

    @skorpil sagte: brauche ich das try noch?

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

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

    @paul53 mit anderen Worten:

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

    wird ersetzt durch

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

    Richtig?

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

    paul53P 1 Reply Last reply
    0
    • S skorpil

      @paul53 mit anderen Worten:

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

      wird ersetzt durch

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

      Richtig?

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

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

      @skorpil sagte: Richtig?

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

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

      S 2 Replies Last reply
      0
      • paul53P paul53

        @skorpil sagte: Richtig?

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

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

        @paul53 alles klar. Nochmals ein großes Danke

        1 Reply Last reply
        0
        • paul53P paul53

          @skorpil sagte: Richtig?

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

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

          @paul53 sorry, noch zwei Fragen:

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

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

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

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

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

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

          Danke!

          paul53P 1 Reply Last reply
          0
          • S skorpil

            @paul53 sorry, noch zwei Fragen:

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

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

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

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

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

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

            Danke!

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

            @skorpil sagte: es gibt diese Fehlermeldung:

            Dann setze den Timeout hoch.

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

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

            S 1 Reply Last reply
            0
            • paul53P paul53

              @skorpil sagte: es gibt diese Fehlermeldung:

              Dann setze den Timeout hoch.

              httpGet(Ansage, {timeout: 10000}, (error) => {
                  if(error) {
                      console.error(error);
                  }        
              });
              
              S Offline
              S Offline
              skorpil
              wrote on last edited by
              #83

              @paul53 das war es! Dankeschön.

              und noch bitte zu meiner Frage 2:

              könnte man den Block

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

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

              paul53P 1 Reply Last reply
              0
              • S skorpil

                @paul53 das war es! Dankeschön.

                und noch bitte zu meiner Frage 2:

                könnte man den Block

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

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

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

                @skorpil sagte: nicht in eine function, entweder im Script selber oder in "globale Scripte" auslagern?

                Kann man. Dann muss anstelle der 5 Zeilen die Funktion aufgerufen werden. Beispiel:

                function ansagen(url) {
                    httpGet(url, {timeout: 10000}, (error) => {
                        if(error) {
                            console.error(error);
                        }        
                    });
                }
                
                // Aufruf
                ansagen(Ansage);
                

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

                S 2 Replies Last reply
                1
                • paul53P paul53

                  @skorpil sagte: nicht in eine function, entweder im Script selber oder in "globale Scripte" auslagern?

                  Kann man. Dann muss anstelle der 5 Zeilen die Funktion aufgerufen werden. Beispiel:

                  function ansagen(url) {
                      httpGet(url, {timeout: 10000}, (error) => {
                          if(error) {
                              console.error(error);
                          }        
                      });
                  }
                  
                  // Aufruf
                  ansagen(Ansage);
                  
                  S Offline
                  S Offline
                  skorpil
                  wrote on last edited by
                  #85

                  @paul53 suuuupi

                  1 Reply Last reply
                  0
                  • paul53P paul53

                    @skorpil sagte: nicht in eine function, entweder im Script selber oder in "globale Scripte" auslagern?

                    Kann man. Dann muss anstelle der 5 Zeilen die Funktion aufgerufen werden. Beispiel:

                    function ansagen(url) {
                        httpGet(url, {timeout: 10000}, (error) => {
                            if(error) {
                                console.error(error);
                            }        
                        });
                    }
                    
                    // Aufruf
                    ansagen(Ansage);
                    
                    S Offline
                    S Offline
                    skorpil
                    wrote on last edited by skorpil
                    #86

                    @paul53 ich benötige bei einem auf httpGet umgestellten Script bitte noch einmal Deine Hilfe (alle anderen funktionieren wie gewünscht)

                    Ich tippe darauf, dass das Problem bei folgendem Script mit den timeouts zusammenhängt. Das ist das httpGet Script:

                    // ##################################################################
                    
                    //        Erst Ansage, dann Radio ein u. nach 45 min aus
                    
                    // ##################################################################
                    
                    
                    
                    // ##################################################################
                    //                      Definitionen Ansage
                    // ##################################################################
                    
                    
                    // Quellen
                    var idWetter =           "hm-rega.0.29954";
                    var idTemperatursensor = 'hm-rpc.0.OEQ1296052.1.TEMPERATURE'/*Außentemperatur:1 TEMPERATURE*/
                    // var idSayVar = "hm-rega.0.38101";//Variable Sayit  <= Alt, wenn Steuerung via CCU Variable;
                    var idBM = 'hm-rpc.0.JEQ0266058.1.MOTION'/*BewMldr Treppenhaus:1 MOTION*/
                    
                    // 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 Lautstärke;
                        var lautstaerke = "50";
                    
                    var aufstehen = false;
                    
                    // ####################################################
                    //          Funktionen (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<=17){Begr = "Guten Tag"};
                            if(stunde>17){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]
                            };
                        }
                    
                    // ##########################################################
                    //         ANSAGE (GETRIGGERT via BewMldr)
                    //  EINMALIG im Zeitraum 6:00 - 10:00, wenn BewMldr
                    // ##########################################################
                    
                    
                    on(idBM, function(dp) {
                       
                       log("Motion ausgelöst");
                       
                       if(dp.state.val && compareTime('6:00', '10:00', 'between') && !aufstehen) {
                          aufstehen = true;
                    
                          log("Motion ausgelöst, in der Zeit und aufstehen falsch");
                    
                        // ##########################################################
                        //         ANSAGE Verögerung 10 sec
                        // ##########################################################
                    
                        setTimeout(function() {
                    
                          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
                    // ##################################################################
                    
                    
                        // 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
                        Ansage = APIsayKueche + Ansage + "/" + lautstaerke;       
                        
                        ansagenSonos(Ansage);//Funktion mit HttpGet in Global
                    
                       }, 15000);
                       // Ende timeout/ Verzögerung
                    
                    
                    //****************************************************************************************** */
                    
                    
                    //************************************************
                    //Javascript zum Schalten von Sonos via BewMldr
                    //************************************************
                    
                            /* Das folgende sind nur Befehle, die ich mir aufgehoben habe: 
                            // var idSonosfav = getState("sonos.0.root.192_168_0_63.favorites_list").val;      //speichern des aktuellen Senders
                            // var idSonosplay = getState ("sonos.0.root.192_168_0_63.state_simple").val;     //Status des Speakers
                            // laut = getState('sonos.0.root.' + raum + '.volume').val;
                            // log(idSonosfav);
                            // log(idSonosplay);*/
                    
                    
                    //*******************************************
                    //              Definitionen für Radio
                    //*******************************************
                    
                        // *******************************************************************************  
                        // Info zum Verzeichnis     /home/brs/node-sonos-http-api-master/static/says/;
                        // Definitionen MP3;
                        // herzlichWillkommen.mp3";
                        // var herz = "herzlichWillkommen.mp3";
                        // HundeGebell.mp3;
                        // var hund = "HundeGebell.mp3";
                        // Rolladen.mp3;
                        // var roll = "Rolladen.mp3";
                    
                        //AUFRUF:
                                //Beispiel: http://192.168.0.105:5005/B%C3%BCro%20Ikea/favorite/RTL - Die besten Hits aller Zeiten
                    
                        
                        // IDsonosAufr = "http://192.168.0.105:5005/"<------hier richtige IP eintragen
                        
                        // Definition STRUKTUR
                        // Achtung, am Ende der Einzelteile des Aufrufs jeweils ein "7"
                        // IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender + laut
                            
                            //Favorites bzw. Sender
                            //IDsonosSender = "104.6 RTL Weihnachtsradio/"
                            //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                            //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                            //IDsonosSender = "RTL Deutschlands Hit-Radio/"
                    
                            //Definition Räume
                            // Definition raum Büro Ikea;
                            // IDsonosRaum ="B%C3%BCro%20Ikea/";
                    
                            // Definition raum Schlafzimmer;
                            // IDsonosRaum = "Schlafzimmer/";
                    
                            // Definition raum Kueche;
                            // IDsonosRaum = "K%C3%BCche/";
                    
                            // Definition raum Terrasse;
                            // IDsonosRaum = "Terrasse/";
                    
                            // Definition Funktionen
                            // IDsonosFunktion = "say/"
                            // IDsonosFunktion = "clip/"
                            // IDsonosFunktion = "favorite/"
                            // IDsonosFunktion = "pause"; <-------ohne "/"
                    
                     
                    
                        //STOP
                        //BEISPIEL: http://192.168.0.105:5005/B%C3%BCro%20Ikea/pause
                        //STRUKTUR: IDsonosAufr + IDsonosRaum + IDsonosFunktion
                    
                        // das ist der Aufruf
                        // ansagenSonos(radioAbspiel);
                        // Funktion mit HttpGet in Global
                    
                        // Anweisung setzen LAUTSTAERKE
                        // var laut = "8";//<------hier gewünschte LAUTSTÄRKE eintragen
                        
                        // *******************************************************************************  
                    
                    var IDsonosAufr = "http://192.168.0.105:5005/";
                    var IDsonosRaum = "K%C3%BCche/";
                    
                    
                    
                    
                        // ************************************************  
                        // Auswahl Radiosender
                            // Sender muß in Favoriten vorhanden sein
                            // momentan: 104.6 RTL Weihnachtsradio, RTL Deutschlands Hit-Radio, RTL - Die besten Hits aller Zeiten
                        // ************************************************
                        
                    var IDsonosSender = "RTL - Die besten Hits aller Zeiten/";
                    // var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;  
                    
                    setTimeout(function() {
                        // ************************************************
                        //  nach 60 sekunden starten
                        // ************************************************
                    
                    // Befehle ausführen
                    
                        // ************************************************
                        // Befehl zum play
                        // ************************************************
                    
                    
                    
                    var IDsonosFunktion = "favorite/";
                    var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;
                    
                    ansagenSonos(radioAbspiel);//Funktion mit HttpGet in Global
                    
                    // Lautstaeke einstellen 
                    var IDsonosFunktion = "volume/";
                    var laut = "8";
                    var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + laut;
                    
                    ansagenSonos(radioAbspiel);//Funktion mit HttpGet in Global
                    
                    // Ende lautstaerke
                    
                     
                    
                     }, 60000);
                       // Ende timeout für Start
                    
                    setTimeout(function() {
                        // ************************************************
                        // Befehl zum stop nach 45 Minuten
                        // ************************************************
                    
                    var IDsonosFunktion = "pause";
                    var radioAbspielStop = IDsonosAufr + IDsonosRaum + IDsonosFunktion; 
                    
                    log("radioAbspielStop--------------------->" + radioAbspielStop);
                    
                    ansagenSonos(radioAbspielStop);//Funktion mit HttpGet in Global
                    
                    }, 2700000);
                    // Ende timeout für Stop
                    
                    
                       }
                       // Ende If
                       
                    });
                    
                    
                        // ####################################################
                        //     var "aufstehen" zurücksetzen auf false um 3 Uhr
                        // ####################################################
                    
                    
                    schedule('0 3 * * *', function() {
                       aufstehen = false;
                    });
                    

                    hier ist das zugehörige globale Script resp Function:

                    function ansagenSonos(url) {
                        httpGet(url, {timeout: 30000}, (error) => {
                            if(error) {
                                console.error(error);
                            }        
                        });
                    }
                    

                    Das Merkwürdige ist, es löst nicht aus. Ich habe mir zum debuggen schon logs eingefügt:

                    log("Motion ausgelöst");
                    
                    und
                    
                    log("Motion ausgelöst, in der Zeit und aufstehen falsch");
                    

                    Es kommt aber nur "Motion ausgelöst", also wird die if Aweisung nicht zutreffend ausgelöst.

                    Dieses "alte" Script mit "request" funktioniert dagegen perfekt:

                    // ##################################################################
                    
                    //        Erst Ansage, dann Radio ein u. nach 45 min aus
                    
                    // ##################################################################
                    
                    
                    
                    // ##################################################################
                    //                      Definitionen Ansage
                    // ##################################################################
                    
                    
                    // Quellen
                    var idWetter =           "hm-rega.0.29954";
                    var idTemperatursensor = 'hm-rpc.0.OEQ1296052.1.TEMPERATURE'/*Außentemperatur:1 TEMPERATURE*/
                    // var idSayVar = "hm-rega.0.38101";//Variable Sayit  <= Alt, wenn Steuerung via CCU Variable;
                    var idBM = 'hm-rpc.0.JEQ0266058.1.MOTION'/*BewMldr Treppenhaus:1 MOTION*/
                    
                    // 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 Lautstärke;
                        var lautstaerke = "50";
                    
                    var aufstehen = false;
                    
                    // ####################################################
                    //          Funktionen (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<=17){Begr = "Guten Tag"};
                            if(stunde>17){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]
                            };
                        }
                    
                    // ##########################################################
                    //         ANSAGE (GETRIGGERT via BewMldr)
                    //  EINMALIG im Zeitraum 6:00 - 10:00, wenn BewMldr
                    // ##########################################################
                    
                    
                    on(idBM, function(dp) {
                       if(dp.state.val && compareTime('6:00', '10:00', 'between') && !aufstehen) {
                          aufstehen = true;
                    
                        // ##########################################################
                        //         ANSAGE Verögerung 10 sec
                        // ##########################################################
                    
                        setTimeout(function() {
                    
                          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
                    // ##################################################################
                    
                    
                        // 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
                        Ansage = APIsayKueche + Ansage + "/" + lautstaerke;       
                        
                        try {
                        require("request")(Ansage).on("error", function (e) {console.error(e);});
                            } catch (e) { console.error(e); };
                    
                       }, 15000);
                       // Ende timeout/ Verzögerung
                    
                    
                    //****************************************************************************************** */
                    
                    
                    //************************************************
                    //Javascript zum Schalten von Sonos via BewMldr
                    //************************************************
                    
                            /* Das folgende sind nur Befehle, die ich mir aufgehoben habe: 
                            // var idSonosfav = getState("sonos.0.root.192_168_0_63.favorites_list").val;      //speichern des aktuellen Senders
                            // var idSonosplay = getState ("sonos.0.root.192_168_0_63.state_simple").val;     //Status des Speakers
                            // laut = getState('sonos.0.root.' + raum + '.volume').val;
                            // log(idSonosfav);
                            // log(idSonosplay);*/
                    
                    
                    //*******************************************
                    //              Definitionen für Radio
                    //*******************************************
                    
                        // *******************************************************************************  
                        // Info zum Verzeichnis     /home/brs/node-sonos-http-api-master/static/says/;
                        // Definitionen MP3;
                        // herzlichWillkommen.mp3";
                        // var herz = "herzlichWillkommen.mp3";
                        // HundeGebell.mp3;
                        // var hund = "HundeGebell.mp3";
                        // Rolladen.mp3;
                        // var roll = "Rolladen.mp3";
                    
                        //AUFRUF:
                                //Beispiel: http://192.168.0.105:5005/B%C3%BCro%20Ikea/favorite/RTL - Die besten Hits aller Zeiten
                    
                        
                        // IDsonosAufr = "http://192.168.0.105:5005/"<------hier richtige IP eintragen
                        
                        // Definition STRUKTUR
                        // Achtung, am Ende der Einzelteile des Aufrufs jeweils ein "7"
                        // IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender + laut
                            
                            //Favorites bzw. Sender
                            //IDsonosSender = "104.6 RTL Weihnachtsradio/"
                            //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                            //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                            //IDsonosSender = "RTL Deutschlands Hit-Radio/"
                    
                            //Definition Räume
                            // Definition raum Büro Ikea;
                            // IDsonosRaum ="B%C3%BCro%20Ikea/";
                    
                            // Definition raum Schlafzimmer;
                            // IDsonosRaum = "Schlafzimmer/";
                    
                            // Definition raum Kueche;
                            // IDsonosRaum = "K%C3%BCche/";
                    
                            // Definition raum Terrasse;
                            // IDsonosRaum = "Terrasse/";
                    
                            // Definition Funktionen
                            // IDsonosFunktion = "say/"
                            // IDsonosFunktion = "clip/"
                            // IDsonosFunktion = "favorite/"
                            // IDsonosFunktion = "pause"; <-------ohne "/"
                    
                     
                    
                        //STOP
                        //BEISPIEL: http://192.168.0.105:5005/B%C3%BCro%20Ikea/pause
                        //STRUKTUR: IDsonosAufr + IDsonosRaum + IDsonosFunktion
                    
                        // das ist der Aufruf
                        //try {
                        //    require("request")(abspielSchlaf).on("error", function (e) {console.error(e);});
                        //        } catch (e) { console.error(e); };
                    
                        // Anweisung setzen LAUTSTAERKE
                        // var laut = "8";//<------hier gewünschte LAUTSTÄRKE eintragen
                        
                        // *******************************************************************************  
                    
                    var IDsonosAufr = "http://192.168.0.105:5005/";
                    var IDsonosRaum = "K%C3%BCche/";
                    
                    
                    
                    
                        // ************************************************  
                        // Auswahl Radiosender
                            // Sender muß in Favoriten vorhanden sein
                            // momentan: 104.6 RTL Weihnachtsradio, RTL Deutschlands Hit-Radio, RTL - Die besten Hits aller Zeiten
                        // ************************************************
                        
                    var IDsonosSender = "RTL - Die besten Hits aller Zeiten/";
                    // var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;  
                    
                    setTimeout(function() {
                        // ************************************************
                        //  nach 60 sekunden starten
                        // ************************************************
                    
                    // Befehle ausführen
                    
                        // ************************************************
                        // Befehl zum play
                        // ************************************************
                    
                    
                    
                    var IDsonosFunktion = "favorite/";
                    var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;
                    
                    try {
                            require("request")(radioAbspiel).on("error", function (e) {console.error(e);});
                                } catch (e) { console.error(e); };
                    
                    // Lautstaeke einstellen 
                    var IDsonosFunktion = "volume/";
                    var laut = "8";
                    var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + laut;
                    
                    try {
                            require("request")(radioAbspiel).on("error", function (e) {console.error(e);});
                                } catch (e) { console.error(e); };
                    // Ende lautstaerke
                    
                     
                    
                     }, 60000);
                       // Ende timeout für Start
                    
                    setTimeout(function() {
                        // ************************************************
                        // Befehl zum stop nach 45 Minuten
                        // ************************************************
                    
                    var IDsonosFunktion = "pause";
                    var radioAbspielStop = IDsonosAufr + IDsonosRaum + IDsonosFunktion; 
                    
                    log("radioAbspielStop--------------------->" + radioAbspielStop);
                    
                    try {
                            require("request")(radioAbspielStop).on("error", function (e) {console.error(e);});
                                } catch (e) { console.error(e); };
                    
                    }, 2700000);
                    // Ende timeout für Stop
                    
                    
                       }
                       // Ende If
                       
                    });
                    
                    
                        // ####################################################
                        //     var "aufstehen" zurücksetzen auf false um 3 Uhr
                        // ####################################################
                    
                    
                    schedule('0 3 * * *', function() {
                       aufstehen = false;
                    });
                    

                    Ich finde einfach den Fehler nicht. Würdest Du bitte mal drüberschauen?

                    paul53P 1 Reply Last reply
                    0
                    • S skorpil

                      @paul53 ich benötige bei einem auf httpGet umgestellten Script bitte noch einmal Deine Hilfe (alle anderen funktionieren wie gewünscht)

                      Ich tippe darauf, dass das Problem bei folgendem Script mit den timeouts zusammenhängt. Das ist das httpGet Script:

                      // ##################################################################
                      
                      //        Erst Ansage, dann Radio ein u. nach 45 min aus
                      
                      // ##################################################################
                      
                      
                      
                      // ##################################################################
                      //                      Definitionen Ansage
                      // ##################################################################
                      
                      
                      // Quellen
                      var idWetter =           "hm-rega.0.29954";
                      var idTemperatursensor = 'hm-rpc.0.OEQ1296052.1.TEMPERATURE'/*Außentemperatur:1 TEMPERATURE*/
                      // var idSayVar = "hm-rega.0.38101";//Variable Sayit  <= Alt, wenn Steuerung via CCU Variable;
                      var idBM = 'hm-rpc.0.JEQ0266058.1.MOTION'/*BewMldr Treppenhaus:1 MOTION*/
                      
                      // 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 Lautstärke;
                          var lautstaerke = "50";
                      
                      var aufstehen = false;
                      
                      // ####################################################
                      //          Funktionen (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<=17){Begr = "Guten Tag"};
                              if(stunde>17){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]
                              };
                          }
                      
                      // ##########################################################
                      //         ANSAGE (GETRIGGERT via BewMldr)
                      //  EINMALIG im Zeitraum 6:00 - 10:00, wenn BewMldr
                      // ##########################################################
                      
                      
                      on(idBM, function(dp) {
                         
                         log("Motion ausgelöst");
                         
                         if(dp.state.val && compareTime('6:00', '10:00', 'between') && !aufstehen) {
                            aufstehen = true;
                      
                            log("Motion ausgelöst, in der Zeit und aufstehen falsch");
                      
                          // ##########################################################
                          //         ANSAGE Verögerung 10 sec
                          // ##########################################################
                      
                          setTimeout(function() {
                      
                            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
                      // ##################################################################
                      
                      
                          // 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
                          Ansage = APIsayKueche + Ansage + "/" + lautstaerke;       
                          
                          ansagenSonos(Ansage);//Funktion mit HttpGet in Global
                      
                         }, 15000);
                         // Ende timeout/ Verzögerung
                      
                      
                      //****************************************************************************************** */
                      
                      
                      //************************************************
                      //Javascript zum Schalten von Sonos via BewMldr
                      //************************************************
                      
                              /* Das folgende sind nur Befehle, die ich mir aufgehoben habe: 
                              // var idSonosfav = getState("sonos.0.root.192_168_0_63.favorites_list").val;      //speichern des aktuellen Senders
                              // var idSonosplay = getState ("sonos.0.root.192_168_0_63.state_simple").val;     //Status des Speakers
                              // laut = getState('sonos.0.root.' + raum + '.volume').val;
                              // log(idSonosfav);
                              // log(idSonosplay);*/
                      
                      
                      //*******************************************
                      //              Definitionen für Radio
                      //*******************************************
                      
                          // *******************************************************************************  
                          // Info zum Verzeichnis     /home/brs/node-sonos-http-api-master/static/says/;
                          // Definitionen MP3;
                          // herzlichWillkommen.mp3";
                          // var herz = "herzlichWillkommen.mp3";
                          // HundeGebell.mp3;
                          // var hund = "HundeGebell.mp3";
                          // Rolladen.mp3;
                          // var roll = "Rolladen.mp3";
                      
                          //AUFRUF:
                                  //Beispiel: http://192.168.0.105:5005/B%C3%BCro%20Ikea/favorite/RTL - Die besten Hits aller Zeiten
                      
                          
                          // IDsonosAufr = "http://192.168.0.105:5005/"<------hier richtige IP eintragen
                          
                          // Definition STRUKTUR
                          // Achtung, am Ende der Einzelteile des Aufrufs jeweils ein "7"
                          // IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender + laut
                              
                              //Favorites bzw. Sender
                              //IDsonosSender = "104.6 RTL Weihnachtsradio/"
                              //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                              //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                              //IDsonosSender = "RTL Deutschlands Hit-Radio/"
                      
                              //Definition Räume
                              // Definition raum Büro Ikea;
                              // IDsonosRaum ="B%C3%BCro%20Ikea/";
                      
                              // Definition raum Schlafzimmer;
                              // IDsonosRaum = "Schlafzimmer/";
                      
                              // Definition raum Kueche;
                              // IDsonosRaum = "K%C3%BCche/";
                      
                              // Definition raum Terrasse;
                              // IDsonosRaum = "Terrasse/";
                      
                              // Definition Funktionen
                              // IDsonosFunktion = "say/"
                              // IDsonosFunktion = "clip/"
                              // IDsonosFunktion = "favorite/"
                              // IDsonosFunktion = "pause"; <-------ohne "/"
                      
                       
                      
                          //STOP
                          //BEISPIEL: http://192.168.0.105:5005/B%C3%BCro%20Ikea/pause
                          //STRUKTUR: IDsonosAufr + IDsonosRaum + IDsonosFunktion
                      
                          // das ist der Aufruf
                          // ansagenSonos(radioAbspiel);
                          // Funktion mit HttpGet in Global
                      
                          // Anweisung setzen LAUTSTAERKE
                          // var laut = "8";//<------hier gewünschte LAUTSTÄRKE eintragen
                          
                          // *******************************************************************************  
                      
                      var IDsonosAufr = "http://192.168.0.105:5005/";
                      var IDsonosRaum = "K%C3%BCche/";
                      
                      
                      
                      
                          // ************************************************  
                          // Auswahl Radiosender
                              // Sender muß in Favoriten vorhanden sein
                              // momentan: 104.6 RTL Weihnachtsradio, RTL Deutschlands Hit-Radio, RTL - Die besten Hits aller Zeiten
                          // ************************************************
                          
                      var IDsonosSender = "RTL - Die besten Hits aller Zeiten/";
                      // var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;  
                      
                      setTimeout(function() {
                          // ************************************************
                          //  nach 60 sekunden starten
                          // ************************************************
                      
                      // Befehle ausführen
                      
                          // ************************************************
                          // Befehl zum play
                          // ************************************************
                      
                      
                      
                      var IDsonosFunktion = "favorite/";
                      var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;
                      
                      ansagenSonos(radioAbspiel);//Funktion mit HttpGet in Global
                      
                      // Lautstaeke einstellen 
                      var IDsonosFunktion = "volume/";
                      var laut = "8";
                      var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + laut;
                      
                      ansagenSonos(radioAbspiel);//Funktion mit HttpGet in Global
                      
                      // Ende lautstaerke
                      
                       
                      
                       }, 60000);
                         // Ende timeout für Start
                      
                      setTimeout(function() {
                          // ************************************************
                          // Befehl zum stop nach 45 Minuten
                          // ************************************************
                      
                      var IDsonosFunktion = "pause";
                      var radioAbspielStop = IDsonosAufr + IDsonosRaum + IDsonosFunktion; 
                      
                      log("radioAbspielStop--------------------->" + radioAbspielStop);
                      
                      ansagenSonos(radioAbspielStop);//Funktion mit HttpGet in Global
                      
                      }, 2700000);
                      // Ende timeout für Stop
                      
                      
                         }
                         // Ende If
                         
                      });
                      
                      
                          // ####################################################
                          //     var "aufstehen" zurücksetzen auf false um 3 Uhr
                          // ####################################################
                      
                      
                      schedule('0 3 * * *', function() {
                         aufstehen = false;
                      });
                      

                      hier ist das zugehörige globale Script resp Function:

                      function ansagenSonos(url) {
                          httpGet(url, {timeout: 30000}, (error) => {
                              if(error) {
                                  console.error(error);
                              }        
                          });
                      }
                      

                      Das Merkwürdige ist, es löst nicht aus. Ich habe mir zum debuggen schon logs eingefügt:

                      log("Motion ausgelöst");
                      
                      und
                      
                      log("Motion ausgelöst, in der Zeit und aufstehen falsch");
                      

                      Es kommt aber nur "Motion ausgelöst", also wird die if Aweisung nicht zutreffend ausgelöst.

                      Dieses "alte" Script mit "request" funktioniert dagegen perfekt:

                      // ##################################################################
                      
                      //        Erst Ansage, dann Radio ein u. nach 45 min aus
                      
                      // ##################################################################
                      
                      
                      
                      // ##################################################################
                      //                      Definitionen Ansage
                      // ##################################################################
                      
                      
                      // Quellen
                      var idWetter =           "hm-rega.0.29954";
                      var idTemperatursensor = 'hm-rpc.0.OEQ1296052.1.TEMPERATURE'/*Außentemperatur:1 TEMPERATURE*/
                      // var idSayVar = "hm-rega.0.38101";//Variable Sayit  <= Alt, wenn Steuerung via CCU Variable;
                      var idBM = 'hm-rpc.0.JEQ0266058.1.MOTION'/*BewMldr Treppenhaus:1 MOTION*/
                      
                      // 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 Lautstärke;
                          var lautstaerke = "50";
                      
                      var aufstehen = false;
                      
                      // ####################################################
                      //          Funktionen (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<=17){Begr = "Guten Tag"};
                              if(stunde>17){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]
                              };
                          }
                      
                      // ##########################################################
                      //         ANSAGE (GETRIGGERT via BewMldr)
                      //  EINMALIG im Zeitraum 6:00 - 10:00, wenn BewMldr
                      // ##########################################################
                      
                      
                      on(idBM, function(dp) {
                         if(dp.state.val && compareTime('6:00', '10:00', 'between') && !aufstehen) {
                            aufstehen = true;
                      
                          // ##########################################################
                          //         ANSAGE Verögerung 10 sec
                          // ##########################################################
                      
                          setTimeout(function() {
                      
                            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
                      // ##################################################################
                      
                      
                          // 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
                          Ansage = APIsayKueche + Ansage + "/" + lautstaerke;       
                          
                          try {
                          require("request")(Ansage).on("error", function (e) {console.error(e);});
                              } catch (e) { console.error(e); };
                      
                         }, 15000);
                         // Ende timeout/ Verzögerung
                      
                      
                      //****************************************************************************************** */
                      
                      
                      //************************************************
                      //Javascript zum Schalten von Sonos via BewMldr
                      //************************************************
                      
                              /* Das folgende sind nur Befehle, die ich mir aufgehoben habe: 
                              // var idSonosfav = getState("sonos.0.root.192_168_0_63.favorites_list").val;      //speichern des aktuellen Senders
                              // var idSonosplay = getState ("sonos.0.root.192_168_0_63.state_simple").val;     //Status des Speakers
                              // laut = getState('sonos.0.root.' + raum + '.volume').val;
                              // log(idSonosfav);
                              // log(idSonosplay);*/
                      
                      
                      //*******************************************
                      //              Definitionen für Radio
                      //*******************************************
                      
                          // *******************************************************************************  
                          // Info zum Verzeichnis     /home/brs/node-sonos-http-api-master/static/says/;
                          // Definitionen MP3;
                          // herzlichWillkommen.mp3";
                          // var herz = "herzlichWillkommen.mp3";
                          // HundeGebell.mp3;
                          // var hund = "HundeGebell.mp3";
                          // Rolladen.mp3;
                          // var roll = "Rolladen.mp3";
                      
                          //AUFRUF:
                                  //Beispiel: http://192.168.0.105:5005/B%C3%BCro%20Ikea/favorite/RTL - Die besten Hits aller Zeiten
                      
                          
                          // IDsonosAufr = "http://192.168.0.105:5005/"<------hier richtige IP eintragen
                          
                          // Definition STRUKTUR
                          // Achtung, am Ende der Einzelteile des Aufrufs jeweils ein "7"
                          // IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender + laut
                              
                              //Favorites bzw. Sender
                              //IDsonosSender = "104.6 RTL Weihnachtsradio/"
                              //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                              //IDsonosSender = "RTL - Die besten Hits aller Zeiten/"
                              //IDsonosSender = "RTL Deutschlands Hit-Radio/"
                      
                              //Definition Räume
                              // Definition raum Büro Ikea;
                              // IDsonosRaum ="B%C3%BCro%20Ikea/";
                      
                              // Definition raum Schlafzimmer;
                              // IDsonosRaum = "Schlafzimmer/";
                      
                              // Definition raum Kueche;
                              // IDsonosRaum = "K%C3%BCche/";
                      
                              // Definition raum Terrasse;
                              // IDsonosRaum = "Terrasse/";
                      
                              // Definition Funktionen
                              // IDsonosFunktion = "say/"
                              // IDsonosFunktion = "clip/"
                              // IDsonosFunktion = "favorite/"
                              // IDsonosFunktion = "pause"; <-------ohne "/"
                      
                       
                      
                          //STOP
                          //BEISPIEL: http://192.168.0.105:5005/B%C3%BCro%20Ikea/pause
                          //STRUKTUR: IDsonosAufr + IDsonosRaum + IDsonosFunktion
                      
                          // das ist der Aufruf
                          //try {
                          //    require("request")(abspielSchlaf).on("error", function (e) {console.error(e);});
                          //        } catch (e) { console.error(e); };
                      
                          // Anweisung setzen LAUTSTAERKE
                          // var laut = "8";//<------hier gewünschte LAUTSTÄRKE eintragen
                          
                          // *******************************************************************************  
                      
                      var IDsonosAufr = "http://192.168.0.105:5005/";
                      var IDsonosRaum = "K%C3%BCche/";
                      
                      
                      
                      
                          // ************************************************  
                          // Auswahl Radiosender
                              // Sender muß in Favoriten vorhanden sein
                              // momentan: 104.6 RTL Weihnachtsradio, RTL Deutschlands Hit-Radio, RTL - Die besten Hits aller Zeiten
                          // ************************************************
                          
                      var IDsonosSender = "RTL - Die besten Hits aller Zeiten/";
                      // var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;  
                      
                      setTimeout(function() {
                          // ************************************************
                          //  nach 60 sekunden starten
                          // ************************************************
                      
                      // Befehle ausführen
                      
                          // ************************************************
                          // Befehl zum play
                          // ************************************************
                      
                      
                      
                      var IDsonosFunktion = "favorite/";
                      var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + IDsonosSender;
                      
                      try {
                              require("request")(radioAbspiel).on("error", function (e) {console.error(e);});
                                  } catch (e) { console.error(e); };
                      
                      // Lautstaeke einstellen 
                      var IDsonosFunktion = "volume/";
                      var laut = "8";
                      var radioAbspiel = IDsonosAufr + IDsonosRaum + IDsonosFunktion + laut;
                      
                      try {
                              require("request")(radioAbspiel).on("error", function (e) {console.error(e);});
                                  } catch (e) { console.error(e); };
                      // Ende lautstaerke
                      
                       
                      
                       }, 60000);
                         // Ende timeout für Start
                      
                      setTimeout(function() {
                          // ************************************************
                          // Befehl zum stop nach 45 Minuten
                          // ************************************************
                      
                      var IDsonosFunktion = "pause";
                      var radioAbspielStop = IDsonosAufr + IDsonosRaum + IDsonosFunktion; 
                      
                      log("radioAbspielStop--------------------->" + radioAbspielStop);
                      
                      try {
                              require("request")(radioAbspielStop).on("error", function (e) {console.error(e);});
                                  } catch (e) { console.error(e); };
                      
                      }, 2700000);
                      // Ende timeout für Stop
                      
                      
                         }
                         // Ende If
                         
                      });
                      
                      
                          // ####################################################
                          //     var "aufstehen" zurücksetzen auf false um 3 Uhr
                          // ####################################################
                      
                      
                      schedule('0 3 * * *', function() {
                         aufstehen = false;
                      });
                      

                      Ich finde einfach den Fehler nicht. Würdest Du bitte mal drüberschauen?

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

                      @skorpil sagte: Es kommt aber nur "Motion ausgelöst",

                      Dann wird getriggert. Ich kann keinen Fehler erkennen. Logge mal aufstehen bevor es auf true gesetzt wird.

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

                      S 1 Reply Last reply
                      0
                      • paul53P paul53

                        @skorpil sagte: Es kommt aber nur "Motion ausgelöst",

                        Dann wird getriggert. Ich kann keinen Fehler erkennen. Logge mal aufstehen bevor es auf true gesetzt wird.

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

                        @paul53 Danke. okay, ich werde aufstehen loggen

                        Die quasi ineinander geschachtelten timeouts, in der globalen Function
                        "{timeout: 30000}"
                        und in Zeile 207 im Script von 15 Sekunden
                        " }, 15000)"
                        sind okay?

                        paul53P 1 Reply Last reply
                        0
                        • S skorpil

                          @paul53 Danke. okay, ich werde aufstehen loggen

                          Die quasi ineinander geschachtelten timeouts, in der globalen Function
                          "{timeout: 30000}"
                          und in Zeile 207 im Script von 15 Sekunden
                          " }, 15000)"
                          sind okay?

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

                          @skorpil sagte: sind okay?

                          Die Timeouts haben nichts miteinander zu tun. Das Timeout in httpGet verzögert nicht, sondern gibt vor, wie lange gewartet wird, bis mit einer Fehlermeldung abgebrochen wird.

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

                          S 2 Replies Last reply
                          0
                          • paul53P paul53

                            @skorpil sagte: sind okay?

                            Die Timeouts haben nichts miteinander zu tun. Das Timeout in httpGet verzögert nicht, sondern gibt vor, wie lange gewartet wird, bis mit einer Fehlermeldung abgebrochen wird.

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

                            @paul53 feedback ist ja bekanntlich breakfast for champions: es geschehen noch Zeiten und Wunder. Ich hab keine Ahnung, warum. Aber heute Morgen hat das Script so ausgelöst, wie ich es gewünscht habe . Ich habe gestern nur die logs für „aufstehen“ hinzugefügt, um heute Morgen zu sehen, wie sich das Skript verhält und, Überraschung, es funktioniert. Manchmal habe ich den Eindruck, iobroker spielt ein Spiel mit mir. Nochmals vielen Dank für die Hilfe und ein schönes Wochenende.

                            1 Reply Last reply
                            0
                            • paul53P paul53

                              @skorpil sagte: sind okay?

                              Die Timeouts haben nichts miteinander zu tun. Das Timeout in httpGet verzögert nicht, sondern gibt vor, wie lange gewartet wird, bis mit einer Fehlermeldung abgebrochen wird.

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

                              @paul53 ich komme noch einmal zurück auf dieses Thema. Gestern habe ich nodejs von 18 auf 20 angehoben. Jetzt erhalte ich bei der Script Ausführung die Fehlermeldung „socket hang up“. Und, es funktioniert auch nicht mehr. Was kann ich tun?

                              paul53P Ro75R 2 Replies Last reply
                              0
                              • S skorpil

                                @paul53 ich komme noch einmal zurück auf dieses Thema. Gestern habe ich nodejs von 18 auf 20 angehoben. Jetzt erhalte ich bei der Script Ausführung die Fehlermeldung „socket hang up“. Und, es funktioniert auch nicht mehr. Was kann ich tun?

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

                                @skorpil sagte: Fehlermeldung „socket hang up“.

                                Die Fehlermeldung kenne ich nicht. Node.js 20 verwende ich schon seit einiger Zeit.

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

                                S 1 Reply Last reply
                                1
                                • S skorpil

                                  @paul53 ich komme noch einmal zurück auf dieses Thema. Gestern habe ich nodejs von 18 auf 20 angehoben. Jetzt erhalte ich bei der Script Ausführung die Fehlermeldung „socket hang up“. Und, es funktioniert auch nicht mehr. Was kann ich tun?

                                  Ro75R Online
                                  Ro75R Online
                                  Ro75
                                  wrote on last edited by
                                  #93

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

                                  Fehlermeldung „socket hang up“.

                                  finde das Skript und die URL die aufgerufen wird. Eventuell gibt es in dem Moment Probleme mit der URL oder der Art wie diese aufgerufen wird.

                                  Wenn gefunden, dann hier mal bitte Details. Hat definitiv nichts mit nodejs 18 oder 20.

                                  Ro75.

                                  SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

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

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

                                    finde das Skript und die URL die aufgerufen wird. Eventuell gibt es in dem Moment Probleme mit der URL oder der Art wie diese aufgerufen wird.
                                    Wenn gefunden, dann hier mal bitte Details

                                    Das Script habe ich am 1. Juni 2024, 10:23 weiter oben gepostet. Merkwürdig, dass esbis zum nodejs update vernünftig gearbeitet hat....

                                    1 Reply Last reply
                                    0
                                    • paul53P paul53

                                      @skorpil sagte: Fehlermeldung „socket hang up“.

                                      Die Fehlermeldung kenne ich nicht. Node.js 20 verwende ich schon seit einiger Zeit.

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

                                      @paul53 ich habe jetzt ausführlich getestet. Das ging gut, weil linux bei mir unter einer VM (Orcacle Virtualbox) läuft. So konnte ich auch auf "alte" Zustände zurückgreifen.

                                      Ich habe das upgrade von nodejs einmal via "iob nodejs-update 20" und einmal manuel über apt, wie hier beschrieben "Diskussion zum HowTo nodejs-Installation und upgrade" auf die 20 durchgeführt.

                                      Ergebnisse:

                                      • Im Verhalten führen beide upgrade Varianten zu gleichen Ergebnissen (was schon mal gut ist)

                                      • unter der Version 18 laufen meine Scripte komplett fehlerfrei durch

                                      • unter der 20er Version entsteht der Fehler "socket hang up"

                                      • es ist bemerkenswert, dass das Script fehlerfrei, also ohne "socket hang up", durchläuft, wenn ich es nach ca. 20 Sekunden erneut auslöse (wir sprechen noch immer von den Scripten, die ich am 1.Juni umd 10:23 hier gepostet habe). Dieses Verhalten ist reproduzierbar, ebenso die Tatsache, daß es beim ersten Auslösen stets die Fehlermeldung bringt.

                                      Hat irgendwer eine Idee, was ich testen, wo ich ansetzen könnte, um den bug (falls es überhaupt einer ist) zu finden, einzugrenzen oder zu eliminieren? Oder mit wem ich dieses Problem diskutieren resp. in welchem threat ich es melden sollte?

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


                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      625

                                      Online

                                      32.4k

                                      Users

                                      81.3k

                                      Topics

                                      1.3m

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

                                      • Don't have an account? Register

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