n8n-mcp 2.8.1 → 2.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/README.md +29 -1
  2. package/data/nodes.db +0 -0
  3. package/dist/http-server-single-session.d.ts +21 -1
  4. package/dist/http-server-single-session.d.ts.map +1 -1
  5. package/dist/http-server-single-session.js +530 -44
  6. package/dist/http-server-single-session.js.map +1 -1
  7. package/dist/http-server.d.ts.map +1 -1
  8. package/dist/http-server.js +5 -2
  9. package/dist/http-server.js.map +1 -1
  10. package/dist/mcp/server.d.ts +4 -0
  11. package/dist/mcp/server.d.ts.map +1 -1
  12. package/dist/mcp/server.js +391 -17
  13. package/dist/mcp/server.js.map +1 -1
  14. package/dist/mcp/tools-n8n-friendly.d.ts +6 -0
  15. package/dist/mcp/tools-n8n-friendly.d.ts.map +1 -0
  16. package/dist/mcp/tools-n8n-friendly.js +131 -0
  17. package/dist/mcp/tools-n8n-friendly.js.map +1 -0
  18. package/dist/mcp/tools.d.ts.map +1 -1
  19. package/dist/mcp/tools.js +187 -11
  20. package/dist/mcp/tools.js.map +1 -1
  21. package/dist/mcp/workflow-examples.d.ts +76 -0
  22. package/dist/mcp/workflow-examples.d.ts.map +1 -0
  23. package/dist/mcp/workflow-examples.js +111 -0
  24. package/dist/mcp/workflow-examples.js.map +1 -0
  25. package/dist/scripts/test-protocol-negotiation.d.ts +3 -0
  26. package/dist/scripts/test-protocol-negotiation.d.ts.map +1 -0
  27. package/dist/scripts/test-protocol-negotiation.js +154 -0
  28. package/dist/scripts/test-protocol-negotiation.js.map +1 -0
  29. package/dist/services/enhanced-config-validator.d.ts +4 -0
  30. package/dist/services/enhanced-config-validator.d.ts.map +1 -1
  31. package/dist/services/enhanced-config-validator.js +86 -1
  32. package/dist/services/enhanced-config-validator.js.map +1 -1
  33. package/dist/services/n8n-validation.d.ts +2 -2
  34. package/dist/types/index.d.ts +6 -0
  35. package/dist/types/index.d.ts.map +1 -1
  36. package/dist/utils/fixed-collection-validator.d.ts +35 -0
  37. package/dist/utils/fixed-collection-validator.d.ts.map +1 -0
  38. package/dist/utils/fixed-collection-validator.js +358 -0
  39. package/dist/utils/fixed-collection-validator.js.map +1 -0
  40. package/dist/utils/logger.d.ts.map +1 -1
  41. package/dist/utils/logger.js +6 -3
  42. package/dist/utils/logger.js.map +1 -1
  43. package/dist/utils/protocol-version.d.ts +19 -0
  44. package/dist/utils/protocol-version.d.ts.map +1 -0
  45. package/dist/utils/protocol-version.js +95 -0
  46. package/dist/utils/protocol-version.js.map +1 -0
  47. package/dist/utils/simple-cache.d.ts +2 -0
  48. package/dist/utils/simple-cache.d.ts.map +1 -1
  49. package/dist/utils/simple-cache.js +9 -1
  50. package/dist/utils/simple-cache.js.map +1 -1
  51. package/package.json +4 -6
@@ -0,0 +1,358 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FixedCollectionValidator = void 0;
4
+ class FixedCollectionValidator {
5
+ static isNodeConfig(value) {
6
+ return typeof value === 'object' && value !== null && !Array.isArray(value);
7
+ }
8
+ static getNestedValue(obj, path) {
9
+ const parts = path.split('.');
10
+ let current = obj;
11
+ for (const part of parts) {
12
+ if (!this.isNodeConfig(current)) {
13
+ return undefined;
14
+ }
15
+ current = current[part];
16
+ }
17
+ return current;
18
+ }
19
+ static validate(nodeType, config) {
20
+ if (typeof config !== 'object' || config === null || Array.isArray(config)) {
21
+ return { isValid: true, errors: [] };
22
+ }
23
+ const normalizedNodeType = this.normalizeNodeType(nodeType);
24
+ const pattern = this.getPatternForNode(normalizedNodeType);
25
+ if (!pattern) {
26
+ return { isValid: true, errors: [] };
27
+ }
28
+ const result = {
29
+ isValid: true,
30
+ errors: []
31
+ };
32
+ for (const invalidPattern of pattern.invalidPatterns) {
33
+ if (this.hasInvalidStructure(config, invalidPattern)) {
34
+ result.isValid = false;
35
+ result.errors.push({
36
+ pattern: invalidPattern,
37
+ message: `Invalid structure for nodes-base.${pattern.nodeType} node: found nested "${invalidPattern}" but expected "${pattern.expectedStructure}". This causes "propertyValues[itemName] is not iterable" error in n8n.`,
38
+ fix: this.generateFixMessage(pattern)
39
+ });
40
+ if (!result.autofix) {
41
+ result.autofix = this.generateAutofix(config, pattern);
42
+ }
43
+ }
44
+ }
45
+ return result;
46
+ }
47
+ static applyAutofix(config, pattern) {
48
+ const fixedConfig = this.generateAutofix(config, pattern);
49
+ if (pattern.nodeType === 'if' || pattern.nodeType === 'filter') {
50
+ const conditions = config.conditions;
51
+ if (conditions && typeof conditions === 'object' && !Array.isArray(conditions) && 'values' in conditions) {
52
+ const values = conditions.values;
53
+ if (values !== undefined && values !== null &&
54
+ (Array.isArray(values) || typeof values === 'object')) {
55
+ return values;
56
+ }
57
+ }
58
+ }
59
+ return fixedConfig;
60
+ }
61
+ static normalizeNodeType(nodeType) {
62
+ return nodeType
63
+ .replace('n8n-nodes-base.', '')
64
+ .replace('nodes-base.', '')
65
+ .replace('@n8n/n8n-nodes-langchain.', '')
66
+ .toLowerCase();
67
+ }
68
+ static getPatternForNode(nodeType) {
69
+ return this.KNOWN_PATTERNS.find(p => p.nodeType === nodeType);
70
+ }
71
+ static hasInvalidStructure(config, pattern) {
72
+ const parts = pattern.split('.');
73
+ let current = config;
74
+ const visited = new WeakSet();
75
+ for (const part of parts) {
76
+ if (current === null || current === undefined) {
77
+ return false;
78
+ }
79
+ if (typeof current !== 'object' || Array.isArray(current)) {
80
+ return false;
81
+ }
82
+ if (visited.has(current)) {
83
+ return false;
84
+ }
85
+ visited.add(current);
86
+ if (!Object.prototype.hasOwnProperty.call(current, part)) {
87
+ return false;
88
+ }
89
+ const nextValue = current[part];
90
+ if (typeof nextValue !== 'object' || nextValue === null) {
91
+ if (parts.indexOf(part) < parts.length - 1) {
92
+ return false;
93
+ }
94
+ }
95
+ current = nextValue;
96
+ }
97
+ return true;
98
+ }
99
+ static generateFixMessage(pattern) {
100
+ switch (pattern.nodeType) {
101
+ case 'switch':
102
+ return 'Use: { "rules": { "values": [{ "conditions": {...}, "outputKey": "output1" }] } }';
103
+ case 'if':
104
+ case 'filter':
105
+ return 'Use: { "conditions": {...} } or { "conditions": [...] } directly, not nested under "values"';
106
+ case 'summarize':
107
+ return 'Use: { "fieldsToSummarize": { "values": [...] } } not nested values.values';
108
+ case 'comparedatasets':
109
+ return 'Use: { "mergeByFields": { "values": [...] } } not nested values.values';
110
+ case 'sort':
111
+ return 'Use: { "sortFieldsUi": { "sortField": [...] } } not sortField.values';
112
+ case 'aggregate':
113
+ return 'Use: { "fieldsToAggregate": { "fieldToAggregate": [...] } } not fieldToAggregate.values';
114
+ case 'set':
115
+ return 'Use: { "fields": { "values": [...] } } not nested values.values';
116
+ case 'html':
117
+ return 'Use: { "extractionValues": { "values": [...] } } not nested values.values';
118
+ case 'httprequest':
119
+ return 'Use: { "body": { "parameters": [...] } } not parameters.values';
120
+ case 'airtable':
121
+ return 'Use: { "sort": { "sortField": [...] } } not sortField.values';
122
+ default:
123
+ return `Use ${pattern.expectedStructure} structure`;
124
+ }
125
+ }
126
+ static generateAutofix(config, pattern) {
127
+ const fixedConfig = { ...config };
128
+ switch (pattern.nodeType) {
129
+ case 'switch': {
130
+ const rules = config.rules;
131
+ if (this.isNodeConfig(rules)) {
132
+ const conditions = rules.conditions;
133
+ if (this.isNodeConfig(conditions) && 'values' in conditions) {
134
+ const values = conditions.values;
135
+ fixedConfig.rules = {
136
+ values: Array.isArray(values)
137
+ ? values.map((condition, index) => ({
138
+ conditions: condition,
139
+ outputKey: `output${index + 1}`
140
+ }))
141
+ : [{
142
+ conditions: values,
143
+ outputKey: 'output1'
144
+ }]
145
+ };
146
+ }
147
+ else if (conditions) {
148
+ fixedConfig.rules = {
149
+ values: [{
150
+ conditions: conditions,
151
+ outputKey: 'output1'
152
+ }]
153
+ };
154
+ }
155
+ }
156
+ break;
157
+ }
158
+ case 'if':
159
+ case 'filter': {
160
+ const conditions = config.conditions;
161
+ if (this.isNodeConfig(conditions) && 'values' in conditions) {
162
+ const values = conditions.values;
163
+ if (values !== undefined && values !== null &&
164
+ (Array.isArray(values) || typeof values === 'object')) {
165
+ return values;
166
+ }
167
+ }
168
+ break;
169
+ }
170
+ case 'summarize': {
171
+ const fieldsToSummarize = config.fieldsToSummarize;
172
+ if (this.isNodeConfig(fieldsToSummarize)) {
173
+ const values = fieldsToSummarize.values;
174
+ if (this.isNodeConfig(values) && 'values' in values) {
175
+ fixedConfig.fieldsToSummarize = {
176
+ values: values.values
177
+ };
178
+ }
179
+ }
180
+ break;
181
+ }
182
+ case 'comparedatasets': {
183
+ const mergeByFields = config.mergeByFields;
184
+ if (this.isNodeConfig(mergeByFields)) {
185
+ const values = mergeByFields.values;
186
+ if (this.isNodeConfig(values) && 'values' in values) {
187
+ fixedConfig.mergeByFields = {
188
+ values: values.values
189
+ };
190
+ }
191
+ }
192
+ break;
193
+ }
194
+ case 'sort': {
195
+ const sortFieldsUi = config.sortFieldsUi;
196
+ if (this.isNodeConfig(sortFieldsUi)) {
197
+ const sortField = sortFieldsUi.sortField;
198
+ if (this.isNodeConfig(sortField) && 'values' in sortField) {
199
+ fixedConfig.sortFieldsUi = {
200
+ sortField: sortField.values
201
+ };
202
+ }
203
+ }
204
+ break;
205
+ }
206
+ case 'aggregate': {
207
+ const fieldsToAggregate = config.fieldsToAggregate;
208
+ if (this.isNodeConfig(fieldsToAggregate)) {
209
+ const fieldToAggregate = fieldsToAggregate.fieldToAggregate;
210
+ if (this.isNodeConfig(fieldToAggregate) && 'values' in fieldToAggregate) {
211
+ fixedConfig.fieldsToAggregate = {
212
+ fieldToAggregate: fieldToAggregate.values
213
+ };
214
+ }
215
+ }
216
+ break;
217
+ }
218
+ case 'set': {
219
+ const fields = config.fields;
220
+ if (this.isNodeConfig(fields)) {
221
+ const values = fields.values;
222
+ if (this.isNodeConfig(values) && 'values' in values) {
223
+ fixedConfig.fields = {
224
+ values: values.values
225
+ };
226
+ }
227
+ }
228
+ break;
229
+ }
230
+ case 'html': {
231
+ const extractionValues = config.extractionValues;
232
+ if (this.isNodeConfig(extractionValues)) {
233
+ const values = extractionValues.values;
234
+ if (this.isNodeConfig(values) && 'values' in values) {
235
+ fixedConfig.extractionValues = {
236
+ values: values.values
237
+ };
238
+ }
239
+ }
240
+ break;
241
+ }
242
+ case 'httprequest': {
243
+ const body = config.body;
244
+ if (this.isNodeConfig(body)) {
245
+ const parameters = body.parameters;
246
+ if (this.isNodeConfig(parameters) && 'values' in parameters) {
247
+ fixedConfig.body = {
248
+ ...body,
249
+ parameters: parameters.values
250
+ };
251
+ }
252
+ }
253
+ break;
254
+ }
255
+ case 'airtable': {
256
+ const sort = config.sort;
257
+ if (this.isNodeConfig(sort)) {
258
+ const sortField = sort.sortField;
259
+ if (this.isNodeConfig(sortField) && 'values' in sortField) {
260
+ fixedConfig.sort = {
261
+ sortField: sortField.values
262
+ };
263
+ }
264
+ }
265
+ break;
266
+ }
267
+ }
268
+ return fixedConfig;
269
+ }
270
+ static getAllPatterns() {
271
+ return this.KNOWN_PATTERNS.map(pattern => ({
272
+ ...pattern,
273
+ invalidPatterns: [...pattern.invalidPatterns]
274
+ }));
275
+ }
276
+ static isNodeSusceptible(nodeType) {
277
+ const normalizedType = this.normalizeNodeType(nodeType);
278
+ return this.KNOWN_PATTERNS.some(p => p.nodeType === normalizedType);
279
+ }
280
+ }
281
+ exports.FixedCollectionValidator = FixedCollectionValidator;
282
+ FixedCollectionValidator.KNOWN_PATTERNS = [
283
+ {
284
+ nodeType: 'switch',
285
+ property: 'rules',
286
+ expectedStructure: 'rules.values array',
287
+ invalidPatterns: ['rules.conditions', 'rules.conditions.values']
288
+ },
289
+ {
290
+ nodeType: 'if',
291
+ property: 'conditions',
292
+ expectedStructure: 'conditions array/object',
293
+ invalidPatterns: ['conditions.values']
294
+ },
295
+ {
296
+ nodeType: 'filter',
297
+ property: 'conditions',
298
+ expectedStructure: 'conditions array/object',
299
+ invalidPatterns: ['conditions.values']
300
+ },
301
+ {
302
+ nodeType: 'summarize',
303
+ property: 'fieldsToSummarize',
304
+ subProperty: 'values',
305
+ expectedStructure: 'fieldsToSummarize.values array',
306
+ invalidPatterns: ['fieldsToSummarize.values.values']
307
+ },
308
+ {
309
+ nodeType: 'comparedatasets',
310
+ property: 'mergeByFields',
311
+ subProperty: 'values',
312
+ expectedStructure: 'mergeByFields.values array',
313
+ invalidPatterns: ['mergeByFields.values.values']
314
+ },
315
+ {
316
+ nodeType: 'sort',
317
+ property: 'sortFieldsUi',
318
+ subProperty: 'sortField',
319
+ expectedStructure: 'sortFieldsUi.sortField array',
320
+ invalidPatterns: ['sortFieldsUi.sortField.values']
321
+ },
322
+ {
323
+ nodeType: 'aggregate',
324
+ property: 'fieldsToAggregate',
325
+ subProperty: 'fieldToAggregate',
326
+ expectedStructure: 'fieldsToAggregate.fieldToAggregate array',
327
+ invalidPatterns: ['fieldsToAggregate.fieldToAggregate.values']
328
+ },
329
+ {
330
+ nodeType: 'set',
331
+ property: 'fields',
332
+ subProperty: 'values',
333
+ expectedStructure: 'fields.values array',
334
+ invalidPatterns: ['fields.values.values']
335
+ },
336
+ {
337
+ nodeType: 'html',
338
+ property: 'extractionValues',
339
+ subProperty: 'values',
340
+ expectedStructure: 'extractionValues.values array',
341
+ invalidPatterns: ['extractionValues.values.values']
342
+ },
343
+ {
344
+ nodeType: 'httprequest',
345
+ property: 'body',
346
+ subProperty: 'parameters',
347
+ expectedStructure: 'body.parameters array',
348
+ invalidPatterns: ['body.parameters.values']
349
+ },
350
+ {
351
+ nodeType: 'airtable',
352
+ property: 'sort',
353
+ subProperty: 'sortField',
354
+ expectedStructure: 'sort.sortField array',
355
+ invalidPatterns: ['sort.sortField.values']
356
+ }
357
+ ];
358
+ //# sourceMappingURL=fixed-collection-validator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fixed-collection-validator.js","sourceRoot":"","sources":["../../src/utils/fixed-collection-validator.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAAA,oBAAY,QAAQ;IAClB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,KAAK,IAAI;CACV;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,QAAQ,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAS;IAChC,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,UAAU,CAAa;IAE/B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAoC;IAC5D,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAiD;IAC5E,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmC;IAC1D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA8E;gBAEzF,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC;IAS1C,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,MAAM;IAO1D,OAAO,CAAC,aAAa;IAiBrB,OAAO,CAAC,GAAG;IAgCX,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI3C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI3C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI5C,QAAQ,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAI/B,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,QAAQ;CAa9C;AAGD,eAAO,MAAM,MAAM,QAEjB,CAAC"}
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAAA,oBAAY,QAAQ;IAClB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,KAAK,IAAI;CACV;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,QAAQ,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAS;IAChC,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,UAAU,CAAa;IAE/B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAoC;IAC5D,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAiD;IAC5E,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmC;IAC1D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA8E;gBAEzF,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC;IAS1C,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,MAAM;IAO1D,OAAO,CAAC,aAAa;IAiBrB,OAAO,CAAC,GAAG;IAqCX,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI3C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI3C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI;IAI5C,QAAQ,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAI/B,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,QAAQ;CAa9C;AAGD,eAAO,MAAM,MAAM,QAEjB,CAAC"}
@@ -42,12 +42,15 @@ class Logger {
42
42
  return parts.join(' ');
43
43
  }
44
44
  log(level, levelName, message, ...args) {
45
+ const allowErrorLogs = level === LogLevel.ERROR && (this.isHttp || process.env.DEBUG === 'true');
45
46
  if (this.isStdio || this.isDisabled || (this.isTest && process.env.DEBUG !== 'true')) {
46
- return;
47
+ if (!allowErrorLogs) {
48
+ return;
49
+ }
47
50
  }
48
- if (level <= this.config.level) {
51
+ if (level <= this.config.level || allowErrorLogs) {
49
52
  const formattedMessage = this.formatMessage(levelName, message);
50
- if (this.isHttp && process.env.MCP_REQUEST_ACTIVE === 'true') {
53
+ if (this.isHttp && process.env.MCP_REQUEST_ACTIVE === 'true' && !allowErrorLogs) {
51
54
  return;
52
55
  }
53
56
  switch (level) {
@@ -1 +1 @@
1
- {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ export interface ClientInfo {
2
+ name?: string;
3
+ version?: string;
4
+ [key: string]: any;
5
+ }
6
+ export interface ProtocolNegotiationResult {
7
+ version: string;
8
+ isN8nClient: boolean;
9
+ reasoning: string;
10
+ }
11
+ export declare const STANDARD_PROTOCOL_VERSION = "2025-03-26";
12
+ export declare const N8N_PROTOCOL_VERSION = "2024-11-05";
13
+ export declare const SUPPORTED_VERSIONS: string[];
14
+ export declare function isN8nClient(clientInfo?: ClientInfo, userAgent?: string, headers?: Record<string, string | string[] | undefined>): boolean;
15
+ export declare function negotiateProtocolVersion(clientRequestedVersion?: string, clientInfo?: ClientInfo, userAgent?: string, headers?: Record<string, string | string[] | undefined>): ProtocolNegotiationResult;
16
+ export declare function isVersionSupported(version: string): boolean;
17
+ export declare function getCompatibleVersion(targetVersion?: string): string;
18
+ export declare function logProtocolNegotiation(result: ProtocolNegotiationResult, logger: any, context?: string): void;
19
+ //# sourceMappingURL=protocol-version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"protocol-version.d.ts","sourceRoot":"","sources":["../../src/utils/protocol-version.ts"],"names":[],"mappings":"AAOA,MAAM,WAAW,UAAU;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACpB;AAED,MAAM,WAAW,yBAAyB;IACxC,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,OAAO,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;CACnB;AAKD,eAAO,MAAM,yBAAyB,eAAe,CAAC;AAKtD,eAAO,MAAM,oBAAoB,eAAe,CAAC;AAKjD,eAAO,MAAM,kBAAkB,UAI9B,CAAC;AAKF,wBAAgB,WAAW,CACzB,UAAU,CAAC,EAAE,UAAU,EACvB,SAAS,CAAC,EAAE,MAAM,EAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,GACtD,OAAO,CAqCT;AAKD,wBAAgB,wBAAwB,CACtC,sBAAsB,CAAC,EAAE,MAAM,EAC/B,UAAU,CAAC,EAAE,UAAU,EACvB,SAAS,CAAC,EAAE,MAAM,EAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,GACtD,yBAAyB,CAqC3B;AAKD,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAE3D;AAMD,wBAAgB,oBAAoB,CAAC,aAAa,CAAC,EAAE,MAAM,GAAG,MAAM,CAWnE;AAKD,wBAAgB,sBAAsB,CACpC,MAAM,EAAE,yBAAyB,EACjC,MAAM,EAAE,GAAG,EACX,OAAO,CAAC,EAAE,MAAM,GACf,IAAI,CAYN"}
@@ -0,0 +1,95 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SUPPORTED_VERSIONS = exports.N8N_PROTOCOL_VERSION = exports.STANDARD_PROTOCOL_VERSION = void 0;
4
+ exports.isN8nClient = isN8nClient;
5
+ exports.negotiateProtocolVersion = negotiateProtocolVersion;
6
+ exports.isVersionSupported = isVersionSupported;
7
+ exports.getCompatibleVersion = getCompatibleVersion;
8
+ exports.logProtocolNegotiation = logProtocolNegotiation;
9
+ exports.STANDARD_PROTOCOL_VERSION = '2025-03-26';
10
+ exports.N8N_PROTOCOL_VERSION = '2024-11-05';
11
+ exports.SUPPORTED_VERSIONS = [
12
+ exports.STANDARD_PROTOCOL_VERSION,
13
+ exports.N8N_PROTOCOL_VERSION,
14
+ '2024-06-25',
15
+ ];
16
+ function isN8nClient(clientInfo, userAgent, headers) {
17
+ if (clientInfo?.name) {
18
+ const clientName = clientInfo.name.toLowerCase();
19
+ if (clientName.includes('n8n') || clientName.includes('langchain')) {
20
+ return true;
21
+ }
22
+ }
23
+ if (userAgent) {
24
+ const ua = userAgent.toLowerCase();
25
+ if (ua.includes('n8n') || ua.includes('langchain')) {
26
+ return true;
27
+ }
28
+ }
29
+ if (headers) {
30
+ const headerValues = Object.values(headers).join(' ').toLowerCase();
31
+ if (headerValues.includes('n8n') || headerValues.includes('langchain')) {
32
+ return true;
33
+ }
34
+ if (headers['x-n8n-version'] || headers['x-langchain-version']) {
35
+ return true;
36
+ }
37
+ }
38
+ if (process.env.N8N_MODE === 'true') {
39
+ return true;
40
+ }
41
+ return false;
42
+ }
43
+ function negotiateProtocolVersion(clientRequestedVersion, clientInfo, userAgent, headers) {
44
+ const isN8n = isN8nClient(clientInfo, userAgent, headers);
45
+ if (isN8n) {
46
+ return {
47
+ version: exports.N8N_PROTOCOL_VERSION,
48
+ isN8nClient: true,
49
+ reasoning: 'n8n client detected, using n8n-compatible protocol version'
50
+ };
51
+ }
52
+ if (clientRequestedVersion && exports.SUPPORTED_VERSIONS.includes(clientRequestedVersion)) {
53
+ return {
54
+ version: clientRequestedVersion,
55
+ isN8nClient: false,
56
+ reasoning: `Using client-requested version: ${clientRequestedVersion}`
57
+ };
58
+ }
59
+ if (clientRequestedVersion) {
60
+ return {
61
+ version: exports.STANDARD_PROTOCOL_VERSION,
62
+ isN8nClient: false,
63
+ reasoning: `Client requested unsupported version ${clientRequestedVersion}, using standard version`
64
+ };
65
+ }
66
+ return {
67
+ version: exports.STANDARD_PROTOCOL_VERSION,
68
+ isN8nClient: false,
69
+ reasoning: 'No specific client detected, using standard protocol version'
70
+ };
71
+ }
72
+ function isVersionSupported(version) {
73
+ return exports.SUPPORTED_VERSIONS.includes(version);
74
+ }
75
+ function getCompatibleVersion(targetVersion) {
76
+ if (!targetVersion) {
77
+ return exports.STANDARD_PROTOCOL_VERSION;
78
+ }
79
+ if (exports.SUPPORTED_VERSIONS.includes(targetVersion)) {
80
+ return targetVersion;
81
+ }
82
+ return exports.STANDARD_PROTOCOL_VERSION;
83
+ }
84
+ function logProtocolNegotiation(result, logger, context) {
85
+ const logContext = context ? `[${context}] ` : '';
86
+ logger.info(`${logContext}Protocol version negotiated`, {
87
+ version: result.version,
88
+ isN8nClient: result.isN8nClient,
89
+ reasoning: result.reasoning
90
+ });
91
+ if (result.isN8nClient) {
92
+ logger.info(`${logContext}Using n8n-compatible protocol version for better integration`);
93
+ }
94
+ }
95
+ //# sourceMappingURL=protocol-version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"protocol-version.js","sourceRoot":"","sources":["../../src/utils/protocol-version.ts"],"names":[],"mappings":"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"}
@@ -1,8 +1,10 @@
1
1
  export declare class SimpleCache {
2
2
  private cache;
3
+ private cleanupTimer;
3
4
  constructor();
4
5
  get(key: string): any;
5
6
  set(key: string, data: any, ttlSeconds?: number): void;
6
7
  clear(): void;
8
+ destroy(): void;
7
9
  }
8
10
  //# sourceMappingURL=simple-cache.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"simple-cache.d.ts","sourceRoot":"","sources":["../../src/utils/simple-cache.ts"],"names":[],"mappings":"AAIA,qBAAa,WAAW;IACtB,OAAO,CAAC,KAAK,CAAqD;;IAYlE,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG;IASrB,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,UAAU,GAAE,MAAY,GAAG,IAAI;IAO3D,KAAK,IAAI,IAAI;CAGd"}
1
+ {"version":3,"file":"simple-cache.d.ts","sourceRoot":"","sources":["../../src/utils/simple-cache.ts"],"names":[],"mappings":"AAIA,qBAAa,WAAW;IACtB,OAAO,CAAC,KAAK,CAAqD;IAClE,OAAO,CAAC,YAAY,CAA+B;;IAYnD,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG;IASrB,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,UAAU,GAAE,MAAY,GAAG,IAAI;IAO3D,KAAK,IAAI,IAAI;IAQb,OAAO,IAAI,IAAI;CAOhB"}
@@ -4,7 +4,8 @@ exports.SimpleCache = void 0;
4
4
  class SimpleCache {
5
5
  constructor() {
6
6
  this.cache = new Map();
7
- setInterval(() => {
7
+ this.cleanupTimer = null;
8
+ this.cleanupTimer = setInterval(() => {
8
9
  const now = Date.now();
9
10
  for (const [key, item] of this.cache.entries()) {
10
11
  if (item.expires < now)
@@ -29,6 +30,13 @@ class SimpleCache {
29
30
  clear() {
30
31
  this.cache.clear();
31
32
  }
33
+ destroy() {
34
+ if (this.cleanupTimer) {
35
+ clearInterval(this.cleanupTimer);
36
+ this.cleanupTimer = null;
37
+ }
38
+ this.cache.clear();
39
+ }
32
40
  }
33
41
  exports.SimpleCache = SimpleCache;
34
42
  //# sourceMappingURL=simple-cache.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"simple-cache.js","sourceRoot":"","sources":["../../src/utils/simple-cache.ts"],"names":[],"mappings":";;;AAIA,MAAa,WAAW;IAGtB;QAFQ,UAAK,GAAG,IAAI,GAAG,EAA0C,CAAC;QAIhE,WAAW,CAAC,GAAG,EAAE;YACf,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,KAAK,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;gBAC/C,IAAI,IAAI,CAAC,OAAO,GAAG,GAAG;oBAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjD,CAAC;QACH,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;YACvC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,IAAS,EAAE,aAAqB,GAAG;QAClD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,IAAI;YACJ,OAAO,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,UAAU,GAAG,IAAI,CAAC;SAC1C,CAAC,CAAC;IACL,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF;AAhCD,kCAgCC"}
1
+ {"version":3,"file":"simple-cache.js","sourceRoot":"","sources":["../../src/utils/simple-cache.ts"],"names":[],"mappings":";;;AAIA,MAAa,WAAW;IAItB;QAHQ,UAAK,GAAG,IAAI,GAAG,EAA0C,CAAC;QAC1D,iBAAY,GAA0B,IAAI,CAAC;QAIjD,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE;YACnC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACvB,KAAK,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;gBAC/C,IAAI,IAAI,CAAC,OAAO,GAAG,GAAG;oBAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjD,CAAC;QACH,CAAC,EAAE,KAAK,CAAC,CAAC;IACZ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;YACvC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACvB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,IAAS,EAAE,aAAqB,GAAG;QAClD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,IAAI;YACJ,OAAO,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,UAAU,GAAG,IAAI,CAAC;SAC1C,CAAC,CAAC;IACL,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAMD,OAAO;QACL,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF;AA7CD,kCA6CC"}
package/package.json CHANGED
@@ -1,16 +1,14 @@
1
1
  {
2
2
  "name": "n8n-mcp",
3
- "version": "2.8.1",
3
+ "version": "2.10.1",
4
4
  "description": "Integration between n8n workflow automation and Model Context Protocol (MCP)",
5
5
  "dependencies": {
6
6
  "@modelcontextprotocol/sdk": "^1.13.2",
7
- "better-sqlite3": "^11.10.0",
8
- "sql.js": "^1.13.0",
9
7
  "express": "^5.1.0",
10
8
  "dotenv": "^16.5.0",
11
- "axios": "^1.7.2",
12
- "zod": "^3.23.8",
13
- "uuid": "^10.0.0"
9
+ "sql.js": "^1.13.0",
10
+ "uuid": "^10.0.0",
11
+ "axios": "^1.7.7"
14
12
  },
15
13
  "engines": {
16
14
  "node": ">=16.0.0"