Skip to content

Commit

Permalink
feat(DeepL Node): Add support for longer texts + Credential tests (#3651
Browse files Browse the repository at this point in the history
)

* Updated DeepL to send data with Body instead of QS allowing larger translations

* Updated Credentials and added test
  • Loading branch information
Joffcom authored Jul 5, 2022
1 parent 088daf9 commit 88d6cfc
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 14 deletions.
23 changes: 22 additions & 1 deletion packages/nodes-base/credentials/DeepLApi.credentials.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,9 @@
import { ICredentialType, INodeProperties } from 'n8n-workflow';
import {
IAuthenticateGeneric,
ICredentialTestRequest,
ICredentialType,
INodeProperties,
} from 'n8n-workflow';

export class DeepLApi implements ICredentialType {
name = 'deepLApi';
Expand Down Expand Up @@ -28,4 +33,20 @@ export class DeepLApi implements ICredentialType {
default: 'pro',
},
];

authenticate: IAuthenticateGeneric = {
type: 'generic',
properties: {
qs: {
auth_key: '={{$credentials.apiKey}}',
},
},
};

test: ICredentialTestRequest = {
request: {
baseURL: '={{$credentials.apiPlan === "pro" ? "https://api.deepl.com/v2" : "https://api-free.deepl.com/v2" }}',
url: '/usage',
},
};
}
8 changes: 4 additions & 4 deletions packages/nodes-base/nodes/DeepL/DeepL.node.ts
Original file line number Diff line number Diff line change
Expand Up @@ -116,18 +116,18 @@ export class DeepL implements INodeType {
if (resource === 'language') {

if (operation === 'translate') {

let body: IDataObject = {};
const text = this.getNodeParameter('text', i) as string;
const translateTo = this.getNodeParameter('translateTo', i) as string;
const qs = { target_lang: translateTo, text } as IDataObject;
body = { target_lang: translateTo, 'text': text } as IDataObject;

if (additionalFields.sourceLang !== undefined) {
qs.source_lang = ['EN-GB', 'EN-US'].includes(additionalFields.sourceLang as string)
body.source_lang = ['EN-GB', 'EN-US'].includes(additionalFields.sourceLang as string)
? 'EN'
: additionalFields.sourceLang;
}

const response = await deepLApiRequest.call(this, 'GET', '/translate', {}, qs);
const response = await deepLApiRequest.call(this, 'GET', '/translate', body);
responseData.push(response.translations[0]);
}
}
Expand Down
16 changes: 7 additions & 9 deletions packages/nodes-base/nodes/DeepL/GenericFunctions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,9 @@ import {
} from 'n8n-core';

import {
IDataObject, NodeApiError, NodeOperationError,
IDataObject,
JsonObject,
NodeApiError,
} from 'n8n-workflow';

export async function deepLApiRequest(
Expand All @@ -29,10 +31,10 @@ export async function deepLApiRequest(

const options: OptionsWithUri = {
headers: {
'Content-Type': 'application/json',
'Content-Type': 'application/x-www-form-urlencoded',
},
method,
body,
form: body,
qs,
uri: uri || `${credentials.apiPlan === 'pro' ? proApiEndpoint : freeApiEndpoint}${resource}`,
json: true,
Expand All @@ -47,13 +49,9 @@ export async function deepLApiRequest(
delete options.body;
}

const credentials = await this.getCredentials('deepLApi');

options.qs.auth_key = credentials.apiKey;

return await this.helpers.request!(options);
return await this.helpers.requestWithAuthentication.call(this, 'deepLApi', options);

} catch (error) {
throw new NodeApiError(this.getNode(), error);
throw new NodeApiError(this.getNode(), error as JsonObject);
}
}

0 comments on commit 88d6cfc

Please sign in to comment.