Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Yahka Rolläden mit KNX

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Yahka Rolläden mit KNX

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

      Mit den beiden skripten geht es.

      Man könnte das skript noch abkürzen, das sich immer nur eine Variable ändern muss nicht hin und her.

      Es ist aber sehr aufwändig.

      Interessanter wäre vll eine globale funktion, die für alle die Umrechnung macht.

      Sprich das man im yahka dann als ID nicht nur die ID angibt sondern es dort direkt mit der Funktion verbindet.

      So hätte das skript einmalig im IoBroker ohne erstmal den yahka zu ändern.

      Gesendet von iPhone mit Tapatalk

      1 Reply Last reply Reply Quote 0
      • Dutchman
        Dutchman Developer Most Active Administrators last edited by

        @Matze1708:

        Mit den beiden skripten geht es.

        Man könnte das skript noch abkürzen, das sich immer nur eine Variable ändern muss nicht hin und her.

        Es ist aber sehr aufwändig.

        Interessanter wäre vll eine globale funktion, die für alle die Umrechnung macht.

        Sprich das man im yahka dann als ID nicht nur die ID angibt sondern es dort direkt mit der Funktion verbindet.

        So hätte das skript einmalig im IoBroker ohne erstmal den yahka zu ändern.

        Gesendet von iPhone mit Tapatalk `

        Jup also weiterspielen ! 🙂

        Ich habe mal angefangen was zusammen zu basteln, die grund idee:

        • wir pakken all eine rolladen in eine enum function.rolladen "rolladen" (als einfach in iObroker die states im reiter objecte an den wert rolladen zuweisen

        • wir lesen den inhalt dieser enum.function aus mit dem wert rolladen

        • jetzt bekommen wir eine listen mit alle states der rolladen

        • daraus machen wir automatisch fuer jeden einen neuen state fuer die berechnungen

        Die logic dazu habe ich bereits (siehe hier unten)

        jetzt muss noch:

        • mit einem regxp al diese states auf aenderungen ueberwacht werden und dan halt in das richtige KNX object geschrieben (kannst du mich noch ein bisschen folgen ? 🙂

        koenntest du mal bei dir die enum erstellen mit namen rolladen und probieren ob das script auch laueft.

        (nach erstellen der enum javascript adapter neu starten !)

        `// Auslesen aller functionen und einlesen in einer variable
        functions = getEnums('functions');
        
        // loop ueber die fuctionen und suchen nach den rolladen
        for (var i in functions){
            if (functions[i].name == 'rolladen'){
                var rolladen = functions[i].members;
        
                }
        
            }
        
        str = " ' " + rolladen + " ' ";
        var str_array = str.split(',');
        for(var i = 0; i < str_array.length; i++) {
           // Trim the excess whitespace.
           str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
           // Add additional code here, such as:
           log(str_array[i]);
        }`
        
        Wen du die enum richtig erstellt hast, die states zugeweisen und das script laueft sollten um log al deine KNX objecte der rolladen kommen.
        
         ![979_enum_erstellen.jpg](/assets/uploads/files/979_enum_erstellen.jpg) 
        
         ![979_func_zuweisen.jpg](/assets/uploads/files/979_func_zuweisen.jpg) [/i][/i][/i][/i][/i]
        
        1 Reply Last reply Reply Quote 0
        • Dutchman
          Dutchman Developer Most Active Administrators last edited by

          edit: script ergaenzt damit name und wert dese states im log kommt

          also soweit so gut, damit koennen wir die variable schonmal fuellen und mit dem states aus KNX objecten.

          (grrr schwierig das zu emulieren so wen man selber die geraete/objecte nicht hat…. )

          `// Auslesen aller functionen und einlesen in einer variable
          functions = getEnums('functions');
          
          // loop ueber die fuctionen und suchen nach den rolladen
          for (var i in functions){
              if (functions[i].name == 'rolladen'){
                  var rolladen = functions[i].members;
          
                  }
          
              }
          
          str = " ' " + rolladen + " ' ";
          var str_array = str.split(',');
          for(var i = 0; i < str_array.length; i++) {
             // Trim the excess whitespace.
             str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
             // Add additional code here, such as:
             log("ObjectId = " + str_array[i] + ", Wert = " + (getState(str_array[i]).val));
          }` [/i][/i][/i][/i][/i][/i]
          
          1 Reply Last reply Reply Quote 0
          • M
            Matze1708 last edited by

            Hallo,

            Ganz kapiert habe ich es noch nicht.

            Also dieses enum ergzeugt states ?

            Das wort Rolladen im code was bewirkt das? Alle Rolläden suchen im Knx?

            Gesendet von iPhone mit Tapatalk

            1 Reply Last reply Reply Quote 0
            • Dutchman
              Dutchman Developer Most Active Administrators last edited by

              @Matze1708:

              Hallo,

              Ganz kapiert habe ich es noch nicht.

              Also dieses enum ergzeugt states ?

              Das wort Rolladen im code was bewirkt das? Alle Rolläden suchen im Knx?

              Gesendet von iPhone mit Tapatalk `

              ja, also due packst all deine states der rolladen in eine enum die rolladen heist.

              Das script such dan nach alle states die in dieser enum sind und ich baue gerade and der function um fuer jeden rolladen ein neues object zu erstellen.

              In diesem objecten legen wir dan den umgedrehten wert rein

              1 Reply Last reply Reply Quote 0
              • M
                Matze1708 last edited by

                Entschuldigung aber was macht das enum?

                Gesendet von iPhone mit Tapatalk

                1 Reply Last reply Reply Quote 0
                • Dutchman
                  Dutchman Developer Most Active Administrators last edited by

                  @Matze1708:

                  Entschuldigung aber was macht das enum?

                  Gesendet von iPhone mit Tapatalk `

                  er versammelt alle deine rollenlaeden, damit bekommen wir ein "array" was wir dan im script benutzen koennen um die noetigen states zu erstellen

                  1 Reply Last reply Reply Quote 0
                  • M
                    Matze1708 last edited by

                    ich kann dieses Enum bei mir nicht finden.

                    Wo versteckt sich das?

                    1 Reply Last reply Reply Quote 0
                    • Dutchman
                      Dutchman Developer Most Active Administrators last edited by

                      @Matze1708:

                      ich kann dieses Enum bei mir nicht finden.

                      Wo versteckt sich das? `

                      Klik mal oben rechts auf den bleistift dan kannst du den reiter hinzufügen

                      –-----------------------

                      Send from mobile device

                      1 Reply Last reply Reply Quote 0
                      • M
                        Matze1708 last edited by

                        Ich finde nur unter Aufzählung enum.rooms

                        1 Reply Last reply Reply Quote 0
                        • Dutchman
                          Dutchman Developer Most Active Administrators last edited by

                          @Matze1708:

                          Ich finde nur unter Aufzählung enum.rooms `

                          dan den enum manuell erstellen:

                          979_enum_functions.jpg

                          1 Reply Last reply Reply Quote 0
                          • M
                            Matze1708 last edited by

                            das habe ich. und wie kommen die States aus KNX dort hin?

                            1 Reply Last reply Reply Quote 0
                            • Dutchman
                              Dutchman Developer Most Active Administrators last edited by

                              @Matze1708:

                              das habe ich. und wie kommen die States aus KNX dort hin? `

                              • function rolladen erstellt ?

                              • meine screenshots gesehen in diesem post: http://forum.iobroker.net/viewtopic.php … 405#p94365 ? 🙂

                              ~Dutch

                              1 Reply Last reply Reply Quote 0
                              • Dutchman
                                Dutchman Developer Most Active Administrators last edited by

                                Hey @Matze1708,

                                Hat es geklappt ? Ich habe das script jetzt erweitert damit er alle states erstellt und den jetzigen wert syncronisiert.

                                Jetzt fehlt in grundegenommen nur noch die function um die wert zum updaten wen sich was aendert.

                                das resultat sollte sein das bei dir bei den objecten unter javascript ein ordner erstellt wird "rolladen_reversed_values" mit darin al deine KNX geraete die du an die enum.function rolladen verknuepft hast

                                `// Read all enums related to enum.functions
                                functions = getEnums('functions');
                                
                                // Loop on all values and store members of function "rolladen" to variable
                                for (var i in functions){
                                    if (functions[i].name == 'rolladen'){
                                        var rolladen = functions[i].members;
                                        }
                                    }
                                
                                //Seperate values in variable "rolladen" to seperate devices
                                //and create new objects reflecting all current devies and states for "rolladen" in javascript tree
                                str = " ' " + rolladen + " ' ";
                                var str_array = str.split(',');
                                for(i = 0; i < str_array.length; i++) {
                                    str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
                                
                                	try{
                                
                                        //retrieve device name for all found devices
                                        var objname = getObject(str_array[i]).common.name;
                                        var objvalue = getState(str_array[i]).val;
                                        var revName = getObject(str_array[i]).common.name + '_reversed';
                                
                                        //Check if object already exist, otherwise create and sync current value
                                		if (typeof(getIdByName(revName)) === 'undefined') {
                                
                                        createState("rolladen_reversed_values." + objname, objvalue, {
                                            name: revName,
                                            read: true,
                                            write: true,
                                            min: 0,
                                            max: 100,
                                            type: 'number',
                                            role: 'level.hight',
                                            unit: "%",
                                            linkorigin: str_array[i]
                                            });
                                        }
                                        }   catch(e){}   
                                
                                }` [/i][/i][/i][/i][/i][/i][/i][/i]
                                
                                1 Reply Last reply Reply Quote 0
                                • Dutchman
                                  Dutchman Developer Most Active Administrators last edited by

                                  Geschafft ! :mrgreen: :mrgreen: :mrgreen:

                                  Erhoffe mir das du was dran hast, wen nicht war es fuer mich auf jedenfall eine super gelegenheit einige sachen im javascript zu entdecken die ich noch nicht wusste und bereits seit langen auf meiner to-do stand 8-)

                                  Also mein script setzt voraus das alle deine KNX werte der rollaeden in die enum.functions.rolladen aufgenommen sind

                                  Dan sorgt das script fuer:

                                  • anlegen aller states inter javascript.rolladen_reversed_values

                                  • wen ein wert sich dort aendert, wird automatisch der wert in der source (KNX bei dir) geaendert, hierbei rechnet er um

                                  • wen ein wert sich in de KNX objecten aendert, wird automatisch der wert in der reverse geaendert, hierbei rechnet er auch um

                                  das ergebnis sollte also sein das:

                                  • du deine rollaeden mit den reverse werten in yahka integrierst

                                  • jede aenderung da umgerechnet wird und auf KNX gebracht

                                  • andersum genauso, aendert sich was in KNX durch grund x wird der wert den yahka benutzt geaenert.

                                  hier mal eine kleine vid in gif dieser function

                                  979_reverse.gif

                                  Beim ersten start meldet er dir in der consoe welche objecte erstellt wurden: "New object " xxx " created within " xxx "".

                                  Das schalten selben zeigt er nur wen dein loglevel auf debug steht, dan verraeht er auch was empfangen wurden + die umrechnung

                                  value change based on Yahka trigger, received value = 20 ,calculated to = 80
                                  value change based on KNX trigger, received value = 10 ,calculated to = 90
                                  
                                  

                                  Und hier das script

                                  `//******************************************
                                  //*****************Dutchman*****************
                                  //*revert values to use KNX shutters with yahka*
                                  //*******************V 0.6****************** 
                                  //******************************************
                                  //******************************************
                                  
                                  // Read all enums related to enum.functions
                                  functions = getEnums('functions');
                                  
                                  // Loop on all values and store members of function "rolladen" to variable
                                  for (var i in functions){
                                      if (functions[i].name == 'rolladen'){
                                          var rolladen = functions[i].members;
                                  
                                      }
                                  
                                  }
                                  
                                  //Seperate values in variable "rolladen" to seperate devices
                                  //and create new objects reflecting all current devies and states for "rolladen" in javascript tree
                                  str = " ' " + rolladen + " ' ";
                                  var str_array = str.split(',');
                                  for(i = 0; i < str_array.length; i++) {
                                      str_array[i] = str_array[i].replace(/^\s*/, "").replace(/\s*$/, "");
                                  
                                  	try{
                                  
                                          //retrieve device name for all found devices
                                          var objname = getObject(str_array[i]).common.name;
                                          var objvalue = 100 - getState(str_array[i]).val;
                                          var revName = getObject(str_array[i]).common.name + '_reversed';
                                  
                                          //Check if object already exist, otherwise create and sync current value
                                  		if (typeof(getIdByName(revName)) === 'undefined') {
                                  
                                              createState("rolladen_reversed_values." + objname, objvalue, {
                                                  name: revName,
                                                  read: true,
                                                  write: true,
                                                  min: 0,
                                                  max: 100,
                                                  type: 'number',
                                                  role: 'level.hight',
                                                  unit: "%",
                                                  linkorigin: str_array[i]
                                  
                                              });
                                  
                                              log('New object  "' + revName + '"  created within "rolladen_reversed_values"');
                                  
                                  		}
                                  
                                  	}   catch(e){}   
                                  
                                  }
                                  
                                  // Trigger on value change in reverse values and syncronise to origin
                                  on({id: /^javascript.1.rolladen_reversed_values\./, change: "ne"}, function (obj) {
                                  
                                      //reverse value from Yahka to KNX logic
                                      var newvalue = 100 - obj.state.val;
                                  
                                      //verify is calculated value is different, if yes update Yahka value to reversed object otherwise do nothing
                                      if (newvalue !== getState(obj.common.linkorigin).val){
                                          setState (obj.common.linkorigin, newvalue);
                                          console.debug('value change based on Yahka trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                                  
                                      }
                                  
                                  });
                                  
                                  // Trigger on value change in origin values and syncronise to reverse values
                                  on({enumName: 'rolladen', change: "ne"}, function (obj) {
                                  
                                      //reverse value from KNX to Yahka logic
                                      var newvalue = 100 - obj.state.val;
                                  
                                      //verify is calculated value is different, if yes update KNX value to reversed object otherwise do nothing
                                      if (newvalue !== getState("rolladen_reversed_values." + obj.common.name).val){
                                          setState("rolladen_reversed_values." + obj.common.name, newvalue, true);
                                          console.debug('value change based on KNX trigger, received value = ' + obj.state.val + ' ,calculated to = ' + newvalue);
                                  
                                      }
                                  
                                  });` [/i][/i][/i][/i][/i][/i][/i][/i]
                                  
                                  1 Reply Last reply Reply Quote 0
                                  • M
                                    Matze1708 last edited by

                                    Sau stark!

                                    Ich versuche es mal morgen einzubauen.

                                    Ich gebe info.

                                    Einbinden muss ich aber immer die JavaScript objecte oder?

                                    1 Reply Last reply Reply Quote 0
                                    • Dutchman
                                      Dutchman Developer Most Active Administrators last edited by

                                      @Matze1708:

                                      Einbinden muss ich aber immer die JavaScript objecte oder? `

                                      Im yahka? Jup

                                      –-----------------------

                                      Send from mobile device

                                      1 Reply Last reply Reply Quote 0
                                      • M
                                        Matze1708 last edited by

                                        Hallo,

                                        das hier ist meine Ausgabe im Log:

                                        Drücke Strg+A und danach Strg+C, um den Inhalt in die Zwischenablage zu kopieren. Klicke irgendwo, um das Fenster zu schliessen.
                                        javascript.0	2017-11-07 17:41:21.609	info	script.js.Rolläden.Schlaf2_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:21.607	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:21.441	info	Start javascript script.js.Rolläden.Schlaf2_Status
                                        javascript.0	2017-11-07 17:41:21.438	info	script.js.Rolläden.Schlaf1_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:21.436	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:21.270	info	Start javascript script.js.Rolläden.Schlaf1_Pos
                                        javascript.0	2017-11-07 17:41:21.268	info	script.js.Rolläden.Kind_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:21.266	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:21.098	info	Start javascript script.js.Rolläden.Kind_Pos
                                        javascript.0	2017-11-07 17:41:21.096	info	script.js.Rolläden.Kind_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:21.093	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:20.927	info	Start javascript script.js.Rolläden.Kind_Status
                                        javascript.0	2017-11-07 17:41:20.924	info	script.js.Rolläden.Schlaf2_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:20.921	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:20.757	info	Start javascript script.js.Rolläden.Schlaf2_Pos
                                        javascript.0	2017-11-07 17:41:20.754	info	script.js.Rolläden.Schlaf1_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:20.752	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:20.590	info	Start javascript script.js.Rolläden.Schlaf1_Status
                                        javascript.0	2017-11-07 17:41:20.588	info	script.js.Rolläden.Büro_OG_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:20.586	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:20.424	info	Start javascript script.js.Rolläden.Büro_OG_Status
                                        javascript.0	2017-11-07 17:41:20.422	info	script.js.Rolläden.Büro_OG_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:20.419	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:20.251	info	Start javascript script.js.Rolläden.Büro_OG_Pos
                                        javascript.0	2017-11-07 17:41:20.249	info	script.js.Rolläden.Essen_Pos(4): registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:20.246	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:20.085	info	Start javascript script.js.Rolläden.Essen_Pos(4)
                                        javascript.0	2017-11-07 17:41:20.082	info	script.js.Rolläden.Gaderobe_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:20.079	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:19.919	info	Start javascript script.js.Rolläden.Gaderobe_Pos
                                        javascript.0	2017-11-07 17:41:19.917	info	script.js.Rolläden.WZ_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:19.915	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:19.754	info	Start javascript script.js.Rolläden.WZ_Pos
                                        javascript.0	2017-11-07 17:41:19.751	info	script.js.Rolläden.Gaderobe_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:19.749	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:19.592	info	Start javascript script.js.Rolläden.Gaderobe_Status
                                        javascript.0	2017-11-07 17:41:19.590	info	script.js.Rolläden.WZ_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:19.587	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:19.395	info	Start javascript script.js.Rolläden.WZ_Status
                                        javascript.0	2017-11-07 17:41:19.394	info	script.js.Rolläden.WZ_Tür_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:19.391	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:19.231	info	Start javascript script.js.Rolläden.WZ_Tür_Status
                                        javascript.0	2017-11-07 17:41:19.229	info	script.js.Rolläden.WZ_Tür_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:19.226	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:19.071	info	Start javascript script.js.Rolläden.WZ_Tür_Pos
                                        javascript.0	2017-11-07 17:41:19.069	info	script.js.Rolläden.Essen_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:19.067	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:18.914	info	Start javascript script.js.Rolläden.Essen_Status
                                        javascript.0	2017-11-07 17:41:18.912	info	script.js.Rolläden.Küche_Status: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:18.909	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:18.750	info	Start javascript script.js.Rolläden.Küche_Status
                                        javascript.0	2017-11-07 17:41:18.748	info	script.js.Rolläden.Küche_Pos: registered 4 subscriptions and 0 schedules
                                        javascript.0	2017-11-07 17:41:18.739	warn	Object '' undefined '' does not exist
                                        javascript.0	2017-11-07 17:41:18.563	info	Start javascript script.js.Rolläden.Küche_Pos
                                        javascript.0	2017-11-07 17:41:18.460	info	received all objects
                                        javascript.0	2017-11-07 17:41:17.712	info	received all states
                                        javascript.0	2017-11-07 17:41:17.071	info	requesting all objects
                                        javascript.0	2017-11-07 17:41:17.067	info	requesting all states
                                        javascript.0	2017-11-07 17:41:17.054	info	starting. Version 3.2.6 in /opt/iobroker/node_modules/iobroker.javascript, node: v6.11.1
                                        javascript.0	2017-11-07 17:41:16.987	info	States connected to redis 127.0.0.1:6379
                                        host.ioBroker-RasPi	2017-11-07 17:41:14.245	info	instance system.adapter.javascript.0 started with pid 28595
                                        yahka.0	2017-11-07 17:41:11.710	info	objectChange system.adapter.javascript.0 {'_id':'system.adapter.javascript.0','type':'instance','common':{'name':'javascript','version':'3.2.6','title':'Javascript/Blockly Script Engine','titleLang':{'en':'Javascript/Blockly Script Engine','de':'Javascript/Blockly Skriptausführung','ru':'Javascript/Blockly Скрипты'},'authors':['bluefox ','hobbyquaker '],'news':{'3.3.5':{'en':'add the genitive month for formatDate','de':'Genitiv Monat für formatDate hinzugefügt','ru':'Добавлены месяцы в дательном падеже для formatDate'},'3.3.4':{'en':'Catch error by request if host unavailable','de':'Fange den Fehler ab, falls URL nicht online','ru':'Ловятся ошибки request, если адрес не доступен'},'3.3.3':{'en':'Fix stopScript','de':'Korrigiere stopScript','ru':'Исправлен stopScript'},'3.3.2':{'en':'Support of system coordinates','de':'Unterstützung von Systemkoordinaten','ru':'Поддержка системных настроек для координат'},'3.3.1':{'en':'fix error if no scripts exists','de':'Korrigiere das Problem, falls keine Skripte existieren','ru':'Исправлена ошибка, если нет никаких скриптов'},'3.3.0':{'en':'all callbacks in try/catch','de':'Alle Callbacks in try/catch','ru':'Все callbacks в try/catch'},'3.2.8':{'en':'Translations','de':'Übersetzungen','ru':'Перевод'},'3.2.7':{'en':'allow creation of states for other javascript instances','de':'Erlaube States-Erzeugung für andere Javascirpt-Instanzen','ru':'Можно создавать переменные для других Javascirpt экземпляров'},'3.2.6':{'en':'Fix import of scripts\nAsk to save before start the script','de':'Korrigiere Skriptimport\nFrage um Speichern bevor Skriptstart','ru':'Исправлен импорт скриптов\nСохранение скриптов прежде, чем запустить их'},'3.2.5':{'en':'Extend compareTime function with astro features','de':'Erweitere compareTime Funktion mit astro Möglichkeiten','ru':'Функция compareTime расширена astro возможностями'},'3.2.4':{'en':'fix stopScript','de':'Korrigiere stopScript','ru':'Исправлен stopScript'},'3.2.3':{'en':'Try to fix error with sayit','de':'Try to fix error with sayit','ru':'Try to fix error with sayit'},'3.2.2':{'en':'Allow with stopScript() to stop itself','de':'Ermögliche mit stopScript() sich anzuhalten','ru':'Позволяет при помощи stopScript() остановить сам скрипт'},'3.2.1':{'en':'Fix error with subscribe for only required states','de':'Korrigiere den Fahler mit dem Subscribe nur für benötigten States','ru':'Исправлена ошибка в подписвании только на необходимые объекты'},'3.2.0':{'en':'Fix error with of blocks in adapters\nSupport of subscribe for only required states','de':'Korrigiere den Fahler mit Blöcken in Adaptern\nUnterstützung von Subscribe nur für benötigten States','ru':'Исправлена ошибка в блоках при драйверах\nПоддержка режима, что подписваются только на необходимые объекты'},'3.1.0':{'en':'Support of blocks in adapters\nMove sendTo blocks into adapters','de':'Unterstützung von Blöcken in Adaptern\nVerschiebe sendTo Blöcke in Adaptern','ru':'Поддержка блоков в драйверах\nБлоки sendTo передвинуты в драйвера'},'3.0.10':{'en':'New blocks: compare time, write state\nDocumentation','de':'Neue Blöcke: Zeitvergleich, Zustand schreiben\nDokumentation ','ru':'Новые блоки: сравнение времени, запись в состояние\nДокументация'},'3.0.9':{'en':'Bugfixing of blockly','de':'Fehler korrigiert in Blockly','ru':'Исправлены ошибки в Blockly'},'3.0.7':{'en':'add ack for trigger in blockly\nadd block to get info about trigger\nstart description of blockly\nadd runScript functions\ndisable zoom on wheel in blockly\nfix block: time compare','de':'add ack for trigger in blockly\nadd block to get info about trigger\nstart description of blockly\nadd runScript functions\ndisable zoom on wheel in blockly\nfix block: time compare','ru':'add ack for trigger in blockly\nadd block to get info about trigger\nstart description of blockly\nadd runScript functions\ndisable zoom on wheel in blockly\nfix block: time compare'},'3.0.6':{'en':'add extendObject function\nadd custom sendTo block\nadd multiple trigger block','de':'Neue Funktion: extendObject\nNeuer Block: custom sendTo\nNeuer Block: multiple trigger','ru':'Добавлена функция extendObject\nДобавлен блок: custom sendTo\nДобавлен блок: multiple trigger'},'3.0.5':{'en':'Fix sendTo blocks','de':'Repariere sendTo Blöcke','ru':'Исправлены sendTo блоки'},'3.0.4':{'en':'Support of convert day of week into text in blockly','de':'Unterstützung von der Konvertierung des Wochentages in Text','ru':'Поддержка конвертирования дня недели в текст в blockly'},'3.0.3':{'en':'Fixed the convert date block','de':'Block für Datumkonevrtirung ist geändert','ru':'Поправлен блок конвертирования даты'},'3.0.2':{'en':'Change name of sandbox debug variable','de':'Ändere Name von Sandbox-Debug','ru':'Изменено имя Sandbox debug переменной'},'3.0.1':{'en':'Fix disabling of script','de':'Fix Deaktivierung vom Skript','ru':'Исправлена деактивация скрипта'},'3.0.0':{'en':'Beta Release with Blockly','de':'Beta Release mit Blockly','ru':'Бета релих с Blockly'},'2.3.4':{'en':'fix sayIt Block','de':'Repariere sayIt Block','ru':'Исправлен sayIt блок'},'2.3.3':{'en':'add more blockly modules\nadd debug mode and verbose mode','de':'add more blockly modules\nadd debug mode and verbose mode','ru':'add more blockly modules\nadd debug mode and verbose mode'},'2.3.1':{'en':'blockly support','de':'blockly support','ru':'blockly support'},'2.3.0':{'en':'export/import of scripts','de':'export/import of scripts','ru':'export/import of scripts'},'2.2.1':{'en':'fix delete state','de':'fix delete state','ru':'fix delete state'},'2.2.0':{'en':'adapter is compatible with redis','de':'adapter is compatible with redis','ru':'adapter is compatible with redis'},'2.1.9':{'en':'add for script onStop handler','de':'add for script onStop handler','ru':'add for script onStop handler'},'2.1.8':{'en':'do not show error if regexp ID','de':'do not show error if regexp ID','ru':'do not show error if regexp ID'},'2.1.7':{'en':'keep configured libraries by upgrade','de':'keep configured libraries by upgrade','ru':'keep configured libraries by upgrade'},'2.1.4':{'en':'catch an error if some system object changed, e.g. _design/history','de':'catch an error if some system object changed, e.g. _design/history','ru':'catch an error if some system object changed, e.g. _design/history'},'2.1.3':{'en':'fix warning with wrong types one more time','de':'fix warning with wrong types one more time','ru':'fix warning with wrong types one more time'},'2.1.2':{'en':'fix warning with wrong types','de':'fix warning with wrong types','ru':'fix warning with wrong types'}},'desc':'Javascript/Coffeescript Script Engine','platform':'Javascript/Node.js','mode':'daemon','loglevel':'info','icon':'js.jpeg','extIcon':'https://raw.githubusercontent.com/ioBroker/ioBroker.javascript/master/admin/js.jpeg','keywords':['js','javascript','coffeescript','rules','automate','scriptengine'],'readme':'https://github.com/iobroker/ioBroker.javascript/blob/master/README.md','license':'MIT','engineTypes':['Blockly','Javascript/js','Coffeescript/coffee'],'adminTab':{'singleton':true,'name':'Scripts'},'type':'script','installedVersion':'3.2.6','enabled':true,'host':'ioBroker-RasPi'},'native':{'latitude':'','longitude':'','enableSetObject':false,'libraries':'','subscribe':false,'useSystemGPS':true}}
                                        host.ioBroker-RasPi	2017-11-07 17:41:11.725	info	instance system.adapter.javascript.0 terminated with code 0 (OK)
                                        host.ioBroker-RasPi	2017-11-07 17:41:11.679	info	stopInstance system.adapter.javascript.0 killing pid 810
                                        host.ioBroker-RasPi	2017-11-07 17:41:11.678	info	stopInstance system.adapter.javascript.0
                                        javascript.0	2017-11-07 17:41:11.686	info	terminating
                                        host.ioBroker-RasPi	2017-11-07 17:41:11.667	info	object change system.adapter.javascript.0
                                        javascript.0	2017-11-07 17:41:05.743	info	Stop script script.js.global.Skript1
                                        
                                        

                                        geändert: Code in Code-Tags; Homoran (Mod)

                                        1 Reply Last reply Reply Quote 0
                                        • Dutchman
                                          Dutchman Developer Most Active Administrators last edited by

                                          @Matze1708:

                                          Sau stark!

                                          Ich versuche es mal morgen einzubauen.

                                          Ich gebe info.

                                          Einbinden muss ich aber immer die JavaScript objecte oder? `

                                          fuer mal bitten diesen code aus, was sagt dein log:

                                          `// Read all enums related to enum.functions
                                          functions = getEnums('functions');
                                          
                                          // Loop on all values and store members of function "rolladen" to variable
                                          for (var i in functions){
                                              if (functions[i].name == 'rolladen'){
                                                  var rolladen = functions[i].members;
                                          
                                          	log(rolladen)
                                          
                                              }
                                          
                                          }` [/i][/i]
                                          
                                          1 Reply Last reply Reply Quote 0
                                          • M
                                            Matze1708 last edited by

                                            wenn ich es global ausführe kommt ziemlich das gleiche wie eben.

                                            wenn ich es nicht global ausführe kommt das hier

                                            ` > javascript.0 2017-11-07 18:01:59.633 warn unsubscribe: empty name

                                            javascript.0 2017-11-07 18:01:59.630 info Stop script script.js.Rolläden.Skript1

                                            javascript.0 2017-11-07 18:01:54.337 info script.js.Rolläden.Skript1: registered 2 subscriptions and 0 schedules

                                            javascript.0 2017-11-07 18:01:54.335 warn Object "' undefined '" does not exist

                                            javascript.0 2017-11-07 18:01:54.165 info Start javascript script.js.Rolläden.Skript1 `

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            914
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

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