n8n 2.7.4 → 2.8.1
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.js +0 -1
- package/dist/active-workflow-manager.js.map +1 -1
- package/dist/auth/auth-handler.registry.d.ts +15 -0
- package/dist/auth/auth-handler.registry.js +87 -0
- package/dist/auth/auth-handler.registry.js.map +1 -0
- package/dist/auth/handlers/email.auth-handler.d.ts +19 -0
- package/dist/auth/handlers/email.auth-handler.js +52 -0
- package/dist/auth/handlers/email.auth-handler.js.map +1 -0
- package/dist/build.tsbuildinfo +1 -1
- package/dist/chat/chat-service.types.d.ts +2 -2
- package/dist/commands/base-command.js +5 -2
- package/dist/commands/base-command.js.map +1 -1
- package/dist/commands/start.js +17 -0
- package/dist/commands/start.js.map +1 -1
- package/dist/controllers/ai.controller.js +2 -0
- package/dist/controllers/ai.controller.js.map +1 -1
- package/dist/controllers/auth.controller.d.ts +8 -1
- package/dist/controllers/auth.controller.js +66 -85
- package/dist/controllers/auth.controller.js.map +1 -1
- package/dist/controllers/dynamic-node-parameters.controller.d.ts +2 -2
- package/dist/controllers/dynamic-node-parameters.controller.js +13 -13
- package/dist/controllers/dynamic-node-parameters.controller.js.map +1 -1
- package/dist/controllers/e2e.controller.d.ts +4 -0
- package/dist/controllers/e2e.controller.js +18 -0
- package/dist/controllers/e2e.controller.js.map +1 -1
- package/dist/controllers/me.controller.d.ts +2 -2
- package/dist/controllers/me.controller.js +1 -1
- package/dist/controllers/me.controller.js.map +1 -1
- package/dist/controllers/mfa.controller.js +11 -0
- package/dist/controllers/mfa.controller.js.map +1 -1
- package/dist/controllers/security-settings.controller.d.ts +18 -0
- package/dist/controllers/security-settings.controller.js +96 -0
- package/dist/controllers/security-settings.controller.js.map +1 -0
- package/dist/controllers/users.controller.js.map +1 -1
- package/dist/credentials/credentials-finder.service.d.ts +1 -5
- package/dist/credentials/credentials-finder.service.js +2 -2
- package/dist/credentials/credentials-finder.service.js.map +1 -1
- package/dist/eventbus/event-message-classes/event-message-audit.d.ts +4 -0
- package/dist/eventbus/event-message-classes/event-message-audit.js.map +1 -1
- package/dist/eventbus/event-message-classes/index.d.ts +2 -2
- package/dist/eventbus/event-message-classes/index.js +7 -0
- package/dist/eventbus/event-message-classes/index.js.map +1 -1
- package/dist/events/maps/relay.event-map.d.ts +14 -0
- package/dist/events/relays/log-streaming.event-relay.d.ts +2 -0
- package/dist/events/relays/log-streaming.event-relay.js +60 -2
- package/dist/events/relays/log-streaming.event-relay.js.map +1 -1
- package/dist/events/relays/telemetry.event-relay.d.ts +1 -0
- package/dist/events/relays/telemetry.event-relay.js +7 -0
- package/dist/events/relays/telemetry.event-relay.js.map +1 -1
- package/dist/execution-lifecycle/execution-lifecycle-hooks.js +14 -0
- package/dist/execution-lifecycle/execution-lifecycle-hooks.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-execution-store.service.d.ts +44 -0
- package/dist/modules/chat-hub/chat-hub-execution-store.service.js +159 -0
- package/dist/modules/chat-hub/chat-hub-execution-store.service.js.map +1 -0
- package/dist/modules/chat-hub/chat-hub-execution-watcher.service.d.ts +25 -0
- package/dist/modules/chat-hub/chat-hub-execution-watcher.service.js +205 -0
- package/dist/modules/chat-hub/chat-hub-execution-watcher.service.js.map +1 -0
- package/dist/modules/chat-hub/chat-hub-execution.service.d.ts +10 -12
- package/dist/modules/chat-hub/chat-hub-execution.service.js +93 -187
- package/dist/modules/chat-hub/chat-hub-execution.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-title.service.js +2 -2
- package/dist/modules/chat-hub/chat-hub-title.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-workflow.service.d.ts +1 -0
- package/dist/modules/chat-hub/chat-hub-workflow.service.js +101 -9
- package/dist/modules/chat-hub/chat-hub-workflow.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.constants.js +7 -3
- package/dist/modules/chat-hub/chat-hub.constants.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.models.service.d.ts +2 -2
- package/dist/modules/chat-hub/chat-hub.models.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.module.js +7 -0
- package/dist/modules/chat-hub/chat-hub.module.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.service.js +3 -6
- package/dist/modules/chat-hub/chat-hub.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-stream-state.service.d.ts +4 -2
- package/dist/modules/chat-hub/chat-stream-state.service.js +11 -11
- package/dist/modules/chat-hub/chat-stream-state.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-stream.service.d.ts +1 -1
- package/dist/modules/chat-hub/chat-stream.service.js +1 -1
- package/dist/modules/chat-hub/chat-stream.service.js.map +1 -1
- package/dist/modules/chat-hub/dto/chat-models-request.dto.d.ts +3 -2
- package/dist/modules/chat-hub/dto/chat-models-request.dto.js +1 -2
- package/dist/modules/chat-hub/dto/chat-models-request.dto.js.map +1 -1
- package/dist/modules/community-packages/community-node-types.service.d.ts +1 -0
- package/dist/modules/community-packages/community-node-types.service.js +30 -0
- package/dist/modules/community-packages/community-node-types.service.js.map +1 -1
- package/dist/modules/data-table/data-table.controller.d.ts +4 -1
- package/dist/modules/data-table/data-table.controller.js +23 -2
- package/dist/modules/data-table/data-table.controller.js.map +1 -1
- package/dist/modules/data-table/middleware/branch-write-access-middleware.d.ts +2 -0
- package/dist/modules/data-table/middleware/branch-write-access-middleware.js +15 -0
- package/dist/modules/data-table/middleware/branch-write-access-middleware.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-introspection-identifier.d.ts +2 -2
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-web.service.js +2 -2
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-web.service.js.map +1 -1
- package/dist/modules/external-secrets.ee/external-secrets-manager.ee.d.ts +16 -7
- package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js +63 -20
- package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/external-secrets-providers.ee.d.ts +2 -0
- package/dist/modules/external-secrets.ee/external-secrets-providers.ee.js +8 -0
- package/dist/modules/external-secrets.ee/external-secrets-providers.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/external-secrets.controller.ee.d.ts +7 -3
- package/dist/modules/external-secrets.ee/external-secrets.module.js +1 -1
- package/dist/modules/external-secrets.ee/external-secrets.module.js.map +1 -1
- package/dist/modules/external-secrets.ee/external-secrets.service.ee.d.ts +10 -5
- package/dist/modules/external-secrets.ee/external-secrets.service.ee.js +7 -45
- package/dist/modules/external-secrets.ee/external-secrets.service.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/redaction.service.ee.d.ts +7 -0
- package/dist/modules/external-secrets.ee/redaction.service.ee.js +56 -0
- package/dist/modules/external-secrets.ee/redaction.service.ee.js.map +1 -0
- package/dist/modules/external-secrets.ee/secrets-providers-completions.controller.ee.d.ts +15 -0
- package/dist/modules/external-secrets.ee/secrets-providers-completions.controller.ee.js +76 -0
- package/dist/modules/external-secrets.ee/secrets-providers-completions.controller.ee.js.map +1 -0
- package/dist/modules/external-secrets.ee/secrets-providers-connections.controller.ee.d.ts +10 -12
- package/dist/modules/external-secrets.ee/secrets-providers-connections.controller.ee.js +21 -42
- package/dist/modules/external-secrets.ee/secrets-providers-connections.controller.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers-connections.service.ee.d.ts +16 -3
- package/dist/modules/external-secrets.ee/secrets-providers-connections.service.ee.js +60 -5
- package/dist/modules/external-secrets.ee/secrets-providers-connections.service.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers-project.controller.ee.d.ts +8 -4
- package/dist/modules/external-secrets.ee/secrets-providers-project.controller.ee.js +20 -9
- package/dist/modules/external-secrets.ee/secrets-providers-project.controller.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers-types.controller.ee.d.ts +9 -5
- package/dist/modules/external-secrets.ee/secrets-providers-types.controller.ee.js +33 -13
- package/dist/modules/external-secrets.ee/secrets-providers-types.controller.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers.responses.ee.d.ts +9 -3
- package/dist/modules/insights/database/repositories/insights-by-period.repository.d.ts +3 -3
- package/dist/modules/insights/insights.service.d.ts +3 -3
- package/dist/modules/ldap.ee/ldap.module.js +1 -4
- package/dist/modules/ldap.ee/ldap.module.js.map +1 -1
- package/dist/modules/ldap.ee/ldap.service.ee.d.ts +11 -4
- package/dist/modules/ldap.ee/ldap.service.ee.js +5 -2
- package/dist/modules/ldap.ee/ldap.service.ee.js.map +1 -1
- package/dist/modules/log-streaming.ee/destinations/message-event-bus-destination-syslog.ee.js +1 -1
- package/dist/modules/log-streaming.ee/destinations/message-event-bus-destination-syslog.ee.js.map +1 -1
- package/dist/modules/log-streaming.ee/destinations/message-event-bus-destination-webhook.ee.js +10 -1
- package/dist/modules/log-streaming.ee/destinations/message-event-bus-destination-webhook.ee.js.map +1 -1
- package/dist/modules/mcp/dto/approve-consent-request.dto.d.ts +3 -2
- package/dist/modules/mcp/dto/approve-consent-request.dto.js +2 -2
- package/dist/modules/mcp/dto/approve-consent-request.dto.js.map +1 -1
- package/dist/modules/mcp/dto/update-mcp-settings.dto.d.ts +3 -2
- package/dist/modules/mcp/dto/update-mcp-settings.dto.js +2 -2
- package/dist/modules/mcp/dto/update-mcp-settings.dto.js.map +1 -1
- package/dist/modules/mcp/dto/update-workflow-availability.dto.d.ts +3 -2
- package/dist/modules/mcp/dto/update-workflow-availability.dto.js +2 -2
- package/dist/modules/mcp/dto/update-workflow-availability.dto.js.map +1 -1
- package/dist/modules/mcp/mcp.service.d.ts +15 -2
- package/dist/modules/mcp/mcp.service.js +66 -3
- package/dist/modules/mcp/mcp.service.js.map +1 -1
- package/dist/modules/mcp/tools/execute-workflow.tool.d.ts +3 -2
- package/dist/modules/mcp/tools/execute-workflow.tool.js +18 -9
- package/dist/modules/mcp/tools/execute-workflow.tool.js.map +1 -1
- package/dist/modules/mcp/tools/get-workflow-details.tool.js.map +1 -1
- package/dist/modules/mcp/tools/search-workflows.tool.js +1 -1
- package/dist/modules/mcp/tools/search-workflows.tool.js.map +1 -1
- package/dist/modules/quick-connect/handlers/quick-connect.handler.d.ts +11 -0
- package/dist/modules/quick-connect/handlers/quick-connect.handler.js +26 -0
- package/dist/modules/quick-connect/handlers/quick-connect.handler.js.map +1 -0
- package/dist/modules/quick-connect/handlers/sample.handler.d.ts +7 -0
- package/dist/modules/quick-connect/handlers/sample.handler.js +27 -0
- package/dist/modules/quick-connect/handlers/sample.handler.js.map +1 -0
- package/dist/modules/quick-connect/quick-connect.config.d.ts +95 -0
- package/dist/modules/quick-connect/quick-connect.config.js +48 -0
- package/dist/modules/quick-connect/quick-connect.config.js.map +1 -0
- package/dist/modules/quick-connect/quick-connect.controller.d.ts +10 -0
- package/dist/modules/quick-connect/quick-connect.controller.js +39 -0
- package/dist/modules/quick-connect/quick-connect.controller.js.map +1 -0
- package/dist/modules/quick-connect/quick-connect.errors.d.ts +5 -0
- package/dist/modules/quick-connect/quick-connect.errors.js +12 -0
- package/dist/modules/quick-connect/quick-connect.errors.js.map +1 -0
- package/dist/modules/quick-connect/quick-connect.module.d.ts +15 -0
- package/dist/modules/quick-connect/quick-connect.module.js +70 -0
- package/dist/modules/quick-connect/quick-connect.module.js.map +1 -0
- package/dist/modules/quick-connect/quick-connect.service.d.ts +17 -0
- package/dist/modules/quick-connect/quick-connect.service.js +87 -0
- package/dist/modules/quick-connect/quick-connect.service.js.map +1 -0
- package/dist/modules/source-control.ee/constants.d.ts +2 -0
- package/dist/modules/source-control.ee/constants.js +3 -1
- package/dist/modules/source-control.ee/constants.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-export.service.ee.d.ts +6 -1
- package/dist/modules/source-control.ee/source-control-export.service.ee.js +136 -19
- package/dist/modules/source-control.ee/source-control-export.service.ee.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-helper.ee.d.ts +10 -2
- package/dist/modules/source-control.ee/source-control-helper.ee.js +81 -5
- package/dist/modules/source-control.ee/source-control-helper.ee.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-import.service.ee.d.ts +15 -1
- package/dist/modules/source-control.ee/source-control-import.service.ee.js +209 -3
- package/dist/modules/source-control.ee/source-control-import.service.ee.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-scoped.service.d.ts +2 -0
- package/dist/modules/source-control.ee/source-control-scoped.service.js +8 -0
- package/dist/modules/source-control.ee/source-control-scoped.service.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-status.service.ee.d.ts +3 -0
- package/dist/modules/source-control.ee/source-control-status.service.ee.js +494 -328
- package/dist/modules/source-control.ee/source-control-status.service.ee.js.map +1 -1
- package/dist/modules/source-control.ee/source-control.controller.ee.d.ts +2 -2
- package/dist/modules/source-control.ee/source-control.service.ee.d.ts +1 -1
- package/dist/modules/source-control.ee/source-control.service.ee.js +12 -1
- package/dist/modules/source-control.ee/source-control.service.ee.js.map +1 -1
- package/dist/modules/source-control.ee/types/exportable-data-table.d.ts +20 -0
- package/dist/modules/source-control.ee/types/exportable-data-table.js +3 -0
- package/dist/modules/source-control.ee/types/exportable-data-table.js.map +1 -0
- package/dist/modules/source-control.ee/types/source-control-get-status.d.ts +4 -0
- package/dist/modules/source-control.ee/types/source-control-get-status.js.map +1 -1
- package/dist/modules/sso-oidc/oidc.service.ee.js +7 -4
- package/dist/modules/sso-oidc/oidc.service.ee.js.map +1 -1
- package/dist/modules/sso-saml/saml.controller.ee.d.ts +10 -3
- package/dist/modules/workflow-index/workflow-index.service.d.ts +4 -2
- package/dist/modules/workflow-index/workflow-index.service.js +56 -29
- package/dist/modules/workflow-index/workflow-index.service.js.map +1 -1
- package/dist/oauth/oauth.service.js +9 -3
- package/dist/oauth/oauth.service.js.map +1 -1
- package/dist/public-api/types.d.ts +5 -0
- package/dist/public-api/v1/handlers/credentials/credentials.handler.d.ts +15 -0
- package/dist/public-api/v1/handlers/credentials/credentials.handler.js +37 -0
- package/dist/public-api/v1/handlers/credentials/credentials.handler.js.map +1 -1
- package/dist/public-api/v1/handlers/credentials/credentials.service.d.ts +8 -0
- package/dist/public-api/v1/handlers/credentials/credentials.service.js +13 -0
- package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
- package/dist/public-api/v1/handlers/projects/projects.handler.d.ts +4 -0
- package/dist/public-api/v1/handlers/projects/projects.handler.js +57 -0
- package/dist/public-api/v1/handlers/projects/projects.handler.js.map +1 -1
- package/dist/public-api/v1/handlers/workflows/workflows.handler.js +15 -15
- package/dist/public-api/v1/handlers/workflows/workflows.handler.js.map +1 -1
- package/dist/public-api/v1/openapi.yml +185 -31
- package/dist/push/abstract.push.js +2 -0
- package/dist/push/abstract.push.js.map +1 -1
- package/dist/scaling/constants.d.ts +1 -0
- package/dist/scaling/constants.js +2 -1
- package/dist/scaling/constants.js.map +1 -1
- package/dist/scaling/job-processor.d.ts +1 -0
- package/dist/scaling/job-processor.js +106 -0
- package/dist/scaling/job-processor.js.map +1 -1
- package/dist/scaling/pubsub/publisher.service.d.ts +4 -0
- package/dist/scaling/pubsub/publisher.service.js +14 -0
- package/dist/scaling/pubsub/publisher.service.js.map +1 -1
- package/dist/scaling/pubsub/subscriber.service.d.ts +10 -0
- package/dist/scaling/pubsub/subscriber.service.js +25 -0
- package/dist/scaling/pubsub/subscriber.service.js.map +1 -1
- package/dist/scaling/scaling.service.d.ts +1 -0
- package/dist/scaling/scaling.service.js +54 -0
- package/dist/scaling/scaling.service.js.map +1 -1
- package/dist/scaling/scaling.types.d.ts +20 -1
- package/dist/server.d.ts +1 -0
- package/dist/server.js +1 -0
- package/dist/server.js.map +1 -1
- package/dist/services/dynamic-node-parameters.service.d.ts +5 -3
- package/dist/services/dynamic-node-parameters.service.js +20 -3
- package/dist/services/dynamic-node-parameters.service.js.map +1 -1
- package/dist/services/folder.service.js +1 -1
- package/dist/services/folder.service.js.map +1 -1
- package/dist/services/frontend.service.d.ts +1 -0
- package/dist/services/frontend.service.js +9 -2
- package/dist/services/frontend.service.js.map +1 -1
- package/dist/services/rate-limit.service.d.ts +1 -1
- package/dist/services/rate-limit.service.js +1 -1
- package/dist/services/rate-limit.service.js.map +1 -1
- package/dist/services/role.service.d.ts +6 -3
- package/dist/services/role.service.js +39 -2
- package/dist/services/role.service.js.map +1 -1
- package/dist/services/security-settings.service.d.ts +20 -0
- package/dist/services/security-settings.service.js +68 -0
- package/dist/services/security-settings.service.js.map +1 -0
- package/dist/task-runners/task-broker/task-broker-ws-server.d.ts +4 -2
- package/dist/task-runners/task-broker/task-broker-ws-server.js +24 -2
- package/dist/task-runners/task-broker/task-broker-ws-server.js.map +1 -1
- package/dist/task-runners/task-broker/task-broker.service.d.ts +4 -0
- package/dist/task-runners/task-broker/task-broker.service.js +19 -0
- package/dist/task-runners/task-broker/task-broker.service.js.map +1 -1
- package/dist/telemetry/index.js +3 -0
- package/dist/telemetry/index.js.map +1 -1
- package/dist/webhooks/live-webhooks.js +2 -3
- package/dist/webhooks/live-webhooks.js.map +1 -1
- package/dist/webhooks/webhook-helpers.js +66 -7
- package/dist/webhooks/webhook-helpers.js.map +1 -1
- package/dist/workflow-runner.js +8 -2
- package/dist/workflow-runner.js.map +1 -1
- package/dist/workflows/workflow-finder.service.d.ts +2 -0
- package/dist/workflows/workflow-finder.service.js +22 -2
- package/dist/workflows/workflow-finder.service.js.map +1 -1
- package/dist/workflows/workflow-history/workflow-history-manager.d.ts +3 -1
- package/dist/workflows/workflow-history/workflow-history-manager.js +7 -3
- package/dist/workflows/workflow-history/workflow-history-manager.js.map +1 -1
- package/dist/workflows/workflow-history/workflow-history.controller.d.ts +6 -1
- package/dist/workflows/workflow-history/workflow-history.controller.js +24 -0
- package/dist/workflows/workflow-history/workflow-history.controller.js.map +1 -1
- package/dist/workflows/workflow-history/workflow-history.service.d.ts +7 -3
- package/dist/workflows/workflow-history/workflow-history.service.js +41 -4
- package/dist/workflows/workflow-history/workflow-history.service.js.map +1 -1
- package/dist/workflows/workflow-sharing.service.d.ts +1 -1
- package/dist/workflows/workflow-sharing.service.js +2 -2
- package/dist/workflows/workflow-sharing.service.js.map +1 -1
- package/dist/workflows/workflow-validation.service.d.ts +4 -2
- package/dist/workflows/workflow-validation.service.js +93 -1
- package/dist/workflows/workflow-validation.service.js.map +1 -1
- package/dist/workflows/workflow.service.d.ts +13 -6
- package/dist/workflows/workflow.service.ee.js +11 -4
- package/dist/workflows/workflow.service.ee.js.map +1 -1
- package/dist/workflows/workflow.service.js +70 -47
- package/dist/workflows/workflow.service.js.map +1 -1
- package/dist/workflows/workflows.controller.d.ts +3 -3
- package/dist/workflows/workflows.controller.js +16 -8
- package/dist/workflows/workflows.controller.js.map +1 -1
- package/package.json +29 -24
- package/templates/form-trigger-completion.handlebars +1 -1
- package/dist/auth/index.d.ts +0 -1
- package/dist/auth/index.js +0 -18
- package/dist/auth/index.js.map +0 -1
- package/dist/auth/methods/email.d.ts +0 -2
- package/dist/auth/methods/email.js +0 -26
- package/dist/auth/methods/email.js.map +0 -1
- package/dist/modules/external-secrets.ee/secrets-providers-autocomplete.controller.ee.d.ts +0 -11
- package/dist/modules/external-secrets.ee/secrets-providers-autocomplete.controller.ee.js +0 -64
- package/dist/modules/external-secrets.ee/secrets-providers-autocomplete.controller.ee.js.map +0 -1
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ChatHubExecutionStore = void 0;
|
|
13
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
14
|
+
const config_1 = require("@n8n/config");
|
|
15
|
+
const constants_1 = require("@n8n/constants");
|
|
16
|
+
const decorators_1 = require("@n8n/decorators");
|
|
17
|
+
const di_1 = require("@n8n/di");
|
|
18
|
+
const n8n_core_1 = require("n8n-core");
|
|
19
|
+
const redis_client_service_1 = require("../../services/redis-client.service");
|
|
20
|
+
let ChatHubExecutionStore = class ChatHubExecutionStore {
|
|
21
|
+
constructor(logger, instanceSettings, executionsConfig, globalConfig, chatHubConfig, redisClientService) {
|
|
22
|
+
this.logger = logger;
|
|
23
|
+
this.instanceSettings = instanceSettings;
|
|
24
|
+
this.executionsConfig = executionsConfig;
|
|
25
|
+
this.globalConfig = globalConfig;
|
|
26
|
+
this.chatHubConfig = chatHubConfig;
|
|
27
|
+
this.redisClientService = redisClientService;
|
|
28
|
+
this.memoryStore = new Map();
|
|
29
|
+
this.cleanupTimers = new Map();
|
|
30
|
+
this.redisClient = null;
|
|
31
|
+
this.logger = this.logger.scoped('chat-hub');
|
|
32
|
+
this.useRedis = this.instanceSettings.isMultiMain || this.executionsConfig.mode === 'queue';
|
|
33
|
+
this.redisPrefix = `${this.globalConfig.redis.prefix}:chat-hub:exec:`;
|
|
34
|
+
this.cleanupDelayMs = this.chatHubConfig.executionContextTtl * constants_1.Time.seconds.toMilliseconds;
|
|
35
|
+
if (this.useRedis) {
|
|
36
|
+
this.redisClient = this.redisClientService.createClient({ type: 'subscriber(n8n)' });
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
async register(context) {
|
|
40
|
+
const { executionId } = context;
|
|
41
|
+
if (this.useRedis) {
|
|
42
|
+
await this.setRedisContext(executionId, context);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.memoryStore.set(executionId, context);
|
|
46
|
+
this.scheduleCleanup(executionId);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
async get(executionId) {
|
|
50
|
+
if (this.useRedis) {
|
|
51
|
+
return await this.getRedisContext(executionId);
|
|
52
|
+
}
|
|
53
|
+
return this.memoryStore.get(executionId) ?? null;
|
|
54
|
+
}
|
|
55
|
+
async update(executionId, updates) {
|
|
56
|
+
const context = await this.get(executionId);
|
|
57
|
+
if (!context) {
|
|
58
|
+
this.logger.warn(`Attempted to update non-existent execution context: ${executionId}`);
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
const updatedContext = { ...context, ...updates };
|
|
62
|
+
if (this.useRedis) {
|
|
63
|
+
await this.setRedisContext(executionId, updatedContext);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
this.memoryStore.set(executionId, updatedContext);
|
|
67
|
+
this.scheduleCleanup(executionId);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
async remove(executionId) {
|
|
71
|
+
if (this.useRedis) {
|
|
72
|
+
await this.deleteRedisContext(executionId);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
this.memoryStore.delete(executionId);
|
|
76
|
+
this.cancelCleanup(executionId);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
shutdown() {
|
|
80
|
+
for (const timer of this.cleanupTimers.values()) {
|
|
81
|
+
clearTimeout(timer);
|
|
82
|
+
}
|
|
83
|
+
this.cleanupTimers.clear();
|
|
84
|
+
this.memoryStore.clear();
|
|
85
|
+
if (this.redisClient) {
|
|
86
|
+
this.redisClient.disconnect();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
getContextKey(executionId) {
|
|
90
|
+
return `${this.redisPrefix}${executionId}`;
|
|
91
|
+
}
|
|
92
|
+
async getRedisContext(executionId) {
|
|
93
|
+
if (!this.redisClient)
|
|
94
|
+
return null;
|
|
95
|
+
try {
|
|
96
|
+
const data = await this.redisClient.get(this.getContextKey(executionId));
|
|
97
|
+
if (!data)
|
|
98
|
+
return null;
|
|
99
|
+
return JSON.parse(data);
|
|
100
|
+
}
|
|
101
|
+
catch (error) {
|
|
102
|
+
this.logger.error(`Failed to get Redis context for execution ${executionId}`, { error });
|
|
103
|
+
return null;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
async setRedisContext(executionId, context) {
|
|
107
|
+
if (!this.redisClient)
|
|
108
|
+
return;
|
|
109
|
+
try {
|
|
110
|
+
await this.redisClient.set(this.getContextKey(executionId), JSON.stringify(context), 'EX', this.chatHubConfig.executionContextTtl);
|
|
111
|
+
}
|
|
112
|
+
catch (error) {
|
|
113
|
+
this.logger.error(`Failed to set Redis context for execution ${executionId}`, { error });
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
async deleteRedisContext(executionId) {
|
|
117
|
+
if (!this.redisClient)
|
|
118
|
+
return;
|
|
119
|
+
try {
|
|
120
|
+
await this.redisClient.del(this.getContextKey(executionId));
|
|
121
|
+
}
|
|
122
|
+
catch (error) {
|
|
123
|
+
this.logger.error(`Failed to delete Redis context for execution ${executionId}`, { error });
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
scheduleCleanup(executionId) {
|
|
127
|
+
this.cancelCleanup(executionId);
|
|
128
|
+
const timer = setTimeout(() => {
|
|
129
|
+
this.memoryStore.delete(executionId);
|
|
130
|
+
this.cleanupTimers.delete(executionId);
|
|
131
|
+
this.logger.debug(`Cleaned up expired execution context for ${executionId}`);
|
|
132
|
+
}, this.cleanupDelayMs);
|
|
133
|
+
this.cleanupTimers.set(executionId, timer);
|
|
134
|
+
}
|
|
135
|
+
cancelCleanup(executionId) {
|
|
136
|
+
const timer = this.cleanupTimers.get(executionId);
|
|
137
|
+
if (timer) {
|
|
138
|
+
clearTimeout(timer);
|
|
139
|
+
this.cleanupTimers.delete(executionId);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
};
|
|
143
|
+
exports.ChatHubExecutionStore = ChatHubExecutionStore;
|
|
144
|
+
__decorate([
|
|
145
|
+
(0, decorators_1.OnShutdown)(),
|
|
146
|
+
__metadata("design:type", Function),
|
|
147
|
+
__metadata("design:paramtypes", []),
|
|
148
|
+
__metadata("design:returntype", void 0)
|
|
149
|
+
], ChatHubExecutionStore.prototype, "shutdown", null);
|
|
150
|
+
exports.ChatHubExecutionStore = ChatHubExecutionStore = __decorate([
|
|
151
|
+
(0, di_1.Service)(),
|
|
152
|
+
__metadata("design:paramtypes", [backend_common_1.Logger,
|
|
153
|
+
n8n_core_1.InstanceSettings,
|
|
154
|
+
config_1.ExecutionsConfig,
|
|
155
|
+
config_1.GlobalConfig,
|
|
156
|
+
config_1.ChatHubConfig,
|
|
157
|
+
redis_client_service_1.RedisClientService])
|
|
158
|
+
], ChatHubExecutionStore);
|
|
159
|
+
//# sourceMappingURL=chat-hub-execution-store.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chat-hub-execution-store.service.js","sourceRoot":"","sources":["../../../src/modules/chat-hub/chat-hub-execution-store.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Logger } from '@n8n/backend-common';
|
|
2
|
+
import { ExecutionRepository } from '@n8n/db';
|
|
3
|
+
import { type WorkflowExecuteAfterContext, type WorkflowExecuteResumeContext } from '@n8n/decorators';
|
|
4
|
+
import { ChatExecutionManager } from '../../chat/chat-execution-manager';
|
|
5
|
+
import { ChatHubExecutionStore } from './chat-hub-execution-store.service';
|
|
6
|
+
import { ChatHubExecutionService } from './chat-hub-execution.service';
|
|
7
|
+
import { ChatHubMessageRepository } from './chat-message.repository';
|
|
8
|
+
import { ChatStreamService } from './chat-stream.service';
|
|
9
|
+
export declare class ChatHubExecutionWatcherService {
|
|
10
|
+
private readonly logger;
|
|
11
|
+
private readonly executionStore;
|
|
12
|
+
private readonly messageRepository;
|
|
13
|
+
private readonly chatHubExecutionService;
|
|
14
|
+
private readonly executionRepository;
|
|
15
|
+
private readonly chatStreamService;
|
|
16
|
+
private readonly executionManager;
|
|
17
|
+
constructor(logger: Logger, executionStore: ChatHubExecutionStore, messageRepository: ChatHubMessageRepository, chatHubExecutionService: ChatHubExecutionService, executionRepository: ExecutionRepository, chatStreamService: ChatStreamService, executionManager: ChatExecutionManager);
|
|
18
|
+
handleExecutionResumed(ctx: WorkflowExecuteResumeContext): Promise<void>;
|
|
19
|
+
handleWorkflowExecuteAfter(ctx: WorkflowExecuteAfterContext): Promise<void>;
|
|
20
|
+
private handleWaitingExecution;
|
|
21
|
+
private triggerAutoResume;
|
|
22
|
+
private createNextMessage;
|
|
23
|
+
private pushFinalResults;
|
|
24
|
+
private pushErrorResults;
|
|
25
|
+
}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ChatHubExecutionWatcherService = void 0;
|
|
13
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
14
|
+
const db_1 = require("@n8n/db");
|
|
15
|
+
const decorators_1 = require("@n8n/decorators");
|
|
16
|
+
const di_1 = require("@n8n/di");
|
|
17
|
+
const uuid_1 = require("uuid");
|
|
18
|
+
const chat_execution_manager_1 = require("../../chat/chat-execution-manager");
|
|
19
|
+
const chat_hub_execution_store_service_1 = require("./chat-hub-execution-store.service");
|
|
20
|
+
const chat_hub_execution_service_1 = require("./chat-hub-execution.service");
|
|
21
|
+
const chat_message_repository_1 = require("./chat-message.repository");
|
|
22
|
+
const chat_stream_service_1 = require("./chat-stream.service");
|
|
23
|
+
const utils_1 = require("../../chat/utils");
|
|
24
|
+
let ChatHubExecutionWatcherService = class ChatHubExecutionWatcherService {
|
|
25
|
+
constructor(logger, executionStore, messageRepository, chatHubExecutionService, executionRepository, chatStreamService, executionManager) {
|
|
26
|
+
this.logger = logger;
|
|
27
|
+
this.executionStore = executionStore;
|
|
28
|
+
this.messageRepository = messageRepository;
|
|
29
|
+
this.chatHubExecutionService = chatHubExecutionService;
|
|
30
|
+
this.executionRepository = executionRepository;
|
|
31
|
+
this.chatStreamService = chatStreamService;
|
|
32
|
+
this.executionManager = executionManager;
|
|
33
|
+
this.logger = this.logger.scoped('chat-hub');
|
|
34
|
+
}
|
|
35
|
+
async handleExecutionResumed(ctx) {
|
|
36
|
+
const { executionId } = ctx;
|
|
37
|
+
const context = await this.executionStore.get(executionId);
|
|
38
|
+
if (!context)
|
|
39
|
+
return;
|
|
40
|
+
if (!context.awaitingResume)
|
|
41
|
+
return;
|
|
42
|
+
this.logger.debug('Chat hub execution resumed, notifying frontend', { executionId });
|
|
43
|
+
await this.chatStreamService.startExecution(context.userId, context.sessionId);
|
|
44
|
+
if (context.createMessageOnResume) {
|
|
45
|
+
const newMessageId = (0, uuid_1.v4)();
|
|
46
|
+
await this.messageRepository.updateChatMessage(context.messageId, { status: 'success' });
|
|
47
|
+
await this.createNextMessage(context, newMessageId, executionId);
|
|
48
|
+
await this.executionStore.update(executionId, {
|
|
49
|
+
previousMessageId: context.messageId,
|
|
50
|
+
messageId: newMessageId,
|
|
51
|
+
createMessageOnResume: false,
|
|
52
|
+
awaitingResume: false,
|
|
53
|
+
});
|
|
54
|
+
await this.chatStreamService.startStream({
|
|
55
|
+
userId: context.userId,
|
|
56
|
+
sessionId: context.sessionId,
|
|
57
|
+
messageId: newMessageId,
|
|
58
|
+
previousMessageId: context.messageId,
|
|
59
|
+
retryOfMessageId: null,
|
|
60
|
+
executionId: parseInt(executionId, 10),
|
|
61
|
+
});
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
await this.executionStore.update(executionId, { awaitingResume: false });
|
|
65
|
+
await this.chatStreamService.startStream({
|
|
66
|
+
userId: context.userId,
|
|
67
|
+
sessionId: context.sessionId,
|
|
68
|
+
messageId: context.messageId,
|
|
69
|
+
previousMessageId: context.previousMessageId,
|
|
70
|
+
retryOfMessageId: null,
|
|
71
|
+
executionId: parseInt(executionId, 10),
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
async handleWorkflowExecuteAfter(ctx) {
|
|
75
|
+
const { runData, executionId } = ctx;
|
|
76
|
+
const context = await this.executionStore.get(executionId);
|
|
77
|
+
if (!context)
|
|
78
|
+
return;
|
|
79
|
+
this.logger.debug('Handling workflow execution completion', { executionId });
|
|
80
|
+
if (!['success', 'waiting', 'canceled'].includes(runData.status)) {
|
|
81
|
+
const errorMessage = this.chatHubExecutionService.extractErrorMessage(runData) ??
|
|
82
|
+
'Failed to generate a response';
|
|
83
|
+
await this.pushErrorResults(context, errorMessage);
|
|
84
|
+
await this.executionStore.remove(executionId);
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (runData.status === 'canceled') {
|
|
88
|
+
await this.chatStreamService.endExecution(context.userId, context.sessionId, 'cancelled');
|
|
89
|
+
await this.executionStore.remove(executionId);
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
const message = this.chatHubExecutionService.extractMessage(runData, context.responseMode);
|
|
93
|
+
if (runData.status === 'waiting') {
|
|
94
|
+
await this.handleWaitingExecution(context, executionId, message);
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
if (runData.finished) {
|
|
98
|
+
await this.pushFinalResults(context, message);
|
|
99
|
+
await this.executionStore.remove(executionId);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
async handleWaitingExecution(context, executionId, message) {
|
|
103
|
+
await this.messageRepository.updateChatMessage(context.messageId, {
|
|
104
|
+
content: message ?? '',
|
|
105
|
+
status: 'waiting',
|
|
106
|
+
});
|
|
107
|
+
if (message) {
|
|
108
|
+
await this.chatStreamService.sendChunk(context.sessionId, context.messageId, message);
|
|
109
|
+
}
|
|
110
|
+
await this.chatStreamService.endStream(context.sessionId, context.messageId, 'waiting');
|
|
111
|
+
await this.chatStreamService.endExecution(context.userId, context.sessionId, 'success');
|
|
112
|
+
if (context.responseMode === 'responseNodes') {
|
|
113
|
+
const execution = await this.executionRepository.findSingleExecution(executionId, {
|
|
114
|
+
includeData: true,
|
|
115
|
+
unflattenData: true,
|
|
116
|
+
});
|
|
117
|
+
if (execution) {
|
|
118
|
+
const lastNode = (0, utils_1.getLastNodeExecuted)(execution);
|
|
119
|
+
if (lastNode && (0, utils_1.shouldResumeImmediately)(lastNode)) {
|
|
120
|
+
await this.triggerAutoResume(context, execution);
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
await this.executionStore.update(executionId, {
|
|
126
|
+
awaitingResume: true,
|
|
127
|
+
createMessageOnResume: true,
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
async triggerAutoResume(context, execution) {
|
|
131
|
+
this.logger.debug('Triggering auto-resume of execution', { executionId: execution.id });
|
|
132
|
+
await this.messageRepository.updateChatMessage(context.messageId, { status: 'success' });
|
|
133
|
+
const newMessageId = (0, uuid_1.v4)();
|
|
134
|
+
await this.createNextMessage(context, newMessageId, execution.id);
|
|
135
|
+
await this.executionStore.update(execution.id, {
|
|
136
|
+
previousMessageId: context.messageId,
|
|
137
|
+
messageId: newMessageId,
|
|
138
|
+
awaitingResume: true,
|
|
139
|
+
createMessageOnResume: false,
|
|
140
|
+
});
|
|
141
|
+
void this.executionManager.runWorkflow(execution, {
|
|
142
|
+
action: 'sendMessage',
|
|
143
|
+
chatInput: '',
|
|
144
|
+
sessionId: context.sessionId,
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
async createNextMessage(context, messageId, executionId) {
|
|
148
|
+
await this.messageRepository.createChatMessage({
|
|
149
|
+
id: messageId,
|
|
150
|
+
sessionId: context.sessionId,
|
|
151
|
+
previousMessageId: context.messageId,
|
|
152
|
+
executionId: parseInt(executionId, 10),
|
|
153
|
+
type: 'ai',
|
|
154
|
+
name: 'AI',
|
|
155
|
+
status: 'running',
|
|
156
|
+
content: '',
|
|
157
|
+
retryOfMessageId: null,
|
|
158
|
+
...context.model,
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
async pushFinalResults(context, message) {
|
|
162
|
+
if (message) {
|
|
163
|
+
await this.chatStreamService.sendChunk(context.sessionId, context.messageId, message);
|
|
164
|
+
}
|
|
165
|
+
await this.chatStreamService.endStream(context.sessionId, context.messageId, 'success');
|
|
166
|
+
await this.chatStreamService.endExecution(context.userId, context.sessionId, 'success');
|
|
167
|
+
await this.messageRepository.updateChatMessage(context.messageId, {
|
|
168
|
+
content: message ?? '',
|
|
169
|
+
status: 'success',
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
async pushErrorResults(context, errorMessage) {
|
|
173
|
+
await this.chatStreamService.sendChunk(context.sessionId, context.messageId, errorMessage);
|
|
174
|
+
await this.chatStreamService.endStream(context.sessionId, context.messageId, 'error');
|
|
175
|
+
await this.chatStreamService.endExecution(context.userId, context.sessionId, 'error');
|
|
176
|
+
await this.messageRepository.updateChatMessage(context.messageId, {
|
|
177
|
+
content: errorMessage,
|
|
178
|
+
status: 'error',
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
};
|
|
182
|
+
exports.ChatHubExecutionWatcherService = ChatHubExecutionWatcherService;
|
|
183
|
+
__decorate([
|
|
184
|
+
(0, decorators_1.OnLifecycleEvent)('workflowExecuteResume'),
|
|
185
|
+
__metadata("design:type", Function),
|
|
186
|
+
__metadata("design:paramtypes", [Object]),
|
|
187
|
+
__metadata("design:returntype", Promise)
|
|
188
|
+
], ChatHubExecutionWatcherService.prototype, "handleExecutionResumed", null);
|
|
189
|
+
__decorate([
|
|
190
|
+
(0, decorators_1.OnLifecycleEvent)('workflowExecuteAfter'),
|
|
191
|
+
__metadata("design:type", Function),
|
|
192
|
+
__metadata("design:paramtypes", [Object]),
|
|
193
|
+
__metadata("design:returntype", Promise)
|
|
194
|
+
], ChatHubExecutionWatcherService.prototype, "handleWorkflowExecuteAfter", null);
|
|
195
|
+
exports.ChatHubExecutionWatcherService = ChatHubExecutionWatcherService = __decorate([
|
|
196
|
+
(0, di_1.Service)(),
|
|
197
|
+
__metadata("design:paramtypes", [backend_common_1.Logger,
|
|
198
|
+
chat_hub_execution_store_service_1.ChatHubExecutionStore,
|
|
199
|
+
chat_message_repository_1.ChatHubMessageRepository,
|
|
200
|
+
chat_hub_execution_service_1.ChatHubExecutionService,
|
|
201
|
+
db_1.ExecutionRepository,
|
|
202
|
+
chat_stream_service_1.ChatStreamService,
|
|
203
|
+
chat_execution_manager_1.ChatExecutionManager])
|
|
204
|
+
], ChatHubExecutionWatcherService);
|
|
205
|
+
//# sourceMappingURL=chat-hub-execution-watcher.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chat-hub-execution-watcher.service.js","sourceRoot":"","sources":["../../../src/modules/chat-hub/chat-hub-execution-watcher.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,13 +2,14 @@ import { type ChatMessageId, type ChatSessionId, ChatHubConversationModel } from
|
|
|
2
2
|
import { Logger } from '@n8n/backend-common';
|
|
3
3
|
import { ExecutionRepository, IExecutionResponse, User } from '@n8n/db';
|
|
4
4
|
import { InstanceSettings } from 'n8n-core';
|
|
5
|
-
import { type IWorkflowBase, IRunExecutionData } from 'n8n-workflow';
|
|
5
|
+
import { type IWorkflowBase, IRunExecutionData, IRun } from 'n8n-workflow';
|
|
6
6
|
import { ActiveExecutions } from '../../active-executions';
|
|
7
7
|
import { ChatExecutionManager } from '../../chat/chat-execution-manager';
|
|
8
8
|
import { ExecutionService } from '../../executions/execution.service';
|
|
9
9
|
import { WorkflowExecutionService } from '../../workflows/workflow-execution.service';
|
|
10
|
+
import { ChatHubExecutionStore } from './chat-hub-execution-store.service';
|
|
10
11
|
import { ChatHubWorkflowService } from './chat-hub-workflow.service';
|
|
11
|
-
import { ChatTriggerResponseMode } from './chat-hub.types';
|
|
12
|
+
import type { NonStreamingResponseMode, ChatTriggerResponseMode } from './chat-hub.types';
|
|
12
13
|
import { ChatHubMessageRepository } from './chat-message.repository';
|
|
13
14
|
import { ChatStreamService } from './chat-stream.service';
|
|
14
15
|
export declare class ChatHubExecutionService {
|
|
@@ -21,8 +22,9 @@ export declare class ChatHubExecutionService {
|
|
|
21
22
|
private readonly instanceSettings;
|
|
22
23
|
private readonly chatStreamService;
|
|
23
24
|
private readonly chatHubWorkflowService;
|
|
25
|
+
private readonly chatHubExecutionStore;
|
|
24
26
|
private readonly messageRepository;
|
|
25
|
-
constructor(logger: Logger, executionService: ExecutionService, workflowExecutionService: WorkflowExecutionService, executionRepository: ExecutionRepository, executionManager: ChatExecutionManager, activeExecutions: ActiveExecutions, instanceSettings: InstanceSettings, chatStreamService: ChatStreamService, chatHubWorkflowService: ChatHubWorkflowService, messageRepository: ChatHubMessageRepository);
|
|
27
|
+
constructor(logger: Logger, executionService: ExecutionService, workflowExecutionService: WorkflowExecutionService, executionRepository: ExecutionRepository, executionManager: ChatExecutionManager, activeExecutions: ActiveExecutions, instanceSettings: InstanceSettings, chatStreamService: ChatStreamService, chatHubWorkflowService: ChatHubWorkflowService, chatHubExecutionStore: ChatHubExecutionStore, messageRepository: ChatHubMessageRepository);
|
|
26
28
|
execute(user: User, workflowData: IWorkflowBase, executionData: IRunExecutionData): Promise<{
|
|
27
29
|
executionId: string;
|
|
28
30
|
}>;
|
|
@@ -30,19 +32,15 @@ export declare class ChatHubExecutionService {
|
|
|
30
32
|
executeChatWorkflowWithCleanup(user: User, model: ChatHubConversationModel, workflowData: IWorkflowBase, executionData: IRunExecutionData, sessionId: ChatSessionId, previousMessageId: ChatMessageId, retryOfMessageId: ChatMessageId | null, responseMode: ChatTriggerResponseMode): Promise<void>;
|
|
31
33
|
private executeChatWorkflow;
|
|
32
34
|
private executeWithStreaming;
|
|
33
|
-
private
|
|
34
|
-
resumeChatExecution(execution: IExecutionResponse, message: string, sessionId: ChatSessionId,
|
|
35
|
-
private resumeExecution;
|
|
35
|
+
private executeNonStreaming;
|
|
36
|
+
resumeChatExecution(execution: IExecutionResponse, message: string, sessionId: ChatSessionId, _user: User, previousMessageId: ChatMessageId, model: ChatHubConversationModel, _responseMode: 'responseNodes'): Promise<void>;
|
|
36
37
|
waitForExecutionCompletion(executionId: string): Promise<void>;
|
|
37
38
|
private waitForExecutionPoller;
|
|
38
39
|
private waitForExecutionPromise;
|
|
39
40
|
private waitForErrorDetails;
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
private getLastNodeExecutedName;
|
|
44
|
-
private getNodeOutputs;
|
|
41
|
+
private createStreamAdapter;
|
|
42
|
+
extractErrorMessage(runData: IRun): string | undefined;
|
|
43
|
+
extractMessage(runData: IRun, responseMode: NonStreamingResponseMode): string | undefined;
|
|
45
44
|
private getFirstOutputEntry;
|
|
46
45
|
private extractMessageFromEntry;
|
|
47
|
-
private createStreamAdapter;
|
|
48
46
|
}
|