import type { IExecuteFunctions, IHookFunctions, IDataObject, IHttpRequestMethods, IRequestOptions, IHttpRequestOptions, ILoadOptionsFunctions, } from 'n8n-workflow'; /** * Make an API request to Twilio * */ export async function twilioApiRequest( this: IHookFunctions | IExecuteFunctions, method: IHttpRequestMethods, endpoint: string, body: IDataObject, query?: IDataObject, ): Promise { const credentials = (await this.getCredentials('twilioApi')) as { accountSid: string; authType: 'authToken' | 'apiKey'; authToken: string; apiKeySid: string; apiKeySecret: string; }; if (query === undefined) { query = {}; } const options: IRequestOptions = { method, form: body, qs: query, uri: `https://api.twilio.com/2010-04-01/Accounts/${credentials.accountSid}${endpoint}`, json: true, }; return await this.helpers.requestWithAuthentication.call(this, 'twilioApi', options); } export async function twilioTriggerApiRequest( this: IHookFunctions | IExecuteFunctions | ILoadOptionsFunctions, method: IHttpRequestMethods, endpoint: string, body: FormData | IDataObject = {}, ): Promise { const options: IHttpRequestOptions = { method, body, headers: { 'Content-Type': 'application/x-www-form-urlencoded', }, url: `https://events.twilio.com/v1/${endpoint}`, json: true, }; return await this.helpers.requestWithAuthentication.call(this, 'twilioApi', options); } const XML_CHAR_MAP: { [key: string]: string } = { '<': '<', '>': '>', '&': '&', '"': '"', "'": ''', }; export function escapeXml(str: string) { return str.replace(/[<>&"']/g, (ch: string) => { return XML_CHAR_MAP[ch]; }); }