From e91981207f2d59b4d0077da51257046fa21c713e Mon Sep 17 00:00:00 2001 From: Nick O'Leary Date: Fri, 3 Mar 2023 18:46:49 +0000 Subject: [PATCH] Generate stable ids for subflow instance internal nodes Fixes #3996 #3889 --- .../@node-red/runtime/lib/flows/Subflow.js | 2 +- .../runtime/lib/nodes/context/index.js | 29 +++++++++++++------ 2 files changed, 21 insertions(+), 10 deletions(-) diff --git a/packages/node_modules/@node-red/runtime/lib/flows/Subflow.js b/packages/node_modules/@node-red/runtime/lib/flows/Subflow.js index 824b88a28..78f0c7550 100644 --- a/packages/node_modules/@node-red/runtime/lib/flows/Subflow.js +++ b/packages/node_modules/@node-red/runtime/lib/flows/Subflow.js @@ -474,7 +474,7 @@ class Subflow extends Flow { */ function createNodeInSubflow(subflowInstanceId, def) { let node = clone(def); - let nid = redUtil.generateId(); + let nid = `${subflowInstanceId}-${node.id}` //redUtil.generateId(); // console.log("Create Node In subflow",node._alias, "--->",nid, "(",node.type,")") // node_map[node.id] = node; node._alias = node.id; diff --git a/packages/node_modules/@node-red/runtime/lib/nodes/context/index.js b/packages/node_modules/@node-red/runtime/lib/nodes/context/index.js index aff44db04..36dfdf000 100644 --- a/packages/node_modules/@node-red/runtime/lib/nodes/context/index.js +++ b/packages/node_modules/@node-red/runtime/lib/nodes/context/index.js @@ -589,17 +589,28 @@ function deleteContext(id,flowId) { * If flowConfig is undefined, all flow/node contexts will be removed **/ function clean(flowConfig) { - flowConfig = flowConfig || { allNodes: {} }; - var promises = []; - for(var plugin in stores){ - if(stores.hasOwnProperty(plugin)){ - promises.push(stores[plugin].clean(Object.keys(flowConfig.allNodes))); - } + flowConfig = flowConfig || { allNodes: {}, subflows: {} }; + const knownNodes = new Set(Object.keys(flowConfig.allNodes)) + + // We need to alias all of the subflow instance contents + for (const subflow of Object.values(flowConfig.subflows)) { + subflow.instances.forEach(instance => { + for (const nodeId of Object.keys(subflow.nodes || {})) { + knownNodes.add(`${instance.id}-${nodeId}`) + } + for (const nodeId of Object.keys(subflow.configs || {})) { + knownNodes.add(`${instance.id}-${nodeId}`) + } + }) } - for (var id in contexts) { - if (contexts.hasOwnProperty(id) && id !== "global") { + var promises = []; + for (const store of Object.values(stores)){ + promises.push(store.clean(Array.from(knownNodes))); + } + for (const id of Object.keys(contexts)) { + if (id !== "global") { var idParts = id.split(":"); - if (!flowConfig.allNodes.hasOwnProperty(idParts[0])) { + if (!knownNodes.has(idParts[0])) { delete contexts[id]; } }