mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 18:12:04 +00:00
refactor: Switch plain errors in nodes-base to ApplicationError (no-changelog) (#7914)
Ensure all errors in `nodes-base` are `ApplicationError` or children of it and contain no variables in the message, to continue normalizing all the backend errors we report to Sentry. Also, skip reporting to Sentry errors from user input and from external APIs. In future we should refine `ApplicationError` to more specific errors. Follow-up to: [#7877](https://github.com/n8n-io/n8n/pull/7877) - [x] Test workflows: https://github.com/n8n-io/n8n/actions/runs/7084627970 - [x] e2e: https://github.com/n8n-io/n8n/actions/runs/7084936861 --------- Co-authored-by: Michael Kret <michael.k@radency.com>
This commit is contained in:
@@ -6,7 +6,7 @@ import type {
|
||||
IPairedItemData,
|
||||
} from 'n8n-workflow';
|
||||
|
||||
import { jsonParse } from 'n8n-workflow';
|
||||
import { ApplicationError, jsonParse } from 'n8n-workflow';
|
||||
|
||||
import { isEqual, isNull, merge } from 'lodash';
|
||||
|
||||
@@ -90,12 +90,12 @@ export function processJsonInput<T>(jsonData: T, inputName?: string) {
|
||||
try {
|
||||
values = jsonParse(jsonData);
|
||||
} catch (error) {
|
||||
throw new Error(`Input ${input}must contain a valid JSON`);
|
||||
throw new ApplicationError(`Input ${input} must contain a valid JSON`, { level: 'warning' });
|
||||
}
|
||||
} else if (typeof jsonData === 'object') {
|
||||
values = jsonData;
|
||||
} else {
|
||||
throw new Error(`Input ${input}must contain a valid JSON`);
|
||||
throw new ApplicationError(`Input ${input} must contain a valid JSON`, { level: 'warning' });
|
||||
}
|
||||
|
||||
return values;
|
||||
|
||||
Reference in New Issue
Block a user