n8n/packages/nodes-base/nodes/Orbit/Orbit.node.ts
Omar Ajoue d6239d5bfb
Add full continue-on-fail support to all nodes (#1996)
* Update Compression node

* Update Crypto node

* Update DateTime node

* Update EditImage node

* Update EmailSend node

* Update ExecuteWorkflow node

* Update FTP node

* Update Function node

* Update FunctionItem node

* Update ExecuteCommand node

* Update OpenWeatherMap node

* Update ReadBinaryFile node

* Update ReadPdf node

* Update RssFeedRead node & add URL validation

* Update SpreadsheetFile node

* Update Switch node

* Update WriteBinaryFile node

* Update Xml node

* Update ActiveCampaign node

* Update Airtable node

* Update ApiTemplateIo node

* Update Asana node

* Update AwsLambda node

* Update AwsSns node

* Update AwsComprehend node

* Update AwsRekognition node

* Update AwsS3 node

* Fix Error item

* Update AwsSes node

* Update AwsSqs node

* Update Amqp node

* Update Bitly node

* Update Box node

* Update Brandfetch node

* Update CircleCi node

* Update Clearbit node

* Update ClickUp node

* Update Cockpit node

* Update CoinGecko node

* Update Contentful node

* Update ConvertKit node

* Update Cortex node

* Update CustomerIo node

* Update DeepL node

* Update Demio node

* Update Disqus node

* Update Drift node

* Update Dropbox node

* Update GetResponse node

* Refactor & Update Ghost node

* Update Github node

* Update Gitlab node

* Update GoogleAnalytics node

* Update GoogleBooks node

* Update GoogleCalendar node

* Update GoogleDrive node

* Update Gmail node

* Update GoogleSheets node

* Update GoogleSlides node

* Update GoogleTasks node

* Update Gotify node

* Update GraphQL node

* Update HackerNews node

* Update Harvest node

* Update HtmlExtract node

* Update Hubspot node

* Update Hunter node

* Update Intercom node

* Update Kafka node

* Refactor & update Line node

* Update LinkedIn node

* Update Mailchimp node

* Update Mandrill node

* Update Matrix node

* Update Mautic node

* Update Medium node

* Update MessageBird node

* Update Mindee node

* Update Mocean node

* Update MondayCom node

* Update MicrosoftExcel node

* Update MicrosoftOneDrive node

* Update MicrosoftOutlook node

* Update Affinity node

* Update Chargebee node

* Update Discourse node

* Update Freshdesk node

* Update YouTube node

* Update InvoiceNinja node

* Update MailerLite node

* Update Mailgun node

* Update Mailjet node

* Update Mattermost node

* Update Nasa node

* Update NextCloud node

* Update OpenThesaurus node

* Update Orbit node

* Update PagerDuty node

* Update PayPal node

* Update Peekalink node

* Update Phantombuster node

* Update PostHog node

* Update ProfitWell node

* Refactor & Update Pushbullet node

* Update QuickBooks node

* Update Raindrop node

* Update Reddit node

* Update Rocketchat node

* Update S3 node

* Update Salesforce node

* Update SendGrid node

* Update SentryIo node

* Update Shopify node

* Update Signl4 node

* Update Slack node

* Update Spontit node

* Update Spotify node

* Update Storyblok node

* Refactor & Update Strapi node

* Refactor & Update Strava node

* Update Taiga node

* Refactor & update Tapfiliate node

* Update Telegram node

* Update TheHive node

* Update Todoist node

* Update TravisCi node

* Update Trello node

* Update Twilio node

* Update Twist node

* Update Twitter node

* Update Uplead node

* Update UProc node

* Update Vero node

* Update Webflow node

* Update Wekan node

* Update Wordpress node

* Update Xero node

* Update Yourls node

* Update Zendesk node

* Update ZohoCrm node

* Refactor & Update Zoom node

* Update Zulip node

* Update Clockify node

* Update MongoDb node

* Update MySql node

* Update MicrosoftTeams node

* Update Stackby node

* Refactor Discourse node

* Support corner-case in Github node update

* Support corner-case in Gitlab node update

* Refactor & Update GoogleContacts node

* Refactor Mindee node

* Update Coda node

* Lint fixes

* Update Beeminder node

* Update Google Firebase RealtimeDatabase node

* Update HelpScout node

* Update Mailcheck node

* Update Paddle node

* Update Pipedrive node

* Update Pushover node

* Update Segment node

* Refactor & Update Vonage node

* Added new conditions to warnings on execute batch cmd

* Added keep only properties flag

* Fixed code for keep only props

* Added dependencies for image editing

Co-authored-by: dali <servfrdali@yahoo.fr>
2021-07-20 08:58:54 +02:00

482 lines
16 KiB
TypeScript

import {
IExecuteFunctions,
} from 'n8n-core';
import {
IDataObject,
ILoadOptionsFunctions,
INodeExecutionData,
INodePropertyOptions,
INodeType,
INodeTypeDescription,
} from 'n8n-workflow';
import {
orbitApiRequest,
orbitApiRequestAllItems,
resolveIdentities,
} from './GenericFunctions';
import {
activityFields,
activityOperations,
} from './ActivityDescription';
import {
memberFields,
memberOperations,
} from './MemberDescription';
import {
noteFields,
noteOperations,
} from './NoteDescription';
import {
postFields,
postOperations,
} from './PostDescription';
import * as moment from 'moment';
export class Orbit implements INodeType {
description: INodeTypeDescription = {
displayName: 'Orbit',
name: 'orbit',
icon: 'file:orbit.svg',
group: ['output'],
version: 1,
subtitle: '={{$parameter["operation"] + ": " + $parameter["resource"]}}',
description: 'Consume Orbit API',
defaults: {
name: 'Orbit',
color: '#00ade8',
},
inputs: ['main'],
outputs: ['main'],
credentials: [
{
name: 'orbitApi',
required: true,
},
],
properties: [
{
displayName: 'Resource',
name: 'resource',
type: 'options',
options: [
{
name: 'Activity',
value: 'activity',
},
{
name: 'Member',
value: 'member',
},
{
name: 'Note',
value: 'note',
},
{
name: 'Post',
value: 'post',
},
],
default: 'member',
description: 'Resource to consume.',
},
// ACTIVITY
...activityOperations,
...activityFields,
// MEMBER
...memberOperations,
...memberFields,
// NOTE
...noteOperations,
...noteFields,
// POST
...postOperations,
...postFields,
],
};
methods = {
loadOptions: {
async getWorkspaces(
this: ILoadOptionsFunctions,
): Promise<INodePropertyOptions[]> {
const returnData: INodePropertyOptions[] = [];
const workspaces = await orbitApiRequest.call(
this,
'GET',
'/workspaces',
);
for (const workspace of workspaces.data) {
returnData.push({
name: workspace.attributes.name,
value: workspace.id,
});
}
return returnData;
},
async getActivityTypes(
this: ILoadOptionsFunctions,
): Promise<INodePropertyOptions[]> {
const returnData: INodePropertyOptions[] = [];
const { data } = await orbitApiRequest.call(
this,
'GET',
'/activity_types',
);
for (const activityType of data) {
returnData.push({
name: activityType.attributes.short_name,
value: activityType.id,
});
}
return returnData;
},
},
};
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
const items = this.getInputData();
const returnData: IDataObject[] = [];
const length = items.length as unknown as number;
const qs: IDataObject = {};
let responseData;
const resource = this.getNodeParameter('resource', 0) as string;
const operation = this.getNodeParameter('operation', 0) as string;
for (let i = 0; i < length; i++) {
try {
if (resource === 'activity') {
if (operation === 'create') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const title = this.getNodeParameter('title', i) as string;
const additionalFields = this.getNodeParameter('additionalFields', i) as IDataObject;
const body: IDataObject = {
title,
};
if (additionalFields.description) {
body.description = additionalFields.description as string;
}
if (additionalFields.link) {
body.link = additionalFields.link as string;
}
if (additionalFields.linkText) {
body.link_text = additionalFields.linkText as string;
}
if (additionalFields.activityType) {
body.activity_type = additionalFields.activityType as string;
}
if (additionalFields.key) {
body.key = additionalFields.key as string;
}
if (additionalFields.occurredAt) {
body.occurred_at = additionalFields.occurredAt as string;
}
responseData = await orbitApiRequest.call(this, 'POST', `/${workspaceId}/members/${memberId}/activities`, body);
responseData = responseData.data;
}
if (operation === 'getAll') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
const filters = this.getNodeParameter('filters', i) as IDataObject;
let endpoint = `/${workspaceId}/activities`;
if (filters.memberId) {
endpoint = `/${workspaceId}/members/${filters.memberId}/activities`;
}
if (returnAll === true) {
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', endpoint, {}, qs);
} else {
qs.limit = this.getNodeParameter('limit', 0) as boolean;
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', endpoint, {}, qs);
responseData = responseData.splice(0, qs.limit);
}
}
}
if (resource === 'member') {
if (operation === 'upsert') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const additionalFields = this.getNodeParameter('additionalFields', i) as IDataObject;
const member: IDataObject = {};
const identity: IDataObject = {};
if (additionalFields.bio) {
member.bio = additionalFields.bio as string;
}
if (additionalFields.birthday) {
member.birthday = moment(additionalFields.birthday as string).format('MM-DD-YYYY');
}
if (additionalFields.company) {
member.company = additionalFields.company as string;
}
if (additionalFields.location) {
member.location = additionalFields.location as string;
}
if (additionalFields.name) {
member.name = additionalFields.name as string;
}
if (additionalFields.bio) {
member.bio = additionalFields.bio as string;
}
if (additionalFields.pronouns) {
member.pronouns = additionalFields.pronouns as string;
}
if (additionalFields.shippingAddress) {
member.shipping_address = additionalFields.shippingAddress as string;
}
if (additionalFields.slug) {
member.slug = additionalFields.slug as string;
}
if (additionalFields.tagsToAdd) {
member.tags_to_add = additionalFields.tagsToAdd as string;
}
if (additionalFields.tagList) {
member.tag_list = additionalFields.tagList as string;
}
if (additionalFields.tshirt) {
member.tshirt = additionalFields.tshirt as string;
}
if (additionalFields.hasOwnProperty('teammate')) {
member.teammate = additionalFields.teammate as boolean;
}
if (additionalFields.url) {
member.url = additionalFields.url as string;
}
const data = (this.getNodeParameter('identityUi', i) as IDataObject).identityValue as IDataObject;
if (data) {
if (['github', 'twitter', 'discourse'].includes(data.source as string)) {
identity.source = data.source as string;
const searchBy = data.searchBy as string;
if (searchBy === 'id') {
identity.uid = data.id as string;
} else {
identity.username = data.username as string;
}
if (data.source === 'discourse') {
identity.source_host = data.host as string;
}
} else {
//it's email
identity.email = data.email as string;
}
}
responseData = await orbitApiRequest.call(this, 'POST', `/${workspaceId}/members`, { member, identity });
responseData = responseData.data;
}
if (operation === 'delete') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
responseData = await orbitApiRequest.call(this, 'DELETE', `/${workspaceId}/members/${memberId}`);
responseData = { success: true };
}
if (operation === 'get') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const resolve = this.getNodeParameter('resolveIdentities', 0) as boolean;
responseData = await orbitApiRequest.call(this, 'GET', `/${workspaceId}/members/${memberId}`);
if (resolve === true) {
resolveIdentities(responseData);
}
responseData = responseData.data;
}
if (operation === 'getAll') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const returnAll = this.getNodeParameter('returnAll', 0) as boolean;
const options = this.getNodeParameter('options', i) as IDataObject;
Object.assign(qs, options);
qs.resolveIdentities = this.getNodeParameter('resolveIdentities', 0) as boolean;
if (returnAll === true) {
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', `/${workspaceId}/members`, {}, qs);
} else {
qs.limit = this.getNodeParameter('limit', 0) as boolean;
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', `/${workspaceId}/members`, {}, qs);
responseData = responseData.splice(0, qs.limit);
}
}
if (operation === 'lookup') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const source = this.getNodeParameter('source', i) as string;
if (['github', 'twitter', 'discourse'].includes(source)) {
qs.source = this.getNodeParameter('source', i) as string;
const searchBy = this.getNodeParameter('searchBy', i) as string;
if (searchBy === 'id') {
qs.uid = this.getNodeParameter('id', i) as string;
} else {
qs.username = this.getNodeParameter('username', i) as string;
}
if (source === 'discourse') {
qs.source_host = this.getNodeParameter('host', i) as string;
}
} else {
//it's email
qs.email = this.getNodeParameter('email', i) as string;
}
responseData = await orbitApiRequest.call(this, 'GET', `/${workspaceId}/members/find`, {}, qs);
responseData = responseData.data;
}
if (operation === 'update') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const updateFields = this.getNodeParameter('updateFields', i) as IDataObject;
const body: IDataObject = {
};
if (updateFields.bio) {
body.bio = updateFields.bio as string;
}
if (updateFields.birthday) {
body.birthday = moment(updateFields.birthday as string).format('MM-DD-YYYY');
}
if (updateFields.company) {
body.company = updateFields.company as string;
}
if (updateFields.location) {
body.location = updateFields.location as string;
}
if (updateFields.name) {
body.name = updateFields.name as string;
}
if (updateFields.bio) {
body.bio = updateFields.bio as string;
}
if (updateFields.pronouns) {
body.pronouns = updateFields.pronouns as string;
}
if (updateFields.shippingAddress) {
body.shipping_address = updateFields.shippingAddress as string;
}
if (updateFields.slug) {
body.slug = updateFields.slug as string;
}
if (updateFields.tagsToAdd) {
body.tags_to_add = updateFields.tagsToAdd as string;
}
if (updateFields.tagList) {
body.tag_list = updateFields.tagList as string;
}
if (updateFields.tshirt) {
body.tshirt = updateFields.tshirt as string;
}
if (updateFields.hasOwnProperty('teammate')) {
body.teammate = updateFields.teammate as boolean;
}
if (updateFields.url) {
body.url = updateFields.url as string;
}
responseData = await orbitApiRequest.call(this, 'PUT', `/${workspaceId}/members/${memberId}`, body);
responseData = { success: true };
}
}
if (resource === 'note') {
if (operation === 'create') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const note = this.getNodeParameter('note', i) as string;
responseData = await orbitApiRequest.call(this, 'POST', `/${workspaceId}/members/${memberId}/notes`, { body: note });
responseData = responseData.data;
}
if (operation === 'getAll') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
qs.resolveMember = this.getNodeParameter('resolveMember', 0) as boolean;
if (returnAll === true) {
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', `/${workspaceId}/members/${memberId}/notes`, {}, qs);
} else {
qs.limit = this.getNodeParameter('limit', 0) as boolean;
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', `/${workspaceId}/members/${memberId}/notes`, {}, qs);
responseData = responseData.splice(0, qs.limit);
}
}
if (operation === 'update') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const noteId = this.getNodeParameter('noteId', i) as string;
const note = this.getNodeParameter('note', i) as string;
responseData = await orbitApiRequest.call(this, 'PUT', `/${workspaceId}/members/${memberId}/notes/${noteId}`, { body: note });
responseData = { success: true };
}
}
if (resource === 'post') {
if (operation === 'create') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const url = this.getNodeParameter('url', i) as string;
const additionalFields = this.getNodeParameter('additionalFields', i) as IDataObject;
const body: IDataObject = {
type: 'post',
activity_type: 'post',
url,
};
if (additionalFields.publishedAt) {
body.occurred_at = additionalFields.publishedAt as string;
delete body.publishedAt;
}
responseData = await orbitApiRequest.call(this, 'POST', `/${workspaceId}/members/${memberId}/activities/`, body);
responseData = responseData.data;
}
if (operation === 'getAll') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
const filters = this.getNodeParameter('filters', i) as IDataObject;
let endpoint = `/${workspaceId}/activities`;
qs.type = 'content';
if (filters.memberId) {
endpoint = `/${workspaceId}/members/${filters.memberId}/activities`;
}
if (returnAll === true) {
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', endpoint, {}, qs);
} else {
qs.limit = this.getNodeParameter('limit', 0) as boolean;
responseData = await orbitApiRequestAllItems.call(this, 'data', 'GET', endpoint, {}, qs);
responseData = responseData.splice(0, qs.limit);
}
}
if (operation === 'delete') {
const workspaceId = this.getNodeParameter('workspaceId', i) as string;
const memberId = this.getNodeParameter('memberId', i) as string;
const postId = this.getNodeParameter('postId', i) as string;
responseData = await orbitApiRequest.call(this, 'DELETE', `/${workspaceId}/members/${memberId}/activities/${postId}`);
responseData = { success: true };
}
}
if (Array.isArray(responseData)) {
returnData.push.apply(returnData, responseData as IDataObject[]);
} else {
returnData.push(responseData as IDataObject);
}
} catch (error) {
if (this.continueOnFail()) {
returnData.push({ error: error.message });
continue;
}
throw error;
}
}
return [this.helpers.returnJsonArray(returnData)];
}
}