mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-20 19:32:15 +00:00
fix(core): Handle Date and RegExp correctly in jsonStringify (#5812)
This commit is contained in:
committed by
GitHub
parent
522c790817
commit
4f91525022
@@ -67,7 +67,8 @@ type JSONStringifyOptions = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const replaceCircularReferences = <T>(value: T, knownObjects = new WeakSet()): T => {
|
const replaceCircularReferences = <T>(value: T, knownObjects = new WeakSet()): T => {
|
||||||
if (value && typeof value === 'object') {
|
if (typeof value !== 'object' || value === null || value instanceof RegExp) return value;
|
||||||
|
if ('toJSON' in value && typeof value.toJSON === 'function') return value.toJSON() as T;
|
||||||
if (knownObjects.has(value)) return '[Circular Reference]' as T;
|
if (knownObjects.has(value)) return '[Circular Reference]' as T;
|
||||||
knownObjects.add(value);
|
knownObjects.add(value);
|
||||||
const copy = (Array.isArray(value) ? [] : {}) as T;
|
const copy = (Array.isArray(value) ? [] : {}) as T;
|
||||||
@@ -76,8 +77,6 @@ const replaceCircularReferences = <T>(value: T, knownObjects = new WeakSet()): T
|
|||||||
}
|
}
|
||||||
knownObjects.delete(value);
|
knownObjects.delete(value);
|
||||||
return copy;
|
return copy;
|
||||||
}
|
|
||||||
return value;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
export const jsonStringify = (obj: unknown, options: JSONStringifyOptions = {}): string => {
|
export const jsonStringify = (obj: unknown, options: JSONStringifyOptions = {}): string => {
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ describe('jsonParse', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('jsonStringify', () => {
|
describe('jsonStringify', () => {
|
||||||
const source: any = { a: 1, b: 2 };
|
const source: any = { a: 1, b: 2, d: new Date(1680089084200), r: new RegExp('^test$', 'ig') };
|
||||||
source.c = source;
|
source.c = source;
|
||||||
|
|
||||||
it('should throw errors on circular references by default', () => {
|
it('should throw errors on circular references by default', () => {
|
||||||
@@ -27,7 +27,7 @@ describe('jsonStringify', () => {
|
|||||||
|
|
||||||
it('should break circular references when requested', () => {
|
it('should break circular references when requested', () => {
|
||||||
expect(jsonStringify(source, { replaceCircularRefs: true })).toEqual(
|
expect(jsonStringify(source, { replaceCircularRefs: true })).toEqual(
|
||||||
'{"a":1,"b":2,"c":"[Circular Reference]"}',
|
'{"a":1,"b":2,"d":"2023-03-29T11:24:44.200Z","r":{},"c":"[Circular Reference]"}',
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user