mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-30 06:59:41 -08:00
b03e358a12
* 👕 Enable `consistent-type-imports` for nodes-base
* 👕 Apply to nodes-base
* ⏪ Undo unrelated changes
* 🚚 Move to `.eslintrc.js` in nodes-base
* ⏪ Revert "Enable `consistent-type-imports` for nodes-base"
This reverts commit 529ad72b05
.
* 👕 Fix severity
85 lines
2.1 KiB
TypeScript
85 lines
2.1 KiB
TypeScript
import type { OptionsWithUri } from 'request';
|
|
|
|
import type { IExecuteFunctions } from 'n8n-core';
|
|
|
|
import type { IDataObject } from 'n8n-workflow';
|
|
import { NodeApiError, NodeOperationError } from 'n8n-workflow';
|
|
|
|
export async function marketstackApiRequest(
|
|
this: IExecuteFunctions,
|
|
method: string,
|
|
endpoint: string,
|
|
body: IDataObject = {},
|
|
qs: IDataObject = {},
|
|
) {
|
|
const credentials = await this.getCredentials('marketstackApi');
|
|
const protocol = credentials.useHttps ? 'https' : 'http'; // Free API does not support HTTPS
|
|
|
|
const options: OptionsWithUri = {
|
|
method,
|
|
uri: `${protocol}://api.marketstack.com/v1${endpoint}`,
|
|
qs: {
|
|
access_key: credentials.apiKey,
|
|
...qs,
|
|
},
|
|
json: true,
|
|
};
|
|
|
|
if (!Object.keys(body).length) {
|
|
delete options.body;
|
|
}
|
|
|
|
try {
|
|
return await this.helpers.request(options);
|
|
} catch (error) {
|
|
throw new NodeApiError(this.getNode(), error);
|
|
}
|
|
}
|
|
|
|
export async function marketstackApiRequestAllItems(
|
|
this: IExecuteFunctions,
|
|
method: string,
|
|
endpoint: string,
|
|
body: IDataObject = {},
|
|
qs: IDataObject = {},
|
|
) {
|
|
const returnAll = this.getNodeParameter('returnAll', 0, false);
|
|
const limit = this.getNodeParameter('limit', 0, 0);
|
|
|
|
let responseData;
|
|
const returnData: IDataObject[] = [];
|
|
|
|
qs.offset = 0;
|
|
|
|
do {
|
|
responseData = await marketstackApiRequest.call(this, method, endpoint, body, qs);
|
|
returnData.push(...responseData.data);
|
|
|
|
if (!returnAll && returnData.length > limit) {
|
|
return returnData.slice(0, limit);
|
|
}
|
|
|
|
qs.offset += responseData.count;
|
|
} while (responseData.total > returnData.length);
|
|
|
|
return returnData;
|
|
}
|
|
|
|
export const format = (datetime?: string) => datetime?.split('T')[0];
|
|
|
|
export function validateTimeOptions(this: IExecuteFunctions, timeOptions: boolean[]) {
|
|
if (timeOptions.every((o) => !o)) {
|
|
throw new NodeOperationError(
|
|
this.getNode(),
|
|
'Please filter by latest, specific date or timeframe (start and end dates).',
|
|
);
|
|
}
|
|
|
|
if (timeOptions.filter(Boolean).length > 1) {
|
|
throw new NodeOperationError(
|
|
this.getNode(),
|
|
'Please filter by one of latest, specific date, or timeframe (start and end dates).',
|
|
);
|
|
}
|
|
}
|