Add user Create API

This commit is contained in:
trojanh
2020-01-31 18:49:16 +05:30
parent 8374a23389
commit adcc482703
2 changed files with 304 additions and 131 deletions

View File

@@ -111,7 +111,7 @@ export class Harvest implements INodeType {
}, },
{ {
name: 'User', name: 'User',
value: 'user', value: 'users',
}, },
], ],
default: 'task', default: 'task',
@@ -356,7 +356,7 @@ export class Harvest implements INodeType {
} else { } else {
throw new Error(`The resource "${resource}" is not known!`); throw new Error(`The resource "${resource}" is not known!`);
} }
} else if (resource === 'user') { } else if (resource === 'users') {
if (operation === 'get') { if (operation === 'get') {
// ---------------------------------- // ----------------------------------
// get // get
@@ -365,7 +365,7 @@ export class Harvest implements INodeType {
requestMethod = 'GET'; requestMethod = 'GET';
const id = this.getNodeParameter('id', i) as string; const id = this.getNodeParameter('id', i) as string;
endpoint = `users/${id}`; endpoint = `${resource}/${id}`;
const responseData = await harvestApiRequest.call(this, requestMethod, qs, endpoint); const responseData = await harvestApiRequest.call(this, requestMethod, qs, endpoint);
returnData.push(responseData); returnData.push(responseData);
@@ -375,7 +375,7 @@ export class Harvest implements INodeType {
// getAll // getAll
// ---------------------------------- // ----------------------------------
const responseData: IDataObject[] = await getAllResource.call(this, 'users', i); const responseData: IDataObject[] = await getAllResource.call(this, resource, i);
returnData.push.apply(returnData, responseData); returnData.push.apply(returnData, responseData);
} else if (operation === 'me') { } else if (operation === 'me') {
@@ -385,11 +385,29 @@ export class Harvest implements INodeType {
requestMethod = 'GET'; requestMethod = 'GET';
endpoint = 'users/me'; endpoint = `${resource}/me`;
const responseData = await harvestApiRequest.call(this, requestMethod, qs, endpoint); const responseData = await harvestApiRequest.call(this, requestMethod, qs, endpoint);
returnData.push(responseData); returnData.push(responseData);
} else if (operation === 'create') {
// ----------------------------------
// createByDuration
// ----------------------------------
requestMethod = 'POST';
endpoint = resource;
['first_name', 'last_name', 'email'].forEach(val => {
body[val] = this.getNodeParameter(val, i) as string;
})
const additionalFields = this.getNodeParameter('additionalFields', i) as IDataObject;
Object.assign(body, additionalFields);
const responseData = await harvestApiRequest.call(this, requestMethod, qs, endpoint, body);
returnData.push(responseData);
} else if (operation === 'delete') { } else if (operation === 'delete') {
// ---------------------------------- // ----------------------------------
// delete // delete

View File

@@ -1,5 +1,7 @@
import { INodeProperties } from "n8n-workflow"; import { INodeProperties } from "n8n-workflow";
const resource = ['users'];
export const userOperations = [ export const userOperations = [
{ {
displayName: 'Operation', displayName: 'Operation',
@@ -7,9 +9,7 @@ export const userOperations = [
type: 'options', type: 'options',
displayOptions: { displayOptions: {
show: { show: {
resource: [ resource,
'user',
],
}, },
}, },
options: [ options: [
@@ -28,6 +28,11 @@ export const userOperations = [
value: 'getAll', value: 'getAll',
description: 'Get data of all users', description: 'Get data of all users',
}, },
{
name: 'Create',
value: 'create',
description: `Create a user`,
},
{ {
name: 'Delete', name: 'Delete',
value: 'delete', value: 'delete',
@@ -42,19 +47,17 @@ export const userOperations = [
export const userFields = [ export const userFields = [
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
/* user:getAll */ /* user:getAll */
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
{ {
displayName: 'Return All', displayName: 'Return All',
name: 'returnAll', name: 'returnAll',
type: 'boolean', type: 'boolean',
displayOptions: { displayOptions: {
show: { show: {
resource: [ resource,
'user',
],
operation: [ operation: [
'getAll', 'getAll',
], ],
@@ -62,16 +65,14 @@ export const userFields = [
}, },
default: false, default: false,
description: 'Returns a list of your users.', description: 'Returns a list of your users.',
}, },
{ {
displayName: 'Limit', displayName: 'Limit',
name: 'limit', name: 'limit',
type: 'number', type: 'number',
displayOptions: { displayOptions: {
show: { show: {
resource: [ resource,
'user',
],
operation: [ operation: [
'getAll', 'getAll',
], ],
@@ -86,8 +87,8 @@ export const userFields = [
}, },
default: 100, default: 100,
description: 'How many results to return.', description: 'How many results to return.',
}, },
{ {
displayName: 'Filters', displayName: 'Filters',
name: 'filters', name: 'filters',
type: 'collection', type: 'collection',
@@ -95,9 +96,7 @@ export const userFields = [
default: {}, default: {},
displayOptions: { displayOptions: {
show: { show: {
resource: [ resource,
'user',
],
operation: [ operation: [
'getAll', 'getAll',
], ],
@@ -129,12 +128,12 @@ export const userFields = [
description: 'The page number to use in pagination..', description: 'The page number to use in pagination..',
} }
] ]
}, },
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
/* user:get */ /* user:get */
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
{ {
displayName: 'User Id', displayName: 'User Id',
name: 'id', name: 'id',
type: 'string', type: 'string',
@@ -145,18 +144,16 @@ export const userFields = [
operation: [ operation: [
'get', 'get',
], ],
resource: [ resource,
'user',
],
}, },
}, },
description: 'The ID of the user you are retrieving.', description: 'The ID of the user you are retrieving.',
}, },
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
/* user:delete */ /* user:delete */
/* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */
{ {
displayName: 'User Id', displayName: 'User Id',
name: 'id', name: 'id',
type: 'string', type: 'string',
@@ -167,12 +164,170 @@ export const userFields = [
operation: [ operation: [
'delete', 'delete',
], ],
resource: [ resource,
'user',
],
}, },
}, },
description: 'The ID of the user you want to delete.', description: 'The ID of the user you want to delete.',
} },
/* -------------------------------------------------------------------------- */
/* user:create */
/* -------------------------------------------------------------------------- */
{
displayName: 'First Name',
name: 'first_name',
type: 'string',
displayOptions: {
show: {
operation: [
'create',
],
resource,
},
},
default: '',
required: true,
description: 'The first name of the user.',
},
{
displayName: 'Last Name',
name: 'last_name',
type: 'string',
displayOptions: {
show: {
operation: [
'create',
],
resource,
},
},
default: '',
required: true,
description: 'The last name of the user.',
},
{
displayName: 'Email',
name: 'email',
type: 'string',
displayOptions: {
show: {
operation: [
'create',
],
resource,
},
},
default: '',
required: true,
description: 'The email of the user.',
},
{
displayName: 'Additional Fields',
name: 'additionalFields',
type: 'collection',
placeholder: 'Add Field',
displayOptions: {
show: {
operation: [
'create',
],
resource,
},
},
default: {},
options: [
{
displayName: 'Timezone',
name: 'timezone',
type: 'string',
default: '',
description: 'The users timezone. Defaults to the companys timezone. See a list of <a href="/api-v2/introduction/overview/supported-timezones/">supported time zones</a>.</td>'
},
{
displayName: 'Has Access To All Future Projects',
name: 'has_access_to_all_future_projects',
type: 'string',
default: '',
description: 'Whether the user should be automatically added to future projects. Defaults to <code class="language-plaintext highlighter-rouge">false</code>.</td>'
},
{
displayName: 'Is Contractor',
name: 'is_contractor',
type: 'string',
default: '',
description: 'Whether the user is a contractor or an employee. Defaults to <code class="language-plaintext highlighter-rouge">false</code>.</td>'
},
{
displayName: 'Is Admin',
name: 'is_admin',
type: 'string',
default: '',
description: 'Whether the user has Admin permissions. Defaults to <code class="language-plaintext highlighter-rouge">false</code>.</td>'
},
{
displayName: 'Is Project Manager',
name: 'is_project_manager',
type: 'string',
default: '',
description: 'Whether the user has Project Manager permissions. Defaults to <code class="language-plaintext highlighter-rouge">false</code>.</td>'
},
{
displayName: 'Can See Rates',
name: 'can_see_rates',
type: 'string',
default: '',
description: 'Whether the user can see billable rates on projects. Only applicable to Project Managers. Defaults to <code class="language-plaintext highlighter-rouge">false</code>.</td>'
},
{
displayName: 'Can Create Projects',
name: 'can_create_projects',
type: 'string',
default: '',
description: 'Whether the user can create projects. Only applicable to Project Managers. Defaults to <code class="language-plaintext highlighter-rouge">false</code>.</td>'
},
{
displayName: 'Can Create Invoices',
name: 'can_create_invoices',
type: 'string',
default: '',
description: 'Whether the user can create invoices. Only applicable to Project Managers. Defaults to <code class="language-plaintext highlighter-rouge">false</code>.</td>'
},
{
displayName: 'Is Active',
name: 'is_active',
type: 'string',
default: '',
description: 'Whether the user is active or archived. Defaults to <code class="language-plaintext highlighter-rouge">true</code>.</td>'
},
{
displayName: 'Weekly Capacity',
name: 'weekly_capacity',
type: 'string',
default: '',
description: 'The number of hours per week this person is available to work in seconds. Defaults to <code class="language-plaintext highlighter-rouge">126000</code> seconds (35 hours).</td>'
},
{
displayName: 'Default Hourly Rate',
name: 'default_hourly_rate',
type: 'string',
default: '',
description: 'The billable rate to use for this user when they are added to a project. Defaults to <code class="language-plaintext highlighter-rouge">0</code>.</td>'
},
{
displayName: 'Cost Rate',
name: 'cost_rate',
type: 'string',
default: '',
description: 'The cost rate to use for this user when calculating a projects costs vs billable amount. Defaults to <code class="language-plaintext highlighter-rouge">0</code>.</td>'
},
{
displayName: 'Roles',
name: 'roles',
type: 'string',
default: '',
description: 'The role names assigned to this person.</td>'
},
],
},
] as INodeProperties[]; ] as INodeProperties[];