n8n 2.14.2 → 2.15.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 (179) hide show
  1. package/dist/abstract-server.js +1 -1
  2. package/dist/abstract-server.js.map +1 -1
  3. package/dist/build.tsbuildinfo +1 -1
  4. package/dist/commands/base-command.d.ts +1 -0
  5. package/dist/commands/base-command.js +8 -6
  6. package/dist/commands/base-command.js.map +1 -1
  7. package/dist/commands/execute-batch.js +2 -0
  8. package/dist/commands/execute-batch.js.map +1 -1
  9. package/dist/commands/execute.js +2 -0
  10. package/dist/commands/execute.js.map +1 -1
  11. package/dist/commands/start.js +1 -0
  12. package/dist/commands/start.js.map +1 -1
  13. package/dist/commands/webhook.js +1 -0
  14. package/dist/commands/webhook.js.map +1 -1
  15. package/dist/commands/worker.js +1 -0
  16. package/dist/commands/worker.js.map +1 -1
  17. package/dist/constants.js +1 -0
  18. package/dist/constants.js.map +1 -1
  19. package/dist/controllers/ai.controller.js +1 -1
  20. package/dist/controllers/ai.controller.js.map +1 -1
  21. package/dist/controllers/binary-data.controller.js +1 -1
  22. package/dist/controllers/binary-data.controller.js.map +1 -1
  23. package/dist/controllers/me.controller.d.ts +3 -1
  24. package/dist/controllers/me.controller.js +6 -3
  25. package/dist/controllers/me.controller.js.map +1 -1
  26. package/dist/controllers/project.controller.d.ts +2 -0
  27. package/dist/credentials/credentials.service.js +1 -1
  28. package/dist/credentials/credentials.service.js.map +1 -1
  29. package/dist/execution-lifecycle/execution-lifecycle-hooks.js +9 -8
  30. package/dist/execution-lifecycle/execution-lifecycle-hooks.js.map +1 -1
  31. package/dist/executions/execution-persistence.d.ts +4 -1
  32. package/dist/executions/execution-persistence.js +16 -2
  33. package/dist/executions/execution-persistence.js.map +1 -1
  34. package/dist/executions/executions.controller.d.ts +3 -5
  35. package/dist/executions/executions.controller.js +17 -9
  36. package/dist/executions/executions.controller.js.map +1 -1
  37. package/dist/modules/community-packages/community-packages.controller.d.ts +6 -19
  38. package/dist/modules/community-packages/community-packages.controller.js +8 -231
  39. package/dist/modules/community-packages/community-packages.controller.js.map +1 -1
  40. package/dist/modules/community-packages/community-packages.lifecycle.service.d.ts +32 -0
  41. package/dist/modules/community-packages/community-packages.lifecycle.service.js +282 -0
  42. package/dist/modules/community-packages/community-packages.lifecycle.service.js.map +1 -0
  43. package/dist/modules/community-packages/community-packages.service.js +8 -8
  44. package/dist/modules/community-packages/community-packages.service.js.map +1 -1
  45. package/dist/modules/community-packages/npm-utils.d.ts +4 -0
  46. package/dist/modules/community-packages/npm-utils.js +4 -0
  47. package/dist/modules/community-packages/npm-utils.js.map +1 -1
  48. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.d.ts +1 -0
  49. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js +1 -0
  50. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js.map +1 -1
  51. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/slack-signature-extractor.d.ts +11 -0
  52. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/slack-signature-extractor.js +88 -0
  53. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/slack-signature-extractor.js.map +1 -0
  54. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/slack-signature-identifier.d.ts +28 -0
  55. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/slack-signature-identifier.js +158 -0
  56. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/slack-signature-identifier.js.map +1 -0
  57. package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.d.ts +1 -0
  58. package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js +1 -0
  59. package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js.map +1 -1
  60. package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.d.ts +50 -0
  61. package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.js +118 -0
  62. package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.js.map +1 -0
  63. package/dist/modules/instance-registry/storage/memory-storage.d.ts +15 -0
  64. package/dist/modules/instance-registry/storage/memory-storage.js +41 -0
  65. package/dist/modules/instance-registry/storage/memory-storage.js.map +1 -0
  66. package/dist/modules/mcp/mcp-oauth-service.d.ts +1 -1
  67. package/dist/modules/mcp/mcp-oauth-service.js +5 -1
  68. package/dist/modules/mcp/mcp-oauth-service.js.map +1 -1
  69. package/dist/modules/mcp/mcp.errors.js +1 -1
  70. package/dist/modules/mcp/mcp.oauth-clients.controller.js +1 -1
  71. package/dist/modules/mcp/mcp.oauth-clients.controller.js.map +1 -1
  72. package/dist/modules/mcp/mcp.service.d.ts +3 -1
  73. package/dist/modules/mcp/mcp.service.js +13 -4
  74. package/dist/modules/mcp/mcp.service.js.map +1 -1
  75. package/dist/modules/mcp/mcp.types.d.ts +1 -1
  76. package/dist/modules/mcp/tools/execute-workflow.tool.js +8 -44
  77. package/dist/modules/mcp/tools/execute-workflow.tool.js.map +1 -1
  78. package/dist/modules/mcp/tools/execution-utils.d.ts +5 -0
  79. package/dist/modules/mcp/tools/execution-utils.js +45 -0
  80. package/dist/modules/mcp/tools/execution-utils.js.map +1 -0
  81. package/dist/modules/mcp/tools/prepare-workflow-pin-data.tool.d.ts +31 -0
  82. package/dist/modules/mcp/tools/prepare-workflow-pin-data.tool.js +165 -0
  83. package/dist/modules/mcp/tools/prepare-workflow-pin-data.tool.js.map +1 -0
  84. package/dist/modules/mcp/tools/test-workflow.tool.d.ts +31 -0
  85. package/dist/modules/mcp/tools/test-workflow.tool.js +178 -0
  86. package/dist/modules/mcp/tools/test-workflow.tool.js.map +1 -0
  87. package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js +1 -0
  88. package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js.map +1 -1
  89. package/dist/modules/mcp/tools/workflow-builder/credentials-auto-assign.d.ts +2 -1
  90. package/dist/modules/mcp/tools/workflow-builder/credentials-auto-assign.js +15 -0
  91. package/dist/modules/mcp/tools/workflow-builder/credentials-auto-assign.js.map +1 -1
  92. package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js +1 -0
  93. package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js.map +1 -1
  94. package/dist/modules/otel/handlers/interfaces.d.ts +5 -0
  95. package/dist/modules/otel/handlers/interfaces.js +3 -0
  96. package/dist/modules/otel/handlers/interfaces.js.map +1 -0
  97. package/dist/modules/otel/handlers/workflow-end.handler.d.ts +7 -0
  98. package/dist/modules/otel/handlers/workflow-end.handler.js +65 -0
  99. package/dist/modules/otel/handlers/workflow-end.handler.js.map +1 -0
  100. package/dist/modules/otel/handlers/workflow-start.handler.d.ts +7 -0
  101. package/dist/modules/otel/handlers/workflow-start.handler.js +29 -0
  102. package/dist/modules/otel/handlers/workflow-start.handler.js.map +1 -0
  103. package/dist/modules/otel/n8n-instrumentation.d.ts +15 -0
  104. package/dist/modules/otel/n8n-instrumentation.js +72 -0
  105. package/dist/modules/otel/n8n-instrumentation.js.map +1 -0
  106. package/dist/modules/otel/otel.config.d.ts +9 -0
  107. package/dist/modules/otel/otel.config.js +57 -0
  108. package/dist/modules/otel/otel.config.js.map +1 -0
  109. package/dist/modules/otel/otel.constants.d.ts +15 -0
  110. package/dist/modules/otel/otel.constants.js +20 -0
  111. package/dist/modules/otel/otel.constants.js.map +1 -0
  112. package/dist/modules/otel/otel.module.d.ts +5 -0
  113. package/dist/modules/otel/otel.module.js +80 -0
  114. package/dist/modules/otel/otel.module.js.map +1 -0
  115. package/dist/modules/otel/otel.service.d.ts +18 -0
  116. package/dist/modules/otel/otel.service.js +123 -0
  117. package/dist/modules/otel/otel.service.js.map +1 -0
  118. package/dist/modules/otel/span-registry.d.ts +13 -0
  119. package/dist/modules/otel/span-registry.js +47 -0
  120. package/dist/modules/otel/span-registry.js.map +1 -0
  121. package/dist/modules/provisioning.ee/provisioning.module.js +1 -0
  122. package/dist/modules/provisioning.ee/provisioning.module.js.map +1 -1
  123. package/dist/modules/provisioning.ee/role-mapping-rule.controller.ee.d.ts +18 -0
  124. package/dist/modules/provisioning.ee/role-mapping-rule.controller.ee.js +105 -0
  125. package/dist/modules/provisioning.ee/role-mapping-rule.controller.ee.js.map +1 -0
  126. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.d.ts +34 -0
  127. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js +221 -0
  128. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js.map +1 -0
  129. package/dist/modules/provisioning.ee/role-mapping-rule.validation.d.ts +3 -0
  130. package/dist/modules/provisioning.ee/role-mapping-rule.validation.js +29 -0
  131. package/dist/modules/provisioning.ee/role-mapping-rule.validation.js.map +1 -0
  132. package/dist/modules/source-control.ee/source-control-import.service.ee.js +6 -0
  133. package/dist/modules/source-control.ee/source-control-import.service.ee.js.map +1 -1
  134. package/dist/modules/source-control.ee/types/source-control-preferences.js +3 -0
  135. package/dist/modules/source-control.ee/types/source-control-preferences.js.map +1 -1
  136. package/dist/modules/workflow-builder/workflow-builder-session.entity.d.ts +4 -0
  137. package/dist/modules/workflow-builder/workflow-builder-session.entity.js +8 -0
  138. package/dist/modules/workflow-builder/workflow-builder-session.entity.js.map +1 -1
  139. package/dist/modules/workflow-builder/workflow-builder-session.repository.js +14 -2
  140. package/dist/modules/workflow-builder/workflow-builder-session.repository.js.map +1 -1
  141. package/dist/modules/workflow-index/workflow-dependency-query.service.js +26 -3
  142. package/dist/modules/workflow-index/workflow-dependency-query.service.js.map +1 -1
  143. package/dist/modules/workflow-index/workflow-index.service.d.ts +1 -0
  144. package/dist/modules/workflow-index/workflow-index.service.js +15 -3
  145. package/dist/modules/workflow-index/workflow-index.service.js.map +1 -1
  146. package/dist/posthog/index.d.ts +1 -0
  147. package/dist/posthog/index.js +32 -8
  148. package/dist/posthog/index.js.map +1 -1
  149. package/dist/public-api/v1/handlers/credentials/credentials.handler.js +6 -5
  150. package/dist/public-api/v1/handlers/credentials/credentials.handler.js.map +1 -1
  151. package/dist/public-api/v1/handlers/credentials/credentials.service.d.ts +2 -2
  152. package/dist/public-api/v1/handlers/credentials/credentials.service.js +3 -6
  153. package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
  154. package/dist/public-api/v1/handlers/workflows/workflows.handler.d.ts +8 -0
  155. package/dist/public-api/v1/handlers/workflows/workflows.handler.js +44 -0
  156. package/dist/public-api/v1/handlers/workflows/workflows.handler.js.map +1 -1
  157. package/dist/public-api/v1/openapi.yml +54 -1
  158. package/dist/scaling/job-processor.js +3 -0
  159. package/dist/scaling/job-processor.js.map +1 -1
  160. package/dist/scaling/scaling.service.js +1 -2
  161. package/dist/scaling/scaling.service.js.map +1 -1
  162. package/dist/scaling/worker-server.js +1 -1
  163. package/dist/scaling/worker-server.js.map +1 -1
  164. package/dist/services/ai-workflow-builder.service.d.ts +1 -1
  165. package/dist/services/ai-workflow-builder.service.js +3 -6
  166. package/dist/services/ai-workflow-builder.service.js.map +1 -1
  167. package/dist/services/frontend.service.js +2 -1
  168. package/dist/services/frontend.service.js.map +1 -1
  169. package/dist/utils/health-endpoint.util.d.ts +2 -1
  170. package/dist/utils/health-endpoint.util.js +11 -3
  171. package/dist/utils/health-endpoint.util.js.map +1 -1
  172. package/dist/webhooks/waiting-forms.js +3 -1
  173. package/dist/webhooks/waiting-forms.js.map +1 -1
  174. package/dist/webhooks/webhook-request-handler.js +1 -1
  175. package/dist/webhooks/webhook-request-handler.js.map +1 -1
  176. package/dist/workflows/workflow.service.d.ts +6 -1
  177. package/dist/workflows/workflow.service.js +22 -6
  178. package/dist/workflows/workflow.service.js.map +1 -1
  179. package/package.json +32 -25
@@ -0,0 +1,7 @@
1
+ import type { WorkflowExecuteAfterContext } from '@n8n/decorators';
2
+ import type { SpanHandler } from './interfaces';
3
+ import type { SpanRegistry } from '../span-registry';
4
+ export declare class WorkflowEndHandler implements SpanHandler<WorkflowExecuteAfterContext> {
5
+ handle(ctx: WorkflowExecuteAfterContext, spans: SpanRegistry): void;
6
+ private getErrorType;
7
+ }
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.WorkflowEndHandler = void 0;
10
+ const di_1 = require("@n8n/di");
11
+ const api_1 = require("@opentelemetry/api");
12
+ const otel_constants_1 = require("../otel.constants");
13
+ let WorkflowEndHandler = class WorkflowEndHandler {
14
+ handle(ctx, spans) {
15
+ const span = spans.removeWorkflow(ctx.executionId);
16
+ if (!span)
17
+ return;
18
+ const attributes = {
19
+ [otel_constants_1.ATTR.EXECUTION_MODE]: ctx.runData.mode,
20
+ [otel_constants_1.ATTR.EXECUTION_STATUS]: ctx.runData.status,
21
+ [otel_constants_1.ATTR.EXECUTION_IS_RETRY]: ctx.runData.mode === 'retry',
22
+ };
23
+ if (ctx.retryOf) {
24
+ attributes[otel_constants_1.ATTR.EXECUTION_RETRY_OF] = ctx.retryOf;
25
+ }
26
+ span.setAttributes(attributes);
27
+ if (['error', 'crashed'].includes(ctx.runData.status)) {
28
+ span.setStatus({ code: api_1.SpanStatusCode.ERROR });
29
+ const error = ctx.runData.data.resultData.error;
30
+ if (error) {
31
+ span.setAttribute(otel_constants_1.ATTR.EXECUTION_ERROR_TYPE, this.getErrorType(error));
32
+ }
33
+ }
34
+ else {
35
+ span.setStatus({ code: api_1.SpanStatusCode.OK });
36
+ }
37
+ span.end();
38
+ spans.cleanup(ctx.executionId);
39
+ }
40
+ getErrorType(error) {
41
+ if (!isRecord(error))
42
+ return 'UnknownError';
43
+ const errorName = error.name;
44
+ if (typeof errorName === 'string' && errorName.trim() !== '')
45
+ return errorName;
46
+ const constructor = error.constructor;
47
+ if (typeof constructor !== 'function')
48
+ return 'UnknownError';
49
+ const constructorName = constructor.name;
50
+ if (typeof constructorName === 'string' &&
51
+ constructorName.trim() !== '' &&
52
+ constructorName !== 'Object') {
53
+ return constructorName;
54
+ }
55
+ return 'UnknownError';
56
+ }
57
+ };
58
+ exports.WorkflowEndHandler = WorkflowEndHandler;
59
+ exports.WorkflowEndHandler = WorkflowEndHandler = __decorate([
60
+ (0, di_1.Service)()
61
+ ], WorkflowEndHandler);
62
+ function isRecord(value) {
63
+ return typeof value === 'object' && value !== null;
64
+ }
65
+ //# sourceMappingURL=workflow-end.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-end.handler.js","sourceRoot":"","sources":["../../../../src/modules/otel/handlers/workflow-end.handler.ts"],"names":[],"mappings":";;;;;;;;;AACA,gCAAkC;AAClC,4CAAoD;AAEpD,sDAAyC;AAKlC,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC9B,MAAM,CAAC,GAAgC,EAAE,KAAmB;QAC3D,MAAM,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACnD,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,MAAM,UAAU,GAAqC;YACpD,CAAC,qBAAI,CAAC,cAAc,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,IAAI;YACvC,CAAC,qBAAI,CAAC,gBAAgB,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM;YAC3C,CAAC,qBAAI,CAAC,kBAAkB,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,IAAI,KAAK,OAAO;SACvD,CAAC;QACF,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;YACjB,UAAU,CAAC,qBAAI,CAAC,kBAAkB,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC;QACnD,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAE/B,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YACvD,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,oBAAc,CAAC,KAAK,EAAE,CAAC,CAAC;YAE/C,MAAM,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;YAChD,IAAI,KAAK,EAAE,CAAC;gBACX,IAAI,CAAC,YAAY,CAAC,qBAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;YACxE,CAAC;QACF,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,oBAAc,CAAC,EAAE,EAAE,CAAC,CAAC;QAC7C,CAAC;QAED,IAAI,CAAC,GAAG,EAAE,CAAC;QACX,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IAChC,CAAC;IAEO,YAAY,CAAC,KAAc;QAClC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;YAAE,OAAO,cAAc,CAAC;QAE5C,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC;QAC7B,IAAI,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,CAAC,IAAI,EAAE,KAAK,EAAE;YAAE,OAAO,SAAS,CAAC;QAE/E,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACtC,IAAI,OAAO,WAAW,KAAK,UAAU;YAAE,OAAO,cAAc,CAAC;QAE7D,MAAM,eAAe,GAAG,WAAW,CAAC,IAAI,CAAC;QACzC,IACC,OAAO,eAAe,KAAK,QAAQ;YACnC,eAAe,CAAC,IAAI,EAAE,KAAK,EAAE;YAC7B,eAAe,KAAK,QAAQ,EAC3B,CAAC;YACF,OAAO,eAAe,CAAC;QACxB,CAAC;QAED,OAAO,cAAc,CAAC;IACvB,CAAC;CACD,CAAA;AAlDY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,YAAO,GAAE;GACG,kBAAkB,CAkD9B;AAED,SAAS,QAAQ,CAAC,KAAc;IAC/B,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,CAAC;AACpD,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { WorkflowExecuteBeforeContext } from '@n8n/decorators';
2
+ import type { Tracer } from '@opentelemetry/api';
3
+ import type { SpanHandler } from './interfaces';
4
+ import type { SpanRegistry } from '../span-registry';
5
+ export declare class WorkflowStartHandler implements SpanHandler<WorkflowExecuteBeforeContext> {
6
+ handle(ctx: WorkflowExecuteBeforeContext, spans: SpanRegistry, tracer: Tracer): void;
7
+ }
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.WorkflowStartHandler = void 0;
10
+ const di_1 = require("@n8n/di");
11
+ const otel_constants_1 = require("../otel.constants");
12
+ let WorkflowStartHandler = class WorkflowStartHandler {
13
+ handle(ctx, spans, tracer) {
14
+ const span = tracer.startSpan('workflow.execute', {
15
+ attributes: {
16
+ [otel_constants_1.ATTR.WORKFLOW_ID]: ctx.workflow.id,
17
+ [otel_constants_1.ATTR.WORKFLOW_NAME]: ctx.workflow.name,
18
+ [otel_constants_1.ATTR.WORKFLOW_NODE_COUNT]: ctx.workflow.nodes.length,
19
+ [otel_constants_1.ATTR.EXECUTION_ID]: ctx.executionId,
20
+ },
21
+ });
22
+ spans.addWorkflow(ctx.executionId, span);
23
+ }
24
+ };
25
+ exports.WorkflowStartHandler = WorkflowStartHandler;
26
+ exports.WorkflowStartHandler = WorkflowStartHandler = __decorate([
27
+ (0, di_1.Service)()
28
+ ], WorkflowStartHandler);
29
+ //# sourceMappingURL=workflow-start.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-start.handler.js","sourceRoot":"","sources":["../../../../src/modules/otel/handlers/workflow-start.handler.ts"],"names":[],"mappings":";;;;;;;;;AACA,gCAAkC;AAGlC,sDAAyC;AAKlC,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAChC,MAAM,CAAC,GAAiC,EAAE,KAAmB,EAAE,MAAc;QAC5E,MAAM,IAAI,GAAG,MAAM,CAAC,SAAS,CAAC,kBAAkB,EAAE;YACjD,UAAU,EAAE;gBACX,CAAC,qBAAI,CAAC,WAAW,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC,EAAE;gBACnC,CAAC,qBAAI,CAAC,aAAa,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC,IAAI;gBACvC,CAAC,qBAAI,CAAC,mBAAmB,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM;gBACrD,CAAC,qBAAI,CAAC,YAAY,CAAC,EAAE,GAAG,CAAC,WAAW;aACpC;SACD,CAAC,CAAC;QAEH,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;IAC1C,CAAC;CACD,CAAA;AAbY,oDAAoB;+BAApB,oBAAoB;IADhC,IAAA,YAAO,GAAE;GACG,oBAAoB,CAahC"}
@@ -0,0 +1,15 @@
1
+ import { Logger } from '@n8n/backend-common';
2
+ import type { WorkflowExecuteBeforeContext, WorkflowExecuteAfterContext } from '@n8n/decorators';
3
+ import { WorkflowEndHandler } from './handlers/workflow-end.handler';
4
+ import { WorkflowStartHandler } from './handlers/workflow-start.handler';
5
+ export declare class N8nInstrumentation {
6
+ private readonly logger;
7
+ private readonly spans;
8
+ private readonly tracer;
9
+ private readonly lifecycleDispatchers;
10
+ private readonly loggedFailureEvents;
11
+ constructor(workflowStartHandler: WorkflowStartHandler, workflowEndHandler: WorkflowEndHandler, logger: Logger);
12
+ onWorkflowStart(ctx: WorkflowExecuteBeforeContext): void;
13
+ onWorkflowEnd(ctx: WorkflowExecuteAfterContext): void;
14
+ private executeLifecycleHandler;
15
+ }
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.N8nInstrumentation = void 0;
13
+ const backend_common_1 = require("@n8n/backend-common");
14
+ const decorators_1 = require("@n8n/decorators");
15
+ const di_1 = require("@n8n/di");
16
+ const api_1 = require("@opentelemetry/api");
17
+ const workflow_end_handler_1 = require("./handlers/workflow-end.handler");
18
+ const workflow_start_handler_1 = require("./handlers/workflow-start.handler");
19
+ const span_registry_1 = require("./span-registry");
20
+ const TRACER_NAME = 'n8n-workflow';
21
+ let N8nInstrumentation = class N8nInstrumentation {
22
+ constructor(workflowStartHandler, workflowEndHandler, logger) {
23
+ this.logger = logger;
24
+ this.spans = new span_registry_1.SpanRegistry();
25
+ this.tracer = api_1.trace.getTracer(TRACER_NAME);
26
+ this.loggedFailureEvents = new Set();
27
+ this.lifecycleDispatchers = {
28
+ workflowExecuteBefore: (ctx) => workflowStartHandler.handle(ctx, this.spans, this.tracer),
29
+ workflowExecuteAfter: (ctx) => workflowEndHandler.handle(ctx, this.spans),
30
+ };
31
+ }
32
+ onWorkflowStart(ctx) {
33
+ this.executeLifecycleHandler('workflowExecuteBefore', ctx);
34
+ }
35
+ onWorkflowEnd(ctx) {
36
+ this.executeLifecycleHandler('workflowExecuteAfter', ctx);
37
+ }
38
+ executeLifecycleHandler(event, ctx) {
39
+ try {
40
+ this.lifecycleDispatchers[event](ctx);
41
+ }
42
+ catch (error) {
43
+ if (this.loggedFailureEvents.has(event))
44
+ return;
45
+ this.loggedFailureEvents.add(event);
46
+ this.logger.error('Failed to process OpenTelemetry span data', {
47
+ event,
48
+ error: error instanceof Error ? error.message : String(error),
49
+ });
50
+ }
51
+ }
52
+ };
53
+ exports.N8nInstrumentation = N8nInstrumentation;
54
+ __decorate([
55
+ (0, decorators_1.OnLifecycleEvent)('workflowExecuteBefore'),
56
+ __metadata("design:type", Function),
57
+ __metadata("design:paramtypes", [Object]),
58
+ __metadata("design:returntype", void 0)
59
+ ], N8nInstrumentation.prototype, "onWorkflowStart", null);
60
+ __decorate([
61
+ (0, decorators_1.OnLifecycleEvent)('workflowExecuteAfter'),
62
+ __metadata("design:type", Function),
63
+ __metadata("design:paramtypes", [Object]),
64
+ __metadata("design:returntype", void 0)
65
+ ], N8nInstrumentation.prototype, "onWorkflowEnd", null);
66
+ exports.N8nInstrumentation = N8nInstrumentation = __decorate([
67
+ (0, di_1.Service)(),
68
+ __metadata("design:paramtypes", [workflow_start_handler_1.WorkflowStartHandler,
69
+ workflow_end_handler_1.WorkflowEndHandler,
70
+ backend_common_1.Logger])
71
+ ], N8nInstrumentation);
72
+ //# sourceMappingURL=n8n-instrumentation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"n8n-instrumentation.js","sourceRoot":"","sources":["../../../src/modules/otel/n8n-instrumentation.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wDAA6C;AAC7C,gDAAmD;AAEnD,gCAAkC;AAClC,4CAA2C;AAE3C,0EAAqE;AACrE,8EAAyE;AACzE,mDAA+C;AAE/C,MAAM,WAAW,GAAG,cAAc,CAAC;AAU5B,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAM9B,YACC,oBAA0C,EAC1C,kBAAsC,EACrB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QARf,UAAK,GAAG,IAAI,4BAAY,EAAE,CAAC;QAC3B,WAAM,GAAG,WAAK,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAEtC,wBAAmB,GAAG,IAAI,GAAG,EAAkC,CAAC;QAOhF,IAAI,CAAC,oBAAoB,GAAG;YAC3B,qBAAqB,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,oBAAoB,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC;YACzF,oBAAoB,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC;SACzE,CAAC;IACH,CAAC;IAGD,eAAe,CAAC,GAAiC;QAChD,IAAI,CAAC,uBAAuB,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAC;IAC5D,CAAC;IAGD,aAAa,CAAC,GAAgC;QAC7C,IAAI,CAAC,uBAAuB,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC;IAC3D,CAAC;IAEO,uBAAuB,CAC9B,KAAQ,EACR,GAA6B;QAE7B,IAAI,CAAC;YACJ,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC;QACvC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC;gBAAE,OAAO;YAEhD,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACpC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,2CAA2C,EAAE;gBAC9D,KAAK;gBACL,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;aAC7D,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;CACD,CAAA;AA3CY,gDAAkB;AAkB9B;IADC,IAAA,6BAAgB,EAAC,uBAAuB,CAAC;;;;yDAGzC;AAGD;IADC,IAAA,6BAAgB,EAAC,sBAAsB,CAAC;;;;uDAGxC;6BAzBW,kBAAkB;IAD9B,IAAA,YAAO,GAAE;qCAQc,6CAAoB;QACtB,yCAAkB;QACb,uBAAM;GATpB,kBAAkB,CA2C9B"}
@@ -0,0 +1,9 @@
1
+ export declare class OtelConfig {
2
+ enabled: boolean;
3
+ exporterEndpoint: string;
4
+ exporterTracingPath: string;
5
+ exporterHeaders: string;
6
+ exporterServiceName: string;
7
+ tracesSampleRate: number;
8
+ startupConnectivityTimeoutMs: number;
9
+ }
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.OtelConfig = void 0;
13
+ const config_1 = require("@n8n/config");
14
+ let OtelConfig = class OtelConfig {
15
+ constructor() {
16
+ this.enabled = false;
17
+ this.exporterEndpoint = 'http://localhost:4318';
18
+ this.exporterTracingPath = '/v1/traces';
19
+ this.exporterHeaders = '';
20
+ this.exporterServiceName = 'n8n';
21
+ this.tracesSampleRate = 1.0;
22
+ this.startupConnectivityTimeoutMs = 2_000;
23
+ }
24
+ };
25
+ exports.OtelConfig = OtelConfig;
26
+ __decorate([
27
+ (0, config_1.Env)('N8N_OTEL_ENABLED'),
28
+ __metadata("design:type", Boolean)
29
+ ], OtelConfig.prototype, "enabled", void 0);
30
+ __decorate([
31
+ (0, config_1.Env)('N8N_OTEL_EXPORTER_OTLP_ENDPOINT'),
32
+ __metadata("design:type", String)
33
+ ], OtelConfig.prototype, "exporterEndpoint", void 0);
34
+ __decorate([
35
+ (0, config_1.Env)('N8N_OTEL_EXPORTER_OTLP_TRACING_PATH'),
36
+ __metadata("design:type", String)
37
+ ], OtelConfig.prototype, "exporterTracingPath", void 0);
38
+ __decorate([
39
+ (0, config_1.Env)('N8N_OTEL_EXPORTER_OTLP_HEADERS'),
40
+ __metadata("design:type", String)
41
+ ], OtelConfig.prototype, "exporterHeaders", void 0);
42
+ __decorate([
43
+ (0, config_1.Env)('N8N_OTEL_EXPORTER_SERVICE_NAME'),
44
+ __metadata("design:type", String)
45
+ ], OtelConfig.prototype, "exporterServiceName", void 0);
46
+ __decorate([
47
+ (0, config_1.Env)('N8N_OTEL_TRACES_SAMPLE_RATE'),
48
+ __metadata("design:type", Number)
49
+ ], OtelConfig.prototype, "tracesSampleRate", void 0);
50
+ __decorate([
51
+ (0, config_1.Env)('N8N_OTEL_STARTUP_CONNECTIVITY_TIMEOUT_MS'),
52
+ __metadata("design:type", Number)
53
+ ], OtelConfig.prototype, "startupConnectivityTimeoutMs", void 0);
54
+ exports.OtelConfig = OtelConfig = __decorate([
55
+ config_1.Config
56
+ ], OtelConfig);
57
+ //# sourceMappingURL=otel.config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"otel.config.js","sourceRoot":"","sources":["../../../src/modules/otel/otel.config.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wCAA0C;AAGnC,IAAM,UAAU,GAAhB,MAAM,UAAU;IAAhB;QAEN,YAAO,GAAY,KAAK,CAAC;QAGzB,qBAAgB,GAAW,uBAAuB,CAAC;QAGnD,wBAAmB,GAAW,YAAY,CAAC;QAG3C,oBAAe,GAAW,EAAE,CAAC;QAG7B,wBAAmB,GAAW,KAAK,CAAC;QAGpC,qBAAgB,GAAW,GAAG,CAAC;QAG/B,iCAA4B,GAAW,KAAK,CAAC;IAC9C,CAAC;CAAA,CAAA;AArBY,gCAAU;AAEtB;IADC,IAAA,YAAG,EAAC,kBAAkB,CAAC;;2CACC;AAGzB;IADC,IAAA,YAAG,EAAC,iCAAiC,CAAC;;oDACY;AAGnD;IADC,IAAA,YAAG,EAAC,qCAAqC,CAAC;;uDACA;AAG3C;IADC,IAAA,YAAG,EAAC,gCAAgC,CAAC;;mDACT;AAG7B;IADC,IAAA,YAAG,EAAC,gCAAgC,CAAC;;uDACF;AAGpC;IADC,IAAA,YAAG,EAAC,6BAA6B,CAAC;;oDACJ;AAG/B;IADC,IAAA,YAAG,EAAC,0CAA0C,CAAC;;gEACH;qBApBjC,UAAU;IADtB,eAAM;GACM,UAAU,CAqBtB"}
@@ -0,0 +1,15 @@
1
+ export declare const ATTR: {
2
+ readonly OTEL_SERVICE_NAME: "service.name";
3
+ readonly OTEL_SERVICE_VERSION: "service.version";
4
+ readonly INSTANCE_ID: "n8n.instance.id";
5
+ readonly INSTANCE_ROLE: "n8n.instance.role";
6
+ readonly WORKFLOW_ID: "n8n.workflow.id";
7
+ readonly WORKFLOW_NAME: "n8n.workflow.name";
8
+ readonly WORKFLOW_NODE_COUNT: "n8n.workflow.node_count";
9
+ readonly EXECUTION_ID: "n8n.execution.id";
10
+ readonly EXECUTION_MODE: "n8n.execution.mode";
11
+ readonly EXECUTION_STATUS: "n8n.execution.status";
12
+ readonly EXECUTION_IS_RETRY: "n8n.execution.is_retry";
13
+ readonly EXECUTION_RETRY_OF: "n8n.execution.retry_of";
14
+ readonly EXECUTION_ERROR_TYPE: "n8n.execution.error_type";
15
+ };
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ATTR = void 0;
4
+ const semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
5
+ exports.ATTR = {
6
+ OTEL_SERVICE_NAME: semantic_conventions_1.ATTR_SERVICE_NAME,
7
+ OTEL_SERVICE_VERSION: semantic_conventions_1.ATTR_SERVICE_VERSION,
8
+ INSTANCE_ID: 'n8n.instance.id',
9
+ INSTANCE_ROLE: 'n8n.instance.role',
10
+ WORKFLOW_ID: 'n8n.workflow.id',
11
+ WORKFLOW_NAME: 'n8n.workflow.name',
12
+ WORKFLOW_NODE_COUNT: 'n8n.workflow.node_count',
13
+ EXECUTION_ID: 'n8n.execution.id',
14
+ EXECUTION_MODE: 'n8n.execution.mode',
15
+ EXECUTION_STATUS: 'n8n.execution.status',
16
+ EXECUTION_IS_RETRY: 'n8n.execution.is_retry',
17
+ EXECUTION_RETRY_OF: 'n8n.execution.retry_of',
18
+ EXECUTION_ERROR_TYPE: 'n8n.execution.error_type',
19
+ };
20
+ //# sourceMappingURL=otel.constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"otel.constants.js","sourceRoot":"","sources":["../../../src/modules/otel/otel.constants.ts"],"names":[],"mappings":";;;AAAA,8EAA8F;AAEjF,QAAA,IAAI,GAAG;IACnB,iBAAiB,EAAE,wCAAiB;IACpC,oBAAoB,EAAE,2CAAoB;IAE1C,WAAW,EAAE,iBAAiB;IAC9B,aAAa,EAAE,mBAAmB;IAElC,WAAW,EAAE,iBAAiB;IAC9B,aAAa,EAAE,mBAAmB;IAClC,mBAAmB,EAAE,yBAAyB;IAE9C,YAAY,EAAE,kBAAkB;IAChC,cAAc,EAAE,oBAAoB;IACpC,gBAAgB,EAAE,sBAAsB;IACxC,kBAAkB,EAAE,wBAAwB;IAC5C,kBAAkB,EAAE,wBAAwB;IAC5C,oBAAoB,EAAE,0BAA0B;CACvC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { ModuleInterface } from '@n8n/decorators';
2
+ export declare class OtelModule implements ModuleInterface {
3
+ init(): Promise<void>;
4
+ shutdown(): Promise<void>;
5
+ }
@@ -0,0 +1,80 @@
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.OtelModule = void 0;
46
+ const decorators_1 = require("@n8n/decorators");
47
+ const di_1 = require("@n8n/di");
48
+ let OtelModule = class OtelModule {
49
+ async init() {
50
+ const { OtelConfig } = await Promise.resolve().then(() => __importStar(require('./otel.config')));
51
+ const config = di_1.Container.get(OtelConfig);
52
+ if (!config.enabled)
53
+ return;
54
+ const { OtelService } = await Promise.resolve().then(() => __importStar(require('./otel.service')));
55
+ di_1.Container.get(OtelService).init();
56
+ await Promise.resolve().then(() => __importStar(require('./n8n-instrumentation')));
57
+ }
58
+ async shutdown() {
59
+ const { OtelConfig } = await Promise.resolve().then(() => __importStar(require('./otel.config')));
60
+ const config = di_1.Container.get(OtelConfig);
61
+ if (!config.enabled)
62
+ return;
63
+ const { OtelService } = await Promise.resolve().then(() => __importStar(require('./otel.service')));
64
+ await di_1.Container.get(OtelService).shutdown();
65
+ }
66
+ };
67
+ exports.OtelModule = OtelModule;
68
+ __decorate([
69
+ (0, decorators_1.OnShutdown)(),
70
+ __metadata("design:type", Function),
71
+ __metadata("design:paramtypes", []),
72
+ __metadata("design:returntype", Promise)
73
+ ], OtelModule.prototype, "shutdown", null);
74
+ exports.OtelModule = OtelModule = __decorate([
75
+ (0, decorators_1.BackendModule)({
76
+ name: 'otel',
77
+ instanceTypes: ['main', 'worker', 'webhook'],
78
+ })
79
+ ], OtelModule);
80
+ //# sourceMappingURL=otel.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"otel.module.js","sourceRoot":"","sources":["../../../src/modules/otel/otel.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,gDAA4D;AAC5D,gCAAoC;AAM7B,IAAM,UAAU,GAAhB,MAAM,UAAU;IACtB,KAAK,CAAC,IAAI;QACT,MAAM,EAAE,UAAU,EAAE,GAAG,wDAAa,eAAe,GAAC,CAAC;QACrD,MAAM,MAAM,GAAG,cAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACzC,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,OAAO;QAE5B,MAAM,EAAE,WAAW,EAAE,GAAG,wDAAa,gBAAgB,GAAC,CAAC;QACvD,cAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,CAAC;QAGlC,wDAAa,uBAAuB,GAAC,CAAC;IACvC,CAAC;IAGK,AAAN,KAAK,CAAC,QAAQ;QACb,MAAM,EAAE,UAAU,EAAE,GAAG,wDAAa,eAAe,GAAC,CAAC;QACrD,MAAM,MAAM,GAAG,cAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACzC,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,OAAO;QAE5B,MAAM,EAAE,WAAW,EAAE,GAAG,wDAAa,gBAAgB,GAAC,CAAC;QACvD,MAAM,cAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC7C,CAAC;CACD,CAAA;AAtBY,gCAAU;AAchB;IADL,IAAA,uBAAU,GAAE;;;;0CAQZ;qBArBW,UAAU;IAJtB,IAAA,0BAAa,EAAC;QACd,IAAI,EAAE,MAAM;QACZ,aAAa,EAAE,CAAC,MAAM,EAAE,QAAQ,EAAE,SAAS,CAAC;KAC5C,CAAC;GACW,UAAU,CAsBtB"}
@@ -0,0 +1,18 @@
1
+ import { Logger } from '@n8n/backend-common';
2
+ import { InstanceSettings } from 'n8n-core';
3
+ import { OtelConfig } from './otel.config';
4
+ export declare class OtelService {
5
+ private readonly config;
6
+ private readonly instanceSettings;
7
+ private readonly logger;
8
+ private static isDiagnosticsLoggerConfigured;
9
+ private sdk?;
10
+ private hasLoggedStartupConnectivityFailure;
11
+ constructor(config: OtelConfig, instanceSettings: InstanceSettings, logger: Logger);
12
+ init(): void;
13
+ shutdown(): Promise<void>;
14
+ private configureDiagnosticsLogger;
15
+ private parseOtlpHeaders;
16
+ private buildOtlpTracesUrl;
17
+ private checkEndpointReachability;
18
+ }
@@ -0,0 +1,123 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ 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;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var OtelService_1;
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.OtelService = void 0;
14
+ const backend_common_1 = require("@n8n/backend-common");
15
+ const di_1 = require("@n8n/di");
16
+ const api_1 = require("@opentelemetry/api");
17
+ const exporter_trace_otlp_proto_1 = require("@opentelemetry/exporter-trace-otlp-proto");
18
+ const resources_1 = require("@opentelemetry/resources");
19
+ const sdk_node_1 = require("@opentelemetry/sdk-node");
20
+ const sdk_trace_node_1 = require("@opentelemetry/sdk-trace-node");
21
+ const n8n_core_1 = require("n8n-core");
22
+ const constants_1 = require("../../constants");
23
+ const otel_config_1 = require("./otel.config");
24
+ const otel_constants_1 = require("./otel.constants");
25
+ let OtelService = OtelService_1 = class OtelService {
26
+ constructor(config, instanceSettings, logger) {
27
+ this.config = config;
28
+ this.instanceSettings = instanceSettings;
29
+ this.logger = logger;
30
+ this.hasLoggedStartupConnectivityFailure = false;
31
+ }
32
+ init() {
33
+ if (!this.config.enabled)
34
+ return;
35
+ this.configureDiagnosticsLogger();
36
+ const otlpTracesUrl = this.buildOtlpTracesUrl();
37
+ const otlpHeaders = this.parseOtlpHeaders();
38
+ this.sdk = new sdk_node_1.NodeSDK({
39
+ resource: (0, resources_1.resourceFromAttributes)({
40
+ [otel_constants_1.ATTR.OTEL_SERVICE_NAME]: this.config.exporterServiceName,
41
+ [otel_constants_1.ATTR.OTEL_SERVICE_VERSION]: constants_1.N8N_VERSION,
42
+ [otel_constants_1.ATTR.INSTANCE_ID]: this.instanceSettings.instanceId,
43
+ [otel_constants_1.ATTR.INSTANCE_ROLE]: this.instanceSettings.instanceType,
44
+ }),
45
+ traceExporter: new exporter_trace_otlp_proto_1.OTLPTraceExporter({
46
+ url: otlpTracesUrl,
47
+ headers: otlpHeaders,
48
+ }),
49
+ sampler: new sdk_trace_node_1.TraceIdRatioBasedSampler(this.config.tracesSampleRate),
50
+ });
51
+ this.sdk.start();
52
+ void this.checkEndpointReachability(otlpTracesUrl);
53
+ }
54
+ async shutdown() {
55
+ await this.sdk?.shutdown();
56
+ }
57
+ configureDiagnosticsLogger() {
58
+ if (OtelService_1.isDiagnosticsLoggerConfigured)
59
+ return;
60
+ const diagnosticsLogger = {
61
+ error: (...args) => this.logger.error('OpenTelemetry diagnostics error', { args }),
62
+ warn: (...args) => this.logger.warn('OpenTelemetry diagnostics warning', { args }),
63
+ info: (...args) => this.logger.info('OpenTelemetry diagnostics info', { args }),
64
+ debug: (...args) => this.logger.debug('OpenTelemetry diagnostics debug', { args }),
65
+ verbose: (...args) => this.logger.debug('OpenTelemetry diagnostics verbose', { args }),
66
+ };
67
+ api_1.diag.setLogger(diagnosticsLogger, api_1.DiagLogLevel.WARN);
68
+ OtelService_1.isDiagnosticsLoggerConfigured = true;
69
+ }
70
+ parseOtlpHeaders() {
71
+ const exporterHeaders = this.config.exporterHeaders;
72
+ const headers = {};
73
+ for (const pair of exporterHeaders.split(',')) {
74
+ const trimmedPair = pair.trim();
75
+ if (!trimmedPair)
76
+ continue;
77
+ if (!trimmedPair.includes('=')) {
78
+ this.logger.warn(`Skipping invalid OTEL exporter header "${trimmedPair}": missing "=" separator. Expected format: "key=value".`);
79
+ continue;
80
+ }
81
+ const [key, ...rest] = trimmedPair.split('=');
82
+ const trimmedKey = key.trim();
83
+ if (!trimmedKey) {
84
+ this.logger.warn(`Skipping invalid OTEL exporter header "${trimmedPair}": empty key. Expected format: "key=value".`);
85
+ continue;
86
+ }
87
+ headers[trimmedKey] = rest.join('=').trim();
88
+ }
89
+ return headers;
90
+ }
91
+ buildOtlpTracesUrl() {
92
+ const exporterEndpoint = this.config.exporterEndpoint;
93
+ const exporterTracingPath = this.config.exporterTracingPath;
94
+ const exporterEndpointWithoutTrailingSlash = exporterEndpoint.replace(/\/+$/, '');
95
+ return `${exporterEndpointWithoutTrailingSlash}${exporterTracingPath}`;
96
+ }
97
+ async checkEndpointReachability(url) {
98
+ try {
99
+ await fetch(url, {
100
+ method: 'HEAD',
101
+ signal: AbortSignal.timeout(this.config.startupConnectivityTimeoutMs),
102
+ });
103
+ }
104
+ catch (error) {
105
+ if (this.hasLoggedStartupConnectivityFailure)
106
+ return;
107
+ this.hasLoggedStartupConnectivityFailure = true;
108
+ this.logger.error('Failed to connect to OpenTelemetry OTLP endpoint during startup', {
109
+ endpoint: url,
110
+ error: error instanceof Error ? error.message : String(error),
111
+ });
112
+ }
113
+ }
114
+ };
115
+ exports.OtelService = OtelService;
116
+ OtelService.isDiagnosticsLoggerConfigured = false;
117
+ exports.OtelService = OtelService = OtelService_1 = __decorate([
118
+ (0, di_1.Service)(),
119
+ __metadata("design:paramtypes", [otel_config_1.OtelConfig,
120
+ n8n_core_1.InstanceSettings,
121
+ backend_common_1.Logger])
122
+ ], OtelService);
123
+ //# sourceMappingURL=otel.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"otel.service.js","sourceRoot":"","sources":["../../../src/modules/otel/otel.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { Span } from '@opentelemetry/api';
2
+ export declare class SpanRegistry {
3
+ private spans;
4
+ static workflowKey(executionId: string): string;
5
+ static nodeKey(executionId: string, nodeId: string): string;
6
+ addWorkflow(executionId: string, span: Span): void;
7
+ getWorkflow(executionId: string): Span | undefined;
8
+ removeWorkflow(executionId: string): Span | undefined;
9
+ addNode(executionId: string, nodeId: string, span: Span): void;
10
+ getNode(executionId: string, nodeId: string): Span | undefined;
11
+ removeNode(executionId: string, nodeId: string): Span | undefined;
12
+ cleanup(executionId: string): void;
13
+ }
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SpanRegistry = void 0;
4
+ class SpanRegistry {
5
+ constructor() {
6
+ this.spans = new Map();
7
+ }
8
+ static workflowKey(executionId) {
9
+ return executionId;
10
+ }
11
+ static nodeKey(executionId, nodeId) {
12
+ return `${executionId}:${nodeId}`;
13
+ }
14
+ addWorkflow(executionId, span) {
15
+ this.spans.set(SpanRegistry.workflowKey(executionId), span);
16
+ }
17
+ getWorkflow(executionId) {
18
+ return this.spans.get(SpanRegistry.workflowKey(executionId));
19
+ }
20
+ removeWorkflow(executionId) {
21
+ const key = SpanRegistry.workflowKey(executionId);
22
+ const span = this.spans.get(key);
23
+ this.spans.delete(key);
24
+ return span;
25
+ }
26
+ addNode(executionId, nodeId, span) {
27
+ this.spans.set(SpanRegistry.nodeKey(executionId, nodeId), span);
28
+ }
29
+ getNode(executionId, nodeId) {
30
+ return this.spans.get(SpanRegistry.nodeKey(executionId, nodeId));
31
+ }
32
+ removeNode(executionId, nodeId) {
33
+ const key = SpanRegistry.nodeKey(executionId, nodeId);
34
+ const span = this.spans.get(key);
35
+ this.spans.delete(key);
36
+ return span;
37
+ }
38
+ cleanup(executionId) {
39
+ for (const key of this.spans.keys()) {
40
+ if (key === executionId || key.startsWith(`${executionId}:`)) {
41
+ this.spans.delete(key);
42
+ }
43
+ }
44
+ }
45
+ }
46
+ exports.SpanRegistry = SpanRegistry;
47
+ //# sourceMappingURL=span-registry.js.map