Skip to content

Commit

Permalink
⚡ Always stringify data of Function-Nodes (#2606)
Browse files Browse the repository at this point in the history
* ⚡ Always stringify data of Function-Nodes

* ⚡ Fix lint issue and fix data
  • Loading branch information
janober authored Jan 2, 2022
1 parent 815e405 commit 6d0a4d2
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 4 deletions.
22 changes: 19 additions & 3 deletions packages/nodes-base/nodes/Function/Function.node.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { IExecuteFunctions } from 'n8n-core';
import {
IDataObject,
INodeExecutionData,
INodeType,
INodeTypeDescription,
Expand Down Expand Up @@ -58,6 +59,21 @@ return items;`,
// Copy the items as they may get changed in the functions
items = JSON.parse(JSON.stringify(items));

const cleanupData = (inputData: IDataObject): IDataObject => {
Object.keys(inputData).map(key => {
if (inputData[key] !== null && typeof inputData[key] === 'object') {
if (inputData[key]!.constructor.name === 'Object') {
// Is regular node.js object so check its data
inputData[key] = cleanupData(inputData[key] as IDataObject);
} else {
// Is some special object like a Date so stringify
inputData[key] = JSON.parse(JSON.stringify(inputData[key]));
}
}
});
return inputData;
};

// Define the global objects for the custom function
const sandbox = {
getNodeParameter: this.getNodeParameter,
Expand Down Expand Up @@ -117,6 +133,9 @@ return items;`,
if (typeof item.json !== 'object') {
throw new NodeOperationError(this.getNode(), 'The json-property has to be an object!');
}

item.json = cleanupData(item.json);

if (item.binary !== undefined) {
if (Array.isArray(item.binary) || typeof item.binary !== 'object') {
throw new NodeOperationError(this.getNode(), 'The binary-property has to be an object!');
Expand All @@ -143,9 +162,6 @@ return items;`,
}
}




return this.prepareOutputData(items);
}
}
17 changes: 16 additions & 1 deletion packages/nodes-base/nodes/FunctionItem/FunctionItem.node.ts
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,21 @@ return item;`,
const length = items.length as unknown as number;
let item: INodeExecutionData;

const cleanupData = (inputData: IDataObject): IDataObject => {
Object.keys(inputData).map(key => {
if (inputData[key] !== null && typeof inputData[key] === 'object') {
if (inputData[key]!.constructor.name === 'Object') {
// Is regular node.js object so check its data
inputData[key] = cleanupData(inputData[key] as IDataObject);
} else {
// Is some special object like a Date so stringify
inputData[key] = JSON.parse(JSON.stringify(inputData[key]));
}
}
});
return inputData;
};

for (let itemIndex = 0; itemIndex < length; itemIndex++) {
try {
item = items[itemIndex];
Expand Down Expand Up @@ -145,7 +160,7 @@ return item;`,
}

const returnItem: INodeExecutionData = {
json: jsonData,
json: cleanupData(jsonData),
};

if (item.binary) {
Expand Down

0 comments on commit 6d0a4d2

Please sign in to comment.