mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 18:12:04 +00:00
✨ Add UptimeRobot Node (#1830)
* Add Monitor & account resources * Add alert contact resource * Add mwindows resource * Add 'public status page' resource * Clean up & lint fixes * Minor fixes * Apply code review suggestions * Minor fixes * Fix options name casing * ⚡ Improvements * ⚡ Improvements * ⚡ Improvements on UptimeRobot Node * ⚡ Activate continueOnFail support Co-authored-by: dali <servfrdali@yahoo.fr> Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
This commit is contained in:
@@ -0,0 +1,19 @@
|
|||||||
|
import {
|
||||||
|
ICredentialType,
|
||||||
|
NodePropertyTypes,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
|
||||||
|
export class UptimeRobotApi implements ICredentialType {
|
||||||
|
name = 'uptimeRobotApi';
|
||||||
|
displayName = 'Uptime Robot API';
|
||||||
|
documentationUrl = 'uptimeRobot';
|
||||||
|
properties = [
|
||||||
|
{
|
||||||
|
displayName: 'API Key',
|
||||||
|
name: 'apiKey',
|
||||||
|
type: 'string' as NodePropertyTypes,
|
||||||
|
default: '',
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
300
packages/nodes-base/nodes/UptimeRobot/AlertContactDescription.ts
Normal file
300
packages/nodes-base/nodes/UptimeRobot/AlertContactDescription.ts
Normal file
@@ -0,0 +1,300 @@
|
|||||||
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
export const alertContactOperations = [
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Create',
|
||||||
|
value: 'create',
|
||||||
|
description: 'Create an alert contact',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Delete',
|
||||||
|
value: 'delete',
|
||||||
|
description: 'Delete an alert contact',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get',
|
||||||
|
value: 'get',
|
||||||
|
description: 'Get an alert contact',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get All',
|
||||||
|
value: 'getAll',
|
||||||
|
description: 'Get all alert contacts',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Update',
|
||||||
|
value: 'update',
|
||||||
|
description: 'Update an alert contact',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'getAll',
|
||||||
|
description: 'The operation to perform.',
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
|
|
||||||
|
export const alertContactFields = [
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* alertContact:create */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendlyName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The friendly name of the alert contact.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Type',
|
||||||
|
name: 'type',
|
||||||
|
type: 'options',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Boxcar',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'E-mail',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'SMS',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Twitter DM',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Pushbullet',
|
||||||
|
value: 6,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Pushover',
|
||||||
|
value: 9,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Webhook',
|
||||||
|
value: 5,
|
||||||
|
},
|
||||||
|
// the commented option are not supported yet
|
||||||
|
// {
|
||||||
|
// name:'HipChat',
|
||||||
|
// value:10,
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name:'Slack',
|
||||||
|
// value:11
|
||||||
|
// },
|
||||||
|
// {
|
||||||
|
// name:'Zapier',
|
||||||
|
// value:7,
|
||||||
|
// },
|
||||||
|
|
||||||
|
],
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The type of the alert contact.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Value',
|
||||||
|
name: 'value',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The correspondent value for the alert contact type.',
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* alertContact:delete */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'delete',
|
||||||
|
'get',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the alert contact.',
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* alertContact:getAll */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Return All',
|
||||||
|
name: 'returnAll',
|
||||||
|
type: 'boolean',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: false,
|
||||||
|
description: 'If all results should be returned or only up to a given limit.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Limit',
|
||||||
|
name: 'limit',
|
||||||
|
type: 'number',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
returnAll: [
|
||||||
|
false,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
typeOptions: {
|
||||||
|
minValue: 1,
|
||||||
|
maxValue: 100,
|
||||||
|
},
|
||||||
|
default: 50,
|
||||||
|
description: 'How many results to return.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Filters',
|
||||||
|
name: 'filters',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Alert Contact IDs',
|
||||||
|
name: 'alert_contacts',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'Alert contact ids separated with dash, e.g. 236-1782-4790.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* alertContact:update */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the alert contact.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Update Fields',
|
||||||
|
name: 'updateFields',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'alertContact',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendly_name',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The friendly name of the alert contact.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Value',
|
||||||
|
name: 'value',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The correspondent value for the alert contact type (can only be used if it is a Webhook alert contact).',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
41
packages/nodes-base/nodes/UptimeRobot/GenericFunctions.ts
Normal file
41
packages/nodes-base/nodes/UptimeRobot/GenericFunctions.ts
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
import {
|
||||||
|
OptionsWithUri
|
||||||
|
} from 'request';
|
||||||
|
|
||||||
|
import {
|
||||||
|
IExecuteFunctions,
|
||||||
|
} from 'n8n-core';
|
||||||
|
|
||||||
|
import {
|
||||||
|
IDataObject,
|
||||||
|
NodeApiError,
|
||||||
|
NodeOperationError,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
export async function uptimeRobotApiRequest(this: IExecuteFunctions, method: string, resource: string, body: IDataObject = {}, qs: IDataObject = {}, uri?: string, option: IDataObject = {}) {
|
||||||
|
const credentials = this.getCredentials('uptimeRobotApi');
|
||||||
|
if (credentials === undefined) {
|
||||||
|
throw new NodeOperationError(this.getNode(), 'No credentials got returned!');
|
||||||
|
}
|
||||||
|
|
||||||
|
let options: OptionsWithUri = {
|
||||||
|
method,
|
||||||
|
qs,
|
||||||
|
form: {
|
||||||
|
api_key: credentials.apiKey,
|
||||||
|
...body,
|
||||||
|
},
|
||||||
|
uri: uri || `https://api.uptimerobot.com/v2${resource}`,
|
||||||
|
json: true,
|
||||||
|
};
|
||||||
|
options = Object.assign({}, options, option);
|
||||||
|
try {
|
||||||
|
const responseData = await this.helpers.request(options);
|
||||||
|
if (responseData.stat !== 'ok') {
|
||||||
|
throw new NodeOperationError(this.getNode(), responseData);
|
||||||
|
}
|
||||||
|
return responseData;
|
||||||
|
} catch (error) {
|
||||||
|
throw new NodeApiError(this.getNode(), error);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,468 @@
|
|||||||
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
export const maintenanceWindowOperations = [
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Create',
|
||||||
|
value: 'create',
|
||||||
|
description: 'Create a maintenance window',
|
||||||
|
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Delete',
|
||||||
|
value: 'delete',
|
||||||
|
description: 'Delete a maintenance window',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get',
|
||||||
|
value: 'get',
|
||||||
|
description: 'Get a maintenance window',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get All',
|
||||||
|
value: 'getAll',
|
||||||
|
description: 'Get all a maintenance windows',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Update',
|
||||||
|
value: 'update',
|
||||||
|
description: 'Update a maintenance window',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'getAll',
|
||||||
|
description: 'The operation to perform.',
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
|
|
||||||
|
export const maintenanceWindowFields = [
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* maintenanceWindow:create */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Duration (minutes)',
|
||||||
|
name: 'duration',
|
||||||
|
type: 'number',
|
||||||
|
required: true,
|
||||||
|
default: 1,
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The maintenance window activation period (minutes).',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendlyName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The friendly name of the maintenance window.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Type',
|
||||||
|
name: 'type',
|
||||||
|
type: 'options',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Once',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Daily',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Weekly',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Monthly',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The type of the maintenance window.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Week Day',
|
||||||
|
name: 'weekDay',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
type: [
|
||||||
|
3,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
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: 7,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: '',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Month Day',
|
||||||
|
name: 'monthDay',
|
||||||
|
type: 'number',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
type: [
|
||||||
|
4,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
typeOptions: {
|
||||||
|
minValue: 1,
|
||||||
|
maxValue: 30,
|
||||||
|
},
|
||||||
|
default: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Start Time',
|
||||||
|
name: 'start_time',
|
||||||
|
type: 'dateTime',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The maintenance window start datetime.',
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* maintenanceWindow:delete */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'delete',
|
||||||
|
'get',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the maintenance window.',
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* maintenanceWindow:getAll */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Return All',
|
||||||
|
name: 'returnAll',
|
||||||
|
type: 'boolean',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: false,
|
||||||
|
description: 'Whether all results should be returned or only up to a given limit.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Limit',
|
||||||
|
name: 'limit',
|
||||||
|
type: 'number',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
returnAll: [
|
||||||
|
false,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
typeOptions: {
|
||||||
|
minValue: 1,
|
||||||
|
maxValue: 100,
|
||||||
|
},
|
||||||
|
default: 50,
|
||||||
|
description: 'How many results to return.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Filters',
|
||||||
|
name: 'filters',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Maintenance Window IDs',
|
||||||
|
name: 'mwindow',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'Maintenance windows ids separated with dash, e.g. 236-1782-4790.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* maintenanceWindow:update */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the maintenance window.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Duration (minutes)',
|
||||||
|
name: 'duration',
|
||||||
|
type: 'number',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The maintenance window activation period (minutes).',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Update Fields',
|
||||||
|
name: 'updateFields',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'maintenanceWindow',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendly_name',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The friendly name of the maintenance window.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Start Time',
|
||||||
|
name: 'start_time',
|
||||||
|
type: 'dateTime',
|
||||||
|
default: '',
|
||||||
|
description: 'The maintenance window start datetime.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Type',
|
||||||
|
name: 'type',
|
||||||
|
type: 'options',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Once',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Daily',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Weekly',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Monthly',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'The type of the maintenance window.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Week Day',
|
||||||
|
name: 'weekDay',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
type: [
|
||||||
|
3,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
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: 7,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: '',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Month Day',
|
||||||
|
name: 'monthDay',
|
||||||
|
type: 'number',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
type: [
|
||||||
|
4,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
typeOptions: {
|
||||||
|
minValue: 1,
|
||||||
|
maxValue: 30,
|
||||||
|
},
|
||||||
|
default: 1,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
512
packages/nodes-base/nodes/UptimeRobot/MonitorDescription.ts
Normal file
512
packages/nodes-base/nodes/UptimeRobot/MonitorDescription.ts
Normal file
@@ -0,0 +1,512 @@
|
|||||||
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
export const monitorOperations = [
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Create',
|
||||||
|
value: 'create',
|
||||||
|
description: 'Create a monitor',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Delete',
|
||||||
|
value: 'delete',
|
||||||
|
description: 'Delete a monitor',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get',
|
||||||
|
value: 'get',
|
||||||
|
description: 'Get a monitor',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get All',
|
||||||
|
value: 'getAll',
|
||||||
|
description: 'Get all monitors',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Reset',
|
||||||
|
value: 'reset',
|
||||||
|
description: 'Reset a monitor',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Update',
|
||||||
|
value: 'update',
|
||||||
|
description: 'Update a monitor',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'getAll',
|
||||||
|
description: 'The operation to perform.',
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
|
|
||||||
|
export const monitorFields = [
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* monitor:create */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendlyName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The friendly name of the monitor.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Type',
|
||||||
|
name: 'type',
|
||||||
|
type: 'options',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Heartbeat',
|
||||||
|
value: 5,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'HTTP(S)',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Keyword',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Ping',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Port',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The type of the monitor.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'URL',
|
||||||
|
name: 'url',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The URL/IP of the monitor.',
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* monitor:delete/reset */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'delete',
|
||||||
|
'reset',
|
||||||
|
'get',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the monitor.',
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* monitor:getAll */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Return All',
|
||||||
|
name: 'returnAll',
|
||||||
|
type: 'boolean',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: false,
|
||||||
|
description: 'If all results should be returned or only up to a given limit.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Limit',
|
||||||
|
name: 'limit',
|
||||||
|
type: 'number',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
returnAll: [
|
||||||
|
false,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
typeOptions: {
|
||||||
|
minValue: 1,
|
||||||
|
maxValue: 100,
|
||||||
|
},
|
||||||
|
default: 50,
|
||||||
|
description: 'How many results to return.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Filters',
|
||||||
|
name: 'filters',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Alert Contacts',
|
||||||
|
name: 'alert_contacts',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'Whether the alert contacts set for the monitor to be returned.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Logs',
|
||||||
|
name: 'logs',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'If the logs of each monitor will be returned.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Maintenance Window',
|
||||||
|
name: 'mwindow',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'If the maintenance windows for the monitors to be returned.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Monitor IDs',
|
||||||
|
name: 'monitors',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'Monitors IDs separated with dash, e.g. 15830-32696-83920.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Response Times',
|
||||||
|
name: 'response_times',
|
||||||
|
type: 'boolean',
|
||||||
|
default: false,
|
||||||
|
description: 'Whether the response time data of each monitor will be returned.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Search',
|
||||||
|
name: 'search',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'A keyword to be matched against url and friendly name.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Statuses',
|
||||||
|
name: 'statuses',
|
||||||
|
type: 'multiOptions',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Paused',
|
||||||
|
value: 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Not Checked Yet',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Up',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Seems Down',
|
||||||
|
value: 8,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Down',
|
||||||
|
value: 9,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Types',
|
||||||
|
name: 'types',
|
||||||
|
type: 'multiOptions',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Heartbeat',
|
||||||
|
value: 5,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'HTTP(S)',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Keyword',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Ping',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Port',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'Select monitor types.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* monitor:update */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the monitor.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Update Fields',
|
||||||
|
name: 'updateFields',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'monitor',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendly_name',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The friendly name of the monitor.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'HTTP Auth Type',
|
||||||
|
name: 'http_auth_type',
|
||||||
|
type: 'options',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'HTTP Basic',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Digest',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'The authentication type for password-protected web pages.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'HTTP Method',
|
||||||
|
name: 'http_method',
|
||||||
|
type: 'options',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'DELETE',
|
||||||
|
value: 6,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'GET',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'HEAD',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'OPTIONS',
|
||||||
|
value: 7,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'PATCH',
|
||||||
|
value: 5,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'POST',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'PUT',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'The HTTP method to be used.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'HTTP Password',
|
||||||
|
name: 'http_password',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The password used for password-protected web pages.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'HTTP Username',
|
||||||
|
name: 'http_username',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The username used for password-protected web pages.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Interval',
|
||||||
|
name: 'interval',
|
||||||
|
type: 'number',
|
||||||
|
default: '',
|
||||||
|
description: 'The interval for the monitoring check.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Port',
|
||||||
|
name: 'port',
|
||||||
|
type: 'number',
|
||||||
|
default: '',
|
||||||
|
description: 'The monitored port.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Status',
|
||||||
|
name: 'status',
|
||||||
|
type: 'options',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Pause',
|
||||||
|
value: 0,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Resume',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'Select monitor statuses.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Sub type',
|
||||||
|
name: 'sub_type',
|
||||||
|
type: 'options',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Custom Port',
|
||||||
|
value: 99,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'FTP (21)',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'HTTP (80)',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'HTTPS (443)',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'IMAP (143)',
|
||||||
|
value: 6,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'POP3 (110)',
|
||||||
|
value: 5,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'SMTP (25)',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'Specify which pre-defined port/service or custom port is monitored.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'URL',
|
||||||
|
name: 'url',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The URL/IP of the monitor.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
@@ -0,0 +1,338 @@
|
|||||||
|
import {
|
||||||
|
INodeProperties,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
export const publicStatusPageOperations = [
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Create',
|
||||||
|
value: 'create',
|
||||||
|
description: 'Create a public status page',
|
||||||
|
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Delete',
|
||||||
|
value: 'delete',
|
||||||
|
description: 'Delete a public status page',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get',
|
||||||
|
value: 'get',
|
||||||
|
description: 'Get a public status page',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Get All',
|
||||||
|
value: 'getAll',
|
||||||
|
description: 'Get all a public status pages',
|
||||||
|
},
|
||||||
|
// Got deactivated because it did not work reliably. Looks like it is on the UptimeRobot
|
||||||
|
// side but we deactivate for now just to be sure
|
||||||
|
// {
|
||||||
|
// name: 'Update',
|
||||||
|
// value: 'update',
|
||||||
|
// description: 'Update a public status page',
|
||||||
|
// },
|
||||||
|
],
|
||||||
|
default: 'getAll',
|
||||||
|
description: 'The operation to perform.',
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
|
|
||||||
|
export const publicStatusPageFields = [
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* publicStatusPage:create */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendlyName',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The friendly name of the status page.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Monitor IDs',
|
||||||
|
name: 'monitors',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'Monitor ids to be displayed in status page (the values are separated with a dash (-) or 0 for all monitors).',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Additional Fields',
|
||||||
|
name: 'additionalFields',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'create',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Custom Domain',
|
||||||
|
name: 'custom_domain',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The domain or subdomain that the status page will run on.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Password',
|
||||||
|
name: 'password',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The password for the status page.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Sort',
|
||||||
|
name: 'sort',
|
||||||
|
type: 'options',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Friendly Name (A-Z)',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Friendly Name (Z-A)',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Status (Up-Down-Paused)',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Status (Down-Up-Paused)',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'The sorting of the status page.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* publicStatusPage:delete */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'delete',
|
||||||
|
'get',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the public status page.',
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* publicStatusPage:getAll */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Return All',
|
||||||
|
name: 'returnAll',
|
||||||
|
type: 'boolean',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
default: false,
|
||||||
|
description: 'If all results should be returned or only up to a given limit.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Limit',
|
||||||
|
name: 'limit',
|
||||||
|
type: 'number',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
returnAll: [
|
||||||
|
false,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
typeOptions: {
|
||||||
|
minValue: 1,
|
||||||
|
maxValue: 100,
|
||||||
|
},
|
||||||
|
default: 50,
|
||||||
|
description: 'How many results to return.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Filters',
|
||||||
|
name: 'filters',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'getAll',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Public Status Page IDs',
|
||||||
|
name: 'psps',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'Public status pages ids separated with dash, e.g. 236-1782-4790.',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* publicStatusPage:update */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'ID',
|
||||||
|
name: 'id',
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
description: 'The ID of the public status page.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Update Fields',
|
||||||
|
name: 'updateFields',
|
||||||
|
type: 'collection',
|
||||||
|
placeholder: 'Add Field',
|
||||||
|
default: {},
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'publicStatusPage',
|
||||||
|
],
|
||||||
|
operation: [
|
||||||
|
'update',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
displayName: 'Custom Domain',
|
||||||
|
name: 'custom_domain',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The domain or subdomain that the status page will run on.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Friendly Name',
|
||||||
|
name: 'friendly_name',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The friendly name of the status page.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Monitor IDs',
|
||||||
|
name: 'monitors',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'Monitor IDs to be displayed in status page (the values are separated with a dash (-) or 0 for all monitors).',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Password',
|
||||||
|
name: 'password',
|
||||||
|
type: 'string',
|
||||||
|
default: '',
|
||||||
|
description: 'The password for the status page.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Sort',
|
||||||
|
name: 'sort',
|
||||||
|
type: 'options',
|
||||||
|
default: '',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Friendly Name (A-Z)',
|
||||||
|
value: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Friendly Name (Z-A)',
|
||||||
|
value: 2,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Status (Up-Down-Paused)',
|
||||||
|
value: 3,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Status (Down-Up-Paused)',
|
||||||
|
value: 4,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
description: 'The sorting of the status page',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
] as INodeProperties[];
|
||||||
20
packages/nodes-base/nodes/UptimeRobot/UptimeRobot.node.json
Normal file
20
packages/nodes-base/nodes/UptimeRobot/UptimeRobot.node.json
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
"node": "n8n-nodes-base.uptimeRobot",
|
||||||
|
"nodeVersion": "1.0",
|
||||||
|
"codexVersion": "1.0",
|
||||||
|
"categories": [
|
||||||
|
"Monitoring"
|
||||||
|
],
|
||||||
|
"resources": {
|
||||||
|
"credentialDocumentation": [
|
||||||
|
{
|
||||||
|
"url": "https://docs.n8n.io/credentials/uptimeRobot"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"primaryDocumentation": [
|
||||||
|
{
|
||||||
|
"url": "https://docs.n8n.io/nodes/n8n-nodes-base.uptimeRobot/"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
447
packages/nodes-base/nodes/UptimeRobot/UptimeRobot.node.ts
Normal file
447
packages/nodes-base/nodes/UptimeRobot/UptimeRobot.node.ts
Normal file
@@ -0,0 +1,447 @@
|
|||||||
|
import {
|
||||||
|
IExecuteFunctions,
|
||||||
|
} from 'n8n-core';
|
||||||
|
|
||||||
|
import {
|
||||||
|
IDataObject,
|
||||||
|
INodeExecutionData,
|
||||||
|
INodeType,
|
||||||
|
INodeTypeDescription,
|
||||||
|
} from 'n8n-workflow';
|
||||||
|
|
||||||
|
import {
|
||||||
|
uptimeRobotApiRequest,
|
||||||
|
} from './GenericFunctions';
|
||||||
|
|
||||||
|
import {
|
||||||
|
monitorFields,
|
||||||
|
monitorOperations,
|
||||||
|
} from './MonitorDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
alertContactFields,
|
||||||
|
alertContactOperations,
|
||||||
|
} from './AlertContactDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
maintenanceWindowFields,
|
||||||
|
maintenanceWindowOperations,
|
||||||
|
} from './MaintenanceWindowDescription';
|
||||||
|
|
||||||
|
import {
|
||||||
|
publicStatusPageFields,
|
||||||
|
publicStatusPageOperations,
|
||||||
|
} from './PublicStatusPageDescription';
|
||||||
|
|
||||||
|
import * as moment from 'moment-timezone';
|
||||||
|
|
||||||
|
export class UptimeRobot implements INodeType {
|
||||||
|
description: INodeTypeDescription = {
|
||||||
|
displayName: 'UptimeRobot',
|
||||||
|
name: 'uptimeRobot',
|
||||||
|
icon: 'file:uptimerobot.svg',
|
||||||
|
group: ['output'],
|
||||||
|
version: 1,
|
||||||
|
subtitle: '={{$parameter["operation"] + ": " + $parameter["resource"]}}',
|
||||||
|
description: 'Consume UptimeRobot API',
|
||||||
|
defaults: {
|
||||||
|
name: 'UptimeRobot',
|
||||||
|
color: '#3bd671',
|
||||||
|
},
|
||||||
|
inputs: ['main'],
|
||||||
|
outputs: ['main'],
|
||||||
|
credentials: [
|
||||||
|
{
|
||||||
|
name: 'uptimeRobotApi',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
properties: [
|
||||||
|
{
|
||||||
|
displayName: 'Resource',
|
||||||
|
name: 'resource',
|
||||||
|
type: 'options',
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Account',
|
||||||
|
value: 'account',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Alert Contact',
|
||||||
|
value: 'alertContact',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Maintenance Window',
|
||||||
|
value: 'maintenanceWindow',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Monitor',
|
||||||
|
value: 'monitor',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Public Status Page',
|
||||||
|
value: 'publicStatusPage',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'account',
|
||||||
|
description: 'Resource to consume.',
|
||||||
|
},
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* account:getAccountDetails */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
{
|
||||||
|
displayName: 'Operation',
|
||||||
|
name: 'operation',
|
||||||
|
type: 'options',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
resource: [
|
||||||
|
'account',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: [
|
||||||
|
{
|
||||||
|
name: 'Get',
|
||||||
|
value: 'get',
|
||||||
|
description: 'Get account details',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
default: 'get',
|
||||||
|
description: 'The operation to perform.',
|
||||||
|
},
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* Monitor */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
...monitorOperations,
|
||||||
|
...monitorFields,
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* Alert Contact */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
...alertContactOperations,
|
||||||
|
...alertContactFields,
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* Maintenance Window */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
...maintenanceWindowOperations,
|
||||||
|
...maintenanceWindowFields,
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
/* Public Status Page */
|
||||||
|
/* -------------------------------------------------------------------------- */
|
||||||
|
...publicStatusPageOperations,
|
||||||
|
...publicStatusPageFields,
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
||||||
|
const items = this.getInputData();
|
||||||
|
const returnData = [];
|
||||||
|
const length = items.length;
|
||||||
|
let responseData;
|
||||||
|
const timezone = this.getTimezone();
|
||||||
|
for (let i = 0; i < length; i++) {
|
||||||
|
try {
|
||||||
|
const resource = this.getNodeParameter('resource', 0) as string;
|
||||||
|
const operation = this.getNodeParameter('operation', 0) as string;
|
||||||
|
let body: IDataObject = {};
|
||||||
|
//https://uptimerobot.com/#methods
|
||||||
|
if (resource === 'account') {
|
||||||
|
if (operation === 'get') {
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getAccountDetails');
|
||||||
|
responseData = responseData.account;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (resource === 'monitor') {
|
||||||
|
if (operation === 'create') {
|
||||||
|
body = {
|
||||||
|
friendly_name: this.getNodeParameter('friendlyName', i) as string,
|
||||||
|
url: this.getNodeParameter('url', i) as string,
|
||||||
|
type: this.getNodeParameter('type', i) as number,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/newMonitor', body);
|
||||||
|
responseData = responseData.monitor;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (operation === 'delete') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/deleteMonitor', body);
|
||||||
|
responseData = responseData.monitor;
|
||||||
|
}
|
||||||
|
if (operation === 'get') {
|
||||||
|
const monitors = this.getNodeParameter('id', i) as string;
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getMonitors', { monitors });
|
||||||
|
responseData = responseData.monitors;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (operation === 'getAll') {
|
||||||
|
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
|
||||||
|
const filters = this.getNodeParameter('filters', i) as IDataObject;
|
||||||
|
|
||||||
|
body = {
|
||||||
|
...filters,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (body.statuses) {
|
||||||
|
body.statuses = (body.statuses as string[]).join('-');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (body.types) {
|
||||||
|
body.types = (body.types as string[]).join('-');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (body.alert_contacts) {
|
||||||
|
body.alert_contacts = 1;
|
||||||
|
}
|
||||||
|
if (body.logs) {
|
||||||
|
body.logs = 1;
|
||||||
|
}
|
||||||
|
if (body.mwindow) {
|
||||||
|
body.mwindows = 1;
|
||||||
|
}
|
||||||
|
if (body.response_times) {
|
||||||
|
body.response_times = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!returnAll) {
|
||||||
|
body.limit = this.getNodeParameter('limit', i) as number;
|
||||||
|
}
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getMonitors', body);
|
||||||
|
responseData = responseData.monitors;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (operation === 'reset') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/resetMonitor', body);
|
||||||
|
responseData = responseData.monitor;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (operation === 'update') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
...this.getNodeParameter('updateFields', i) as IDataObject,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/editMonitor', body);
|
||||||
|
responseData = responseData.monitor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (resource === 'alertContact') {
|
||||||
|
if (operation === 'create') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
friendly_name: this.getNodeParameter('friendlyName', i) as string,
|
||||||
|
value: this.getNodeParameter('value', i) as string,
|
||||||
|
type: this.getNodeParameter('type', i) as number,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/newAlertContact', body);
|
||||||
|
responseData = responseData.alertcontact;
|
||||||
|
}
|
||||||
|
if (operation === 'delete') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/deleteAlertContact', body);
|
||||||
|
responseData = responseData.alert_contact;
|
||||||
|
}
|
||||||
|
if (operation === 'get') {
|
||||||
|
const id = this.getNodeParameter('id', i) as string;
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getAlertContacts', { alert_contacts: id });
|
||||||
|
responseData = responseData.alert_contacts;
|
||||||
|
}
|
||||||
|
if (operation === 'getAll') {
|
||||||
|
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
|
||||||
|
|
||||||
|
body = {
|
||||||
|
...this.getNodeParameter('filters', i) as IDataObject,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!returnAll) {
|
||||||
|
body.limit = this.getNodeParameter('limit', i) as number;
|
||||||
|
}
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getAlertContacts', body);
|
||||||
|
responseData = responseData.alert_contacts;
|
||||||
|
}
|
||||||
|
if (operation === 'update') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
...this.getNodeParameter('updateFields', i) as IDataObject,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/editAlertContact', body);
|
||||||
|
responseData = responseData.alert_contact;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (resource === 'maintenanceWindow') {
|
||||||
|
if (operation === 'create') {
|
||||||
|
const startTime = this.getNodeParameter('start_time', i) as string;
|
||||||
|
const type = this.getNodeParameter('type', i) as number;
|
||||||
|
|
||||||
|
const parsedStartTime = type === 1
|
||||||
|
? moment.tz(startTime, timezone).unix()
|
||||||
|
: moment.tz(startTime, timezone).format('HH:mm');
|
||||||
|
|
||||||
|
body = {
|
||||||
|
duration: this.getNodeParameter('duration', i) as number,
|
||||||
|
friendly_name: this.getNodeParameter('friendlyName', i) as string,
|
||||||
|
start_time: parsedStartTime,
|
||||||
|
type,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (type === 3) {
|
||||||
|
body['value'] = this.getNodeParameter('weekDay', i) as number;
|
||||||
|
}
|
||||||
|
if (type === 4) {
|
||||||
|
body['value'] = this.getNodeParameter('monthDay', i) as number;
|
||||||
|
}
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/newMWindow', body);
|
||||||
|
responseData = responseData.mwindow;
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'delete') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/deleteMWindow', body);
|
||||||
|
responseData = { status: responseData.message };
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'get') {
|
||||||
|
const mwindows = this.getNodeParameter('id', i) as string;
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getMWindows', { mwindows });
|
||||||
|
responseData = responseData.mwindows;
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'getAll') {
|
||||||
|
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
|
||||||
|
|
||||||
|
body = {
|
||||||
|
...this.getNodeParameter('filters', i) as IDataObject,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!returnAll) {
|
||||||
|
body.limit = this.getNodeParameter('limit', i) as number;
|
||||||
|
}
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getMWindows', body);
|
||||||
|
responseData = responseData.mwindows;
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'update') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
duration: this.getNodeParameter('duration', i) as string,
|
||||||
|
...this.getNodeParameter('updateFields', i) as IDataObject,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (body.type === 1 && body.start_time) {
|
||||||
|
body.start_time = moment.tz(body.start_time, timezone).unix();
|
||||||
|
} else {
|
||||||
|
body.start_time = moment.tz(body.start_time, timezone).format('HH:mm');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (body.type === 3) {
|
||||||
|
body['value'] = body.weekDay;
|
||||||
|
delete body.weekDay;
|
||||||
|
}
|
||||||
|
if (body.type === 4) {
|
||||||
|
body['value'] = body.monthDay;
|
||||||
|
delete body.monthDay;
|
||||||
|
}
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/editMWindow', body);
|
||||||
|
responseData = responseData.mwindow;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (resource === 'publicStatusPage') {
|
||||||
|
if (operation === 'create') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
friendly_name: this.getNodeParameter('friendlyName', i) as string,
|
||||||
|
monitors: this.getNodeParameter('monitors', i) as string,
|
||||||
|
...this.getNodeParameter('additionalFields', i) as IDataObject,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/newPSP', body);
|
||||||
|
responseData = responseData.psp;
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'delete') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
};
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/deletePSP', body);
|
||||||
|
responseData = responseData.psp;
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'get') {
|
||||||
|
const psps = this.getNodeParameter('id', i) as string;
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getPSPs', { psps });
|
||||||
|
responseData = responseData.psps;
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'getAll') {
|
||||||
|
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
|
||||||
|
|
||||||
|
body = {
|
||||||
|
...this.getNodeParameter('filters', i) as IDataObject,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!returnAll) {
|
||||||
|
body.limit = this.getNodeParameter('limit', i) as number;
|
||||||
|
}
|
||||||
|
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/getPSPs', body);
|
||||||
|
responseData = responseData.psps;
|
||||||
|
|
||||||
|
}
|
||||||
|
if (operation === 'update') {
|
||||||
|
|
||||||
|
body = {
|
||||||
|
id: this.getNodeParameter('id', i) as string,
|
||||||
|
...this.getNodeParameter('updateFields', i) as IDataObject,
|
||||||
|
};
|
||||||
|
responseData = await uptimeRobotApiRequest.call(this, 'POST', '/editPSP', body);
|
||||||
|
responseData = responseData.psp;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Array.isArray(responseData)
|
||||||
|
? returnData.push(...responseData)
|
||||||
|
: returnData.push(responseData);
|
||||||
|
} catch (error) {
|
||||||
|
if (this.continueOnFail()) {
|
||||||
|
returnData.push({ error: error.message });
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return [this.helpers.returnJsonArray(returnData)];
|
||||||
|
}
|
||||||
|
}
|
||||||
6
packages/nodes-base/nodes/UptimeRobot/uptimerobot.svg
Normal file
6
packages/nodes-base/nodes/UptimeRobot/uptimerobot.svg
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" width="512" height="512" viewBox="0 0 512 512">
|
||||||
|
<g fill="none" fill-rule="evenodd">
|
||||||
|
<circle cx="256" cy="256" r="256" fill="#2A8C00"/>
|
||||||
|
<circle cx="256.5" cy="256.5" r="141.5" fill="#20201F" stroke="#FFFFFF" stroke-width="20"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 291 B |
@@ -259,6 +259,7 @@
|
|||||||
"dist/credentials/UnleashedSoftwareApi.credentials.js",
|
"dist/credentials/UnleashedSoftwareApi.credentials.js",
|
||||||
"dist/credentials/UpleadApi.credentials.js",
|
"dist/credentials/UpleadApi.credentials.js",
|
||||||
"dist/credentials/UProcApi.credentials.js",
|
"dist/credentials/UProcApi.credentials.js",
|
||||||
|
"dist/credentials/UptimeRobotApi.credentials.js",
|
||||||
"dist/credentials/VeroApi.credentials.js",
|
"dist/credentials/VeroApi.credentials.js",
|
||||||
"dist/credentials/VonageApi.credentials.js",
|
"dist/credentials/VonageApi.credentials.js",
|
||||||
"dist/credentials/WebflowApi.credentials.js",
|
"dist/credentials/WebflowApi.credentials.js",
|
||||||
@@ -546,6 +547,7 @@
|
|||||||
"dist/nodes/UnleashedSoftware/UnleashedSoftware.node.js",
|
"dist/nodes/UnleashedSoftware/UnleashedSoftware.node.js",
|
||||||
"dist/nodes/Uplead/Uplead.node.js",
|
"dist/nodes/Uplead/Uplead.node.js",
|
||||||
"dist/nodes/UProc/UProc.node.js",
|
"dist/nodes/UProc/UProc.node.js",
|
||||||
|
"dist/nodes/UptimeRobot/UptimeRobot.node.js",
|
||||||
"dist/nodes/Vero/Vero.node.js",
|
"dist/nodes/Vero/Vero.node.js",
|
||||||
"dist/nodes/Vonage/Vonage.node.js",
|
"dist/nodes/Vonage/Vonage.node.js",
|
||||||
"dist/nodes/Webflow/Webflow.node.js",
|
"dist/nodes/Webflow/Webflow.node.js",
|
||||||
|
|||||||
Reference in New Issue
Block a user