mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-11 12:57:29 -08:00
feat(Execute Workflow Node): Add 'Wait For Sub-Workflow Completion' option (#8389)
Co-authored-by: Michael Kret <michael.k@radency.com>
This commit is contained in:
parent
1b0ba2c028
commit
ff92fc7fef
|
@ -170,6 +170,23 @@ export class ExecuteWorkflow implements INodeType {
|
|||
],
|
||||
default: 'once',
|
||||
},
|
||||
{
|
||||
displayName: 'Options',
|
||||
name: 'options',
|
||||
type: 'collection',
|
||||
default: {},
|
||||
placeholder: 'Add Option',
|
||||
options: [
|
||||
{
|
||||
displayName: 'Wait For Sub-Workflow Completion',
|
||||
name: 'waitForSubWorkflow',
|
||||
type: 'boolean',
|
||||
default: true,
|
||||
description:
|
||||
'Whether the main workflow should wait for the sub-workflow to complete its execution before proceeding',
|
||||
},
|
||||
],
|
||||
},
|
||||
],
|
||||
};
|
||||
|
||||
|
@ -179,14 +196,22 @@ export class ExecuteWorkflow implements INodeType {
|
|||
const items = this.getInputData();
|
||||
|
||||
if (mode === 'each') {
|
||||
const returnData: INodeExecutionData[][] = [];
|
||||
let returnData: INodeExecutionData[][] = [];
|
||||
|
||||
for (let i = 0; i < items.length; i++) {
|
||||
try {
|
||||
const waitForSubWorkflow = this.getNodeParameter(
|
||||
'options.waitForSubWorkflow',
|
||||
i,
|
||||
true,
|
||||
) as boolean;
|
||||
const workflowInfo = await getWorkflowInfo.call(this, source, i);
|
||||
const workflowResult: INodeExecutionData[][] = await this.executeWorkflow(workflowInfo, [
|
||||
items[i],
|
||||
]);
|
||||
|
||||
if (waitForSubWorkflow) {
|
||||
const workflowResult: INodeExecutionData[][] = await this.executeWorkflow(
|
||||
workflowInfo,
|
||||
[items[i]],
|
||||
);
|
||||
|
||||
for (const [outputIndex, outputData] of workflowResult.entries()) {
|
||||
for (const item of outputData) {
|
||||
|
@ -199,6 +224,10 @@ export class ExecuteWorkflow implements INodeType {
|
|||
|
||||
returnData[outputIndex].push(...outputData);
|
||||
}
|
||||
} else {
|
||||
void this.executeWorkflow(workflowInfo, [items[i]]);
|
||||
returnData = [items];
|
||||
}
|
||||
} catch (error) {
|
||||
if (this.continueOnFail()) {
|
||||
return [[{ json: { error: error.message }, pairedItem: { item: i } }]];
|
||||
|
@ -214,7 +243,18 @@ export class ExecuteWorkflow implements INodeType {
|
|||
return returnData;
|
||||
} else {
|
||||
try {
|
||||
const waitForSubWorkflow = this.getNodeParameter(
|
||||
'options.waitForSubWorkflow',
|
||||
0,
|
||||
true,
|
||||
) as boolean;
|
||||
const workflowInfo = await getWorkflowInfo.call(this, source);
|
||||
|
||||
if (!waitForSubWorkflow) {
|
||||
void this.executeWorkflow(workflowInfo, items);
|
||||
return [items];
|
||||
}
|
||||
|
||||
const workflowResult: INodeExecutionData[][] = await this.executeWorkflow(
|
||||
workflowInfo,
|
||||
items,
|
||||
|
|
Loading…
Reference in a new issue