n8n/packages/nodes-base/nodes/Harvest/GenericFunctions.ts

120 lines
3.4 KiB
TypeScript
Raw Normal View History

import {
OptionsWithUri,
} from 'request';
2020-01-28 06:46:38 -08:00
import {
IExecuteFunctions,
IExecuteSingleFunctions,
IHookFunctions,
ILoadOptionsFunctions,
} from 'n8n-core';
import {
IDataObject
} from 'n8n-workflow';
2020-01-28 06:46:38 -08:00
export async function harvestApiRequest(this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions, method: string, qs: IDataObject = {}, path: string, body: IDataObject = {}, option: IDataObject = {}, uri?: string): Promise<any> { // tslint:disable-line:no-any
2020-01-28 06:46:38 -08:00
let options: OptionsWithUri = {
headers: {
'Harvest-Account-Id': `${this.getNodeParameter('accountId', 0)}`,
'User-Agent': 'Harvest App',
'Authorization': '',
},
2020-01-28 06:46:38 -08:00
method,
body,
uri: uri || `https://api.harvestapp.com/v2/${path}`,
qs,
2020-01-28 06:46:38 -08:00
json: true,
};
options = Object.assign({}, options, option);
if (Object.keys(options.body).length === 0) {
delete options.body;
}
const authenticationMethod = this.getNodeParameter('authentication', 0);
2020-02-03 04:55:21 -08:00
2020-01-28 06:46:38 -08:00
try {
if (authenticationMethod === 'accessToken') {
const credentials = this.getCredentials('harvestApi') as IDataObject;
if (credentials === undefined) {
throw new Error('No credentials got returned!');
}
//@ts-ignore
options.headers['Authorization'] = `Bearer ${credentials.accessToken}`;
return await this.helpers.request!(options);
} else {
return await this.helpers.requestOAuth2!.call(this, 'harvestOAuth2Api', options);
}
2020-01-28 06:46:38 -08:00
} catch (error) {
if (error.statusCode === 401) {
// Return a clear error
throw new Error('The Harvest credentials are not valid!');
}
2020-01-29 15:51:14 -08:00
if (error.error && error.error.message) {
2020-01-28 06:46:38 -08:00
// Try to return the error prettier
2020-01-29 15:51:14 -08:00
throw new Error(`Harvest error response [${error.statusCode}]: ${error.error.message}`);
2020-01-28 06:46:38 -08:00
}
// If that data does not exist for some reason return the actual error
2020-01-29 15:51:14 -08:00
throw new Error(`Harvest error response: ${error.message}`);
2020-01-28 06:46:38 -08:00
}
}
/**
* Make an API request to paginated flow endpoint
* and return all results
*/
export async function harvestApiRequestAllItems(
this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions,
method: string,
qs: IDataObject = {},
uri: string,
resource: string,
body: IDataObject = {},
option: IDataObject = {},
): Promise<any> { // tslint:disable-line:no-any
2020-01-28 06:46:38 -08:00
const returnData: IDataObject[] = [];
let responseData;
do {
responseData = await harvestApiRequest.call(this, method, qs, uri, body, option);
qs.page = responseData.next_page;
returnData.push.apply(returnData, responseData[resource]);
} while (responseData.next_page);
return returnData;
}
/**
* fetch All resource using paginated calls
*/
export async function getAllResource(this: IExecuteFunctions | ILoadOptionsFunctions, resource: string, i: number) {
const endpoint = resource;
const qs: IDataObject = {};
const requestMethod = 'GET';
qs.per_page = 100;
const additionalFields = this.getNodeParameter('filters', i) as IDataObject;
const returnAll = this.getNodeParameter('returnAll', i) as boolean;
Object.assign(qs, additionalFields);
let responseData: IDataObject = {};
if (returnAll) {
responseData[resource] = await harvestApiRequestAllItems.call(this, requestMethod, qs, endpoint, resource);
} else {
const limit = this.getNodeParameter('limit', i) as string;
qs.per_page = limit;
responseData = await harvestApiRequest.call(this, requestMethod, qs, endpoint);
2020-01-28 06:46:38 -08:00
}
return responseData[resource] as IDataObject[];
2020-01-28 06:46:38 -08:00
}