fix: remove false positive validation for Code node syntax

- Removed overly simplistic parenthesis pattern check that flagged valid code
- Pattern /)\s*)\s*{/ was incorrectly flagging valid n8n Code node patterns like:
  - .first().json (node data access)
  - func()() (function chaining)
  - array.map().filter() (method chaining)
- These are all valid JavaScript patterns used in n8n Code nodes
- Only kept check for excessive closing braces at end of code

This eliminates false positives for workflow 85blKFvzQYvZXnLF which uses
valid  syntax in Code nodes.
This commit is contained in:
czlonkowski
2025-09-29 18:18:54 +02:00
parent e217d022d6
commit 9fa1c44149

View File

@@ -1132,8 +1132,11 @@ export class NodeSpecificValidators {
const syntaxPatterns = [
{ pattern: /const\s+const/, message: 'Duplicate const declaration' },
{ pattern: /let\s+let/, message: 'Duplicate let declaration' },
{ pattern: /\)\s*\)\s*{/, message: 'Extra closing parenthesis before {' },
{ pattern: /}\s*}$/, message: 'Extra closing brace at end' }
// Removed overly simplistic parenthesis check - it was causing false positives
// for valid patterns like $('NodeName').first().json or func()()
// { pattern: /\)\s*\)\s*{/, message: 'Extra closing parenthesis before {' },
// Only check for multiple closing braces at the very end (more likely to be an error)
{ pattern: /}\s*}\s*}\s*}$/, message: 'Multiple closing braces at end - check your nesting' }
];
syntaxPatterns.forEach(({ pattern, message }) => {