mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-12 13:27:31 -08:00
👕 Fix lint issue
This commit is contained in:
parent
974f5f9f15
commit
d432eae601
68
packages/nodes-base/nodes/Example.node.ts
Normal file
68
packages/nodes-base/nodes/Example.node.ts
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
import { IExecuteFunctions } from 'n8n-core';
|
||||||
|
import {
|
||||||
|
INodeExecutionData,
|
||||||
|
INodeType,
|
||||||
|
INodeTypeDescription,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
|
||||||
|
export class Example implements INodeType {
|
||||||
|
description: INodeTypeDescription = {
|
||||||
|
displayName: 'Example',
|
||||||
|
name: 'example',
|
||||||
|
group: ['input'],
|
||||||
|
version: 1,
|
||||||
|
description: 'Example',
|
||||||
|
defaults: {
|
||||||
|
name: 'Example',
|
||||||
|
color: '#0000FF',
|
||||||
|
},
|
||||||
|
inputs: ['main'],
|
||||||
|
outputs: ['main'],
|
||||||
|
properties: [
|
||||||
|
{
|
||||||
|
displayName: 'Age',
|
||||||
|
name: 'age',
|
||||||
|
type: 'number',
|
||||||
|
default: 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Brand Name',
|
||||||
|
name: 'brandName',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
||||||
|
|
||||||
|
const items = this.getInputData();
|
||||||
|
|
||||||
|
if (items.length === 0) {
|
||||||
|
items.push({json: {}});
|
||||||
|
}
|
||||||
|
|
||||||
|
const returnData: INodeExecutionData[] = [];
|
||||||
|
let item: INodeExecutionData;
|
||||||
|
|
||||||
|
for (let i = 0; i < items.length; i++) {
|
||||||
|
const age = this.getNodeParameter('age', i) as number | undefined;
|
||||||
|
const brandName = this.getNodeParameter('brandName', i) as string | undefined;
|
||||||
|
|
||||||
|
item = items[i];
|
||||||
|
|
||||||
|
const newItem: INodeExecutionData = {
|
||||||
|
json: {
|
||||||
|
age: age || item.json.age,
|
||||||
|
brandName: brandName || item.json.brandName,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
returnData.push(newItem);
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.prepareOutputData(returnData);
|
||||||
|
}
|
||||||
|
}
|
|
@ -159,7 +159,7 @@ export class GSuiteAdmin implements INodeType {
|
||||||
this,
|
this,
|
||||||
'DELETE',
|
'DELETE',
|
||||||
`/directory/v1/groups/${groupId}`,
|
`/directory/v1/groups/${groupId}`,
|
||||||
{}
|
{},
|
||||||
);
|
);
|
||||||
|
|
||||||
responseData = { success: true };
|
responseData = { success: true };
|
||||||
|
@ -196,7 +196,7 @@ export class GSuiteAdmin implements INodeType {
|
||||||
'GET',
|
'GET',
|
||||||
`/directory/v1/groups`,
|
`/directory/v1/groups`,
|
||||||
{},
|
{},
|
||||||
qs
|
qs,
|
||||||
);
|
);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
@ -207,7 +207,7 @@ export class GSuiteAdmin implements INodeType {
|
||||||
'GET',
|
'GET',
|
||||||
`/directory/v1/groups`,
|
`/directory/v1/groups`,
|
||||||
{},
|
{},
|
||||||
qs
|
qs,
|
||||||
);
|
);
|
||||||
|
|
||||||
responseData = responseData.groups;
|
responseData = responseData.groups;
|
||||||
|
|
|
@ -42,8 +42,8 @@ export const groupOperations = [
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
default: 'create',
|
default: 'create',
|
||||||
description: 'The operation to perform.'
|
description: 'The operation to perform.',
|
||||||
}
|
},
|
||||||
] as INodeProperties[];
|
] as INodeProperties[];
|
||||||
|
|
||||||
export const groupFields = [
|
export const groupFields = [
|
||||||
|
@ -122,7 +122,7 @@ export const groupFields = [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
default: '',
|
default: '',
|
||||||
description: `Identifies the group in the API request. The value can be the group's email address, group alias, or the unique group ID.`
|
description: `Identifies the group in the API request. The value can be the group's email address, group alias, or the unique group ID.`,
|
||||||
},
|
},
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* group:get */
|
/* group:get */
|
||||||
|
@ -143,7 +143,7 @@ export const groupFields = [
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
default: '',
|
default: '',
|
||||||
description: `Identifies the group in the API request. The value can be the group's email address, group alias, or the unique group ID.`
|
description: `Identifies the group in the API request. The value can be the group's email address, group alias, or the unique group ID.`,
|
||||||
},
|
},
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* group:getAll */
|
/* group:getAll */
|
||||||
|
|
346
packages/nodes-base/nodes/RunAt.node.ts
Normal file
346
packages/nodes-base/nodes/RunAt.node.ts
Normal file
|
@ -0,0 +1,346 @@
|
||||||
|
import { ITriggerFunctions } from 'n8n-core';
|
||||||
|
import {
|
||||||
|
INodeType,
|
||||||
|
INodeTypeDescription,
|
||||||
|
ITriggerResponse,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
|
||||||
|
export class RunAt implements INodeType {
|
||||||
|
description: INodeTypeDescription = {
|
||||||
|
displayName: 'RunAt',
|
||||||
|
name: 'runAt',
|
||||||
|
icon: 'fa:calendar',
|
||||||
|
group: ['trigger'],
|
||||||
|
version: 1,
|
||||||
|
description: 'Triggers the workflow at a specific time',
|
||||||
|
defaults: {
|
||||||
|
name: 'RunAt',
|
||||||
|
color: '#00FF00',
|
||||||
|
},
|
||||||
|
inputs: [],
|
||||||
|
outputs: ['main'],
|
||||||
|
properties: [
|
||||||
|
{
|
||||||
|
displayName: 'Trigger Times',
|
||||||
|
name: 'triggerTimes',
|
||||||
|
type: 'dateTime',
|
||||||
|
typeOptions: {
|
||||||
|
multipleValues: true,
|
||||||
|
multipleValueButtonText: 'Add Time',
|
||||||
|
},
|
||||||
|
default: '',
|
||||||
|
// default: [],
|
||||||
|
description: 'Triggers for the workflow',
|
||||||
|
placeholder: 'Add Time',
|
||||||
|
},
|
||||||
|
// {
|
||||||
|
// displayName: 'Trigger Times',
|
||||||
|
// name: 'triggerTimes',
|
||||||
|
// type: 'fixedCollection',
|
||||||
|
// typeOptions: {
|
||||||
|
// multipleValues: true,
|
||||||
|
// multipleValueButtonText: 'Add Time',
|
||||||
|
// },
|
||||||
|
// default: {},
|
||||||
|
// description: 'Triggers for the workflow',
|
||||||
|
// placeholder: 'Add Cron Time',
|
||||||
|
// options: [
|
||||||
|
// {
|
||||||
|
// name: 'item',
|
||||||
|
// displayName: 'Item',
|
||||||
|
// values: [
|
||||||
|
// {
|
||||||
|
// displayName: 'Mode',
|
||||||
|
// name: 'mode',
|
||||||
|
// type: 'options',
|
||||||
|
// options: [
|
||||||
|
// {
|
||||||
|
// name: 'Every Minute',
|
||||||
|
// value: 'everyMinute',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Every Hour',
|
||||||
|
// value: 'everyHour',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Every Day',
|
||||||
|
// value: 'everyDay',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Every Week',
|
||||||
|
// value: 'everyWeek',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Every Month',
|
||||||
|
// value: 'everyMonth',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Every X',
|
||||||
|
// value: 'everyX',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Custom',
|
||||||
|
// value: 'custom',
|
||||||
|
// },
|
||||||
|
// ],
|
||||||
|
// default: 'everyDay',
|
||||||
|
// description: 'How often to trigger.',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// displayName: 'Hour',
|
||||||
|
// name: 'hour',
|
||||||
|
// type: 'number',
|
||||||
|
// typeOptions: {
|
||||||
|
// minValue: 0,
|
||||||
|
// maxValue: 23,
|
||||||
|
// },
|
||||||
|
// displayOptions: {
|
||||||
|
// hide: {
|
||||||
|
// mode: [
|
||||||
|
// 'custom',
|
||||||
|
// 'everyHour',
|
||||||
|
// 'everyMinute',
|
||||||
|
// 'everyX',
|
||||||
|
// ],
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// default: 14,
|
||||||
|
// description: 'The hour of the day to trigger (24h format).',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// displayName: 'Minute',
|
||||||
|
// name: 'minute',
|
||||||
|
// type: 'number',
|
||||||
|
// typeOptions: {
|
||||||
|
// minValue: 0,
|
||||||
|
// maxValue: 59,
|
||||||
|
// },
|
||||||
|
// displayOptions: {
|
||||||
|
// hide: {
|
||||||
|
// mode: [
|
||||||
|
// 'custom',
|
||||||
|
// 'everyMinute',
|
||||||
|
// 'everyX',
|
||||||
|
// ],
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// default: 0,
|
||||||
|
// description: 'The minute of the day to trigger.',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// displayName: 'Day of Month',
|
||||||
|
// name: 'dayOfMonth',
|
||||||
|
// type: 'number',
|
||||||
|
// displayOptions: {
|
||||||
|
// show: {
|
||||||
|
// mode: [
|
||||||
|
// 'everyMonth',
|
||||||
|
// ],
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// typeOptions: {
|
||||||
|
// minValue: 1,
|
||||||
|
// maxValue: 31,
|
||||||
|
// },
|
||||||
|
// default: 1,
|
||||||
|
// description: 'The day of the month to trigger.',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// displayName: 'Weekday',
|
||||||
|
// name: 'weekday',
|
||||||
|
// type: 'options',
|
||||||
|
// displayOptions: {
|
||||||
|
// show: {
|
||||||
|
// mode: [
|
||||||
|
// 'everyWeek',
|
||||||
|
// ],
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// options: [
|
||||||
|
// {
|
||||||
|
// name: 'Monday',
|
||||||
|
// value: '1',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Tuesday',
|
||||||
|
// value: '2',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Wednesday',
|
||||||
|
// value: '3',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Thursday',
|
||||||
|
// value: '4',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Friday',
|
||||||
|
// value: '5',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Saturday',
|
||||||
|
// value: '6',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Sunday',
|
||||||
|
// value: '0',
|
||||||
|
// },
|
||||||
|
// ],
|
||||||
|
// default: '1',
|
||||||
|
// description: 'The weekday to trigger.',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// displayName: 'Cron Expression',
|
||||||
|
// name: 'cronExpression',
|
||||||
|
// type: 'string',
|
||||||
|
// displayOptions: {
|
||||||
|
// show: {
|
||||||
|
// mode: [
|
||||||
|
// 'custom',
|
||||||
|
// ],
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// default: '* * * * * *',
|
||||||
|
// description: 'Use custom cron expression. Values and ranges as follows:<ul><li>Seconds: 0-59</li><li>Minutes: 0 - 59</li><li>Hours: 0 - 23</li><li>Day of Month: 1 - 31</li><li>Months: 0 - 11 (Jan - Dec)</li><li>Day of Week: 0 - 6 (Sun - Sat)</li></ul>',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// displayName: 'Value',
|
||||||
|
// name: 'value',
|
||||||
|
// type: 'number',
|
||||||
|
// typeOptions: {
|
||||||
|
// minValue: 0,
|
||||||
|
// maxValue: 1000,
|
||||||
|
// },
|
||||||
|
// displayOptions: {
|
||||||
|
// show: {
|
||||||
|
// mode: [
|
||||||
|
// 'everyX',
|
||||||
|
// ],
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// default: 2,
|
||||||
|
// description: 'All how many X minutes/hours it should trigger.',
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// displayName: 'Unit',
|
||||||
|
// name: 'unit',
|
||||||
|
// type: 'options',
|
||||||
|
// displayOptions: {
|
||||||
|
// show: {
|
||||||
|
// mode: [
|
||||||
|
// 'everyX',
|
||||||
|
// ],
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// options: [
|
||||||
|
// {
|
||||||
|
// name: 'Minutes',
|
||||||
|
// value: 'minutes'
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name: 'Hours',
|
||||||
|
// value: 'hours'
|
||||||
|
// },
|
||||||
|
// ],
|
||||||
|
// default: 'hours',
|
||||||
|
// description: 'If it should trigger all X minutes or hours.',
|
||||||
|
// },
|
||||||
|
// ]
|
||||||
|
// },
|
||||||
|
// ],
|
||||||
|
// }
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
async trigger(this: ITriggerFunctions): Promise<ITriggerResponse> {
|
||||||
|
|
||||||
|
// const triggerTimes = this.getNodeParameter('triggerTimes') as unknown as {
|
||||||
|
// item: TriggerTime[];
|
||||||
|
// };
|
||||||
|
|
||||||
|
// // Define the order the cron-time-parameter appear
|
||||||
|
// const parameterOrder = [
|
||||||
|
// 'second', // 0 - 59
|
||||||
|
// 'minute', // 0 - 59
|
||||||
|
// 'hour', // 0 - 23
|
||||||
|
// 'dayOfMonth', // 1 - 31
|
||||||
|
// 'month', // 0 - 11(Jan - Dec)
|
||||||
|
// 'weekday', // 0 - 6(Sun - Sat)
|
||||||
|
// ];
|
||||||
|
|
||||||
|
// // Get all the trigger times
|
||||||
|
// const cronTimes: string[] = [];
|
||||||
|
// let cronTime: string[];
|
||||||
|
// let parameterName: string;
|
||||||
|
// if (triggerTimes.item !== undefined) {
|
||||||
|
// for (const item of triggerTimes.item) {
|
||||||
|
// cronTime = [];
|
||||||
|
// if (item.mode === 'custom') {
|
||||||
|
// cronTimes.push(item.cronExpression as string);
|
||||||
|
// continue;
|
||||||
|
// }
|
||||||
|
// if (item.mode === 'everyMinute') {
|
||||||
|
// cronTimes.push(`${Math.floor(Math.random() * 60).toString()} * * * * *`);
|
||||||
|
// continue;
|
||||||
|
// }
|
||||||
|
// if (item.mode === 'everyX') {
|
||||||
|
// if (item.unit === 'minutes') {
|
||||||
|
// cronTimes.push(`${Math.floor(Math.random() * 60).toString()} */${item.value} * * * *`);
|
||||||
|
// } else if (item.unit === 'hours') {
|
||||||
|
// cronTimes.push(`${Math.floor(Math.random() * 60).toString()} 0 */${item.value} * * *`);
|
||||||
|
// }
|
||||||
|
// continue;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// for (parameterName of parameterOrder) {
|
||||||
|
// if (item[parameterName] !== undefined) {
|
||||||
|
// // Value is set so use it
|
||||||
|
// cronTime.push(item[parameterName] as string);
|
||||||
|
// } else if (parameterName === 'second') {
|
||||||
|
// // For seconds we use by default a random one to make sure to
|
||||||
|
// // balance the load a little bit over time
|
||||||
|
// cronTime.push(Math.floor(Math.random() * 60).toString());
|
||||||
|
// } else {
|
||||||
|
// // For all others set "any"
|
||||||
|
// cronTime.push('*');
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// cronTimes.push(cronTime.join(' '));
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// // The trigger function to execute when the cron-time got reached
|
||||||
|
// // or when manually triggered
|
||||||
|
// const executeTrigger = () => {
|
||||||
|
// this.emit([this.helpers.returnJsonArray([{}])]);
|
||||||
|
// };
|
||||||
|
|
||||||
|
// const timezone = this.getTimezone();
|
||||||
|
|
||||||
|
// // Start the cron-jobs
|
||||||
|
// const cronJobs: CronJob[] = [];
|
||||||
|
// for (const cronTime of cronTimes) {
|
||||||
|
// cronJobs.push(new CronJob(cronTime, executeTrigger, undefined, true, timezone));
|
||||||
|
// }
|
||||||
|
|
||||||
|
// // Stop the cron-jobs
|
||||||
|
// async function closeFunction() {
|
||||||
|
// for (const cronJob of cronJobs) {
|
||||||
|
// cronJob.stop();
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// async function manualTriggerFunction() {
|
||||||
|
// executeTrigger();
|
||||||
|
// }
|
||||||
|
|
||||||
|
return {
|
||||||
|
// closeFunction,
|
||||||
|
// manualTriggerFunction,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue