mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-28 04:41:55 -08:00
70ae90fa3c
* ⚡ Update `lintfix` script * 👕 Remove unneeded lint exceptions * 👕 Run baseline `lintfix` * 👕 Apply `node-param-description-miscased-url` (#3441) * 👕 Apply `rule node-param-placeholder-miscased-id` (#3443) Co-authored-by: Iván Ovejero <ivov.src@gmail.com> * 👕 Apply `node-param-option-name-wrong-for-upsert` (#3446) * 👕 Apply `node-param-min-value-wrong-for-limit` (#3442) Co-authored-by: Iván Ovejero <ivov.src@gmail.com> * Apply `node-param-display-name-wrong-for-dynamic-options` (#3454) * 🔨 fix * ⚡ Fix `Assigned To` fields Co-authored-by: Michael Kret <michael.k@radency.com> * 👕 Apply `rule node-param-default-wrong-for-number` (#3453) * 👕 Apply `node-param-default-wrong-for-string` (#3452) Co-authored-by: Iván Ovejero <ivov.src@gmail.com> * Apply `node-param-display-name-miscased` (#3449) * 🔨 fix * 🔨 exceptions * ⚡ review fixes * 👕 Apply `node-param-description-lowercase-first-char` (#3451) * ⚡ fix * ⚡ review fixes * ⚡ fix Co-authored-by: Iván Ovejero <ivov.src@gmail.com> * 👕 Apply `node-param-description-wrong-for-dynamic-options` (#3456) * Rule working as intended * Add rule * 🔥 Remove repetitions * 👕 Add exceptions Co-authored-by: Iván Ovejero <ivov.src@gmail.com> * 👕 Small fix for `node-param-description-wrong-for-dynamic-options` * 👕 Apply `node-param-default-wrong-for-fixed-collection` (#3460) * 👕 Apply `node-param-description-line-break-html-tag` (#3462) * 👕 Run baseline `lintfix` * 👕 Apply `node-param-options-type-unsorted-items` (#3459) * ⚡ fix * 🔨 exceptions * Add exception for Salesmate and Zoom Co-authored-by: Michael Kret <michael.k@radency.com> Co-authored-by: Iván Ovejero <ivov.src@gmail.com> * ⚡ Restore `lintfix` command Co-authored-by: Omar Ajoue <krynble@gmail.com> Co-authored-by: Michael Kret <88898367+michael-radency@users.noreply.github.com> Co-authored-by: agobrech <45268029+agobrech@users.noreply.github.com> Co-authored-by: Michael Kret <michael.k@radency.com> Co-authored-by: brianinoa <54530642+brianinoa@users.noreply.github.com>
292 lines
6.4 KiB
TypeScript
292 lines
6.4 KiB
TypeScript
import {
|
|
IExecuteFunctions,
|
|
} from 'n8n-core';
|
|
|
|
import {
|
|
IDataObject,
|
|
ILoadOptionsFunctions,
|
|
INodeExecutionData,
|
|
INodePropertyOptions,
|
|
INodeType,
|
|
INodeTypeDescription,
|
|
NodeOperationError,
|
|
} from 'n8n-workflow';
|
|
|
|
import {
|
|
AttributesValuesUi,
|
|
CommentAnalyzeBody,
|
|
Language,
|
|
RequestedAttributes,
|
|
} from './types';
|
|
|
|
import {
|
|
googleApiRequest,
|
|
} from './GenericFunctions';
|
|
|
|
const ISO6391 = require('iso-639-1');
|
|
|
|
export class GooglePerspective implements INodeType {
|
|
description: INodeTypeDescription = {
|
|
displayName: 'Google Perspective',
|
|
name: 'googlePerspective',
|
|
icon: 'file:perspective.svg',
|
|
group: [
|
|
'transform',
|
|
],
|
|
version: 1,
|
|
description: 'Consume Google Perspective API',
|
|
subtitle: '={{$parameter["operation"]}}',
|
|
defaults: {
|
|
name: 'Google Perspective',
|
|
},
|
|
inputs: [
|
|
'main',
|
|
],
|
|
outputs: [
|
|
'main',
|
|
],
|
|
credentials: [
|
|
{
|
|
name: 'googlePerspectiveOAuth2Api',
|
|
required: true,
|
|
},
|
|
],
|
|
properties: [
|
|
{
|
|
displayName: 'Operation',
|
|
name: 'operation',
|
|
type: 'options',
|
|
noDataExpression: true,
|
|
options: [
|
|
{
|
|
name: 'Analyze Comment',
|
|
value: 'analyzeComment',
|
|
},
|
|
],
|
|
default: 'analyzeComment',
|
|
},
|
|
{
|
|
displayName: 'Text',
|
|
name: 'text',
|
|
type: 'string',
|
|
default: '',
|
|
required: true,
|
|
displayOptions: {
|
|
show: {
|
|
operation: [
|
|
'analyzeComment',
|
|
],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Attributes to Analyze',
|
|
name: 'requestedAttributesUi',
|
|
type: 'fixedCollection',
|
|
default: {},
|
|
typeOptions: {
|
|
multipleValues: true,
|
|
},
|
|
placeholder: 'Add Atrribute',
|
|
required: true,
|
|
displayOptions: {
|
|
show: {
|
|
operation: [
|
|
'analyzeComment',
|
|
],
|
|
},
|
|
},
|
|
options: [
|
|
{
|
|
displayName: 'Properties',
|
|
name: 'requestedAttributesValues',
|
|
values: [
|
|
{
|
|
displayName: 'Attribute Name',
|
|
name: 'attributeName',
|
|
type: 'options',
|
|
options: [
|
|
{
|
|
name: 'Flirtation',
|
|
value: 'flirtation',
|
|
},
|
|
{
|
|
name: 'Identity Attack',
|
|
value: 'identity_attack',
|
|
},
|
|
{
|
|
name: 'Insult',
|
|
value: 'insult',
|
|
},
|
|
{
|
|
name: 'Profanity',
|
|
value: 'profanity',
|
|
},
|
|
{
|
|
name: 'Severe Toxicity',
|
|
value: 'severe_toxicity',
|
|
},
|
|
{
|
|
name: 'Sexually Explicit',
|
|
value: 'sexually_explicit',
|
|
},
|
|
{
|
|
name: 'Threat',
|
|
value: 'threat',
|
|
},
|
|
{
|
|
name: 'Toxicity',
|
|
value: 'toxicity',
|
|
},
|
|
],
|
|
description: 'Attribute to analyze in the text. Details <a href="https://developers.perspectiveapi.com/s/about-the-api-attributes-and-languages">here</a>.',
|
|
default: 'flirtation',
|
|
},
|
|
{
|
|
displayName: 'Score Threshold',
|
|
name: 'scoreThreshold',
|
|
type: 'number',
|
|
typeOptions: {
|
|
numberPrecision: 2,
|
|
minValue: 0,
|
|
maxValue: 1,
|
|
},
|
|
description: 'Score above which to return results. At zero, all scores are returned.',
|
|
default: 0,
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
{
|
|
displayName: 'Options',
|
|
name: 'options',
|
|
type: 'collection',
|
|
displayOptions: {
|
|
show: {
|
|
operation: [
|
|
'analyzeComment',
|
|
],
|
|
},
|
|
},
|
|
default: {},
|
|
placeholder: 'Add Option',
|
|
options: [
|
|
{
|
|
displayName: 'Language Name or ID',
|
|
name: 'languages',
|
|
type: 'options',
|
|
typeOptions: {
|
|
loadOptionsMethod: 'getLanguages',
|
|
},
|
|
default: '',
|
|
description: 'Languages of the text input. If unspecified, the API will auto-detect the comment language. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/nodes/expressions.html#expressions">expression</a>.',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
};
|
|
|
|
methods = {
|
|
loadOptions: {
|
|
// Get all the available languages to display them to user so that he can
|
|
// select them easily
|
|
async getLanguages(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]> {
|
|
const returnData: INodePropertyOptions[] = [];
|
|
const supportedLanguages = [
|
|
'English',
|
|
'Spanish',
|
|
'French',
|
|
'German',
|
|
'Portuguese',
|
|
'Italian',
|
|
'Russian',
|
|
];
|
|
|
|
const languages = ISO6391.getAllNames().filter((language: string) => supportedLanguages.includes(language));
|
|
for (const language of languages) {
|
|
const languageName = language;
|
|
const languageId = ISO6391.getCode(language);
|
|
returnData.push({
|
|
name: languageName,
|
|
value: languageId,
|
|
});
|
|
}
|
|
return returnData;
|
|
},
|
|
},
|
|
};
|
|
|
|
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
|
const items = this.getInputData();
|
|
|
|
const operation = this.getNodeParameter('operation', 0);
|
|
|
|
const returnData: IDataObject[] = [];
|
|
let responseData;
|
|
|
|
for (let i = 0; i < items.length; i++) {
|
|
|
|
try {
|
|
|
|
|
|
if (operation === 'analyzeComment') {
|
|
|
|
// https://developers.perspectiveapi.com/s/about-the-api-methods
|
|
|
|
const attributes = this.getNodeParameter(
|
|
'requestedAttributesUi.requestedAttributesValues', i, [],
|
|
) as AttributesValuesUi[];
|
|
|
|
if (!attributes.length) {
|
|
throw new NodeOperationError(
|
|
this.getNode(),
|
|
'Please enter at least one attribute to analyze.',
|
|
);
|
|
}
|
|
|
|
const requestedAttributes = attributes.reduce<RequestedAttributes>((acc, cur) => {
|
|
return Object.assign(acc, {
|
|
[cur.attributeName.toUpperCase()]: {
|
|
scoreType: 'probability',
|
|
scoreThreshold: cur.scoreThreshold,
|
|
},
|
|
});
|
|
}, {});
|
|
|
|
const body: CommentAnalyzeBody = {
|
|
comment: {
|
|
type: 'PLAIN_TEXT',
|
|
text: this.getNodeParameter('text', i) as string,
|
|
},
|
|
requestedAttributes,
|
|
};
|
|
|
|
const { languages } = this.getNodeParameter('options', i) as { languages: Language };
|
|
|
|
if (languages?.length) {
|
|
body.languages = languages;
|
|
}
|
|
|
|
responseData = await googleApiRequest.call(this, 'POST', '/v1alpha1/comments:analyze', body);
|
|
}
|
|
|
|
|
|
} catch (error) {
|
|
if (this.continueOnFail()) {
|
|
returnData.push({ error: error.message });
|
|
continue;
|
|
}
|
|
throw error;
|
|
}
|
|
|
|
Array.isArray(responseData)
|
|
? returnData.push(...responseData)
|
|
: returnData.push(responseData);
|
|
|
|
}
|
|
|
|
return [this.helpers.returnJsonArray(responseData)];
|
|
}
|
|
}
|