From 2fee4396f1c06e6137da937aed85b13ef02ef2e6 Mon Sep 17 00:00:00 2001 From: Jan Oberhauser Date: Wed, 16 Sep 2020 23:55:34 +0200 Subject: [PATCH] :bug: Fix Test-Webhook registration issues --- packages/cli/src/ActiveWorkflowRunner.ts | 2 ++ packages/cli/src/TestWebhooks.ts | 29 +++++++++--------------- 2 files changed, 13 insertions(+), 18 deletions(-) diff --git a/packages/cli/src/ActiveWorkflowRunner.ts b/packages/cli/src/ActiveWorkflowRunner.ts index a7a4a4cf2e..ae462c0b38 100644 --- a/packages/cli/src/ActiveWorkflowRunner.ts +++ b/packages/cli/src/ActiveWorkflowRunner.ts @@ -317,6 +317,8 @@ export class ActiveWorkflowRunner { await workflow.runWebhookMethod('delete', webhookData, NodeExecuteFunctions, mode, false); } + await WorkflowHelpers.saveStaticData(workflow); + // if it's a mongo objectId convert it to string if (typeof workflowData.id === 'object') { workflowData.id = workflowData.id.toString(); diff --git a/packages/cli/src/TestWebhooks.ts b/packages/cli/src/TestWebhooks.ts index 1294258546..2eb213ebf8 100644 --- a/packages/cli/src/TestWebhooks.ts +++ b/packages/cli/src/TestWebhooks.ts @@ -3,11 +3,9 @@ import * as express from 'express'; import { IResponseCallbackData, IWorkflowDb, - NodeTypes, Push, ResponseHelper, WebhookHelpers, - WorkflowHelpers, } from './'; import { @@ -31,6 +29,7 @@ export class TestWebhooks { sessionId?: string; timeout: NodeJS.Timeout, workflowData: IWorkflowDb; + workflow: Workflow; }; } = {}; private activeWebhooks: ActiveWebhooks | null = null; @@ -64,10 +63,13 @@ export class TestWebhooks { const webhookKey = this.activeWebhooks!.getWebhookKey(webhookData.httpMethod, webhookData.path); - const workflowData = this.testWebhookData[webhookKey].workflowData; + // TODO: Clean that duplication up one day and improve code generally + if (this.testWebhookData[webhookKey] === undefined) { + // The requested webhook is not registered + throw new ResponseHelper.ResponseError(`The requested webhook "${httpMethod} ${path}" is not registered.`, 404, 404); + } - const nodeTypes = NodeTypes(); - const workflow = new Workflow({ id: webhookData.workflowId, name: workflowData.name, nodes: workflowData.nodes, connections: workflowData.connections, active: workflowData.active, nodeTypes, staticData: workflowData.staticData, settings: workflowData.settings}); + const workflow = this.testWebhookData[webhookKey].workflow; // Get the node which has the webhook defined to know where to start from and to // get additional data @@ -157,16 +159,14 @@ export class TestWebhooks { for (const webhookData of webhooks) { key = this.activeWebhooks!.getWebhookKey(webhookData.httpMethod, webhookData.path); - await this.activeWebhooks!.add(workflow, webhookData, mode); - this.testWebhookData[key] = { sessionId, timeout, + workflow, workflowData, }; - // Save static data! - this.testWebhookData[key].workflowData.staticData = workflow.staticData; + await this.activeWebhooks!.add(workflow, webhookData, mode); } return true; @@ -181,8 +181,6 @@ export class TestWebhooks { * @memberof TestWebhooks */ cancelTestWebhook(workflowId: string): boolean { - const nodeTypes = NodeTypes(); - let foundWebhook = false; for (const webhookKey of Object.keys(this.testWebhookData)) { const webhookData = this.testWebhookData[webhookKey]; @@ -205,8 +203,7 @@ export class TestWebhooks { } } - const workflowData = webhookData.workflowData; - const workflow = new Workflow({ id: workflowData.id.toString(), name: workflowData.name, nodes: workflowData.nodes, connections: workflowData.connections, active: workflowData.active, nodeTypes, staticData: workflowData.staticData, settings: workflowData.settings }); + const workflow = this.testWebhookData[webhookKey].workflow; // Remove the webhook delete this.testWebhookData[webhookKey]; @@ -225,14 +222,10 @@ export class TestWebhooks { return; } - const nodeTypes = NodeTypes(); - - let workflowData: IWorkflowDb; let workflow: Workflow; const workflows: Workflow[] = []; for (const webhookKey of Object.keys(this.testWebhookData)) { - workflowData = this.testWebhookData[webhookKey].workflowData; - workflow = new Workflow({ id: workflowData.id.toString(), name: workflowData.name, nodes: workflowData.nodes, connections: workflowData.connections, active: workflowData.active, nodeTypes, staticData: workflowData.staticData, settings: workflowData.settings }); + workflow = this.testWebhookData[webhookKey].workflow; workflows.push(workflow); }