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

131 lines
3.8 KiB
TypeScript
Raw Normal View History

2019-11-23 16:36:47 -08:00
import { OptionsWithUri } from 'request';
import {
BINARY_ENCODING,
2019-11-23 16:36:47 -08:00
IExecuteFunctions,
IExecuteSingleFunctions,
2019-11-23 16:36:47 -08:00
IHookFunctions,
ILoadOptionsFunctions,
2019-12-01 07:38:54 -08:00
IWebhookFunctions,
2019-11-23 16:36:47 -08:00
} from 'n8n-core';
import {
IDataObject,
} from 'n8n-workflow';
export async function payPalApiRequest(this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions | IWebhookFunctions, endpoint: string, method: string, body: any = {}, query?: IDataObject, uri?: string): Promise<any> { // tslint:disable-line:no-any
const credentials = this.getCredentials('payPalApi');
const env = getEnvironment(credentials!.env as string);
2019-11-26 08:59:27 -08:00
const tokenInfo = await getAccessToken.call(this);
const headerWithAuthentication = Object.assign({ },
{ Authorization: `Bearer ${tokenInfo.access_token}`, 'Content-Type': 'application/json' });
const options = {
headers: headerWithAuthentication,
method,
qs: query || {},
uri: uri || `${env}/v1${endpoint}`,
body,
2020-10-22 06:46:03 -07:00
json: true,
2019-11-26 08:59:27 -08:00
};
2019-11-23 16:36:47 -08:00
try {
2019-11-26 08:59:27 -08:00
return await this.helpers.request!(options);
2019-11-23 16:36:47 -08:00
} catch (error) {
if (error.response.body) {
let errorMessage = error.response.body.message;
if (error.response.body.details) {
errorMessage += ` - Details: ${JSON.stringify(error.response.body.details)}`;
}
throw new Error(errorMessage);
}
throw error;
2019-11-23 16:36:47 -08:00
}
2019-11-26 08:59:27 -08:00
}
2019-11-23 16:36:47 -08:00
function getEnvironment(env: string): string {
2019-11-26 08:59:27 -08:00
// @ts-ignore
return {
'sanbox': 'https://api.sandbox.paypal.com',
'live': 'https://api.paypal.com',
2019-11-26 08:59:27 -08:00
}[env];
}
2019-11-23 16:36:47 -08:00
2019-12-01 07:38:54 -08:00
async function getAccessToken(this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions | IWebhookFunctions): Promise<any> { // tslint:disable-line:no-any
const credentials = this.getCredentials('payPalApi');
2019-11-26 08:59:27 -08:00
if (credentials === undefined) {
throw new Error('No credentials got returned!');
}
const env = getEnvironment(credentials!.env as string);
2019-11-26 08:59:27 -08:00
const data = Buffer.from(`${credentials!.clientId}:${credentials!.secret}`).toString(BINARY_ENCODING);
const headerWithAuthentication = Object.assign({},
{ Authorization: `Basic ${data}`, 'Content-Type': 'application/x-www-form-urlencoded' });
const options: OptionsWithUri = {
headers: headerWithAuthentication,
method: 'POST',
form: {
grant_type: 'client_credentials',
},
uri: `${env}/v1/oauth2/token`,
2020-10-22 06:46:03 -07:00
json: true,
2019-11-26 08:59:27 -08:00
};
2019-11-23 16:36:47 -08:00
try {
return await this.helpers.request!(options);
} catch (error) {
const errorMessage = error.response.body.message || error.response.body.Message;
if (errorMessage !== undefined) {
throw new Error(errorMessage);
2019-11-23 16:36:47 -08:00
}
throw new Error(error.response.body);
2019-11-23 16:36:47 -08:00
}
}
2019-11-23 16:36:47 -08:00
/**
2019-11-26 08:59:27 -08:00
* Make an API request to paginated paypal endpoint
2019-11-23 16:36:47 -08:00
* and return all results
*/
export async function payPalApiRequestAllItems(this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions, propertyName: string, endpoint: string, method: string, body: any = {}, query?: IDataObject, uri?: string): Promise<any> { // tslint:disable-line:no-any
2019-11-23 16:36:47 -08:00
const returnData: IDataObject[] = [];
let responseData;
2019-11-26 08:59:27 -08:00
query!.page_size = 1000;
2019-11-23 16:36:47 -08:00
do {
responseData = await payPalApiRequest.call(this, endpoint, method, body, query, uri);
2019-11-26 08:59:27 -08:00
uri = getNext(responseData.links);
2019-11-23 16:36:47 -08:00
returnData.push.apply(returnData, responseData[propertyName]);
} while (
2019-11-26 08:59:27 -08:00
getNext(responseData.links) !== undefined
2019-11-23 16:36:47 -08:00
);
return returnData;
}
2019-11-26 08:59:27 -08:00
function getNext(links: IDataObject[]): string | undefined {
for (const link of links) {
if (link.rel === 'next') {
return link.href as string;
}
}
return undefined;
}
2019-11-23 16:36:47 -08:00
export function validateJSON(json: string | undefined): any { // tslint:disable-line:no-any
let result;
try {
result = JSON.parse(json!);
} catch (exception) {
result = '';
}
return result;
}
2019-12-01 07:38:54 -08:00
export function upperFist(s: string): string {
return s.split('.').map(e => {
return e.toLowerCase().charAt(0).toUpperCase() + e.toLowerCase().slice(1);
}).join(' ');
}