n8n/packages/nodes-base/nodes/Microsoft/Excel/GenericFunctions.ts

92 lines
2.2 KiB
TypeScript
Raw Normal View History

import type { OptionsWithUri } from 'request';
import type {
IDataObject,
IExecuteFunctions,
IExecuteSingleFunctions,
ILoadOptionsFunctions,
JsonObject,
} from 'n8n-workflow';
import { NodeApiError } from 'n8n-workflow';
2020-03-15 16:51:31 -07:00
export async function microsoftApiRequest(
this: IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions,
method: string,
resource: string,
body: any = {},
qs: IDataObject = {},
uri?: string,
headers: IDataObject = {},
): Promise<any> {
2020-03-15 16:51:31 -07:00
const options: OptionsWithUri = {
headers: {
'Content-Type': 'application/json',
},
method,
body,
qs,
uri: uri || `https://graph.microsoft.com/v1.0/me${resource}`,
2020-10-22 06:46:03 -07:00
json: true,
2020-03-15 16:51:31 -07:00
};
try {
if (Object.keys(headers).length !== 0) {
options.headers = Object.assign({}, options.headers, headers);
}
//@ts-ignore
return await this.helpers.requestOAuth2.call(this, 'microsoftExcelOAuth2Api', options);
2020-03-15 16:51:31 -07:00
} catch (error) {
throw new NodeApiError(this.getNode(), error as JsonObject);
2020-03-15 16:51:31 -07:00
}
}
export async function microsoftApiRequestAllItems(
this: IExecuteFunctions | ILoadOptionsFunctions,
propertyName: string,
method: string,
endpoint: string,
body: any = {},
query: IDataObject = {},
): Promise<any> {
2020-03-15 16:51:31 -07:00
const returnData: IDataObject[] = [];
let responseData;
let uri: string | undefined;
query.$top = 100;
2020-03-15 16:51:31 -07:00
do {
responseData = await microsoftApiRequest.call(this, method, endpoint, body, query, uri);
uri = responseData['@odata.nextLink'];
if (uri?.includes('$top')) {
delete query.$top;
}
returnData.push.apply(returnData, responseData[propertyName] as IDataObject[]);
} while (responseData['@odata.nextLink'] !== undefined);
2020-03-15 16:51:31 -07:00
return returnData;
}
export async function microsoftApiRequestAllItemsSkip(
this: IExecuteFunctions | ILoadOptionsFunctions,
propertyName: string,
method: string,
endpoint: string,
body: any = {},
query: IDataObject = {},
): Promise<any> {
2020-03-15 16:51:31 -07:00
const returnData: IDataObject[] = [];
let responseData;
query.$top = 100;
query.$skip = 0;
2020-03-15 16:51:31 -07:00
do {
responseData = await microsoftApiRequest.call(this, method, endpoint, body, query);
query.$skip += query.$top;
returnData.push.apply(returnData, responseData[propertyName] as IDataObject[]);
} while (responseData.value.length !== 0);
2020-03-15 16:51:31 -07:00
return returnData;
}