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,11 @@
|
|
|
1
|
+
import type { PreparedWorkflow } from '../entities/workflow/workflow-import.types';
|
|
2
|
+
import { WorkflowSerializer } from '../entities/workflow/workflow.serializer';
|
|
3
|
+
import type { PackageReader } from '../io/package-reader';
|
|
4
|
+
import type { PackageManifest } from '../spec/manifest.schema';
|
|
5
|
+
export declare class N8nPackageParser {
|
|
6
|
+
private readonly workflowSerializer;
|
|
7
|
+
constructor(workflowSerializer: WorkflowSerializer);
|
|
8
|
+
getManifest(reader: PackageReader): Promise<PackageManifest>;
|
|
9
|
+
getWorkflows(reader: PackageReader): Promise<PreparedWorkflow[]>;
|
|
10
|
+
private readWorkflow;
|
|
11
|
+
}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
19
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
20
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
21
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
22
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
23
|
+
};
|
|
24
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
25
|
+
var ownKeys = function(o) {
|
|
26
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
27
|
+
var ar = [];
|
|
28
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
29
|
+
return ar;
|
|
30
|
+
};
|
|
31
|
+
return ownKeys(o);
|
|
32
|
+
};
|
|
33
|
+
return function (mod) {
|
|
34
|
+
if (mod && mod.__esModule) return mod;
|
|
35
|
+
var result = {};
|
|
36
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
37
|
+
__setModuleDefault(result, mod);
|
|
38
|
+
return result;
|
|
39
|
+
};
|
|
40
|
+
})();
|
|
41
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
42
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
43
|
+
};
|
|
44
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
|
+
exports.N8nPackageParser = void 0;
|
|
46
|
+
const db_1 = require("@n8n/db");
|
|
47
|
+
const di_1 = require("@n8n/di");
|
|
48
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
49
|
+
const zod_1 = require("zod");
|
|
50
|
+
const bad_request_error_1 = require("../../../errors/response-errors/bad-request.error");
|
|
51
|
+
const WorkflowHelpers = __importStar(require("../../../workflow-helpers"));
|
|
52
|
+
const workflow_serializer_1 = require("../entities/workflow/workflow.serializer");
|
|
53
|
+
const manifest_schema_1 = require("../spec/manifest.schema");
|
|
54
|
+
let N8nPackageParser = class N8nPackageParser {
|
|
55
|
+
constructor(workflowSerializer) {
|
|
56
|
+
this.workflowSerializer = workflowSerializer;
|
|
57
|
+
}
|
|
58
|
+
async getManifest(reader) {
|
|
59
|
+
try {
|
|
60
|
+
return manifest_schema_1.packageManifestSchema.parse(await reader.readManifest());
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
if (error instanceof bad_request_error_1.BadRequestError)
|
|
64
|
+
throw error;
|
|
65
|
+
if (error instanceof zod_1.ZodError)
|
|
66
|
+
throw new bad_request_error_1.BadRequestError('Package manifest failed validation');
|
|
67
|
+
throw new bad_request_error_1.BadRequestError('Failed to read package manifest');
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
async getWorkflows(reader) {
|
|
71
|
+
const manifest = await this.getManifest(reader);
|
|
72
|
+
const workflows = [];
|
|
73
|
+
for (const entry of manifest.workflows ?? []) {
|
|
74
|
+
workflows.push(await this.readWorkflow(reader, entry));
|
|
75
|
+
}
|
|
76
|
+
return workflows;
|
|
77
|
+
}
|
|
78
|
+
async readWorkflow(reader, entry) {
|
|
79
|
+
const path = `${entry.target}/workflow.json`;
|
|
80
|
+
let content;
|
|
81
|
+
try {
|
|
82
|
+
content = await reader.readFile(path);
|
|
83
|
+
}
|
|
84
|
+
catch (cause) {
|
|
85
|
+
throw new n8n_workflow_1.UserError(`Package manifest references a missing workflow file at ${path}.`, {
|
|
86
|
+
cause,
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
const wire = (0, n8n_workflow_1.jsonParse)(content.toString('utf-8'), {
|
|
90
|
+
errorMessage: `Package workflow file at ${path} is not valid JSON.`,
|
|
91
|
+
});
|
|
92
|
+
let entity;
|
|
93
|
+
try {
|
|
94
|
+
const partial = this.workflowSerializer.deserialize(wire);
|
|
95
|
+
entity = Object.assign(new db_1.WorkflowEntity(), partial);
|
|
96
|
+
}
|
|
97
|
+
catch (cause) {
|
|
98
|
+
if (cause instanceof zod_1.ZodError) {
|
|
99
|
+
throw new n8n_workflow_1.UserError(`Package workflow file at ${path} failed schema validation.`, {
|
|
100
|
+
cause,
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
throw cause;
|
|
104
|
+
}
|
|
105
|
+
WorkflowHelpers.validateWorkflowStructure(entity);
|
|
106
|
+
return { entity, sourceWorkflowId: entry.id, sourcePublished: wire.isPublished };
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
exports.N8nPackageParser = N8nPackageParser;
|
|
110
|
+
exports.N8nPackageParser = N8nPackageParser = __decorate([
|
|
111
|
+
(0, di_1.Service)(),
|
|
112
|
+
__metadata("design:paramtypes", [workflow_serializer_1.WorkflowSerializer])
|
|
113
|
+
], N8nPackageParser);
|
|
114
|
+
//# sourceMappingURL=n8n-package-parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"n8n-package-parser.js","sourceRoot":"","sources":["../../../../src/modules/n8n-packages/engine/n8n-package-parser.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,gCAAyC;AACzC,gCAAkC;AAClC,+CAAoD;AACpD,6BAA+B;AAE/B,kFAA6E;AAC7E,oEAAsD;AAGtD,kFAA8E;AAG9E,6DAAgE;AAUzD,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAC5B,YAA6B,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;IAAG,CAAC;IAEvE,KAAK,CAAC,WAAW,CAAC,MAAqB;QACtC,IAAI,CAAC;YACJ,OAAO,uCAAqB,CAAC,KAAK,CAAC,MAAM,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;QACjE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,KAAK,YAAY,mCAAe;gBAAE,MAAM,KAAK,CAAC;YAClD,IAAI,KAAK,YAAY,cAAQ;gBAC5B,MAAM,IAAI,mCAAe,CAAC,oCAAoC,CAAC,CAAC;YACjE,MAAM,IAAI,mCAAe,CAAC,iCAAiC,CAAC,CAAC;QAC9D,CAAC;IACF,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAAqB;QACvC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAEhD,MAAM,SAAS,GAAuB,EAAE,CAAC;QACzC,KAAK,MAAM,KAAK,IAAI,QAAQ,CAAC,SAAS,IAAI,EAAE,EAAE,CAAC;YAC9C,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;QACxD,CAAC;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;IAEO,KAAK,CAAC,YAAY,CACzB,MAAqB,EACrB,KAAoB;QAEpB,MAAM,IAAI,GAAG,GAAG,KAAK,CAAC,MAAM,gBAAgB,CAAC;QAE7C,IAAI,OAAe,CAAC;QACpB,IAAI,CAAC;YACJ,OAAO,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,MAAM,IAAI,wBAAS,CAAC,0DAA0D,IAAI,GAAG,EAAE;gBACtF,KAAK;aACL,CAAC,CAAC;QACJ,CAAC;QAED,MAAM,IAAI,GAAG,IAAA,wBAAS,EAAqB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YACrE,YAAY,EAAE,4BAA4B,IAAI,qBAAqB;SACnE,CAAC,CAAC;QAEH,IAAI,MAAsB,CAAC;QAC3B,IAAI,CAAC;YACJ,MAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAC1D,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,mBAAc,EAAE,EAAE,OAAO,CAAC,CAAC;QACvD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,KAAK,YAAY,cAAQ,EAAE,CAAC;gBAC/B,MAAM,IAAI,wBAAS,CAAC,4BAA4B,IAAI,4BAA4B,EAAE;oBACjF,KAAK;iBACL,CAAC,CAAC;YACJ,CAAC;YACD,MAAM,KAAK,CAAC;QACb,CAAC;QAED,eAAe,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC;QAElD,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,CAAC,EAAE,EAAE,eAAe,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;IAClF,CAAC;CACD,CAAA;AA5DY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,YAAO,GAAE;qCAEwC,wCAAkB;GADvD,gBAAgB,CA4D5B"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { CredentialMatcherFactory } from './credential-matcher-factory';
|
|
2
|
-
import {
|
|
3
|
-
import type { CredentialBindingRequest, CredentialResolution } from './credential.types';
|
|
2
|
+
import type { CredentialBindingRequest, CredentialResolution, CredentialResolutionFailure } from './credential.types';
|
|
4
3
|
export declare class CredentialImporter {
|
|
5
4
|
private readonly credentialMatcherFactory;
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
constructor(credentialMatcherFactory: CredentialMatcherFactory);
|
|
6
|
+
plan(request: CredentialBindingRequest): Promise<CredentialResolution>;
|
|
7
|
+
blockingFailures(resolution: CredentialResolution, request: CredentialBindingRequest): CredentialResolutionFailure[];
|
|
9
8
|
}
|
|
@@ -12,30 +12,27 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
12
12
|
exports.CredentialImporter = void 0;
|
|
13
13
|
const di_1 = require("@n8n/di");
|
|
14
14
|
const credential_matcher_factory_1 = require("./credential-matcher-factory");
|
|
15
|
-
const
|
|
15
|
+
const credential_missing_mode_1 = require("./credential-missing-mode");
|
|
16
16
|
let CredentialImporter = class CredentialImporter {
|
|
17
|
-
constructor(credentialMatcherFactory
|
|
17
|
+
constructor(credentialMatcherFactory) {
|
|
18
18
|
this.credentialMatcherFactory = credentialMatcherFactory;
|
|
19
|
-
this.credentialMissingModeFactory = credentialMissingModeFactory;
|
|
20
19
|
}
|
|
21
|
-
async
|
|
22
|
-
|
|
20
|
+
async plan(request) {
|
|
21
|
+
return await this.credentialMatcherFactory
|
|
23
22
|
.getMatcher(request.matchingMode)
|
|
24
23
|
.match(request.requirements, {
|
|
25
24
|
targetProject: request.targetProject,
|
|
26
25
|
user: request.user,
|
|
26
|
+
credentialBindings: request.credentialBindings,
|
|
27
27
|
});
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
user: request.user,
|
|
32
|
-
});
|
|
28
|
+
}
|
|
29
|
+
blockingFailures(resolution, request) {
|
|
30
|
+
return (0, credential_missing_mode_1.credentialBlockingFailures)(request.missingMode, resolution);
|
|
33
31
|
}
|
|
34
32
|
};
|
|
35
33
|
exports.CredentialImporter = CredentialImporter;
|
|
36
34
|
exports.CredentialImporter = CredentialImporter = __decorate([
|
|
37
35
|
(0, di_1.Service)(),
|
|
38
|
-
__metadata("design:paramtypes", [credential_matcher_factory_1.CredentialMatcherFactory
|
|
39
|
-
credential_missing_mode_factory_1.CredentialMissingModeFactory])
|
|
36
|
+
__metadata("design:paramtypes", [credential_matcher_factory_1.CredentialMatcherFactory])
|
|
40
37
|
], CredentialImporter);
|
|
41
38
|
//# sourceMappingURL=credential-importer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"credential-importer.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-importer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAElC,6EAAwE;AACxE,
|
|
1
|
+
{"version":3,"file":"credential-importer.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-importer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAElC,6EAAwE;AACxE,uEAAuE;AAQhE,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC9B,YAA6B,wBAAkD;QAAlD,6BAAwB,GAAxB,wBAAwB,CAA0B;IAAG,CAAC;IAOnF,KAAK,CAAC,IAAI,CAAC,OAAiC;QAC3C,OAAO,MAAM,IAAI,CAAC,wBAAwB;aACxC,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC;aAChC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE;YAC5B,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;SAC9C,CAAC,CAAC;IACL,CAAC;IAOD,gBAAgB,CACf,UAAgC,EAChC,OAAiC;QAEjC,OAAO,IAAA,oDAA0B,EAAC,OAAO,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;IACpE,CAAC;CACD,CAAA;AA7BY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,YAAO,GAAE;qCAE8C,qDAAwB;GADnE,kBAAkB,CA6B9B"}
|
|
@@ -7,6 +7,7 @@ import type { PackageCredentialRequirement } from '../../spec/requirements.schem
|
|
|
7
7
|
export interface CredentialMatcherContext {
|
|
8
8
|
targetProject: Project;
|
|
9
9
|
user: User;
|
|
10
|
+
credentialBindings?: ImportBindingMap;
|
|
10
11
|
}
|
|
11
12
|
export declare abstract class CredentialMatcher {
|
|
12
13
|
protected readonly credentialsFinderService: CredentialsFinderService;
|
|
@@ -9,12 +9,16 @@ class CredentialMatcher {
|
|
|
9
9
|
this.credentialTypes = credentialTypes;
|
|
10
10
|
}
|
|
11
11
|
async match(requirements, context) {
|
|
12
|
+
const orphanFailures = orphanBindingFailures(context.credentialBindings, requirements);
|
|
12
13
|
const { known, unknownTypeFailures } = partitionByKnownType(requirements, this.credentialTypes);
|
|
13
14
|
const successes = await this.resolve(known, context);
|
|
14
15
|
const notFoundFailures = known
|
|
15
16
|
.filter((reference) => !successes.has(reference.id))
|
|
16
|
-
.map((reference) => (
|
|
17
|
-
return {
|
|
17
|
+
.map((reference) => createNotFoundFailure(reference, context.credentialBindings?.get(reference.id)));
|
|
18
|
+
return {
|
|
19
|
+
successes,
|
|
20
|
+
failures: [...orphanFailures, ...unknownTypeFailures, ...notFoundFailures],
|
|
21
|
+
};
|
|
18
22
|
}
|
|
19
23
|
}
|
|
20
24
|
exports.CredentialMatcher = CredentialMatcher;
|
|
@@ -31,4 +35,25 @@ function partitionByKnownType(requirements, credentialTypes) {
|
|
|
31
35
|
}
|
|
32
36
|
return { known, unknownTypeFailures };
|
|
33
37
|
}
|
|
38
|
+
function createNotFoundFailure(reference, requestedTargetId) {
|
|
39
|
+
const failure = (0, credential_types_1.createFailure)(reference, 'not_found');
|
|
40
|
+
return requestedTargetId === undefined ? failure : { ...failure, targetId: requestedTargetId };
|
|
41
|
+
}
|
|
42
|
+
function orphanBindingFailures(bindings, requirements) {
|
|
43
|
+
if (!bindings || bindings.size === 0)
|
|
44
|
+
return [];
|
|
45
|
+
const requirementIds = new Set((requirements ?? []).map((requirement) => requirement.id));
|
|
46
|
+
const failures = [];
|
|
47
|
+
for (const [sourceId, targetId] of bindings) {
|
|
48
|
+
if (!requirementIds.has(sourceId)) {
|
|
49
|
+
failures.push({
|
|
50
|
+
kind: 'source_not_found',
|
|
51
|
+
sourceId,
|
|
52
|
+
targetId,
|
|
53
|
+
usedByWorkflows: [],
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return failures;
|
|
58
|
+
}
|
|
34
59
|
//# sourceMappingURL=credential-matcher.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-matcher.ts"],"names":[],"mappings":";;;AAKA,yDAI4B;
|
|
1
|
+
{"version":3,"file":"credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-matcher.ts"],"names":[],"mappings":";;;AAKA,yDAI4B;AAU5B,MAAsB,iBAAiB;IACtC,YACoB,wBAAkD,EAClD,2BAAwD,EACxD,eAAgC;QAFhC,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,gCAA2B,GAA3B,2BAA2B,CAA6B;QACxD,oBAAe,GAAf,eAAe,CAAiB;IACjD,CAAC;IAEJ,KAAK,CAAC,KAAK,CACV,YAAwD,EACxD,OAAiC;QAEjC,MAAM,cAAc,GAAG,qBAAqB,CAAC,OAAO,CAAC,kBAAkB,EAAE,YAAY,CAAC,CAAC;QACvF,MAAM,EAAE,KAAK,EAAE,mBAAmB,EAAE,GAAG,oBAAoB,CAAC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAEhG,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAErD,MAAM,gBAAgB,GAAG,KAAK;aAC5B,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;aACnD,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAClB,qBAAqB,CAAC,SAAS,EAAE,OAAO,CAAC,kBAAkB,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAC/E,CAAC;QAEH,OAAO;YACN,SAAS;YACT,QAAQ,EAAE,CAAC,GAAG,cAAc,EAAE,GAAG,mBAAmB,EAAE,GAAG,gBAAgB,CAAC;SAC1E,CAAC;IACH,CAAC;CAMD;AAhCD,8CAgCC;AAED,SAAS,oBAAoB,CAC5B,YAAwD,EACxD,eAAgC;IAKhC,MAAM,KAAK,GAAmC,EAAE,CAAC;IACjD,MAAM,mBAAmB,GAAkC,EAAE,CAAC;IAE9D,KAAK,MAAM,SAAS,IAAI,YAAY,IAAI,EAAE,EAAE,CAAC;QAC5C,IAAI,eAAe,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,CAAC;aAAM,CAAC;YACP,mBAAmB,CAAC,IAAI,CAAC,IAAA,gCAAa,EAAC,SAAS,EAAE,cAAc,CAAC,CAAC,CAAC;QACpE,CAAC;IACF,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC;AACvC,CAAC;AAMD,SAAS,qBAAqB,CAC7B,SAAuC,EACvC,iBAAqC;IAErC,MAAM,OAAO,GAAG,IAAA,gCAAa,EAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IACtD,OAAO,iBAAiB,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAAC;AAChG,CAAC;AAOD,SAAS,qBAAqB,CAC7B,QAAsC,EACtC,YAAwD;IAExD,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,IAAI,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAEhD,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1F,MAAM,QAAQ,GAAkC,EAAE,CAAC;IAEnD,KAAK,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,QAAQ,EAAE,CAAC;QAC7C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnC,QAAQ,CAAC,IAAI,CAAC;gBACb,IAAI,EAAE,kBAAkB;gBACxB,QAAQ;gBACR,QAAQ;gBACR,eAAe,EAAE,EAAE;aACnB,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,OAAO,QAAQ,CAAC;AACjB,CAAC"}
|
|
@@ -1,7 +1,3 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
}
|
|
5
|
-
export declare class MustPreexistCredentialMissingModeHandler extends CredentialMissingModeHandler {
|
|
6
|
-
handle(result: CredentialResolution): Promise<CredentialResolution>;
|
|
7
|
-
}
|
|
1
|
+
import type { CredentialResolution, CredentialResolutionFailure } from './credential.types';
|
|
2
|
+
import type { CredentialMissingMode } from '../../n8n-packages.types';
|
|
3
|
+
export declare function credentialBlockingFailures(mode: CredentialMissingMode, resolution: CredentialResolution): CredentialResolutionFailure[];
|
|
@@ -1,17 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
const
|
|
5
|
-
|
|
3
|
+
exports.credentialBlockingFailures = credentialBlockingFailures;
|
|
4
|
+
const BLOCKING_FAILURES = {
|
|
5
|
+
'must-preexist': (resolution) => resolution.failures,
|
|
6
|
+
};
|
|
7
|
+
function credentialBlockingFailures(mode, resolution) {
|
|
8
|
+
return BLOCKING_FAILURES[mode](resolution);
|
|
6
9
|
}
|
|
7
|
-
exports.CredentialMissingModeHandler = CredentialMissingModeHandler;
|
|
8
|
-
class MustPreexistCredentialMissingModeHandler extends CredentialMissingModeHandler {
|
|
9
|
-
async handle(result) {
|
|
10
|
-
if (result.failures.length === 0) {
|
|
11
|
-
return result;
|
|
12
|
-
}
|
|
13
|
-
throw (0, credential_resolution_error_1.toCredentialResolutionFailedError)(result.failures);
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
exports.MustPreexistCredentialMissingModeHandler = MustPreexistCredentialMissingModeHandler;
|
|
17
10
|
//# sourceMappingURL=credential-missing-mode.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"credential-missing-mode.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-missing-mode.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"credential-missing-mode.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-missing-mode.ts"],"names":[],"mappings":";;AAgBA,gEAKC;AAbD,MAAM,iBAAiB,GAGnB;IACH,eAAe,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ;CACpD,CAAC;AAGF,SAAgB,0BAA0B,CACzC,IAA2B,EAC3B,UAAgC;IAEhC,OAAO,iBAAiB,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC;AAC5C,CAAC"}
|
|
@@ -7,10 +7,11 @@ export interface WorkflowCredentialRequirement {
|
|
|
7
7
|
credentialName: string;
|
|
8
8
|
credentialType: string;
|
|
9
9
|
}
|
|
10
|
-
export type CredentialResolutionFailureKind = 'not_found' | 'unknown_type';
|
|
10
|
+
export type CredentialResolutionFailureKind = 'not_found' | 'unknown_type' | 'source_not_found';
|
|
11
11
|
export type CredentialResolutionFailure = {
|
|
12
12
|
kind: CredentialResolutionFailureKind;
|
|
13
13
|
sourceId: string;
|
|
14
|
+
targetId?: string;
|
|
14
15
|
usedByWorkflows: string[];
|
|
15
16
|
};
|
|
16
17
|
export interface CredentialResolution {
|
|
@@ -21,16 +22,8 @@ export interface CredentialBindingRequest {
|
|
|
21
22
|
requirements: PackageCredentialRequirement[] | undefined;
|
|
22
23
|
matchingMode: CredentialMatchingMode;
|
|
23
24
|
missingMode: CredentialMissingMode;
|
|
24
|
-
|
|
25
|
-
user: User;
|
|
26
|
-
}
|
|
27
|
-
export interface CredentialMissingModeContext {
|
|
28
|
-
requirements: PackageCredentialRequirement[] | undefined;
|
|
25
|
+
credentialBindings?: ImportBindingMap;
|
|
29
26
|
targetProject: Project;
|
|
30
27
|
user: User;
|
|
31
28
|
}
|
|
32
29
|
export declare function createFailure(reference: PackageCredentialRequirement, kind: CredentialResolutionFailureKind): CredentialResolutionFailure;
|
|
33
|
-
export declare function resolvedBindingsToSummaries(successes: ImportBindingMap): Array<{
|
|
34
|
-
sourceId: string;
|
|
35
|
-
targetId: string;
|
|
36
|
-
}>;
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.createFailure = createFailure;
|
|
4
|
-
exports.resolvedBindingsToSummaries = resolvedBindingsToSummaries;
|
|
5
4
|
function createFailure(reference, kind) {
|
|
6
5
|
return {
|
|
7
6
|
kind,
|
|
@@ -9,7 +8,4 @@ function createFailure(reference, kind) {
|
|
|
9
8
|
usedByWorkflows: [...reference.usedByWorkflows].sort(),
|
|
10
9
|
};
|
|
11
10
|
}
|
|
12
|
-
function resolvedBindingsToSummaries(successes) {
|
|
13
|
-
return [...successes].map(([sourceId, targetId]) => ({ sourceId, targetId }));
|
|
14
|
-
}
|
|
15
11
|
//# sourceMappingURL=credential.types.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"credential.types.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential.types.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"credential.types.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential.types.ts"],"names":[],"mappings":";;AAuCA,sCASC;AATD,SAAgB,aAAa,CAC5B,SAAuC,EACvC,IAAqC;IAErC,OAAO;QACN,IAAI;QACJ,QAAQ,EAAE,SAAS,CAAC,EAAE;QACtB,eAAe,EAAE,CAAC,GAAG,SAAS,CAAC,eAAe,CAAC,CAAC,IAAI,EAAE;KACtD,CAAC;AACH,CAAC"}
|
|
@@ -22,13 +22,18 @@ let IdBasedCredentialMatcher = class IdBasedCredentialMatcher extends credential
|
|
|
22
22
|
this.credentialsService = credentialsService;
|
|
23
23
|
}
|
|
24
24
|
async resolve(known, context) {
|
|
25
|
-
const
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
25
|
+
const bindings = context.credentialBindings;
|
|
26
|
+
const targetIds = known.map((reference) => bindings?.get(reference.id) ?? reference.id);
|
|
27
|
+
const resolvableIds = await this.findResolvableCredentialIds(targetIds, context.targetProject, context.user);
|
|
28
|
+
return new Map(known.flatMap((reference) => {
|
|
29
|
+
const targetId = bindings?.get(reference.id) ?? reference.id;
|
|
30
|
+
if (!resolvableIds.has(targetId))
|
|
31
|
+
return [];
|
|
32
|
+
return [[reference.id, targetId]];
|
|
33
|
+
}));
|
|
29
34
|
}
|
|
30
|
-
async findResolvableCredentialIds(
|
|
31
|
-
const uniqueIds = new Set(
|
|
35
|
+
async findResolvableCredentialIds(candidateIds, targetProject, user) {
|
|
36
|
+
const uniqueIds = new Set(candidateIds);
|
|
32
37
|
if (uniqueIds.size === 0) {
|
|
33
38
|
return new Set();
|
|
34
39
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"id-based-credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/id-based-credential-matcher.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAsD;AAEtD,gCAAkC;AAElC,yDAAqD;AACrD,yFAAoF;AACpF,2EAAuE;AAEvE,6DAAwF;AAKjF,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,sCAAiB;IAC9D,YACC,wBAAkD,EAClD,2BAAwD,EACxD,eAAgC,EACf,kBAAsC;QAEvD,KAAK,CAAC,wBAAwB,EAAE,2BAA2B,EAAE,eAAe,CAAC,CAAC;QAF7D,uBAAkB,GAAlB,kBAAkB,CAAoB;IAGxD,CAAC;IAES,KAAK,CAAC,OAAO,CACtB,KAAqC,EACrC,OAAiC;QAEjC,MAAM,
|
|
1
|
+
{"version":3,"file":"id-based-credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/id-based-credential-matcher.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAsD;AAEtD,gCAAkC;AAElC,yDAAqD;AACrD,yFAAoF;AACpF,2EAAuE;AAEvE,6DAAwF;AAKjF,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,sCAAiB;IAC9D,YACC,wBAAkD,EAClD,2BAAwD,EACxD,eAAgC,EACf,kBAAsC;QAEvD,KAAK,CAAC,wBAAwB,EAAE,2BAA2B,EAAE,eAAe,CAAC,CAAC;QAF7D,uBAAkB,GAAlB,kBAAkB,CAAoB;IAGxD,CAAC;IAES,KAAK,CAAC,OAAO,CACtB,KAAqC,EACrC,OAAiC;QAEjC,MAAM,QAAQ,GAAG,OAAO,CAAC,kBAAkB,CAAC;QAC5C,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QACxF,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,2BAA2B,CAC3D,SAAS,EACT,OAAO,CAAC,aAAa,EACrB,OAAO,CAAC,IAAI,CACZ,CAAC;QAEF,OAAO,IAAI,GAAG,CACb,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC3B,MAAM,QAAQ,GAAG,QAAQ,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,EAAE,CAAC;YAC7D,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC;gBAAE,OAAO,EAAE,CAAC;YAC5C,OAAO,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,QAAQ,CAAU,CAAC,CAAC;QAC5C,CAAC,CAAC,CACF,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,2BAA2B,CACxC,YAAsB,EACtB,aAAsB,EACtB,IAAU;QAEV,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,YAAY,CAAC,CAAC;QACxC,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,IAAI,GAAG,EAAE,CAAC;QAClB,CAAC;QAED,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,oCAAoC,CAC3F,IAAI,EACJ,EAAE,SAAS,EAAE,aAAa,CAAC,EAAE,EAAE,CAC/B,CAAC;QAEF,OAAO,IAAI,GAAG,CACb,iBAAiB,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CACtF,CAAC;IACH,CAAC;CACD,CAAA;AAlDY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,YAAO,GAAE;qCAGkB,qDAAwB;QACrB,gCAA2B;QACvC,kCAAe;QACK,wCAAkB;GAL5C,wBAAwB,CAkDpC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { WorkflowEntity } from '@n8n/db';
|
|
2
|
+
import type { WorkflowDecision } from './workflow-import.types';
|
|
3
|
+
import type { WorkflowConflictPolicy } from '../../n8n-packages.types';
|
|
4
|
+
export declare function decideWorkflowConflictAction(policy: WorkflowConflictPolicy, existing: WorkflowEntity | null): WorkflowDecision;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decideWorkflowConflictAction = decideWorkflowConflictAction;
|
|
4
|
+
const WORKFLOW_CONFLICT_POLICIES = {
|
|
5
|
+
'new-version': (existing) => ({ action: existing ? 'update' : 'create', blocked: false }),
|
|
6
|
+
fail: (existing) => ({ action: 'create', blocked: existing !== null }),
|
|
7
|
+
skip: (existing) => ({ action: existing ? 'skip' : 'create', blocked: false }),
|
|
8
|
+
};
|
|
9
|
+
function decideWorkflowConflictAction(policy, existing) {
|
|
10
|
+
return WORKFLOW_CONFLICT_POLICIES[policy](existing);
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=workflow-conflict-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-conflict-policy.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-conflict-policy.ts"],"names":[],"mappings":";;AAqBA,oEAKC;AAfD,MAAM,0BAA0B,GAG5B;IACH,aAAa,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IACzF,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,KAAK,IAAI,EAAE,CAAC;IACtE,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;CAC9E,CAAC;AAGF,SAAgB,4BAA4B,CAC3C,MAA8B,EAC9B,QAA+B;IAE/B,OAAO,0BAA0B,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC;AACrD,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decideWorkflowId = decideWorkflowId;
|
|
4
|
+
const db_1 = require("@n8n/db");
|
|
5
|
+
const WORKFLOW_ID_POLICIES = {
|
|
6
|
+
new: () => (0, db_1.generateNanoId)(),
|
|
7
|
+
source: (sourceWorkflowId) => sourceWorkflowId,
|
|
8
|
+
};
|
|
9
|
+
function decideWorkflowId(policy, sourceWorkflowId) {
|
|
10
|
+
return WORKFLOW_ID_POLICIES[policy](sourceWorkflowId);
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=workflow-id-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-id-policy.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-id-policy.ts"],"names":[],"mappings":";;AAcA,4CAEC;AAhBD,gCAAyC;AASzC,MAAM,oBAAoB,GAAmE;IAC5F,GAAG,EAAE,GAAG,EAAE,CAAC,IAAA,mBAAc,GAAE;IAC3B,MAAM,EAAE,CAAC,gBAAgB,EAAE,EAAE,CAAC,gBAAgB;CAC9C,CAAC;AAEF,SAAgB,gBAAgB,CAAC,MAAwB,EAAE,gBAAwB;IAClF,OAAO,oBAAoB,CAAC,MAAM,CAAC,CAAC,gBAAgB,CAAC,CAAC;AACvD,CAAC"}
|
|
@@ -1,7 +1,20 @@
|
|
|
1
|
-
import { type WorkflowEntity } from '@n8n/db';
|
|
1
|
+
import { WorkflowRepository, type WorkflowEntity } from '@n8n/db';
|
|
2
2
|
import { WorkflowFinderService } from '../../../../workflows/workflow-finder.service';
|
|
3
|
+
export interface WorkflowIdConflict {
|
|
4
|
+
sourceWorkflowId: string;
|
|
5
|
+
existingWorkflowId: string;
|
|
6
|
+
existingProjectId: string | null;
|
|
7
|
+
isArchived: boolean;
|
|
8
|
+
name: string;
|
|
9
|
+
}
|
|
3
10
|
export declare class WorkflowImportMatchService {
|
|
4
11
|
private readonly workflowFinderService;
|
|
5
|
-
|
|
12
|
+
private readonly workflowRepository;
|
|
13
|
+
constructor(workflowFinderService: WorkflowFinderService, workflowRepository: WorkflowRepository);
|
|
14
|
+
findOwningProjectsByWorkflowId(workflowIds: string[]): Promise<Map<string, {
|
|
15
|
+
projectId: string | null;
|
|
16
|
+
name: string;
|
|
17
|
+
isArchived: boolean;
|
|
18
|
+
}>>;
|
|
6
19
|
findBySourceWorkflowIds(projectId: string, sourceWorkflowIds: string[]): Promise<Map<string, WorkflowEntity>>;
|
|
7
20
|
}
|
|
@@ -10,12 +10,27 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.WorkflowImportMatchService = void 0;
|
|
13
|
+
const db_1 = require("@n8n/db");
|
|
13
14
|
const di_1 = require("@n8n/di");
|
|
14
15
|
const n8n_workflow_1 = require("n8n-workflow");
|
|
15
16
|
const workflow_finder_service_1 = require("../../../../workflows/workflow-finder.service");
|
|
16
17
|
let WorkflowImportMatchService = class WorkflowImportMatchService {
|
|
17
|
-
constructor(workflowFinderService) {
|
|
18
|
+
constructor(workflowFinderService, workflowRepository) {
|
|
18
19
|
this.workflowFinderService = workflowFinderService;
|
|
20
|
+
this.workflowRepository = workflowRepository;
|
|
21
|
+
}
|
|
22
|
+
async findOwningProjectsByWorkflowId(workflowIds) {
|
|
23
|
+
if (workflowIds.length === 0)
|
|
24
|
+
return new Map();
|
|
25
|
+
const workflows = await this.workflowRepository.findPreExistingWorkflows(workflowIds);
|
|
26
|
+
return new Map(workflows.map((workflow) => [
|
|
27
|
+
workflow.id,
|
|
28
|
+
{
|
|
29
|
+
projectId: workflow.shared?.[0]?.projectId ?? null,
|
|
30
|
+
name: workflow.name,
|
|
31
|
+
isArchived: workflow.isArchived,
|
|
32
|
+
},
|
|
33
|
+
]));
|
|
19
34
|
}
|
|
20
35
|
async findBySourceWorkflowIds(projectId, sourceWorkflowIds) {
|
|
21
36
|
if (sourceWorkflowIds.length === 0)
|
|
@@ -49,6 +64,7 @@ let WorkflowImportMatchService = class WorkflowImportMatchService {
|
|
|
49
64
|
exports.WorkflowImportMatchService = WorkflowImportMatchService;
|
|
50
65
|
exports.WorkflowImportMatchService = WorkflowImportMatchService = __decorate([
|
|
51
66
|
(0, di_1.Service)(),
|
|
52
|
-
__metadata("design:paramtypes", [workflow_finder_service_1.WorkflowFinderService
|
|
67
|
+
__metadata("design:paramtypes", [workflow_finder_service_1.WorkflowFinderService,
|
|
68
|
+
db_1.WorkflowRepository])
|
|
53
69
|
], WorkflowImportMatchService);
|
|
54
70
|
//# sourceMappingURL=workflow-import-match.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"workflow-import-match.service.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-import-match.service.ts"],"names":[],"mappings":";;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"workflow-import-match.service.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-import-match.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkE;AAClE,gCAAkC;AAClC,+CAA+C;AAE/C,iFAA4E;AAYrE,IAAM,0BAA0B,GAAhC,MAAM,0BAA0B;IACtC,YACkB,qBAA4C,EAC5C,kBAAsC;QADtC,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,uBAAkB,GAAlB,kBAAkB,CAAoB;IACrD,CAAC;IAEJ,KAAK,CAAC,8BAA8B,CACnC,WAAqB;QAErB,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,GAAG,EAAE,CAAC;QAE/C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,wBAAwB,CAAC,WAAW,CAAC,CAAC;QAEtF,OAAO,IAAI,GAAG,CACb,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC;YAC3B,QAAQ,CAAC,EAAE;YACX;gBACC,SAAS,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,SAAS,IAAI,IAAI;gBAClD,IAAI,EAAE,QAAQ,CAAC,IAAI;gBACnB,UAAU,EAAE,QAAQ,CAAC,UAAU;aAC/B;SACD,CAAC,CACF,CAAC;IACH,CAAC;IAED,KAAK,CAAC,uBAAuB,CAC5B,SAAiB,EACjB,iBAA2B;QAE3B,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,GAAG,EAAE,CAAC;QAErD,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACtD,MAAM,aAAa,GAAG,EAAE,oBAAoB,EAAE,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAW,CAAC;QACzF,MAAM,uBAAuB,GAAG,IAAI,GAAG,EAA0B,CAAC;QAElE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,qCAAqC,CACvF,SAAS,EACT,iBAAiB,EACjB,aAAa,CACb,CAAC;QAEF,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YAClC,IAAI,CAAC,QAAQ,CAAC,gBAAgB;gBAAE,SAAS;YAEzC,MAAM,GAAG,GAAG,QAAQ,CAAC,gBAAgB,CAAC;YACtC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC;gBAAE,SAAS;YAE3C,IAAI,uBAAuB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBACtC,MAAM,IAAI,8BAAe,CACxB,0EAA0E,EAC1E,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAG,EAAE,EAAE,CAC/C,CAAC;YACH,CAAC;YAED,uBAAuB,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5C,CAAC;QAED,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YAClC,IAAI,QAAQ,CAAC,gBAAgB,KAAK,IAAI;gBAAE,SAAS;YAEjD,MAAM,GAAG,GAAG,QAAQ,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,uBAAuB,CAAC,GAAG,CAAC,GAAG,CAAC;gBAAE,SAAS;YAE/E,uBAAuB,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5C,CAAC;QAED,OAAO,uBAAuB,CAAC;IAChC,CAAC;CACD,CAAA;AApEY,gEAA0B;qCAA1B,0BAA0B;IADtC,IAAA,YAAO,GAAE;qCAGgC,+CAAqB;QACxB,uBAAkB;GAH5C,0BAA0B,CAoEtC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { User, WorkflowEntity } from '@n8n/db';
|
|
2
|
+
import type { WorkflowIdConflict } from './workflow-import-match.service';
|
|
3
|
+
import type { WorkflowPublishingPolicy } from './workflow-publishing-policy.types';
|
|
4
|
+
export interface WorkflowImportContext {
|
|
5
|
+
user: User;
|
|
6
|
+
projectId: string;
|
|
7
|
+
folderId: string | null;
|
|
8
|
+
publishingPolicy: WorkflowPublishingPolicy;
|
|
9
|
+
}
|
|
10
|
+
export interface PreparedWorkflow {
|
|
11
|
+
entity: WorkflowEntity;
|
|
12
|
+
sourceWorkflowId: string;
|
|
13
|
+
sourcePublished: boolean;
|
|
14
|
+
}
|
|
15
|
+
export type WorkflowPlannedAction = 'create' | 'update' | 'skip';
|
|
16
|
+
export interface WorkflowDecision {
|
|
17
|
+
action: WorkflowPlannedAction;
|
|
18
|
+
blocked: boolean;
|
|
19
|
+
}
|
|
20
|
+
export type WorkflowPlanItem = ({
|
|
21
|
+
action: 'create';
|
|
22
|
+
decidedId: string;
|
|
23
|
+
} & PreparedWorkflow) | ({
|
|
24
|
+
action: 'update';
|
|
25
|
+
existing: WorkflowEntity;
|
|
26
|
+
} & PreparedWorkflow) | ({
|
|
27
|
+
action: 'skip';
|
|
28
|
+
existing: WorkflowEntity;
|
|
29
|
+
} & PreparedWorkflow);
|
|
30
|
+
export type PersistedWorkflowPlanItem = Extract<WorkflowPlanItem, {
|
|
31
|
+
action: 'create' | 'update';
|
|
32
|
+
}>;
|
|
33
|
+
export interface WorkflowConflict {
|
|
34
|
+
sourceWorkflowId: string;
|
|
35
|
+
existingWorkflowId: string;
|
|
36
|
+
name: string;
|
|
37
|
+
}
|
|
38
|
+
export interface WorkflowImportPlan {
|
|
39
|
+
items: WorkflowPlanItem[];
|
|
40
|
+
conflicts: WorkflowConflict[];
|
|
41
|
+
idConflicts: WorkflowIdConflict[];
|
|
42
|
+
}
|
|
43
|
+
export interface WorkflowImportOutcome {
|
|
44
|
+
status: 'created' | 'updated' | 'skipped';
|
|
45
|
+
workflow: WorkflowEntity;
|
|
46
|
+
sourceWorkflowId: string;
|
|
47
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-import.types.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-import.types.ts"],"names":[],"mappings":""}
|
|
@@ -1,14 +1,22 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { WorkflowCreationService } from '../../../../workflows/workflow-creation.service';
|
|
2
|
+
import { WorkflowService } from '../../../../workflows/workflow.service';
|
|
2
3
|
import { WorkflowImportMatchService } from './workflow-import-match.service';
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
4
|
+
import type { PreparedWorkflow, WorkflowImportContext, WorkflowImportOutcome, WorkflowImportPlan } from './workflow-import.types';
|
|
5
|
+
import { WorkflowPublisher } from './workflow-publisher';
|
|
6
|
+
import type { ImportWorkflowProperties, PackageImportBindings } from '../../n8n-packages.types';
|
|
5
7
|
export interface WorkflowImportResult {
|
|
6
8
|
outcomes: WorkflowImportOutcome[];
|
|
7
9
|
bindings: PackageImportBindings;
|
|
8
10
|
}
|
|
9
11
|
export declare class WorkflowImporter {
|
|
10
|
-
private readonly workflowConflictPolicyFactory;
|
|
11
12
|
private readonly workflowImportMatchService;
|
|
12
|
-
|
|
13
|
-
|
|
13
|
+
private readonly workflowCreationService;
|
|
14
|
+
private readonly workflowService;
|
|
15
|
+
private readonly workflowPublisher;
|
|
16
|
+
constructor(workflowImportMatchService: WorkflowImportMatchService, workflowCreationService: WorkflowCreationService, workflowService: WorkflowService, workflowPublisher: WorkflowPublisher);
|
|
17
|
+
plan(context: WorkflowImportContext, prepared: PreparedWorkflow[], options: ImportWorkflowProperties): Promise<WorkflowImportPlan>;
|
|
18
|
+
private collectIdConflicts;
|
|
19
|
+
apply(plan: WorkflowImportPlan, context: WorkflowImportContext, bindings: PackageImportBindings): Promise<WorkflowImportResult>;
|
|
20
|
+
private applyItem;
|
|
21
|
+
private persistWorkflow;
|
|
14
22
|
}
|