From 9f600c191af58355900a3b7b164c61be06a222e5 Mon Sep 17 00:00:00 2001 From: agobrech Date: Thu, 2 Jun 2022 12:01:05 +0200 Subject: [PATCH 1/2] Update icon, add cred injection and test, update url for integration --- .../credentials/TwakeCloudApi.credentials.ts | 16 ++++++++++++++++ .../nodes/Twake/GenericFunctions.ts | 7 ++----- packages/nodes-base/nodes/Twake/twake.png | Bin 1996 -> 3673 bytes 3 files changed, 18 insertions(+), 5 deletions(-) diff --git a/packages/nodes-base/credentials/TwakeCloudApi.credentials.ts b/packages/nodes-base/credentials/TwakeCloudApi.credentials.ts index 798bb9efe3f6f..93abdec472a36 100644 --- a/packages/nodes-base/credentials/TwakeCloudApi.credentials.ts +++ b/packages/nodes-base/credentials/TwakeCloudApi.credentials.ts @@ -1,4 +1,6 @@ import { + IAuthenticateBearer, + ICredentialTestRequest, ICredentialType, INodeProperties, } from 'n8n-workflow'; @@ -15,4 +17,18 @@ export class TwakeCloudApi implements ICredentialType { default: '', }, ]; + authenticate = { + type: 'bearer', + properties: { + tokenPropertyName: 'workspaceKey', + }, + } as IAuthenticateBearer; + + test: ICredentialTestRequest = { + request: { + baseURL: 'https://plugins.twake.app/plugins/n8n', + url: '/channel', + method: 'POST', + }, + }; } diff --git a/packages/nodes-base/nodes/Twake/GenericFunctions.ts b/packages/nodes-base/nodes/Twake/GenericFunctions.ts index c02f3f0a059fd..deb2891abe9ff 100644 --- a/packages/nodes-base/nodes/Twake/GenericFunctions.ts +++ b/packages/nodes-base/nodes/Twake/GenericFunctions.ts @@ -28,15 +28,12 @@ export async function twakeApiRequest(this: IHookFunctions | IExecuteFunctions | method, body, qs: query, - uri: uri || `https://connectors.albatros.twakeapp.com/n8n${resource}`, + uri: uri || `https://plugins.twake.app/plugins/n8n${resource}`, json: true, }; // if (authenticationMethod === 'cloud') { - const credentials = await this.getCredentials('twakeCloudApi'); - options.headers!.Authorization = `Bearer ${credentials.workspaceKey}`; - // } else { // const credentials = await this.getCredentials('twakeServerApi'); // options.auth = { user: credentials!.publicId as string, pass: credentials!.privateApiKey as string }; @@ -44,7 +41,7 @@ export async function twakeApiRequest(this: IHookFunctions | IExecuteFunctions | // } try { - return await this.helpers.request!(options); + return await this.helpers.requestWithAuthentication.call(this, 'twakeCloudApi', options); } catch (error) { if (error.error.code === 'ECONNREFUSED') { throw new NodeApiError(this.getNode(), error, { message: 'Twake host is not accessible!' }); diff --git a/packages/nodes-base/nodes/Twake/twake.png b/packages/nodes-base/nodes/Twake/twake.png index 6bc6953716f8ec3f36df7f8a323cc630e1d71de2..3afce345b12cec257a2f5aa2ef60535d5e3aa28b 100644 GIT binary patch literal 3673 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 From 02a7731acdf7592a0d386fda03db9a2ad48da59b Mon Sep 17 00:00:00 2001 From: Jan Oberhauser Date: Sat, 18 Jun 2022 20:08:42 -0700 Subject: [PATCH 2/2] :zap: Fix error display for some edge cases --- packages/nodes-base/nodes/Twake/GenericFunctions.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/nodes-base/nodes/Twake/GenericFunctions.ts b/packages/nodes-base/nodes/Twake/GenericFunctions.ts index deb2891abe9ff..66b182e6f695f 100644 --- a/packages/nodes-base/nodes/Twake/GenericFunctions.ts +++ b/packages/nodes-base/nodes/Twake/GenericFunctions.ts @@ -43,7 +43,7 @@ export async function twakeApiRequest(this: IHookFunctions | IExecuteFunctions | try { return await this.helpers.requestWithAuthentication.call(this, 'twakeCloudApi', options); } catch (error) { - if (error.error.code === 'ECONNREFUSED') { + if (error.error?.code === 'ECONNREFUSED') { throw new NodeApiError(this.getNode(), error, { message: 'Twake host is not accessible!' }); } throw new NodeApiError(this.getNode(), error);