import type {
IDataObject,
IExecuteFunctions,
INodeExecutionData,
INodeProperties,
} from 'n8n-workflow';
import { NodeOperationError, jsonParse } from 'n8n-workflow';
import { theHiveApiRequest } from '../../transport';
import { updateDisplayOptions, wrapData } from '@utils/utilities';
const properties: INodeProperties[] = [
{
displayName: 'Query',
name: 'queryJson',
type: 'string',
required: true,
default: '=[\n {\n "_name": "listOrganisation"\n }\n]',
description: 'Search for objects with filtering and sorting capabilities',
hint: 'The query should be an array of operations with the required selection and optional filtering, sorting, and pagination. See Query API for more information.',
typeOptions: {
editor: 'json',
rows: 10,
},
},
];
const displayOptions = {
show: {
resource: ['query'],
operation: ['executeQuery'],
},
};
export const description = updateDisplayOptions(displayOptions, properties);
export async function execute(this: IExecuteFunctions, i: number): Promise {
let responseData: IDataObject | IDataObject[] = [];
const queryJson = this.getNodeParameter('queryJson', i) as string;
let query: IDataObject = {};
if (typeof queryJson === 'object') {
query = queryJson;
} else {
query = jsonParse(queryJson, {
errorMessage: 'Query JSON must be a valid JSON object',
});
}
if (query.query) {
query = query.query as IDataObject;
}
if (!Array.isArray(query)) {
throw new NodeOperationError(
this.getNode(),
'The query should be an array of operations with the required selection and optional filtering, sorting, and pagination',
);
}
const body: IDataObject = {
query,
};
responseData = await theHiveApiRequest.call(this, 'POST', '/v1/query', body);
if (typeof responseData !== 'object') {
responseData = { queryResult: responseData };
}
const executionData = this.helpers.constructExecutionMetaData(wrapData(responseData), {
itemData: { item: i },
});
return executionData;
}