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

58 lines
1.3 KiB
TypeScript
Raw Normal View History

import { IExecuteFunctions, IHookFunctions, ILoadOptionsFunctions } from 'n8n-core';
2019-07-12 08:54:15 -07:00
import { OptionsWithUri } from 'request';
2019-07-12 08:54:15 -07:00
import { IDataObject } from 'n8n-workflow';
2019-07-12 08:54:15 -07:00
/**
* Make an API request to Trello
*
*/
export async function apiRequest(
this: IHookFunctions | IExecuteFunctions | ILoadOptionsFunctions,
method: string,
endpoint: string,
body: object,
query?: IDataObject,
// tslint:disable-next-line:no-any
): Promise<any> {
2019-07-12 08:54:15 -07:00
query = query || {};
const options: OptionsWithUri = {
method,
body,
qs: query,
uri: `https://api.trello.com/1/${endpoint}`,
json: true,
};
return this.helpers.requestWithAuthentication.call(this, 'trelloApi', options);
2019-07-12 08:54:15 -07:00
}
export async function apiRequestAllItems(
this: IHookFunctions | IExecuteFunctions,
method: string,
endpoint: string,
body: IDataObject,
query: IDataObject = {},
// tslint:disable-next-line:no-any
): Promise<any> {
query.limit = 30;
query.sort = '-id';
const returnData: IDataObject[] = [];
let responseData;
do {
responseData = await apiRequest.call(this, method, endpoint, body, query);
returnData.push.apply(returnData, responseData);
if (responseData.length !== 0) {
query.before = responseData[responseData.length - 1].id;
}
} while (query.limit <= responseData.length);
return returnData;
}