From f3248e46e478e5ac061c3d69da988b0db8acf553 Mon Sep 17 00:00:00 2001 From: Jon Date: Thu, 10 Aug 2023 08:58:51 +0100 Subject: [PATCH] fix(Email Trigger (IMAP) Node): Fix connection issue with unexpected spaces in host (#6886) --- .../EmailReadImap/v1/EmailReadImapV1.node.ts | 8 +++---- .../EmailReadImap/v2/EmailReadImapV2.node.ts | 24 +++++++++---------- 2 files changed, 16 insertions(+), 16 deletions(-) diff --git a/packages/nodes-base/nodes/EmailReadImap/v1/EmailReadImapV1.node.ts b/packages/nodes-base/nodes/EmailReadImap/v1/EmailReadImapV1.node.ts index be149e125e..fd4aa0714e 100644 --- a/packages/nodes-base/nodes/EmailReadImap/v1/EmailReadImapV1.node.ts +++ b/packages/nodes-base/nodes/EmailReadImap/v1/EmailReadImapV1.node.ts @@ -241,7 +241,7 @@ export class EmailReadImapV1 implements INodeType { imap: { user: credentials.user as string, password: credentials.password as string, - host: credentials.host as string, + host: (credentials.host as string).trim(), port: credentials.port as number, tls: credentials.secure as boolean, authTimeout: 20000, @@ -250,7 +250,7 @@ export class EmailReadImapV1 implements INodeType { const tlsOptions: IDataObject = {}; if (credentials.secure) { - tlsOptions.servername = credentials.host as string; + tlsOptions.servername = (credentials.host as string).trim(); } if (!isEmpty(tlsOptions)) { config.imap.tlsOptions = tlsOptions; @@ -527,7 +527,7 @@ export class EmailReadImapV1 implements INodeType { imap: { user: credentials.user as string, password: credentials.password as string, - host: credentials.host as string, + host: (credentials.host as string).trim(), port: credentials.port as number, tls: credentials.secure as boolean, authTimeout: 20000, @@ -579,7 +579,7 @@ export class EmailReadImapV1 implements INodeType { } if (credentials.secure) { - tlsOptions.servername = credentials.host as string; + tlsOptions.servername = (credentials.host as string).trim(); } if (!isEmpty(tlsOptions)) { diff --git a/packages/nodes-base/nodes/EmailReadImap/v2/EmailReadImapV2.node.ts b/packages/nodes-base/nodes/EmailReadImap/v2/EmailReadImapV2.node.ts index 4ba43f92a7..7b6214c383 100644 --- a/packages/nodes-base/nodes/EmailReadImap/v2/EmailReadImapV2.node.ts +++ b/packages/nodes-base/nodes/EmailReadImap/v2/EmailReadImapV2.node.ts @@ -34,14 +34,14 @@ export async function parseRawEmail( ): Promise { const responseData = await simpleParser(messageEncoded); const headers: IDataObject = {}; - const addidtionalData: IDataObject = {}; + const additionalData: IDataObject = {}; for (const header of responseData.headerLines) { headers[header.key] = header.line; } - addidtionalData.headers = headers; - addidtionalData.headerLines = undefined; + additionalData.headers = headers; + additionalData.headerLines = undefined; const binaryData: IBinaryKeyData = {}; if (responseData.attachments) { @@ -54,11 +54,11 @@ export async function parseRawEmail( ); } - addidtionalData.attachments = undefined; + additionalData.attachments = undefined; } return { - json: { ...responseData, ...addidtionalData }, + json: { ...responseData, ...additionalData }, binary: Object.keys(binaryData).length ? binaryData : undefined, } as INodeExecutionData; } @@ -238,7 +238,7 @@ export class EmailReadImapV2 implements INodeType { imap: { user: credentials.user, password: credentials.password, - host: credentials.host, + host: credentials.host.trim(), port: credentials.port, tls: credentials.secure, authTimeout: 20000, @@ -251,7 +251,7 @@ export class EmailReadImapV2 implements INodeType { } if (credentials.secure) { - tlsOptions.servername = credentials.host; + tlsOptions.servername = credentials.host.trim(); } if (!isEmpty(tlsOptions)) { config.imap.tlsOptions = tlsOptions; @@ -554,7 +554,7 @@ export class EmailReadImapV2 implements INodeType { imap: { user: credentials.user, password: credentials.password, - host: credentials.host, + host: credentials.host.trim(), port: credentials.port, tls: credentials.secure, authTimeout: 20000, @@ -609,7 +609,7 @@ export class EmailReadImapV2 implements INodeType { } if (credentials.secure) { - tlsOptions.servername = credentials.host; + tlsOptions.servername = credentials.host.trim(); } if (!isEmpty(tlsOptions)) { @@ -648,7 +648,7 @@ export class EmailReadImapV2 implements INodeType { let reconnectionInterval: NodeJS.Timeout | undefined; - const handleReconect = async () => { + const handleReconnect = async () => { this.logger.verbose('Forcing reconnect to IMAP server'); try { isCurrentlyReconnecting = true; @@ -665,12 +665,12 @@ export class EmailReadImapV2 implements INodeType { if (options.forceReconnect !== undefined) { reconnectionInterval = setInterval( - handleReconect, + handleReconnect, (options.forceReconnect as number) * 1000 * 60, ); } - // When workflow and so node gets set to inactive close the connectoin + // When workflow and so node gets set to inactive close the connection async function closeFunction() { closeFunctionWasCalled = true; if (reconnectionInterval) {