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,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.resolveOutputRedaction = resolveOutputRedaction;
|
|
4
|
+
const agents_1 = require("@n8n/agents");
|
|
5
|
+
function resolveOutputRedaction(config) {
|
|
6
|
+
if (!config.outputRedactionEnabled)
|
|
7
|
+
return false;
|
|
8
|
+
const detect = config.outputRedactionPii
|
|
9
|
+
.split(',')
|
|
10
|
+
.map((value) => value.trim())
|
|
11
|
+
.filter((value) => agents_1.SUPPORTED_PII_CATEGORIES.includes(value));
|
|
12
|
+
const placeholder = config.outputRedactionPlaceholder;
|
|
13
|
+
return {
|
|
14
|
+
secrets: config.outputRedactionSecrets,
|
|
15
|
+
detect,
|
|
16
|
+
...(placeholder ? { placeholder } : {}),
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=output-redaction-config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"output-redaction-config.js","sourceRoot":"","sources":["../../../src/modules/instance-ai/output-redaction-config.ts"],"names":[],"mappings":";;AAWA,wDAiBC;AA5BD,wCAIqB;AAOrB,SAAgB,sBAAsB,CAAC,MAAwB;IAC9D,IAAI,CAAC,MAAM,CAAC,sBAAsB;QAAE,OAAO,KAAK,CAAC;IAEjD,MAAM,MAAM,GAAG,MAAM,CAAC,kBAAkB;SACtC,KAAK,CAAC,GAAG,CAAC;SACV,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;SAC5B,MAAM,CAAC,CAAC,KAAK,EAA6B,EAAE,CAC3C,iCAA8C,CAAC,QAAQ,CAAC,KAAK,CAAC,CAC/D,CAAC;IAEH,MAAM,WAAW,GAAG,MAAM,CAAC,0BAA0B,CAAC;IACtD,OAAO;QACN,OAAO,EAAE,MAAM,CAAC,sBAAsB;QACtC,MAAM;QAEN,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACvC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { InstanceAiSandboxService, type InstanceAiSandboxBackgroundTasks, type InstanceAiSandboxProxy, type InstanceAiSandboxRunState, type InstanceAiSandboxServiceOptions, type InstanceAiSandboxSettings, type RuntimeSandboxEntry, } from './instance-ai-sandbox.service';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InstanceAiSandboxService = void 0;
|
|
4
|
+
var instance_ai_sandbox_service_1 = require("./instance-ai-sandbox.service");
|
|
5
|
+
Object.defineProperty(exports, "InstanceAiSandboxService", { enumerable: true, get: function () { return instance_ai_sandbox_service_1.InstanceAiSandboxService; } });
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/modules/instance-ai/sandbox/index.ts"],"names":[],"mappings":";;;AAAA,6EAQuC;AAPtC,uIAAA,wBAAwB,OAAA"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import type { InstanceAiConfig } from '@n8n/config';
|
|
2
|
+
import type { User } from '@n8n/db';
|
|
3
|
+
import { createSandbox, createWorkspace, type InstanceAiContext, type Logger, type ManagedBackgroundTask, type SandboxConfig } from '@n8n/instance-ai';
|
|
4
|
+
import type { ErrorReporter } from 'n8n-core';
|
|
5
|
+
export type RuntimeSandboxEntry = {
|
|
6
|
+
sandbox: NonNullable<Awaited<ReturnType<typeof createSandbox>>>;
|
|
7
|
+
workspace: NonNullable<ReturnType<typeof createWorkspace>>;
|
|
8
|
+
setupComplete: boolean;
|
|
9
|
+
setupPromise: Promise<void> | undefined;
|
|
10
|
+
expiresAt: number;
|
|
11
|
+
cleanupTimer?: ReturnType<typeof setTimeout>;
|
|
12
|
+
};
|
|
13
|
+
export type InstanceAiSandboxRunState = {
|
|
14
|
+
getActiveRunId: (threadId: string) => string | undefined;
|
|
15
|
+
hasSuspendedRun: (threadId: string) => boolean;
|
|
16
|
+
};
|
|
17
|
+
export type InstanceAiSandboxBackgroundTasks = {
|
|
18
|
+
getRunningTasks: (threadId: string) => ManagedBackgroundTask[];
|
|
19
|
+
};
|
|
20
|
+
export type InstanceAiSandboxSettings = {
|
|
21
|
+
resolveDaytonaConfig: (user: User) => Promise<{
|
|
22
|
+
apiUrl?: string;
|
|
23
|
+
apiKey?: string;
|
|
24
|
+
}>;
|
|
25
|
+
resolveN8nSandboxConfig: (user: User) => Promise<{
|
|
26
|
+
serviceUrl?: string;
|
|
27
|
+
apiKey?: string;
|
|
28
|
+
}>;
|
|
29
|
+
};
|
|
30
|
+
export type InstanceAiSandboxProxy = {
|
|
31
|
+
isProxyEnabled: () => boolean;
|
|
32
|
+
getClient: () => Promise<{
|
|
33
|
+
getSandboxProxyConfig: () => Promise<{
|
|
34
|
+
image?: string;
|
|
35
|
+
}>;
|
|
36
|
+
getSandboxProxyBaseUrl: () => string;
|
|
37
|
+
getBuilderApiProxyToken: (user: {
|
|
38
|
+
id: string;
|
|
39
|
+
}, options: {
|
|
40
|
+
userMessageId: string;
|
|
41
|
+
}) => Promise<{
|
|
42
|
+
accessToken: string;
|
|
43
|
+
}>;
|
|
44
|
+
}>;
|
|
45
|
+
};
|
|
46
|
+
export type InstanceAiSandboxServiceOptions = {
|
|
47
|
+
config: InstanceAiConfig;
|
|
48
|
+
logger: Logger;
|
|
49
|
+
errorReporter: ErrorReporter;
|
|
50
|
+
runState: InstanceAiSandboxRunState;
|
|
51
|
+
backgroundTasks: InstanceAiSandboxBackgroundTasks;
|
|
52
|
+
settingsService: InstanceAiSandboxSettings;
|
|
53
|
+
aiService: InstanceAiSandboxProxy;
|
|
54
|
+
};
|
|
55
|
+
export declare class InstanceAiSandboxService {
|
|
56
|
+
private readonly options;
|
|
57
|
+
private readonly sandboxes;
|
|
58
|
+
private readonly sandboxCreations;
|
|
59
|
+
constructor(options: InstanceAiSandboxServiceOptions);
|
|
60
|
+
private get logger();
|
|
61
|
+
private get instanceAiConfig();
|
|
62
|
+
getSandboxConfigFromEnv(): SandboxConfig;
|
|
63
|
+
resolveSandboxConfig(user: User): Promise<SandboxConfig>;
|
|
64
|
+
getOrCreateWorkspaceEntry(threadId: string, user: User): Promise<RuntimeSandboxEntry | undefined>;
|
|
65
|
+
getOrCreateWorkspace(threadId: string, user: User, context: InstanceAiContext): Promise<RuntimeSandboxEntry | undefined>;
|
|
66
|
+
private ensureWorkspaceSetup;
|
|
67
|
+
private createWorkspaceEntry;
|
|
68
|
+
private evictSandboxEntry;
|
|
69
|
+
destroySandbox(threadId: string, reason?: string): Promise<void>;
|
|
70
|
+
private get sandboxTtlMs();
|
|
71
|
+
private nextSandboxExpiry;
|
|
72
|
+
private isSandboxEntryExpired;
|
|
73
|
+
private touchSandboxEntry;
|
|
74
|
+
private isSandboxInUse;
|
|
75
|
+
private scheduleSandboxExpiry;
|
|
76
|
+
stopSandboxExpiryTimers(): void;
|
|
77
|
+
}
|
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InstanceAiSandboxService = void 0;
|
|
4
|
+
const instance_ai_1 = require("@n8n/instance-ai");
|
|
5
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
6
|
+
const nanoid_1 = require("nanoid");
|
|
7
|
+
const constants_1 = require("../../../constants");
|
|
8
|
+
const sandbox_provider_1 = require("../sandbox-provider");
|
|
9
|
+
const SANDBOX_NAME_MAX_LEN = 63;
|
|
10
|
+
const SANDBOX_LABEL_MAX_LEN = 63;
|
|
11
|
+
const NAME_PREFIX_SLUG_MAX_LEN = 24;
|
|
12
|
+
const DEFAULT_SANDBOX_TTL_MS = 15 * 60 * 1000;
|
|
13
|
+
function slugifySandboxName(value, maxLen) {
|
|
14
|
+
const slug = value
|
|
15
|
+
.toLowerCase()
|
|
16
|
+
.replace(/[^a-z0-9]+/g, '-')
|
|
17
|
+
.replace(/^-+|-+$/g, '');
|
|
18
|
+
return slug.slice(0, maxLen).replace(/-+$/, '');
|
|
19
|
+
}
|
|
20
|
+
function slugifySandboxLabel(value, maxLen) {
|
|
21
|
+
return value
|
|
22
|
+
.replace(/[^A-Za-z0-9_.-]+/g, '-')
|
|
23
|
+
.replace(/^[-.]+|[-.]+$/g, '')
|
|
24
|
+
.slice(0, maxLen)
|
|
25
|
+
.replace(/[-.]+$/, '');
|
|
26
|
+
}
|
|
27
|
+
function getThreadScopedSandboxName(threadId) {
|
|
28
|
+
return `instance-ai-thread-${threadId}`;
|
|
29
|
+
}
|
|
30
|
+
function buildThreadScopedSandboxName(threadId, namePrefix) {
|
|
31
|
+
const parts = [];
|
|
32
|
+
if (namePrefix) {
|
|
33
|
+
const prefixSlug = slugifySandboxName(namePrefix, NAME_PREFIX_SLUG_MAX_LEN);
|
|
34
|
+
if (prefixSlug)
|
|
35
|
+
parts.push(prefixSlug);
|
|
36
|
+
}
|
|
37
|
+
const threadSlug = slugifySandboxName(getThreadScopedSandboxName(threadId), SANDBOX_NAME_MAX_LEN);
|
|
38
|
+
if (threadSlug)
|
|
39
|
+
parts.push(threadSlug);
|
|
40
|
+
const name = slugifySandboxName(parts.join('-'), SANDBOX_NAME_MAX_LEN);
|
|
41
|
+
if (!name)
|
|
42
|
+
throw new n8n_workflow_1.UnexpectedError('Failed to build thread-scoped sandbox name');
|
|
43
|
+
return name;
|
|
44
|
+
}
|
|
45
|
+
function buildThreadScopedSandboxLabels(threadId, namePrefix) {
|
|
46
|
+
const baseName = getThreadScopedSandboxName(threadId);
|
|
47
|
+
const labels = {
|
|
48
|
+
'n8n-builder': slugifySandboxLabel(baseName, SANDBOX_LABEL_MAX_LEN),
|
|
49
|
+
thread_id: slugifySandboxLabel(threadId, SANDBOX_LABEL_MAX_LEN),
|
|
50
|
+
};
|
|
51
|
+
if (namePrefix)
|
|
52
|
+
labels.name_prefix = slugifySandboxLabel(namePrefix, SANDBOX_LABEL_MAX_LEN);
|
|
53
|
+
return labels;
|
|
54
|
+
}
|
|
55
|
+
function withThreadScopedSandboxIdentity(config, threadId) {
|
|
56
|
+
if (!config.enabled || config.provider !== 'daytona')
|
|
57
|
+
return config;
|
|
58
|
+
const name = buildThreadScopedSandboxName(threadId, config.namePrefix);
|
|
59
|
+
return {
|
|
60
|
+
...config,
|
|
61
|
+
id: name,
|
|
62
|
+
name,
|
|
63
|
+
labels: {
|
|
64
|
+
...buildThreadScopedSandboxLabels(threadId, config.namePrefix),
|
|
65
|
+
...config.labels,
|
|
66
|
+
},
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
class InstanceAiSandboxService {
|
|
70
|
+
constructor(options) {
|
|
71
|
+
this.options = options;
|
|
72
|
+
this.sandboxes = new Map();
|
|
73
|
+
this.sandboxCreations = new Map();
|
|
74
|
+
}
|
|
75
|
+
get logger() {
|
|
76
|
+
return this.options.logger;
|
|
77
|
+
}
|
|
78
|
+
get instanceAiConfig() {
|
|
79
|
+
return this.options.config;
|
|
80
|
+
}
|
|
81
|
+
getSandboxConfigFromEnv() {
|
|
82
|
+
const { sandboxEnabled, sandboxProvider, daytonaApiUrl, daytonaApiKey, n8nSandboxServiceUrl, n8nSandboxServiceApiKey, sandboxImage, sandboxTimeout, sandboxNamePrefix, sandboxEphemeral, sandboxAutoStopMinutes, sandboxAutoArchiveMinutes, sandboxAutoDeleteMinutes, daytonaTokenRefreshSkewMs, } = this.instanceAiConfig;
|
|
83
|
+
const provider = (0, sandbox_provider_1.normalizeSandboxProvider)(sandboxProvider);
|
|
84
|
+
if (!sandboxEnabled) {
|
|
85
|
+
return {
|
|
86
|
+
enabled: false,
|
|
87
|
+
provider,
|
|
88
|
+
timeout: sandboxTimeout,
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
if (provider === 'daytona') {
|
|
92
|
+
return {
|
|
93
|
+
enabled: true,
|
|
94
|
+
provider: 'daytona',
|
|
95
|
+
daytonaApiUrl: daytonaApiUrl || undefined,
|
|
96
|
+
daytonaApiKey: daytonaApiKey || undefined,
|
|
97
|
+
image: sandboxImage || undefined,
|
|
98
|
+
n8nVersion: constants_1.N8N_VERSION || undefined,
|
|
99
|
+
timeout: sandboxTimeout,
|
|
100
|
+
namePrefix: sandboxNamePrefix || undefined,
|
|
101
|
+
ephemeral: sandboxEphemeral,
|
|
102
|
+
autoStopInterval: sandboxAutoStopMinutes,
|
|
103
|
+
autoArchiveInterval: sandboxAutoArchiveMinutes,
|
|
104
|
+
autoDeleteInterval: sandboxEphemeral ? undefined : sandboxAutoDeleteMinutes,
|
|
105
|
+
refreshSkewMs: daytonaTokenRefreshSkewMs,
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
return {
|
|
109
|
+
enabled: true,
|
|
110
|
+
provider: 'n8n-sandbox',
|
|
111
|
+
serviceUrl: (0, sandbox_provider_1.requireN8nSandboxServiceUrl)(n8nSandboxServiceUrl),
|
|
112
|
+
apiKey: n8nSandboxServiceApiKey || undefined,
|
|
113
|
+
timeout: sandboxTimeout,
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
async resolveSandboxConfig(user) {
|
|
117
|
+
const base = this.getSandboxConfigFromEnv();
|
|
118
|
+
if (!base.enabled)
|
|
119
|
+
return base;
|
|
120
|
+
if (base.provider === 'daytona') {
|
|
121
|
+
if (this.options.aiService.isProxyEnabled()) {
|
|
122
|
+
const client = await this.options.aiService.getClient();
|
|
123
|
+
const proxyConfig = await client.getSandboxProxyConfig();
|
|
124
|
+
return {
|
|
125
|
+
...base,
|
|
126
|
+
daytonaApiUrl: client.getSandboxProxyBaseUrl(),
|
|
127
|
+
image: proxyConfig.image,
|
|
128
|
+
logger: this.logger,
|
|
129
|
+
getAuthToken: async () => {
|
|
130
|
+
const token = await client.getBuilderApiProxyToken({ id: user.id }, { userMessageId: (0, nanoid_1.nanoid)() });
|
|
131
|
+
return token.accessToken;
|
|
132
|
+
},
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
const daytona = await this.options.settingsService.resolveDaytonaConfig(user);
|
|
136
|
+
return {
|
|
137
|
+
...base,
|
|
138
|
+
daytonaApiUrl: daytona.apiUrl ?? base.daytonaApiUrl,
|
|
139
|
+
daytonaApiKey: daytona.apiKey ?? base.daytonaApiKey,
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
const sandbox = await this.options.settingsService.resolveN8nSandboxConfig(user);
|
|
143
|
+
return {
|
|
144
|
+
...base,
|
|
145
|
+
serviceUrl: sandbox.serviceUrl ?? base.serviceUrl,
|
|
146
|
+
apiKey: sandbox.apiKey ?? base.apiKey,
|
|
147
|
+
};
|
|
148
|
+
}
|
|
149
|
+
async getOrCreateWorkspaceEntry(threadId, user) {
|
|
150
|
+
const existing = this.sandboxes.get(threadId);
|
|
151
|
+
if (existing) {
|
|
152
|
+
if (this.isSandboxEntryExpired(existing) && !this.isSandboxInUse(threadId)) {
|
|
153
|
+
this.evictSandboxEntry(threadId, existing);
|
|
154
|
+
}
|
|
155
|
+
else {
|
|
156
|
+
this.touchSandboxEntry(threadId, existing);
|
|
157
|
+
return existing;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
const pending = this.sandboxCreations.get(threadId);
|
|
161
|
+
if (pending)
|
|
162
|
+
return await pending;
|
|
163
|
+
const creation = this.createWorkspaceEntry(threadId, user);
|
|
164
|
+
this.sandboxCreations.set(threadId, creation);
|
|
165
|
+
try {
|
|
166
|
+
return await creation;
|
|
167
|
+
}
|
|
168
|
+
finally {
|
|
169
|
+
this.sandboxCreations.delete(threadId);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
async getOrCreateWorkspace(threadId, user, context) {
|
|
173
|
+
const entry = await this.getOrCreateWorkspaceEntry(threadId, user);
|
|
174
|
+
if (entry)
|
|
175
|
+
await this.ensureWorkspaceSetup(entry, context);
|
|
176
|
+
return entry;
|
|
177
|
+
}
|
|
178
|
+
async ensureWorkspaceSetup(entry, context) {
|
|
179
|
+
if (entry.setupComplete)
|
|
180
|
+
return;
|
|
181
|
+
entry.setupPromise ??= (0, instance_ai_1.setupSandboxWorkspace)(entry.workspace, context)
|
|
182
|
+
.then(() => {
|
|
183
|
+
entry.setupComplete = true;
|
|
184
|
+
})
|
|
185
|
+
.finally(() => {
|
|
186
|
+
entry.setupPromise = undefined;
|
|
187
|
+
});
|
|
188
|
+
await entry.setupPromise;
|
|
189
|
+
}
|
|
190
|
+
async createWorkspaceEntry(threadId, user) {
|
|
191
|
+
const config = withThreadScopedSandboxIdentity(await this.resolveSandboxConfig(user), threadId);
|
|
192
|
+
if (!config.enabled)
|
|
193
|
+
return undefined;
|
|
194
|
+
const sandbox = await (0, instance_ai_1.createSandbox)(config, {
|
|
195
|
+
logger: this.logger,
|
|
196
|
+
errorReporter: this.options.errorReporter,
|
|
197
|
+
useSnapshotFallback: true,
|
|
198
|
+
});
|
|
199
|
+
const workspace = (0, instance_ai_1.createWorkspace)(sandbox);
|
|
200
|
+
if (!sandbox || !workspace)
|
|
201
|
+
return undefined;
|
|
202
|
+
try {
|
|
203
|
+
await workspace.init();
|
|
204
|
+
}
|
|
205
|
+
catch (error) {
|
|
206
|
+
try {
|
|
207
|
+
await workspace.destroy();
|
|
208
|
+
}
|
|
209
|
+
catch {
|
|
210
|
+
}
|
|
211
|
+
throw error;
|
|
212
|
+
}
|
|
213
|
+
const entry = {
|
|
214
|
+
sandbox,
|
|
215
|
+
workspace,
|
|
216
|
+
setupComplete: false,
|
|
217
|
+
setupPromise: undefined,
|
|
218
|
+
expiresAt: this.nextSandboxExpiry(),
|
|
219
|
+
};
|
|
220
|
+
this.sandboxes.set(threadId, entry);
|
|
221
|
+
this.scheduleSandboxExpiry(threadId, entry);
|
|
222
|
+
return entry;
|
|
223
|
+
}
|
|
224
|
+
evictSandboxEntry(threadId, entry) {
|
|
225
|
+
if (this.sandboxes.get(threadId) !== entry)
|
|
226
|
+
return;
|
|
227
|
+
this.sandboxes.delete(threadId);
|
|
228
|
+
if (entry.cleanupTimer) {
|
|
229
|
+
clearTimeout(entry.cleanupTimer);
|
|
230
|
+
entry.cleanupTimer = undefined;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
async destroySandbox(threadId, reason = 'thread_cleanup') {
|
|
234
|
+
const entry = this.sandboxes.get(threadId);
|
|
235
|
+
if (!entry?.sandbox)
|
|
236
|
+
return;
|
|
237
|
+
this.evictSandboxEntry(threadId, entry);
|
|
238
|
+
try {
|
|
239
|
+
await entry.workspace?.destroy();
|
|
240
|
+
}
|
|
241
|
+
catch (error) {
|
|
242
|
+
this.logger.warn('Failed to destroy sandbox', {
|
|
243
|
+
threadId,
|
|
244
|
+
reason,
|
|
245
|
+
error: error instanceof Error ? error.message : String(error),
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
get sandboxTtlMs() {
|
|
250
|
+
return this.instanceAiConfig?.builderSandboxTtlMs ?? DEFAULT_SANDBOX_TTL_MS;
|
|
251
|
+
}
|
|
252
|
+
nextSandboxExpiry() {
|
|
253
|
+
return Date.now() + this.sandboxTtlMs;
|
|
254
|
+
}
|
|
255
|
+
isSandboxEntryExpired(entry) {
|
|
256
|
+
return this.sandboxTtlMs > 0 && entry.expiresAt <= Date.now();
|
|
257
|
+
}
|
|
258
|
+
touchSandboxEntry(threadId, entry) {
|
|
259
|
+
if (this.sandboxTtlMs <= 0)
|
|
260
|
+
return;
|
|
261
|
+
entry.expiresAt = this.nextSandboxExpiry();
|
|
262
|
+
this.scheduleSandboxExpiry(threadId, entry);
|
|
263
|
+
}
|
|
264
|
+
isSandboxInUse(threadId) {
|
|
265
|
+
return Boolean(this.options.runState.getActiveRunId(threadId) ||
|
|
266
|
+
this.options.runState.hasSuspendedRun(threadId) ||
|
|
267
|
+
this.options.backgroundTasks.getRunningTasks(threadId).length > 0);
|
|
268
|
+
}
|
|
269
|
+
scheduleSandboxExpiry(threadId, entry) {
|
|
270
|
+
if (this.sandboxTtlMs <= 0)
|
|
271
|
+
return;
|
|
272
|
+
if (entry.cleanupTimer)
|
|
273
|
+
clearTimeout(entry.cleanupTimer);
|
|
274
|
+
const delay = Math.max(0, entry.expiresAt - Date.now());
|
|
275
|
+
entry.cleanupTimer = setTimeout(() => {
|
|
276
|
+
const current = this.sandboxes.get(threadId);
|
|
277
|
+
if (current !== entry)
|
|
278
|
+
return;
|
|
279
|
+
if (this.isSandboxInUse(threadId)) {
|
|
280
|
+
this.touchSandboxEntry(threadId, entry);
|
|
281
|
+
return;
|
|
282
|
+
}
|
|
283
|
+
this.evictSandboxEntry(threadId, entry);
|
|
284
|
+
}, delay);
|
|
285
|
+
entry.cleanupTimer.unref();
|
|
286
|
+
}
|
|
287
|
+
stopSandboxExpiryTimers() {
|
|
288
|
+
for (const entry of this.sandboxes.values()) {
|
|
289
|
+
if (!entry.cleanupTimer)
|
|
290
|
+
continue;
|
|
291
|
+
clearTimeout(entry.cleanupTimer);
|
|
292
|
+
entry.cleanupTimer = undefined;
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
exports.InstanceAiSandboxService = InstanceAiSandboxService;
|
|
297
|
+
//# sourceMappingURL=instance-ai-sandbox.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instance-ai-sandbox.service.js","sourceRoot":"","sources":["../../../../src/modules/instance-ai/sandbox/instance-ai-sandbox.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import type { InstanceAiEvent } from '@n8n/api-types';
|
|
2
|
+
import type { Logger } from '@n8n/backend-common';
|
|
3
|
+
import type { User } from '@n8n/db';
|
|
4
|
+
import type { ConfirmationData, SuspendedRunState } from '@n8n/instance-ai';
|
|
5
|
+
import type { InstanceAiPendingConfirmation } from './entities/instance-ai-pending-confirmation.entity';
|
|
6
|
+
import type { InstanceAiPendingConfirmationRepository } from './repositories/instance-ai-pending-confirmation.repository';
|
|
7
|
+
import type { DbSnapshotStorage } from './storage/db-snapshot-storage';
|
|
8
|
+
type ClaimedOrphan = InstanceAiPendingConfirmation;
|
|
9
|
+
export type ResumableOrphan = ClaimedOrphan & {
|
|
10
|
+
toolCallId: string;
|
|
11
|
+
checkpointKey: string;
|
|
12
|
+
};
|
|
13
|
+
export type RebuildSuspendedRunOutcome = {
|
|
14
|
+
kind: 'ready';
|
|
15
|
+
state: SuspendedRunState<User>;
|
|
16
|
+
} | {
|
|
17
|
+
kind: 'no-user';
|
|
18
|
+
} | {
|
|
19
|
+
kind: 'no-checkpoint';
|
|
20
|
+
error?: unknown;
|
|
21
|
+
} | {
|
|
22
|
+
kind: 'env-failure';
|
|
23
|
+
error: unknown;
|
|
24
|
+
} | {
|
|
25
|
+
kind: 'agent-failure';
|
|
26
|
+
error: unknown;
|
|
27
|
+
};
|
|
28
|
+
export interface SuspendedRunRebuilder {
|
|
29
|
+
rebuildSuspendedRun(orphan: ResumableOrphan): Promise<RebuildSuspendedRunOutcome>;
|
|
30
|
+
resumeSuspendedRun(requestingUserId: string, requestId: string, data: ConfirmationData): Promise<boolean>;
|
|
31
|
+
}
|
|
32
|
+
export type OrphanConfirmationStore = Pick<InstanceAiPendingConfirmationRepository, 'claim'>;
|
|
33
|
+
export interface SuspendedRunStateRegistry {
|
|
34
|
+
suspendRun(threadId: string, state: SuspendedRunState<User>): void;
|
|
35
|
+
}
|
|
36
|
+
export type RunSnapshotCanceller = Pick<DbSnapshotStorage, 'markRunCancelled'>;
|
|
37
|
+
export interface RunFinishEventPublisher {
|
|
38
|
+
publish(threadId: string, event: InstanceAiEvent): void;
|
|
39
|
+
}
|
|
40
|
+
export interface SuspendedRunRestorerOptions {
|
|
41
|
+
logger: Logger;
|
|
42
|
+
pendingConfirmationRepo: OrphanConfirmationStore;
|
|
43
|
+
runState: SuspendedRunStateRegistry;
|
|
44
|
+
dbSnapshotStorage: RunSnapshotCanceller;
|
|
45
|
+
eventBus: RunFinishEventPublisher;
|
|
46
|
+
rebuilder: SuspendedRunRebuilder;
|
|
47
|
+
}
|
|
48
|
+
export declare class SuspendedRunRestorer {
|
|
49
|
+
private readonly logger;
|
|
50
|
+
private readonly pendingConfirmationRepo;
|
|
51
|
+
private readonly runState;
|
|
52
|
+
private readonly dbSnapshotStorage;
|
|
53
|
+
private readonly eventBus;
|
|
54
|
+
private readonly rebuilder;
|
|
55
|
+
constructor(options: SuspendedRunRestorerOptions);
|
|
56
|
+
resolveOrphanedConfirmation(userId: string, requestId: string, data: ConfirmationData): Promise<boolean>;
|
|
57
|
+
private canResumeOrphan;
|
|
58
|
+
private finalizeUnresumableOrphan;
|
|
59
|
+
private publishRunFinish;
|
|
60
|
+
private tryResumeFromOrphan;
|
|
61
|
+
}
|
|
62
|
+
export {};
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SuspendedRunRestorer = void 0;
|
|
4
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
5
|
+
const ORCHESTRATOR_AGENT_ID = 'agent-001';
|
|
6
|
+
function getErrorMessage(error) {
|
|
7
|
+
return error instanceof Error ? error.message : String(error);
|
|
8
|
+
}
|
|
9
|
+
class SuspendedRunRestorer {
|
|
10
|
+
constructor(options) {
|
|
11
|
+
this.logger = options.logger;
|
|
12
|
+
this.pendingConfirmationRepo = options.pendingConfirmationRepo;
|
|
13
|
+
this.runState = options.runState;
|
|
14
|
+
this.dbSnapshotStorage = options.dbSnapshotStorage;
|
|
15
|
+
this.eventBus = options.eventBus;
|
|
16
|
+
this.rebuilder = options.rebuilder;
|
|
17
|
+
}
|
|
18
|
+
async resolveOrphanedConfirmation(userId, requestId, data) {
|
|
19
|
+
let orphan;
|
|
20
|
+
try {
|
|
21
|
+
orphan = await this.pendingConfirmationRepo.claim(requestId, userId);
|
|
22
|
+
}
|
|
23
|
+
catch (error) {
|
|
24
|
+
this.logger.warn('Failed to claim orphaned pending confirmation', {
|
|
25
|
+
requestId,
|
|
26
|
+
error: getErrorMessage(error),
|
|
27
|
+
});
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
if (!orphan)
|
|
31
|
+
return false;
|
|
32
|
+
this.logger.info('Reclaiming pending confirmation orphaned by a process restart', {
|
|
33
|
+
requestId,
|
|
34
|
+
threadId: orphan.threadId,
|
|
35
|
+
runId: orphan.runId,
|
|
36
|
+
kind: orphan.kind,
|
|
37
|
+
hasCheckpoint: Boolean(orphan.checkpointKey),
|
|
38
|
+
});
|
|
39
|
+
if (orphan.kind === 'suspended' && this.canResumeOrphan(orphan)) {
|
|
40
|
+
const resumed = await this.tryResumeFromOrphan(orphan, data);
|
|
41
|
+
if (resumed)
|
|
42
|
+
return true;
|
|
43
|
+
}
|
|
44
|
+
this.finalizeUnresumableOrphan(orphan);
|
|
45
|
+
throw new n8n_workflow_1.UserError('This confirmation was lost when the assistant restarted. Send a new message to continue.');
|
|
46
|
+
}
|
|
47
|
+
canResumeOrphan(orphan) {
|
|
48
|
+
return Boolean(orphan.toolCallId && orphan.checkpointKey);
|
|
49
|
+
}
|
|
50
|
+
finalizeUnresumableOrphan(orphan) {
|
|
51
|
+
try {
|
|
52
|
+
this.publishRunFinish(orphan.threadId, orphan.runId, 'restart_lost_confirmation');
|
|
53
|
+
void this.dbSnapshotStorage
|
|
54
|
+
.markRunCancelled(orphan.threadId, orphan.runId)
|
|
55
|
+
.catch((error) => {
|
|
56
|
+
this.logger.warn('Failed to mark orphan snapshot as cancelled', {
|
|
57
|
+
requestId: orphan.requestId,
|
|
58
|
+
threadId: orphan.threadId,
|
|
59
|
+
runId: orphan.runId,
|
|
60
|
+
error: getErrorMessage(error),
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
catch (error) {
|
|
65
|
+
this.logger.warn('Failed to finalize orphaned confirmation snapshot', {
|
|
66
|
+
requestId: orphan.requestId,
|
|
67
|
+
error: getErrorMessage(error),
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
publishRunFinish(threadId, runId, reason) {
|
|
72
|
+
this.eventBus.publish(threadId, {
|
|
73
|
+
type: 'run-finish',
|
|
74
|
+
runId,
|
|
75
|
+
agentId: ORCHESTRATOR_AGENT_ID,
|
|
76
|
+
payload: { status: 'cancelled', reason },
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
async tryResumeFromOrphan(orphan, data) {
|
|
80
|
+
const outcome = await this.rebuilder.rebuildSuspendedRun(orphan);
|
|
81
|
+
switch (outcome.kind) {
|
|
82
|
+
case 'ready':
|
|
83
|
+
this.runState.suspendRun(orphan.threadId, outcome.state);
|
|
84
|
+
return await this.rebuilder.resumeSuspendedRun(orphan.userId, orphan.requestId, data);
|
|
85
|
+
case 'no-user':
|
|
86
|
+
this.logger.warn('Cannot resume orphaned run: user no longer authorized', {
|
|
87
|
+
requestId: orphan.requestId,
|
|
88
|
+
userId: orphan.userId,
|
|
89
|
+
});
|
|
90
|
+
return false;
|
|
91
|
+
case 'no-checkpoint':
|
|
92
|
+
this.logger.warn('Cannot resume orphaned run: checkpoint missing or unavailable', {
|
|
93
|
+
requestId: orphan.requestId,
|
|
94
|
+
checkpointKey: orphan.checkpointKey,
|
|
95
|
+
...(outcome.error ? { error: getErrorMessage(outcome.error) } : {}),
|
|
96
|
+
});
|
|
97
|
+
return false;
|
|
98
|
+
case 'env-failure':
|
|
99
|
+
this.logger.warn('Cannot resume orphaned run: failed to build execution environment', {
|
|
100
|
+
requestId: orphan.requestId,
|
|
101
|
+
threadId: orphan.threadId,
|
|
102
|
+
error: getErrorMessage(outcome.error),
|
|
103
|
+
});
|
|
104
|
+
return false;
|
|
105
|
+
case 'agent-failure':
|
|
106
|
+
this.logger.warn('Cannot resume orphaned run: failed to build agent', {
|
|
107
|
+
requestId: orphan.requestId,
|
|
108
|
+
threadId: orphan.threadId,
|
|
109
|
+
error: getErrorMessage(outcome.error),
|
|
110
|
+
});
|
|
111
|
+
return false;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
exports.SuspendedRunRestorer = SuspendedRunRestorer;
|
|
116
|
+
//# sourceMappingURL=suspended-run-restorer.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"suspended-run-restorer.service.js","sourceRoot":"","sources":["../../../src/modules/instance-ai/suspended-run-restorer.service.ts"],"names":[],"mappings":"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"}
|