mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-12 05:17:28 -08:00
0ecbb4a19d
* 🔨 prettier formated nodes - A * 🔨 prettier formated nodes - B * ⚡ prettier formated nodes - C * ⚡ prettier formated nodes - D * ⚡ prettier formated nodes - E-F * 🎨 Adjust nodes-base formatting command (#3805) * Format additional files in nodes A-F (#3811) * ⚡ fixes * 🎨 Add Mindee to ignored dirs Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
99 lines
2.5 KiB
TypeScript
99 lines
2.5 KiB
TypeScript
import { OptionsWithUri } from 'request';
|
|
|
|
import {
|
|
IExecuteFunctions,
|
|
IExecuteSingleFunctions,
|
|
IHookFunctions,
|
|
ILoadOptionsFunctions,
|
|
} from 'n8n-core';
|
|
|
|
import { IDataObject, NodeApiError, NodeOperationError } from 'n8n-workflow';
|
|
|
|
import moment from 'moment';
|
|
|
|
export async function cortexApiRequest(
|
|
this: IHookFunctions | IExecuteFunctions | IExecuteSingleFunctions | ILoadOptionsFunctions,
|
|
method: string,
|
|
resource: string,
|
|
// tslint:disable-next-line:no-any
|
|
body: any = {},
|
|
query: IDataObject = {},
|
|
uri?: string,
|
|
option: IDataObject = {},
|
|
// tslint:disable-next-line:no-any
|
|
): Promise<any> {
|
|
const credentials = await this.getCredentials('cortexApi');
|
|
|
|
let options: OptionsWithUri = {
|
|
headers: {},
|
|
method,
|
|
qs: query,
|
|
uri: uri || `${credentials.host}/api${resource}`,
|
|
body,
|
|
json: true,
|
|
};
|
|
if (Object.keys(option).length !== 0) {
|
|
options = Object.assign({}, options, option);
|
|
}
|
|
if (Object.keys(body).length === 0) {
|
|
delete options.body;
|
|
}
|
|
if (Object.keys(query).length === 0) {
|
|
delete options.qs;
|
|
}
|
|
|
|
try {
|
|
return await this.helpers.requestWithAuthentication.call(this, 'cortexApi', options);
|
|
} catch (error) {
|
|
throw new NodeApiError(this.getNode(), error);
|
|
}
|
|
}
|
|
|
|
export function getEntityLabel(entity: IDataObject): string {
|
|
let label = '';
|
|
switch (entity._type) {
|
|
case 'case':
|
|
label = `#${entity.caseId} ${entity.title}`;
|
|
break;
|
|
case 'case_artifact':
|
|
//@ts-ignore
|
|
label = `[${entity.dataType}] ${entity.data ? entity.data : entity.attachment.name}`;
|
|
break;
|
|
case 'alert':
|
|
label = `[${entity.source}:${entity.sourceRef}] ${entity.title}`;
|
|
break;
|
|
case 'case_task_log':
|
|
label = `${entity.message} from ${entity.createdBy}`;
|
|
break;
|
|
case 'case_task':
|
|
label = `${entity.title} (${entity.status})`;
|
|
break;
|
|
case 'job':
|
|
label = `${entity.analyzerName} (${entity.status})`;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
return label;
|
|
}
|
|
|
|
export function splitTags(tags: string): string[] {
|
|
return tags.split(',').filter((tag) => tag !== ' ' && tag);
|
|
}
|
|
|
|
export function prepareParameters(values: IDataObject): IDataObject {
|
|
const response: IDataObject = {};
|
|
for (const key in values) {
|
|
if (values[key] !== undefined && values[key] !== null && values[key] !== '') {
|
|
if (moment(values[key] as string, moment.ISO_8601).isValid()) {
|
|
response[key] = Date.parse(values[key] as string);
|
|
} else if (key === 'tags') {
|
|
response[key] = splitTags(values[key] as string);
|
|
} else {
|
|
response[key] = values[key];
|
|
}
|
|
}
|
|
}
|
|
return response;
|
|
}
|