diff --git a/packages/nodes-base/credentials/OrbitApi.credentials.ts b/packages/nodes-base/credentials/OrbitApi.credentials.ts
index b07225c60a08a..1157041f7e206 100644
--- a/packages/nodes-base/credentials/OrbitApi.credentials.ts
+++ b/packages/nodes-base/credentials/OrbitApi.credentials.ts
@@ -8,6 +8,13 @@ export class OrbitApi implements ICredentialType {
documentationUrl = 'orbit';
properties: INodeProperties[] = [
+ {
+ displayName:
+ 'Orbit has been shutdown and will no longer function from July 11th, You can read more here.',
+ name: 'deprecated',
+ type: 'notice',
+ default: '',
+ },
{
displayName: 'API Token',
name: 'accessToken',
diff --git a/packages/nodes-base/nodes/Orbit/ActivityDescription.ts b/packages/nodes-base/nodes/Orbit/ActivityDescription.ts
index b37055b14e713..c88a0ad3e7665 100644
--- a/packages/nodes-base/nodes/Orbit/ActivityDescription.ts
+++ b/packages/nodes-base/nodes/Orbit/ActivityDescription.ts
@@ -42,7 +42,7 @@ export const activityFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -97,7 +97,7 @@ export const activityFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getActivityTypes',
},
- default: '',
+ default: 'Deprecated',
description:
'A user-defined way to group activities of the same nature. Choose from the list, or specify an ID using an expression.',
},
@@ -151,7 +151,7 @@ export const activityFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
diff --git a/packages/nodes-base/nodes/Orbit/MemberDescription.ts b/packages/nodes-base/nodes/Orbit/MemberDescription.ts
index 6de1470f01c6c..5f84d91e9dd3a 100644
--- a/packages/nodes-base/nodes/Orbit/MemberDescription.ts
+++ b/packages/nodes-base/nodes/Orbit/MemberDescription.ts
@@ -66,7 +66,7 @@ export const memberFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -101,7 +101,7 @@ export const memberFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -151,7 +151,7 @@ export const memberFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -257,7 +257,7 @@ export const memberFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -398,7 +398,7 @@ export const memberFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -528,7 +528,7 @@ export const memberFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
diff --git a/packages/nodes-base/nodes/Orbit/NoteDescription.ts b/packages/nodes-base/nodes/Orbit/NoteDescription.ts
index 751e7fd23c3bb..1d1f03b48b4e8 100644
--- a/packages/nodes-base/nodes/Orbit/NoteDescription.ts
+++ b/packages/nodes-base/nodes/Orbit/NoteDescription.ts
@@ -48,7 +48,7 @@ export const noteFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -96,7 +96,7 @@ export const noteFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -174,7 +174,7 @@ export const noteFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
diff --git a/packages/nodes-base/nodes/Orbit/Orbit.node.ts b/packages/nodes-base/nodes/Orbit/Orbit.node.ts
index 29492054239a0..d019979d56069 100644
--- a/packages/nodes-base/nodes/Orbit/Orbit.node.ts
+++ b/packages/nodes-base/nodes/Orbit/Orbit.node.ts
@@ -1,6 +1,5 @@
import type {
IExecuteFunctions,
- IDataObject,
ILoadOptionsFunctions,
INodeExecutionData,
INodePropertyOptions,
@@ -8,8 +7,7 @@ import type {
INodeTypeDescription,
} from 'n8n-workflow';
-import moment from 'moment-timezone';
-import { orbitApiRequest, orbitApiRequestAllItems, resolveIdentities } from './GenericFunctions';
+import { NodeApiError } from 'n8n-workflow';
import { activityFields, activityOperations } from './ActivityDescription';
@@ -19,8 +17,6 @@ import { noteFields, noteOperations } from './NoteDescription';
import { postFields, postOperations } from './PostDescription';
-import type { IRelation } from './Interfaces';
-
export class Orbit implements INodeType {
description: INodeTypeDescription = {
displayName: 'Orbit',
@@ -30,6 +26,7 @@ export class Orbit implements INodeType {
version: 1,
subtitle: '={{$parameter["operation"] + ": " + $parameter["resource"]}}',
description: 'Consume Orbit API',
+ hidden: true,
defaults: {
name: 'Orbit',
},
@@ -42,6 +39,13 @@ export class Orbit implements INodeType {
},
],
properties: [
+ {
+ displayName:
+ 'Orbit has been shutdown and will no longer function from July 11th, You can read more here.',
+ name: 'deprecated',
+ type: 'notice',
+ default: '',
+ },
{
displayName: 'Resource',
name: 'resource',
@@ -85,463 +89,18 @@ export class Orbit implements INodeType {
methods = {
loadOptions: {
async getWorkspaces(this: ILoadOptionsFunctions): Promise {
- 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.attributes.slug,
- });
- }
- return returnData;
+ return [{ name: 'Deprecated', value: 'Deprecated' }];
},
async getActivityTypes(this: ILoadOptionsFunctions): Promise {
- 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;
+ return [{ name: 'Deprecated', value: 'Deprecated' }];
},
},
};
async execute(this: IExecuteFunctions): Promise {
- const items = this.getInputData();
- const returnData: INodeExecutionData[] = [];
- const length = items.length;
- const qs: IDataObject = {};
- let responseData;
- const resource = this.getNodeParameter('resource', 0);
- const operation = this.getNodeParameter('operation', 0);
- 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);
- 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);
- const filters = this.getNodeParameter('filters', i);
- let endpoint = `/${workspaceId}/activities`;
- if (filters.memberId) {
- endpoint = `/${workspaceId}/members/${filters.memberId}/activities`;
- }
- if (returnAll) {
- responseData = await orbitApiRequestAllItems.call(
- this,
- 'data',
- 'GET',
- endpoint,
- {},
- qs,
- );
- } else {
- qs.limit = this.getNodeParameter('limit', 0);
- 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);
- 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) {
- resolveIdentities(responseData as IRelation);
- }
- responseData = responseData.data;
- }
- if (operation === 'getAll') {
- const workspaceId = this.getNodeParameter('workspaceId', i) as string;
- const returnAll = this.getNodeParameter('returnAll', 0);
- const options = this.getNodeParameter('options', i);
- Object.assign(qs, options);
- qs.resolveIdentities = this.getNodeParameter('resolveIdentities', 0) as boolean;
- if (returnAll) {
- responseData = await orbitApiRequestAllItems.call(
- this,
- 'data',
- 'GET',
- `/${workspaceId}/members`,
- {},
- qs,
- );
- } else {
- qs.limit = this.getNodeParameter('limit', 0);
- 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);
- 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);
- qs.resolveMember = this.getNodeParameter('resolveMember', 0) as boolean;
- if (returnAll) {
- responseData = await orbitApiRequestAllItems.call(
- this,
- 'data',
- 'GET',
- `/${workspaceId}/members/${memberId}/notes`,
- {},
- qs,
- );
- } else {
- qs.limit = this.getNodeParameter('limit', 0);
- 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);
- 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);
- const filters = this.getNodeParameter('filters', i);
- let endpoint = `/${workspaceId}/activities`;
- qs.type = 'content';
- if (filters.memberId) {
- endpoint = `/${workspaceId}/members/${filters.memberId}/activities`;
- }
- if (returnAll) {
- responseData = await orbitApiRequestAllItems.call(
- this,
- 'data',
- 'GET',
- endpoint,
- {},
- qs,
- );
- } else {
- qs.limit = this.getNodeParameter('limit', 0);
- 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 };
- }
- }
-
- const executionData = this.helpers.constructExecutionMetaData(
- this.helpers.returnJsonArray(responseData as IDataObject),
- { itemData: { item: i } },
- );
-
- returnData.push(...executionData);
- } catch (error) {
- if (this.continueOnFail(error)) {
- const executionErrorData = this.helpers.constructExecutionMetaData(
- this.helpers.returnJsonArray({ error: error.message }),
- { itemData: { item: i } },
- );
- returnData.push(...executionErrorData);
- continue;
- }
- throw error;
- }
- }
- return [returnData];
+ throw new NodeApiError(this.getNode(), {
+ message: 'Service is deprecated, From July 11th Orbit will no longer function.',
+ level: 'warning',
+ });
}
}
diff --git a/packages/nodes-base/nodes/Orbit/PostDescription.ts b/packages/nodes-base/nodes/Orbit/PostDescription.ts
index 0c153ef81906f..6b317a11539f7 100644
--- a/packages/nodes-base/nodes/Orbit/PostDescription.ts
+++ b/packages/nodes-base/nodes/Orbit/PostDescription.ts
@@ -48,7 +48,7 @@ export const postFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -119,7 +119,7 @@ export const postFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {
@@ -194,7 +194,7 @@ export const postFields: INodeProperties[] = [
typeOptions: {
loadOptionsMethod: 'getWorkspaces',
},
- default: '',
+ default: 'Deprecated',
required: true,
displayOptions: {
show: {