mirror of
https://github.com/node-red/node-red.git
synced 2023-10-10 13:36:53 +02:00
Merge branch 'master' into dev
This commit is contained in:
commit
ce905ba2c4
@ -64,7 +64,7 @@
|
|||||||
"mqtt": "4.2.6",
|
"mqtt": "4.2.6",
|
||||||
"multer": "1.4.2",
|
"multer": "1.4.2",
|
||||||
"mustache": "4.2.0",
|
"mustache": "4.2.0",
|
||||||
"node-red-admin": "^0.2.6",
|
"node-red-admin": "0.2.7",
|
||||||
"nopt": "5.0.0",
|
"nopt": "5.0.0",
|
||||||
"oauth2orize": "1.11.0",
|
"oauth2orize": "1.11.0",
|
||||||
"on-headers": "1.0.2",
|
"on-headers": "1.0.2",
|
||||||
|
@ -648,7 +648,7 @@
|
|||||||
},
|
},
|
||||||
"context": {
|
"context": {
|
||||||
"name": "上下文数据",
|
"name": "上下文数据",
|
||||||
"label": "上下午",
|
"label": "上下文",
|
||||||
"none": "未选择",
|
"none": "未选择",
|
||||||
"refresh": "刷新以加载",
|
"refresh": "刷新以加载",
|
||||||
"empty": "空",
|
"empty": "空",
|
||||||
|
@ -23,10 +23,14 @@ module.exports = function(RED) {
|
|||||||
var getAllDirs = function (dir, filelist) {
|
var getAllDirs = function (dir, filelist) {
|
||||||
filelist = filelist || [];
|
filelist = filelist || [];
|
||||||
fs.readdirSync(dir).forEach(file => {
|
fs.readdirSync(dir).forEach(file => {
|
||||||
|
try {
|
||||||
if (fs.statSync(path.join(dir, file)).isDirectory() ) {
|
if (fs.statSync(path.join(dir, file)).isDirectory() ) {
|
||||||
filelist.push(path.join(dir, file));
|
filelist.push(path.join(dir, file));
|
||||||
getAllDirs(path.join(dir, file), filelist);
|
getAllDirs(path.join(dir, file), filelist);
|
||||||
}
|
}
|
||||||
|
} catch (error) {
|
||||||
|
//should we raise an error?
|
||||||
|
}
|
||||||
});
|
});
|
||||||
return filelist;
|
return filelist;
|
||||||
}
|
}
|
||||||
|
@ -369,12 +369,12 @@ class Flow {
|
|||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
// console.log((new Error().stack).toString().split("\n").slice(1,3).join("\n"))
|
// console.log((new Error().stack).toString().split("\n").slice(1,3).join("\n"))
|
||||||
if ((this.flow.configs && this.flow.configs[id]) || (this.flow.nodes && this.flow.nodes[id])) {
|
if ((this.flow.configs && this.flow.configs[id]) || (this.flow.nodes && this.flow.nodes[id] && this.flow.nodes[id].type.substring(0,8) != "subflow:")) {
|
||||||
// This is a node owned by this flow, so return whatever we have got
|
// This is a node owned by this flow, so return whatever we have got
|
||||||
// During a stop/restart, activeNodes could be null for this id
|
// During a stop/restart, activeNodes could be null for this id
|
||||||
return this.activeNodes[id];
|
return this.activeNodes[id];
|
||||||
} else if (this.activeNodes[id]) {
|
} else if (this.activeNodes[id]) {
|
||||||
// TEMP: this is a subflow internal node within this flow
|
// TEMP: this is a subflow internal node within this flow or subflow instance node
|
||||||
return this.activeNodes[id];
|
return this.activeNodes[id];
|
||||||
} else if (this.subflowInstanceNodes[id]) {
|
} else if (this.subflowInstanceNodes[id]) {
|
||||||
return this.subflowInstanceNodes[id];
|
return this.subflowInstanceNodes[id];
|
||||||
|
@ -697,7 +697,9 @@ async function updateFlow(id,newFlow, user) {
|
|||||||
|
|
||||||
nodes = [tabNode].concat(newFlow.nodes||[]).concat(newFlow.configs||[]);
|
nodes = [tabNode].concat(newFlow.nodes||[]).concat(newFlow.configs||[]);
|
||||||
nodes.forEach(function(n) {
|
nodes.forEach(function(n) {
|
||||||
|
if (n.type !== 'tab') {
|
||||||
n.z = id;
|
n.z = id;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -215,6 +215,22 @@ function followParentContext(parent, key) {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function validateContextKey(key) {
|
||||||
|
try {
|
||||||
|
const keys = Array.isArray(key) ? key : [key];
|
||||||
|
if(!keys.length) { return false }; //no key to get/set
|
||||||
|
for (let index = 0; index < keys.length; index++) {
|
||||||
|
const k = keys[index];
|
||||||
|
if (typeof k !== "string" || !k.length) {
|
||||||
|
return false; //not string or zero-length
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
function createContext(id,seed,parent) {
|
function createContext(id,seed,parent) {
|
||||||
// Seed is only set for global context - sourced from functionGlobalContext
|
// Seed is only set for global context - sourced from functionGlobalContext
|
||||||
var scope = id;
|
var scope = id;
|
||||||
@ -251,11 +267,11 @@ function createContext(id,seed,parent) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Object.defineProperties(obj, {
|
Object.defineProperties(obj, {
|
||||||
get: {
|
get: {
|
||||||
value: function(key, storage, callback) {
|
value: function(key, storage, callback) {
|
||||||
var context;
|
var context;
|
||||||
|
|
||||||
if (!callback && typeof storage === 'function') {
|
if (!callback && typeof storage === 'function') {
|
||||||
callback = storage;
|
callback = storage;
|
||||||
storage = undefined;
|
storage = undefined;
|
||||||
@ -263,7 +279,14 @@ function createContext(id,seed,parent) {
|
|||||||
if (callback && typeof callback !== 'function'){
|
if (callback && typeof callback !== 'function'){
|
||||||
throw new Error("Callback must be a function");
|
throw new Error("Callback must be a function");
|
||||||
}
|
}
|
||||||
|
if (!validateContextKey(key)) {
|
||||||
|
var err = Error("Invalid context key");
|
||||||
|
if(callback) {
|
||||||
|
return callback(err);
|
||||||
|
} else {
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (!Array.isArray(key)) {
|
if (!Array.isArray(key)) {
|
||||||
var keyParts = util.parseContextStore(key);
|
var keyParts = util.parseContextStore(key);
|
||||||
key = keyParts.key;
|
key = keyParts.key;
|
||||||
@ -337,7 +360,6 @@ function createContext(id,seed,parent) {
|
|||||||
set: {
|
set: {
|
||||||
value: function(key, value, storage, callback) {
|
value: function(key, value, storage, callback) {
|
||||||
var context;
|
var context;
|
||||||
|
|
||||||
if (!callback && typeof storage === 'function') {
|
if (!callback && typeof storage === 'function') {
|
||||||
callback = storage;
|
callback = storage;
|
||||||
storage = undefined;
|
storage = undefined;
|
||||||
@ -345,7 +367,14 @@ function createContext(id,seed,parent) {
|
|||||||
if (callback && typeof callback !== 'function'){
|
if (callback && typeof callback !== 'function'){
|
||||||
throw new Error("Callback must be a function");
|
throw new Error("Callback must be a function");
|
||||||
}
|
}
|
||||||
|
if (!validateContextKey(key)) {
|
||||||
|
var err = Error("Invalid context key");
|
||||||
|
if(callback) {
|
||||||
|
return callback(err);
|
||||||
|
} else {
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
}
|
||||||
if (!Array.isArray(key)) {
|
if (!Array.isArray(key)) {
|
||||||
var keyParts = util.parseContextStore(key);
|
var keyParts = util.parseContextStore(key);
|
||||||
key = keyParts.key;
|
key = keyParts.key;
|
||||||
|
@ -291,7 +291,7 @@ function parseLog(log) {
|
|||||||
currentCommit = {}
|
currentCommit = {}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
var m = /^(.*): (.*)$/.exec(l);
|
var m = /^(.*?): (.*)$/.exec(l);
|
||||||
if (m) {
|
if (m) {
|
||||||
// git 2.1.4 (Debian Stable) doesn't support %D for refs - so filter out
|
// git 2.1.4 (Debian Stable) doesn't support %D for refs - so filter out
|
||||||
if (m[1] === 'refs' && m[2]) {
|
if (m[1] === 'refs' && m[2]) {
|
||||||
|
2
packages/node_modules/node-red/package.json
vendored
2
packages/node_modules/node-red/package.json
vendored
@ -39,7 +39,7 @@
|
|||||||
"bcryptjs": "2.4.3",
|
"bcryptjs": "2.4.3",
|
||||||
"express": "4.17.1",
|
"express": "4.17.1",
|
||||||
"fs-extra": "10.0.0",
|
"fs-extra": "10.0.0",
|
||||||
"node-red-admin": "^0.2.6",
|
"node-red-admin": "0.2.7",
|
||||||
"nopt": "5.0.0",
|
"nopt": "5.0.0",
|
||||||
"semver": "7.3.5"
|
"semver": "7.3.5"
|
||||||
},
|
},
|
||||||
|
@ -1006,7 +1006,155 @@ describe('context', function() {
|
|||||||
done();
|
done();
|
||||||
}).catch(done);
|
}).catch(done);
|
||||||
});
|
});
|
||||||
|
it('should throw an error in context.get if key is empty string', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.get("");
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.get if key is an object', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.get({});
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.get if key is a number', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.get(1);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.get if key array contains an empty string', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.get(["ok1", "", "ok2"]);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.get if key array contains an object', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.get(["ok1", {}, "ok2"]);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.get if key array contains a number', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.get(["ok1", 1, "ok2"]);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should throw an error in context.set if key is empty string', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.set("", 1);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.set if key is an object', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.set({}, 1);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.set if key is a number', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.set(1, 1);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.set if key array contains an empty string', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.set(["ok1", "", "ok2"], 1);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.set if key array contains an object', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.set(["ok1", {}, "ok2"], 1);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
it('should throw an error in context.set if key array contains a number', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.set(["ok1", 1, "ok2"], 1);
|
||||||
|
done("should throw an error.");
|
||||||
|
}).catch(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should have an err set in callback for invalid key in context.get', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.get("", function(err) {
|
||||||
|
if(err) {
|
||||||
|
done();
|
||||||
|
} else {
|
||||||
|
done("should throw an error.");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}).catch(done);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should have an err set in callback for invalid key in context.set', function (done) {
|
||||||
|
Context.init({ contextStorage: memoryStorage });
|
||||||
|
Context.load().then(function () {
|
||||||
|
var context = Context.get("1", "flow");
|
||||||
|
context.set("", "value", function(err) {
|
||||||
|
if(err) {
|
||||||
|
done();
|
||||||
|
} else {
|
||||||
|
done("should throw an error.");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}).catch(done);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('listStores', function () {
|
describe('listStores', function () {
|
||||||
|
Loading…
Reference in New Issue
Block a user