n8n-core 1.72.1 → 1.74.0

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 (113) hide show
  1. package/LICENSE.md +5 -3
  2. package/dist/ActiveWorkflows.d.ts +9 -3
  3. package/dist/ActiveWorkflows.js +25 -14
  4. package/dist/ActiveWorkflows.js.map +1 -1
  5. package/dist/BinaryData/BinaryData.service.js +3 -3
  6. package/dist/BinaryData/BinaryData.service.js.map +1 -1
  7. package/dist/BinaryData/ObjectStore.manager.js +2 -2
  8. package/dist/BinaryData/ObjectStore.manager.js.map +1 -1
  9. package/dist/Cipher.js +2 -2
  10. package/dist/Cipher.js.map +1 -1
  11. package/dist/Constants.d.ts +5 -0
  12. package/dist/Constants.js +29 -1
  13. package/dist/Constants.js.map +1 -1
  14. package/dist/CreateNodeAsTool.d.ts +2 -2
  15. package/dist/CreateNodeAsTool.js +30 -44
  16. package/dist/CreateNodeAsTool.js.map +1 -1
  17. package/dist/Credentials.js +2 -2
  18. package/dist/Credentials.js.map +1 -1
  19. package/dist/DirectoryLoader.d.ts +3 -0
  20. package/dist/DirectoryLoader.js +26 -6
  21. package/dist/DirectoryLoader.js.map +1 -1
  22. package/dist/InstanceSettings.d.ts +11 -3
  23. package/dist/InstanceSettings.js +53 -24
  24. package/dist/InstanceSettings.js.map +1 -1
  25. package/dist/InstanceSettingsConfig.d.ts +3 -0
  26. package/dist/InstanceSettingsConfig.js +9 -1
  27. package/dist/InstanceSettingsConfig.js.map +1 -1
  28. package/dist/NodeExecuteFunctions.d.ts +2 -7
  29. package/dist/NodeExecuteFunctions.js +27 -125
  30. package/dist/NodeExecuteFunctions.js.map +1 -1
  31. package/dist/ObjectStore/ObjectStore.service.ee.d.ts +3 -1
  32. package/dist/ObjectStore/ObjectStore.service.ee.js +9 -4
  33. package/dist/ObjectStore/ObjectStore.service.ee.js.map +1 -1
  34. package/dist/RoutingNode.d.ts +18 -0
  35. package/dist/RoutingNode.js +560 -0
  36. package/dist/RoutingNode.js.map +1 -0
  37. package/dist/SSHClientsManager.js +2 -2
  38. package/dist/SSHClientsManager.js.map +1 -1
  39. package/dist/ScheduledTaskManager.js +2 -2
  40. package/dist/ScheduledTaskManager.js.map +1 -1
  41. package/dist/SerializedBuffer.d.ts +6 -0
  42. package/dist/SerializedBuffer.js +16 -0
  43. package/dist/SerializedBuffer.js.map +1 -0
  44. package/dist/TriggersAndPollers.d.ts +5 -0
  45. package/dist/TriggersAndPollers.js +70 -0
  46. package/dist/TriggersAndPollers.js.map +1 -0
  47. package/dist/WorkflowExecute.d.ts +9 -1
  48. package/dist/WorkflowExecute.js +267 -117
  49. package/dist/WorkflowExecute.js.map +1 -1
  50. package/dist/build.tsbuildinfo +1 -1
  51. package/dist/decorators/index.d.ts +1 -0
  52. package/dist/decorators/index.js +6 -0
  53. package/dist/decorators/index.js.map +1 -0
  54. package/dist/decorators/memoized.d.ts +1 -0
  55. package/dist/decorators/memoized.js +23 -0
  56. package/dist/decorators/memoized.js.map +1 -0
  57. package/dist/error-reporter.d.ts +18 -0
  58. package/dist/error-reporter.js +184 -0
  59. package/dist/error-reporter.js.map +1 -0
  60. package/dist/index.d.ts +6 -0
  61. package/dist/index.js +10 -1
  62. package/dist/index.js.map +1 -1
  63. package/dist/logging/logger.d.ts +34 -0
  64. package/dist/logging/logger.js +210 -0
  65. package/dist/logging/logger.js.map +1 -0
  66. package/dist/node-execution-context/base-execute-context.d.ts +1 -3
  67. package/dist/node-execution-context/base-execute-context.js +2 -10
  68. package/dist/node-execution-context/base-execute-context.js.map +1 -1
  69. package/dist/node-execution-context/execute-context.d.ts +2 -2
  70. package/dist/node-execution-context/execute-context.js +4 -2
  71. package/dist/node-execution-context/execute-context.js.map +1 -1
  72. package/dist/node-execution-context/execute-single-context.js +1 -0
  73. package/dist/node-execution-context/execute-single-context.js.map +1 -1
  74. package/dist/node-execution-context/index.d.ts +2 -1
  75. package/dist/node-execution-context/index.js +5 -3
  76. package/dist/node-execution-context/index.js.map +1 -1
  77. package/dist/node-execution-context/local-load-options-context.d.ts +10 -0
  78. package/dist/node-execution-context/local-load-options-context.js +49 -0
  79. package/dist/node-execution-context/local-load-options-context.js.map +1 -0
  80. package/dist/node-execution-context/node-execution-context.d.ts +10 -4
  81. package/dist/node-execution-context/node-execution-context.js +70 -8
  82. package/dist/node-execution-context/node-execution-context.js.map +1 -1
  83. package/dist/node-execution-context/supply-data-context.d.ts +5 -6
  84. package/dist/node-execution-context/supply-data-context.js +9 -19
  85. package/dist/node-execution-context/supply-data-context.js.map +1 -1
  86. package/dist/node-execution-context/utils/cleanupParameterData.d.ts +2 -0
  87. package/dist/node-execution-context/utils/cleanupParameterData.js +27 -0
  88. package/dist/node-execution-context/utils/cleanupParameterData.js.map +1 -0
  89. package/dist/node-execution-context/utils/ensureType.d.ts +6 -0
  90. package/dist/node-execution-context/utils/ensureType.js +75 -0
  91. package/dist/node-execution-context/utils/ensureType.js.map +1 -0
  92. package/dist/node-execution-context/utils/getAdditionalKeys.d.ts +4 -0
  93. package/dist/node-execution-context/utils/getAdditionalKeys.js +57 -0
  94. package/dist/node-execution-context/utils/getAdditionalKeys.js.map +1 -0
  95. package/dist/node-execution-context/utils/getInputConnectionData.d.ts +4 -0
  96. package/dist/node-execution-context/utils/getInputConnectionData.js +99 -0
  97. package/dist/node-execution-context/utils/getInputConnectionData.js.map +1 -0
  98. package/dist/node-execution-context/utils/validateValueAgainstSchema.d.ts +2 -0
  99. package/dist/node-execution-context/utils/validateValueAgainstSchema.js +129 -0
  100. package/dist/node-execution-context/utils/validateValueAgainstSchema.js.map +1 -0
  101. package/dist/node-execution-context/webhook-context.d.ts +2 -2
  102. package/dist/node-execution-context/webhook-context.js +2 -1
  103. package/dist/node-execution-context/webhook-context.js.map +1 -1
  104. package/dist/node-execution-context/workflow-node-context.d.ts +6 -0
  105. package/dist/node-execution-context/workflow-node-context.js +14 -0
  106. package/dist/node-execution-context/workflow-node-context.js.map +1 -0
  107. package/dist/utils.d.ts +5 -0
  108. package/dist/utils.js +10 -0
  109. package/dist/utils.js.map +1 -0
  110. package/package.json +13 -8
  111. package/dist/node-execution-context/utils.d.ts +0 -11
  112. package/dist/node-execution-context/utils.js +0 -275
  113. package/dist/node-execution-context/utils.js.map +0 -1
@@ -0,0 +1 @@
1
+ export { Memoized } from './memoized';
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Memoized = void 0;
4
+ var memoized_1 = require("./memoized");
5
+ Object.defineProperty(exports, "Memoized", { enumerable: true, get: function () { return memoized_1.Memoized; } });
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/decorators/index.ts"],"names":[],"mappings":";;;AAAA,uCAAsC;AAA7B,oGAAA,QAAQ,OAAA"}
@@ -0,0 +1 @@
1
+ export declare function Memoized<T = unknown>(target: object, propertyKey: string | symbol, descriptor?: TypedPropertyDescriptor<T>): TypedPropertyDescriptor<T>;
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Memoized = Memoized;
7
+ const node_assert_1 = __importDefault(require("node:assert"));
8
+ function Memoized(target, propertyKey, descriptor) {
9
+ const originalGetter = descriptor?.get;
10
+ (0, node_assert_1.default)(originalGetter, '@Memoized can only be used on getters');
11
+ descriptor.get = function () {
12
+ const value = originalGetter.call(this);
13
+ Object.defineProperty(this, propertyKey, {
14
+ value,
15
+ configurable: false,
16
+ enumerable: false,
17
+ writable: false,
18
+ });
19
+ return value;
20
+ };
21
+ return descriptor;
22
+ }
23
+ //# sourceMappingURL=memoized.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memoized.js","sourceRoot":"","sources":["../../src/decorators/memoized.ts"],"names":[],"mappings":";;;;;AAkBA,4BAsBC;AAxCD,8DAAiC;AAkBjC,SAAgB,QAAQ,CACvB,MAAc,EACd,WAA4B,EAC5B,UAAuC;IAEvC,MAAM,cAAc,GAAG,UAAU,EAAE,GAAG,CAAC;IACvC,IAAA,qBAAM,EAAC,cAAc,EAAE,uCAAuC,CAAC,CAAC;IAGhE,UAAU,CAAC,GAAG,GAAG;QAChB,MAAM,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,WAAW,EAAE;YACxC,KAAK;YACL,YAAY,EAAE,KAAK;YACnB,UAAU,EAAE,KAAK;YACjB,QAAQ,EAAE,KAAK;SACf,CAAC,CAAC;QACH,OAAO,KAAK,CAAC;IACd,CAAC,CAAC;IAEF,OAAO,UAAU,CAAC;AACnB,CAAC"}
@@ -0,0 +1,18 @@
1
+ import type { ErrorEvent, EventHint } from '@sentry/types';
2
+ import { type ReportingOptions } from 'n8n-workflow';
3
+ import type { InstanceType } from './InstanceSettings';
4
+ import { Logger } from './logging/logger';
5
+ export declare class ErrorReporter {
6
+ private readonly logger;
7
+ private seenErrors;
8
+ private report;
9
+ constructor(logger: Logger);
10
+ private defaultReport;
11
+ shutdown(timeoutInMs?: number): Promise<void>;
12
+ init(instanceType: InstanceType | 'task_runner', dsn: string): Promise<void>;
13
+ beforeSend(event: ErrorEvent, { originalException }: EventHint): Promise<ErrorEvent | null>;
14
+ error(e: unknown, options?: ReportingOptions): void;
15
+ warn(warning: Error | string, options?: ReportingOptions): void;
16
+ info(msg: string, options?: ReportingOptions): void;
17
+ private wrap;
18
+ }
@@ -0,0 +1,184 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
19
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
20
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
21
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
22
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
23
+ };
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ var __metadata = (this && this.__metadata) || function (k, v) {
42
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
43
+ };
44
+ Object.defineProperty(exports, "__esModule", { value: true });
45
+ exports.ErrorReporter = void 0;
46
+ const di_1 = require("@n8n/di");
47
+ const node_1 = require("@sentry/node");
48
+ const axios_1 = require("axios");
49
+ const n8n_workflow_1 = require("n8n-workflow");
50
+ const node_crypto_1 = require("node:crypto");
51
+ const logger_1 = require("./logging/logger");
52
+ let ErrorReporter = class ErrorReporter {
53
+ constructor(logger) {
54
+ this.logger = logger;
55
+ this.seenErrors = new Set();
56
+ this.report = this.defaultReport;
57
+ }
58
+ defaultReport(error, options) {
59
+ if (error instanceof Error) {
60
+ let e = error;
61
+ const { executionId } = options ?? {};
62
+ const context = executionId ? ` (execution ${executionId})` : '';
63
+ do {
64
+ const msg = [
65
+ e.message + context,
66
+ e instanceof n8n_workflow_1.ApplicationError && e.level === 'error' && e.stack ? `\n${e.stack}\n` : '',
67
+ ].join('');
68
+ const meta = e instanceof n8n_workflow_1.ApplicationError ? e.extra : undefined;
69
+ this.logger.error(msg, meta);
70
+ e = e.cause;
71
+ } while (e);
72
+ }
73
+ }
74
+ async shutdown(timeoutInMs = 1000) {
75
+ await (0, node_1.close)(timeoutInMs);
76
+ }
77
+ async init(instanceType, dsn) {
78
+ process.on('uncaughtException', (error) => {
79
+ this.error(error);
80
+ });
81
+ if (!dsn)
82
+ return;
83
+ Error.stackTraceLimit = 50;
84
+ const { N8N_VERSION: release, ENVIRONMENT: environment, DEPLOYMENT_NAME: serverName, } = process.env;
85
+ const { init, captureException, setTag } = await Promise.resolve().then(() => __importStar(require('@sentry/node')));
86
+ const { requestDataIntegration, rewriteFramesIntegration } = await Promise.resolve().then(() => __importStar(require('@sentry/node')));
87
+ const enabledIntegrations = [
88
+ 'InboundFilters',
89
+ 'FunctionToString',
90
+ 'LinkedErrors',
91
+ 'OnUnhandledRejection',
92
+ 'ContextLines',
93
+ ];
94
+ init({
95
+ dsn,
96
+ release,
97
+ environment,
98
+ enableTracing: false,
99
+ serverName,
100
+ beforeBreadcrumb: () => null,
101
+ beforeSend: this.beforeSend.bind(this),
102
+ integrations: (integrations) => [
103
+ ...integrations.filter(({ name }) => enabledIntegrations.includes(name)),
104
+ rewriteFramesIntegration({ root: process.cwd() }),
105
+ requestDataIntegration({
106
+ include: {
107
+ cookies: false,
108
+ data: false,
109
+ headers: false,
110
+ query_string: false,
111
+ url: true,
112
+ user: false,
113
+ },
114
+ }),
115
+ ],
116
+ });
117
+ setTag('server_type', instanceType);
118
+ this.report = (error, options) => captureException(error, options);
119
+ }
120
+ async beforeSend(event, { originalException }) {
121
+ if (!originalException)
122
+ return null;
123
+ if (originalException instanceof Promise) {
124
+ originalException = await originalException.catch((error) => error);
125
+ }
126
+ if (originalException instanceof axios_1.AxiosError)
127
+ return null;
128
+ if (originalException instanceof Error &&
129
+ originalException.name === 'QueryFailedError' &&
130
+ ['SQLITE_FULL', 'SQLITE_IOERR'].some((errMsg) => originalException.message.includes(errMsg))) {
131
+ return null;
132
+ }
133
+ if (originalException instanceof n8n_workflow_1.ApplicationError) {
134
+ const { level, extra, tags } = originalException;
135
+ if (level === 'warning')
136
+ return null;
137
+ event.level = level;
138
+ if (extra)
139
+ event.extra = { ...event.extra, ...extra };
140
+ if (tags)
141
+ event.tags = { ...event.tags, ...tags };
142
+ }
143
+ if (originalException instanceof Error &&
144
+ 'cause' in originalException &&
145
+ originalException.cause instanceof Error &&
146
+ 'level' in originalException.cause &&
147
+ originalException.cause.level === 'warning') {
148
+ return null;
149
+ }
150
+ if (originalException instanceof Error && originalException.stack) {
151
+ const eventHash = (0, node_crypto_1.createHash)('sha1').update(originalException.stack).digest('base64');
152
+ if (this.seenErrors.has(eventHash))
153
+ return null;
154
+ this.seenErrors.add(eventHash);
155
+ }
156
+ return event;
157
+ }
158
+ error(e, options) {
159
+ if (e instanceof n8n_workflow_1.ExecutionCancelledError)
160
+ return;
161
+ const toReport = this.wrap(e);
162
+ if (toReport)
163
+ this.report(toReport, options);
164
+ }
165
+ warn(warning, options) {
166
+ this.error(warning, { ...options, level: 'warning' });
167
+ }
168
+ info(msg, options) {
169
+ this.report(msg, { ...options, level: 'info' });
170
+ }
171
+ wrap(e) {
172
+ if (e instanceof Error)
173
+ return e;
174
+ if (typeof e === 'string')
175
+ return new n8n_workflow_1.ApplicationError(e);
176
+ return;
177
+ }
178
+ };
179
+ exports.ErrorReporter = ErrorReporter;
180
+ exports.ErrorReporter = ErrorReporter = __decorate([
181
+ (0, di_1.Service)(),
182
+ __metadata("design:paramtypes", [logger_1.Logger])
183
+ ], ErrorReporter);
184
+ //# sourceMappingURL=error-reporter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error-reporter.js","sourceRoot":"","sources":["../src/error-reporter.ts"],"names":[],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import * as NodeExecuteFunctions from './NodeExecuteFunctions';
2
+ export * from './decorators';
2
3
  export * from './errors';
3
4
  export * from './ActiveWorkflows';
4
5
  export * from './BinaryData/BinaryData.service';
@@ -9,7 +10,9 @@ export * from './Credentials';
9
10
  export * from './DirectoryLoader';
10
11
  export * from './Interfaces';
11
12
  export { InstanceSettings, InstanceType } from './InstanceSettings';
13
+ export { Logger } from './logging/logger';
12
14
  export * from './NodeExecuteFunctions';
15
+ export * from './RoutingNode';
13
16
  export * from './WorkflowExecute';
14
17
  export { NodeExecuteFunctions };
15
18
  export * from './data-deduplication-service';
@@ -20,3 +23,6 @@ export { isStoredMode as isValidNonDefaultMode } from './BinaryData/utils';
20
23
  export * from './ExecutionMetadata';
21
24
  export * from './node-execution-context';
22
25
  export * from './PartialExecutionUtils';
26
+ export { ErrorReporter } from './error-reporter';
27
+ export * from './SerializedBuffer';
28
+ export { isObjectLiteral } from './utils';
package/dist/index.js CHANGED
@@ -36,9 +36,10 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
36
36
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
37
37
  };
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.isValidNonDefaultMode = exports.ObjectStoreService = exports.NodeExecuteFunctions = exports.InstanceSettings = exports.Cipher = void 0;
39
+ exports.isObjectLiteral = exports.ErrorReporter = exports.isValidNonDefaultMode = exports.ObjectStoreService = exports.NodeExecuteFunctions = exports.Logger = exports.InstanceSettings = exports.Cipher = void 0;
40
40
  const NodeExecuteFunctions = __importStar(require("./NodeExecuteFunctions"));
41
41
  exports.NodeExecuteFunctions = NodeExecuteFunctions;
42
+ __exportStar(require("./decorators"), exports);
42
43
  __exportStar(require("./errors"), exports);
43
44
  __exportStar(require("./ActiveWorkflows"), exports);
44
45
  __exportStar(require("./BinaryData/BinaryData.service"), exports);
@@ -51,7 +52,10 @@ __exportStar(require("./DirectoryLoader"), exports);
51
52
  __exportStar(require("./Interfaces"), exports);
52
53
  var InstanceSettings_1 = require("./InstanceSettings");
53
54
  Object.defineProperty(exports, "InstanceSettings", { enumerable: true, get: function () { return InstanceSettings_1.InstanceSettings; } });
55
+ var logger_1 = require("./logging/logger");
56
+ Object.defineProperty(exports, "Logger", { enumerable: true, get: function () { return logger_1.Logger; } });
54
57
  __exportStar(require("./NodeExecuteFunctions"), exports);
58
+ __exportStar(require("./RoutingNode"), exports);
55
59
  __exportStar(require("./WorkflowExecute"), exports);
56
60
  __exportStar(require("./data-deduplication-service"), exports);
57
61
  __exportStar(require("./errors"), exports);
@@ -62,4 +66,9 @@ Object.defineProperty(exports, "isValidNonDefaultMode", { enumerable: true, get:
62
66
  __exportStar(require("./ExecutionMetadata"), exports);
63
67
  __exportStar(require("./node-execution-context"), exports);
64
68
  __exportStar(require("./PartialExecutionUtils"), exports);
69
+ var error_reporter_1 = require("./error-reporter");
70
+ Object.defineProperty(exports, "ErrorReporter", { enumerable: true, get: function () { return error_reporter_1.ErrorReporter; } });
71
+ __exportStar(require("./SerializedBuffer"), exports);
72
+ var utils_2 = require("./utils");
73
+ Object.defineProperty(exports, "isObjectLiteral", { enumerable: true, get: function () { return utils_2.isObjectLiteral; } });
65
74
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6EAA+D;AActD,oDAAoB;AAZ7B,2CAAyB;AACzB,oDAAkC;AAClC,kEAAgD;AAChD,qDAAmC;AACnC,mCAAkC;AAAzB,gGAAA,MAAM,OAAA;AACf,8CAA4B;AAC5B,gDAA8B;AAC9B,oDAAkC;AAClC,+CAA6B;AAC7B,uDAAoE;AAA3D,oHAAA,gBAAgB,OAAA;AACzB,yDAAuC;AACvC,oDAAkC;AAElC,+DAA6C;AAC7C,2CAAyB;AACzB,+EAA0E;AAAjE,4HAAA,kBAAkB,OAAA;AAE3B,4CAA2E;AAAlE,8GAAA,YAAY,OAAyB;AAC9C,sDAAoC;AACpC,2DAAyC;AACzC,0DAAwC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6EAA+D;AAiBtD,oDAAoB;AAf7B,+CAA6B;AAC7B,2CAAyB;AACzB,oDAAkC;AAClC,kEAAgD;AAChD,qDAAmC;AACnC,mCAAkC;AAAzB,gGAAA,MAAM,OAAA;AACf,8CAA4B;AAC5B,gDAA8B;AAC9B,oDAAkC;AAClC,+CAA6B;AAC7B,uDAAoE;AAA3D,oHAAA,gBAAgB,OAAA;AACzB,2CAA0C;AAAjC,gGAAA,MAAM,OAAA;AACf,yDAAuC;AACvC,gDAA8B;AAC9B,oDAAkC;AAElC,+DAA6C;AAC7C,2CAAyB;AACzB,+EAA0E;AAAjE,4HAAA,kBAAkB,OAAA;AAE3B,4CAA2E;AAAlE,8GAAA,YAAY,OAAyB;AAC9C,sDAAoC;AACpC,2DAAyC;AACzC,0DAAwC;AACxC,mDAAiD;AAAxC,+GAAA,aAAa,OAAA;AACtB,qDAAmC;AACnC,iCAA0C;AAAjC,wGAAA,eAAe,OAAA"}
@@ -0,0 +1,34 @@
1
+ import type { LogScope } from '@n8n/config';
2
+ import { GlobalConfig } from '@n8n/config';
3
+ import type { Logger as LoggerType, LogMetadata } from 'n8n-workflow';
4
+ import winston from 'winston';
5
+ import { InstanceSettingsConfig } from '../InstanceSettingsConfig';
6
+ export declare class Logger implements LoggerType {
7
+ private readonly globalConfig;
8
+ private readonly instanceSettingsConfig;
9
+ private internalLogger;
10
+ private readonly level;
11
+ private readonly scopes;
12
+ private get isScopingEnabled();
13
+ private readonly noColor;
14
+ constructor(globalConfig: GlobalConfig, instanceSettingsConfig: InstanceSettingsConfig, { isRoot }?: {
15
+ isRoot?: boolean;
16
+ });
17
+ private setInternalLogger;
18
+ scoped(scopes: LogScope | LogScope[]): Logger;
19
+ private log;
20
+ private setLevel;
21
+ private setConsoleTransport;
22
+ private scopeFilter;
23
+ private color;
24
+ private debugDevConsoleFormat;
25
+ private debugProdConsoleFormat;
26
+ private devTsFormat;
27
+ private toPrintable;
28
+ private setFileTransport;
29
+ error(message: string, metadata?: LogMetadata): void;
30
+ warn(message: string, metadata?: LogMetadata): void;
31
+ info(message: string, metadata?: LogMetadata): void;
32
+ debug(message: string, metadata?: LogMetadata): void;
33
+ getInternalLogger(): winston.Logger;
34
+ }
@@ -0,0 +1,210 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
19
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
20
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
21
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
22
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
23
+ };
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ var __metadata = (this && this.__metadata) || function (k, v) {
42
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
43
+ };
44
+ var __importDefault = (this && this.__importDefault) || function (mod) {
45
+ return (mod && mod.__esModule) ? mod : { "default": mod };
46
+ };
47
+ var Logger_1;
48
+ Object.defineProperty(exports, "__esModule", { value: true });
49
+ exports.Logger = void 0;
50
+ const config_1 = require("@n8n/config");
51
+ const di_1 = require("@n8n/di");
52
+ const callsites_1 = __importDefault(require("callsites"));
53
+ const n8n_workflow_1 = require("n8n-workflow");
54
+ const node_path_1 = __importStar(require("node:path"));
55
+ const picocolors_1 = __importDefault(require("picocolors"));
56
+ const winston_1 = __importDefault(require("winston"));
57
+ const Constants_1 = require("../Constants");
58
+ const InstanceSettingsConfig_1 = require("../InstanceSettingsConfig");
59
+ const utils_1 = require("../utils");
60
+ const noOp = () => { };
61
+ let Logger = Logger_1 = class Logger {
62
+ get isScopingEnabled() {
63
+ return this.scopes.size > 0;
64
+ }
65
+ constructor(globalConfig, instanceSettingsConfig, { isRoot } = { isRoot: true }) {
66
+ this.globalConfig = globalConfig;
67
+ this.instanceSettingsConfig = instanceSettingsConfig;
68
+ this.noColor = process.env.NO_COLOR !== undefined && process.env.NO_COLOR !== '';
69
+ this.level = this.globalConfig.logging.level;
70
+ const isSilent = this.level === 'silent';
71
+ this.internalLogger = winston_1.default.createLogger({
72
+ level: this.level,
73
+ silent: isSilent,
74
+ });
75
+ if (!isSilent) {
76
+ this.setLevel();
77
+ const { outputs, scopes } = this.globalConfig.logging;
78
+ if (outputs.includes('console'))
79
+ this.setConsoleTransport();
80
+ if (outputs.includes('file'))
81
+ this.setFileTransport();
82
+ this.scopes = new Set(scopes);
83
+ }
84
+ else {
85
+ this.scopes = new Set();
86
+ }
87
+ if (isRoot)
88
+ n8n_workflow_1.LoggerProxy.init(this);
89
+ }
90
+ setInternalLogger(internalLogger) {
91
+ this.internalLogger = internalLogger;
92
+ }
93
+ scoped(scopes) {
94
+ scopes = Array.isArray(scopes) ? scopes : [scopes];
95
+ const scopedLogger = new Logger_1(this.globalConfig, this.instanceSettingsConfig, {
96
+ isRoot: false,
97
+ });
98
+ const childLogger = this.internalLogger.child({ scopes });
99
+ scopedLogger.setInternalLogger(childLogger);
100
+ return scopedLogger;
101
+ }
102
+ log(level, message, metadata) {
103
+ const location = {};
104
+ const caller = (0, callsites_1.default)().at(2);
105
+ if (caller !== undefined) {
106
+ location.file = (0, node_path_1.basename)(caller.getFileName() ?? '');
107
+ const fnName = caller.getFunctionName();
108
+ if (fnName)
109
+ location.function = fnName;
110
+ }
111
+ this.internalLogger.log(level, message, { ...metadata, ...location });
112
+ }
113
+ setLevel() {
114
+ const { levels } = this.internalLogger;
115
+ for (const logLevel of n8n_workflow_1.LOG_LEVELS) {
116
+ if (levels[logLevel] > levels[this.level]) {
117
+ Object.defineProperty(this, logLevel, { value: noOp });
118
+ }
119
+ }
120
+ }
121
+ setConsoleTransport() {
122
+ const format = this.level === 'debug' && Constants_1.inDevelopment
123
+ ? this.debugDevConsoleFormat()
124
+ : this.level === 'debug' && Constants_1.inProduction
125
+ ? this.debugProdConsoleFormat()
126
+ : winston_1.default.format.printf(({ message }) => message);
127
+ this.internalLogger.add(new winston_1.default.transports.Console({ format }));
128
+ }
129
+ scopeFilter() {
130
+ return winston_1.default.format((info) => {
131
+ if (!this.isScopingEnabled)
132
+ return info;
133
+ const { scopes } = info.metadata;
134
+ const shouldIncludeScope = scopes && scopes?.length > 0 && scopes.some((s) => this.scopes.has(s));
135
+ return shouldIncludeScope ? info : false;
136
+ })();
137
+ }
138
+ color() {
139
+ return this.noColor ? winston_1.default.format.uncolorize() : winston_1.default.format.colorize({ all: true });
140
+ }
141
+ debugDevConsoleFormat() {
142
+ return winston_1.default.format.combine(winston_1.default.format.metadata(), winston_1.default.format.timestamp({ format: () => this.devTsFormat() }), this.color(), this.scopeFilter(), winston_1.default.format.printf(({ level: rawLevel, message, timestamp, metadata: rawMetadata }) => {
143
+ const separator = ' '.repeat(3);
144
+ const logLevelColumnWidth = this.noColor ? 5 : 15;
145
+ const level = rawLevel.toLowerCase().padEnd(logLevelColumnWidth, ' ');
146
+ const metadata = this.toPrintable(rawMetadata);
147
+ return [timestamp, level, message + ' ' + picocolors_1.default.dim(metadata)].join(separator);
148
+ }));
149
+ }
150
+ debugProdConsoleFormat() {
151
+ return winston_1.default.format.combine(winston_1.default.format.metadata(), winston_1.default.format.timestamp(), this.color(), this.scopeFilter(), winston_1.default.format.printf(({ level, message, timestamp, metadata: rawMetadata }) => {
152
+ const metadata = this.toPrintable(rawMetadata);
153
+ return `${timestamp} | ${level.padEnd(5)} | ${message}${metadata ? ' ' + metadata : ''}`;
154
+ }));
155
+ }
156
+ devTsFormat() {
157
+ const now = new Date();
158
+ const pad = (num, digits = 2) => num.toString().padStart(digits, '0');
159
+ const hours = pad(now.getHours());
160
+ const minutes = pad(now.getMinutes());
161
+ const seconds = pad(now.getSeconds());
162
+ const milliseconds = pad(now.getMilliseconds(), 3);
163
+ return `${hours}:${minutes}:${seconds}.${milliseconds}`;
164
+ }
165
+ toPrintable(metadata) {
166
+ if ((0, utils_1.isObjectLiteral)(metadata) && Object.keys(metadata).length > 0) {
167
+ return Constants_1.inProduction
168
+ ? JSON.stringify(metadata)
169
+ : JSON.stringify(metadata)
170
+ .replace(/{"/g, '{ "')
171
+ .replace(/,"/g, ', "')
172
+ .replace(/:/g, ': ')
173
+ .replace(/}/g, ' }');
174
+ }
175
+ return '';
176
+ }
177
+ setFileTransport() {
178
+ const format = winston_1.default.format.combine(winston_1.default.format.timestamp(), winston_1.default.format.metadata(), winston_1.default.format.json());
179
+ const filename = node_path_1.default.join(this.instanceSettingsConfig.n8nFolder, this.globalConfig.logging.file.location);
180
+ const { fileSizeMax, fileCountMax } = this.globalConfig.logging.file;
181
+ this.internalLogger.add(new winston_1.default.transports.File({
182
+ filename,
183
+ format,
184
+ maxsize: fileSizeMax * 1_048_576,
185
+ maxFiles: fileCountMax,
186
+ }));
187
+ }
188
+ error(message, metadata = {}) {
189
+ this.log('error', message, metadata);
190
+ }
191
+ warn(message, metadata = {}) {
192
+ this.log('warn', message, metadata);
193
+ }
194
+ info(message, metadata = {}) {
195
+ this.log('info', message, metadata);
196
+ }
197
+ debug(message, metadata = {}) {
198
+ this.log('debug', message, metadata);
199
+ }
200
+ getInternalLogger() {
201
+ return this.internalLogger;
202
+ }
203
+ };
204
+ exports.Logger = Logger;
205
+ exports.Logger = Logger = Logger_1 = __decorate([
206
+ (0, di_1.Service)(),
207
+ __metadata("design:paramtypes", [config_1.GlobalConfig,
208
+ InstanceSettingsConfig_1.InstanceSettingsConfig, Object])
209
+ ], Logger);
210
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logging/logger.ts"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import type { Workflow, INode, IWorkflowExecuteAdditionalData, WorkflowExecuteMode, IRunExecutionData, INodeExecutionData, ITaskDataConnections, IExecuteData, ICredentialDataDecryptedObject, CallbackManager, IExecuteWorkflowInfo, RelatedExecution, ExecuteWorkflowData, ITaskMetadata, ContextType, IContextObject, INodeInputConfiguration, INodeOutputConfiguration, IWorkflowDataProxyData, ISourceData, AiEvent } from 'n8n-workflow';
1
+ import type { Workflow, INode, IWorkflowExecuteAdditionalData, WorkflowExecuteMode, IRunExecutionData, INodeExecutionData, ITaskDataConnections, IExecuteData, ICredentialDataDecryptedObject, CallbackManager, IExecuteWorkflowInfo, RelatedExecution, ExecuteWorkflowData, ITaskMetadata, ContextType, IContextObject, IWorkflowDataProxyData, ISourceData, AiEvent } from 'n8n-workflow';
2
2
  import { NodeConnectionType } from 'n8n-workflow';
3
3
  import { BinaryDataService } from '../BinaryData/BinaryData.service';
4
4
  import { NodeExecutionContext } from './node-execution-context';
@@ -23,8 +23,6 @@ export declare class BaseExecuteContext extends NodeExecutionContext {
23
23
  parentExecution?: RelatedExecution;
24
24
  }): Promise<ExecuteWorkflowData>;
25
25
  protected getInputItems(inputIndex: number, connectionType: NodeConnectionType): INodeExecutionData[] | undefined;
26
- getNodeInputs(): INodeInputConfiguration[];
27
- getNodeOutputs(): INodeOutputConfiguration[];
28
26
  getInputSourceData(inputIndex?: number, connectionType?: NodeConnectionType): ISourceData;
29
27
  getWorkflowDataProxy(itemIndex: number): IWorkflowDataProxyData;
30
28
  sendMessageToUI(...args: any[]): void;
@@ -1,9 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.BaseExecuteContext = void 0;
4
+ const di_1 = require("@n8n/di");
4
5
  const lodash_1 = require("lodash");
5
6
  const n8n_workflow_1 = require("n8n-workflow");
6
- const typedi_1 = require("typedi");
7
7
  const BinaryData_service_1 = require("../BinaryData/BinaryData.service");
8
8
  const node_execution_context_1 = require("./node-execution-context");
9
9
  class BaseExecuteContext extends node_execution_context_1.NodeExecutionContext {
@@ -14,7 +14,7 @@ class BaseExecuteContext extends node_execution_context_1.NodeExecutionContext {
14
14
  this.inputData = inputData;
15
15
  this.executeData = executeData;
16
16
  this.abortSignal = abortSignal;
17
- this.binaryDataService = typedi_1.Container.get(BinaryData_service_1.BinaryDataService);
17
+ this.binaryDataService = di_1.Container.get(BinaryData_service_1.BinaryDataService);
18
18
  }
19
19
  getExecutionCancelSignal() {
20
20
  return this.abortSignal;
@@ -84,14 +84,6 @@ class BaseExecuteContext extends node_execution_context_1.NodeExecutionContext {
84
84
  }
85
85
  return allItems;
86
86
  }
87
- getNodeInputs() {
88
- const nodeType = this.workflow.nodeTypes.getByNameAndVersion(this.node.type, this.node.typeVersion);
89
- return n8n_workflow_1.NodeHelpers.getNodeInputs(this.workflow, this.node, nodeType.description).map((input) => typeof input === 'string' ? { type: input } : input);
90
- }
91
- getNodeOutputs() {
92
- const nodeType = this.workflow.nodeTypes.getByNameAndVersion(this.node.type, this.node.typeVersion);
93
- return n8n_workflow_1.NodeHelpers.getNodeOutputs(this.workflow, this.node, nodeType.description).map((output) => (typeof output === 'string' ? { type: output } : output));
94
- }
95
87
  getInputSourceData(inputIndex = 0, connectionType = "main") {
96
88
  if (this.executeData?.source === null) {
97
89
  throw new n8n_workflow_1.ApplicationError('Source data is missing');