zhongjin 6 years ago
parent 6b4ec16652
commit 7f92cd3156

@ -12,7 +12,7 @@ before_script:
- 'if [[ $NPMVERSION == 5 ]]; then npm install -g npm@5; fi'
- npm -v
- npm install winston@2.3.1
- 'npm install https://github.com/ioBroker/ioBroker.js-controller/tarball/master --production'
- 'npm install https://github.com/yunkong2/yunkong2.js-controller/tarball/master --production'
env:
- CXX=g++-4.8
addons:

@ -1,11 +1,11 @@
![Logo](admin/node-red.png)
# ioBroker node-red Adapter
# yunkong2 node-red Adapter
==============
[![NPM version](http://img.shields.io/npm/v/iobroker.node-red.svg)](https://www.npmjs.com/package/iobroker.node-red)
[![Downloads](https://img.shields.io/npm/dm/iobroker.node-red.svg)](https://www.npmjs.com/package/iobroker.node-red)
[![Tests](https://travis-ci.org/ioBroker/ioBroker.node-red.svg?branch=master)](https://travis-ci.org/ioBroker/ioBroker.node-red)
[![NPM version](http://img.shields.io/npm/v/yunkong2.node-red.svg)](https://www.npmjs.com/package/yunkong2.node-red)
[![Downloads](https://img.shields.io/npm/dm/yunkong2.node-red.svg)](https://www.npmjs.com/package/yunkong2.node-red)
[![Tests](https://travis-ci.org/yunkong2/yunkong2.node-red.svg?branch=master)](https://travis-ci.org/yunkong2/yunkong2.node-red)
[![NPM](https://nodei.co/npm/iobroker.node-red.png?downloads=true)](https://nodei.co/npm/iobroker.node-red/)
[![NPM](https://nodei.co/npm/yunkong2.node-red.png?downloads=true)](https://nodei.co/npm/yunkong2.node-red/)
# Starts node-red instance and communicates with it.
@ -13,7 +13,7 @@
This adapter uses the node-red server from https://github.com/node-red/node-red
**Note:** If in select ID dialog of the ioBroker node you cannot find some variable, restart node-red instance. By restarting the new list of objects will be created.
**Note:** If in select ID dialog of the yunkong2 node you cannot find some variable, restart node-red instance. By restarting the new list of objects will be created.
## Changelog
### 1.7.1 (2017-09-24)
@ -30,7 +30,7 @@ This adapter uses the node-red server from https://github.com/node-red/node-red
* (bluefox) add credentialSecret option
### 1.5.1 (2017-02-16)
* (Apollon77) queue set state requests till ioBroker connection has been initialized
* (Apollon77) queue set state requests till yunkong2 connection has been initialized
### 1.5.0 (2018-02-14)
* (Apollon77) use newer version of node-red 0.18.2
@ -87,7 +87,7 @@ This adapter uses the node-red server from https://github.com/node-red/node-red
### 0.4.1 (2016-01-14)
* (nobodyMO) Add --max-old-space-size=128 to support systems with low memory.
* (nobodyMO) Add version 0.12.5 for node-red because it works.
* (nobodyMO) Add ioBroker get node.
* (nobodyMO) Add yunkong2 get node.
* (nobodyMO) Set _maxListeners = 100 to suppress warnings in the log.
### 0.3.5 (2015-08-23)
@ -100,14 +100,14 @@ This adapter uses the node-red server from https://github.com/node-red/node-red
* (bluefox) enable node-red 0.11.x
### 0.3.2 (2015-06-29)
* (bluefox) fix error with ioBroker nodes
* (bluefox) fix error with yunkong2 nodes
### 0.3.1 (2015-06-28)
* (bluefox) change link in admin to node-red web server
### 0.3.0 (2015-05-18)
* (bluefox) add flag "stopBeforeUpdate"
* (bluefox) store data in iobroker-data directory
* (bluefox) store data in yunkong2-data directory
### 0.2.2 (2015-05-17)
* (bluefox) fix error with invalid additional npm package
@ -125,7 +125,7 @@ This adapter uses the node-red server from https://github.com/node-red/node-red
* (bluefox) remove warnings
### 0.1.6 (2015-03-18)
* (bluefox) make node-red compatible with ioBroker again
* (bluefox) make node-red compatible with yunkong2 again
### 0.1.5 (2015-02-12)
* (bluefox) update node-red to 0.10.1
@ -163,14 +163,14 @@ This adapter uses the node-red server from https://github.com/node-red/node-red
* (bluefox) fix some errors
### 0.0.2 (2014-11-04)
* (bluefox) use adapter.js to communicate with ioBroker
* (bluefox) use adapter.js to communicate with yunkong2
### 0.0.1 (2014-11-03)
* (bluefox) initial commit
## Install
```node iobroker.js add node-red```
```node yunkong2.js add node-red```
## Configuration

@ -10,7 +10,7 @@ systemDictionary = {
"Divided by comma": { "en": "Divided by comma", "de": "Getrennt mit Komma", "ru": "Через запятую", "pt": "Dividido por vírgula", "nl": "Verdeeld door een komma", "fr": "Divisé par une virgule", "it": "Diviso in virgola", "es": "Dividido por coma", "pl": "Podzielone przecinkiem"},
"Additional npm modules:": { "en": "Additional npm modules", "de": "Zusätzliche NPM-Module", "ru": "Дополнительные NPM Модули", "pt": "Módulos npm adicionais", "nl": "Extra npm-modules", "fr": "Modules NPM supplémentaires", "it": "Ulteriori moduli npm", "es": "Módulos npm adicionales", "pl": "Dodatkowe moduły npm"},
"http root directory:": { "en": "http root directory", "de": "http Stammpfad", "ru": "http root directory", "pt": "diretório raiz http", "nl": "http root directory", "fr": "répertoire racine http", "it": "directory root http", "es": "directorio raíz http", "pl": "główny katalog http"},
"Convert values to string:": { "en": "Convert ioBroker values to string", "de": "ioBroker-Werte in String konvertieren:", "ru": "Конвертировать значения из ioBroker в строки", "pt": "Converter valores de ioBroker em string", "nl": "IoBroker-waarden converteren naar tekenreeks", "fr": "Convertir les valeurs de ioBroker en chaîne", "it": "Converti i valori di ioBroker in stringa", "es": "Convierta los valores de ioBroker en una cadena", "pl": "Konwertuj wartości ioBroker na ciąg"},
"Convert values to string:": { "en": "Convert yunkong2 values to string", "de": "yunkong2-Werte in String konvertieren:", "ru": "Конвертировать значения из yunkong2 в строки", "pt": "Converter valores de yunkong2 em string", "nl": "yunkong2-waarden converteren naar tekenreeks", "fr": "Convertir les valeurs de yunkong2 en chaîne", "it": "Converti i valori di yunkong2 in stringa", "es": "Convierta los valores de yunkong2 en una cadena", "pl": "Konwertuj wartości yunkong2 na ciąg"},
"Add module": { "en": "Add module", "de": "Modul hinzufügen", "ru": "Добавить модуль", "pt": "Adicionar módulo", "nl": "Module toevoegen", "fr": "Ajouter un module", "it": "Aggiungi modulo", "es": "Agregar módulo", "pl": "Dodaj moduł"},
"Max allocated RAM:": { "en": "Max allocated RAM", "de": "Max zugewiesener RAM", "ru": "Выделено RAM", "pt": "RAM alocada máxima", "nl": "Max toegewezen RAM", "fr": "Max allouée RAM", "it": "RAM allocata massima", "es": "RAM máxima asignada", "pl": "Maksymalna przydzielona pamięć RAM"},
"Module names": { "en": "Module names", "de": "Modulnamen", "ru": "Имена модулей", "pt": "Nomes de módulos", "nl": "Module namen", "fr": "Noms de modules", "it": "Nomi dei moduli", "es": "Nombres de módulos", "pl": "Nazwy modułów"},

@ -16,7 +16,7 @@ install:
- ps: npm --version
- npm install
- npm install winston@2.3.1
- 'npm install https://github.com/ioBroker/ioBroker.js-controller/tarball/master --production'
- 'npm install https://github.com/yunkong2/yunkong2.js-controller/tarball/master --production'
test_script:
- echo %cd%
- node --version

@ -38,9 +38,9 @@
"pl": "zastosowano nowszą wersję węzła-czerwonego 0.18.7\nZaimplementowano okno Admin3\nDodano ustawienia pamięci RAM"
},
"1.5.1": {
"en": "queue set state requests till ioBroker connection has been initialized",
"de": "Verzögern von ioBroker-Schreibaktionen bis Verbindung zu ioBroker initialisiert wurde",
"ru": "queue set state requests till ioBroker connection has been initialized"
"en": "queue set state requests till yunkong2 connection has been initialized",
"de": "Verzögern von yunkong2-Schreibaktionen bis Verbindung zu yunkong2 initialisiert wurde",
"ru": "queue set state requests till yunkong2 connection has been initialized"
},
"1.5.0": {
"en": "use newer version of node-red 0.18.2",
@ -98,7 +98,7 @@
"logic",
"script"
],
"extIcon": "https://raw.githubusercontent.com/ioBroker/ioBroker.node-red/master/admin/node-red.png",
"extIcon": "https://raw.githubusercontent.com/yunkong2/yunkong2.node-red/master/admin/node-red.png",
"localLink": "http://%ip%:%port%%httpRoot%",
"enabled": true,
"singletonHost": true,
@ -106,7 +106,7 @@
"unsafePerm": true,
"materialize": true,
"type": "logic",
"readme": "https://github.com/ioBroker/ioBroker.node-red/blob/master/README.md",
"readme": "https://github.com/yunkong2/yunkong2.node-red/blob/master/README.md",
"stopBeforeUpdate": true,
"adminTab": {
"link": "http://%ip%:%port%%httpRoot%",

@ -27,8 +27,8 @@ let appName;
function getControllerDir(isInstall) {
// Find the js-controller location
const possibilities = [
'iobroker.js-controller',
'ioBroker.js-controller',
'yunkong2.js-controller',
'yunkong2.js-controller',
];
/** @type {string} */
let controllerPath;

@ -1,6 +1,6 @@
/**
*
* ioBroker node-red Adapter
* yunkong2 node-red Adapter
*
* (c) 2014 bluefox<bluefox@ccu.io>
*
@ -289,7 +289,7 @@ function writeStateList(callback) {
}
}
fs.writeFileSync(nodePath + '/public/iobroker.json', JSON.stringify(obj));
fs.writeFileSync(nodePath + '/public/yunkong2.json', JSON.stringify(obj));
if (callback) callback(err);
});
}
@ -393,14 +393,14 @@ function installNotifierCreds(isFirst) {
function main() {
// Find userdata directory
// normally /opt/iobroker/node_modules/iobroker.js-controller
// but can be /example/ioBroker.js-controller
// normally /opt/yunkong2/node_modules/yunkong2.js-controller
// but can be /example/yunkong2.js-controller
const controllerDir = utils.controllerDir;
const parts = controllerDir.split('/');
if (parts.length > 1 && parts[parts.length - 2] === 'node_modules') {
parts.splice(parts.length - 2, 2);
userdataDir = parts.join('/');
userdataDir += '/iobroker-data/node-red/';
userdataDir += '/yunkong2-data/node-red/';
}
// create userdata directory

@ -14,7 +14,7 @@
limitations under the License.
-->
<script type="text/x-red" data-template-name="ioBroker in">
<script type="text/x-red" data-template-name="yunkong2 in">
<div class="form-row">
<label for="node-input-topic"><i class="fa fa-tasks"></i> Topic</label>
<input type="text" id="node-input-topic" placeholder="Topic" style="width:60%"><input type="button" id="node-input-topic-button" style="display:inline-block;width:10%" value="."/>
@ -50,8 +50,8 @@
</div>
</script>
<script type="text/x-red" data-help-name="ioBroker in">
<p>ioBroker input node. Connects to a ioBroker and subscribes to the specified topic. The topic may contain redis wildcards (*).</p>
<script type="text/x-red" data-help-name="yunkong2 in">
<p>yunkong2 input node. Connects to a yunkong2 and subscribes to the specified topic. The topic may contain redis wildcards (*).</p>
<p>Outputs an object called <b>msg</b> containing <b>msg.topic, msg.payload, msg.timestamp, msg.lastchange and msg.acknowledged.</p>
<p>The checkbox determines whether only States with ack == true or all events are forwarded.</p>
<p>The select box Mode offers further filtering options. The options are the same as for the RBE node.</p>
@ -70,7 +70,7 @@
<script type="text/javascript">
RED.nodes.registerType('ioBroker in',{
RED.nodes.registerType('yunkong2 in',{
category: 'input',
defaults: {
name: {value:""},
@ -84,19 +84,19 @@
color:"#a8bfd8",
inputs:0,
outputs:1,
icon: "ioBroker.png",
icon: "yunkong2.png",
label: function() {
return this.name||this.topic||"ioBroker";
return this.name||this.topic||"yunkong2";
},
labelStyle: function() {
return this.name?"node_label_italic":"";
},
oneditprepare: function() {
if (!window.__iobroker) {
$.getJSON("iobroker.json", function(data) {
window.__iobroker = data;
if (!window.__yunkong2) {
$.getJSON("yunkong2.json", function(data) {
window.__yunkong2 = data;
$('#dialog-select-member').selectId('init', {
objects: window.__iobroker,
objects: window.__yunkong2,
noMultiselect: true,
columns: ['name', 'role', 'enum', 'room'],
states: null,
@ -105,7 +105,7 @@
});
} else {
$('#dialog-select-member').selectId('init', {
objects: window.__iobroker,
objects: window.__yunkong2,
noMultiselect: true,
columns: ['name', 'role', 'enum', 'room'],
states: null,
@ -142,7 +142,7 @@
});
</script>
<script type="text/x-red" data-template-name="ioBroker out">
<script type="text/x-red" data-template-name="yunkong2 out">
<div class="form-row">
<label for="node-input-topic"><i class="fa fa-tasks"></i> Topic</label>
<input type="text" id="node-input-topic" placeholder="Topic" style="width:60%"><input type="button" id="node-input-topic-button" style="display:inline-block;width:10%" value="."/>
@ -169,14 +169,14 @@
<div class="form-tips">Tip: Leave topic blank if you want to set them via msg properties.</div>
</script>
<script type="text/x-red" data-help-name="ioBroker out">
<p>Connects to a ioBroker and publishes <b>msg.payload</b> either to the <b>msg.topic</b> or to the topic specified in the edit window. The value in the edit window has precedence.</p>
<script type="text/x-red" data-help-name="yunkong2 out">
<p>Connects to a yunkong2 and publishes <b>msg.payload</b> either to the <b>msg.topic</b> or to the topic specified in the edit window. The value in the edit window has precedence.</p>
<p>If <b>msg.payload</b> contains an object it will be stringified before being sent.</p>
<p>If <b>msg.payload</b> contains "__create__", the object will be only created, but no value will be written.</p>
</script>
<script type="text/javascript">
RED.nodes.registerType('ioBroker out',{
RED.nodes.registerType('yunkong2 out',{
category: 'output',
defaults: {
name: {value:""},
@ -187,20 +187,20 @@ RED.nodes.registerType('ioBroker out',{
color:"#a8bfd8",
inputs:1,
outputs:0,
icon: "ioBroker.png",
icon: "yunkong2.png",
align: "right",
label: function() {
return this.name||this.topic||"ioBroker";
return this.name||this.topic||"yunkong2";
},
labelStyle: function() {
return this.name?"node_label_italic":"";
},
oneditprepare: function() {
if (!window.__iobroker) {
$.getJSON("iobroker.json", function(data) {
window.__iobroker = data;
if (!window.__yunkong2) {
$.getJSON("yunkong2.json", function(data) {
window.__yunkong2 = data;
$('#dialog-select-member').selectId('init', {
objects: window.__iobroker,
objects: window.__yunkong2,
noMultiselect: true,
columns: ['name', 'role', 'enum', 'room'],
states: null,
@ -209,7 +209,7 @@ RED.nodes.registerType('ioBroker out',{
});
} else {
$('#dialog-select-member').selectId('init', {
objects: window.__iobroker,
objects: window.__yunkong2,
noMultiselect: true,
columns: ['name', 'role', 'enum', 'room'],
states: null,
@ -236,7 +236,7 @@ RED.nodes.registerType('ioBroker out',{
});
</script>
<script type="text/x-red" data-template-name="ioBroker get">
<script type="text/x-red" data-template-name="yunkong2 get">
<div class="form-row">
<label for="node-input-topic"><i class="fa fa-tasks"></i> Topic</label>
<input type="text" id="node-input-topic" placeholder="Topic" style="width:60%"><input type="button" id="node-input-topic-button" style="display:inline-block;width:10%" value="."/>
@ -260,14 +260,14 @@ RED.nodes.registerType('ioBroker out',{
<div class="form-tips">Tip: Leave topic blank if you want to set them via msg properties.</div>
</script>
<script type="text/x-red" data-help-name="ioBroker get">
<p>Connects to a ioBroker and returns the requested value or the object in the massage attribute in the properties dialog, e.g. <b>msg.payload</b>. The object could be identified either by the <b>msg.topic</b> or specified in the poperties dialog. The value in the poperties dialog has precedence.</p>
<script type="text/x-red" data-help-name="yunkong2 get">
<p>Connects to a yunkong2 and returns the requested value or the object in the massage attribute in the properties dialog, e.g. <b>msg.payload</b>. The object could be identified either by the <b>msg.topic</b> or specified in the poperties dialog. The value in the poperties dialog has precedence.</p>
<p>The msg object also contains the attributs <b>msg.timestamp</b>, <b>msg.lastchange</b> and <b>msg.acknowledged</b>. All other attributes ob the input msg object will be passed to the output msg object.</p>
</script>
<script type="text/javascript">
RED.nodes.registerType('ioBroker get',{
RED.nodes.registerType('yunkong2 get',{
category: 'function',
defaults: {
name: {value:""},
@ -278,19 +278,19 @@ RED.nodes.registerType('ioBroker get',{
color:"#a8bfd8",
inputs:1,
outputs:1,
icon: "ioBroker.png",
icon: "yunkong2.png",
label: function() {
return this.name||this.topic||"ioBroker get";
return this.name||this.topic||"yunkong2 get";
},
labelStyle: function() {
return this.name?"node_label_italic":"";
},
oneditprepare: function() {
if (!window.__iobroker) {
$.getJSON("iobroker.json", function(data) {
window.__iobroker = data;
if (!window.__yunkong2) {
$.getJSON("yunkong2.json", function(data) {
window.__yunkong2 = data;
$('#dialog-select-member').selectId('init', {
objects: window.__iobroker,
objects: window.__yunkong2,
noMultiselect: true,
columns: ['name', 'role', 'enum', 'room'],
states: null,
@ -299,7 +299,7 @@ RED.nodes.registerType('ioBroker get',{
});
} else {
$('#dialog-select-member').selectId('init', {
objects: window.__iobroker,
objects: window.__yunkong2,
noMultiselect: true,
columns: ['name', 'role', 'enum', 'room'],
states: null,

@ -24,8 +24,8 @@ module.exports = function(RED) {
// Get the redis address
var settings = require(process.env.NODE_RED_HOME + '/red/red').settings;
var instance = settings.get('iobrokerInstance') || 0;
var config = settings.get('iobrokerConfig');
var instance = settings.get('yunkong2Instance') || 0;
var config = settings.get('yunkong2Config');
var valueConvert = settings.get('valueConvert');
if (typeof config == 'string') {
config = JSON.parse(config);
@ -47,7 +47,7 @@ module.exports = function(RED) {
adapter.subscribeForeignStates('*');
while (nodes.length) {
var node = nodes.pop();
if (node instanceof IOBrokerInNode) {
if (node instanceof yunkong2InNode) {
adapter.on('stateChange', node.stateChange);
}
node.status({fill: 'green', shape: 'dot', text: 'connected'});
@ -58,7 +58,7 @@ module.exports = function(RED) {
nodeSetData.node.emit('input', nodeSetData.msg);
count++;
}
if (count > 0) log(count + ' queued state values set in ioBroker');
if (count > 0) log(count + ' queued state values set in yunkong2');
});
@ -85,7 +85,7 @@ module.exports = function(RED) {
if (!obj) {
adapter.getForeignObject(id, function (err, obj) {
if (!obj) {
log('State "' + id + '" was created in the ioBroker as ' + adapter._fixId(id));
log('State "' + id + '" was created in the yunkong2 as ' + adapter._fixId(id));
// Create object
adapter.setObject(id, {
common: {
@ -130,7 +130,7 @@ module.exports = function(RED) {
});
}
function IOBrokerInNode(n) {
function yunkong2InNode(n) {
var node = this;
RED.nodes.createNode(node,n);
node.topic = (n.topic || '*').replace(/\//g, '.');
@ -226,9 +226,9 @@ module.exports = function(RED) {
nodes.push(node);
}
}
RED.nodes.registerType('ioBroker in', IOBrokerInNode);
RED.nodes.registerType('yunkong2 in', yunkong2InNode);
function IOBrokerOutNode(n) {
function yunkong2OutNode(n) {
var node = this;
RED.nodes.createNode(node,n);
node.topic = n.topic;
@ -257,7 +257,7 @@ module.exports = function(RED) {
var id = node.topic || msg.topic;
if (!ready) {
nodeSets.push({'node': node, 'msg': msg});
//log('Message for "' + id + '" queued because ioBroker connection not initialized');
//log('Message for "' + id + '" queued because yunkong2 connection not initialized');
return;
}
if (id) {
@ -280,12 +280,12 @@ module.exports = function(RED) {
adapter.setForeignState(id, {val: msg.payload, ack: node.ack});
node.status({fill: 'green', shape: 'dot', text: msg.payload.toString() });
} else {
log('State "' + id + '" does not exist in the ioBroker');
log('State "' + id + '" does not exist in the yunkong2');
}
});
} else {
if (id.indexOf('*') !== -1) {
log('Invalid topic name "' + id + '" for ioBroker');
log('Invalid topic name "' + id + '" for yunkong2');
} else {
setState(id, msg.payload, node.ack);
node.status({fill: 'green', shape: 'dot', text: msg.payload.toString() });
@ -305,9 +305,9 @@ module.exports = function(RED) {
// });
}
RED.nodes.registerType('ioBroker out', IOBrokerOutNode);
RED.nodes.registerType('yunkong2 out', yunkong2OutNode);
function IOBrokerGetNode(n) {
function yunkong2GetNode(n) {
var node = this;
RED.nodes.createNode(node,n);
node.topic = (typeof n.topic=== 'string' && n.topic.length > 0 ? n.topic.replace(/\//g, '.') : null) ;
@ -350,7 +350,7 @@ module.exports = function(RED) {
});
node.send(msg);
} else {
log('State "' + id + '" does not exist in the ioBroker');
log('State "' + id + '" does not exist in the yunkong2');
}
};
};
@ -359,7 +359,7 @@ module.exports = function(RED) {
var id = node.topic || msg.topic;
if (!ready) {
nodeSets.push({'node': node, 'msg': msg});
//log('Message for "' + id + '" queued because ioBroker connection not initialized');
//log('Message for "' + id + '" queued because yunkong2 connection not initialized');
return;
}
if (id) {
@ -370,7 +370,7 @@ module.exports = function(RED) {
adapter.getForeignState(id, node.getStateValue(msg));
} else {
if (id.indexOf('*') !== -1) {
log('Invalid topic name "' + id + '" for ioBroker');
log('Invalid topic name "' + id + '" for yunkong2');
} else {
adapter.getState(id, node.getStateValue(msg));
}
@ -385,5 +385,5 @@ module.exports = function(RED) {
}
}
RED.nodes.registerType('ioBroker get', IOBrokerGetNode);
RED.nodes.registerType('yunkong2 get', yunkong2GetNode);
};

@ -1,6 +1,6 @@
{
"name": "iobroker.node-red",
"description": "This adapter uses node-red as a service of ioBroker. No additional node-red instance required.",
"name": "yunkong2.node-red",
"description": "This adapter uses node-red as a service of yunkong2. No additional node-red instance required.",
"version": "1.7.1",
"author": {
"name": "bluefox",
@ -12,16 +12,16 @@
"email": "dogafox@gmail.com"
}
],
"homepage": "https://github.com/ioBroker/ioBroker.node-red",
"homepage": "https://github.com/yunkong2/yunkong2.node-red",
"license": "Apache-2.0",
"keywords": [
"ioBroker",
"yunkong2",
"node-red",
"home automation"
],
"repository": {
"type": "git",
"url": "https://github.com/ioBroker/ioBroker.node-red"
"url": "https://github.com/yunkong2/yunkong2.node-red"
},
"optionalDependencies": {
"js2xmlparser": "^3.0.0",
@ -34,7 +34,8 @@
"node-red-contrib-os": "^0.1.7",
"node-red-dashboard": "^2.9.8",
"node-red-contrib-aggregator": "^1.3.0",
"node-red-contrib-polymer": "^0.0.21"
"node-red-contrib-polymer": "^0.0.21",
"node-red-dashboard": ""
},
"devDependencies": {
"gulp": "^3.9.1",
@ -43,7 +44,7 @@
"chai": "^4.1.2"
},
"bugs": {
"url": "https://github.com/ioBroker/ioBroker.node-red/issues"
"url": "https://github.com/yunkong2/yunkong2.node-red/issues"
},
"main": "main.js",
"scripts": {

@ -3,7 +3,7 @@
version: 1.0.2 (2017.04.13)
To use this dialog as standalone in ioBroker environment include:
To use this dialog as standalone in yunkong2 environment include:
<link type="text/css" rel="stylesheet" href="lib/css/redmond/jquery-ui.min.css">
<link rel="stylesheet" type="text/css" href="lib/css/fancytree/ui.fancytree.min.css"/>
@ -101,7 +101,7 @@
editStart: null, // function (id, $inputs) called after edit start to correct input fields (inputs are jquery objects),
zindex: null, // z-index of dialog or table
customButtonFilter: null, // if in the filter over the buttons some specific button must be shown. It has type like {icons:{primary: 'ui-icon-close'}, text: false, callback: function ()}
expertModeRegEx: null // list of regex with objects, that will be shown only in expert mode, like /^system\.|^iobroker\.|^_|^[\w-]+$|^enum\.|^[\w-]+\.admin/
expertModeRegEx: null // list of regex with objects, that will be shown only in expert mode, like /^system\.|^yunkong2\.|^_|^[\w-]+$|^enum\.|^[\w-]+\.admin/
quickEdit: null, // list of fields with edit on click. Elements can be just names from standard list or objects like:
// {name: 'field', options: {a1: 'a111_Text', a2: 'a22_Text'}}, options can be a function (id, name), that give back such an object
quickEditCallback: null // function (id, attr, newValue, oldValue)

@ -27,8 +27,8 @@ module.exports = {
// The following property can be used to listen on a specific interface. For
// example, the following would only allow connections from the local machine.
//uiHost: "127.0.0.1",
iobrokerInstance: '%%instance%%',
iobrokerConfig: '%%config%%',
yunkong2Instance: '%%instance%%',
yunkong2Config: '%%config%%',
// Retry time in milliseconds for MQTT connections
mqttReconnectTime: 15000,

@ -415,7 +415,7 @@ function clearControllerLog() {
}
function clearDB() {
var dirPath = rootDir + 'tmp/iobroker-data/sqlite';
var dirPath = rootDir + 'tmp/yunkong2-data/sqlite';
var files;
try {
if (fs.existsSync(dirPath)) {

@ -52,12 +52,12 @@ describe('Test package.json and io-package.json', function() {
console.log();
}
if (
ioPackage.common.title.indexOf('iobroker') !== -1 ||
ioPackage.common.title.indexOf('ioBroker') !== -1 ||
ioPackage.common.title.indexOf('yunkong2') !== -1 ||
ioPackage.common.title.indexOf('yunkong2') !== -1 ||
ioPackage.common.title.indexOf('adapter') !== -1 ||
ioPackage.common.title.indexOf('Adapter') !== -1
) {
console.log('WARNING: title contains Adapter or ioBroker. It is clear anyway, that it is adapter for ioBroker.');
console.log('WARNING: title contains Adapter or yunkong2. It is clear anyway, that it is adapter for yunkong2.');
console.log();
}

Loading…
Cancel
Save