NEWS
Yahka Rolläden mit KNX
-
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
-
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.   [/i][/i][/i][/i][/i]
-
-
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]
-
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
-
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
-
Entschuldigung aber was macht das enum?
Gesendet von iPhone mit Tapatalk
-
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
-
ich kann dieses Enum bei mir nicht finden.
Wo versteckt sich das?
-
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
-
Ich finde nur unter Aufzählung enum.rooms
-
-
das habe ich. und wie kommen die States aus KNX dort hin?
-
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
-
-
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]
-
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
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]
-
-
Sau stark!
Ich versuche es mal morgen einzubauen.
Ich gebe info.
Einbinden muss ich aber immer die JavaScript objecte oder?
-
Einbinden muss ich aber immer die JavaScript objecte oder? `
Im yahka? Jup
–-----------------------
Send from mobile device
-
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)
-
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]
-
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 `