import type { IDataObject, IExecuteFunctions, IHttpRequestMethods, ILoadOptionsFunctions, IRequestOptions, JsonObject, } from 'n8n-workflow'; import { NodeApiError } from 'n8n-workflow'; export async function microsoftApiRequest( this: IExecuteFunctions | ILoadOptionsFunctions, method: IHttpRequestMethods, resource: string, body: any = {}, qs: IDataObject = {}, uri?: string, headers: IDataObject = {}, ): Promise { const options: IRequestOptions = { headers: { 'Content-Type': 'application/json', }, method, body, qs, uri: uri || `https://graph.microsoft.com/v1.0/me${resource}`, json: true, }; try { if (Object.keys(headers).length !== 0) { options.headers = Object.assign({}, options.headers, headers); } return await this.helpers.requestOAuth2.call(this, 'microsoftExcelOAuth2Api', options); } catch (error) { throw new NodeApiError(this.getNode(), error as JsonObject); } } export async function microsoftApiRequestAllItems( this: IExecuteFunctions | ILoadOptionsFunctions, propertyName: string, method: IHttpRequestMethods, endpoint: string, body: any = {}, query: IDataObject = {}, ): Promise { const returnData: IDataObject[] = []; let responseData; let uri: string | undefined; query.$top = 100; 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); return returnData; } export async function microsoftApiRequestAllItemsSkip( this: IExecuteFunctions | ILoadOptionsFunctions, propertyName: string, method: IHttpRequestMethods, endpoint: string, body: any = {}, query: IDataObject = {}, ): Promise { const returnData: IDataObject[] = []; let responseData; query.$top = 100; query.$skip = 0; 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); return returnData; }