Minor improvements on loading parameters on demand

This commit is contained in:
Jan Oberhauser 2020-10-22 17:32:05 +02:00
parent 37f787d7b2
commit 53162ba462

View file

@ -718,8 +718,9 @@ class App {
// Make a copy of the object. If we don't do this, then when
// The method below is called the properties are removed for good
// This happens because nodes are returned as reference.
let nodeInfo: INodeTypeDescription = {...nodeData.description};
if (!['true', '1'].includes(req.query.includeProperties as string)) {
const nodeInfo: INodeTypeDescription = {...nodeData.description};
if (req.query.includeProperties !== 'true') {
// @ts-ignore
delete nodeInfo.properties;
}
returnData.push(nodeInfo);
@ -731,10 +732,16 @@ class App {
// Returns node information baesd on namese
this.app.post(`/${this.restEndpoint}/node-types`, ResponseHelper.send(async (req: express.Request, res: express.Response): Promise<INodeTypeDescription[]> => {
const nodeNames = _.get(req, 'body.nodeNames', []);
const nodeNames = _.get(req, 'body.nodeNames', []) as string[];
const nodeTypes = NodeTypes();
const allNodes = nodeTypes.getAll();
return allNodes.filter(node => nodeNames.includes(node.description.name)).map(node => node.description);
return nodeNames.map(name => {
try {
return nodeTypes.getByName(name);
} catch (e) {
return undefined;
}
}).filter(nodeData => !!nodeData).map(nodeData => nodeData!.description);
}));