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.
- package/dist/abstract-server.js +1 -1
- package/dist/abstract-server.js.map +1 -1
- package/dist/build.tsbuildinfo +1 -1
- package/dist/commands/base-command.d.ts +1 -0
- package/dist/commands/base-command.js +8 -6
- package/dist/commands/base-command.js.map +1 -1
- package/dist/commands/execute-batch.js +2 -0
- package/dist/commands/execute-batch.js.map +1 -1
- package/dist/commands/execute.js +2 -0
- package/dist/commands/execute.js.map +1 -1
- package/dist/commands/start.js +1 -0
- package/dist/commands/start.js.map +1 -1
- package/dist/commands/webhook.js +1 -0
- package/dist/commands/webhook.js.map +1 -1
- package/dist/commands/worker.js +1 -0
- package/dist/commands/worker.js.map +1 -1
- package/dist/constants.js +1 -0
- package/dist/constants.js.map +1 -1
- package/dist/controllers/ai.controller.js +1 -1
- package/dist/controllers/ai.controller.js.map +1 -1
- package/dist/controllers/binary-data.controller.js +1 -1
- package/dist/controllers/binary-data.controller.js.map +1 -1
- package/dist/controllers/me.controller.d.ts +3 -1
- package/dist/controllers/me.controller.js +6 -3
- package/dist/controllers/me.controller.js.map +1 -1
- package/dist/controllers/project.controller.d.ts +2 -0
- package/dist/credentials/credentials.service.js +1 -1
- package/dist/credentials/credentials.service.js.map +1 -1
- package/dist/execution-lifecycle/execution-lifecycle-hooks.js +9 -8
- package/dist/execution-lifecycle/execution-lifecycle-hooks.js.map +1 -1
- package/dist/executions/execution-persistence.d.ts +4 -1
- package/dist/executions/execution-persistence.js +16 -2
- package/dist/executions/execution-persistence.js.map +1 -1
- package/dist/executions/executions.controller.d.ts +3 -5
- package/dist/executions/executions.controller.js +17 -9
- package/dist/executions/executions.controller.js.map +1 -1
- package/dist/modules/community-packages/community-packages.controller.d.ts +6 -19
- package/dist/modules/community-packages/community-packages.controller.js +8 -231
- package/dist/modules/community-packages/community-packages.controller.js.map +1 -1
- package/dist/modules/community-packages/community-packages.lifecycle.service.d.ts +32 -0
- package/dist/modules/community-packages/community-packages.lifecycle.service.js +282 -0
- package/dist/modules/community-packages/community-packages.lifecycle.service.js.map +1 -0
- package/dist/modules/community-packages/community-packages.service.js +8 -8
- package/dist/modules/community-packages/community-packages.service.js.map +1 -1
- package/dist/modules/community-packages/npm-utils.d.ts +4 -0
- package/dist/modules/community-packages/npm-utils.js +4 -0
- package/dist/modules/community-packages/npm-utils.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.d.ts +1 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js +1 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/slack-signature-extractor.d.ts +11 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/slack-signature-extractor.js +88 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/slack-signature-extractor.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/slack-signature-identifier.d.ts +28 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/slack-signature-identifier.js +158 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/slack-signature-identifier.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.d.ts +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.d.ts +50 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.js +118 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.js.map +1 -0
- package/dist/modules/instance-registry/storage/memory-storage.d.ts +15 -0
- package/dist/modules/instance-registry/storage/memory-storage.js +41 -0
- package/dist/modules/instance-registry/storage/memory-storage.js.map +1 -0
- package/dist/modules/mcp/mcp-oauth-service.d.ts +1 -1
- package/dist/modules/mcp/mcp-oauth-service.js +5 -1
- package/dist/modules/mcp/mcp-oauth-service.js.map +1 -1
- package/dist/modules/mcp/mcp.errors.js +1 -1
- package/dist/modules/mcp/mcp.oauth-clients.controller.js +1 -1
- package/dist/modules/mcp/mcp.oauth-clients.controller.js.map +1 -1
- package/dist/modules/mcp/mcp.service.d.ts +3 -1
- package/dist/modules/mcp/mcp.service.js +13 -4
- package/dist/modules/mcp/mcp.service.js.map +1 -1
- package/dist/modules/mcp/mcp.types.d.ts +1 -1
- package/dist/modules/mcp/tools/execute-workflow.tool.js +8 -44
- package/dist/modules/mcp/tools/execute-workflow.tool.js.map +1 -1
- package/dist/modules/mcp/tools/execution-utils.d.ts +5 -0
- package/dist/modules/mcp/tools/execution-utils.js +45 -0
- package/dist/modules/mcp/tools/execution-utils.js.map +1 -0
- package/dist/modules/mcp/tools/prepare-workflow-pin-data.tool.d.ts +31 -0
- package/dist/modules/mcp/tools/prepare-workflow-pin-data.tool.js +165 -0
- package/dist/modules/mcp/tools/prepare-workflow-pin-data.tool.js.map +1 -0
- package/dist/modules/mcp/tools/test-workflow.tool.d.ts +31 -0
- package/dist/modules/mcp/tools/test-workflow.tool.js +178 -0
- package/dist/modules/mcp/tools/test-workflow.tool.js.map +1 -0
- package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js +1 -0
- package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/credentials-auto-assign.d.ts +2 -1
- package/dist/modules/mcp/tools/workflow-builder/credentials-auto-assign.js +15 -0
- package/dist/modules/mcp/tools/workflow-builder/credentials-auto-assign.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js +1 -0
- package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js.map +1 -1
- package/dist/modules/otel/handlers/interfaces.d.ts +5 -0
- package/dist/modules/otel/handlers/interfaces.js +3 -0
- package/dist/modules/otel/handlers/interfaces.js.map +1 -0
- package/dist/modules/otel/handlers/workflow-end.handler.d.ts +7 -0
- package/dist/modules/otel/handlers/workflow-end.handler.js +65 -0
- package/dist/modules/otel/handlers/workflow-end.handler.js.map +1 -0
- package/dist/modules/otel/handlers/workflow-start.handler.d.ts +7 -0
- package/dist/modules/otel/handlers/workflow-start.handler.js +29 -0
- package/dist/modules/otel/handlers/workflow-start.handler.js.map +1 -0
- package/dist/modules/otel/n8n-instrumentation.d.ts +15 -0
- package/dist/modules/otel/n8n-instrumentation.js +72 -0
- package/dist/modules/otel/n8n-instrumentation.js.map +1 -0
- package/dist/modules/otel/otel.config.d.ts +9 -0
- package/dist/modules/otel/otel.config.js +57 -0
- package/dist/modules/otel/otel.config.js.map +1 -0
- package/dist/modules/otel/otel.constants.d.ts +15 -0
- package/dist/modules/otel/otel.constants.js +20 -0
- package/dist/modules/otel/otel.constants.js.map +1 -0
- package/dist/modules/otel/otel.module.d.ts +5 -0
- package/dist/modules/otel/otel.module.js +80 -0
- package/dist/modules/otel/otel.module.js.map +1 -0
- package/dist/modules/otel/otel.service.d.ts +18 -0
- package/dist/modules/otel/otel.service.js +123 -0
- package/dist/modules/otel/otel.service.js.map +1 -0
- package/dist/modules/otel/span-registry.d.ts +13 -0
- package/dist/modules/otel/span-registry.js +47 -0
- package/dist/modules/otel/span-registry.js.map +1 -0
- package/dist/modules/provisioning.ee/provisioning.module.js +1 -0
- package/dist/modules/provisioning.ee/provisioning.module.js.map +1 -1
- package/dist/modules/provisioning.ee/role-mapping-rule.controller.ee.d.ts +18 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.controller.ee.js +105 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.controller.ee.js.map +1 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.d.ts +34 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js +221 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js.map +1 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.validation.d.ts +3 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.validation.js +29 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.validation.js.map +1 -0
- package/dist/modules/source-control.ee/source-control-import.service.ee.js +6 -0
- package/dist/modules/source-control.ee/source-control-import.service.ee.js.map +1 -1
- package/dist/modules/source-control.ee/types/source-control-preferences.js +3 -0
- package/dist/modules/source-control.ee/types/source-control-preferences.js.map +1 -1
- package/dist/modules/workflow-builder/workflow-builder-session.entity.d.ts +4 -0
- package/dist/modules/workflow-builder/workflow-builder-session.entity.js +8 -0
- package/dist/modules/workflow-builder/workflow-builder-session.entity.js.map +1 -1
- package/dist/modules/workflow-builder/workflow-builder-session.repository.js +14 -2
- package/dist/modules/workflow-builder/workflow-builder-session.repository.js.map +1 -1
- package/dist/modules/workflow-index/workflow-dependency-query.service.js +26 -3
- package/dist/modules/workflow-index/workflow-dependency-query.service.js.map +1 -1
- package/dist/modules/workflow-index/workflow-index.service.d.ts +1 -0
- package/dist/modules/workflow-index/workflow-index.service.js +15 -3
- package/dist/modules/workflow-index/workflow-index.service.js.map +1 -1
- package/dist/posthog/index.d.ts +1 -0
- package/dist/posthog/index.js +32 -8
- package/dist/posthog/index.js.map +1 -1
- package/dist/public-api/v1/handlers/credentials/credentials.handler.js +6 -5
- package/dist/public-api/v1/handlers/credentials/credentials.handler.js.map +1 -1
- package/dist/public-api/v1/handlers/credentials/credentials.service.d.ts +2 -2
- package/dist/public-api/v1/handlers/credentials/credentials.service.js +3 -6
- package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
- package/dist/public-api/v1/handlers/workflows/workflows.handler.d.ts +8 -0
- package/dist/public-api/v1/handlers/workflows/workflows.handler.js +44 -0
- package/dist/public-api/v1/handlers/workflows/workflows.handler.js.map +1 -1
- package/dist/public-api/v1/openapi.yml +54 -1
- package/dist/scaling/job-processor.js +3 -0
- package/dist/scaling/job-processor.js.map +1 -1
- package/dist/scaling/scaling.service.js +1 -2
- package/dist/scaling/scaling.service.js.map +1 -1
- package/dist/scaling/worker-server.js +1 -1
- package/dist/scaling/worker-server.js.map +1 -1
- package/dist/services/ai-workflow-builder.service.d.ts +1 -1
- package/dist/services/ai-workflow-builder.service.js +3 -6
- package/dist/services/ai-workflow-builder.service.js.map +1 -1
- package/dist/services/frontend.service.js +2 -1
- package/dist/services/frontend.service.js.map +1 -1
- package/dist/utils/health-endpoint.util.d.ts +2 -1
- package/dist/utils/health-endpoint.util.js +11 -3
- package/dist/utils/health-endpoint.util.js.map +1 -1
- package/dist/webhooks/waiting-forms.js +3 -1
- package/dist/webhooks/waiting-forms.js.map +1 -1
- package/dist/webhooks/webhook-request-handler.js +1 -1
- package/dist/webhooks/webhook-request-handler.js.map +1 -1
- package/dist/workflows/workflow.service.d.ts +6 -1
- package/dist/workflows/workflow.service.js +22 -6
- package/dist/workflows/workflow.service.js.map +1 -1
- 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,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,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
|