n8n 2.26.3 → 2.27.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/active-workflow-manager.d.ts +9 -17
- package/dist/active-workflow-manager.js +48 -159
- package/dist/active-workflow-manager.js.map +1 -1
- package/dist/binary-data/database.manager.js +2 -1
- package/dist/binary-data/database.manager.js.map +1 -1
- package/dist/build.tsbuildinfo +1 -1
- package/dist/commands/audit.d.ts +1 -0
- package/dist/commands/audit.js +9 -0
- package/dist/commands/audit.js.map +1 -1
- package/dist/commands/base-command.d.ts +1 -0
- package/dist/commands/base-command.js +31 -10
- package/dist/commands/base-command.js.map +1 -1
- package/dist/commands/export/workflow.js +9 -0
- package/dist/commands/export/workflow.js.map +1 -1
- package/dist/commands/import/workflow.js +6 -0
- package/dist/commands/import/workflow.js.map +1 -1
- package/dist/commands/start.js +7 -3
- package/dist/commands/start.js.map +1 -1
- package/dist/commands/worker.js +6 -3
- package/dist/commands/worker.js.map +1 -1
- package/dist/concurrency/concurrency-queue.d.ts +1 -1
- package/dist/concurrency/concurrency-queue.js +2 -2
- package/dist/concurrency/concurrency-queue.js.map +1 -1
- package/dist/controllers/api-keys.controller.js +6 -2
- package/dist/controllers/api-keys.controller.js.map +1 -1
- package/dist/controllers/e2e.controller.js +1 -1
- package/dist/controllers/e2e.controller.js.map +1 -1
- package/dist/controllers/oauth/oauth2-credential.controller.js +7 -0
- package/dist/controllers/oauth/oauth2-credential.controller.js.map +1 -1
- package/dist/controllers/security-settings.controller.d.ts +3 -3
- package/dist/controllers/security-settings.controller.js +3 -8
- package/dist/controllers/security-settings.controller.js.map +1 -1
- package/dist/credentials-helper.js +3 -0
- package/dist/credentials-helper.js.map +1 -1
- package/dist/errors/http-error-serializers.js +2 -15
- package/dist/errors/http-error-serializers.js.map +1 -1
- package/dist/errors/response-errors/bad-request.error.d.ts +1 -1
- package/dist/errors/response-errors/bad-request.error.js +2 -2
- package/dist/errors/response-errors/bad-request.error.js.map +1 -1
- package/dist/errors/response-errors/unprocessable.error.d.ts +2 -1
- package/dist/errors/response-errors/unprocessable.error.js +2 -1
- package/dist/errors/response-errors/unprocessable.error.js.map +1 -1
- package/dist/events/event.service.d.ts +1 -1
- package/dist/events/event.service.js +2 -2
- package/dist/events/event.service.js.map +1 -1
- package/dist/events/maps/execution-data.event-map.d.ts +1 -0
- package/dist/events/maps/relay.event-map.d.ts +13 -0
- package/dist/events/relays/log-streaming.event-relay.js +2 -2
- package/dist/events/relays/log-streaming.event-relay.js.map +1 -1
- package/dist/events/relays/telemetry.event-relay.d.ts +2 -0
- package/dist/events/relays/telemetry.event-relay.js +21 -2
- package/dist/events/relays/telemetry.event-relay.js.map +1 -1
- package/dist/executions/execution-data/db-store.d.ts +3 -1
- package/dist/executions/execution-data/db-store.js +14 -0
- package/dist/executions/execution-data/db-store.js.map +1 -1
- package/dist/executions/execution-data/fs-store.d.ts +1 -1
- package/dist/executions/execution-data/fs-store.js +3 -1
- package/dist/executions/execution-data/fs-store.js.map +1 -1
- package/dist/executions/execution-data/s3-store.ee.d.ts +15 -0
- package/dist/executions/execution-data/s3-store.ee.js +115 -0
- package/dist/executions/execution-data/s3-store.ee.js.map +1 -0
- package/dist/executions/execution-data/types.d.ts +1 -1
- package/dist/executions/execution-persistence.d.ts +16 -2
- package/dist/executions/execution-persistence.js +80 -22
- package/dist/executions/execution-persistence.js.map +1 -1
- package/dist/metrics/prometheus/active-workflow-metrics.service.d.ts +12 -0
- package/dist/metrics/prometheus/active-workflow-metrics.service.js +61 -0
- package/dist/metrics/prometheus/active-workflow-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/base.d.ts +5 -0
- package/dist/metrics/{types.js → prometheus/base.js} +1 -1
- package/dist/metrics/prometheus/base.js.map +1 -0
- package/dist/metrics/prometheus/cache-metrics.service.d.ts +11 -0
- package/dist/metrics/prometheus/cache-metrics.service.js +48 -0
- package/dist/metrics/prometheus/cache-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/constant.d.ts +2 -0
- package/dist/metrics/prometheus/constant.js +18 -0
- package/dist/metrics/prometheus/constant.js.map +1 -0
- package/dist/metrics/prometheus/default-metrics.service.d.ts +8 -0
- package/dist/metrics/prometheus/default-metrics.service.js +35 -0
- package/dist/metrics/prometheus/default-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/dns-cache-metrics.service.d.ts +12 -0
- package/dist/metrics/prometheus/dns-cache-metrics.service.js +58 -0
- package/dist/metrics/prometheus/dns-cache-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/event-bus-metrics.service.d.ts +15 -0
- package/dist/metrics/prometheus/event-bus-metrics.service.js +106 -0
- package/dist/metrics/prometheus/event-bus-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/execution-data-metrics.service.d.ts +12 -0
- package/dist/metrics/prometheus/execution-data-metrics.service.js +106 -0
- package/dist/metrics/prometheus/execution-data-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/index.d.ts +1 -0
- package/dist/metrics/prometheus/index.js +6 -0
- package/dist/metrics/prometheus/index.js.map +1 -0
- package/dist/metrics/prometheus/instance-role-metrics.service.d.ts +13 -0
- package/dist/metrics/prometheus/instance-role-metrics.service.js +61 -0
- package/dist/metrics/prometheus/instance-role-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/prometheus.service.d.ts +26 -0
- package/dist/metrics/prometheus/prometheus.service.js +105 -0
- package/dist/metrics/prometheus/prometheus.service.js.map +1 -0
- package/dist/metrics/prometheus/pss-metrics.service.d.ts +9 -0
- package/dist/metrics/prometheus/pss-metrics.service.js +59 -0
- package/dist/metrics/prometheus/pss-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/queue-metrics.service.d.ts +13 -0
- package/dist/metrics/prometheus/queue-metrics.service.js +71 -0
- package/dist/metrics/prometheus/queue-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/route-metrics.service.d.ts +11 -0
- package/dist/metrics/prometheus/route-metrics.service.js +69 -0
- package/dist/metrics/prometheus/route-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/ssrf-metrics.service.d.ts +11 -0
- package/dist/metrics/prometheus/ssrf-metrics.service.js +65 -0
- package/dist/metrics/prometheus/ssrf-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/token-exchange-metrics.service.d.ts +10 -0
- package/dist/metrics/prometheus/token-exchange-metrics.service.js +91 -0
- package/dist/metrics/prometheus/token-exchange-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/version-metrics.service.d.ts +8 -0
- package/dist/metrics/prometheus/version-metrics.service.js +46 -0
- package/dist/metrics/prometheus/version-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.d.ts +10 -0
- package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.js +61 -0
- package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.js.map +1 -0
- package/dist/metrics/prometheus/workflow-statistics-metrics.service.d.ts +17 -0
- package/dist/metrics/prometheus/workflow-statistics-metrics.service.js +130 -0
- package/dist/metrics/prometheus/workflow-statistics-metrics.service.js.map +1 -0
- package/dist/modules/agents/agent-knowledge.service.d.ts +3 -32
- package/dist/modules/agents/agent-knowledge.service.js +7 -248
- package/dist/modules/agents/agent-knowledge.service.js.map +1 -1
- package/dist/modules/agents/agent-runtime-reconstruction.service.d.ts +1 -6
- package/dist/modules/agents/agent-runtime-reconstruction.service.js +2 -28
- package/dist/modules/agents/agent-runtime-reconstruction.service.js.map +1 -1
- package/dist/modules/agents/agents-list.controller.d.ts +9 -0
- package/dist/modules/agents/agents-list.controller.js +39 -0
- package/dist/modules/agents/agents-list.controller.js.map +1 -0
- package/dist/modules/agents/agents.controller.d.ts +6 -6
- package/dist/modules/agents/agents.controller.js +12 -19
- package/dist/modules/agents/agents.controller.js.map +1 -1
- package/dist/modules/agents/agents.module.d.ts +3 -2
- package/dist/modules/agents/agents.module.js +4 -2
- package/dist/modules/agents/agents.module.js.map +1 -1
- package/dist/modules/agents/agents.service.d.ts +10 -2
- package/dist/modules/agents/agents.service.js +119 -82
- package/dist/modules/agents/agents.service.js.map +1 -1
- package/dist/modules/agents/entities/agent-chat-subscription.entity.d.ts +10 -0
- package/dist/modules/agents/entities/{agent-file.entity.js → agent-chat-subscription.entity.js} +34 -23
- package/dist/modules/agents/entities/agent-chat-subscription.entity.js.map +1 -0
- package/dist/modules/agents/execution-recorder.js +15 -2
- package/dist/modules/agents/execution-recorder.js.map +1 -1
- package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.d.ts +43 -0
- package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.js +139 -0
- package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.js.map +1 -0
- package/dist/modules/agents/integrations/agent-chat-subscription-state.service.d.ts +26 -0
- package/dist/modules/agents/integrations/agent-chat-subscription-state.service.js +88 -0
- package/dist/modules/agents/integrations/agent-chat-subscription-state.service.js.map +1 -0
- package/dist/modules/agents/integrations/chat-integration.service.d.ts +3 -1
- package/dist/modules/agents/integrations/chat-integration.service.js +47 -18
- package/dist/modules/agents/integrations/chat-integration.service.js.map +1 -1
- package/dist/modules/agents/integrations/component-mapper.js.map +1 -1
- package/dist/modules/agents/integrations/slack-app-setup.service.js +8 -8
- package/dist/modules/agents/integrations/slack-app-setup.service.js.map +1 -1
- package/dist/modules/agents/repositories/agent-chat-subscription.repository.d.ts +15 -0
- package/dist/modules/agents/repositories/agent-chat-subscription.repository.js +51 -0
- package/dist/modules/agents/repositories/agent-chat-subscription.repository.js.map +1 -0
- package/dist/modules/agents/repositories/agent.repository.d.ts +7 -0
- package/dist/modules/agents/repositories/agent.repository.js +28 -0
- package/dist/modules/agents/repositories/agent.repository.js.map +1 -1
- package/dist/modules/data-table/data-table.repository.js +1 -1
- package/dist/modules/data-table/data-table.repository.js.map +1 -1
- package/dist/modules/data-table/utils/sql-utils.js +16 -1
- package/dist/modules/data-table/utils/sql-utils.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js +15 -7
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js.map +1 -1
- package/dist/modules/instance-ai/eval/execution.service.js +51 -32
- package/dist/modules/instance-ai/eval/execution.service.js.map +1 -1
- package/dist/modules/instance-ai/eval/mock-handler.js +77 -13
- package/dist/modules/instance-ai/eval/mock-handler.js.map +1 -1
- package/dist/modules/instance-ai/eval/mock-quirks.js +8 -1
- package/dist/modules/instance-ai/eval/mock-quirks.js.map +1 -1
- package/dist/modules/instance-ai/eval/workflow-analysis.js +2 -0
- package/dist/modules/instance-ai/eval/workflow-analysis.js.map +1 -1
- package/dist/modules/instance-ai/instance-ai.adapter.service.d.ts +5 -4
- package/dist/modules/instance-ai/instance-ai.adapter.service.js +7 -121
- package/dist/modules/instance-ai/instance-ai.adapter.service.js.map +1 -1
- package/dist/modules/instance-ai/instance-ai.controller.js +1 -1
- package/dist/modules/instance-ai/instance-ai.service.d.ts +5 -28
- package/dist/modules/instance-ai/instance-ai.service.js +58 -471
- package/dist/modules/instance-ai/instance-ai.service.js.map +1 -1
- package/dist/modules/instance-ai/output-redaction-config.d.ts +3 -0
- package/dist/modules/instance-ai/output-redaction-config.js +19 -0
- package/dist/modules/instance-ai/output-redaction-config.js.map +1 -0
- package/dist/modules/instance-ai/sandbox/index.d.ts +1 -0
- package/dist/modules/instance-ai/sandbox/index.js +6 -0
- package/dist/modules/instance-ai/sandbox/index.js.map +1 -0
- package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.d.ts +77 -0
- package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.js +297 -0
- package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.js.map +1 -0
- package/dist/modules/instance-ai/suspended-run-restorer.service.d.ts +62 -0
- package/dist/modules/instance-ai/suspended-run-restorer.service.js +116 -0
- package/dist/modules/instance-ai/suspended-run-restorer.service.js.map +1 -0
- package/dist/modules/instance-ai/suspended-thread-persistence.service.d.ts +51 -0
- package/dist/modules/instance-ai/suspended-thread-persistence.service.js +106 -0
- package/dist/modules/instance-ai/suspended-thread-persistence.service.js.map +1 -0
- package/dist/modules/instance-ai/web-research/fetch-and-extract.d.ts +1 -1
- package/dist/modules/mcp/mcp-api-key.service.d.ts +3 -7
- package/dist/modules/mcp/mcp-api-key.service.js +1 -22
- package/dist/modules/mcp/mcp-api-key.service.js.map +1 -1
- package/dist/modules/mcp/mcp-protected-resource.d.ts +13 -0
- package/dist/modules/mcp/mcp-protected-resource.js +39 -0
- package/dist/modules/mcp/mcp-protected-resource.js.map +1 -0
- package/dist/modules/mcp/mcp-server-middleware.service.d.ts +5 -4
- package/dist/modules/mcp/mcp-server-middleware.service.js +9 -6
- package/dist/modules/mcp/mcp-server-middleware.service.js.map +1 -1
- package/dist/modules/mcp/mcp.errors.d.ts +0 -13
- package/dist/modules/mcp/mcp.errors.js +1 -27
- package/dist/modules/mcp/mcp.errors.js.map +1 -1
- package/dist/modules/mcp/mcp.module.d.ts +0 -1
- package/dist/modules/mcp/mcp.module.js +3 -11
- package/dist/modules/mcp/mcp.module.js.map +1 -1
- package/dist/modules/mcp/mcp.service.d.ts +5 -1
- package/dist/modules/mcp/mcp.service.js +16 -2
- package/dist/modules/mcp/mcp.service.js.map +1 -1
- package/dist/modules/mcp/mcp.types.d.ts +6 -14
- package/dist/modules/mcp/mcp.types.js.map +1 -1
- package/dist/modules/mcp/tools/get-workflow-details.tool.js +1 -1
- package/dist/modules/mcp/tools/get-workflow-details.tool.js.map +1 -1
- package/dist/modules/mcp/tools/list-tags.tool.d.ts +26 -0
- package/dist/modules/mcp/tools/list-tags.tool.js +91 -0
- package/dist/modules/mcp/tools/list-tags.tool.js.map +1 -0
- package/dist/modules/mcp/tools/schemas.d.ts +7 -0
- package/dist/modules/mcp/tools/schemas.js +3 -1
- package/dist/modules/mcp/tools/schemas.js.map +1 -1
- package/dist/modules/mcp/tools/search-workflows.tool.d.ts +2 -1
- package/dist/modules/mcp/tools/search-workflows.tool.js +14 -4
- package/dist/modules/mcp/tools/search-workflows.tool.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/constants.d.ts +1 -1
- package/dist/modules/mcp/tools/workflow-builder/constants.js +2 -1
- package/dist/modules/mcp/tools/workflow-builder/constants.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js +24 -6
- package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/explore-node-resources.tool.d.ts +18 -0
- package/dist/modules/mcp/tools/workflow-builder/explore-node-resources.tool.js +119 -0
- package/dist/modules/mcp/tools/workflow-builder/explore-node-resources.tool.js.map +1 -0
- package/dist/modules/mcp/tools/workflow-builder/get-workflow-node-types.tool.d.ts +2 -2
- package/dist/modules/mcp/tools/workflow-builder/get-workflow-node-types.tool.js +4 -4
- package/dist/modules/mcp/tools/workflow-builder/get-workflow-node-types.tool.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/mcp-instructions.js +8 -6
- package/dist/modules/mcp/tools/workflow-builder/mcp-instructions.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/search-workflow-nodes.tool.js +1 -1
- package/dist/modules/mcp/tools/workflow-builder/search-workflow-nodes.tool.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.d.ts +4 -294
- package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js +137 -16
- package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-builder/workflow-operations.d.ts +23 -1
- package/dist/modules/mcp/tools/workflow-builder/workflow-operations.js +54 -2
- package/dist/modules/mcp/tools/workflow-builder/workflow-operations.js.map +1 -1
- package/dist/modules/mcp/tools/workflow-validation.utils.d.ts +1 -0
- package/dist/modules/mcp/tools/workflow-validation.utils.js +1 -0
- package/dist/modules/mcp/tools/workflow-validation.utils.js.map +1 -1
- package/dist/modules/mcp-registry/node-description-transform.js +6 -0
- package/dist/modules/mcp-registry/node-description-transform.js.map +1 -1
- package/dist/modules/n8n-packages/engine/import-blocked.error.d.ts +4 -0
- package/dist/modules/n8n-packages/engine/import-blocked.error.js +14 -0
- package/dist/modules/n8n-packages/engine/import-blocked.error.js.map +1 -0
- package/dist/modules/n8n-packages/engine/import-pipeline.d.ts +9 -7
- package/dist/modules/n8n-packages/engine/import-pipeline.js +57 -113
- package/dist/modules/n8n-packages/engine/import-pipeline.js.map +1 -1
- package/dist/modules/n8n-packages/engine/n8n-package-parser.d.ts +11 -0
- package/dist/modules/n8n-packages/engine/n8n-package-parser.js +114 -0
- package/dist/modules/n8n-packages/engine/n8n-package-parser.js.map +1 -0
- package/dist/modules/n8n-packages/entities/credential/credential-importer.d.ts +4 -5
- package/dist/modules/n8n-packages/entities/credential/credential-importer.js +9 -12
- package/dist/modules/n8n-packages/entities/credential/credential-importer.js.map +1 -1
- package/dist/modules/n8n-packages/entities/credential/credential-matcher.d.ts +1 -0
- package/dist/modules/n8n-packages/entities/credential/credential-matcher.js +27 -2
- package/dist/modules/n8n-packages/entities/credential/credential-matcher.js.map +1 -1
- package/dist/modules/n8n-packages/entities/credential/credential-missing-mode.d.ts +3 -7
- package/dist/modules/n8n-packages/entities/credential/credential-missing-mode.js +6 -13
- package/dist/modules/n8n-packages/entities/credential/credential-missing-mode.js.map +1 -1
- package/dist/modules/n8n-packages/entities/credential/credential.types.d.ts +3 -10
- package/dist/modules/n8n-packages/entities/credential/credential.types.js +0 -4
- package/dist/modules/n8n-packages/entities/credential/credential.types.js.map +1 -1
- package/dist/modules/n8n-packages/entities/credential/id-based-credential-matcher.js +11 -6
- package/dist/modules/n8n-packages/entities/credential/id-based-credential-matcher.js.map +1 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.d.ts +4 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.js +12 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.js.map +1 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-id-policy.d.ts +2 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-id-policy.js +12 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-id-policy.js.map +1 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-import-match.service.d.ts +15 -2
- package/dist/modules/n8n-packages/entities/workflow/workflow-import-match.service.js +18 -2
- package/dist/modules/n8n-packages/entities/workflow/workflow-import-match.service.js.map +1 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-import.types.d.ts +47 -0
- package/dist/modules/n8n-packages/entities/workflow/{workflow-conflict-policy.types.js → workflow-import.types.js} +1 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-import.types.js.map +1 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-importer.d.ts +14 -6
- package/dist/modules/n8n-packages/entities/workflow/workflow-importer.js +136 -19
- package/dist/modules/n8n-packages/entities/workflow/workflow-importer.js.map +1 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-publisher.d.ts +16 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publisher.js +87 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publisher.js.map +1 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.d.ts +2 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.js +28 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.js.map +1 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.types.d.ts +14 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.types.js +10 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.types.js.map +1 -0
- package/dist/modules/n8n-packages/entities/workflow/workflow.serializer.js +1 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow.serializer.js.map +1 -1
- package/dist/modules/n8n-packages/io/tar/tar-package-reader.d.ts +10 -3
- package/dist/modules/n8n-packages/io/tar/tar-package-reader.js +103 -20
- package/dist/modules/n8n-packages/io/tar/tar-package-reader.js.map +1 -1
- package/dist/modules/n8n-packages/n8n-packages.config.d.ts +6 -0
- package/dist/modules/n8n-packages/n8n-packages.config.js +43 -0
- package/dist/modules/n8n-packages/n8n-packages.config.js.map +1 -0
- package/dist/modules/n8n-packages/n8n-packages.controller.js +0 -1
- package/dist/modules/n8n-packages/n8n-packages.controller.js.map +1 -1
- package/dist/modules/n8n-packages/n8n-packages.module.js +0 -2
- package/dist/modules/n8n-packages/n8n-packages.module.js.map +1 -1
- package/dist/modules/n8n-packages/n8n-packages.types.d.ts +41 -7
- package/dist/modules/n8n-packages/n8n-packages.types.js +7 -1
- package/dist/modules/n8n-packages/n8n-packages.types.js.map +1 -1
- package/dist/modules/n8n-packages/spec/serialized/workflow.schema.d.ts +3 -3
- package/dist/modules/n8n-packages/spec/serialized/workflow.schema.js +1 -1
- package/dist/modules/n8n-packages/spec/serialized/workflow.schema.js.map +1 -1
- package/dist/modules/n8n-packages/utils/import-package-upload.js +2 -2
- package/dist/modules/n8n-packages/utils/import-package-upload.js.map +1 -1
- package/dist/modules/oauth-server/database/entities/oauth-access-token.entity.js.map +1 -0
- package/dist/modules/oauth-server/database/entities/oauth-authorization-code.entity.js.map +1 -0
- package/dist/modules/oauth-server/database/entities/oauth-client.entity.js.map +1 -0
- package/dist/modules/oauth-server/database/entities/oauth-refresh-token.entity.js.map +1 -0
- package/dist/modules/oauth-server/database/entities/oauth-user-consent.entity.js.map +1 -0
- package/dist/modules/oauth-server/database/repositories/oauth-access-token.repository.js.map +1 -0
- package/dist/modules/oauth-server/database/repositories/oauth-authorization-code.repository.js.map +1 -0
- package/dist/modules/oauth-server/database/repositories/oauth-client.repository.js.map +1 -0
- package/dist/modules/oauth-server/database/repositories/oauth-refresh-token.repository.js.map +1 -0
- package/dist/modules/oauth-server/database/repositories/oauth-user-consent.repository.js.map +1 -0
- package/dist/modules/oauth-server/dto/approve-consent-request.dto.js.map +1 -0
- package/dist/modules/{mcp/mcp-oauth-authorization-code.service.d.ts → oauth-server/oauth-authorization-code.service.d.ts} +1 -1
- package/dist/modules/{mcp/mcp-oauth-authorization-code.service.js → oauth-server/oauth-authorization-code.service.js} +12 -12
- package/dist/modules/oauth-server/oauth-authorization-code.service.js.map +1 -0
- package/dist/modules/{mcp/mcp.oauth-clients.controller.d.ts → oauth-server/oauth-clients.controller.d.ts} +4 -4
- package/dist/modules/{mcp/mcp.oauth-clients.controller.js → oauth-server/oauth-clients.controller.js} +16 -16
- package/dist/modules/oauth-server/oauth-clients.controller.js.map +1 -0
- package/dist/modules/{mcp/mcp.auth.consent.controller.d.ts → oauth-server/oauth-consent.controller.d.ts} +3 -3
- package/dist/modules/{mcp/mcp.auth.consent.controller.js → oauth-server/oauth-consent.controller.js} +16 -10
- package/dist/modules/oauth-server/oauth-consent.controller.js.map +1 -0
- package/dist/modules/{mcp/mcp-oauth-consent.service.d.ts → oauth-server/oauth-consent.service.d.ts} +16 -7
- package/dist/modules/{mcp/mcp-oauth-consent.service.js → oauth-server/oauth-consent.service.js} +28 -12
- package/dist/modules/oauth-server/oauth-consent.service.js.map +1 -0
- package/dist/modules/oauth-server/oauth-server.module.d.ts +5 -0
- package/dist/modules/oauth-server/oauth-server.module.js +75 -0
- package/dist/modules/oauth-server/oauth-server.module.js.map +1 -0
- package/dist/modules/{mcp/mcp-oauth-service.d.ts → oauth-server/oauth-server.service.d.ts} +6 -6
- package/dist/modules/{mcp/mcp-oauth-service.js → oauth-server/oauth-server.service.js} +33 -30
- package/dist/modules/oauth-server/oauth-server.service.js.map +1 -0
- package/dist/modules/oauth-server/oauth-session.service.js.map +1 -0
- package/dist/modules/{mcp/mcp-oauth-token.service.d.ts → oauth-server/oauth-token.service.d.ts} +5 -8
- package/dist/modules/{mcp/mcp-oauth-token.service.js → oauth-server/oauth-token.service.js} +29 -30
- package/dist/modules/oauth-server/oauth-token.service.js.map +1 -0
- package/dist/modules/{mcp/mcp.oauth.controller.d.ts → oauth-server/oauth.controller.d.ts} +5 -3
- package/dist/modules/{mcp/mcp.oauth.controller.js → oauth-server/oauth.controller.js} +79 -68
- package/dist/modules/oauth-server/oauth.controller.js.map +1 -0
- package/dist/modules/oauth-server/oauth.errors.d.ts +13 -0
- package/dist/modules/oauth-server/oauth.errors.js +30 -0
- package/dist/modules/oauth-server/oauth.errors.js.map +1 -0
- package/dist/modules/{mcp/mcp-oauth.helpers.d.ts → oauth-server/oauth.helpers.d.ts} +1 -1
- package/dist/modules/{mcp/mcp-oauth.helpers.js → oauth-server/oauth.helpers.js} +4 -4
- package/dist/modules/oauth-server/oauth.helpers.js.map +1 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/utils.d.ts +4 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/utils.js +41 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/utils.js.map +1 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.d.ts +28 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.js +78 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.js.map +1 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.d.ts +30 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.js +95 -0
- package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.js.map +1 -0
- package/dist/modules/otel/execution-level-tracer.d.ts +5 -4
- package/dist/modules/otel/execution-level-tracer.js +8 -5
- package/dist/modules/otel/execution-level-tracer.js.map +1 -1
- package/dist/modules/otel/otel-lifecycle-handler.d.ts +8 -4
- package/dist/modules/otel/otel-lifecycle-handler.js +32 -15
- package/dist/modules/otel/otel-lifecycle-handler.js.map +1 -1
- package/dist/modules/otel/otel-settings.controller.d.ts +18 -0
- package/dist/modules/otel/otel-settings.controller.js +79 -0
- package/dist/modules/otel/otel-settings.controller.js.map +1 -0
- package/dist/modules/otel/otel-settings.service.d.ts +21 -0
- package/dist/modules/otel/otel-settings.service.js +89 -0
- package/dist/modules/otel/otel-settings.service.js.map +1 -0
- package/dist/modules/otel/otel.config.js +11 -10
- package/dist/modules/otel/otel.config.js.map +1 -1
- package/dist/modules/otel/otel.constants.d.ts +14 -0
- package/dist/modules/otel/otel.constants.js +15 -1
- package/dist/modules/otel/otel.constants.js.map +1 -1
- package/dist/modules/otel/otel.module.js +9 -17
- package/dist/modules/otel/otel.module.js.map +1 -1
- package/dist/modules/otel/otel.service.d.ts +15 -4
- package/dist/modules/otel/otel.service.js +73 -17
- package/dist/modules/otel/otel.service.js.map +1 -1
- package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.d.ts +1 -0
- package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js +46 -19
- package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js.map +1 -1
- package/dist/modules/redaction/instance-redaction-enforcement.service.js +0 -6
- package/dist/modules/redaction/instance-redaction-enforcement.service.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-git.service.ee.js +2 -5
- package/dist/modules/source-control.ee/source-control-git.service.ee.js.map +1 -1
- package/dist/modules/sso-saml/saml.service.ee.js +3 -2
- package/dist/modules/sso-saml/saml.service.ee.js.map +1 -1
- package/dist/modules/workflow-index/workflow-dependency-query.service.js +39 -20
- package/dist/modules/workflow-index/workflow-dependency-query.service.js.map +1 -1
- package/dist/oauth/oauth.service.d.ts +14 -0
- package/dist/oauth/oauth.service.js +220 -102
- package/dist/oauth/oauth.service.js.map +1 -1
- package/dist/oauth/types.d.ts +1 -0
- package/dist/oauth/types.js.map +1 -1
- package/dist/public-api/index.js +8 -8
- package/dist/public-api/index.js.map +1 -1
- package/dist/public-api/types.d.ts +1 -6
- package/dist/public-api/v1/handlers/credentials/credentials.service.js +7 -8
- package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
- package/dist/public-api/v1/handlers/executions/executions.handler.js +1 -1
- package/dist/public-api/v1/handlers/executions/executions.handler.js.map +1 -1
- package/dist/public-api/v1/handlers/n8n-packages/n8n-packages.handler.js +3 -3
- package/dist/public-api/v1/handlers/n8n-packages/n8n-packages.handler.js.map +1 -1
- package/dist/public-api/v1/openapi.yml +208 -51
- package/dist/push/abstract.push.d.ts +1 -2
- package/dist/push/abstract.push.js +1 -2
- package/dist/push/abstract.push.js.map +1 -1
- package/dist/push/index.d.ts +1 -2
- package/dist/push/index.js +3 -4
- package/dist/push/index.js.map +1 -1
- package/dist/scaling/constants.d.ts +2 -2
- package/dist/scaling/constants.js +1 -0
- package/dist/scaling/constants.js.map +1 -1
- package/dist/scaling/job-processor.d.ts +0 -1
- package/dist/scaling/job-processor.js +1 -23
- package/dist/scaling/job-processor.js.map +1 -1
- package/dist/scaling/multi-main-setup.ee.d.ts +1 -2
- package/dist/scaling/multi-main-setup.ee.js +1 -2
- package/dist/scaling/multi-main-setup.ee.js.map +1 -1
- package/dist/scaling/pubsub/pubsub.event-map.d.ts +7 -0
- package/dist/scaling/pubsub/pubsub.eventbus.d.ts +1 -1
- package/dist/scaling/pubsub/pubsub.eventbus.js +2 -2
- package/dist/scaling/pubsub/pubsub.eventbus.js.map +1 -1
- package/dist/scaling/pubsub/pubsub.types.d.ts +3 -1
- package/dist/scaling/worker-server.d.ts +1 -1
- package/dist/scaling/worker-server.js +5 -5
- package/dist/scaling/worker-server.js.map +1 -1
- package/dist/server.js +4 -3
- package/dist/server.js.map +1 -1
- package/dist/services/ai-workflow-builder.service.d.ts +2 -1
- package/dist/services/ai-workflow-builder.service.js +2 -1
- package/dist/services/ai-workflow-builder.service.js.map +1 -1
- package/dist/services/cache/cache.service.d.ts +1 -1
- package/dist/services/cache/cache.service.js +2 -2
- package/dist/services/cache/cache.service.js.map +1 -1
- package/dist/services/node-resource-explorer.service.d.ts +16 -0
- package/dist/services/node-resource-explorer.service.js +154 -0
- package/dist/services/node-resource-explorer.service.js.map +1 -0
- package/dist/services/oauth-token-verifier-proxy.service.d.ts +22 -0
- package/dist/services/oauth-token-verifier-proxy.service.js +36 -0
- package/dist/services/oauth-token-verifier-proxy.service.js.map +1 -0
- package/dist/services/protected-resource.registry.d.ts +31 -0
- package/dist/services/protected-resource.registry.js +115 -0
- package/dist/services/protected-resource.registry.js.map +1 -0
- package/dist/services/public-api-key.service.d.ts +8 -2
- package/dist/services/public-api-key.service.js +29 -6
- package/dist/services/public-api-key.service.js.map +1 -1
- package/dist/services/redis-client.service.d.ts +2 -2
- package/dist/services/redis-client.service.js +6 -4
- package/dist/services/redis-client.service.js.map +1 -1
- package/dist/services/tag.service.d.ts +10 -0
- package/dist/services/tag.service.js +84 -4
- package/dist/services/tag.service.js.map +1 -1
- package/dist/services/workflow-statistics.service.d.ts +1 -2
- package/dist/services/workflow-statistics.service.js +1 -2
- package/dist/services/workflow-statistics.service.js.map +1 -1
- package/dist/task-runners/sliding-window-signal.d.ts +1 -1
- package/dist/task-runners/task-runner-lifecycle-events.d.ts +1 -1
- package/dist/task-runners/task-runner-lifecycle-events.js +2 -2
- package/dist/task-runners/task-runner-lifecycle-events.js.map +1 -1
- package/dist/task-runners/task-runner-process-base.d.ts +1 -2
- package/dist/task-runners/task-runner-process-base.js +1 -2
- package/dist/task-runners/task-runner-process-base.js.map +1 -1
- package/dist/task-runners/task-runner-process-restart-loop-detector.d.ts +1 -1
- package/dist/task-runners/task-runner-process-restart-loop-detector.js +2 -2
- package/dist/task-runners/task-runner-process-restart-loop-detector.js.map +1 -1
- package/dist/user-management/email/templates/api-key-revoked.handlebars +196 -0
- package/dist/user-management/email/user-management-mailer.d.ts +6 -2
- package/dist/user-management/email/user-management-mailer.js +32 -0
- package/dist/user-management/email/user-management-mailer.js.map +1 -1
- package/dist/wait-tracker.d.ts +1 -1
- package/dist/wait-tracker.js +3 -3
- package/dist/wait-tracker.js.map +1 -1
- package/dist/webhooks/webhook-helpers.js +30 -1
- package/dist/webhooks/webhook-helpers.js.map +1 -1
- package/dist/webhooks/webhook-server.js +2 -2
- package/dist/webhooks/webhook-server.js.map +1 -1
- package/dist/webhooks/webhook.service.d.ts +4 -1
- package/dist/webhooks/webhook.service.js +20 -5
- package/dist/webhooks/webhook.service.js.map +1 -1
- package/dist/workflow-execute-additional-data.d.ts +1 -1
- package/dist/workflow-execute-additional-data.js +4 -1
- package/dist/workflow-execute-additional-data.js.map +1 -1
- package/dist/workflow-helpers.d.ts +1 -1
- package/dist/workflow-helpers.js +13 -3
- package/dist/workflow-helpers.js.map +1 -1
- package/dist/workflow-runner.js +0 -2
- package/dist/workflow-runner.js.map +1 -1
- package/dist/workflows/publication/publication-result.d.ts +17 -0
- package/dist/workflows/publication/publication-result.js +3 -0
- package/dist/workflows/publication/publication-result.js.map +1 -0
- package/dist/workflows/publication/publication-status-reporter.d.ts +19 -0
- package/dist/workflows/publication/publication-status-reporter.js +110 -0
- package/dist/workflows/publication/publication-status-reporter.js.map +1 -0
- package/dist/workflows/publication/trigger-diff.d.ts +6 -0
- package/dist/workflows/publication/trigger-diff.js +27 -0
- package/dist/workflows/publication/trigger-diff.js.map +1 -0
- package/dist/workflows/publication/workflow-publication-applier.d.ts +14 -0
- package/dist/workflows/publication/workflow-publication-applier.js +96 -0
- package/dist/workflows/publication/workflow-publication-applier.js.map +1 -0
- package/dist/workflows/{workflow-publication-outbox-consumer.d.ts → publication/workflow-publication-outbox-consumer.d.ts} +9 -13
- package/dist/workflows/{workflow-publication-outbox-consumer.js → publication/workflow-publication-outbox-consumer.js} +25 -93
- package/dist/workflows/publication/workflow-publication-outbox-consumer.js.map +1 -0
- package/dist/workflows/triggers/non-webhook-trigger-registrar.d.ts +39 -0
- package/dist/workflows/triggers/non-webhook-trigger-registrar.js +58 -0
- package/dist/workflows/triggers/non-webhook-trigger-registrar.js.map +1 -0
- package/dist/workflows/triggers/trigger-count.service.d.ts +5 -0
- package/dist/workflows/triggers/trigger-count.service.js +65 -0
- package/dist/workflows/triggers/trigger-count.service.js.map +1 -0
- package/dist/workflows/triggers/trigger-execution-context.factory.d.ts +33 -0
- package/dist/workflows/triggers/trigger-execution-context.factory.js +171 -0
- package/dist/workflows/triggers/trigger-execution-context.factory.js.map +1 -0
- package/dist/workflows/triggers/webhook-trigger-registrar.d.ts +29 -0
- package/dist/workflows/triggers/webhook-trigger-registrar.js +143 -0
- package/dist/workflows/triggers/webhook-trigger-registrar.js.map +1 -0
- package/dist/workflows/triggers/workflow-trigger-activator.d.ts +56 -0
- package/dist/workflows/triggers/workflow-trigger-activator.js +313 -0
- package/dist/workflows/triggers/workflow-trigger-activator.js.map +1 -0
- package/dist/workflows/workflow-validation.service.d.ts +3 -0
- package/dist/workflows/workflow-validation.service.js +63 -37
- package/dist/workflows/workflow-validation.service.js.map +1 -1
- package/dist/workflows/workflow.service.d.ts +5 -3
- package/dist/workflows/workflow.service.js +91 -28
- package/dist/workflows/workflow.service.js.map +1 -1
- package/dist/workflows/workflows.controller.d.ts +3 -3
- package/dist/workflows/workflows.controller.js +3 -3
- package/dist/workflows/workflows.controller.js.map +1 -1
- package/package.json +36 -35
- package/templates/oauth-callback.handlebars +3 -0
- package/templates/oauth-error-callback.handlebars +3 -0
- package/dist/metrics/prometheus-metrics.service.d.ts +0 -54
- package/dist/metrics/prometheus-metrics.service.js +0 -607
- package/dist/metrics/prometheus-metrics.service.js.map +0 -1
- package/dist/metrics/types.d.ts +0 -6
- package/dist/metrics/types.js.map +0 -1
- package/dist/modules/agents/agent-knowledge-command.service.d.ts +0 -40
- package/dist/modules/agents/agent-knowledge-command.service.js +0 -221
- package/dist/modules/agents/agent-knowledge-command.service.js.map +0 -1
- package/dist/modules/agents/entities/agent-file.entity.d.ts +0 -11
- package/dist/modules/agents/entities/agent-file.entity.js.map +0 -1
- package/dist/modules/agents/repositories/agent-file.repository.d.ts +0 -7
- package/dist/modules/agents/repositories/agent-file.repository.js +0 -35
- package/dist/modules/agents/repositories/agent-file.repository.js.map +0 -1
- package/dist/modules/agents/tools/knowledge/csv-helpers.d.ts +0 -73
- package/dist/modules/agents/tools/knowledge/csv-helpers.js +0 -341
- package/dist/modules/agents/tools/knowledge/csv-helpers.js.map +0 -1
- package/dist/modules/agents/tools/knowledge/csv.operation.d.ts +0 -61
- package/dist/modules/agents/tools/knowledge/csv.operation.js +0 -207
- package/dist/modules/agents/tools/knowledge/csv.operation.js.map +0 -1
- package/dist/modules/agents/tools/knowledge/file-references.d.ts +0 -16
- package/dist/modules/agents/tools/knowledge/file-references.js +0 -35
- package/dist/modules/agents/tools/knowledge/file-references.js.map +0 -1
- package/dist/modules/agents/tools/knowledge/read.operation.d.ts +0 -8
- package/dist/modules/agents/tools/knowledge/read.operation.js +0 -38
- package/dist/modules/agents/tools/knowledge/read.operation.js.map +0 -1
- package/dist/modules/agents/tools/knowledge/schemas.d.ts +0 -1505
- package/dist/modules/agents/tools/knowledge/schemas.js +0 -441
- package/dist/modules/agents/tools/knowledge/schemas.js.map +0 -1
- package/dist/modules/agents/tools/knowledge/search.operation.d.ts +0 -9
- package/dist/modules/agents/tools/knowledge/search.operation.js +0 -332
- package/dist/modules/agents/tools/knowledge/search.operation.js.map +0 -1
- package/dist/modules/agents/tools/knowledge/tool.d.ts +0 -8
- package/dist/modules/agents/tools/knowledge/tool.js +0 -121
- package/dist/modules/agents/tools/knowledge/tool.js.map +0 -1
- package/dist/modules/mcp/database/entities/oauth-access-token.entity.js.map +0 -1
- package/dist/modules/mcp/database/entities/oauth-authorization-code.entity.js.map +0 -1
- package/dist/modules/mcp/database/entities/oauth-client.entity.js.map +0 -1
- package/dist/modules/mcp/database/entities/oauth-refresh-token.entity.js.map +0 -1
- package/dist/modules/mcp/database/entities/oauth-user-consent.entity.js.map +0 -1
- package/dist/modules/mcp/database/repositories/oauth-access-token.repository.js.map +0 -1
- package/dist/modules/mcp/database/repositories/oauth-authorization-code.repository.js.map +0 -1
- package/dist/modules/mcp/database/repositories/oauth-client.repository.js.map +0 -1
- package/dist/modules/mcp/database/repositories/oauth-refresh-token.repository.js.map +0 -1
- package/dist/modules/mcp/database/repositories/oauth-user-consent.repository.js.map +0 -1
- package/dist/modules/mcp/dto/approve-consent-request.dto.js.map +0 -1
- package/dist/modules/mcp/mcp-oauth-authorization-code.service.js.map +0 -1
- package/dist/modules/mcp/mcp-oauth-consent.service.js.map +0 -1
- package/dist/modules/mcp/mcp-oauth-service.js.map +0 -1
- package/dist/modules/mcp/mcp-oauth-token.service.js.map +0 -1
- package/dist/modules/mcp/mcp-oauth.helpers.js.map +0 -1
- package/dist/modules/mcp/mcp.auth.consent.controller.js.map +0 -1
- package/dist/modules/mcp/mcp.oauth-clients.controller.js.map +0 -1
- package/dist/modules/mcp/mcp.oauth.controller.js.map +0 -1
- package/dist/modules/mcp/oauth-session.service.js.map +0 -1
- package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.d.ts +0 -7
- package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.js +0 -35
- package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.js.map +0 -1
- package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.d.ts +0 -3
- package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.js +0 -14
- package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.js.map +0 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.d.ts +0 -9
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.js +0 -41
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.js.map +0 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.d.ts +0 -10
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.js +0 -20
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.js.map +0 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.d.ts +0 -11
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.js +0 -42
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.js.map +0 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.d.ts +0 -9
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.js +0 -33
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.js.map +0 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.d.ts +0 -10
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.js +0 -37
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.js.map +0 -1
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.types.d.ts +0 -20
- package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.types.js.map +0 -1
- package/dist/modules/redaction/redaction-enforcement.feature-flag.d.ts +0 -2
- package/dist/modules/redaction/redaction-enforcement.feature-flag.js +0 -9
- package/dist/modules/redaction/redaction-enforcement.feature-flag.js.map +0 -1
- package/dist/typed-emitter.d.ts +0 -14
- package/dist/typed-emitter.js +0 -29
- package/dist/typed-emitter.js.map +0 -1
- package/dist/workflows/workflow-publication-outbox-consumer.js.map +0 -1
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-access-token.entity.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-access-token.entity.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-authorization-code.entity.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-authorization-code.entity.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-client.entity.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-client.entity.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-refresh-token.entity.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-refresh-token.entity.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-user-consent.entity.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-user-consent.entity.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-access-token.repository.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-access-token.repository.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-authorization-code.repository.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-authorization-code.repository.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-client.repository.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-client.repository.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-refresh-token.repository.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-refresh-token.repository.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-user-consent.repository.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-user-consent.repository.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/dto/approve-consent-request.dto.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/dto/approve-consent-request.dto.js +0 -0
- /package/dist/modules/{mcp → oauth-server}/oauth-session.service.d.ts +0 -0
- /package/dist/modules/{mcp → oauth-server}/oauth-session.service.js +0 -0
|
@@ -0,0 +1,71 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PrometheusQueueMetricsService = void 0;
|
|
16
|
+
const config_1 = require("@n8n/config");
|
|
17
|
+
const di_1 = require("@n8n/di");
|
|
18
|
+
const n8n_core_1 = require("n8n-core");
|
|
19
|
+
const prom_client_1 = __importDefault(require("prom-client"));
|
|
20
|
+
const event_service_1 = require("../../events/event.service");
|
|
21
|
+
let PrometheusQueueMetricsService = class PrometheusQueueMetricsService {
|
|
22
|
+
constructor(config, executionsConfig, instanceSettings, eventService) {
|
|
23
|
+
this.config = config;
|
|
24
|
+
this.executionsConfig = executionsConfig;
|
|
25
|
+
this.instanceSettings = instanceSettings;
|
|
26
|
+
this.eventService = eventService;
|
|
27
|
+
}
|
|
28
|
+
get enabled() {
|
|
29
|
+
return (this.config.includeQueueMetrics &&
|
|
30
|
+
this.executionsConfig.mode === 'queue' &&
|
|
31
|
+
this.instanceSettings.instanceType === 'main');
|
|
32
|
+
}
|
|
33
|
+
init() {
|
|
34
|
+
const prefix = this.config.prefix;
|
|
35
|
+
const waitingGauge = new prom_client_1.default.Gauge({
|
|
36
|
+
name: `${prefix}scaling_mode_queue_jobs_waiting`,
|
|
37
|
+
help: 'Current number of enqueued jobs waiting for pickup in scaling mode.',
|
|
38
|
+
});
|
|
39
|
+
waitingGauge.set(0);
|
|
40
|
+
const activeGauge = new prom_client_1.default.Gauge({
|
|
41
|
+
name: `${prefix}scaling_mode_queue_jobs_active`,
|
|
42
|
+
help: 'Current number of jobs being processed across all workers in scaling mode.',
|
|
43
|
+
});
|
|
44
|
+
activeGauge.set(0);
|
|
45
|
+
const completedCounter = new prom_client_1.default.Counter({
|
|
46
|
+
name: `${prefix}scaling_mode_queue_jobs_completed`,
|
|
47
|
+
help: 'Total number of jobs completed across all workers in scaling mode since instance start.',
|
|
48
|
+
});
|
|
49
|
+
completedCounter.inc(0);
|
|
50
|
+
const failedCounter = new prom_client_1.default.Counter({
|
|
51
|
+
name: `${prefix}scaling_mode_queue_jobs_failed`,
|
|
52
|
+
help: 'Total number of jobs failed across all workers in scaling mode since instance start.',
|
|
53
|
+
});
|
|
54
|
+
failedCounter.inc(0);
|
|
55
|
+
this.eventService.on('job-counts-updated', (jobCounts) => {
|
|
56
|
+
waitingGauge.set(jobCounts.waiting);
|
|
57
|
+
activeGauge.set(jobCounts.active);
|
|
58
|
+
completedCounter.inc(jobCounts.completed);
|
|
59
|
+
failedCounter.inc(jobCounts.failed);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
exports.PrometheusQueueMetricsService = PrometheusQueueMetricsService;
|
|
64
|
+
exports.PrometheusQueueMetricsService = PrometheusQueueMetricsService = __decorate([
|
|
65
|
+
(0, di_1.Service)(),
|
|
66
|
+
__metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
|
|
67
|
+
config_1.ExecutionsConfig,
|
|
68
|
+
n8n_core_1.InstanceSettings,
|
|
69
|
+
event_service_1.EventService])
|
|
70
|
+
], PrometheusQueueMetricsService);
|
|
71
|
+
//# sourceMappingURL=queue-metrics.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/queue-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAwE;AACxE,gCAAkC;AAClC,uCAA4C;AAC5C,8DAAqC;AAErC,0DAAsD;AAS/C,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IACzC,YACkB,MAA+B,EAC/B,gBAAkC,EAClC,gBAAkC,EAClC,YAA0B;QAH1B,WAAM,GAAN,MAAM,CAAyB;QAC/B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,iBAAY,GAAZ,YAAY,CAAc;IACzC,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,CACN,IAAI,CAAC,MAAM,CAAC,mBAAmB;YAC/B,IAAI,CAAC,gBAAgB,CAAC,IAAI,KAAK,OAAO;YACtC,IAAI,CAAC,gBAAgB,CAAC,YAAY,KAAK,MAAM,CAC7C,CAAC;IACH,CAAC;IAED,IAAI;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;QAClC,MAAM,YAAY,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;YACzC,IAAI,EAAE,GAAG,MAAM,iCAAiC;YAChD,IAAI,EAAE,qEAAqE;SAC3E,CAAC,CAAC;QACH,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEpB,MAAM,WAAW,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;YACxC,IAAI,EAAE,GAAG,MAAM,gCAAgC;YAC/C,IAAI,EAAE,4EAA4E;SAClF,CAAC,CAAC;QACH,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEnB,MAAM,gBAAgB,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC/C,IAAI,EAAE,GAAG,MAAM,mCAAmC;YAClD,IAAI,EAAE,yFAAyF;SAC/F,CAAC,CAAC;QACH,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAExB,MAAM,aAAa,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC5C,IAAI,EAAE,GAAG,MAAM,gCAAgC;YAC/C,IAAI,EAAE,sFAAsF;SAC5F,CAAC,CAAC;QACH,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAErB,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,oBAAoB,EAAE,CAAC,SAAS,EAAE,EAAE;YACxD,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YACpC,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YAClC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAC1C,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AAjDY,sEAA6B;wCAA7B,6BAA6B;IADzC,IAAA,YAAO,GAAE;qCAGiB,gCAAuB;QACb,yBAAgB;QAChB,2BAAgB;QACpB,4BAAY;GALhC,6BAA6B,CAiDzC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EndpointsConfig, PrometheusMetricsConfig } from '@n8n/config';
|
|
2
|
+
import type express from 'express';
|
|
3
|
+
import type { PrometheusMetricsCollector } from './base';
|
|
4
|
+
export declare class PrometheusRouteMetricsService implements PrometheusMetricsCollector {
|
|
5
|
+
private readonly config;
|
|
6
|
+
private readonly endpointsConfig;
|
|
7
|
+
constructor(config: PrometheusMetricsConfig, endpointsConfig: EndpointsConfig);
|
|
8
|
+
get enabled(): boolean;
|
|
9
|
+
init(app?: express.Application): void;
|
|
10
|
+
private registerMiddleware;
|
|
11
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PrometheusRouteMetricsService = void 0;
|
|
16
|
+
const config_1 = require("@n8n/config");
|
|
17
|
+
const di_1 = require("@n8n/di");
|
|
18
|
+
const express_prom_bundle_1 = __importDefault(require("express-prom-bundle"));
|
|
19
|
+
const luxon_1 = require("luxon");
|
|
20
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
21
|
+
const prom_client_1 = __importDefault(require("prom-client"));
|
|
22
|
+
let PrometheusRouteMetricsService = class PrometheusRouteMetricsService {
|
|
23
|
+
constructor(config, endpointsConfig) {
|
|
24
|
+
this.config = config;
|
|
25
|
+
this.endpointsConfig = endpointsConfig;
|
|
26
|
+
}
|
|
27
|
+
get enabled() {
|
|
28
|
+
return this.config.includeApiEndpoints;
|
|
29
|
+
}
|
|
30
|
+
init(app) {
|
|
31
|
+
(0, n8n_workflow_1.assert)(app, "PrometheusRouteMetricsService is initialized through the app middleware. 'app' must be defined.");
|
|
32
|
+
const gauge = new prom_client_1.default.Gauge({
|
|
33
|
+
name: `${this.config.prefix}last_activity`,
|
|
34
|
+
help: 'last instance activity (backend request) in Unix time (seconds).',
|
|
35
|
+
});
|
|
36
|
+
gauge.set(luxon_1.DateTime.now().toUnixInteger());
|
|
37
|
+
this.registerMiddleware(app, gauge);
|
|
38
|
+
}
|
|
39
|
+
registerMiddleware(app, gauge) {
|
|
40
|
+
const metricsMiddleware = (0, express_prom_bundle_1.default)({
|
|
41
|
+
autoregister: false,
|
|
42
|
+
includeUp: false,
|
|
43
|
+
includePath: this.config.includeApiPathLabel,
|
|
44
|
+
includeMethod: this.config.includeApiMethodLabel,
|
|
45
|
+
includeStatusCode: this.config.includeApiStatusCodeLabel,
|
|
46
|
+
httpDurationMetricName: `${this.config.prefix}http_request_duration_seconds`,
|
|
47
|
+
});
|
|
48
|
+
app.use([
|
|
49
|
+
'/api/',
|
|
50
|
+
`/${this.endpointsConfig.rest}/`,
|
|
51
|
+
`/${this.endpointsConfig.webhook}/`,
|
|
52
|
+
`/${this.endpointsConfig.webhookWaiting}/`,
|
|
53
|
+
`/${this.endpointsConfig.webhookTest}/`,
|
|
54
|
+
`/${this.endpointsConfig.form}/`,
|
|
55
|
+
`/${this.endpointsConfig.formWaiting}/`,
|
|
56
|
+
`/${this.endpointsConfig.formTest}/`,
|
|
57
|
+
], async (req, res, next) => {
|
|
58
|
+
gauge.set(luxon_1.DateTime.now().toUnixInteger());
|
|
59
|
+
await metricsMiddleware(req, res, next);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
exports.PrometheusRouteMetricsService = PrometheusRouteMetricsService;
|
|
64
|
+
exports.PrometheusRouteMetricsService = PrometheusRouteMetricsService = __decorate([
|
|
65
|
+
(0, di_1.Service)(),
|
|
66
|
+
__metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
|
|
67
|
+
config_1.EndpointsConfig])
|
|
68
|
+
], PrometheusRouteMetricsService);
|
|
69
|
+
//# sourceMappingURL=route-metrics.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"route-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/route-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAuE;AACvE,gCAAkC;AAElC,8EAA6C;AAC7C,iCAAiC;AACjC,+CAAsC;AACtC,8DAAgD;AASzC,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IACzC,YACkB,MAA+B,EAC/B,eAAgC;QADhC,WAAM,GAAN,MAAM,CAAyB;QAC/B,oBAAe,GAAf,eAAe,CAAiB;IAC/C,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC;IACxC,CAAC;IAED,IAAI,CAAC,GAAyB;QAC7B,IAAA,qBAAM,EACL,GAAG,EACH,iGAAiG,CACjG,CAAC;QAEF,MAAM,KAAK,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;YAClC,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,eAAe;YAC1C,IAAI,EAAE,kEAAkE;SACxE,CAAC,CAAC;QAEH,KAAK,CAAC,GAAG,CAAC,gBAAQ,CAAC,GAAG,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACrC,CAAC;IAEO,kBAAkB,CAAC,GAAwB,EAAE,KAAY;QAChE,MAAM,iBAAiB,GAAG,IAAA,6BAAU,EAAC;YACpC,YAAY,EAAE,KAAK;YACnB,SAAS,EAAE,KAAK;YAChB,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,mBAAmB;YAC5C,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,qBAAqB;YAChD,iBAAiB,EAAE,IAAI,CAAC,MAAM,CAAC,yBAAyB;YACxD,sBAAsB,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,+BAA+B;SAC5E,CAAC,CAAC;QAEH,GAAG,CAAC,GAAG,CACN;YACC,OAAO;YACP,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG;YAChC,IAAI,IAAI,CAAC,eAAe,CAAC,OAAO,GAAG;YACnC,IAAI,IAAI,CAAC,eAAe,CAAC,cAAc,GAAG;YAC1C,IAAI,IAAI,CAAC,eAAe,CAAC,WAAW,GAAG;YACvC,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG;YAChC,IAAI,IAAI,CAAC,eAAe,CAAC,WAAW,GAAG;YACvC,IAAI,IAAI,CAAC,eAAe,CAAC,QAAQ,GAAG;SACpC,EACD,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YACxB,KAAK,CAAC,GAAG,CAAC,gBAAQ,CAAC,GAAG,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC;YAC1C,MAAM,iBAAiB,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACzC,CAAC,CACD,CAAC;IACH,CAAC;CACD,CAAA;AApDY,sEAA6B;wCAA7B,6BAA6B;IADzC,IAAA,YAAO,GAAE;qCAGiB,gCAAuB;QACd,wBAAe;GAHtC,6BAA6B,CAoDzC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { PrometheusMetricsConfig, SsrfProtectionConfig } from '@n8n/config';
|
|
2
|
+
import type { PrometheusMetricsCollector } from './base';
|
|
3
|
+
import { SsrfProtectionService } from '@n8n/backend-network';
|
|
4
|
+
export declare class PrometheusSsrfMetricsService implements PrometheusMetricsCollector {
|
|
5
|
+
private readonly ssrfProtectionService;
|
|
6
|
+
private readonly config;
|
|
7
|
+
private readonly ssrfConfig;
|
|
8
|
+
constructor(ssrfProtectionService: SsrfProtectionService, config: PrometheusMetricsConfig, ssrfConfig: SsrfProtectionConfig);
|
|
9
|
+
get enabled(): boolean;
|
|
10
|
+
init(): void;
|
|
11
|
+
}
|
|
@@ -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
|
+
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PrometheusSsrfMetricsService = void 0;
|
|
16
|
+
const config_1 = require("@n8n/config");
|
|
17
|
+
const di_1 = require("@n8n/di");
|
|
18
|
+
const prom_client_1 = __importDefault(require("prom-client"));
|
|
19
|
+
const constant_1 = require("./constant");
|
|
20
|
+
const backend_network_1 = require("@n8n/backend-network");
|
|
21
|
+
let PrometheusSsrfMetricsService = class PrometheusSsrfMetricsService {
|
|
22
|
+
constructor(ssrfProtectionService, config, ssrfConfig) {
|
|
23
|
+
this.ssrfProtectionService = ssrfProtectionService;
|
|
24
|
+
this.config = config;
|
|
25
|
+
this.ssrfConfig = ssrfConfig;
|
|
26
|
+
}
|
|
27
|
+
get enabled() {
|
|
28
|
+
return this.config.includeSsrfMetrics && this.ssrfConfig.enabled;
|
|
29
|
+
}
|
|
30
|
+
init() {
|
|
31
|
+
const checksCounter = new prom_client_1.default.Counter({
|
|
32
|
+
name: `${this.config.prefix}ssrf_checks_total`,
|
|
33
|
+
help: 'Total number of SSRF checks by result and phase.',
|
|
34
|
+
labelNames: ['result', 'phase'],
|
|
35
|
+
});
|
|
36
|
+
const blockedCounter = new prom_client_1.default.Counter({
|
|
37
|
+
name: `${this.config.prefix}ssrf_blocked_checks_total`,
|
|
38
|
+
help: 'Total number of blocked SSRF checks by phase and reason.',
|
|
39
|
+
labelNames: ['phase', 'reason'],
|
|
40
|
+
});
|
|
41
|
+
const durationHistogram = new prom_client_1.default.Histogram({
|
|
42
|
+
name: `${this.config.prefix}ssrf_check_duration_seconds`,
|
|
43
|
+
help: 'Duration of SSRF checks in seconds.',
|
|
44
|
+
labelNames: ['result', 'phase'],
|
|
45
|
+
buckets: constant_1.DURATION_BUCKETS_SECONDS,
|
|
46
|
+
});
|
|
47
|
+
this.ssrfProtectionService.events.on('ssrf.blocked', ({ phase, reason, durationMs }) => {
|
|
48
|
+
checksCounter.inc({ result: 'blocked', phase });
|
|
49
|
+
blockedCounter.inc({ phase, reason });
|
|
50
|
+
durationHistogram.observe({ result: 'blocked', phase }, durationMs / 1000);
|
|
51
|
+
});
|
|
52
|
+
this.ssrfProtectionService.events.on('ssrf.allowed', ({ phase, durationMs }) => {
|
|
53
|
+
checksCounter.inc({ result: 'allowed', phase });
|
|
54
|
+
durationHistogram.observe({ result: 'allowed', phase }, durationMs / 1000);
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
exports.PrometheusSsrfMetricsService = PrometheusSsrfMetricsService;
|
|
59
|
+
exports.PrometheusSsrfMetricsService = PrometheusSsrfMetricsService = __decorate([
|
|
60
|
+
(0, di_1.Service)(),
|
|
61
|
+
__metadata("design:paramtypes", [backend_network_1.SsrfProtectionService,
|
|
62
|
+
config_1.PrometheusMetricsConfig,
|
|
63
|
+
config_1.SsrfProtectionConfig])
|
|
64
|
+
], PrometheusSsrfMetricsService);
|
|
65
|
+
//# sourceMappingURL=ssrf-metrics.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ssrf-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/ssrf-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAA4E;AAC5E,gCAAkC;AAClC,8DAAqC;AAGrC,yCAAsD;AACtD,0DAA6D;AAUtD,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IACxC,YACkB,qBAA4C,EAC5C,MAA+B,EAC/B,UAAgC;QAFhC,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,WAAM,GAAN,MAAM,CAAyB;QAC/B,eAAU,GAAV,UAAU,CAAsB;IAC/C,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC;IAClE,CAAC;IAED,IAAI;QACH,MAAM,aAAa,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC5C,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,mBAAmB;YAC9C,IAAI,EAAE,kDAAkD;YACxD,UAAU,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;SAC/B,CAAC,CAAC;QAEH,MAAM,cAAc,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC7C,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,2BAA2B;YACtD,IAAI,EAAE,0DAA0D;YAChE,UAAU,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC;SAC/B,CAAC,CAAC;QAEH,MAAM,iBAAiB,GAAG,IAAI,qBAAU,CAAC,SAAS,CAAC;YAClD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,6BAA6B;YACxD,IAAI,EAAE,qCAAqC;YAC3C,UAAU,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;YAC/B,OAAO,EAAE,mCAAwB;SACjC,CAAC,CAAC;QAEH,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,EAAE,EAAE;YACtF,aAAa,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAChD,cAAc,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;YACtC,iBAAiB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,UAAU,GAAG,IAAI,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE;YAC9E,aAAa,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAChD,iBAAiB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,UAAU,GAAG,IAAI,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AA1CY,oEAA4B;uCAA5B,4BAA4B;IADxC,IAAA,YAAO,GAAE;qCAGgC,uCAAqB;QACpC,gCAAuB;QACnB,6BAAoB;GAJtC,4BAA4B,CA0CxC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { PrometheusMetricsConfig } from '@n8n/config';
|
|
2
|
+
import { EventService } from '../../events/event.service';
|
|
3
|
+
import type { PrometheusMetricsCollector } from './base';
|
|
4
|
+
export declare class PrometheusTokenExchangeMetricsService implements PrometheusMetricsCollector {
|
|
5
|
+
private readonly config;
|
|
6
|
+
private readonly eventService;
|
|
7
|
+
constructor(config: PrometheusMetricsConfig, eventService: EventService);
|
|
8
|
+
get enabled(): boolean;
|
|
9
|
+
init(): void;
|
|
10
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PrometheusTokenExchangeMetricsService = void 0;
|
|
16
|
+
const config_1 = require("@n8n/config");
|
|
17
|
+
const di_1 = require("@n8n/di");
|
|
18
|
+
const prom_client_1 = __importDefault(require("prom-client"));
|
|
19
|
+
const event_service_1 = require("../../events/event.service");
|
|
20
|
+
let PrometheusTokenExchangeMetricsService = class PrometheusTokenExchangeMetricsService {
|
|
21
|
+
constructor(config, eventService) {
|
|
22
|
+
this.config = config;
|
|
23
|
+
this.eventService = eventService;
|
|
24
|
+
}
|
|
25
|
+
get enabled() {
|
|
26
|
+
return true;
|
|
27
|
+
}
|
|
28
|
+
init() {
|
|
29
|
+
const tokenExchangeRequestsTotal = new prom_client_1.default.Counter({
|
|
30
|
+
name: `${this.config.prefix}token_exchange_requests_total`,
|
|
31
|
+
help: 'Total number of token exchange requests.',
|
|
32
|
+
labelNames: ['result'],
|
|
33
|
+
});
|
|
34
|
+
tokenExchangeRequestsTotal.inc({ result: 'success' }, 0);
|
|
35
|
+
tokenExchangeRequestsTotal.inc({ result: 'failure' }, 0);
|
|
36
|
+
const tokenExchangeFailuresTotal = new prom_client_1.default.Counter({
|
|
37
|
+
name: `${this.config.prefix}token_exchange_failures_total`,
|
|
38
|
+
help: 'Total number of token exchange failures broken down by reason.',
|
|
39
|
+
labelNames: ['reason'],
|
|
40
|
+
});
|
|
41
|
+
const embedLoginRequestsTotal = new prom_client_1.default.Counter({
|
|
42
|
+
name: `${this.config.prefix}embed_login_requests_total`,
|
|
43
|
+
help: 'Total number of embed login requests.',
|
|
44
|
+
labelNames: ['result'],
|
|
45
|
+
});
|
|
46
|
+
embedLoginRequestsTotal.inc({ result: 'success' }, 0);
|
|
47
|
+
embedLoginRequestsTotal.inc({ result: 'failure' }, 0);
|
|
48
|
+
const embedLoginFailuresTotal = new prom_client_1.default.Counter({
|
|
49
|
+
name: `${this.config.prefix}embed_login_failures_total`,
|
|
50
|
+
help: 'Total number of embed login failures broken down by reason.',
|
|
51
|
+
labelNames: ['reason'],
|
|
52
|
+
});
|
|
53
|
+
const tokenExchangeJitProvisioningTotal = new prom_client_1.default.Counter({
|
|
54
|
+
name: `${this.config.prefix}token_exchange_jit_provisioning_total`,
|
|
55
|
+
help: 'Total number of users JIT-provisioned via token exchange.',
|
|
56
|
+
});
|
|
57
|
+
tokenExchangeJitProvisioningTotal.inc(0);
|
|
58
|
+
const tokenExchangeIdentityLinkedTotal = new prom_client_1.default.Counter({
|
|
59
|
+
name: `${this.config.prefix}token_exchange_identity_linked_total`,
|
|
60
|
+
help: 'Total number of external identities linked to existing users via token exchange.',
|
|
61
|
+
});
|
|
62
|
+
tokenExchangeIdentityLinkedTotal.inc(0);
|
|
63
|
+
this.eventService.on('token-exchange-succeeded', () => {
|
|
64
|
+
tokenExchangeRequestsTotal.inc({ result: 'success' }, 1);
|
|
65
|
+
});
|
|
66
|
+
this.eventService.on('token-exchange-failed', ({ failureReason }) => {
|
|
67
|
+
tokenExchangeRequestsTotal.inc({ result: 'failure' }, 1);
|
|
68
|
+
tokenExchangeFailuresTotal.inc({ reason: failureReason }, 1);
|
|
69
|
+
});
|
|
70
|
+
this.eventService.on('embed-login', () => {
|
|
71
|
+
embedLoginRequestsTotal.inc({ result: 'success' }, 1);
|
|
72
|
+
});
|
|
73
|
+
this.eventService.on('embed-login-failed', ({ failureReason }) => {
|
|
74
|
+
embedLoginRequestsTotal.inc({ result: 'failure' }, 1);
|
|
75
|
+
embedLoginFailuresTotal.inc({ reason: failureReason }, 1);
|
|
76
|
+
});
|
|
77
|
+
this.eventService.on('token-exchange-user-provisioned', () => {
|
|
78
|
+
tokenExchangeJitProvisioningTotal.inc(1);
|
|
79
|
+
});
|
|
80
|
+
this.eventService.on('token-exchange-identity-linked', () => {
|
|
81
|
+
tokenExchangeIdentityLinkedTotal.inc(1);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
exports.PrometheusTokenExchangeMetricsService = PrometheusTokenExchangeMetricsService;
|
|
86
|
+
exports.PrometheusTokenExchangeMetricsService = PrometheusTokenExchangeMetricsService = __decorate([
|
|
87
|
+
(0, di_1.Service)(),
|
|
88
|
+
__metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
|
|
89
|
+
event_service_1.EventService])
|
|
90
|
+
], PrometheusTokenExchangeMetricsService);
|
|
91
|
+
//# sourceMappingURL=token-exchange-metrics.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-exchange-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/token-exchange-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAsD;AACtD,gCAAkC;AAClC,8DAAqC;AAErC,0DAAsD;AAgB/C,IAAM,qCAAqC,GAA3C,MAAM,qCAAqC;IACjD,YACkB,MAA+B,EAC/B,YAA0B;QAD1B,WAAM,GAAN,MAAM,CAAyB;QAC/B,iBAAY,GAAZ,YAAY,CAAc;IACzC,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI;QACH,MAAM,0BAA0B,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACzD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,+BAA+B;YAC1D,IAAI,EAAE,0CAA0C;YAChD,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QACH,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACzD,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QAEzD,MAAM,0BAA0B,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACzD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,+BAA+B;YAC1D,IAAI,EAAE,gEAAgE;YACtE,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QAEH,MAAM,uBAAuB,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACtD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,4BAA4B;YACvD,IAAI,EAAE,uCAAuC;YAC7C,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QACH,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACtD,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QAEtD,MAAM,uBAAuB,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACtD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,4BAA4B;YACvD,IAAI,EAAE,6DAA6D;YACnE,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QAEH,MAAM,iCAAiC,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAChE,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,uCAAuC;YAClE,IAAI,EAAE,2DAA2D;SACjE,CAAC,CAAC;QACH,iCAAiC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEzC,MAAM,gCAAgC,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC/D,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,sCAAsC;YACjE,IAAI,EAAE,kFAAkF;SACxF,CAAC,CAAC;QACH,gCAAgC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAExC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YACrD,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,uBAAuB,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;YACnE,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;YACzD,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,aAAa,EAAE,GAAG,EAAE;YACxC,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,oBAAoB,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;YAChE,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;YACtD,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YAC5D,iCAAiC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YAC3D,gCAAgC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AA7EY,sFAAqC;gDAArC,qCAAqC;IADjD,IAAA,YAAO,GAAE;qCAGiB,gCAAuB;QACjB,4BAAY;GAHhC,qCAAqC,CA6EjD"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { PrometheusMetricsConfig } from '@n8n/config';
|
|
2
|
+
import type { PrometheusMetricsCollector } from './base';
|
|
3
|
+
export declare class PrometheusVersionMetricsService implements PrometheusMetricsCollector {
|
|
4
|
+
private readonly config;
|
|
5
|
+
constructor(config: PrometheusMetricsConfig);
|
|
6
|
+
get enabled(): boolean;
|
|
7
|
+
init(): void;
|
|
8
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PrometheusVersionMetricsService = void 0;
|
|
16
|
+
const config_1 = require("@n8n/config");
|
|
17
|
+
const di_1 = require("@n8n/di");
|
|
18
|
+
const prom_client_1 = __importDefault(require("prom-client"));
|
|
19
|
+
const parse_1 = __importDefault(require("semver/functions/parse"));
|
|
20
|
+
const constants_1 = require("../../constants");
|
|
21
|
+
let PrometheusVersionMetricsService = class PrometheusVersionMetricsService {
|
|
22
|
+
constructor(config) {
|
|
23
|
+
this.config = config;
|
|
24
|
+
}
|
|
25
|
+
get enabled() {
|
|
26
|
+
return true;
|
|
27
|
+
}
|
|
28
|
+
init() {
|
|
29
|
+
const n8nVersion = (0, parse_1.default)(constants_1.N8N_VERSION ?? '0.0.0');
|
|
30
|
+
if (n8nVersion) {
|
|
31
|
+
const versionGauge = new prom_client_1.default.Gauge({
|
|
32
|
+
name: `${this.config.prefix}version_info`,
|
|
33
|
+
help: 'n8n version info.',
|
|
34
|
+
labelNames: ['version', 'major', 'minor', 'patch'],
|
|
35
|
+
});
|
|
36
|
+
const { version, major, minor, patch } = n8nVersion;
|
|
37
|
+
versionGauge.set({ version: 'v' + version, major, minor, patch }, 1);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
exports.PrometheusVersionMetricsService = PrometheusVersionMetricsService;
|
|
42
|
+
exports.PrometheusVersionMetricsService = PrometheusVersionMetricsService = __decorate([
|
|
43
|
+
(0, di_1.Service)(),
|
|
44
|
+
__metadata("design:paramtypes", [config_1.PrometheusMetricsConfig])
|
|
45
|
+
], PrometheusVersionMetricsService);
|
|
46
|
+
//# sourceMappingURL=version-metrics.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"version-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/version-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAsD;AACtD,gCAAkC;AAClC,8DAAqC;AACrC,mEAAiD;AAEjD,2CAA0C;AAMnC,IAAM,+BAA+B,GAArC,MAAM,+BAA+B;IAC3C,YAA6B,MAA+B;QAA/B,WAAM,GAAN,MAAM,CAAyB;IAAG,CAAC;IAEhE,IAAI,OAAO;QACV,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI;QACH,MAAM,UAAU,GAAG,IAAA,eAAW,EAAC,uBAAW,IAAI,OAAO,CAAC,CAAC;QAEvD,IAAI,UAAU,EAAE,CAAC;YAChB,MAAM,YAAY,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;gBACzC,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,cAAc;gBACzC,IAAI,EAAE,mBAAmB;gBACzB,UAAU,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC;aAClD,CAAC,CAAC;YAEH,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,UAAU,CAAC;YACpD,YAAY,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,GAAG,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC;QACtE,CAAC;IACF,CAAC;CACD,CAAA;AArBY,0EAA+B;0CAA/B,+BAA+B;IAD3C,IAAA,YAAO,GAAE;qCAE4B,gCAAuB;GADhD,+BAA+B,CAqB3C"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { PrometheusMetricsConfig } from '@n8n/config';
|
|
2
|
+
import { EventService } from '../../events/event.service';
|
|
3
|
+
import type { PrometheusMetricsCollector } from './base';
|
|
4
|
+
export declare class PrometheusWorkflowExecutionDurationMetricsService implements PrometheusMetricsCollector {
|
|
5
|
+
private readonly config;
|
|
6
|
+
private readonly eventService;
|
|
7
|
+
constructor(config: PrometheusMetricsConfig, eventService: EventService);
|
|
8
|
+
get enabled(): boolean;
|
|
9
|
+
init(): void;
|
|
10
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PrometheusWorkflowExecutionDurationMetricsService = void 0;
|
|
16
|
+
const config_1 = require("@n8n/config");
|
|
17
|
+
const di_1 = require("@n8n/di");
|
|
18
|
+
const prom_client_1 = __importDefault(require("prom-client"));
|
|
19
|
+
const event_service_1 = require("../../events/event.service");
|
|
20
|
+
const constant_1 = require("./constant");
|
|
21
|
+
let PrometheusWorkflowExecutionDurationMetricsService = class PrometheusWorkflowExecutionDurationMetricsService {
|
|
22
|
+
constructor(config, eventService) {
|
|
23
|
+
this.config = config;
|
|
24
|
+
this.eventService = eventService;
|
|
25
|
+
}
|
|
26
|
+
get enabled() {
|
|
27
|
+
return this.config.includeWorkflowExecutionDuration;
|
|
28
|
+
}
|
|
29
|
+
init() {
|
|
30
|
+
const labelNames = ['status', 'mode'];
|
|
31
|
+
if (this.config.includeWorkflowIdLabel) {
|
|
32
|
+
labelNames.push('workflow_id');
|
|
33
|
+
}
|
|
34
|
+
const durationHistogram = new prom_client_1.default.Histogram({
|
|
35
|
+
name: `${this.config.prefix}workflow_execution_duration_seconds`,
|
|
36
|
+
help: 'Workflow execution duration in seconds.',
|
|
37
|
+
labelNames,
|
|
38
|
+
buckets: constant_1.DURATION_BUCKETS_SECONDS,
|
|
39
|
+
});
|
|
40
|
+
this.eventService.on('workflow-post-execute', ({ runData, workflow }) => {
|
|
41
|
+
if (runData?.stoppedAt) {
|
|
42
|
+
const durationSeconds = (runData.stoppedAt.getTime() - runData.startedAt.getTime()) / 1000;
|
|
43
|
+
const labels = {
|
|
44
|
+
status: runData.status === 'success' ? 'success' : 'failed',
|
|
45
|
+
mode: runData.mode,
|
|
46
|
+
};
|
|
47
|
+
if (this.config.includeWorkflowIdLabel) {
|
|
48
|
+
labels.workflow_id = String(workflow.id ?? 'unknown');
|
|
49
|
+
}
|
|
50
|
+
durationHistogram.observe(labels, durationSeconds);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
exports.PrometheusWorkflowExecutionDurationMetricsService = PrometheusWorkflowExecutionDurationMetricsService;
|
|
56
|
+
exports.PrometheusWorkflowExecutionDurationMetricsService = PrometheusWorkflowExecutionDurationMetricsService = __decorate([
|
|
57
|
+
(0, di_1.Service)(),
|
|
58
|
+
__metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
|
|
59
|
+
event_service_1.EventService])
|
|
60
|
+
], PrometheusWorkflowExecutionDurationMetricsService);
|
|
61
|
+
//# sourceMappingURL=workflow-execution-duration-metrics.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-execution-duration-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/workflow-execution-duration-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAsD;AACtD,gCAAkC;AAClC,8DAAqC;AAErC,0DAAsD;AAGtD,yCAAsD;AAQ/C,IAAM,iDAAiD,GAAvD,MAAM,iDAAiD;IAG7D,YACkB,MAA+B,EAC/B,YAA0B;QAD1B,WAAM,GAAN,MAAM,CAAyB;QAC/B,iBAAY,GAAZ,YAAY,CAAc;IACzC,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,gCAAgC,CAAC;IACrD,CAAC;IAED,IAAI;QACH,MAAM,UAAU,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QACtC,IAAI,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;YACxC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAChC,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,qBAAU,CAAC,SAAS,CAAC;YAClD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,qCAAqC;YAChE,IAAI,EAAE,yCAAyC;YAC/C,UAAU;YACV,OAAO,EAAE,mCAAwB;SACjC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,uBAAuB,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE;YACvE,IAAI,OAAO,EAAE,SAAS,EAAE,CAAC;gBACxB,MAAM,eAAe,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC;gBAC3F,MAAM,MAAM,GAA2B;oBACtC,MAAM,EAAE,OAAO,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ;oBAC3D,IAAI,EAAE,OAAO,CAAC,IAAI;iBAClB,CAAC;gBAEF,IAAI,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;oBACxC,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC,QAAQ,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC;gBACvD,CAAC;gBAED,iBAAiB,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;YACpD,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AAzCY,8GAAiD;4DAAjD,iDAAiD;IAD7D,IAAA,YAAO,GAAE;qCAKiB,gCAAuB;QACjB,4BAAY;GALhC,iDAAiD,CAyC7D"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { PrometheusMetricsConfig } from '@n8n/config';
|
|
2
|
+
import { LicenseMetricsRepository } from '@n8n/db';
|
|
3
|
+
import { CacheService } from '../../services/cache/cache.service';
|
|
4
|
+
import type { PrometheusMetricsCollector } from './base';
|
|
5
|
+
export declare class PrometheusWorkflowStatisticsMetricsService implements PrometheusMetricsCollector {
|
|
6
|
+
private readonly config;
|
|
7
|
+
private readonly cacheService;
|
|
8
|
+
private readonly licenseMetricsRepository;
|
|
9
|
+
private workflowStatisticsCache;
|
|
10
|
+
private inFlightRequest;
|
|
11
|
+
constructor(config: PrometheusMetricsConfig, cacheService: CacheService, licenseMetricsRepository: LicenseMetricsRepository);
|
|
12
|
+
get enabled(): boolean;
|
|
13
|
+
init(): void;
|
|
14
|
+
private createWorkflowStatisticsGauge;
|
|
15
|
+
private getWorkflowStatistics;
|
|
16
|
+
private fetchAndCacheMetrics;
|
|
17
|
+
}
|