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.
    • 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
                • M
                  Matze1708 last edited by

                  Anbei 2 Bilder von dem enum
                  2486_bildschirmfoto_2017-11-07_um_18.04.00.png
                  2486_bildschirmfoto_2017-11-07_um_18.03.51.png

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

                    Führe Mal bitte den code aus 2 Post zurück

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

                    Send from mobile device

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

                      javascript.0	2017-11-07 18:16:41.242	info	script.js.Rolläden.Schlaf2_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.241	info	script.js.Rolläden.Schlaf2_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.241	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.241	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.241	info	Start javascript script.js.Rolläden.Schlaf2_Status
                      javascript.0	2017-11-07 18:16:41.240	info	script.js.Rolläden.Schlaf1_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.240	info	script.js.Rolläden.Schlaf1_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.240	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.240	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.239	info	Start javascript script.js.Rolläden.Schlaf1_Pos
                      javascript.0	2017-11-07 18:16:41.239	info	script.js.Rolläden.Kind_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.239	info	script.js.Rolläden.Kind_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.239	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.238	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.238	info	Start javascript script.js.Rolläden.Kind_Pos
                      javascript.0	2017-11-07 18:16:41.238	info	script.js.Rolläden.Kind_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.237	info	script.js.Rolläden.Kind_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.237	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.236	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.235	info	Start javascript script.js.Rolläden.Kind_Status
                      javascript.0	2017-11-07 18:16:41.235	info	script.js.Rolläden.Schlaf2_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.235	info	script.js.Rolläden.Schlaf2_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.235	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.234	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.234	info	Start javascript script.js.Rolläden.Schlaf2_Pos
                      javascript.0	2017-11-07 18:16:41.234	info	script.js.Rolläden.Schlaf1_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.234	info	script.js.Rolläden.Schlaf1_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.233	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.233	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.233	info	Start javascript script.js.Rolläden.Schlaf1_Status
                      javascript.0	2017-11-07 18:16:41.232	info	script.js.Rolläden.Büro_OG_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.232	info	script.js.Rolläden.Büro_OG_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.232	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.231	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.231	info	Start javascript script.js.Rolläden.Büro_OG_Status
                      javascript.0	2017-11-07 18:16:41.231	info	script.js.Rolläden.Büro_OG_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.230	info	script.js.Rolläden.Büro_OG_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.228	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.228	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.227	info	Start javascript script.js.Rolläden.Büro_OG_Pos
                      javascript.0	2017-11-07 18:16:41.227	info	script.js.Rolläden.Essen_Pos(4): registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.227	info	script.js.Rolläden.Essen_Pos(4): ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.226	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.226	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.226	info	Start javascript script.js.Rolläden.Essen_Pos(4)
                      javascript.0	2017-11-07 18:16:41.225	info	script.js.Rolläden.Gaderobe_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.225	info	script.js.Rolläden.Gaderobe_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.225	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.224	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.224	info	Start javascript script.js.Rolläden.Gaderobe_Pos
                      javascript.0	2017-11-07 18:16:41.218	info	script.js.Rolläden.WZ_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.218	info	script.js.Rolläden.WZ_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.217	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.216	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.216	info	Start javascript script.js.Rolläden.WZ_Pos
                      javascript.0	2017-11-07 18:16:41.215	info	script.js.Rolläden.Gaderobe_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.215	info	script.js.Rolläden.Gaderobe_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.215	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.214	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.214	info	Start javascript script.js.Rolläden.Gaderobe_Status
                      javascript.0	2017-11-07 18:16:41.213	info	script.js.Rolläden.WZ_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.213	info	script.js.Rolläden.WZ_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.212	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.212	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.211	info	Start javascript script.js.Rolläden.WZ_Status
                      javascript.0	2017-11-07 18:16:41.211	info	script.js.Rolläden.WZ_Tür_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.210	info	script.js.Rolläden.WZ_Tür_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.199	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.199	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.199	info	Start javascript script.js.Rolläden.WZ_Tür_Status
                      javascript.0	2017-11-07 18:16:41.198	info	script.js.Rolläden.WZ_Tür_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.198	info	script.js.Rolläden.WZ_Tür_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.198	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.198	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.197	info	Start javascript script.js.Rolläden.WZ_Tür_Pos
                      javascript.0	2017-11-07 18:16:41.197	info	script.js.Rolläden.Essen_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.197	info	script.js.Rolläden.Essen_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.196	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.195	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.195	info	Start javascript script.js.Rolläden.Essen_Status
                      javascript.0	2017-11-07 18:16:41.194	info	script.js.Rolläden.Küche_Status: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.192	info	script.js.Rolläden.Küche_Status: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.191	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.191	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.191	info	Start javascript script.js.Rolläden.Küche_Status
                      javascript.0	2017-11-07 18:16:41.190	info	script.js.Rolläden.Küche_Pos: registered 4 subscriptions and 0 schedules
                      javascript.0	2017-11-07 18:16:41.190	info	script.js.Rolläden.Küche_Pos: ObjectId = ' undefined ', Wert = null
                      javascript.0	2017-11-07 18:16:41.190	warn	State '' undefined '' not found
                      javascript.0	2017-11-07 18:16:41.190	warn	Object '' undefined '' does not exist
                      javascript.0	2017-11-07 18:16:41.189	info	Start javascript script.js.Rolläden.Küche_Pos
                      javascript.0	2017-11-07 18:16:37.949	info	Start javascript script.js.Rolläden.Küche_Pos
                      javascript.0	2017-11-07 18:16:37.882	info	received all objects
                      javascript.0	2017-11-07 18:16:37.219	info	received all states
                      javascript.0	2017-11-07 18:16:36.445	info	requesting all objects
                      javascript.0	2017-11-07 18:16:36.442	info	requesting all states
                      javascript.0	2017-11-07 18:16:36.428	info	starting. Version 3.2.6 in /opt/iobroker/node_modules/iobroker.javascript, node: v6.11.1
                      javascript.0	2017-11-07 18:16:36.361	info	States connected to redis 127.0.0.1:6379
                      

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

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

                        -Javascript Adapter neu gestartet nachdem du die enum erstellt und gefüllt hast?

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

                        Send from mobile device

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

                          Nein…. sorry....

                          ABER.... auch nach java adapter neustart, ändert sich nichts am LOG.

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

                            @Matze1708:

                            Nein…. sorry....

                            ABER.... auch nach java adapter neustart, ändert sich nichts am LOG. `

                            Hast ne PN von mir

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

                            Send from mobile device

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

                              da war noch ein kleiner fehler im script, probier mal version 0.8

                              `//******************************************
                              //*****************Dutchman*****************
                              //****revert values to use KNX with yahka***
                              //*******************V 0.8****************** 
                              //******************************************
                              //******************************************
                              
                              // 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, replace empty spaces in name by _
                                      var objnameT =  getObject(str_array[i]).common.name;
                                      var objname = objnameT.split(' ').join('_');
                                      var objvalue = 100 - getState(str_array[i]).val;
                                      var revName = objname + '_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;
                                  var objnameT =  obj.common.name;
                                  var objname = objnameT.split(' ').join('_');
                              
                                  //verify is calculated value is different, if yes update KNX value to reversed object otherwise do nothing
                                  if (newvalue !== getState("rolladen_reversed_values." + objname).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]
                              
                              1 Reply Last reply Reply Quote 0
                              • Dutchman
                                Dutchman Developer Most Active Administrators last edited by

                                So dar waren noch ein par fehlelr drin, mit zusammenarbeit dan im 0.9 geloest.

                                Wen jemand interessiert ist hier das fertige script, gehen bestimmt sachen besser (tips wilkommen) aber es laeuft soweit 🙂

                                `//******************************************
                                //*****************Dutchman*****************
                                //****revert values to use KNX with yahka***
                                //*******************V 0.9****************** 
                                //******************************************
                                //******************************************
                                
                                // 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, replace empty spaces in name by _
                                        var objnameT =  getObject(str_array[i]).common.name;
                                        var objname = objnameT.split(' ').join('_');
                                        var objvalue = 100 - getState(str_array[i]).val;
                                        var revName = objname + '_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.0.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){
                                
                                        log("object trigger reverses nach IF");
                                        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;
                                    var objnameT =  obj.common.name;
                                    var objname = objnameT.split(' ').join('_');
                                
                                    //verify is calculated value is different, if yes update KNX value to reversed object otherwise do nothing
                                    if (newvalue !== getState("rolladen_reversed_values." + objname).val){
                                
                                        setState("rolladen_reversed_values." + objname, 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]
                                
                                1 Reply Last reply Reply Quote 0
                                • Dutchman
                                  Dutchman Developer Most Active Administrators last edited by

                                  Der Entwickler des Adapters hat soeben auf github die Nachricht erstellt das yahka dies zukünftig Standard Unterstützung.

                                  Wer möchte kann bereits die github Version benutzen um zu testen

                                  Danke an den Entwickler !

                                  https://github.com/jensweigele/ioBroker … -351852394

                                  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

                                  805
                                  Online

                                  31.9k
                                  Users

                                  80.1k
                                  Topics

                                  1.3m
                                  Posts

                                  3
                                  55
                                  6522
                                  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