From 40e41f75064840c40c625d1183db7acee49d4eee Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Ovejero?= Date: Fri, 4 Jun 2021 01:17:18 +0200 Subject: [PATCH] :zap: Restructure IPushData union types (#1836) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * :sparkles: Send console.log messages to editor-UI * :zap: Send message only to session which started workflow * :zap: Made it also work in own process * :zap: Add support for console.log UI forward also to FunctionItem Node * :shirt: Fix lint issue * :shirt: Fix linting issue * :zap: Restructure IPushData unions in /cli * :zap: Restructure IPushData unions in /editor-ui * :fire: Remove unneeded castings * :fire: Remove commented code * :zap: Improve code Co-authored-by: Iván Ovejero Co-authored-by: Jan Oberhauser Co-authored-by: Jan --- packages/cli/src/Interfaces.ts | 43 ++++++++++++++++--- packages/editor-ui/src/Interface.ts | 43 ++++++++++++++++--- .../src/components/mixins/pushConnection.ts | 18 ++++---- 3 files changed, 85 insertions(+), 19 deletions(-) diff --git a/packages/cli/src/Interfaces.ts b/packages/cli/src/Interfaces.ts index 19796bb997..df965c50e7 100644 --- a/packages/cli/src/Interfaces.ts +++ b/packages/cli/src/Interfaces.ts @@ -336,12 +336,45 @@ export interface IPackageVersions { cli: string; } -export interface IPushData { - data: IPushDataExecutionFinished | IPushDataNodeExecuteAfter | IPushDataNodeExecuteBefore | IPushDataTestWebhook | IPushDataConsoleMessage; - type: IPushDataType; -} +export type IPushDataType = IPushData['type']; -export type IPushDataType = 'executionFinished' | 'executionStarted' | 'nodeExecuteAfter' | 'nodeExecuteBefore' | 'sendConsoleMessage' | 'testWebhookDeleted' | 'testWebhookReceived'; +export type IPushData = + | PushDataExecutionFinished + | PushDataExecutionStarted + | PushDataExecuteAfter + | PushDataExecuteBefore + | PushDataConsoleMessage + | PushDataTestWebhook; + +type PushDataExecutionFinished = { + data: IPushDataExecutionFinished; + type: 'executionFinished'; +}; + +type PushDataExecutionStarted = { + data: IPushDataExecutionStarted; + type: 'executionStarted'; +}; + +type PushDataExecuteAfter = { + data: IPushDataNodeExecuteAfter; + type: 'nodeExecuteAfter'; +}; + +type PushDataExecuteBefore = { + data: IPushDataNodeExecuteBefore; + type: 'nodeExecuteBefore'; +}; + +type PushDataConsoleMessage = { + data: IPushDataConsoleMessage; + type: 'sendConsoleMessage'; +}; + +type PushDataTestWebhook = { + data: IPushDataTestWebhook; + type: 'testWebhookDeleted' | 'testWebhookReceived'; +}; export interface IPushDataExecutionFinished { data: IRun; diff --git a/packages/editor-ui/src/Interface.ts b/packages/editor-ui/src/Interface.ts index b674cbf730..3dab3901ee 100644 --- a/packages/editor-ui/src/Interface.ts +++ b/packages/editor-ui/src/Interface.ts @@ -355,12 +355,45 @@ export interface IExecutionDeleteFilter { ids?: string[]; } -export interface IPushData { - data: IPushDataExecutionFinished | IPushDataNodeExecuteAfter | IPushDataNodeExecuteBefore | IPushDataTestWebhook | IPushDataConsoleMessage; - type: IPushDataType; -} +export type IPushDataType = IPushData['type']; -export type IPushDataType = 'executionFinished' | 'executionStarted' | 'nodeExecuteAfter' | 'nodeExecuteBefore' | 'sendConsoleMessage' | 'testWebhookDeleted' | 'testWebhookReceived'; +export type IPushData = + | PushDataExecutionFinished + | PushDataExecutionStarted + | PushDataExecuteAfter + | PushDataExecuteBefore + | PushDataConsoleMessage + | PushDataTestWebhook; + +type PushDataExecutionFinished = { + data: IPushDataExecutionFinished; + type: 'executionFinished'; +}; + +type PushDataExecutionStarted = { + data: IPushDataExecutionStarted; + type: 'executionStarted'; +}; + +type PushDataExecuteAfter = { + data: IPushDataNodeExecuteAfter; + type: 'nodeExecuteAfter'; +}; + +type PushDataExecuteBefore = { + data: IPushDataNodeExecuteBefore; + type: 'nodeExecuteBefore'; +}; + +type PushDataConsoleMessage = { + data: IPushDataConsoleMessage; + type: 'sendConsoleMessage'; +}; + +type PushDataTestWebhook = { + data: IPushDataTestWebhook; + type: 'testWebhookDeleted' | 'testWebhookReceived'; +}; export interface IPushDataExecutionStarted { executionId: string; diff --git a/packages/editor-ui/src/components/mixins/pushConnection.ts b/packages/editor-ui/src/components/mixins/pushConnection.ts index b98efe7104..038335a904 100644 --- a/packages/editor-ui/src/components/mixins/pushConnection.ts +++ b/packages/editor-ui/src/components/mixins/pushConnection.ts @@ -163,7 +163,7 @@ export const pushConnection = mixins( } if (receivedData.type === 'sendConsoleMessage') { - const pushData = receivedData.data as IPushDataConsoleMessage; + const pushData = receivedData.data; console.log(pushData.source, pushData.message); // eslint-disable-line no-console return true; } @@ -175,12 +175,12 @@ export const pushConnection = mixins( return false; } - if (['nodeExecuteAfter', 'nodeExecuteBefore'].includes(receivedData.type)) { + if (receivedData.type === 'nodeExecuteAfter' || receivedData.type === 'nodeExecuteBefore') { if (this.$store.getters.isActionActive('workflowRunning') === false) { // No workflow is running so ignore the messages return false; } - const pushData = receivedData.data as IPushDataNodeExecuteBefore; + const pushData = receivedData.data; if (this.$store.getters.activeExecutionId !== pushData.executionId) { // The data is not for the currently active execution or // we do not have the execution id yet. @@ -193,7 +193,7 @@ export const pushConnection = mixins( if (receivedData.type === 'executionFinished') { // The workflow finished executing - const pushData = receivedData.data as IPushDataExecutionFinished; + const pushData = receivedData.data; this.$store.commit('finishActiveExecution', pushData); @@ -279,7 +279,7 @@ export const pushConnection = mixins( }); } else if (receivedData.type === 'executionStarted') { - const pushData = receivedData.data as IPushDataExecutionStarted; + const pushData = receivedData.data; const executionData: IExecutionsCurrentSummaryExtended = { id: pushData.executionId, @@ -294,15 +294,15 @@ export const pushConnection = mixins( this.$store.commit('addActiveExecution', executionData); } else if (receivedData.type === 'nodeExecuteAfter') { // A node finished to execute. Add its data - const pushData = receivedData.data as IPushDataNodeExecuteAfter; + const pushData = receivedData.data; this.$store.commit('addNodeExecutionData', pushData); } else if (receivedData.type === 'nodeExecuteBefore') { // A node started to be executed. Set it as executing. - const pushData = receivedData.data as IPushDataNodeExecuteBefore; + const pushData = receivedData.data; this.$store.commit('setExecutingNode', pushData.nodeName); } else if (receivedData.type === 'testWebhookDeleted') { // A test-webhook got deleted - const pushData = receivedData.data as IPushDataTestWebhook; + const pushData = receivedData.data; if (pushData.workflowId === this.$store.getters.workflowId) { this.$store.commit('setExecutionWaitingForWebhook', false); @@ -310,7 +310,7 @@ export const pushConnection = mixins( } } else if (receivedData.type === 'testWebhookReceived') { // A test-webhook did get called - const pushData = receivedData.data as IPushDataTestWebhook; + const pushData = receivedData.data; if (pushData.workflowId === this.$store.getters.workflowId) { this.$store.commit('setExecutionWaitingForWebhook', false);