devchain-cli 0.12.4 → 0.13.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/README.md +1 -1
- package/dist/cli.js +63 -104
- package/dist/drizzle/0062_provider_probe_proofs.sql +6 -0
- package/dist/drizzle/0063_session_name.sql +1 -0
- package/dist/drizzle/meta/0062_snapshot.json +5208 -0
- package/dist/drizzle/meta/0063_snapshot.json +5215 -0
- package/dist/drizzle/meta/_journal.json +14 -0
- package/dist/node_modules/@devchain/shared/host-resolver.d.ts +18 -0
- package/dist/node_modules/@devchain/shared/host-resolver.d.ts.map +1 -0
- package/dist/node_modules/@devchain/shared/host-resolver.js +69 -0
- package/dist/node_modules/@devchain/shared/host-resolver.js.map +1 -0
- package/dist/node_modules/@devchain/shared/index.d.ts +1 -0
- package/dist/node_modules/@devchain/shared/index.d.ts.map +1 -1
- package/dist/node_modules/@devchain/shared/index.js +1 -0
- package/dist/node_modules/@devchain/shared/index.js.map +1 -1
- package/dist/node_modules/@devchain/shared/package.json +2 -0
- package/dist/node_modules/@devchain/shared/tsconfig.tsbuildinfo +1 -1
- package/dist/server/app.main.module.js +12 -6
- package/dist/server/app.main.module.js.map +1 -1
- package/dist/server/app.normal.module.js +14 -6
- package/dist/server/app.normal.module.js.map +1 -1
- package/dist/server/common/config/env.config.d.ts +7 -0
- package/dist/server/common/config/env.config.js +11 -0
- package/dist/server/common/config/env.config.js.map +1 -1
- package/dist/server/common/config/host-helpers.d.ts +3 -3
- package/dist/server/common/config/host-helpers.js +5 -28
- package/dist/server/common/config/host-helpers.js.map +1 -1
- package/dist/server/common/errors/service-unavailable.error.d.ts +4 -0
- package/dist/server/common/errors/service-unavailable.error.js +12 -0
- package/dist/server/common/errors/service-unavailable.error.js.map +1 -0
- package/dist/server/common/process-identity.d.ts +1 -0
- package/dist/server/common/process-identity.js +6 -0
- package/dist/server/common/process-identity.js.map +1 -0
- package/dist/server/common/resolve-binary.d.ts +2 -1
- package/dist/server/common/resolve-binary.js +7 -6
- package/dist/server/common/resolve-binary.js.map +1 -1
- package/dist/server/common/template/prompt-render-context.d.ts +12 -0
- package/dist/server/common/template/prompt-render-context.js +37 -0
- package/dist/server/common/template/prompt-render-context.js.map +1 -0
- package/dist/server/common/test/app-bootstrap.helper.d.ts +13 -0
- package/dist/server/common/test/app-bootstrap.helper.js +184 -0
- package/dist/server/common/test/app-bootstrap.helper.js.map +1 -0
- package/dist/server/main.js +2 -2
- package/dist/server/main.js.map +1 -1
- package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.d.ts +5 -0
- package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js +33 -0
- package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js.map +1 -0
- package/dist/server/modules/agent-message-delivery/adapters/legacy-recipient-resolver.adapter.d.ts +6 -0
- package/dist/server/modules/agent-message-delivery/adapters/legacy-recipient-resolver.adapter.js +22 -0
- package/dist/server/modules/agent-message-delivery/adapters/legacy-recipient-resolver.adapter.js.map +1 -0
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.module.d.ts +2 -0
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.module.js +45 -0
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.module.js.map +1 -0
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.d.ts +21 -0
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js +107 -0
- package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js.map +1 -0
- package/dist/server/modules/agent-message-delivery/dtos/delivery.types.d.ts +32 -0
- package/dist/server/modules/agent-message-delivery/dtos/delivery.types.js +3 -0
- package/dist/server/modules/agent-message-delivery/dtos/delivery.types.js.map +1 -0
- package/dist/server/modules/agent-message-delivery/ports/delivery-formatter.d.ts +4 -0
- package/dist/server/modules/agent-message-delivery/ports/delivery-formatter.js +7 -0
- package/dist/server/modules/agent-message-delivery/ports/delivery-formatter.js.map +1 -0
- package/dist/server/modules/agent-message-delivery/ports/delivery-recipient-resolver.d.ts +8 -0
- package/dist/server/modules/agent-message-delivery/ports/delivery-recipient-resolver.js +7 -0
- package/dist/server/modules/agent-message-delivery/ports/delivery-recipient-resolver.js.map +1 -0
- package/dist/server/modules/{events/subscribers/chat-message-broadcaster.subscriber.d.ts → agent-message-delivery/subscribers/chat-message-delivery.subscriber.d.ts} +6 -4
- package/dist/server/modules/agent-message-delivery/subscribers/chat-message-delivery.subscriber.js +63 -0
- package/dist/server/modules/agent-message-delivery/subscribers/chat-message-delivery.subscriber.js.map +1 -0
- package/dist/server/modules/agents/agents.module.js +2 -2
- package/dist/server/modules/agents/agents.module.js.map +1 -1
- package/dist/server/modules/agents/controllers/agents.controller.d.ts +3 -1
- package/dist/server/modules/agents/controllers/agents.controller.js +6 -5
- package/dist/server/modules/agents/controllers/agents.controller.js.map +1 -1
- package/dist/server/modules/chat/chat.module.js +14 -4
- package/dist/server/modules/chat/chat.module.js.map +1 -1
- package/dist/server/modules/chat/services/chat-session-invite.service.d.ts +16 -0
- package/dist/server/modules/chat/services/chat-session-invite.service.js +194 -0
- package/dist/server/modules/chat/services/chat-session-invite.service.js.map +1 -0
- package/dist/server/modules/chat/services/chat-settings.service.js +2 -1
- package/dist/server/modules/chat/services/chat-settings.service.js.map +1 -1
- package/dist/server/modules/chat/services/chat.service.d.ts +6 -4
- package/dist/server/modules/chat/services/chat.service.js +64 -105
- package/dist/server/modules/chat/services/chat.service.js.map +1 -1
- package/dist/server/modules/cloud/cloud.module.d.ts +2 -0
- package/dist/server/modules/cloud/cloud.module.js +54 -0
- package/dist/server/modules/cloud/cloud.module.js.map +1 -0
- package/dist/server/modules/cloud/controllers/activity-proxy.controller.d.ts +6 -0
- package/dist/server/modules/cloud/controllers/activity-proxy.controller.js +39 -0
- package/dist/server/modules/cloud/controllers/activity-proxy.controller.js.map +1 -0
- package/dist/server/modules/cloud/controllers/auth-callback.controller.d.ts +11 -0
- package/dist/server/modules/cloud/controllers/auth-callback.controller.js +72 -0
- package/dist/server/modules/cloud/controllers/auth-callback.controller.js.map +1 -0
- package/dist/server/modules/cloud/controllers/devices-proxy.controller.d.ts +9 -0
- package/dist/server/modules/cloud/controllers/devices-proxy.controller.js +75 -0
- package/dist/server/modules/cloud/controllers/devices-proxy.controller.js.map +1 -0
- package/dist/server/modules/cloud/controllers/egress-config.controller.d.ts +12 -0
- package/dist/server/modules/cloud/controllers/egress-config.controller.js +66 -0
- package/dist/server/modules/cloud/controllers/egress-config.controller.js.map +1 -0
- package/dist/server/modules/cloud/controllers/preferences-proxy.controller.d.ts +30 -0
- package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js +159 -0
- package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js.map +1 -0
- package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.d.ts +11 -0
- package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js +89 -0
- package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js.map +1 -0
- package/dist/server/modules/cloud/dtos/cloud-tokens.dto.d.ts +20 -0
- package/dist/server/modules/cloud/dtos/cloud-tokens.dto.js +12 -0
- package/dist/server/modules/cloud/dtos/cloud-tokens.dto.js.map +1 -0
- package/dist/server/modules/cloud/services/cloud-egress-bridge.service.d.ts +24 -0
- package/dist/server/modules/cloud/services/cloud-egress-bridge.service.js +111 -0
- package/dist/server/modules/cloud/services/cloud-egress-bridge.service.js.map +1 -0
- package/dist/server/modules/cloud/services/cloud-session-manager.service.d.ts +27 -0
- package/dist/server/modules/cloud/services/cloud-session-manager.service.js +257 -0
- package/dist/server/modules/cloud/services/cloud-session-manager.service.js.map +1 -0
- package/dist/server/modules/cloud/services/egress-queue.service.d.ts +20 -0
- package/dist/server/modules/cloud/services/egress-queue.service.js +136 -0
- package/dist/server/modules/cloud/services/egress-queue.service.js.map +1 -0
- package/dist/server/modules/cloud/services/encrypted-token-store.service.d.ts +15 -0
- package/dist/server/modules/cloud/services/encrypted-token-store.service.js +131 -0
- package/dist/server/modules/cloud/services/encrypted-token-store.service.js.map +1 -0
- package/dist/server/modules/cloud/services/event-mapper.service.d.ts +42 -0
- package/dist/server/modules/cloud/services/event-mapper.service.js +44 -0
- package/dist/server/modules/cloud/services/event-mapper.service.js.map +1 -0
- package/dist/server/modules/cloud/services/project-activity-reporter.service.d.ts +21 -0
- package/dist/server/modules/cloud/services/project-activity-reporter.service.js +138 -0
- package/dist/server/modules/cloud/services/project-activity-reporter.service.js.map +1 -0
- package/dist/server/modules/cloud/services/project-egress-config.service.d.ts +13 -0
- package/dist/server/modules/cloud/services/project-egress-config.service.js +87 -0
- package/dist/server/modules/cloud/services/project-egress-config.service.js.map +1 -0
- package/dist/server/modules/cloud/services/refresh-gate.service.d.ts +9 -0
- package/dist/server/modules/cloud/services/refresh-gate.service.js +63 -0
- package/dist/server/modules/cloud/services/refresh-gate.service.js.map +1 -0
- package/dist/server/modules/cloud/types/index.d.ts +14 -0
- package/dist/server/modules/cloud/types/index.js +3 -0
- package/dist/server/modules/cloud/types/index.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.d.ts +2 -0
- package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js +25 -0
- package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.d.ts +39 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js +319 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.d.ts +44 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js +456 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js.map +1 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-keypair.service.d.ts +22 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-keypair.service.js +146 -0
- package/dist/server/modules/cloud-tunnel/services/tunnel-keypair.service.js.map +1 -0
- package/dist/server/modules/codebase-overview-analyzer/codebase-overview-analyzer.module.js +2 -1
- package/dist/server/modules/codebase-overview-analyzer/codebase-overview-analyzer.module.js.map +1 -1
- package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.d.ts +3 -1
- package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.js +14 -20
- package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.js.map +1 -1
- package/dist/server/modules/core/controllers/preflight.controller.d.ts +0 -4
- package/dist/server/modules/core/controllers/preflight.controller.js +0 -17
- package/dist/server/modules/core/controllers/preflight.controller.js.map +1 -1
- package/dist/server/modules/core/controllers/runtime.controller.d.ts +4 -0
- package/dist/server/modules/core/controllers/runtime.controller.js +5 -0
- package/dist/server/modules/core/controllers/runtime.controller.js.map +1 -1
- package/dist/server/modules/core/core-normal-health.module.js +2 -0
- package/dist/server/modules/core/core-normal-health.module.js.map +1 -1
- package/dist/server/modules/core/core-normal.module.js +12 -6
- package/dist/server/modules/core/core-normal.module.js.map +1 -1
- package/dist/server/modules/core/services/gemini-trusted-folders.module.d.ts +2 -0
- package/dist/server/modules/core/services/gemini-trusted-folders.module.js +21 -0
- package/dist/server/modules/core/services/gemini-trusted-folders.module.js.map +1 -0
- package/dist/server/modules/core/services/normal-readiness-checker.service.d.ts +3 -1
- package/dist/server/modules/core/services/normal-readiness-checker.service.js +9 -11
- package/dist/server/modules/core/services/normal-readiness-checker.service.js.map +1 -1
- package/dist/server/modules/core/services/preflight.service.d.ts +4 -3
- package/dist/server/modules/core/services/preflight.service.js +21 -17
- package/dist/server/modules/core/services/preflight.service.js.map +1 -1
- package/dist/server/modules/epics/controllers/epic-comments.controller.d.ts +3 -1
- package/dist/server/modules/epics/controllers/epic-comments.controller.js +5 -7
- package/dist/server/modules/epics/controllers/epic-comments.controller.js.map +1 -1
- package/dist/server/modules/epics/epics.module.js +13 -4
- package/dist/server/modules/epics/epics.module.js.map +1 -1
- package/dist/server/modules/epics/services/epics.service.d.ts +21 -7
- package/dist/server/modules/epics/services/epics.service.js +176 -50
- package/dist/server/modules/epics/services/epics.service.js.map +1 -1
- package/dist/server/modules/epics/subscribers/epic-assignment-notifier.subscriber.d.ts +25 -0
- package/dist/server/modules/{events → epics}/subscribers/epic-assignment-notifier.subscriber.js +47 -105
- package/dist/server/modules/epics/subscribers/epic-assignment-notifier.subscriber.js.map +1 -0
- package/dist/server/modules/epics/subscribers/sub-epic-created-notifier.subscriber.d.ts +15 -0
- package/dist/server/modules/{events → epics}/subscribers/sub-epic-created-notifier.subscriber.js +43 -52
- package/dist/server/modules/epics/subscribers/sub-epic-created-notifier.subscriber.js.map +1 -0
- package/dist/server/modules/events/catalog/broadcast-metadata.d.ts +8 -0
- package/dist/server/modules/events/catalog/broadcast-metadata.js +3 -0
- package/dist/server/modules/events/catalog/broadcast-metadata.js.map +1 -0
- package/dist/server/modules/events/catalog/broadcast-registry.d.ts +4 -0
- package/dist/server/modules/events/catalog/broadcast-registry.js +335 -0
- package/dist/server/modules/events/catalog/broadcast-registry.js.map +1 -0
- package/dist/server/modules/events/catalog/chat.message.read.d.ts +21 -0
- package/dist/server/modules/events/catalog/chat.message.read.js +14 -0
- package/dist/server/modules/events/catalog/chat.message.read.js.map +1 -0
- package/dist/server/modules/events/catalog/epic.comment.created.d.ts +57 -0
- package/dist/server/modules/events/catalog/epic.comment.created.js +28 -0
- package/dist/server/modules/events/catalog/epic.comment.created.js.map +1 -0
- package/dist/server/modules/events/catalog/epic.created.d.ts +18 -0
- package/dist/server/modules/events/catalog/epic.created.js +6 -0
- package/dist/server/modules/events/catalog/epic.created.js.map +1 -1
- package/dist/server/modules/events/catalog/epic.deleted.d.ts +39 -0
- package/dist/server/modules/events/catalog/epic.deleted.js +22 -0
- package/dist/server/modules/events/catalog/epic.deleted.js.map +1 -0
- package/dist/server/modules/events/catalog/epic.updated.d.ts +6 -0
- package/dist/server/modules/events/catalog/epic.updated.js +2 -0
- package/dist/server/modules/events/catalog/epic.updated.js.map +1 -1
- package/dist/server/modules/events/catalog/guest.unregistered.d.ts +2 -2
- package/dist/server/modules/events/catalog/index.d.ts +272 -2
- package/dist/server/modules/events/catalog/index.js +18 -0
- package/dist/server/modules/events/catalog/index.js.map +1 -1
- package/dist/server/modules/events/catalog/review.comment.created.d.ts +6 -0
- package/dist/server/modules/events/catalog/review.comment.created.js +2 -0
- package/dist/server/modules/events/catalog/review.comment.created.js.map +1 -1
- package/dist/server/modules/events/catalog/session.activity.changed.d.ts +21 -0
- package/dist/server/modules/events/catalog/session.activity.changed.js +14 -0
- package/dist/server/modules/events/catalog/session.activity.changed.js.map +1 -0
- package/dist/server/modules/events/catalog/session.cloud-connected.d.ts +12 -0
- package/dist/server/modules/events/catalog/session.cloud-connected.js +11 -0
- package/dist/server/modules/events/catalog/session.cloud-connected.js.map +1 -0
- package/dist/server/modules/events/catalog/session.cloud-disconnected.d.ts +12 -0
- package/dist/server/modules/events/catalog/session.cloud-disconnected.js +11 -0
- package/dist/server/modules/events/catalog/session.cloud-disconnected.js.map +1 -0
- package/dist/server/modules/events/catalog/session.presence.changed.d.ts +18 -0
- package/dist/server/modules/events/catalog/session.presence.changed.js +13 -0
- package/dist/server/modules/events/catalog/session.presence.changed.js.map +1 -0
- package/dist/server/modules/events/catalog/session.provider-session-id.discovered.d.ts +18 -0
- package/dist/server/modules/events/catalog/session.provider-session-id.discovered.js +13 -0
- package/dist/server/modules/events/catalog/session.provider-session-id.discovered.js.map +1 -0
- package/dist/server/modules/events/catalog/session.recommendation.d.ts +30 -0
- package/dist/server/modules/events/catalog/session.recommendation.js +17 -0
- package/dist/server/modules/events/catalog/session.recommendation.js.map +1 -0
- package/dist/server/modules/events/catalog/session.restored.d.ts +3 -0
- package/dist/server/modules/events/catalog/session.restored.js +1 -0
- package/dist/server/modules/events/catalog/session.restored.js.map +1 -1
- package/dist/server/modules/events/catalog/session.transcript.updated.d.ts +21 -0
- package/dist/server/modules/events/catalog/session.transcript.updated.js +7 -0
- package/dist/server/modules/events/catalog/session.transcript.updated.js.map +1 -1
- package/dist/server/modules/events/catalog/team.config.updated.d.ts +9 -0
- package/dist/server/modules/events/catalog/team.config.updated.js +3 -0
- package/dist/server/modules/events/catalog/team.config.updated.js.map +1 -1
- package/dist/server/modules/events/catalog/team.member.added.d.ts +12 -0
- package/dist/server/modules/events/catalog/team.member.added.js +4 -0
- package/dist/server/modules/events/catalog/team.member.added.js.map +1 -1
- package/dist/server/modules/events/catalog/team.member.removed.d.ts +12 -0
- package/dist/server/modules/events/catalog/team.member.removed.js +4 -0
- package/dist/server/modules/events/catalog/team.member.removed.js.map +1 -1
- package/dist/server/modules/events/events-core.module.d.ts +2 -0
- package/dist/server/modules/events/{events-domain.module.js → events-core.module.js} +13 -24
- package/dist/server/modules/events/events-core.module.js.map +1 -0
- package/dist/server/modules/events/events.module.js +3 -4
- package/dist/server/modules/events/events.module.js.map +1 -1
- package/dist/server/modules/events/index.d.ts +2 -1
- package/dist/server/modules/events/index.js +2 -1
- package/dist/server/modules/events/index.js.map +1 -1
- package/dist/server/modules/events/services/catalog-broadcaster.service.d.ts +9 -0
- package/dist/server/modules/events/services/catalog-broadcaster.service.js +56 -0
- package/dist/server/modules/events/services/catalog-broadcaster.service.js.map +1 -0
- package/dist/server/modules/events/services/events-stream.service.d.ts +3 -3
- package/dist/server/modules/events/services/events-stream.service.js +6 -6
- package/dist/server/modules/events/services/events-stream.service.js.map +1 -1
- package/dist/server/modules/git/git.module.js +2 -1
- package/dist/server/modules/git/git.module.js.map +1 -1
- package/dist/server/modules/git/services/git.service.d.ts +3 -1
- package/dist/server/modules/git/services/git.service.js +17 -19
- package/dist/server/modules/git/services/git.service.js.map +1 -1
- package/dist/server/modules/guests/guests.module.js +2 -2
- package/dist/server/modules/guests/guests.module.js.map +1 -1
- package/dist/server/modules/guests/services/guest-health.service.d.ts +3 -3
- package/dist/server/modules/guests/services/guest-health.service.js +7 -7
- package/dist/server/modules/guests/services/guest-health.service.js.map +1 -1
- package/dist/server/modules/guests/services/guests.service.d.ts +3 -3
- package/dist/server/modules/guests/services/guests.service.js +7 -7
- package/dist/server/modules/guests/services/guests.service.js.map +1 -1
- package/dist/server/modules/hooks/hooks.module.js +2 -2
- package/dist/server/modules/hooks/hooks.module.js.map +1 -1
- package/dist/server/modules/mcp/controllers/mcp-http.controller.js +2 -2
- package/dist/server/modules/mcp/controllers/mcp-http.controller.js.map +1 -1
- package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js +2 -2
- package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js.map +1 -1
- package/dist/server/modules/mcp/dtos/mcp.dto.d.ts +40 -27
- package/dist/server/modules/mcp/dtos/mcp.dto.js +20 -4
- package/dist/server/modules/mcp/dtos/mcp.dto.js.map +1 -1
- package/dist/server/modules/mcp/mcp-full.module.d.ts +2 -0
- package/dist/server/modules/mcp/{mcp.module.js → mcp-full.module.js} +15 -21
- package/dist/server/modules/mcp/mcp-full.module.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/activity-context.d.ts +6 -0
- package/dist/server/modules/mcp/services/handlers/activity-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/activity-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/activity-tools.d.ts +3 -3
- package/dist/server/modules/mcp/services/handlers/activity-tools.js +87 -101
- package/dist/server/modules/mcp/services/handlers/activity-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/agent-context.d.ts +16 -0
- package/dist/server/modules/mcp/services/handlers/agent-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/agent-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/agent-tools.d.ts +5 -0
- package/dist/server/modules/mcp/services/handlers/agent-tools.js +194 -0
- package/dist/server/modules/mcp/services/handlers/agent-tools.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/chat-context.d.ts +17 -0
- package/dist/server/modules/mcp/services/handlers/chat-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/chat-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/chat-tools/recipient-resolution.d.ts +13 -0
- package/dist/server/modules/mcp/services/handlers/chat-tools/recipient-resolution.js +40 -0
- package/dist/server/modules/mcp/services/handlers/chat-tools/recipient-resolution.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/chat-tools.d.ts +5 -5
- package/dist/server/modules/mcp/services/handlers/chat-tools.js +149 -306
- package/dist/server/modules/mcp/services/handlers/chat-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/document-context.d.ts +8 -0
- package/dist/server/modules/mcp/services/handlers/document-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/document-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/document-tools.d.ts +5 -5
- package/dist/server/modules/mcp/services/handlers/document-tools.js +20 -54
- package/dist/server/modules/mcp/services/handlers/document-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/epic-context.d.ts +9 -0
- package/dist/server/modules/mcp/services/handlers/epic-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/epic-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/epic-tools.d.ts +8 -10
- package/dist/server/modules/mcp/services/handlers/epic-tools.js +186 -397
- package/dist/server/modules/mcp/services/handlers/epic-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/null-adapter.d.ts +1 -0
- package/dist/server/modules/mcp/services/handlers/null-adapter.js +20 -0
- package/dist/server/modules/mcp/services/handlers/null-adapter.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/prompt-context.d.ts +9 -0
- package/dist/server/modules/mcp/services/handlers/prompt-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/prompt-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/prompt-tools.d.ts +3 -3
- package/dist/server/modules/mcp/services/handlers/prompt-tools.js +22 -51
- package/dist/server/modules/mcp/services/handlers/prompt-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/record-context.d.ts +5 -0
- package/dist/server/modules/mcp/services/handlers/record-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/record-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/record-tools.d.ts +7 -7
- package/dist/server/modules/mcp/services/handlers/record-tools.js +6 -7
- package/dist/server/modules/mcp/services/handlers/record-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/review-context.d.ts +11 -0
- package/dist/server/modules/mcp/services/handlers/review-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/review-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/review-tools.d.ts +7 -7
- package/dist/server/modules/mcp/services/handlers/review-tools.js +164 -362
- package/dist/server/modules/mcp/services/handlers/review-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/session-context.d.ts +9 -0
- package/dist/server/modules/mcp/services/handlers/session-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/session-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/session-tools.d.ts +3 -3
- package/dist/server/modules/mcp/services/handlers/session-tools.js +21 -23
- package/dist/server/modules/mcp/services/handlers/session-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/skill-context.d.ts +6 -0
- package/dist/server/modules/mcp/services/handlers/skill-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/skill-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/skill-tools.d.ts +3 -3
- package/dist/server/modules/mcp/services/handlers/skill-tools.js +55 -75
- package/dist/server/modules/mcp/services/handlers/skill-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/teams-context.d.ts +9 -0
- package/dist/server/modules/mcp/services/handlers/teams-context.js +3 -0
- package/dist/server/modules/mcp/services/handlers/teams-context.js.map +1 -0
- package/dist/server/modules/mcp/services/handlers/teams-tools.d.ts +7 -7
- package/dist/server/modules/mcp/services/handlers/teams-tools.js +260 -267
- package/dist/server/modules/mcp/services/handlers/teams-tools.js.map +1 -1
- package/dist/server/modules/mcp/services/handlers/types.d.ts +2 -35
- package/dist/server/modules/mcp/services/instructions-resolver.d.ts +2 -2
- package/dist/server/modules/mcp/services/instructions-resolver.js.map +1 -1
- package/dist/server/modules/mcp/services/mcp.service.d.ts +21 -8
- package/dist/server/modules/mcp/services/mcp.service.js +208 -109
- package/dist/server/modules/mcp/services/mcp.service.js.map +1 -1
- package/dist/server/modules/mcp/services/utils/agent-name-resolver.d.ts +2 -0
- package/dist/server/modules/mcp/services/utils/agent-name-resolver.js +27 -0
- package/dist/server/modules/mcp/services/utils/agent-name-resolver.js.map +1 -0
- package/dist/server/modules/mcp/services/utils/redact.d.ts +2 -0
- package/dist/server/modules/mcp/services/utils/redact.js +19 -0
- package/dist/server/modules/mcp/services/utils/redact.js.map +1 -0
- package/dist/server/modules/mcp/services/utils/require-project.d.ts +5 -0
- package/dist/server/modules/mcp/services/utils/require-project.js +20 -0
- package/dist/server/modules/mcp/services/utils/require-project.js.map +1 -0
- package/dist/server/modules/mcp/services/utils/resolve-epic-id.d.ts +2 -2
- package/dist/server/modules/mcp/services/utils/resolve-epic-id.js.map +1 -1
- package/dist/server/modules/mcp/services/utils/resource-resolver.d.ts +2 -2
- package/dist/server/modules/mcp/services/utils/resource-resolver.js.map +1 -1
- package/dist/server/modules/mcp/services/utils/session-context-helpers.d.ts +12 -0
- package/dist/server/modules/mcp/services/utils/session-context-helpers.js +34 -0
- package/dist/server/modules/mcp/services/utils/session-context-helpers.js.map +1 -0
- package/dist/server/modules/mcp/services/utils/session-context-resolver.d.ts +4 -4
- package/dist/server/modules/mcp/services/utils/session-context-resolver.js +9 -13
- package/dist/server/modules/mcp/services/utils/session-context-resolver.js.map +1 -1
- package/dist/server/modules/mcp/standalone-mcp.module.d.ts +2 -0
- package/dist/server/modules/mcp/standalone-mcp.module.js +36 -0
- package/dist/server/modules/mcp/standalone-mcp.module.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/activity.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/activity.bindings.js +9 -0
- package/dist/server/modules/mcp/tool-descriptors/activity.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/activity.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/activity.metadata.js +49 -0
- package/dist/server/modules/mcp/tool-descriptors/activity.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/agent.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/agent.bindings.js +10 -0
- package/dist/server/modules/mcp/tool-descriptors/agent.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/agent.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/agent.metadata.js +65 -0
- package/dist/server/modules/mcp/tool-descriptors/agent.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/chat.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/chat.bindings.js +11 -0
- package/dist/server/modules/mcp/tool-descriptors/chat.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/chat.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/chat.metadata.js +89 -0
- package/dist/server/modules/mcp/tool-descriptors/chat.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/document.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/document.bindings.js +11 -0
- package/dist/server/modules/mcp/tool-descriptors/document.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/document.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/document.metadata.js +96 -0
- package/dist/server/modules/mcp/tool-descriptors/document.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/epic.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/epic.bindings.js +17 -0
- package/dist/server/modules/mcp/tool-descriptors/epic.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/epic.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/epic.metadata.js +229 -0
- package/dist/server/modules/mcp/tool-descriptors/epic.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/index.d.ts +4 -0
- package/dist/server/modules/mcp/tool-descriptors/index.js +52 -0
- package/dist/server/modules/mcp/tool-descriptors/index.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/prompt.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/prompt.bindings.js +9 -0
- package/dist/server/modules/mcp/tool-descriptors/prompt.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/prompt.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/prompt.metadata.js +43 -0
- package/dist/server/modules/mcp/tool-descriptors/prompt.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/record.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/record.bindings.js +13 -0
- package/dist/server/modules/mcp/tool-descriptors/record.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/record.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/record.metadata.js +106 -0
- package/dist/server/modules/mcp/tool-descriptors/record.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/review.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/review.bindings.js +13 -0
- package/dist/server/modules/mcp/tool-descriptors/review.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/review.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/review.metadata.js +158 -0
- package/dist/server/modules/mcp/tool-descriptors/review.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/session.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/session.bindings.js +9 -0
- package/dist/server/modules/mcp/tool-descriptors/session.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/session.metadata.d.ts +4 -0
- package/dist/server/modules/mcp/tool-descriptors/session.metadata.js +43 -0
- package/dist/server/modules/mcp/tool-descriptors/session.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/skill.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/skill.bindings.js +9 -0
- package/dist/server/modules/mcp/tool-descriptors/skill.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/skill.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/skill.metadata.js +47 -0
- package/dist/server/modules/mcp/tool-descriptors/skill.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/team.bindings.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/team.bindings.js +13 -0
- package/dist/server/modules/mcp/tool-descriptors/team.bindings.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/team.metadata.d.ts +2 -0
- package/dist/server/modules/mcp/tool-descriptors/team.metadata.js +142 -0
- package/dist/server/modules/mcp/tool-descriptors/team.metadata.js.map +1 -0
- package/dist/server/modules/mcp/tool-descriptors/types.d.ts +9 -0
- package/dist/server/modules/mcp/tool-descriptors/types.js +3 -0
- package/dist/server/modules/mcp/tool-descriptors/types.js.map +1 -0
- package/dist/server/modules/mcp/utils/param-suggestion.js +4 -3
- package/dist/server/modules/mcp/utils/param-suggestion.js.map +1 -1
- package/dist/server/modules/orchestrator/docker/docker.module.js +2 -0
- package/dist/server/modules/orchestrator/docker/docker.module.js.map +1 -1
- package/dist/server/modules/orchestrator/docker/services/docker.service.d.ts +4 -1
- package/dist/server/modules/orchestrator/docker/services/docker.service.js +20 -14
- package/dist/server/modules/orchestrator/docker/services/docker.service.js.map +1 -1
- package/dist/server/modules/orchestrator/git/git.module.js +2 -1
- package/dist/server/modules/orchestrator/git/git.module.js.map +1 -1
- package/dist/server/modules/orchestrator/git/services/git-worktree.service.d.ts +4 -2
- package/dist/server/modules/orchestrator/git/services/git-worktree.service.js +19 -26
- package/dist/server/modules/orchestrator/git/services/git-worktree.service.js.map +1 -1
- package/dist/server/modules/orchestrator/proxy/services/orchestrator-proxy.service.js.map +1 -1
- package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.d.ts +3 -2
- package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js +31 -53
- package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js.map +1 -1
- package/dist/server/modules/orchestrator/worktrees/worktrees.module.js +4 -4
- package/dist/server/modules/orchestrator/worktrees/worktrees.module.js.map +1 -1
- package/dist/server/modules/profiles/controllers/provider-configs.controller.d.ts +3 -1
- package/dist/server/modules/profiles/controllers/provider-configs.controller.js +5 -3
- package/dist/server/modules/profiles/controllers/provider-configs.controller.js.map +1 -1
- package/dist/server/modules/profiles/profiles.module.js +4 -1
- package/dist/server/modules/profiles/profiles.module.js.map +1 -1
- package/dist/server/modules/profiles/services/provider-configs.service.d.ts +13 -0
- package/dist/server/modules/profiles/services/provider-configs.service.js +88 -0
- package/dist/server/modules/profiles/services/provider-configs.service.js.map +1 -0
- package/dist/server/modules/projects/controllers/projects.controller.d.ts +20 -1
- package/dist/server/modules/projects/controllers/projects.controller.js +132 -2
- package/dist/server/modules/projects/controllers/projects.controller.js.map +1 -1
- package/dist/server/modules/projects/dtos/export.dto.d.ts +6 -6
- package/dist/server/modules/projects/dtos/template-upgrade.dto.d.ts +20 -0
- package/dist/server/modules/projects/dtos/template-upgrade.dto.js +90 -0
- package/dist/server/modules/projects/dtos/template-upgrade.dto.js.map +1 -0
- package/dist/server/modules/projects/projects.module.js +21 -2
- package/dist/server/modules/projects/projects.module.js.map +1 -1
- package/dist/server/modules/projects/services/project-provider-provisioning.service.d.ts +1 -1
- package/dist/server/modules/projects/services/project-provider-provisioning.service.js +1 -1
- package/dist/server/modules/projects/services/project-provider-provisioning.service.js.map +1 -1
- package/dist/server/modules/projects/services/project-registry-import.service.d.ts +38 -0
- package/dist/server/modules/projects/services/project-registry-import.service.js +140 -0
- package/dist/server/modules/projects/services/project-registry-import.service.js.map +1 -0
- package/dist/server/modules/{registry/services/template-upgrade.service.d.ts → projects/services/project-template-upgrade.service.d.ts} +6 -8
- package/dist/server/modules/{registry/services/template-upgrade.service.js → projects/services/project-template-upgrade.service.js} +14 -21
- package/dist/server/modules/projects/services/project-template-upgrade.service.js.map +1 -0
- package/dist/server/modules/projects/services/projects.service.d.ts +3 -1
- package/dist/server/modules/projects/services/projects.service.js +7 -4
- package/dist/server/modules/projects/services/projects.service.js.map +1 -1
- package/dist/server/modules/providers/adapters/capabilities/context-window.capability.d.ts +20 -0
- package/dist/server/modules/providers/adapters/capabilities/context-window.capability.js +3 -0
- package/dist/server/modules/providers/adapters/capabilities/context-window.capability.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/hook.capability.d.ts +13 -0
- package/dist/server/modules/providers/adapters/capabilities/hook.capability.js +3 -0
- package/dist/server/modules/providers/adapters/capabilities/hook.capability.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/index.d.ts +2 -0
- package/dist/server/modules/providers/adapters/capabilities/index.js +12 -0
- package/dist/server/modules/providers/adapters/capabilities/index.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/project-mcp-settings.capability.d.ts +3 -0
- package/dist/server/modules/providers/adapters/capabilities/project-mcp-settings.capability.js +3 -0
- package/dist/server/modules/providers/adapters/capabilities/project-mcp-settings.capability.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/project-provisioning.capability.d.ts +14 -0
- package/dist/server/modules/providers/adapters/capabilities/project-provisioning.capability.js +3 -0
- package/dist/server/modules/providers/adapters/capabilities/project-provisioning.capability.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/transcript-discovery.capability.d.ts +6 -0
- package/dist/server/modules/providers/adapters/capabilities/transcript-discovery.capability.js +3 -0
- package/dist/server/modules/providers/adapters/capabilities/transcript-discovery.capability.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/type-guards.d.ts +35 -0
- package/dist/server/modules/providers/adapters/capabilities/type-guards.js +33 -0
- package/dist/server/modules/providers/adapters/capabilities/type-guards.js.map +1 -0
- package/dist/server/modules/providers/adapters/claude.adapter.d.ts +23 -2
- package/dist/server/modules/providers/adapters/claude.adapter.js +134 -0
- package/dist/server/modules/providers/adapters/claude.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/codex.adapter.d.ts +7 -2
- package/dist/server/modules/providers/adapters/codex.adapter.js +4 -0
- package/dist/server/modules/providers/adapters/codex.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/gemini.adapter.d.ts +11 -2
- package/dist/server/modules/providers/adapters/gemini.adapter.js +47 -2
- package/dist/server/modules/providers/adapters/gemini.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/index.d.ts +1 -0
- package/dist/server/modules/providers/adapters/index.js +1 -0
- package/dist/server/modules/providers/adapters/index.js.map +1 -1
- package/dist/server/modules/providers/adapters/opencode.adapter.d.ts +1 -1
- package/dist/server/modules/providers/adapters/opencode.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/provider-adapter.interface.d.ts +4 -8
- package/dist/server/modules/providers/adapters/provider-adapters.module.js +2 -1
- package/dist/server/modules/providers/adapters/provider-adapters.module.js.map +1 -1
- package/dist/server/modules/providers/controllers/provider-models.controller.d.ts +4 -3
- package/dist/server/modules/providers/controllers/provider-models.controller.js +29 -36
- package/dist/server/modules/providers/controllers/provider-models.controller.js.map +1 -1
- package/dist/server/modules/providers/controllers/providers.controller.d.ts +7 -13
- package/dist/server/modules/providers/controllers/providers.controller.js +19 -239
- package/dist/server/modules/providers/controllers/providers.controller.js.map +1 -1
- package/dist/server/modules/providers/providers.module.js +24 -6
- package/dist/server/modules/providers/providers.module.js.map +1 -1
- package/dist/server/modules/providers/services/mcp-provider-registration.service.d.ts +23 -0
- package/dist/server/modules/providers/services/mcp-provider-registration.service.js +111 -0
- package/dist/server/modules/providers/services/mcp-provider-registration.service.js.map +1 -0
- package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.d.ts +26 -0
- package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js +274 -0
- package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js.map +1 -0
- package/dist/server/modules/providers/services/mcp-registration/config-file-mcp-registration.adapter.d.ts +14 -0
- package/dist/server/modules/providers/services/mcp-registration/config-file-mcp-registration.adapter.js +328 -0
- package/dist/server/modules/providers/services/mcp-registration/config-file-mcp-registration.adapter.js.map +1 -0
- package/dist/server/modules/providers/services/mcp-registration/index.d.ts +5 -0
- package/dist/server/modules/providers/services/mcp-registration/index.js +10 -0
- package/dist/server/modules/providers/services/mcp-registration/index.js.map +1 -0
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.d.ts +20 -0
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.js +47 -0
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.js.map +1 -0
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.types.d.ts +43 -0
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.types.js +3 -0
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.types.js.map +1 -0
- package/dist/server/modules/providers/services/probe-proof.service.d.ts +3 -1
- package/dist/server/modules/providers/services/probe-proof.service.js +23 -9
- package/dist/server/modules/providers/services/probe-proof.service.js.map +1 -1
- package/dist/server/modules/{core → providers}/services/provider-mcp-ensure.service.d.ts +3 -8
- package/dist/server/modules/providers/services/provider-mcp-ensure.service.js +175 -0
- package/dist/server/modules/providers/services/provider-mcp-ensure.service.js.map +1 -0
- package/dist/server/modules/providers/services/provider-state-manager.service.d.ts +53 -0
- package/dist/server/modules/providers/services/provider-state-manager.service.js +249 -0
- package/dist/server/modules/providers/services/provider-state-manager.service.js.map +1 -0
- package/dist/server/modules/providers/utils/probe-1m.d.ts +2 -1
- package/dist/server/modules/providers/utils/probe-1m.js +13 -19
- package/dist/server/modules/providers/utils/probe-1m.js.map +1 -1
- package/dist/server/modules/realtime/dtos/ws-envelope.dto.d.ts +19 -0
- package/dist/server/modules/realtime/dtos/ws-envelope.dto.js +20 -0
- package/dist/server/modules/realtime/dtos/ws-envelope.dto.js.map +1 -0
- package/dist/server/modules/realtime/ports/realtime-broadcaster.port.d.ts +4 -0
- package/dist/server/modules/realtime/ports/realtime-broadcaster.port.js +5 -0
- package/dist/server/modules/realtime/ports/realtime-broadcaster.port.js.map +1 -0
- package/dist/server/modules/realtime/realtime-broadcast.module.d.ts +2 -0
- package/dist/server/modules/realtime/realtime-broadcast.module.js +25 -0
- package/dist/server/modules/realtime/realtime-broadcast.module.js.map +1 -0
- package/dist/server/modules/realtime/services/noop-realtime-broadcast.adapter.d.ts +4 -0
- package/dist/server/modules/realtime/services/noop-realtime-broadcast.adapter.js +19 -0
- package/dist/server/modules/realtime/services/noop-realtime-broadcast.adapter.js.map +1 -0
- package/dist/server/modules/realtime/services/realtime-broadcast.service.d.ts +7 -0
- package/dist/server/modules/realtime/services/realtime-broadcast.service.js +33 -0
- package/dist/server/modules/realtime/services/realtime-broadcast.service.js.map +1 -0
- package/dist/server/modules/registry/controllers/registry.controller.d.ts +1 -30
- package/dist/server/modules/registry/controllers/registry.controller.js +2 -105
- package/dist/server/modules/registry/controllers/registry.controller.js.map +1 -1
- package/dist/server/modules/registry/index.d.ts +0 -1
- package/dist/server/modules/registry/index.js +0 -1
- package/dist/server/modules/registry/index.js.map +1 -1
- package/dist/server/modules/registry/registry.module.js +1 -5
- package/dist/server/modules/registry/registry.module.js.map +1 -1
- package/dist/server/modules/registry/services/registry-orchestration.service.d.ts +1 -29
- package/dist/server/modules/registry/services/registry-orchestration.service.js +2 -94
- package/dist/server/modules/registry/services/registry-orchestration.service.js.map +1 -1
- package/dist/server/modules/reviews/reviews.module.js +8 -4
- package/dist/server/modules/reviews/reviews.module.js.map +1 -1
- package/dist/server/modules/reviews/services/review-suggestion-applier.service.d.ts +29 -0
- package/dist/server/modules/reviews/services/review-suggestion-applier.service.js +116 -0
- package/dist/server/modules/reviews/services/review-suggestion-applier.service.js.map +1 -0
- package/dist/server/modules/reviews/services/reviews.service.js +11 -0
- package/dist/server/modules/reviews/services/reviews.service.js.map +1 -1
- package/dist/server/modules/reviews/subscribers/review-comment-notifier.subscriber.d.ts +16 -0
- package/dist/server/modules/{events → reviews}/subscribers/review-comment-notifier.subscriber.js +26 -75
- package/dist/server/modules/reviews/subscribers/review-comment-notifier.subscriber.js.map +1 -0
- package/dist/server/modules/seeders/seeders/0001_seed_compact_on_idle_watcher.d.ts +1 -1
- package/dist/server/modules/seeders/seeders/0002_seed_replace_permission_mode_plan.d.ts +1 -1
- package/dist/server/modules/seeders/seeders/0003_seed_preseed_jeffallan_claude_skills.d.ts +1 -1
- package/dist/server/modules/seeders/seeders/0004_seed_disable_microsoft_source_default.d.ts +1 -1
- package/dist/server/modules/seeders/seeders/0005_seed_renew_instructions_subscriber.d.ts +1 -1
- package/dist/server/modules/seeders/seeders/0006_seed_rename_template_slugs.d.ts +1 -1
- package/dist/server/modules/seeders/seeders/0007_seed_claude_no_flicker_env.d.ts +1 -1
- package/dist/server/modules/seeders/services/data-seeder.service.d.ts +2 -12
- package/dist/server/modules/seeders/services/data-seeder.service.js.map +1 -1
- package/dist/server/modules/seeders/types/seeder.types.d.ts +15 -0
- package/dist/server/modules/seeders/types/seeder.types.js +3 -0
- package/dist/server/modules/seeders/types/seeder.types.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/codex-session-reader.adapter.d.ts +8 -0
- package/dist/server/modules/session-reader/adapters/codex-session-reader.adapter.js +63 -3
- package/dist/server/modules/session-reader/adapters/codex-session-reader.adapter.js.map +1 -1
- package/dist/server/modules/session-reader/controllers/session-reader.controller.d.ts +19 -410
- package/dist/server/modules/session-reader/controllers/session-reader.controller.js +159 -69
- package/dist/server/modules/session-reader/controllers/session-reader.controller.js.map +1 -1
- package/dist/server/modules/session-reader/data/pricing.json +19 -0
- package/dist/server/modules/session-reader/dtos/unified-chunk.types.d.ts +1 -2
- package/dist/server/modules/session-reader/dtos/unified-chunk.types.js.map +1 -1
- package/dist/server/modules/session-reader/dtos/unified-message.types.d.ts +66 -0
- package/dist/server/modules/session-reader/dtos/unified-message.types.js +3 -0
- package/dist/server/modules/session-reader/dtos/unified-message.types.js.map +1 -0
- package/dist/server/modules/session-reader/dtos/unified-session.types.d.ts +2 -66
- package/dist/server/modules/session-reader/dtos/unified-session.types.js.map +1 -1
- package/dist/server/modules/session-reader/services/codex-provider-session-id-backfill.service.d.ts +25 -0
- package/dist/server/modules/session-reader/services/codex-provider-session-id-backfill.service.js +175 -0
- package/dist/server/modules/session-reader/services/codex-provider-session-id-backfill.service.js.map +1 -0
- package/dist/server/modules/session-reader/services/session-cache.service.d.ts +9 -0
- package/dist/server/modules/session-reader/services/session-cache.service.js +15 -0
- package/dist/server/modules/session-reader/services/session-cache.service.js.map +1 -1
- package/dist/server/modules/session-reader/services/session-reader.service.d.ts +50 -4
- package/dist/server/modules/session-reader/services/session-reader.service.js +173 -116
- package/dist/server/modules/session-reader/services/session-reader.service.js.map +1 -1
- package/dist/server/modules/session-reader/services/transcript-cursor.d.ts +6 -0
- package/dist/server/modules/session-reader/services/transcript-cursor.js +27 -0
- package/dist/server/modules/session-reader/services/transcript-cursor.js.map +1 -0
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.d.ts +45 -2
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.js +472 -54
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.js.map +1 -1
- package/dist/server/modules/session-reader/services/transcript-serialization.d.ts +4 -0
- package/dist/server/modules/session-reader/services/transcript-serialization.js +31 -0
- package/dist/server/modules/session-reader/services/transcript-serialization.js.map +1 -0
- package/dist/server/modules/session-reader/services/transcript-truncation.d.ts +6 -0
- package/dist/server/modules/session-reader/services/transcript-truncation.js +175 -0
- package/dist/server/modules/session-reader/services/transcript-truncation.js.map +1 -0
- package/dist/server/modules/session-reader/services/transcript-watcher.service.js +52 -2
- package/dist/server/modules/session-reader/services/transcript-watcher.service.js.map +1 -1
- package/dist/server/modules/session-reader/session-reader.module.js +6 -2
- package/dist/server/modules/session-reader/session-reader.module.js.map +1 -1
- package/dist/server/modules/sessions/controllers/sessions.controller.d.ts +9 -1
- package/dist/server/modules/sessions/controllers/sessions.controller.js +74 -4
- package/dist/server/modules/sessions/controllers/sessions.controller.js.map +1 -1
- package/dist/server/modules/sessions/dtos/active-session-info.dto.d.ts +21 -0
- package/dist/server/modules/sessions/dtos/active-session-info.dto.js +12 -0
- package/dist/server/modules/sessions/dtos/active-session-info.dto.js.map +1 -0
- package/dist/server/modules/sessions/dtos/sessions.dto.d.ts +2 -0
- package/dist/server/modules/sessions/dtos/sessions.dto.js.map +1 -1
- package/dist/server/modules/sessions/services/active-session-lookup.service.d.ts +9 -0
- package/dist/server/modules/sessions/services/active-session-lookup.service.js +70 -0
- package/dist/server/modules/sessions/services/active-session-lookup.service.js.map +1 -0
- package/dist/server/modules/sessions/services/agent-presence-aggregator.d.ts +13 -0
- package/dist/server/modules/sessions/services/agent-presence-aggregator.js +36 -0
- package/dist/server/modules/sessions/services/agent-presence-aggregator.js.map +1 -0
- package/dist/server/modules/sessions/services/delivery-failure-notifier.service.d.ts +9 -0
- package/dist/server/modules/sessions/services/delivery-failure-notifier.service.js +64 -0
- package/dist/server/modules/sessions/services/delivery-failure-notifier.service.js.map +1 -0
- package/dist/server/modules/sessions/services/message-activity-stream.service.d.ts +4 -4
- package/dist/server/modules/sessions/services/message-activity-stream.service.js +6 -6
- package/dist/server/modules/sessions/services/message-activity-stream.service.js.map +1 -1
- package/dist/server/modules/sessions/services/message-enqueue.service.d.ts +30 -0
- package/dist/server/modules/sessions/services/message-enqueue.service.js +55 -0
- package/dist/server/modules/sessions/services/message-enqueue.service.js.map +1 -0
- package/dist/server/modules/sessions/services/message-log.service.d.ts +24 -0
- package/dist/server/modules/sessions/services/message-log.service.js +110 -0
- package/dist/server/modules/sessions/services/message-log.service.js.map +1 -0
- package/dist/server/modules/sessions/services/message-pool.types.d.ts +69 -0
- package/dist/server/modules/sessions/services/message-pool.types.js +5 -0
- package/dist/server/modules/sessions/services/message-pool.types.js.map +1 -0
- package/dist/server/modules/sessions/services/provider-launch-config/index.d.ts +2 -0
- package/dist/server/modules/sessions/services/provider-launch-config/index.js +9 -0
- package/dist/server/modules/sessions/services/provider-launch-config/index.js.map +1 -0
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.d.ts +24 -0
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js +45 -0
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js.map +1 -0
- package/dist/server/modules/sessions/services/session-launcher-facade.service.d.ts +13 -0
- package/dist/server/modules/sessions/services/session-launcher-facade.service.js +73 -0
- package/dist/server/modules/sessions/services/session-launcher-facade.service.js.map +1 -0
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.d.ts +262 -0
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js +329 -0
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js.map +1 -0
- package/dist/server/modules/sessions/services/session-runtime/cleanup-stack.d.ts +11 -0
- package/dist/server/modules/sessions/services/session-runtime/cleanup-stack.js +27 -0
- package/dist/server/modules/sessions/services/session-runtime/cleanup-stack.js.map +1 -0
- package/dist/server/modules/sessions/services/session-runtime/index.d.ts +4 -0
- package/dist/server/modules/sessions/services/session-runtime/index.js +12 -0
- package/dist/server/modules/sessions/services/session-runtime/index.js.map +1 -0
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.d.ts +38 -0
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js +404 -0
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js.map +1 -0
- package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.d.ts +26 -0
- package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js +265 -0
- package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js.map +1 -0
- package/dist/server/modules/sessions/services/session-runtime/session-runtime.service.d.ts +10 -0
- package/dist/server/modules/sessions/services/session-runtime/session-runtime.service.js +34 -0
- package/dist/server/modules/sessions/services/session-runtime/session-runtime.service.js.map +1 -0
- package/dist/server/modules/sessions/services/sessions-message-pool.service.d.ts +11 -84
- package/dist/server/modules/sessions/services/sessions-message-pool.service.js +60 -185
- package/dist/server/modules/sessions/services/sessions-message-pool.service.js.map +1 -1
- package/dist/server/modules/sessions/services/sessions.service.d.ts +25 -52
- package/dist/server/modules/sessions/services/sessions.service.js +134 -840
- package/dist/server/modules/sessions/services/sessions.service.js.map +1 -1
- package/dist/server/modules/sessions/sessions-delivery.module.d.ts +2 -0
- package/dist/server/modules/sessions/sessions-delivery.module.js +26 -0
- package/dist/server/modules/sessions/sessions-delivery.module.js.map +1 -0
- package/dist/server/modules/sessions/sessions-read.module.d.ts +2 -0
- package/dist/server/modules/sessions/sessions-read.module.js +23 -0
- package/dist/server/modules/sessions/sessions-read.module.js.map +1 -0
- package/dist/server/modules/sessions/sessions.module.js +22 -5
- package/dist/server/modules/sessions/sessions.module.js.map +1 -1
- package/dist/server/modules/sessions/utils/claude-config.d.ts +1 -1
- package/dist/server/modules/sessions/utils/claude-config.js +2 -2
- package/dist/server/modules/sessions/utils/env-builder.d.ts +1 -1
- package/dist/server/modules/sessions/utils/env-builder.js +8 -3
- package/dist/server/modules/sessions/utils/env-builder.js.map +1 -1
- package/dist/server/modules/sessions/utils/tmux-naming.util.d.ts +1 -0
- package/dist/server/modules/sessions/utils/tmux-naming.util.js +10 -0
- package/dist/server/modules/sessions/utils/tmux-naming.util.js.map +1 -0
- package/dist/server/modules/settings/dtos/settings.dto.d.ts +14 -0
- package/dist/server/modules/settings/dtos/settings.dto.js +3 -3
- package/dist/server/modules/settings/dtos/settings.dto.js.map +1 -1
- package/dist/server/modules/settings/local/delegates/core-settings.delegate.d.ts +20 -0
- package/dist/server/modules/settings/local/delegates/core-settings.delegate.js +499 -0
- package/dist/server/modules/settings/local/delegates/core-settings.delegate.js.map +1 -0
- package/dist/server/modules/settings/local/delegates/message-pool-settings.delegate.d.ts +14 -0
- package/dist/server/modules/settings/local/delegates/message-pool-settings.delegate.js +67 -0
- package/dist/server/modules/settings/local/delegates/message-pool-settings.delegate.js.map +1 -0
- package/dist/server/modules/settings/local/delegates/preset-settings.delegate.d.ts +36 -0
- package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js +393 -0
- package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js.map +1 -0
- package/dist/server/modules/settings/local/delegates/registry-settings.delegate.d.ts +20 -0
- package/dist/server/modules/settings/local/delegates/registry-settings.delegate.js +82 -0
- package/dist/server/modules/settings/local/delegates/registry-settings.delegate.js.map +1 -0
- package/dist/server/modules/settings/local/delegates/skills-settings.delegate.d.ts +16 -0
- package/dist/server/modules/settings/local/delegates/skills-settings.delegate.js +107 -0
- package/dist/server/modules/settings/local/delegates/skills-settings.delegate.js.map +1 -0
- package/dist/server/modules/settings/services/settings.constants.d.ts +31 -0
- package/dist/server/modules/settings/services/settings.constants.js +24 -0
- package/dist/server/modules/settings/services/settings.constants.js.map +1 -0
- package/dist/server/modules/settings/services/settings.service.d.ts +15 -54
- package/dist/server/modules/settings/services/settings.service.js +85 -897
- package/dist/server/modules/settings/services/settings.service.js.map +1 -1
- package/dist/server/modules/skills/services/skill-search.utils.d.ts +18 -0
- package/dist/server/modules/skills/services/skill-search.utils.js +87 -0
- package/dist/server/modules/skills/services/skill-search.utils.js.map +1 -0
- package/dist/server/modules/skills/services/skills.service.js +25 -27
- package/dist/server/modules/skills/services/skills.service.js.map +1 -1
- package/dist/server/modules/storage/db/schema.d.ts +81 -0
- package/dist/server/modules/storage/db/schema.js +10 -2
- package/dist/server/modules/storage/db/schema.js.map +1 -1
- package/dist/server/modules/storage/db/transaction-runner.d.ts +8 -0
- package/dist/server/modules/storage/db/transaction-runner.js +44 -0
- package/dist/server/modules/storage/db/transaction-runner.js.map +1 -0
- package/dist/server/modules/storage/interfaces/storage.interface.d.ts +4 -0
- package/dist/server/modules/storage/interfaces/storage.interface.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/base-storage.delegate.d.ts +2 -0
- package/dist/server/modules/storage/local/delegates/base-storage.delegate.js +2 -0
- package/dist/server/modules/storage/local/delegates/base-storage.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/epic.delegate.d.ts +2 -1
- package/dist/server/modules/storage/local/delegates/epic.delegate.js +36 -1
- package/dist/server/modules/storage/local/delegates/epic.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/profile-provider-config.delegate.js +5 -35
- package/dist/server/modules/storage/local/delegates/profile-provider-config.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/project.delegate.js +12 -20
- package/dist/server/modules/storage/local/delegates/project.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/provider-model.delegate.js +2 -12
- package/dist/server/modules/storage/local/delegates/provider-model.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/review.delegate.js +22 -38
- package/dist/server/modules/storage/local/delegates/review.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/delegates/skill-source.delegate.js +2 -17
- package/dist/server/modules/storage/local/delegates/skill-source.delegate.js.map +1 -1
- package/dist/server/modules/storage/local/local-storage.service.d.ts +2 -1
- package/dist/server/modules/storage/local/local-storage.service.js +3 -0
- package/dist/server/modules/storage/local/local-storage.service.js.map +1 -1
- package/dist/server/modules/subscribers/actions/action.interface.d.ts +6 -6
- package/dist/server/modules/subscribers/actions/restart-agent.action.js +4 -3
- package/dist/server/modules/subscribers/actions/restart-agent.action.js.map +1 -1
- package/dist/server/modules/subscribers/actions/send-message.action.js +12 -7
- package/dist/server/modules/subscribers/actions/send-message.action.js.map +1 -1
- package/dist/server/modules/subscribers/events/event-fields-catalog.js +1 -0
- package/dist/server/modules/subscribers/events/event-fields-catalog.js.map +1 -1
- package/dist/server/modules/subscribers/services/automation-scheduler.service.d.ts +2 -13
- package/dist/server/modules/subscribers/services/automation-scheduler.service.js.map +1 -1
- package/dist/server/modules/subscribers/services/subscriber-executor.service.d.ts +9 -18
- package/dist/server/modules/subscribers/services/subscriber-executor.service.js +29 -24
- package/dist/server/modules/subscribers/services/subscriber-executor.service.js.map +1 -1
- package/dist/server/modules/subscribers/services/subscriber-scheduler.types.d.ts +23 -0
- package/dist/server/modules/subscribers/services/subscriber-scheduler.types.js +3 -0
- package/dist/server/modules/subscribers/services/subscriber-scheduler.types.js.map +1 -0
- package/dist/server/modules/subscribers/subscribers.module.js +7 -5
- package/dist/server/modules/subscribers/subscribers.module.js.map +1 -1
- package/dist/server/modules/teams/dtos/recipient-context.dto.d.ts +6 -0
- package/dist/server/modules/teams/dtos/recipient-context.dto.js +3 -0
- package/dist/server/modules/teams/dtos/recipient-context.dto.js.map +1 -0
- package/dist/server/modules/teams/services/teams.service.d.ts +4 -0
- package/dist/server/modules/teams/services/teams.service.js +68 -0
- package/dist/server/modules/teams/services/teams.service.js.map +1 -1
- package/dist/server/modules/teams/storage/teams.store.d.ts +2 -0
- package/dist/server/modules/teams/storage/teams.store.js +110 -167
- package/dist/server/modules/teams/storage/teams.store.js.map +1 -1
- package/dist/server/modules/teams/subscribers/team-config-updated-notifier.subscriber.d.ts +18 -0
- package/dist/server/modules/{events → teams}/subscribers/team-config-updated-notifier.subscriber.js +38 -43
- package/dist/server/modules/teams/subscribers/team-config-updated-notifier.subscriber.js.map +1 -0
- package/dist/server/modules/teams/subscribers/team-membership-changed-notifier.subscriber.d.ts +18 -0
- package/dist/server/modules/{events → teams}/subscribers/team-membership-changed-notifier.subscriber.js +29 -44
- package/dist/server/modules/teams/subscribers/team-membership-changed-notifier.subscriber.js.map +1 -0
- package/dist/server/modules/teams/teams.module.js +11 -3
- package/dist/server/modules/teams/teams.module.js.map +1 -1
- package/dist/server/modules/terminal/gateways/terminal.gateway.d.ts +24 -15
- package/dist/server/modules/terminal/gateways/terminal.gateway.js +317 -383
- package/dist/server/modules/terminal/gateways/terminal.gateway.js.map +1 -1
- package/dist/server/modules/terminal/services/guest-delivery.service.d.ts +7 -0
- package/dist/server/modules/terminal/services/guest-delivery.service.js +37 -0
- package/dist/server/modules/terminal/services/guest-delivery.service.js.map +1 -0
- package/dist/server/modules/terminal/services/process-executor/child-process-executor.d.ts +5 -0
- package/dist/server/modules/terminal/services/process-executor/child-process-executor.js +195 -0
- package/dist/server/modules/terminal/services/process-executor/child-process-executor.js.map +1 -0
- package/dist/server/modules/terminal/services/process-executor/fake-process-executor.d.ts +44 -0
- package/dist/server/modules/terminal/services/process-executor/fake-process-executor.js +106 -0
- package/dist/server/modules/terminal/services/process-executor/fake-process-executor.js.map +1 -0
- package/dist/server/modules/terminal/services/process-executor/process-executor.module.d.ts +2 -0
- package/dist/server/modules/terminal/services/process-executor/process-executor.module.js +31 -0
- package/dist/server/modules/terminal/services/process-executor/process-executor.module.js.map +1 -0
- package/dist/server/modules/terminal/services/process-executor/process-executor.port.d.ts +33 -0
- package/dist/server/modules/terminal/services/process-executor/process-executor.port.js +20 -0
- package/dist/server/modules/terminal/services/process-executor/process-executor.port.js.map +1 -0
- package/dist/server/modules/terminal/services/process-executor/pty-executor.d.ts +5 -0
- package/dist/server/modules/terminal/services/process-executor/pty-executor.js +157 -0
- package/dist/server/modules/terminal/services/process-executor/pty-executor.js.map +1 -0
- package/dist/server/modules/terminal/services/process-executor/routing-process-executor.d.ts +10 -0
- package/dist/server/modules/terminal/services/process-executor/routing-process-executor.js +36 -0
- package/dist/server/modules/terminal/services/process-executor/routing-process-executor.js.map +1 -0
- package/dist/server/modules/terminal/services/pty.service.d.ts +11 -14
- package/dist/server/modules/terminal/services/pty.service.js +43 -72
- package/dist/server/modules/terminal/services/pty.service.js.map +1 -1
- package/dist/server/modules/terminal/services/terminal-activity.service.d.ts +24 -0
- package/dist/server/modules/terminal/services/terminal-activity.service.js +164 -0
- package/dist/server/modules/terminal/services/terminal-activity.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-delivery-facade.service.d.ts +9 -0
- package/dist/server/modules/terminal/services/terminal-delivery-facade.service.js +47 -0
- package/dist/server/modules/terminal/services/terminal-delivery-facade.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-delivery.types.d.ts +10 -0
- package/dist/server/modules/terminal/services/terminal-delivery.types.js +3 -0
- package/dist/server/modules/terminal/services/terminal-delivery.types.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-io/capture.d.ts +6 -0
- package/dist/server/modules/terminal/services/terminal-io/capture.js +77 -0
- package/dist/server/modules/terminal/services/terminal-io/capture.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-io/delivery.d.ts +19 -0
- package/dist/server/modules/terminal/services/terminal-io/delivery.js +230 -0
- package/dist/server/modules/terminal/services/terminal-io/delivery.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-io/lifecycle.d.ts +7 -0
- package/dist/server/modules/terminal/services/terminal-io/lifecycle.js +87 -0
- package/dist/server/modules/terminal/services/terminal-io/lifecycle.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-io/monitoring.d.ts +4 -0
- package/dist/server/modules/terminal/services/terminal-io/monitoring.js +65 -0
- package/dist/server/modules/terminal/services/terminal-io/monitoring.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-io/quote-shell-arg.d.ts +1 -0
- package/dist/server/modules/terminal/services/terminal-io/quote-shell-arg.js +9 -0
- package/dist/server/modules/terminal/services/terminal-io/quote-shell-arg.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.d.ts +35 -0
- package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js +210 -0
- package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-io/types.d.ts +42 -0
- package/dist/server/modules/terminal/services/terminal-io/types.js +3 -0
- package/dist/server/modules/terminal/services/terminal-io/types.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-registry-rehydrator.service.d.ts +11 -0
- package/dist/server/modules/terminal/services/terminal-registry-rehydrator.service.js +63 -0
- package/dist/server/modules/terminal/services/terminal-registry-rehydrator.service.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-seed.service.d.ts +7 -5
- package/dist/server/modules/terminal/services/terminal-seed.service.js +48 -45
- package/dist/server/modules/terminal/services/terminal-seed.service.js.map +1 -1
- package/dist/server/modules/terminal/services/terminal-session/terminal-frame-stream.d.ts +11 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-frame-stream.js +17 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-frame-stream.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session-registry.d.ts +15 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session-registry.js +62 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session-registry.js.map +1 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session.d.ts +77 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session.js +252 -0
- package/dist/server/modules/terminal/services/terminal-session/terminal-session.js.map +1 -0
- package/dist/server/modules/terminal/terminal-delivery.module.d.ts +2 -0
- package/dist/server/modules/terminal/terminal-delivery.module.js +26 -0
- package/dist/server/modules/terminal/terminal-delivery.module.js.map +1 -0
- package/dist/server/modules/terminal/terminal.module.js +29 -9
- package/dist/server/modules/terminal/terminal.module.js.map +1 -1
- package/dist/server/modules/terminal/utils/normalize-line-endings.d.ts +1 -0
- package/dist/server/modules/terminal/utils/normalize-line-endings.js +8 -0
- package/dist/server/modules/terminal/utils/normalize-line-endings.js.map +1 -0
- package/dist/server/modules/watchers/services/watcher-runner.service.d.ts +3 -3
- package/dist/server/modules/watchers/services/watcher-runner.service.js +20 -14
- package/dist/server/modules/watchers/services/watcher-runner.service.js.map +1 -1
- package/dist/server/modules/watchers/watchers.module.js +2 -2
- package/dist/server/modules/watchers/watchers.module.js.map +1 -1
- package/dist/server/templates/teams-dev.json +15 -14
- package/dist/server/tsconfig.tsbuildinfo +1 -1
- package/dist/server/ui/assets/{ReviewDetailPage-CoOg-QZq.js → ReviewDetailPage-D-vG55cH.js} +1 -1
- package/dist/server/ui/assets/ReviewsPage-GU7PX-qN.js +6 -0
- package/dist/server/ui/assets/index-59euy2RV.css +32 -0
- package/dist/server/ui/assets/index-fIGAPUv3.js +1085 -0
- package/dist/server/ui/assets/{useReviewSubscription-CnFCUxkN.js → useReviewSubscription-BjoztEj6.js} +22 -27
- package/dist/server/ui/index.html +2 -2
- package/dist/templates/teams-dev.json +15 -14
- package/package.json +15 -2
- package/dist/server/modules/core/services/provider-mcp-ensure.service.js +0 -307
- package/dist/server/modules/core/services/provider-mcp-ensure.service.js.map +0 -1
- package/dist/server/modules/events/events-domain.module.d.ts +0 -2
- package/dist/server/modules/events/events-domain.module.js.map +0 -1
- package/dist/server/modules/events/subscribers/chat-message-broadcaster.subscriber.js +0 -47
- package/dist/server/modules/events/subscribers/chat-message-broadcaster.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.d.ts +0 -28
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js +0 -120
- package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.d.ts +0 -29
- package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/index.d.ts +0 -2
- package/dist/server/modules/events/subscribers/index.js +0 -28
- package/dist/server/modules/events/subscribers/index.js.map +0 -1
- package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.d.ts +0 -16
- package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.js +0 -101
- package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/review-broadcaster.subscriber.d.ts +0 -16
- package/dist/server/modules/events/subscribers/review-broadcaster.subscriber.js +0 -163
- package/dist/server/modules/events/subscribers/review-broadcaster.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/review-comment-notifier.subscriber.d.ts +0 -24
- package/dist/server/modules/events/subscribers/review-comment-notifier.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/sub-epic-created-notifier.subscriber.d.ts +0 -18
- package/dist/server/modules/events/subscribers/sub-epic-created-notifier.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/team-config-updated-notifier.subscriber.d.ts +0 -18
- package/dist/server/modules/events/subscribers/team-config-updated-notifier.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/team-membership-changed-notifier.subscriber.d.ts +0 -18
- package/dist/server/modules/events/subscribers/team-membership-changed-notifier.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/transcript-broadcaster.subscriber.d.ts +0 -12
- package/dist/server/modules/events/subscribers/transcript-broadcaster.subscriber.js +0 -88
- package/dist/server/modules/events/subscribers/transcript-broadcaster.subscriber.js.map +0 -1
- package/dist/server/modules/events/subscribers/worktree-broadcaster.subscriber.d.ts +0 -8
- package/dist/server/modules/events/subscribers/worktree-broadcaster.subscriber.js +0 -48
- package/dist/server/modules/events/subscribers/worktree-broadcaster.subscriber.js.map +0 -1
- package/dist/server/modules/mcp/dtos/schema-registry.d.ts +0 -7
- package/dist/server/modules/mcp/dtos/schema-registry.js +0 -64
- package/dist/server/modules/mcp/dtos/schema-registry.js.map +0 -1
- package/dist/server/modules/mcp/mcp.module.d.ts +0 -2
- package/dist/server/modules/mcp/mcp.module.js.map +0 -1
- package/dist/server/modules/mcp/services/mcp-provider-registration.service.d.ts +0 -64
- package/dist/server/modules/mcp/services/mcp-provider-registration.service.js +0 -663
- package/dist/server/modules/mcp/services/mcp-provider-registration.service.js.map +0 -1
- package/dist/server/modules/mcp/services/terminal-activity.service.d.ts +0 -9
- package/dist/server/modules/mcp/services/terminal-activity.service.js +0 -68
- package/dist/server/modules/mcp/services/terminal-activity.service.js.map +0 -1
- package/dist/server/modules/mcp/tool-definitions.d.ts +0 -3077
- package/dist/server/modules/mcp/tool-definitions.js +0 -913
- package/dist/server/modules/mcp/tool-definitions.js.map +0 -1
- package/dist/server/modules/registry/services/template-upgrade.service.js.map +0 -1
- package/dist/server/modules/sessions/services/activity-tracker.service.d.ts +0 -17
- package/dist/server/modules/sessions/services/activity-tracker.service.js +0 -121
- package/dist/server/modules/sessions/services/activity-tracker.service.js.map +0 -1
- package/dist/server/modules/sessions/utils/template-renderer.d.ts +0 -33
- package/dist/server/modules/sessions/utils/template-renderer.js +0 -44
- package/dist/server/modules/sessions/utils/template-renderer.js.map +0 -1
- package/dist/server/modules/terminal/services/confirmed-delivery.helper.d.ts +0 -17
- package/dist/server/modules/terminal/services/confirmed-delivery.helper.js +0 -65
- package/dist/server/modules/terminal/services/confirmed-delivery.helper.js.map +0 -1
- package/dist/server/modules/terminal/services/terminal-send-coordinator.service.d.ts +0 -5
- package/dist/server/modules/terminal/services/terminal-send-coordinator.service.js +0 -36
- package/dist/server/modules/terminal/services/terminal-send-coordinator.service.js.map +0 -1
- package/dist/server/modules/terminal/services/tmux.service.d.ts +0 -78
- package/dist/server/modules/terminal/services/tmux.service.js +0 -548
- package/dist/server/modules/terminal/services/tmux.service.js.map +0 -1
- package/dist/server/templates/5-agents-dev.json +0 -1084
- package/dist/server/ui/assets/ReviewsPage-DVBA6KIu.js +0 -6
- package/dist/server/ui/assets/index-D6-SAeCU.css +0 -32
- package/dist/server/ui/assets/index-DylwMbnX.js +0 -1032
- package/dist/templates/5-agents-dev.json +0 -1084
|
@@ -16,720 +16,40 @@ exports.SessionsService = void 0;
|
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const promises_1 = require("fs/promises");
|
|
18
18
|
const error_types_1 = require("../../../common/errors/error-types");
|
|
19
|
-
const
|
|
20
|
-
const core_1 = require("@nestjs/core");
|
|
21
|
-
const crypto_1 = require("crypto");
|
|
19
|
+
const terminal_io_service_1 = require("../../terminal/services/terminal-io/terminal-io.service");
|
|
22
20
|
const logger_1 = require("../../../common/logging/logger");
|
|
23
|
-
const tmux_service_1 = require("../../terminal/services/tmux.service");
|
|
24
|
-
const terminal_send_coordinator_service_1 = require("../../terminal/services/terminal-send-coordinator.service");
|
|
25
21
|
const pty_service_1 = require("../../terminal/services/pty.service");
|
|
26
22
|
const preflight_service_1 = require("../../core/services/preflight.service");
|
|
27
|
-
const provider_mcp_ensure_service_1 = require("../../
|
|
23
|
+
const provider_mcp_ensure_service_1 = require("../../providers/services/provider-mcp-ensure.service");
|
|
28
24
|
const storage_interface_1 = require("../../storage/interfaces/storage.interface");
|
|
29
25
|
const db_provider_1 = require("../../storage/db/db.provider");
|
|
30
26
|
const better_sqlite3_1 = require("drizzle-orm/better-sqlite3");
|
|
31
|
-
const
|
|
32
|
-
const
|
|
33
|
-
const
|
|
34
|
-
const
|
|
27
|
+
const sqlite_raw_1 = require("../../storage/db/sqlite-raw");
|
|
28
|
+
const transaction_runner_1 = require("../../storage/db/transaction-runner");
|
|
29
|
+
const terminal_session_registry_1 = require("../../terminal/services/terminal-session/terminal-session-registry");
|
|
30
|
+
const agent_presence_aggregator_1 = require("./agent-presence-aggregator");
|
|
35
31
|
const events_service_1 = require("../../events/services/events.service");
|
|
36
|
-
const terminal_gateway_1 = require("../../terminal/gateways/terminal.gateway");
|
|
37
32
|
const session_coordinator_service_1 = require("./session-coordinator.service");
|
|
38
33
|
const hooks_config_service_1 = require("../../hooks/services/hooks-config.service");
|
|
39
34
|
const provider_adapter_factory_1 = require("../../providers/adapters/provider-adapter.factory");
|
|
40
|
-
const teams_service_1 = require("../../teams/services/teams.service");
|
|
41
|
-
const env_config_1 = require("../../../common/config/env.config");
|
|
42
|
-
const host_helpers_1 = require("../../../common/config/host-helpers");
|
|
43
35
|
const logger = (0, logger_1.createLogger)('SessionsService');
|
|
44
|
-
const BOOT_ID = (0, crypto_1.randomUUID)();
|
|
45
|
-
function isUniqueConstraintError(error) {
|
|
46
|
-
return (typeof error === 'object' &&
|
|
47
|
-
error !== null &&
|
|
48
|
-
'code' in error &&
|
|
49
|
-
(error.code === 'SQLITE_CONSTRAINT' ||
|
|
50
|
-
error.code === 'SQLITE_CONSTRAINT_UNIQUE' ||
|
|
51
|
-
(typeof error.code === 'number' && error.code === 19)));
|
|
52
|
-
}
|
|
53
|
-
const MAX_INITIAL_PROMPT_LENGTH = 4000;
|
|
54
|
-
const MAX_INITIAL_PROMPT_LINES = 80;
|
|
55
|
-
const DEFAULT_INITIAL_PROMPT_TEMPLATE = 'Session {session_id} started for agent {agent_name} on project {project_name} using profile {profile_name}.';
|
|
56
36
|
let SessionsService = class SessionsService {
|
|
57
|
-
constructor(db, storage,
|
|
37
|
+
constructor(db, storage, terminalIO, ptyService, preflightService, mcpEnsureService, sessionCoordinator, hooksConfigService, providerAdapterFactory, eventsService, terminalSessionRegistry) {
|
|
58
38
|
this.db = db;
|
|
59
39
|
this.storage = storage;
|
|
60
|
-
this.
|
|
61
|
-
this.sendCoordinator = sendCoordinator;
|
|
40
|
+
this.terminalIO = terminalIO;
|
|
62
41
|
this.ptyService = ptyService;
|
|
63
42
|
this.preflightService = preflightService;
|
|
64
43
|
this.mcpEnsureService = mcpEnsureService;
|
|
65
44
|
this.sessionCoordinator = sessionCoordinator;
|
|
66
45
|
this.hooksConfigService = hooksConfigService;
|
|
67
46
|
this.providerAdapterFactory = providerAdapterFactory;
|
|
68
|
-
this.
|
|
69
|
-
this.
|
|
47
|
+
this.eventsService = eventsService;
|
|
48
|
+
this.terminalSessionRegistry = terminalSessionRegistry;
|
|
49
|
+
this.sqlite = (0, sqlite_raw_1.getRawSqliteClient)(this.db);
|
|
50
|
+
this.txRunner = new transaction_runner_1.TransactionRunner(this.sqlite);
|
|
70
51
|
logger.info('SessionsService initialized');
|
|
71
52
|
}
|
|
72
|
-
async resolveLaunchTarget(params) {
|
|
73
|
-
const { agentId, projectId, epicId } = params;
|
|
74
|
-
const agent = await this.storage.getAgent(agentId);
|
|
75
|
-
const project = await this.storage.getProject(projectId);
|
|
76
|
-
if (agent.projectId !== projectId) {
|
|
77
|
-
throw new error_types_1.ValidationError(`Agent ${agentId} does not belong to project ${projectId}.`, {
|
|
78
|
-
agentId,
|
|
79
|
-
agentProjectId: agent.projectId,
|
|
80
|
-
requestedProjectId: projectId,
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
const epic = epicId ? await this.storage.getEpic(epicId) : null;
|
|
84
|
-
const profile = await this.storage.getAgentProfile(agent.profileId);
|
|
85
|
-
let provider;
|
|
86
|
-
let options;
|
|
87
|
-
let configEnv = null;
|
|
88
|
-
if (agent.providerConfigId) {
|
|
89
|
-
const config = await this.storage.getProfileProviderConfig(agent.providerConfigId);
|
|
90
|
-
provider = await this.storage.getProvider(config.providerId);
|
|
91
|
-
options = config.options;
|
|
92
|
-
configEnv = config.env;
|
|
93
|
-
logger.info({ agentId, configId: config.id, providerId: provider.id }, 'Resolved provider via config');
|
|
94
|
-
}
|
|
95
|
-
else {
|
|
96
|
-
const configs = await this.storage.listProfileProviderConfigsByProfile(profile.id);
|
|
97
|
-
if (configs.length > 0) {
|
|
98
|
-
const firstConfig = configs[0];
|
|
99
|
-
provider = await this.storage.getProvider(firstConfig.providerId);
|
|
100
|
-
options = firstConfig.options;
|
|
101
|
-
configEnv = firstConfig.env;
|
|
102
|
-
logger.info({ agentId, profileId: profile.id, configId: firstConfig.id, providerId: provider.id }, 'Resolved provider via first profile config (no providerConfigId set on agent)');
|
|
103
|
-
}
|
|
104
|
-
else {
|
|
105
|
-
throw new error_types_1.ValidationError(`Profile ${profile.id} has no provider configs - cannot launch session`);
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
return { agent, project, epic, profile, provider, options, configEnv };
|
|
109
|
-
}
|
|
110
|
-
verifyProviderBinary(provider) {
|
|
111
|
-
if (!provider.binPath) {
|
|
112
|
-
throw new error_types_1.ValidationError(`Provider ${provider.name} is missing a binary path. Set the path before launching sessions.`, {
|
|
113
|
-
code: 'PROVIDER_BINARY_NOT_FOUND',
|
|
114
|
-
providerId: provider.id,
|
|
115
|
-
providerName: provider.name,
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
composeLaunchEnv(params) {
|
|
120
|
-
const { sessionId, tmuxSessionName, projectId, agentId, provider, configEnv, optionArgs } = params;
|
|
121
|
-
const providerEnv = provider.env ?? {};
|
|
122
|
-
const mergedBaseEnv = { ...providerEnv, ...(configEnv ?? {}) };
|
|
123
|
-
let envVars = Object.keys(mergedBaseEnv).length > 0 ? mergedBaseEnv : null;
|
|
124
|
-
let processedOptionArgs = optionArgs;
|
|
125
|
-
if (provider.name.toLowerCase() === 'claude') {
|
|
126
|
-
const env = (0, env_config_1.getEnvConfig)();
|
|
127
|
-
const devchainEnv = {
|
|
128
|
-
DEVCHAIN_API_URL: (0, host_helpers_1.getRuntimeInternalBaseUrl)(env),
|
|
129
|
-
DEVCHAIN_PROJECT_ID: projectId,
|
|
130
|
-
DEVCHAIN_AGENT_ID: agentId,
|
|
131
|
-
DEVCHAIN_SESSION_ID: sessionId,
|
|
132
|
-
DEVCHAIN_TMUX_SESSION_NAME: tmuxSessionName,
|
|
133
|
-
};
|
|
134
|
-
if (provider.oneMillionContextEnabled) {
|
|
135
|
-
processedOptionArgs = (0, profile_options_1.rewriteModelTo1m)(processedOptionArgs);
|
|
136
|
-
}
|
|
137
|
-
const modelStr = (0, profile_options_1.extractModelFromArgs)(processedOptionArgs);
|
|
138
|
-
const family = modelStr ? (0, profile_options_1.detectClaudeModelFamily)(modelStr) : null;
|
|
139
|
-
if (provider.oneMillionContextEnabled &&
|
|
140
|
-
family === 'opus' &&
|
|
141
|
-
provider.autoCompactThreshold1m != null) {
|
|
142
|
-
devchainEnv.CLAUDE_AUTOCOMPACT_PCT_OVERRIDE = String(provider.autoCompactThreshold1m);
|
|
143
|
-
}
|
|
144
|
-
else if (provider.autoCompactThreshold != null) {
|
|
145
|
-
devchainEnv.CLAUDE_AUTOCOMPACT_PCT_OVERRIDE = String(provider.autoCompactThreshold);
|
|
146
|
-
}
|
|
147
|
-
envVars = { ...devchainEnv, ...providerEnv, ...(configEnv ?? {}) };
|
|
148
|
-
delete envVars.CLAUDE_CODE_DISABLE_1M_CONTEXT;
|
|
149
|
-
}
|
|
150
|
-
return { envVars, processedOptionArgs };
|
|
151
|
-
}
|
|
152
|
-
async ensureMcpConfig(provider, projectRootPath) {
|
|
153
|
-
let preflightResult = await this.preflightService.runChecks(projectRootPath);
|
|
154
|
-
let providerCheck = preflightResult.providers?.find((p) => p.id === provider.id);
|
|
155
|
-
if (providerCheck?.mcpStatus && providerCheck.mcpStatus !== 'pass') {
|
|
156
|
-
logger.info({
|
|
157
|
-
providerId: provider.id,
|
|
158
|
-
providerName: provider.name,
|
|
159
|
-
mcpStatus: providerCheck.mcpStatus,
|
|
160
|
-
}, 'MCP not configured, attempting auto-ensure');
|
|
161
|
-
const ensureResult = await this.mcpEnsureService.ensureMcp(provider, projectRootPath);
|
|
162
|
-
if (ensureResult.success) {
|
|
163
|
-
logger.info({ providerId: provider.id, action: ensureResult.action }, 'MCP auto-configured successfully');
|
|
164
|
-
if (ensureResult.warnings?.length) {
|
|
165
|
-
for (const w of ensureResult.warnings) {
|
|
166
|
-
logger.warn({ providerId: provider.id, ...w }, 'MCP ensure warning');
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
preflightResult = await this.preflightService.runChecks(projectRootPath);
|
|
170
|
-
providerCheck = preflightResult.providers?.find((p) => p.id === provider.id);
|
|
171
|
-
}
|
|
172
|
-
else {
|
|
173
|
-
logger.warn({ providerId: provider.id, message: ensureResult.message }, 'MCP auto-ensure failed');
|
|
174
|
-
}
|
|
175
|
-
if (providerCheck?.mcpStatus && providerCheck.mcpStatus !== 'pass') {
|
|
176
|
-
throw new error_types_1.ValidationError('Provider MCP is not configured', {
|
|
177
|
-
code: 'MCP_NOT_CONFIGURED',
|
|
178
|
-
providerId: provider.id,
|
|
179
|
-
providerName: provider.name,
|
|
180
|
-
mcpStatus: providerCheck.mcpStatus,
|
|
181
|
-
mcpMessage: providerCheck.mcpMessage,
|
|
182
|
-
});
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
else if (provider.name.toLowerCase() === 'gemini' && projectRootPath) {
|
|
186
|
-
await this.mcpEnsureService.ensureMcp(provider, projectRootPath);
|
|
187
|
-
}
|
|
188
|
-
return preflightResult;
|
|
189
|
-
}
|
|
190
|
-
async setupHooksConfig(provider, projectRootPath) {
|
|
191
|
-
if (provider.name.toLowerCase() !== 'claude')
|
|
192
|
-
return;
|
|
193
|
-
try {
|
|
194
|
-
await this.hooksConfigService.ensureHooksConfig(projectRootPath);
|
|
195
|
-
logger.info({ projectRootPath }, 'Hooks config ensured for Claude provider');
|
|
196
|
-
}
|
|
197
|
-
catch (error) {
|
|
198
|
-
logger.warn({ error }, 'Failed to ensure hooks config (non-fatal)');
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
async launchSession(data) {
|
|
202
|
-
const { epicId, agentId, projectId, options: launchOptions } = data;
|
|
203
|
-
const silent = launchOptions?.silent === true;
|
|
204
|
-
return this.sessionCoordinator.withAgentLock(agentId, async () => {
|
|
205
|
-
logger.info({ epicId, agentId, projectId }, 'Launching session');
|
|
206
|
-
const existingSession = this.getActiveSessionForAgent(agentId);
|
|
207
|
-
if (existingSession) {
|
|
208
|
-
const tmuxAlive = existingSession.tmuxSessionId
|
|
209
|
-
? await this.tmuxService.hasSession(existingSession.tmuxSessionId)
|
|
210
|
-
: false;
|
|
211
|
-
if (tmuxAlive) {
|
|
212
|
-
logger.info({ agentId, existingSessionId: existingSession.id }, 'Agent already has active session with live tmux, returning existing session (idempotent)');
|
|
213
|
-
const agent = await this.storage.getAgent(agentId);
|
|
214
|
-
const project = await this.storage.getProject(agent.projectId);
|
|
215
|
-
const epic = existingSession.epicId
|
|
216
|
-
? await this.storage.getEpic(existingSession.epicId).catch(() => null)
|
|
217
|
-
: null;
|
|
218
|
-
return {
|
|
219
|
-
...existingSession,
|
|
220
|
-
epic: epic
|
|
221
|
-
? {
|
|
222
|
-
id: epic.id,
|
|
223
|
-
title: epic.title,
|
|
224
|
-
projectId: epic.projectId,
|
|
225
|
-
}
|
|
226
|
-
: null,
|
|
227
|
-
agent: {
|
|
228
|
-
id: agent.id,
|
|
229
|
-
name: agent.name,
|
|
230
|
-
profileId: agent.profileId,
|
|
231
|
-
},
|
|
232
|
-
project: {
|
|
233
|
-
id: project.id,
|
|
234
|
-
name: project.name,
|
|
235
|
-
rootPath: project.rootPath,
|
|
236
|
-
},
|
|
237
|
-
};
|
|
238
|
-
}
|
|
239
|
-
logger.warn({
|
|
240
|
-
agentId,
|
|
241
|
-
orphanedSessionId: existingSession.id,
|
|
242
|
-
tmuxSessionId: existingSession.tmuxSessionId,
|
|
243
|
-
}, 'Found orphaned session (tmux gone), marking as stopped before continuing');
|
|
244
|
-
this.sqlite
|
|
245
|
-
.prepare(`
|
|
246
|
-
UPDATE sessions
|
|
247
|
-
SET status = 'stopped', ended_at = ?, updated_at = ?
|
|
248
|
-
WHERE id = ?
|
|
249
|
-
`)
|
|
250
|
-
.run(new Date().toISOString(), new Date().toISOString(), existingSession.id);
|
|
251
|
-
logger.info({ agentId }, 'Orphaned session cleaned up, proceeding to create new session');
|
|
252
|
-
}
|
|
253
|
-
const { agent, project, epic, profile, provider, options, configEnv } = await this.resolveLaunchTarget({ agentId, projectId, epicId });
|
|
254
|
-
if (provider.name.toLowerCase() === 'claude') {
|
|
255
|
-
const { autoCompactEnabled, configState } = await (0, claude_config_1.checkClaudeAutoCompact)();
|
|
256
|
-
if (!autoCompactEnabled && configState !== 'malformed') {
|
|
257
|
-
this.getTerminalGateway().broadcastEvent('system', 'session_recommendation', {
|
|
258
|
-
reason: 'claude_auto_compact_disabled',
|
|
259
|
-
agentId,
|
|
260
|
-
agentName: agent.name,
|
|
261
|
-
providerId: provider.id,
|
|
262
|
-
providerName: provider.name,
|
|
263
|
-
silent,
|
|
264
|
-
bootId: BOOT_ID,
|
|
265
|
-
});
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
const preflightResult = await this.ensureMcpConfig(provider, project.rootPath);
|
|
269
|
-
await this.setupHooksConfig(provider, project.rootPath);
|
|
270
|
-
if (preflightResult.overall === 'fail') {
|
|
271
|
-
const failedChecks = preflightResult.checks
|
|
272
|
-
.filter((c) => c.status === 'fail')
|
|
273
|
-
.map((c) => `${c.name}: ${c.message}`)
|
|
274
|
-
.join('; ');
|
|
275
|
-
throw new error_types_1.ValidationError('Preflight checks failed', {
|
|
276
|
-
failedChecks,
|
|
277
|
-
projectId,
|
|
278
|
-
});
|
|
279
|
-
}
|
|
280
|
-
const sessionId = (0, crypto_1.randomUUID)();
|
|
281
|
-
const now = new Date().toISOString();
|
|
282
|
-
const projectSlug = project.name
|
|
283
|
-
.toLowerCase()
|
|
284
|
-
.replace(/[^a-z0-9]+/g, '-')
|
|
285
|
-
.replace(/(^-|-$)/g, '');
|
|
286
|
-
const epicSegment = epicId ?? 'independent';
|
|
287
|
-
const tmuxSessionName = this.tmuxService.createSessionName(projectSlug, epicSegment, agentId, sessionId);
|
|
288
|
-
await this.tmuxService.createSession(tmuxSessionName, project.rootPath);
|
|
289
|
-
await this.tmuxService.setAlternateScreenOff(tmuxSessionName);
|
|
290
|
-
this.tmuxService.startHealthCheck(tmuxSessionName, sessionId);
|
|
291
|
-
this.verifyProviderBinary(provider);
|
|
292
|
-
let optionArgs = [];
|
|
293
|
-
try {
|
|
294
|
-
optionArgs = (0, profile_options_1.parseProfileOptions)(options);
|
|
295
|
-
}
|
|
296
|
-
catch (error) {
|
|
297
|
-
if (error instanceof profile_options_1.ProfileOptionsError) {
|
|
298
|
-
throw new error_types_1.ValidationError(error.message, {
|
|
299
|
-
profileId: profile.id,
|
|
300
|
-
profileName: profile.name,
|
|
301
|
-
});
|
|
302
|
-
}
|
|
303
|
-
throw error;
|
|
304
|
-
}
|
|
305
|
-
if (agent.modelOverride) {
|
|
306
|
-
optionArgs = (0, profile_options_1.injectModelOverride)(optionArgs, agent.modelOverride);
|
|
307
|
-
}
|
|
308
|
-
const { envVars, processedOptionArgs } = this.composeLaunchEnv({
|
|
309
|
-
sessionId,
|
|
310
|
-
tmuxSessionName,
|
|
311
|
-
projectId,
|
|
312
|
-
agentId,
|
|
313
|
-
provider,
|
|
314
|
-
configEnv,
|
|
315
|
-
optionArgs,
|
|
316
|
-
});
|
|
317
|
-
optionArgs = processedOptionArgs;
|
|
318
|
-
let launchArgv = optionArgs;
|
|
319
|
-
try {
|
|
320
|
-
const launchAdapter = this.providerAdapterFactory.getAdapter(provider.name);
|
|
321
|
-
launchArgv = launchAdapter.buildLaunchArgs({
|
|
322
|
-
mode: 'new',
|
|
323
|
-
profileOptionArgs: optionArgs,
|
|
324
|
-
}).argv;
|
|
325
|
-
}
|
|
326
|
-
catch {
|
|
327
|
-
}
|
|
328
|
-
let commandArgs;
|
|
329
|
-
try {
|
|
330
|
-
commandArgs = (0, env_builder_1.buildSessionCommand)(envVars, provider.binPath, launchArgv);
|
|
331
|
-
}
|
|
332
|
-
catch (error) {
|
|
333
|
-
if (error instanceof env_builder_1.EnvBuilderError) {
|
|
334
|
-
throw new error_types_1.ValidationError(error.message, {
|
|
335
|
-
agentId,
|
|
336
|
-
providerConfigId: agent.providerConfigId,
|
|
337
|
-
});
|
|
338
|
-
}
|
|
339
|
-
throw error;
|
|
340
|
-
}
|
|
341
|
-
try {
|
|
342
|
-
this.sqlite
|
|
343
|
-
.prepare(`
|
|
344
|
-
INSERT INTO sessions (id, epic_id, agent_id, tmux_session_id, status, started_at, provider_name_at_launch, created_at, updated_at)
|
|
345
|
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
346
|
-
`)
|
|
347
|
-
.run(sessionId, epicId ?? null, agentId, tmuxSessionName, 'running', now, provider.name.toLowerCase(), now, now);
|
|
348
|
-
logger.info({ sessionId, tmuxSessionName }, 'Session created in database');
|
|
349
|
-
}
|
|
350
|
-
catch (error) {
|
|
351
|
-
if (isUniqueConstraintError(error)) {
|
|
352
|
-
logger.warn({ agentId, tmuxSessionName, error }, 'Unique constraint violation - cleaning up orphaned tmux session and returning existing session');
|
|
353
|
-
try {
|
|
354
|
-
await this.tmuxService.destroySession(tmuxSessionName);
|
|
355
|
-
logger.info({ tmuxSessionName }, 'Cleaned up orphaned tmux session');
|
|
356
|
-
}
|
|
357
|
-
catch (tmuxError) {
|
|
358
|
-
logger.warn({ tmuxError, tmuxSessionName }, 'Failed to cleanup orphaned tmux session');
|
|
359
|
-
}
|
|
360
|
-
const existingSession = this.getActiveSessionForAgent(agentId);
|
|
361
|
-
if (existingSession) {
|
|
362
|
-
logger.info({ agentId, existingSessionId: existingSession.id }, 'Returning existing running session after constraint violation');
|
|
363
|
-
const existingAgent = await this.storage.getAgent(agentId);
|
|
364
|
-
const existingProject = await this.storage.getProject(projectId);
|
|
365
|
-
const existingEpic = existingSession.epicId
|
|
366
|
-
? await this.storage.getEpic(existingSession.epicId).catch(() => null)
|
|
367
|
-
: null;
|
|
368
|
-
return {
|
|
369
|
-
...existingSession,
|
|
370
|
-
epic: existingEpic
|
|
371
|
-
? {
|
|
372
|
-
id: existingEpic.id,
|
|
373
|
-
title: existingEpic.title,
|
|
374
|
-
projectId: existingEpic.projectId,
|
|
375
|
-
}
|
|
376
|
-
: null,
|
|
377
|
-
agent: {
|
|
378
|
-
id: existingAgent.id,
|
|
379
|
-
name: existingAgent.name,
|
|
380
|
-
profileId: existingAgent.profileId,
|
|
381
|
-
},
|
|
382
|
-
project: {
|
|
383
|
-
id: existingProject.id,
|
|
384
|
-
name: existingProject.name,
|
|
385
|
-
rootPath: existingProject.rootPath,
|
|
386
|
-
},
|
|
387
|
-
};
|
|
388
|
-
}
|
|
389
|
-
throw error;
|
|
390
|
-
}
|
|
391
|
-
throw error;
|
|
392
|
-
}
|
|
393
|
-
logger.info({ sessionId, provider: provider.name, commandArgs, hasEnvVars: !!envVars }, 'Launching agent with provider binary');
|
|
394
|
-
try {
|
|
395
|
-
await this.tmuxService.sendCommandArgs(tmuxSessionName, commandArgs);
|
|
396
|
-
}
|
|
397
|
-
catch (error) {
|
|
398
|
-
this.sqlite.prepare('DELETE FROM sessions WHERE id = ?').run(sessionId);
|
|
399
|
-
logger.warn({ sessionId, error: String(error) }, 'CLI launch failed, cleaned up session row');
|
|
400
|
-
try {
|
|
401
|
-
await this.tmuxService.destroySession(tmuxSessionName);
|
|
402
|
-
}
|
|
403
|
-
catch (tmuxError) {
|
|
404
|
-
logger.warn({ tmuxError, tmuxSessionName }, 'Failed to cleanup tmux session after CLI launch failure');
|
|
405
|
-
}
|
|
406
|
-
throw error;
|
|
407
|
-
}
|
|
408
|
-
const launchTimestamp = Date.now();
|
|
409
|
-
const { ready, elapsedMs } = await this.tmuxService.waitForOutput(tmuxSessionName, {
|
|
410
|
-
pollIntervalMs: 500,
|
|
411
|
-
timeoutMs: 30_000,
|
|
412
|
-
settleMs: 1_000,
|
|
413
|
-
});
|
|
414
|
-
if (!ready) {
|
|
415
|
-
logger.warn({ sessionId, tmuxSessionName, elapsedMs }, 'CLI output detection timed out, proceeding anyway');
|
|
416
|
-
}
|
|
417
|
-
const MIN_LAUNCH_DELAY_MS = 7_000;
|
|
418
|
-
const elapsed = Date.now() - launchTimestamp;
|
|
419
|
-
if (elapsed < MIN_LAUNCH_DELAY_MS) {
|
|
420
|
-
const remaining = MIN_LAUNCH_DELAY_MS - elapsed;
|
|
421
|
-
logger.debug({ sessionId, elapsed, remaining }, 'Waiting for minimum launch delay before initial prompt paste');
|
|
422
|
-
await new Promise((resolve) => setTimeout(resolve, remaining));
|
|
423
|
-
}
|
|
424
|
-
let launchHandshake;
|
|
425
|
-
try {
|
|
426
|
-
const adapter = this.providerAdapterFactory.getAdapter(provider.name);
|
|
427
|
-
launchHandshake = adapter.launchInitialPromptBehavior;
|
|
428
|
-
logger.debug({
|
|
429
|
-
sessionId,
|
|
430
|
-
providerName: provider.name,
|
|
431
|
-
hasHandshake: !!launchHandshake,
|
|
432
|
-
preKeys: launchHandshake?.preKeys,
|
|
433
|
-
preDelayMs: launchHandshake?.preDelayMs,
|
|
434
|
-
}, 'Resolved provider launch handshake metadata');
|
|
435
|
-
}
|
|
436
|
-
catch (adapterError) {
|
|
437
|
-
logger.debug({ sessionId, providerName: provider.name, error: String(adapterError) }, 'No adapter found for provider, skipping launch handshake');
|
|
438
|
-
}
|
|
439
|
-
try {
|
|
440
|
-
await this.renderAndPasteInitialPrompt({
|
|
441
|
-
sessionId,
|
|
442
|
-
tmuxSessionName,
|
|
443
|
-
agentId,
|
|
444
|
-
project: { id: project.id, name: project.name },
|
|
445
|
-
agent,
|
|
446
|
-
epic,
|
|
447
|
-
profile,
|
|
448
|
-
provider,
|
|
449
|
-
launchHandshake,
|
|
450
|
-
});
|
|
451
|
-
}
|
|
452
|
-
catch (promptError) {
|
|
453
|
-
logger.warn({ sessionId, error: String(promptError) }, 'Initial prompt submit failed, session continues');
|
|
454
|
-
}
|
|
455
|
-
await this.ptyService.startStreaming(sessionId, tmuxSessionName);
|
|
456
|
-
await this.getEventsService().publish('session.started', {
|
|
457
|
-
sessionId,
|
|
458
|
-
epicId: epicId ?? null,
|
|
459
|
-
agentId,
|
|
460
|
-
tmuxSessionName,
|
|
461
|
-
});
|
|
462
|
-
try {
|
|
463
|
-
this.getTerminalGateway().broadcastEvent(`agent/${agentId}`, 'presence', {
|
|
464
|
-
online: true,
|
|
465
|
-
sessionId,
|
|
466
|
-
agentId,
|
|
467
|
-
});
|
|
468
|
-
}
|
|
469
|
-
catch (error) {
|
|
470
|
-
logger.warn({ error, agentId, sessionId }, 'Failed to broadcast presence update');
|
|
471
|
-
}
|
|
472
|
-
return {
|
|
473
|
-
id: sessionId,
|
|
474
|
-
epicId: epicId ?? null,
|
|
475
|
-
agentId,
|
|
476
|
-
tmuxSessionId: tmuxSessionName,
|
|
477
|
-
status: 'running',
|
|
478
|
-
startedAt: now,
|
|
479
|
-
endedAt: null,
|
|
480
|
-
transcriptPath: null,
|
|
481
|
-
createdAt: now,
|
|
482
|
-
updatedAt: now,
|
|
483
|
-
epic: epic
|
|
484
|
-
? {
|
|
485
|
-
id: epic.id,
|
|
486
|
-
title: epic.title,
|
|
487
|
-
projectId: epic.projectId,
|
|
488
|
-
}
|
|
489
|
-
: null,
|
|
490
|
-
agent: {
|
|
491
|
-
id: agent.id,
|
|
492
|
-
name: agent.name,
|
|
493
|
-
profileId: agent.profileId,
|
|
494
|
-
},
|
|
495
|
-
project: {
|
|
496
|
-
id: project.id,
|
|
497
|
-
name: project.name,
|
|
498
|
-
rootPath: project.rootPath,
|
|
499
|
-
},
|
|
500
|
-
};
|
|
501
|
-
});
|
|
502
|
-
}
|
|
503
|
-
async restoreSession(sessionId, projectId) {
|
|
504
|
-
const source = this.sqlite
|
|
505
|
-
.prepare(`SELECT id, epic_id, agent_id, tmux_session_id, status, started_at, ended_at,
|
|
506
|
-
transcript_path, provider_session_id, provider_name_at_launch, created_at, updated_at
|
|
507
|
-
FROM sessions WHERE id = ?`)
|
|
508
|
-
.get(sessionId);
|
|
509
|
-
if (!source) {
|
|
510
|
-
throw new common_1.NotFoundException('Session not found');
|
|
511
|
-
}
|
|
512
|
-
const sourceAgent = await this.storage.getAgent(source.agent_id);
|
|
513
|
-
if (sourceAgent.projectId !== projectId) {
|
|
514
|
-
throw new common_1.ForbiddenException('PROJECT_MISMATCH');
|
|
515
|
-
}
|
|
516
|
-
if (source.status !== 'stopped' && source.status !== 'failed') {
|
|
517
|
-
throw new common_1.ConflictException({
|
|
518
|
-
message: 'Session is not in a restorable state',
|
|
519
|
-
code: 'INVALID_SESSION_STATE',
|
|
520
|
-
});
|
|
521
|
-
}
|
|
522
|
-
if (!source.provider_session_id) {
|
|
523
|
-
throw new common_1.ConflictException({
|
|
524
|
-
message: 'Session has no provider session ID',
|
|
525
|
-
code: 'NO_PROVIDER_SESSION_ID',
|
|
526
|
-
});
|
|
527
|
-
}
|
|
528
|
-
const { provider: currentProvider } = await this.resolveLaunchTarget({
|
|
529
|
-
agentId: source.agent_id,
|
|
530
|
-
projectId,
|
|
531
|
-
epicId: source.epic_id,
|
|
532
|
-
});
|
|
533
|
-
if (source.provider_name_at_launch &&
|
|
534
|
-
currentProvider.name.toLowerCase() !== source.provider_name_at_launch.toLowerCase()) {
|
|
535
|
-
throw new common_1.ConflictException({
|
|
536
|
-
message: 'Current provider differs from launch-time provider',
|
|
537
|
-
code: 'PROVIDER_MISMATCH',
|
|
538
|
-
});
|
|
539
|
-
}
|
|
540
|
-
return this.sessionCoordinator.withAgentLock(source.agent_id, async () => {
|
|
541
|
-
const lockedSource = this.sqlite
|
|
542
|
-
.prepare(`SELECT id, epic_id, agent_id, tmux_session_id, status, started_at, ended_at,
|
|
543
|
-
transcript_path, provider_session_id, provider_name_at_launch, created_at, updated_at
|
|
544
|
-
FROM sessions WHERE id = ?`)
|
|
545
|
-
.get(sessionId);
|
|
546
|
-
if (!lockedSource) {
|
|
547
|
-
throw new common_1.NotFoundException('Session not found');
|
|
548
|
-
}
|
|
549
|
-
if (lockedSource.status !== 'stopped' && lockedSource.status !== 'failed') {
|
|
550
|
-
throw new common_1.ConflictException({
|
|
551
|
-
message: 'Session is not in a restorable state',
|
|
552
|
-
code: 'INVALID_SESSION_STATE',
|
|
553
|
-
});
|
|
554
|
-
}
|
|
555
|
-
if (!lockedSource.provider_session_id) {
|
|
556
|
-
throw new common_1.ConflictException({
|
|
557
|
-
message: 'Session has no provider session ID',
|
|
558
|
-
code: 'NO_PROVIDER_SESSION_ID',
|
|
559
|
-
});
|
|
560
|
-
}
|
|
561
|
-
if (lockedSource.provider_name_at_launch &&
|
|
562
|
-
currentProvider.name.toLowerCase() !== lockedSource.provider_name_at_launch.toLowerCase()) {
|
|
563
|
-
throw new common_1.ConflictException({
|
|
564
|
-
message: 'Current provider differs from launch-time provider',
|
|
565
|
-
code: 'PROVIDER_MISMATCH',
|
|
566
|
-
});
|
|
567
|
-
}
|
|
568
|
-
const existingRunning = this.getActiveSessionForAgent(lockedSource.agent_id);
|
|
569
|
-
if (existingRunning) {
|
|
570
|
-
throw new common_1.ConflictException({
|
|
571
|
-
message: 'Agent already has a running session',
|
|
572
|
-
code: 'INVALID_SESSION_STATE',
|
|
573
|
-
});
|
|
574
|
-
}
|
|
575
|
-
const prior = {
|
|
576
|
-
status: lockedSource.status,
|
|
577
|
-
ended_at: lockedSource.ended_at,
|
|
578
|
-
tmux_session_id: lockedSource.tmux_session_id,
|
|
579
|
-
};
|
|
580
|
-
const { agent, project, epic, profile, provider, options, configEnv } = await this.resolveLaunchTarget({
|
|
581
|
-
agentId: lockedSource.agent_id,
|
|
582
|
-
projectId,
|
|
583
|
-
epicId: lockedSource.epic_id,
|
|
584
|
-
});
|
|
585
|
-
this.verifyProviderBinary(provider);
|
|
586
|
-
if (lockedSource.provider_name_at_launch &&
|
|
587
|
-
provider.name.toLowerCase() !== lockedSource.provider_name_at_launch.toLowerCase()) {
|
|
588
|
-
throw new common_1.ConflictException({
|
|
589
|
-
message: 'Current provider differs from launch-time provider',
|
|
590
|
-
code: 'PROVIDER_MISMATCH',
|
|
591
|
-
});
|
|
592
|
-
}
|
|
593
|
-
let optionArgs = [];
|
|
594
|
-
try {
|
|
595
|
-
optionArgs = (0, profile_options_1.parseProfileOptions)(options);
|
|
596
|
-
}
|
|
597
|
-
catch (error) {
|
|
598
|
-
if (error instanceof profile_options_1.ProfileOptionsError) {
|
|
599
|
-
throw new error_types_1.ValidationError(error.message, {
|
|
600
|
-
profileId: profile.id,
|
|
601
|
-
profileName: profile.name,
|
|
602
|
-
});
|
|
603
|
-
}
|
|
604
|
-
throw error;
|
|
605
|
-
}
|
|
606
|
-
if (agent.modelOverride) {
|
|
607
|
-
optionArgs = (0, profile_options_1.injectModelOverride)(optionArgs, agent.modelOverride);
|
|
608
|
-
}
|
|
609
|
-
const projectSlug = project.name
|
|
610
|
-
.toLowerCase()
|
|
611
|
-
.replace(/[^a-z0-9]+/g, '-')
|
|
612
|
-
.replace(/(^-|-$)/g, '');
|
|
613
|
-
const epicSegment = lockedSource.epic_id ?? 'independent';
|
|
614
|
-
const tmuxSessionName = this.tmuxService.createSessionName(projectSlug, epicSegment, agent.id, lockedSource.id);
|
|
615
|
-
const { envVars, processedOptionArgs } = this.composeLaunchEnv({
|
|
616
|
-
sessionId: lockedSource.id,
|
|
617
|
-
tmuxSessionName,
|
|
618
|
-
projectId,
|
|
619
|
-
agentId: agent.id,
|
|
620
|
-
provider,
|
|
621
|
-
configEnv,
|
|
622
|
-
optionArgs,
|
|
623
|
-
});
|
|
624
|
-
optionArgs = processedOptionArgs;
|
|
625
|
-
const adapter = this.providerAdapterFactory.getAdapter(provider.name);
|
|
626
|
-
const launchArgv = adapter.buildLaunchArgs({
|
|
627
|
-
mode: 'restore',
|
|
628
|
-
providerSessionId: lockedSource.provider_session_id,
|
|
629
|
-
profileOptionArgs: optionArgs,
|
|
630
|
-
}).argv;
|
|
631
|
-
if (!launchArgv.includes(lockedSource.provider_session_id)) {
|
|
632
|
-
throw new error_types_1.ValidationError('Restore argv does not include provider session ID — adapter contract violation', {
|
|
633
|
-
code: 'RESTORE_ARGS_UNAVAILABLE',
|
|
634
|
-
providerName: provider.name,
|
|
635
|
-
providerSessionId: lockedSource.provider_session_id,
|
|
636
|
-
});
|
|
637
|
-
}
|
|
638
|
-
let commandArgs;
|
|
639
|
-
try {
|
|
640
|
-
commandArgs = (0, env_builder_1.buildSessionCommand)(envVars, provider.binPath, launchArgv);
|
|
641
|
-
}
|
|
642
|
-
catch (error) {
|
|
643
|
-
if (error instanceof env_builder_1.EnvBuilderError) {
|
|
644
|
-
throw new error_types_1.ValidationError(error.message, {
|
|
645
|
-
agentId: agent.id,
|
|
646
|
-
providerConfigId: agent.providerConfigId,
|
|
647
|
-
});
|
|
648
|
-
}
|
|
649
|
-
throw error;
|
|
650
|
-
}
|
|
651
|
-
const now = new Date().toISOString();
|
|
652
|
-
this.sqlite
|
|
653
|
-
.prepare(`UPDATE sessions
|
|
654
|
-
SET status = 'running', tmux_session_id = ?, ended_at = NULL,
|
|
655
|
-
last_activity_at = ?, updated_at = ?
|
|
656
|
-
WHERE id = ?`)
|
|
657
|
-
.run(tmuxSessionName, now, now, lockedSource.id);
|
|
658
|
-
try {
|
|
659
|
-
await this.tmuxService.createSession(tmuxSessionName, project.rootPath);
|
|
660
|
-
}
|
|
661
|
-
catch (tmuxError) {
|
|
662
|
-
this.sqlite
|
|
663
|
-
.prepare(`UPDATE sessions
|
|
664
|
-
SET status = ?, ended_at = ?, tmux_session_id = ?, updated_at = ?
|
|
665
|
-
WHERE id = ?`)
|
|
666
|
-
.run(prior.status, prior.ended_at, prior.tmux_session_id, now, lockedSource.id);
|
|
667
|
-
logger.error({ sessionId: lockedSource.id, error: String(tmuxError) }, 'Restore failed: tmux creation error — rolled back');
|
|
668
|
-
throw new common_1.InternalServerErrorException('RESTORE_FAILED');
|
|
669
|
-
}
|
|
670
|
-
await this.tmuxService.setAlternateScreenOff(tmuxSessionName);
|
|
671
|
-
this.tmuxService.startHealthCheck(tmuxSessionName, lockedSource.id);
|
|
672
|
-
try {
|
|
673
|
-
await this.tmuxService.sendCommandArgs(tmuxSessionName, commandArgs);
|
|
674
|
-
}
|
|
675
|
-
catch (sendError) {
|
|
676
|
-
this.sqlite
|
|
677
|
-
.prepare(`UPDATE sessions
|
|
678
|
-
SET status = ?, ended_at = ?, tmux_session_id = ?, updated_at = ?
|
|
679
|
-
WHERE id = ?`)
|
|
680
|
-
.run(prior.status, prior.ended_at, prior.tmux_session_id, now, lockedSource.id);
|
|
681
|
-
try {
|
|
682
|
-
await this.tmuxService.destroySession(tmuxSessionName);
|
|
683
|
-
}
|
|
684
|
-
catch (destroyErr) {
|
|
685
|
-
logger.warn({ tmuxSessionName, error: String(destroyErr) }, 'Failed to destroy tmux session during restore rollback');
|
|
686
|
-
}
|
|
687
|
-
logger.error({ sessionId: lockedSource.id, error: String(sendError) }, 'Restore failed: CLI launch error — rolled back');
|
|
688
|
-
throw new common_1.InternalServerErrorException('RESTORE_FAILED');
|
|
689
|
-
}
|
|
690
|
-
await this.ptyService.startStreaming(lockedSource.id, tmuxSessionName);
|
|
691
|
-
await this.getEventsService().publish('session.restored', {
|
|
692
|
-
sessionId: lockedSource.id,
|
|
693
|
-
epicId: lockedSource.epic_id,
|
|
694
|
-
agentId: agent.id,
|
|
695
|
-
tmuxSessionName,
|
|
696
|
-
});
|
|
697
|
-
if (lockedSource.transcript_path) {
|
|
698
|
-
await this.getEventsService().publish('session.transcript.discovered', {
|
|
699
|
-
sessionId: lockedSource.id,
|
|
700
|
-
agentId: agent.id,
|
|
701
|
-
projectId,
|
|
702
|
-
transcriptPath: lockedSource.transcript_path,
|
|
703
|
-
providerName: provider.name.toLowerCase(),
|
|
704
|
-
});
|
|
705
|
-
}
|
|
706
|
-
try {
|
|
707
|
-
this.getTerminalGateway().broadcastEvent(`agent/${agent.id}`, 'presence', {
|
|
708
|
-
online: true,
|
|
709
|
-
sessionId: lockedSource.id,
|
|
710
|
-
agentId: agent.id,
|
|
711
|
-
});
|
|
712
|
-
}
|
|
713
|
-
catch (error) {
|
|
714
|
-
logger.warn({ error, agentId: agent.id }, 'Failed to broadcast presence after restore');
|
|
715
|
-
}
|
|
716
|
-
return {
|
|
717
|
-
id: lockedSource.id,
|
|
718
|
-
epicId: lockedSource.epic_id,
|
|
719
|
-
agentId: agent.id,
|
|
720
|
-
tmuxSessionId: tmuxSessionName,
|
|
721
|
-
status: 'running',
|
|
722
|
-
startedAt: lockedSource.started_at,
|
|
723
|
-
endedAt: null,
|
|
724
|
-
transcriptPath: lockedSource.transcript_path,
|
|
725
|
-
createdAt: lockedSource.created_at,
|
|
726
|
-
updatedAt: now,
|
|
727
|
-
epic: epic ? { id: epic.id, title: epic.title, projectId: epic.projectId } : null,
|
|
728
|
-
agent: { id: agent.id, name: agent.name, profileId: agent.profileId },
|
|
729
|
-
project: { id: project.id, name: project.name, rootPath: project.rootPath },
|
|
730
|
-
};
|
|
731
|
-
});
|
|
732
|
-
}
|
|
733
53
|
async terminateSession(sessionId) {
|
|
734
54
|
logger.info({ sessionId }, 'Terminating session');
|
|
735
55
|
const session = this.getSession(sessionId);
|
|
@@ -742,10 +62,11 @@ let SessionsService = class SessionsService {
|
|
|
742
62
|
return;
|
|
743
63
|
}
|
|
744
64
|
this.ptyService.stopStreaming(sessionId);
|
|
65
|
+
this.terminalSessionRegistry.dispose(sessionId);
|
|
745
66
|
if (session.tmuxSessionId) {
|
|
746
|
-
const sessionExists = await this.
|
|
67
|
+
const sessionExists = await this.terminalIO.sessionExists({ name: session.tmuxSessionId });
|
|
747
68
|
if (sessionExists) {
|
|
748
|
-
await this.
|
|
69
|
+
await this.terminalIO.destroySession({ name: session.tmuxSessionId });
|
|
749
70
|
}
|
|
750
71
|
else {
|
|
751
72
|
logger.warn({ sessionId, tmuxSessionId: session.tmuxSessionId }, 'Tmux session already gone, cleaning up database record');
|
|
@@ -770,13 +91,13 @@ let SessionsService = class SessionsService {
|
|
|
770
91
|
`)
|
|
771
92
|
.run('stopped', now, sizeBytes, now, sessionId);
|
|
772
93
|
logger.info({ sessionId }, 'Session terminated');
|
|
773
|
-
await this.
|
|
94
|
+
await this.eventsService.publish('session.stopped', { sessionId });
|
|
774
95
|
if (session.agentId) {
|
|
775
96
|
try {
|
|
776
|
-
this.
|
|
97
|
+
await this.eventsService.publish('session.presence.changed', {
|
|
98
|
+
agentId: session.agentId,
|
|
777
99
|
online: false,
|
|
778
100
|
sessionId: null,
|
|
779
|
-
agentId: session.agentId,
|
|
780
101
|
});
|
|
781
102
|
}
|
|
782
103
|
catch (error) {
|
|
@@ -791,7 +112,7 @@ let SessionsService = class SessionsService {
|
|
|
791
112
|
}
|
|
792
113
|
const clampedLimit = Math.min(Math.max(1, limit), 100);
|
|
793
114
|
const sortExpr = `COALESCE(last_activity_at, ended_at, started_at)`;
|
|
794
|
-
const selectCols = `id, provider_session_id, provider_name_at_launch, status, started_at, ended_at, last_activity_at, size_bytes, transcript_path`;
|
|
115
|
+
const selectCols = `id, provider_session_id, provider_name_at_launch, status, started_at, ended_at, last_activity_at, size_bytes, transcript_path, name`;
|
|
795
116
|
const baseStatus = `status IN ('stopped','failed')`;
|
|
796
117
|
const { cnt: total } = this.sqlite
|
|
797
118
|
.prepare(`SELECT COUNT(*) as cnt FROM sessions WHERE agent_id = ? AND ${baseStatus}`)
|
|
@@ -857,13 +178,53 @@ let SessionsService = class SessionsService {
|
|
|
857
178
|
lastActivityAt: row.last_activity_at,
|
|
858
179
|
sizeBytes: row.size_bytes,
|
|
859
180
|
transcriptAvailable: row.transcript_path !== null,
|
|
181
|
+
name: row.name ?? null,
|
|
860
182
|
}));
|
|
861
183
|
return { items, nextCursor, hasMore, total };
|
|
862
184
|
}
|
|
185
|
+
lookupRunningSessionMeta(sessionId) {
|
|
186
|
+
const row = this.sqlite
|
|
187
|
+
.prepare(`SELECT tmux_session_id, provider_name_at_launch
|
|
188
|
+
FROM sessions
|
|
189
|
+
WHERE id = ? AND status = 'running'`)
|
|
190
|
+
.get(sessionId);
|
|
191
|
+
if (!row || !row.tmux_session_id || !row.provider_name_at_launch)
|
|
192
|
+
return null;
|
|
193
|
+
return {
|
|
194
|
+
tmuxSessionName: row.tmux_session_id,
|
|
195
|
+
providerName: row.provider_name_at_launch,
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
shouldNormalizeLfFor(sessionId) {
|
|
199
|
+
const meta = this.lookupRunningSessionMeta(sessionId);
|
|
200
|
+
if (!meta)
|
|
201
|
+
return true;
|
|
202
|
+
try {
|
|
203
|
+
const adapter = this.providerAdapterFactory.getAdapter(meta.providerName);
|
|
204
|
+
return !adapter.terminalOutputBehavior?.rawLineEndings;
|
|
205
|
+
}
|
|
206
|
+
catch {
|
|
207
|
+
return true;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
listRunningSessionMetas() {
|
|
211
|
+
const rows = this.sqlite
|
|
212
|
+
.prepare(`SELECT id, tmux_session_id, provider_name_at_launch
|
|
213
|
+
FROM sessions
|
|
214
|
+
WHERE status = 'running'`)
|
|
215
|
+
.all();
|
|
216
|
+
return rows
|
|
217
|
+
.filter((r) => r.tmux_session_id && r.provider_name_at_launch)
|
|
218
|
+
.map((r) => ({
|
|
219
|
+
sessionId: r.id,
|
|
220
|
+
tmuxSessionName: r.tmux_session_id,
|
|
221
|
+
providerName: r.provider_name_at_launch,
|
|
222
|
+
}));
|
|
223
|
+
}
|
|
863
224
|
getSession(sessionId) {
|
|
864
225
|
const row = this.sqlite
|
|
865
226
|
.prepare(`
|
|
866
|
-
SELECT id, epic_id, agent_id, tmux_session_id, status, started_at, ended_at, last_activity_at, activity_state, busy_since, transcript_path, created_at, updated_at
|
|
227
|
+
SELECT id, epic_id, agent_id, tmux_session_id, status, started_at, ended_at, last_activity_at, activity_state, busy_since, transcript_path, name, created_at, updated_at
|
|
867
228
|
FROM sessions
|
|
868
229
|
WHERE id = ?
|
|
869
230
|
`)
|
|
@@ -884,6 +245,7 @@ let SessionsService = class SessionsService {
|
|
|
884
245
|
activityState: row.activity_state ?? null,
|
|
885
246
|
busySince: row.busy_since ?? null,
|
|
886
247
|
transcriptPath: row.transcript_path ?? null,
|
|
248
|
+
name: row.name ?? null,
|
|
887
249
|
createdAt: row.created_at,
|
|
888
250
|
updatedAt: row.updated_at,
|
|
889
251
|
};
|
|
@@ -891,7 +253,7 @@ let SessionsService = class SessionsService {
|
|
|
891
253
|
async listActiveSessions(projectId, allowedAgentIds) {
|
|
892
254
|
const rows = this.sqlite
|
|
893
255
|
.prepare(`
|
|
894
|
-
SELECT id, epic_id, agent_id, tmux_session_id, status, started_at, ended_at, last_activity_at, activity_state, busy_since, transcript_path, created_at, updated_at
|
|
256
|
+
SELECT id, epic_id, agent_id, tmux_session_id, status, started_at, ended_at, last_activity_at, activity_state, busy_since, transcript_path, name, created_at, updated_at
|
|
895
257
|
FROM sessions
|
|
896
258
|
WHERE status = 'running'
|
|
897
259
|
ORDER BY started_at DESC
|
|
@@ -900,7 +262,7 @@ let SessionsService = class SessionsService {
|
|
|
900
262
|
const now = new Date().toISOString();
|
|
901
263
|
for (const row of rows) {
|
|
902
264
|
if (row.tmux_session_id) {
|
|
903
|
-
const exists = await this.
|
|
265
|
+
const exists = await this.terminalIO.sessionExists({ name: row.tmux_session_id });
|
|
904
266
|
if (!exists) {
|
|
905
267
|
logger.warn({ sessionId: row.id, tmuxSessionId: row.tmux_session_id }, 'Detected orphaned session, marking as stopped');
|
|
906
268
|
this.sqlite
|
|
@@ -929,6 +291,7 @@ let SessionsService = class SessionsService {
|
|
|
929
291
|
activityState: row.activity_state ?? null,
|
|
930
292
|
busySince: row.busy_since ?? null,
|
|
931
293
|
transcriptPath: row.transcript_path ?? null,
|
|
294
|
+
name: row.name ?? null,
|
|
932
295
|
createdAt: row.created_at,
|
|
933
296
|
updatedAt: row.updated_at,
|
|
934
297
|
}));
|
|
@@ -947,7 +310,7 @@ let SessionsService = class SessionsService {
|
|
|
947
310
|
.prepare(`
|
|
948
311
|
SELECT id, epic_id, agent_id, tmux_session_id, status,
|
|
949
312
|
started_at, ended_at, last_activity_at, activity_state,
|
|
950
|
-
busy_since, transcript_path,
|
|
313
|
+
busy_since, transcript_path, name,
|
|
951
314
|
created_at, updated_at
|
|
952
315
|
FROM sessions
|
|
953
316
|
WHERE status = 'running' AND agent_id = ?
|
|
@@ -970,6 +333,7 @@ let SessionsService = class SessionsService {
|
|
|
970
333
|
activityState: row.activity_state ?? null,
|
|
971
334
|
busySince: row.busy_since ?? null,
|
|
972
335
|
transcriptPath: row.transcript_path ?? null,
|
|
336
|
+
name: row.name ?? null,
|
|
973
337
|
createdAt: row.created_at,
|
|
974
338
|
updatedAt: row.updated_at,
|
|
975
339
|
};
|
|
@@ -979,7 +343,7 @@ let SessionsService = class SessionsService {
|
|
|
979
343
|
.prepare(`
|
|
980
344
|
SELECT s.id, s.epic_id, s.agent_id, s.tmux_session_id, s.status,
|
|
981
345
|
s.started_at, s.ended_at, s.last_activity_at, s.activity_state,
|
|
982
|
-
s.busy_since, s.transcript_path,
|
|
346
|
+
s.busy_since, s.transcript_path, s.name,
|
|
983
347
|
s.created_at, s.updated_at
|
|
984
348
|
FROM sessions s
|
|
985
349
|
JOIN agents a ON s.agent_id = a.id
|
|
@@ -999,10 +363,18 @@ let SessionsService = class SessionsService {
|
|
|
999
363
|
activityState: row.activity_state ?? null,
|
|
1000
364
|
busySince: row.busy_since ?? null,
|
|
1001
365
|
transcriptPath: row.transcript_path ?? null,
|
|
366
|
+
name: row.name ?? null,
|
|
1002
367
|
createdAt: row.created_at,
|
|
1003
368
|
updatedAt: row.updated_at,
|
|
1004
369
|
}));
|
|
1005
370
|
}
|
|
371
|
+
markSessionFailed(sessionId, reason) {
|
|
372
|
+
logger.warn({ sessionId, reason }, 'Marking session as failed due to dead tmux');
|
|
373
|
+
const now = new Date().toISOString();
|
|
374
|
+
this.sqlite
|
|
375
|
+
.prepare(`UPDATE sessions SET status = 'failed', ended_at = ?, updated_at = ? WHERE id = ? AND status = 'running'`)
|
|
376
|
+
.run(now, now, sessionId);
|
|
377
|
+
}
|
|
1006
378
|
async getAgentPresence(projectId) {
|
|
1007
379
|
let allowedAgentIds;
|
|
1008
380
|
if (projectId) {
|
|
@@ -1010,15 +382,20 @@ let SessionsService = class SessionsService {
|
|
|
1010
382
|
allowedAgentIds = new Set(agents.items.map((agent) => agent.id));
|
|
1011
383
|
}
|
|
1012
384
|
const activeSessions = await this.listActiveSessions(projectId, allowedAgentIds);
|
|
385
|
+
const sessionAgentMappings = activeSessions
|
|
386
|
+
.filter((s) => s.agentId)
|
|
387
|
+
.map((s) => ({ sessionId: s.id, agentId: s.agentId }));
|
|
388
|
+
const aggregated = (0, agent_presence_aggregator_1.aggregatePresence)(this.terminalSessionRegistry, sessionAgentMappings, allowedAgentIds);
|
|
1013
389
|
const presenceMap = new Map();
|
|
1014
390
|
for (const session of activeSessions) {
|
|
1015
391
|
if (session.agentId) {
|
|
392
|
+
const agg = aggregated.get(session.agentId);
|
|
1016
393
|
presenceMap.set(session.agentId, {
|
|
1017
394
|
online: true,
|
|
1018
395
|
sessionId: session.id,
|
|
1019
|
-
activityState: session.activityState ?? null,
|
|
1020
|
-
lastActivityAt: session.lastActivityAt ?? null,
|
|
1021
|
-
busySince: session.busySince ?? null,
|
|
396
|
+
activityState: agg?.activityState ?? session.activityState ?? null,
|
|
397
|
+
lastActivityAt: agg?.lastActivityAt ?? session.lastActivityAt ?? null,
|
|
398
|
+
busySince: agg?.busySince ?? session.busySince ?? null,
|
|
1022
399
|
currentActivityTitle: this.getCurrentActivityTitle(session.agentId, projectId),
|
|
1023
400
|
});
|
|
1024
401
|
}
|
|
@@ -1047,6 +424,40 @@ let SessionsService = class SessionsService {
|
|
|
1047
424
|
.get(agentId);
|
|
1048
425
|
return row?.title ?? null;
|
|
1049
426
|
}
|
|
427
|
+
updateName(sessionId, name) {
|
|
428
|
+
const trimmed = name?.trim() || null;
|
|
429
|
+
if (trimmed !== null && trimmed.length > 120) {
|
|
430
|
+
throw new error_types_1.ValidationError('Session name must be 120 characters or fewer', {
|
|
431
|
+
sessionId,
|
|
432
|
+
length: trimmed.length,
|
|
433
|
+
});
|
|
434
|
+
}
|
|
435
|
+
const now = new Date().toISOString();
|
|
436
|
+
const result = this.sqlite
|
|
437
|
+
.prepare(`UPDATE sessions SET name = ?, updated_at = ? WHERE id = ?`)
|
|
438
|
+
.run(trimmed, now, sessionId);
|
|
439
|
+
if (result.changes === 0) {
|
|
440
|
+
throw new error_types_1.NotFoundError('Session', sessionId);
|
|
441
|
+
}
|
|
442
|
+
const updated = this.getSession(sessionId);
|
|
443
|
+
if (!updated) {
|
|
444
|
+
throw new error_types_1.NotFoundError('Session', sessionId);
|
|
445
|
+
}
|
|
446
|
+
return updated;
|
|
447
|
+
}
|
|
448
|
+
hardDeleteRecord(sessionId) {
|
|
449
|
+
const session = this.getSession(sessionId);
|
|
450
|
+
if (session?.status === 'running') {
|
|
451
|
+
throw new error_types_1.ValidationError('Cannot delete a running session', { sessionId });
|
|
452
|
+
}
|
|
453
|
+
return this.txRunner.runImmediate(() => {
|
|
454
|
+
this.sqlite
|
|
455
|
+
.prepare('DELETE FROM chat_thread_session_invites WHERE session_id = ?')
|
|
456
|
+
.run(sessionId);
|
|
457
|
+
const result = this.sqlite.prepare('DELETE FROM sessions WHERE id = ?').run(sessionId);
|
|
458
|
+
return { deleted: result.changes > 0 };
|
|
459
|
+
});
|
|
460
|
+
}
|
|
1050
461
|
async injectTextIntoSession(sessionId, text) {
|
|
1051
462
|
const session = this.getSession(sessionId);
|
|
1052
463
|
if (!session) {
|
|
@@ -1068,156 +479,39 @@ let SessionsService = class SessionsService {
|
|
|
1068
479
|
const postPasteDelayMs = agentId
|
|
1069
480
|
? await this.providerAdapterFactory.getPostPasteDelayMsForAgent(agentId)
|
|
1070
481
|
: undefined;
|
|
1071
|
-
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
482
|
+
if (!agentId) {
|
|
483
|
+
const result = await this.terminalIO.deliverImmediate({ name: session.tmuxSessionId }, text, {
|
|
484
|
+
submitKeys: ['Enter'],
|
|
485
|
+
postPasteDelayMs,
|
|
486
|
+
});
|
|
487
|
+
return { confirmed: result.confirmed, method: result.method };
|
|
488
|
+
}
|
|
489
|
+
const result = await this.terminalIO.deliver({ name: session.tmuxSessionId }, text, {
|
|
1075
490
|
agentId,
|
|
491
|
+
submitKeys: ['Enter'],
|
|
1076
492
|
postPasteDelayMs,
|
|
1077
493
|
});
|
|
1078
494
|
return { confirmed: result.confirmed, method: result.method };
|
|
1079
495
|
}
|
|
1080
|
-
async renderAndPasteInitialPrompt(params) {
|
|
1081
|
-
const { sessionId, tmuxSessionName, agentId, project, agent, epic, profile, provider, launchHandshake, } = params;
|
|
1082
|
-
const teams = await this.loadTeamsForAgentOrEmpty(agentId);
|
|
1083
|
-
const context = (0, template_renderer_1.buildInitialPromptContext)({
|
|
1084
|
-
agent: { name: agent.name, id: agentId },
|
|
1085
|
-
project,
|
|
1086
|
-
epic,
|
|
1087
|
-
profile,
|
|
1088
|
-
provider,
|
|
1089
|
-
sessionId,
|
|
1090
|
-
teams,
|
|
1091
|
-
});
|
|
1092
|
-
const defaultRendered = this.normalizeInitialPromptContent((0, template_renderer_1.renderInitialPromptTemplate)(DEFAULT_INITIAL_PROMPT_TEMPLATE, context));
|
|
1093
|
-
let promptTitle;
|
|
1094
|
-
let rendered = defaultRendered;
|
|
1095
|
-
let initialPrompt = null;
|
|
1096
|
-
try {
|
|
1097
|
-
const viaStorage = await this.storage.getInitialSessionPrompt(project.id);
|
|
1098
|
-
if (viaStorage) {
|
|
1099
|
-
initialPrompt = {
|
|
1100
|
-
id: viaStorage.id,
|
|
1101
|
-
title: viaStorage.title,
|
|
1102
|
-
content: viaStorage.content,
|
|
1103
|
-
};
|
|
1104
|
-
logger.debug({ sessionId, promptId: viaStorage.id, source: 'storage.getInitialSessionPrompt' }, 'Resolved initial session prompt via storage');
|
|
1105
|
-
}
|
|
1106
|
-
}
|
|
1107
|
-
catch (error) {
|
|
1108
|
-
logger.warn({ error }, 'Storage getInitialSessionPrompt failed; will try raw settings fallback');
|
|
1109
|
-
}
|
|
1110
|
-
if (!initialPrompt) {
|
|
1111
|
-
logger.debug({ sessionId, source: 'storage.getInitialSessionPrompt' }, 'No initial session prompt resolved via storage');
|
|
1112
|
-
}
|
|
1113
|
-
if (initialPrompt?.content) {
|
|
1114
|
-
promptTitle = initialPrompt.title;
|
|
1115
|
-
const candidate = this.normalizeInitialPromptContent((0, template_renderer_1.renderInitialPromptTemplate)(initialPrompt.content, context));
|
|
1116
|
-
if (candidate) {
|
|
1117
|
-
rendered = candidate;
|
|
1118
|
-
}
|
|
1119
|
-
else {
|
|
1120
|
-
logger.warn({ sessionId, promptId: initialPrompt.id }, 'Initial session prompt rendered to empty content; using default template');
|
|
1121
|
-
}
|
|
1122
|
-
}
|
|
1123
|
-
if (!this.isInitialPromptWithinLimits(rendered)) {
|
|
1124
|
-
logger.warn({
|
|
1125
|
-
sessionId,
|
|
1126
|
-
length: rendered.length,
|
|
1127
|
-
lines: this.countInitialPromptLines(rendered),
|
|
1128
|
-
}, 'Initial session prompt exceeded limits; falling back to default template');
|
|
1129
|
-
rendered = defaultRendered;
|
|
1130
|
-
promptTitle = undefined;
|
|
1131
|
-
}
|
|
1132
|
-
if (!promptTitle) {
|
|
1133
|
-
logger.debug({ sessionId, source: 'default_template' }, 'Using default initial session prompt');
|
|
1134
|
-
}
|
|
1135
|
-
await this.sendCoordinator.ensureAgentGap(agentId, 1000);
|
|
1136
|
-
await this.tmuxService.pasteAndSubmit(tmuxSessionName, rendered, {
|
|
1137
|
-
bracketed: true,
|
|
1138
|
-
submitKeys: ['Enter'],
|
|
1139
|
-
delayMs: 250,
|
|
1140
|
-
preKeys: launchHandshake?.preKeys,
|
|
1141
|
-
preDelayMs: launchHandshake?.preDelayMs,
|
|
1142
|
-
});
|
|
1143
|
-
logger.debug({
|
|
1144
|
-
sessionId,
|
|
1145
|
-
provider: provider.name,
|
|
1146
|
-
submitKeys: ['Enter'],
|
|
1147
|
-
bracketedPaste: true,
|
|
1148
|
-
preKeys: launchHandshake?.preKeys,
|
|
1149
|
-
preDelayMs: launchHandshake?.preDelayMs,
|
|
1150
|
-
}, 'Submitted initial prompt');
|
|
1151
|
-
logger.info({ sessionId, promptTitle }, 'Initial session prompt pasted');
|
|
1152
|
-
}
|
|
1153
|
-
normalizeInitialPromptContent(content) {
|
|
1154
|
-
if (!content) {
|
|
1155
|
-
return '';
|
|
1156
|
-
}
|
|
1157
|
-
return content.replace(/\r\n/g, '\n').trimEnd();
|
|
1158
|
-
}
|
|
1159
|
-
countInitialPromptLines(content) {
|
|
1160
|
-
if (!content) {
|
|
1161
|
-
return 0;
|
|
1162
|
-
}
|
|
1163
|
-
return content.split('\n').length;
|
|
1164
|
-
}
|
|
1165
|
-
isInitialPromptWithinLimits(content) {
|
|
1166
|
-
return (content.length <= MAX_INITIAL_PROMPT_LENGTH &&
|
|
1167
|
-
this.countInitialPromptLines(content) <= MAX_INITIAL_PROMPT_LINES);
|
|
1168
|
-
}
|
|
1169
|
-
getTerminalGateway() {
|
|
1170
|
-
if (!this.terminalGatewayRef) {
|
|
1171
|
-
this.terminalGatewayRef = this.moduleRef.get(terminal_gateway_1.TerminalGateway, { strict: false });
|
|
1172
|
-
if (!this.terminalGatewayRef) {
|
|
1173
|
-
throw new Error('TerminalGateway is not available in the current module context');
|
|
1174
|
-
}
|
|
1175
|
-
}
|
|
1176
|
-
return this.terminalGatewayRef;
|
|
1177
|
-
}
|
|
1178
|
-
getEventsService() {
|
|
1179
|
-
if (!this.eventsServiceRef) {
|
|
1180
|
-
this.eventsServiceRef = this.moduleRef.get(events_service_1.EventsService, { strict: false });
|
|
1181
|
-
if (!this.eventsServiceRef) {
|
|
1182
|
-
throw new Error('EventsService is not available in the current module context');
|
|
1183
|
-
}
|
|
1184
|
-
}
|
|
1185
|
-
return this.eventsServiceRef;
|
|
1186
|
-
}
|
|
1187
|
-
async loadTeamsForAgentOrEmpty(agentId) {
|
|
1188
|
-
if (!agentId)
|
|
1189
|
-
return [];
|
|
1190
|
-
try {
|
|
1191
|
-
const teamsService = this.moduleRef.get(teams_service_1.TeamsService, { strict: false });
|
|
1192
|
-
if (!teamsService || typeof teamsService.listTeamsByAgent !== 'function') {
|
|
1193
|
-
return [];
|
|
1194
|
-
}
|
|
1195
|
-
return await teamsService.listTeamsByAgent(agentId);
|
|
1196
|
-
}
|
|
1197
|
-
catch (error) {
|
|
1198
|
-
logger.warn({ error, agentId }, 'Failed to load teams for initial prompt; defaulting to teamless context');
|
|
1199
|
-
return [];
|
|
1200
|
-
}
|
|
1201
|
-
}
|
|
1202
496
|
};
|
|
1203
497
|
exports.SessionsService = SessionsService;
|
|
1204
498
|
exports.SessionsService = SessionsService = __decorate([
|
|
1205
499
|
(0, common_1.Injectable)(),
|
|
1206
500
|
__param(0, (0, common_1.Inject)(db_provider_1.DB_CONNECTION)),
|
|
1207
501
|
__param(1, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
|
|
1208
|
-
__param(2, (0, common_1.Inject)((0, common_1.forwardRef)(() =>
|
|
1209
|
-
__param(3, (0, common_1.Inject)((0, common_1.forwardRef)(() =>
|
|
1210
|
-
__param(4, (0, common_1.Inject)((0, common_1.forwardRef)(() =>
|
|
1211
|
-
__param(
|
|
1212
|
-
__param(
|
|
1213
|
-
__metadata("design:paramtypes", [better_sqlite3_1.BetterSQLite3Database, Object,
|
|
1214
|
-
terminal_send_coordinator_service_1.TerminalSendCoordinatorService,
|
|
502
|
+
__param(2, (0, common_1.Inject)((0, common_1.forwardRef)(() => terminal_io_service_1.TerminalIOService))),
|
|
503
|
+
__param(3, (0, common_1.Inject)((0, common_1.forwardRef)(() => pty_service_1.PtyService))),
|
|
504
|
+
__param(4, (0, common_1.Inject)((0, common_1.forwardRef)(() => preflight_service_1.PreflightService))),
|
|
505
|
+
__param(9, (0, common_1.Inject)((0, common_1.forwardRef)(() => events_service_1.EventsService))),
|
|
506
|
+
__param(10, (0, common_1.Inject)((0, common_1.forwardRef)(() => terminal_session_registry_1.TerminalSessionRegistry))),
|
|
507
|
+
__metadata("design:paramtypes", [better_sqlite3_1.BetterSQLite3Database, Object, terminal_io_service_1.TerminalIOService,
|
|
1215
508
|
pty_service_1.PtyService,
|
|
1216
509
|
preflight_service_1.PreflightService,
|
|
1217
510
|
provider_mcp_ensure_service_1.ProviderMcpEnsureService,
|
|
1218
511
|
session_coordinator_service_1.SessionCoordinatorService,
|
|
1219
512
|
hooks_config_service_1.HooksConfigService,
|
|
1220
513
|
provider_adapter_factory_1.ProviderAdapterFactory,
|
|
1221
|
-
|
|
514
|
+
events_service_1.EventsService,
|
|
515
|
+
terminal_session_registry_1.TerminalSessionRegistry])
|
|
1222
516
|
], SessionsService);
|
|
1223
517
|
//# sourceMappingURL=sessions.service.js.map
|