Skip to content

Commit

Permalink
fix(Splunk Node): Retry attempts if no response from API call, better…
Browse files Browse the repository at this point in the history
… error with suggestion to use Retry On Fail (#9176)

Co-authored-by: Elias Meire <[email protected]>
  • Loading branch information
michael-radency and elsmr committed Apr 24, 2024
1 parent 2bf0a39 commit 05a569c
Show file tree
Hide file tree
Showing 3 changed files with 189 additions and 21 deletions.
24 changes: 22 additions & 2 deletions packages/nodes-base/nodes/Splunk/GenericFunctions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import type {
IRequestOptions,
IHttpRequestMethods,
} from 'n8n-workflow';
import { NodeApiError } from 'n8n-workflow';
import { NodeApiError, NodeOperationError, sleep } from 'n8n-workflow';

import { parseString } from 'xml2js';

Expand Down Expand Up @@ -139,9 +139,29 @@ export async function splunkApiRequest(
delete options.qs;
}

let result;
try {
return await this.helpers.request(options).then(parseXml);
let attempts = 0;

do {
try {
const response = await this.helpers.request(options);
result = await parseXml(response);
return result;
} catch (error) {
if (attempts >= 5) {
throw error;
}
await sleep(1000);
attempts++;
}
} while (true);
} catch (error) {
if (result === undefined) {
throw new NodeOperationError(this.getNode(), 'No response from API call', {
description: "Try to use 'Retry On Fail' option from node's settings",
});
}
if (error?.cause?.code === 'ECONNREFUSED') {
throw new NodeApiError(this.getNode(), { ...(error as JsonObject), code: 401 });
}
Expand Down
51 changes: 33 additions & 18 deletions packages/nodes-base/nodes/Splunk/Splunk.node.ts
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
import type {
IExecuteFunctions,
ICredentialsDecrypted,
ICredentialTestFunctions,
IDataObject,
ILoadOptionsFunctions,
INodeCredentialTestResult,
INodeExecutionData,
INodeType,
INodeTypeDescription,
IRequestOptions,
import {
type IExecuteFunctions,
type ICredentialsDecrypted,
type ICredentialTestFunctions,
type IDataObject,
type ILoadOptionsFunctions,
type INodeCredentialTestResult,
type INodeExecutionData,
type INodeType,
type INodeTypeDescription,
type IRequestOptions,
NodeApiError,
NodeOperationError,
} from 'n8n-workflow';

import {
Expand All @@ -35,6 +37,7 @@ import {
} from './descriptions';

import type { SplunkCredentials, SplunkFeedResponse } from './types';
import set from 'lodash/set';

export class Splunk implements INodeType {
description: INodeTypeDescription = {
Expand Down Expand Up @@ -155,7 +158,7 @@ export class Splunk implements INodeType {

async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
const items = this.getInputData();
const returnData: IDataObject[] = [];
const returnData: INodeExecutionData[] = [];

const resource = this.getNodeParameter('resource', 0);
const operation = this.getNodeParameter('operation', 0);
Expand Down Expand Up @@ -454,18 +457,30 @@ export class Splunk implements INodeType {
}
} catch (error) {
if (this.continueOnFail()) {
returnData.push({ error: error.cause.error });
returnData.push({ json: { error: error.cause.error }, pairedItem: { item: i } });
continue;
}

throw error;
if (error instanceof NodeApiError) {
set(error, 'context.itemIndex', i);
}

if (error instanceof NodeOperationError && error?.context?.itemIndex === undefined) {
set(error, 'context.itemIndex', i);
}

throw new NodeOperationError(this.getNode(), error, { itemIndex: i });
}

Array.isArray(responseData)
? returnData.push(...(responseData as IDataObject[]))
: returnData.push(responseData as IDataObject);
if (Array.isArray(responseData)) {
for (const item of responseData) {
returnData.push({ json: item, pairedItem: { item: i } });
}
} else {
returnData.push({ json: responseData, pairedItem: { item: i } });
}
}

return [this.helpers.returnJsonArray(returnData)];
return [returnData];
}
}

0 comments on commit 05a569c

Please sign in to comment.