devchain-cli 0.12.4 → 0.13.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1003) hide show
  1. package/README.md +1 -1
  2. package/dist/cli.js +63 -104
  3. package/dist/drizzle/0062_provider_probe_proofs.sql +6 -0
  4. package/dist/drizzle/0063_session_name.sql +1 -0
  5. package/dist/drizzle/meta/0062_snapshot.json +5208 -0
  6. package/dist/drizzle/meta/0063_snapshot.json +5215 -0
  7. package/dist/drizzle/meta/_journal.json +14 -0
  8. package/dist/node_modules/@devchain/shared/host-resolver.d.ts +18 -0
  9. package/dist/node_modules/@devchain/shared/host-resolver.d.ts.map +1 -0
  10. package/dist/node_modules/@devchain/shared/host-resolver.js +69 -0
  11. package/dist/node_modules/@devchain/shared/host-resolver.js.map +1 -0
  12. package/dist/node_modules/@devchain/shared/index.d.ts +1 -0
  13. package/dist/node_modules/@devchain/shared/index.d.ts.map +1 -1
  14. package/dist/node_modules/@devchain/shared/index.js +1 -0
  15. package/dist/node_modules/@devchain/shared/index.js.map +1 -1
  16. package/dist/node_modules/@devchain/shared/package.json +2 -0
  17. package/dist/node_modules/@devchain/shared/tsconfig.tsbuildinfo +1 -1
  18. package/dist/server/app.main.module.js +12 -6
  19. package/dist/server/app.main.module.js.map +1 -1
  20. package/dist/server/app.normal.module.js +14 -6
  21. package/dist/server/app.normal.module.js.map +1 -1
  22. package/dist/server/common/config/env.config.d.ts +7 -0
  23. package/dist/server/common/config/env.config.js +11 -0
  24. package/dist/server/common/config/env.config.js.map +1 -1
  25. package/dist/server/common/config/host-helpers.d.ts +3 -3
  26. package/dist/server/common/config/host-helpers.js +5 -28
  27. package/dist/server/common/config/host-helpers.js.map +1 -1
  28. package/dist/server/common/errors/service-unavailable.error.d.ts +4 -0
  29. package/dist/server/common/errors/service-unavailable.error.js +12 -0
  30. package/dist/server/common/errors/service-unavailable.error.js.map +1 -0
  31. package/dist/server/common/process-identity.d.ts +1 -0
  32. package/dist/server/common/process-identity.js +6 -0
  33. package/dist/server/common/process-identity.js.map +1 -0
  34. package/dist/server/common/resolve-binary.d.ts +2 -1
  35. package/dist/server/common/resolve-binary.js +7 -6
  36. package/dist/server/common/resolve-binary.js.map +1 -1
  37. package/dist/server/common/template/prompt-render-context.d.ts +12 -0
  38. package/dist/server/common/template/prompt-render-context.js +37 -0
  39. package/dist/server/common/template/prompt-render-context.js.map +1 -0
  40. package/dist/server/common/test/app-bootstrap.helper.d.ts +13 -0
  41. package/dist/server/common/test/app-bootstrap.helper.js +184 -0
  42. package/dist/server/common/test/app-bootstrap.helper.js.map +1 -0
  43. package/dist/server/main.js +2 -2
  44. package/dist/server/main.js.map +1 -1
  45. package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.d.ts +5 -0
  46. package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js +33 -0
  47. package/dist/server/modules/agent-message-delivery/adapters/legacy-delivery-formatter.adapter.js.map +1 -0
  48. package/dist/server/modules/agent-message-delivery/adapters/legacy-recipient-resolver.adapter.d.ts +6 -0
  49. package/dist/server/modules/agent-message-delivery/adapters/legacy-recipient-resolver.adapter.js +22 -0
  50. package/dist/server/modules/agent-message-delivery/adapters/legacy-recipient-resolver.adapter.js.map +1 -0
  51. package/dist/server/modules/agent-message-delivery/agent-message-delivery.module.d.ts +2 -0
  52. package/dist/server/modules/agent-message-delivery/agent-message-delivery.module.js +45 -0
  53. package/dist/server/modules/agent-message-delivery/agent-message-delivery.module.js.map +1 -0
  54. package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.d.ts +21 -0
  55. package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js +107 -0
  56. package/dist/server/modules/agent-message-delivery/agent-message-delivery.service.js.map +1 -0
  57. package/dist/server/modules/agent-message-delivery/dtos/delivery.types.d.ts +32 -0
  58. package/dist/server/modules/agent-message-delivery/dtos/delivery.types.js +3 -0
  59. package/dist/server/modules/agent-message-delivery/dtos/delivery.types.js.map +1 -0
  60. package/dist/server/modules/agent-message-delivery/ports/delivery-formatter.d.ts +4 -0
  61. package/dist/server/modules/agent-message-delivery/ports/delivery-formatter.js +7 -0
  62. package/dist/server/modules/agent-message-delivery/ports/delivery-formatter.js.map +1 -0
  63. package/dist/server/modules/agent-message-delivery/ports/delivery-recipient-resolver.d.ts +8 -0
  64. package/dist/server/modules/agent-message-delivery/ports/delivery-recipient-resolver.js +7 -0
  65. package/dist/server/modules/agent-message-delivery/ports/delivery-recipient-resolver.js.map +1 -0
  66. package/dist/server/modules/{events/subscribers/chat-message-broadcaster.subscriber.d.ts → agent-message-delivery/subscribers/chat-message-delivery.subscriber.d.ts} +6 -4
  67. package/dist/server/modules/agent-message-delivery/subscribers/chat-message-delivery.subscriber.js +63 -0
  68. package/dist/server/modules/agent-message-delivery/subscribers/chat-message-delivery.subscriber.js.map +1 -0
  69. package/dist/server/modules/agents/agents.module.js +2 -2
  70. package/dist/server/modules/agents/agents.module.js.map +1 -1
  71. package/dist/server/modules/agents/controllers/agents.controller.d.ts +3 -1
  72. package/dist/server/modules/agents/controllers/agents.controller.js +6 -5
  73. package/dist/server/modules/agents/controllers/agents.controller.js.map +1 -1
  74. package/dist/server/modules/chat/chat.module.js +14 -4
  75. package/dist/server/modules/chat/chat.module.js.map +1 -1
  76. package/dist/server/modules/chat/services/chat-session-invite.service.d.ts +16 -0
  77. package/dist/server/modules/chat/services/chat-session-invite.service.js +194 -0
  78. package/dist/server/modules/chat/services/chat-session-invite.service.js.map +1 -0
  79. package/dist/server/modules/chat/services/chat-settings.service.js +2 -1
  80. package/dist/server/modules/chat/services/chat-settings.service.js.map +1 -1
  81. package/dist/server/modules/chat/services/chat.service.d.ts +6 -4
  82. package/dist/server/modules/chat/services/chat.service.js +64 -105
  83. package/dist/server/modules/chat/services/chat.service.js.map +1 -1
  84. package/dist/server/modules/cloud/cloud.module.d.ts +2 -0
  85. package/dist/server/modules/cloud/cloud.module.js +54 -0
  86. package/dist/server/modules/cloud/cloud.module.js.map +1 -0
  87. package/dist/server/modules/cloud/controllers/activity-proxy.controller.d.ts +6 -0
  88. package/dist/server/modules/cloud/controllers/activity-proxy.controller.js +39 -0
  89. package/dist/server/modules/cloud/controllers/activity-proxy.controller.js.map +1 -0
  90. package/dist/server/modules/cloud/controllers/auth-callback.controller.d.ts +11 -0
  91. package/dist/server/modules/cloud/controllers/auth-callback.controller.js +72 -0
  92. package/dist/server/modules/cloud/controllers/auth-callback.controller.js.map +1 -0
  93. package/dist/server/modules/cloud/controllers/devices-proxy.controller.d.ts +9 -0
  94. package/dist/server/modules/cloud/controllers/devices-proxy.controller.js +75 -0
  95. package/dist/server/modules/cloud/controllers/devices-proxy.controller.js.map +1 -0
  96. package/dist/server/modules/cloud/controllers/egress-config.controller.d.ts +12 -0
  97. package/dist/server/modules/cloud/controllers/egress-config.controller.js +66 -0
  98. package/dist/server/modules/cloud/controllers/egress-config.controller.js.map +1 -0
  99. package/dist/server/modules/cloud/controllers/preferences-proxy.controller.d.ts +30 -0
  100. package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js +159 -0
  101. package/dist/server/modules/cloud/controllers/preferences-proxy.controller.js.map +1 -0
  102. package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.d.ts +11 -0
  103. package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js +89 -0
  104. package/dist/server/modules/cloud/controllers/qr-initiate-proxy.controller.js.map +1 -0
  105. package/dist/server/modules/cloud/dtos/cloud-tokens.dto.d.ts +20 -0
  106. package/dist/server/modules/cloud/dtos/cloud-tokens.dto.js +12 -0
  107. package/dist/server/modules/cloud/dtos/cloud-tokens.dto.js.map +1 -0
  108. package/dist/server/modules/cloud/services/cloud-egress-bridge.service.d.ts +24 -0
  109. package/dist/server/modules/cloud/services/cloud-egress-bridge.service.js +111 -0
  110. package/dist/server/modules/cloud/services/cloud-egress-bridge.service.js.map +1 -0
  111. package/dist/server/modules/cloud/services/cloud-session-manager.service.d.ts +27 -0
  112. package/dist/server/modules/cloud/services/cloud-session-manager.service.js +257 -0
  113. package/dist/server/modules/cloud/services/cloud-session-manager.service.js.map +1 -0
  114. package/dist/server/modules/cloud/services/egress-queue.service.d.ts +20 -0
  115. package/dist/server/modules/cloud/services/egress-queue.service.js +136 -0
  116. package/dist/server/modules/cloud/services/egress-queue.service.js.map +1 -0
  117. package/dist/server/modules/cloud/services/encrypted-token-store.service.d.ts +15 -0
  118. package/dist/server/modules/cloud/services/encrypted-token-store.service.js +131 -0
  119. package/dist/server/modules/cloud/services/encrypted-token-store.service.js.map +1 -0
  120. package/dist/server/modules/cloud/services/event-mapper.service.d.ts +42 -0
  121. package/dist/server/modules/cloud/services/event-mapper.service.js +44 -0
  122. package/dist/server/modules/cloud/services/event-mapper.service.js.map +1 -0
  123. package/dist/server/modules/cloud/services/project-activity-reporter.service.d.ts +21 -0
  124. package/dist/server/modules/cloud/services/project-activity-reporter.service.js +138 -0
  125. package/dist/server/modules/cloud/services/project-activity-reporter.service.js.map +1 -0
  126. package/dist/server/modules/cloud/services/project-egress-config.service.d.ts +13 -0
  127. package/dist/server/modules/cloud/services/project-egress-config.service.js +87 -0
  128. package/dist/server/modules/cloud/services/project-egress-config.service.js.map +1 -0
  129. package/dist/server/modules/cloud/services/refresh-gate.service.d.ts +9 -0
  130. package/dist/server/modules/cloud/services/refresh-gate.service.js +63 -0
  131. package/dist/server/modules/cloud/services/refresh-gate.service.js.map +1 -0
  132. package/dist/server/modules/cloud/types/index.d.ts +14 -0
  133. package/dist/server/modules/cloud/types/index.js +3 -0
  134. package/dist/server/modules/cloud/types/index.js.map +1 -0
  135. package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.d.ts +2 -0
  136. package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js +25 -0
  137. package/dist/server/modules/cloud-tunnel/cloud-tunnel.module.js.map +1 -0
  138. package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.d.ts +39 -0
  139. package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js +319 -0
  140. package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js.map +1 -0
  141. package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.d.ts +44 -0
  142. package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js +456 -0
  143. package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js.map +1 -0
  144. package/dist/server/modules/cloud-tunnel/services/tunnel-keypair.service.d.ts +22 -0
  145. package/dist/server/modules/cloud-tunnel/services/tunnel-keypair.service.js +146 -0
  146. package/dist/server/modules/cloud-tunnel/services/tunnel-keypair.service.js.map +1 -0
  147. package/dist/server/modules/codebase-overview-analyzer/codebase-overview-analyzer.module.js +2 -1
  148. package/dist/server/modules/codebase-overview-analyzer/codebase-overview-analyzer.module.js.map +1 -1
  149. package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.d.ts +3 -1
  150. package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.js +14 -20
  151. package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.js.map +1 -1
  152. package/dist/server/modules/core/controllers/preflight.controller.d.ts +0 -4
  153. package/dist/server/modules/core/controllers/preflight.controller.js +0 -17
  154. package/dist/server/modules/core/controllers/preflight.controller.js.map +1 -1
  155. package/dist/server/modules/core/controllers/runtime.controller.d.ts +4 -0
  156. package/dist/server/modules/core/controllers/runtime.controller.js +5 -0
  157. package/dist/server/modules/core/controllers/runtime.controller.js.map +1 -1
  158. package/dist/server/modules/core/core-normal-health.module.js +2 -0
  159. package/dist/server/modules/core/core-normal-health.module.js.map +1 -1
  160. package/dist/server/modules/core/core-normal.module.js +12 -6
  161. package/dist/server/modules/core/core-normal.module.js.map +1 -1
  162. package/dist/server/modules/core/services/gemini-trusted-folders.module.d.ts +2 -0
  163. package/dist/server/modules/core/services/gemini-trusted-folders.module.js +21 -0
  164. package/dist/server/modules/core/services/gemini-trusted-folders.module.js.map +1 -0
  165. package/dist/server/modules/core/services/normal-readiness-checker.service.d.ts +3 -1
  166. package/dist/server/modules/core/services/normal-readiness-checker.service.js +9 -11
  167. package/dist/server/modules/core/services/normal-readiness-checker.service.js.map +1 -1
  168. package/dist/server/modules/core/services/preflight.service.d.ts +4 -3
  169. package/dist/server/modules/core/services/preflight.service.js +21 -17
  170. package/dist/server/modules/core/services/preflight.service.js.map +1 -1
  171. package/dist/server/modules/epics/controllers/epic-comments.controller.d.ts +3 -1
  172. package/dist/server/modules/epics/controllers/epic-comments.controller.js +5 -7
  173. package/dist/server/modules/epics/controllers/epic-comments.controller.js.map +1 -1
  174. package/dist/server/modules/epics/epics.module.js +13 -4
  175. package/dist/server/modules/epics/epics.module.js.map +1 -1
  176. package/dist/server/modules/epics/services/epics.service.d.ts +21 -7
  177. package/dist/server/modules/epics/services/epics.service.js +176 -50
  178. package/dist/server/modules/epics/services/epics.service.js.map +1 -1
  179. package/dist/server/modules/epics/subscribers/epic-assignment-notifier.subscriber.d.ts +25 -0
  180. package/dist/server/modules/{events → epics}/subscribers/epic-assignment-notifier.subscriber.js +47 -105
  181. package/dist/server/modules/epics/subscribers/epic-assignment-notifier.subscriber.js.map +1 -0
  182. package/dist/server/modules/epics/subscribers/sub-epic-created-notifier.subscriber.d.ts +15 -0
  183. package/dist/server/modules/{events → epics}/subscribers/sub-epic-created-notifier.subscriber.js +43 -52
  184. package/dist/server/modules/epics/subscribers/sub-epic-created-notifier.subscriber.js.map +1 -0
  185. package/dist/server/modules/events/catalog/broadcast-metadata.d.ts +8 -0
  186. package/dist/server/modules/events/catalog/broadcast-metadata.js +3 -0
  187. package/dist/server/modules/events/catalog/broadcast-metadata.js.map +1 -0
  188. package/dist/server/modules/events/catalog/broadcast-registry.d.ts +4 -0
  189. package/dist/server/modules/events/catalog/broadcast-registry.js +335 -0
  190. package/dist/server/modules/events/catalog/broadcast-registry.js.map +1 -0
  191. package/dist/server/modules/events/catalog/chat.message.read.d.ts +21 -0
  192. package/dist/server/modules/events/catalog/chat.message.read.js +14 -0
  193. package/dist/server/modules/events/catalog/chat.message.read.js.map +1 -0
  194. package/dist/server/modules/events/catalog/epic.comment.created.d.ts +57 -0
  195. package/dist/server/modules/events/catalog/epic.comment.created.js +28 -0
  196. package/dist/server/modules/events/catalog/epic.comment.created.js.map +1 -0
  197. package/dist/server/modules/events/catalog/epic.created.d.ts +18 -0
  198. package/dist/server/modules/events/catalog/epic.created.js +6 -0
  199. package/dist/server/modules/events/catalog/epic.created.js.map +1 -1
  200. package/dist/server/modules/events/catalog/epic.deleted.d.ts +39 -0
  201. package/dist/server/modules/events/catalog/epic.deleted.js +22 -0
  202. package/dist/server/modules/events/catalog/epic.deleted.js.map +1 -0
  203. package/dist/server/modules/events/catalog/epic.updated.d.ts +6 -0
  204. package/dist/server/modules/events/catalog/epic.updated.js +2 -0
  205. package/dist/server/modules/events/catalog/epic.updated.js.map +1 -1
  206. package/dist/server/modules/events/catalog/guest.unregistered.d.ts +2 -2
  207. package/dist/server/modules/events/catalog/index.d.ts +272 -2
  208. package/dist/server/modules/events/catalog/index.js +18 -0
  209. package/dist/server/modules/events/catalog/index.js.map +1 -1
  210. package/dist/server/modules/events/catalog/review.comment.created.d.ts +6 -0
  211. package/dist/server/modules/events/catalog/review.comment.created.js +2 -0
  212. package/dist/server/modules/events/catalog/review.comment.created.js.map +1 -1
  213. package/dist/server/modules/events/catalog/session.activity.changed.d.ts +21 -0
  214. package/dist/server/modules/events/catalog/session.activity.changed.js +14 -0
  215. package/dist/server/modules/events/catalog/session.activity.changed.js.map +1 -0
  216. package/dist/server/modules/events/catalog/session.cloud-connected.d.ts +12 -0
  217. package/dist/server/modules/events/catalog/session.cloud-connected.js +11 -0
  218. package/dist/server/modules/events/catalog/session.cloud-connected.js.map +1 -0
  219. package/dist/server/modules/events/catalog/session.cloud-disconnected.d.ts +12 -0
  220. package/dist/server/modules/events/catalog/session.cloud-disconnected.js +11 -0
  221. package/dist/server/modules/events/catalog/session.cloud-disconnected.js.map +1 -0
  222. package/dist/server/modules/events/catalog/session.presence.changed.d.ts +18 -0
  223. package/dist/server/modules/events/catalog/session.presence.changed.js +13 -0
  224. package/dist/server/modules/events/catalog/session.presence.changed.js.map +1 -0
  225. package/dist/server/modules/events/catalog/session.provider-session-id.discovered.d.ts +18 -0
  226. package/dist/server/modules/events/catalog/session.provider-session-id.discovered.js +13 -0
  227. package/dist/server/modules/events/catalog/session.provider-session-id.discovered.js.map +1 -0
  228. package/dist/server/modules/events/catalog/session.recommendation.d.ts +30 -0
  229. package/dist/server/modules/events/catalog/session.recommendation.js +17 -0
  230. package/dist/server/modules/events/catalog/session.recommendation.js.map +1 -0
  231. package/dist/server/modules/events/catalog/session.restored.d.ts +3 -0
  232. package/dist/server/modules/events/catalog/session.restored.js +1 -0
  233. package/dist/server/modules/events/catalog/session.restored.js.map +1 -1
  234. package/dist/server/modules/events/catalog/session.transcript.updated.d.ts +21 -0
  235. package/dist/server/modules/events/catalog/session.transcript.updated.js +7 -0
  236. package/dist/server/modules/events/catalog/session.transcript.updated.js.map +1 -1
  237. package/dist/server/modules/events/catalog/team.config.updated.d.ts +9 -0
  238. package/dist/server/modules/events/catalog/team.config.updated.js +3 -0
  239. package/dist/server/modules/events/catalog/team.config.updated.js.map +1 -1
  240. package/dist/server/modules/events/catalog/team.member.added.d.ts +12 -0
  241. package/dist/server/modules/events/catalog/team.member.added.js +4 -0
  242. package/dist/server/modules/events/catalog/team.member.added.js.map +1 -1
  243. package/dist/server/modules/events/catalog/team.member.removed.d.ts +12 -0
  244. package/dist/server/modules/events/catalog/team.member.removed.js +4 -0
  245. package/dist/server/modules/events/catalog/team.member.removed.js.map +1 -1
  246. package/dist/server/modules/events/events-core.module.d.ts +2 -0
  247. package/dist/server/modules/events/{events-domain.module.js → events-core.module.js} +13 -24
  248. package/dist/server/modules/events/events-core.module.js.map +1 -0
  249. package/dist/server/modules/events/events.module.js +3 -4
  250. package/dist/server/modules/events/events.module.js.map +1 -1
  251. package/dist/server/modules/events/index.d.ts +2 -1
  252. package/dist/server/modules/events/index.js +2 -1
  253. package/dist/server/modules/events/index.js.map +1 -1
  254. package/dist/server/modules/events/services/catalog-broadcaster.service.d.ts +9 -0
  255. package/dist/server/modules/events/services/catalog-broadcaster.service.js +56 -0
  256. package/dist/server/modules/events/services/catalog-broadcaster.service.js.map +1 -0
  257. package/dist/server/modules/events/services/events-stream.service.d.ts +3 -3
  258. package/dist/server/modules/events/services/events-stream.service.js +6 -6
  259. package/dist/server/modules/events/services/events-stream.service.js.map +1 -1
  260. package/dist/server/modules/git/git.module.js +2 -1
  261. package/dist/server/modules/git/git.module.js.map +1 -1
  262. package/dist/server/modules/git/services/git.service.d.ts +3 -1
  263. package/dist/server/modules/git/services/git.service.js +17 -19
  264. package/dist/server/modules/git/services/git.service.js.map +1 -1
  265. package/dist/server/modules/guests/guests.module.js +2 -2
  266. package/dist/server/modules/guests/guests.module.js.map +1 -1
  267. package/dist/server/modules/guests/services/guest-health.service.d.ts +3 -3
  268. package/dist/server/modules/guests/services/guest-health.service.js +7 -7
  269. package/dist/server/modules/guests/services/guest-health.service.js.map +1 -1
  270. package/dist/server/modules/guests/services/guests.service.d.ts +3 -3
  271. package/dist/server/modules/guests/services/guests.service.js +7 -7
  272. package/dist/server/modules/guests/services/guests.service.js.map +1 -1
  273. package/dist/server/modules/hooks/hooks.module.js +2 -2
  274. package/dist/server/modules/hooks/hooks.module.js.map +1 -1
  275. package/dist/server/modules/mcp/controllers/mcp-http.controller.js +2 -2
  276. package/dist/server/modules/mcp/controllers/mcp-http.controller.js.map +1 -1
  277. package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js +2 -2
  278. package/dist/server/modules/mcp/controllers/mcp-sdk.controller.js.map +1 -1
  279. package/dist/server/modules/mcp/dtos/mcp.dto.d.ts +40 -27
  280. package/dist/server/modules/mcp/dtos/mcp.dto.js +20 -4
  281. package/dist/server/modules/mcp/dtos/mcp.dto.js.map +1 -1
  282. package/dist/server/modules/mcp/mcp-full.module.d.ts +2 -0
  283. package/dist/server/modules/mcp/{mcp.module.js → mcp-full.module.js} +15 -21
  284. package/dist/server/modules/mcp/mcp-full.module.js.map +1 -0
  285. package/dist/server/modules/mcp/services/handlers/activity-context.d.ts +6 -0
  286. package/dist/server/modules/mcp/services/handlers/activity-context.js +3 -0
  287. package/dist/server/modules/mcp/services/handlers/activity-context.js.map +1 -0
  288. package/dist/server/modules/mcp/services/handlers/activity-tools.d.ts +3 -3
  289. package/dist/server/modules/mcp/services/handlers/activity-tools.js +87 -101
  290. package/dist/server/modules/mcp/services/handlers/activity-tools.js.map +1 -1
  291. package/dist/server/modules/mcp/services/handlers/agent-context.d.ts +16 -0
  292. package/dist/server/modules/mcp/services/handlers/agent-context.js +3 -0
  293. package/dist/server/modules/mcp/services/handlers/agent-context.js.map +1 -0
  294. package/dist/server/modules/mcp/services/handlers/agent-tools.d.ts +5 -0
  295. package/dist/server/modules/mcp/services/handlers/agent-tools.js +194 -0
  296. package/dist/server/modules/mcp/services/handlers/agent-tools.js.map +1 -0
  297. package/dist/server/modules/mcp/services/handlers/chat-context.d.ts +17 -0
  298. package/dist/server/modules/mcp/services/handlers/chat-context.js +3 -0
  299. package/dist/server/modules/mcp/services/handlers/chat-context.js.map +1 -0
  300. package/dist/server/modules/mcp/services/handlers/chat-tools/recipient-resolution.d.ts +13 -0
  301. package/dist/server/modules/mcp/services/handlers/chat-tools/recipient-resolution.js +40 -0
  302. package/dist/server/modules/mcp/services/handlers/chat-tools/recipient-resolution.js.map +1 -0
  303. package/dist/server/modules/mcp/services/handlers/chat-tools.d.ts +5 -5
  304. package/dist/server/modules/mcp/services/handlers/chat-tools.js +149 -306
  305. package/dist/server/modules/mcp/services/handlers/chat-tools.js.map +1 -1
  306. package/dist/server/modules/mcp/services/handlers/document-context.d.ts +8 -0
  307. package/dist/server/modules/mcp/services/handlers/document-context.js +3 -0
  308. package/dist/server/modules/mcp/services/handlers/document-context.js.map +1 -0
  309. package/dist/server/modules/mcp/services/handlers/document-tools.d.ts +5 -5
  310. package/dist/server/modules/mcp/services/handlers/document-tools.js +20 -54
  311. package/dist/server/modules/mcp/services/handlers/document-tools.js.map +1 -1
  312. package/dist/server/modules/mcp/services/handlers/epic-context.d.ts +9 -0
  313. package/dist/server/modules/mcp/services/handlers/epic-context.js +3 -0
  314. package/dist/server/modules/mcp/services/handlers/epic-context.js.map +1 -0
  315. package/dist/server/modules/mcp/services/handlers/epic-tools.d.ts +8 -10
  316. package/dist/server/modules/mcp/services/handlers/epic-tools.js +186 -397
  317. package/dist/server/modules/mcp/services/handlers/epic-tools.js.map +1 -1
  318. package/dist/server/modules/mcp/services/handlers/null-adapter.d.ts +1 -0
  319. package/dist/server/modules/mcp/services/handlers/null-adapter.js +20 -0
  320. package/dist/server/modules/mcp/services/handlers/null-adapter.js.map +1 -0
  321. package/dist/server/modules/mcp/services/handlers/prompt-context.d.ts +9 -0
  322. package/dist/server/modules/mcp/services/handlers/prompt-context.js +3 -0
  323. package/dist/server/modules/mcp/services/handlers/prompt-context.js.map +1 -0
  324. package/dist/server/modules/mcp/services/handlers/prompt-tools.d.ts +3 -3
  325. package/dist/server/modules/mcp/services/handlers/prompt-tools.js +22 -51
  326. package/dist/server/modules/mcp/services/handlers/prompt-tools.js.map +1 -1
  327. package/dist/server/modules/mcp/services/handlers/record-context.d.ts +5 -0
  328. package/dist/server/modules/mcp/services/handlers/record-context.js +3 -0
  329. package/dist/server/modules/mcp/services/handlers/record-context.js.map +1 -0
  330. package/dist/server/modules/mcp/services/handlers/record-tools.d.ts +7 -7
  331. package/dist/server/modules/mcp/services/handlers/record-tools.js +6 -7
  332. package/dist/server/modules/mcp/services/handlers/record-tools.js.map +1 -1
  333. package/dist/server/modules/mcp/services/handlers/review-context.d.ts +11 -0
  334. package/dist/server/modules/mcp/services/handlers/review-context.js +3 -0
  335. package/dist/server/modules/mcp/services/handlers/review-context.js.map +1 -0
  336. package/dist/server/modules/mcp/services/handlers/review-tools.d.ts +7 -7
  337. package/dist/server/modules/mcp/services/handlers/review-tools.js +164 -362
  338. package/dist/server/modules/mcp/services/handlers/review-tools.js.map +1 -1
  339. package/dist/server/modules/mcp/services/handlers/session-context.d.ts +9 -0
  340. package/dist/server/modules/mcp/services/handlers/session-context.js +3 -0
  341. package/dist/server/modules/mcp/services/handlers/session-context.js.map +1 -0
  342. package/dist/server/modules/mcp/services/handlers/session-tools.d.ts +3 -3
  343. package/dist/server/modules/mcp/services/handlers/session-tools.js +21 -23
  344. package/dist/server/modules/mcp/services/handlers/session-tools.js.map +1 -1
  345. package/dist/server/modules/mcp/services/handlers/skill-context.d.ts +6 -0
  346. package/dist/server/modules/mcp/services/handlers/skill-context.js +3 -0
  347. package/dist/server/modules/mcp/services/handlers/skill-context.js.map +1 -0
  348. package/dist/server/modules/mcp/services/handlers/skill-tools.d.ts +3 -3
  349. package/dist/server/modules/mcp/services/handlers/skill-tools.js +55 -75
  350. package/dist/server/modules/mcp/services/handlers/skill-tools.js.map +1 -1
  351. package/dist/server/modules/mcp/services/handlers/teams-context.d.ts +9 -0
  352. package/dist/server/modules/mcp/services/handlers/teams-context.js +3 -0
  353. package/dist/server/modules/mcp/services/handlers/teams-context.js.map +1 -0
  354. package/dist/server/modules/mcp/services/handlers/teams-tools.d.ts +7 -7
  355. package/dist/server/modules/mcp/services/handlers/teams-tools.js +260 -267
  356. package/dist/server/modules/mcp/services/handlers/teams-tools.js.map +1 -1
  357. package/dist/server/modules/mcp/services/handlers/types.d.ts +2 -35
  358. package/dist/server/modules/mcp/services/instructions-resolver.d.ts +2 -2
  359. package/dist/server/modules/mcp/services/instructions-resolver.js.map +1 -1
  360. package/dist/server/modules/mcp/services/mcp.service.d.ts +21 -8
  361. package/dist/server/modules/mcp/services/mcp.service.js +208 -109
  362. package/dist/server/modules/mcp/services/mcp.service.js.map +1 -1
  363. package/dist/server/modules/mcp/services/utils/agent-name-resolver.d.ts +2 -0
  364. package/dist/server/modules/mcp/services/utils/agent-name-resolver.js +27 -0
  365. package/dist/server/modules/mcp/services/utils/agent-name-resolver.js.map +1 -0
  366. package/dist/server/modules/mcp/services/utils/redact.d.ts +2 -0
  367. package/dist/server/modules/mcp/services/utils/redact.js +19 -0
  368. package/dist/server/modules/mcp/services/utils/redact.js.map +1 -0
  369. package/dist/server/modules/mcp/services/utils/require-project.d.ts +5 -0
  370. package/dist/server/modules/mcp/services/utils/require-project.js +20 -0
  371. package/dist/server/modules/mcp/services/utils/require-project.js.map +1 -0
  372. package/dist/server/modules/mcp/services/utils/resolve-epic-id.d.ts +2 -2
  373. package/dist/server/modules/mcp/services/utils/resolve-epic-id.js.map +1 -1
  374. package/dist/server/modules/mcp/services/utils/resource-resolver.d.ts +2 -2
  375. package/dist/server/modules/mcp/services/utils/resource-resolver.js.map +1 -1
  376. package/dist/server/modules/mcp/services/utils/session-context-helpers.d.ts +12 -0
  377. package/dist/server/modules/mcp/services/utils/session-context-helpers.js +34 -0
  378. package/dist/server/modules/mcp/services/utils/session-context-helpers.js.map +1 -0
  379. package/dist/server/modules/mcp/services/utils/session-context-resolver.d.ts +4 -4
  380. package/dist/server/modules/mcp/services/utils/session-context-resolver.js +9 -13
  381. package/dist/server/modules/mcp/services/utils/session-context-resolver.js.map +1 -1
  382. package/dist/server/modules/mcp/standalone-mcp.module.d.ts +2 -0
  383. package/dist/server/modules/mcp/standalone-mcp.module.js +36 -0
  384. package/dist/server/modules/mcp/standalone-mcp.module.js.map +1 -0
  385. package/dist/server/modules/mcp/tool-descriptors/activity.bindings.d.ts +2 -0
  386. package/dist/server/modules/mcp/tool-descriptors/activity.bindings.js +9 -0
  387. package/dist/server/modules/mcp/tool-descriptors/activity.bindings.js.map +1 -0
  388. package/dist/server/modules/mcp/tool-descriptors/activity.metadata.d.ts +2 -0
  389. package/dist/server/modules/mcp/tool-descriptors/activity.metadata.js +49 -0
  390. package/dist/server/modules/mcp/tool-descriptors/activity.metadata.js.map +1 -0
  391. package/dist/server/modules/mcp/tool-descriptors/agent.bindings.d.ts +2 -0
  392. package/dist/server/modules/mcp/tool-descriptors/agent.bindings.js +10 -0
  393. package/dist/server/modules/mcp/tool-descriptors/agent.bindings.js.map +1 -0
  394. package/dist/server/modules/mcp/tool-descriptors/agent.metadata.d.ts +2 -0
  395. package/dist/server/modules/mcp/tool-descriptors/agent.metadata.js +65 -0
  396. package/dist/server/modules/mcp/tool-descriptors/agent.metadata.js.map +1 -0
  397. package/dist/server/modules/mcp/tool-descriptors/chat.bindings.d.ts +2 -0
  398. package/dist/server/modules/mcp/tool-descriptors/chat.bindings.js +11 -0
  399. package/dist/server/modules/mcp/tool-descriptors/chat.bindings.js.map +1 -0
  400. package/dist/server/modules/mcp/tool-descriptors/chat.metadata.d.ts +2 -0
  401. package/dist/server/modules/mcp/tool-descriptors/chat.metadata.js +89 -0
  402. package/dist/server/modules/mcp/tool-descriptors/chat.metadata.js.map +1 -0
  403. package/dist/server/modules/mcp/tool-descriptors/document.bindings.d.ts +2 -0
  404. package/dist/server/modules/mcp/tool-descriptors/document.bindings.js +11 -0
  405. package/dist/server/modules/mcp/tool-descriptors/document.bindings.js.map +1 -0
  406. package/dist/server/modules/mcp/tool-descriptors/document.metadata.d.ts +2 -0
  407. package/dist/server/modules/mcp/tool-descriptors/document.metadata.js +96 -0
  408. package/dist/server/modules/mcp/tool-descriptors/document.metadata.js.map +1 -0
  409. package/dist/server/modules/mcp/tool-descriptors/epic.bindings.d.ts +2 -0
  410. package/dist/server/modules/mcp/tool-descriptors/epic.bindings.js +17 -0
  411. package/dist/server/modules/mcp/tool-descriptors/epic.bindings.js.map +1 -0
  412. package/dist/server/modules/mcp/tool-descriptors/epic.metadata.d.ts +2 -0
  413. package/dist/server/modules/mcp/tool-descriptors/epic.metadata.js +229 -0
  414. package/dist/server/modules/mcp/tool-descriptors/epic.metadata.js.map +1 -0
  415. package/dist/server/modules/mcp/tool-descriptors/index.d.ts +4 -0
  416. package/dist/server/modules/mcp/tool-descriptors/index.js +52 -0
  417. package/dist/server/modules/mcp/tool-descriptors/index.js.map +1 -0
  418. package/dist/server/modules/mcp/tool-descriptors/prompt.bindings.d.ts +2 -0
  419. package/dist/server/modules/mcp/tool-descriptors/prompt.bindings.js +9 -0
  420. package/dist/server/modules/mcp/tool-descriptors/prompt.bindings.js.map +1 -0
  421. package/dist/server/modules/mcp/tool-descriptors/prompt.metadata.d.ts +2 -0
  422. package/dist/server/modules/mcp/tool-descriptors/prompt.metadata.js +43 -0
  423. package/dist/server/modules/mcp/tool-descriptors/prompt.metadata.js.map +1 -0
  424. package/dist/server/modules/mcp/tool-descriptors/record.bindings.d.ts +2 -0
  425. package/dist/server/modules/mcp/tool-descriptors/record.bindings.js +13 -0
  426. package/dist/server/modules/mcp/tool-descriptors/record.bindings.js.map +1 -0
  427. package/dist/server/modules/mcp/tool-descriptors/record.metadata.d.ts +2 -0
  428. package/dist/server/modules/mcp/tool-descriptors/record.metadata.js +106 -0
  429. package/dist/server/modules/mcp/tool-descriptors/record.metadata.js.map +1 -0
  430. package/dist/server/modules/mcp/tool-descriptors/review.bindings.d.ts +2 -0
  431. package/dist/server/modules/mcp/tool-descriptors/review.bindings.js +13 -0
  432. package/dist/server/modules/mcp/tool-descriptors/review.bindings.js.map +1 -0
  433. package/dist/server/modules/mcp/tool-descriptors/review.metadata.d.ts +2 -0
  434. package/dist/server/modules/mcp/tool-descriptors/review.metadata.js +158 -0
  435. package/dist/server/modules/mcp/tool-descriptors/review.metadata.js.map +1 -0
  436. package/dist/server/modules/mcp/tool-descriptors/session.bindings.d.ts +2 -0
  437. package/dist/server/modules/mcp/tool-descriptors/session.bindings.js +9 -0
  438. package/dist/server/modules/mcp/tool-descriptors/session.bindings.js.map +1 -0
  439. package/dist/server/modules/mcp/tool-descriptors/session.metadata.d.ts +4 -0
  440. package/dist/server/modules/mcp/tool-descriptors/session.metadata.js +43 -0
  441. package/dist/server/modules/mcp/tool-descriptors/session.metadata.js.map +1 -0
  442. package/dist/server/modules/mcp/tool-descriptors/skill.bindings.d.ts +2 -0
  443. package/dist/server/modules/mcp/tool-descriptors/skill.bindings.js +9 -0
  444. package/dist/server/modules/mcp/tool-descriptors/skill.bindings.js.map +1 -0
  445. package/dist/server/modules/mcp/tool-descriptors/skill.metadata.d.ts +2 -0
  446. package/dist/server/modules/mcp/tool-descriptors/skill.metadata.js +47 -0
  447. package/dist/server/modules/mcp/tool-descriptors/skill.metadata.js.map +1 -0
  448. package/dist/server/modules/mcp/tool-descriptors/team.bindings.d.ts +2 -0
  449. package/dist/server/modules/mcp/tool-descriptors/team.bindings.js +13 -0
  450. package/dist/server/modules/mcp/tool-descriptors/team.bindings.js.map +1 -0
  451. package/dist/server/modules/mcp/tool-descriptors/team.metadata.d.ts +2 -0
  452. package/dist/server/modules/mcp/tool-descriptors/team.metadata.js +142 -0
  453. package/dist/server/modules/mcp/tool-descriptors/team.metadata.js.map +1 -0
  454. package/dist/server/modules/mcp/tool-descriptors/types.d.ts +9 -0
  455. package/dist/server/modules/mcp/tool-descriptors/types.js +3 -0
  456. package/dist/server/modules/mcp/tool-descriptors/types.js.map +1 -0
  457. package/dist/server/modules/mcp/utils/param-suggestion.js +4 -3
  458. package/dist/server/modules/mcp/utils/param-suggestion.js.map +1 -1
  459. package/dist/server/modules/orchestrator/docker/docker.module.js +2 -0
  460. package/dist/server/modules/orchestrator/docker/docker.module.js.map +1 -1
  461. package/dist/server/modules/orchestrator/docker/services/docker.service.d.ts +4 -1
  462. package/dist/server/modules/orchestrator/docker/services/docker.service.js +20 -14
  463. package/dist/server/modules/orchestrator/docker/services/docker.service.js.map +1 -1
  464. package/dist/server/modules/orchestrator/git/git.module.js +2 -1
  465. package/dist/server/modules/orchestrator/git/git.module.js.map +1 -1
  466. package/dist/server/modules/orchestrator/git/services/git-worktree.service.d.ts +4 -2
  467. package/dist/server/modules/orchestrator/git/services/git-worktree.service.js +19 -26
  468. package/dist/server/modules/orchestrator/git/services/git-worktree.service.js.map +1 -1
  469. package/dist/server/modules/orchestrator/proxy/services/orchestrator-proxy.service.js.map +1 -1
  470. package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.d.ts +3 -2
  471. package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js +31 -53
  472. package/dist/server/modules/orchestrator/worktrees/services/worktrees.service.js.map +1 -1
  473. package/dist/server/modules/orchestrator/worktrees/worktrees.module.js +4 -4
  474. package/dist/server/modules/orchestrator/worktrees/worktrees.module.js.map +1 -1
  475. package/dist/server/modules/profiles/controllers/provider-configs.controller.d.ts +3 -1
  476. package/dist/server/modules/profiles/controllers/provider-configs.controller.js +5 -3
  477. package/dist/server/modules/profiles/controllers/provider-configs.controller.js.map +1 -1
  478. package/dist/server/modules/profiles/profiles.module.js +4 -1
  479. package/dist/server/modules/profiles/profiles.module.js.map +1 -1
  480. package/dist/server/modules/profiles/services/provider-configs.service.d.ts +13 -0
  481. package/dist/server/modules/profiles/services/provider-configs.service.js +88 -0
  482. package/dist/server/modules/profiles/services/provider-configs.service.js.map +1 -0
  483. package/dist/server/modules/projects/controllers/projects.controller.d.ts +20 -1
  484. package/dist/server/modules/projects/controllers/projects.controller.js +132 -2
  485. package/dist/server/modules/projects/controllers/projects.controller.js.map +1 -1
  486. package/dist/server/modules/projects/dtos/export.dto.d.ts +6 -6
  487. package/dist/server/modules/projects/dtos/template-upgrade.dto.d.ts +20 -0
  488. package/dist/server/modules/projects/dtos/template-upgrade.dto.js +90 -0
  489. package/dist/server/modules/projects/dtos/template-upgrade.dto.js.map +1 -0
  490. package/dist/server/modules/projects/helpers/project-import.d.ts +14 -0
  491. package/dist/server/modules/projects/helpers/project-import.js +76 -1
  492. package/dist/server/modules/projects/helpers/project-import.js.map +1 -1
  493. package/dist/server/modules/projects/helpers/template-loader.js +3 -2
  494. package/dist/server/modules/projects/helpers/template-loader.js.map +1 -1
  495. package/dist/server/modules/projects/projects.module.js +21 -2
  496. package/dist/server/modules/projects/projects.module.js.map +1 -1
  497. package/dist/server/modules/projects/services/project-provider-provisioning.service.d.ts +1 -1
  498. package/dist/server/modules/projects/services/project-provider-provisioning.service.js +1 -1
  499. package/dist/server/modules/projects/services/project-provider-provisioning.service.js.map +1 -1
  500. package/dist/server/modules/projects/services/project-registry-import.service.d.ts +38 -0
  501. package/dist/server/modules/projects/services/project-registry-import.service.js +140 -0
  502. package/dist/server/modules/projects/services/project-registry-import.service.js.map +1 -0
  503. package/dist/server/modules/{registry/services/template-upgrade.service.d.ts → projects/services/project-template-upgrade.service.d.ts} +6 -8
  504. package/dist/server/modules/{registry/services/template-upgrade.service.js → projects/services/project-template-upgrade.service.js} +14 -21
  505. package/dist/server/modules/projects/services/project-template-upgrade.service.js.map +1 -0
  506. package/dist/server/modules/projects/services/projects.service.d.ts +3 -1
  507. package/dist/server/modules/projects/services/projects.service.js +7 -4
  508. package/dist/server/modules/projects/services/projects.service.js.map +1 -1
  509. package/dist/server/modules/providers/adapters/capabilities/context-window.capability.d.ts +20 -0
  510. package/dist/server/modules/providers/adapters/capabilities/context-window.capability.js +3 -0
  511. package/dist/server/modules/providers/adapters/capabilities/context-window.capability.js.map +1 -0
  512. package/dist/server/modules/providers/adapters/capabilities/hook.capability.d.ts +13 -0
  513. package/dist/server/modules/providers/adapters/capabilities/hook.capability.js +3 -0
  514. package/dist/server/modules/providers/adapters/capabilities/hook.capability.js.map +1 -0
  515. package/dist/server/modules/providers/adapters/capabilities/index.d.ts +2 -0
  516. package/dist/server/modules/providers/adapters/capabilities/index.js +12 -0
  517. package/dist/server/modules/providers/adapters/capabilities/index.js.map +1 -0
  518. package/dist/server/modules/providers/adapters/capabilities/project-mcp-settings.capability.d.ts +3 -0
  519. package/dist/server/modules/providers/adapters/capabilities/project-mcp-settings.capability.js +3 -0
  520. package/dist/server/modules/providers/adapters/capabilities/project-mcp-settings.capability.js.map +1 -0
  521. package/dist/server/modules/providers/adapters/capabilities/project-provisioning.capability.d.ts +14 -0
  522. package/dist/server/modules/providers/adapters/capabilities/project-provisioning.capability.js +3 -0
  523. package/dist/server/modules/providers/adapters/capabilities/project-provisioning.capability.js.map +1 -0
  524. package/dist/server/modules/providers/adapters/capabilities/transcript-discovery.capability.d.ts +6 -0
  525. package/dist/server/modules/providers/adapters/capabilities/transcript-discovery.capability.js +3 -0
  526. package/dist/server/modules/providers/adapters/capabilities/transcript-discovery.capability.js.map +1 -0
  527. package/dist/server/modules/providers/adapters/capabilities/type-guards.d.ts +35 -0
  528. package/dist/server/modules/providers/adapters/capabilities/type-guards.js +33 -0
  529. package/dist/server/modules/providers/adapters/capabilities/type-guards.js.map +1 -0
  530. package/dist/server/modules/providers/adapters/claude.adapter.d.ts +23 -2
  531. package/dist/server/modules/providers/adapters/claude.adapter.js +134 -0
  532. package/dist/server/modules/providers/adapters/claude.adapter.js.map +1 -1
  533. package/dist/server/modules/providers/adapters/codex.adapter.d.ts +7 -2
  534. package/dist/server/modules/providers/adapters/codex.adapter.js +4 -0
  535. package/dist/server/modules/providers/adapters/codex.adapter.js.map +1 -1
  536. package/dist/server/modules/providers/adapters/gemini.adapter.d.ts +11 -2
  537. package/dist/server/modules/providers/adapters/gemini.adapter.js +47 -2
  538. package/dist/server/modules/providers/adapters/gemini.adapter.js.map +1 -1
  539. package/dist/server/modules/providers/adapters/index.d.ts +1 -0
  540. package/dist/server/modules/providers/adapters/index.js +1 -0
  541. package/dist/server/modules/providers/adapters/index.js.map +1 -1
  542. package/dist/server/modules/providers/adapters/opencode.adapter.d.ts +1 -1
  543. package/dist/server/modules/providers/adapters/opencode.adapter.js.map +1 -1
  544. package/dist/server/modules/providers/adapters/provider-adapter.interface.d.ts +4 -8
  545. package/dist/server/modules/providers/adapters/provider-adapters.module.js +2 -1
  546. package/dist/server/modules/providers/adapters/provider-adapters.module.js.map +1 -1
  547. package/dist/server/modules/providers/controllers/provider-models.controller.d.ts +4 -3
  548. package/dist/server/modules/providers/controllers/provider-models.controller.js +29 -36
  549. package/dist/server/modules/providers/controllers/provider-models.controller.js.map +1 -1
  550. package/dist/server/modules/providers/controllers/providers.controller.d.ts +7 -13
  551. package/dist/server/modules/providers/controllers/providers.controller.js +19 -239
  552. package/dist/server/modules/providers/controllers/providers.controller.js.map +1 -1
  553. package/dist/server/modules/providers/providers.module.js +24 -6
  554. package/dist/server/modules/providers/providers.module.js.map +1 -1
  555. package/dist/server/modules/providers/services/mcp-provider-registration.service.d.ts +23 -0
  556. package/dist/server/modules/providers/services/mcp-provider-registration.service.js +111 -0
  557. package/dist/server/modules/providers/services/mcp-provider-registration.service.js.map +1 -0
  558. package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.d.ts +26 -0
  559. package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js +274 -0
  560. package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js.map +1 -0
  561. package/dist/server/modules/providers/services/mcp-registration/config-file-mcp-registration.adapter.d.ts +14 -0
  562. package/dist/server/modules/providers/services/mcp-registration/config-file-mcp-registration.adapter.js +328 -0
  563. package/dist/server/modules/providers/services/mcp-registration/config-file-mcp-registration.adapter.js.map +1 -0
  564. package/dist/server/modules/providers/services/mcp-registration/index.d.ts +5 -0
  565. package/dist/server/modules/providers/services/mcp-registration/index.js +10 -0
  566. package/dist/server/modules/providers/services/mcp-registration/index.js.map +1 -0
  567. package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.d.ts +20 -0
  568. package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.js +47 -0
  569. package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.js.map +1 -0
  570. package/dist/server/modules/providers/services/mcp-registration/mcp-registration.types.d.ts +43 -0
  571. package/dist/server/modules/providers/services/mcp-registration/mcp-registration.types.js +3 -0
  572. package/dist/server/modules/providers/services/mcp-registration/mcp-registration.types.js.map +1 -0
  573. package/dist/server/modules/providers/services/probe-proof.service.d.ts +3 -1
  574. package/dist/server/modules/providers/services/probe-proof.service.js +23 -9
  575. package/dist/server/modules/providers/services/probe-proof.service.js.map +1 -1
  576. package/dist/server/modules/{core → providers}/services/provider-mcp-ensure.service.d.ts +3 -8
  577. package/dist/server/modules/providers/services/provider-mcp-ensure.service.js +175 -0
  578. package/dist/server/modules/providers/services/provider-mcp-ensure.service.js.map +1 -0
  579. package/dist/server/modules/providers/services/provider-state-manager.service.d.ts +53 -0
  580. package/dist/server/modules/providers/services/provider-state-manager.service.js +249 -0
  581. package/dist/server/modules/providers/services/provider-state-manager.service.js.map +1 -0
  582. package/dist/server/modules/providers/utils/probe-1m.d.ts +2 -1
  583. package/dist/server/modules/providers/utils/probe-1m.js +13 -19
  584. package/dist/server/modules/providers/utils/probe-1m.js.map +1 -1
  585. package/dist/server/modules/realtime/dtos/ws-envelope.dto.d.ts +19 -0
  586. package/dist/server/modules/realtime/dtos/ws-envelope.dto.js +20 -0
  587. package/dist/server/modules/realtime/dtos/ws-envelope.dto.js.map +1 -0
  588. package/dist/server/modules/realtime/ports/realtime-broadcaster.port.d.ts +4 -0
  589. package/dist/server/modules/realtime/ports/realtime-broadcaster.port.js +5 -0
  590. package/dist/server/modules/realtime/ports/realtime-broadcaster.port.js.map +1 -0
  591. package/dist/server/modules/realtime/realtime-broadcast.module.d.ts +2 -0
  592. package/dist/server/modules/realtime/realtime-broadcast.module.js +25 -0
  593. package/dist/server/modules/realtime/realtime-broadcast.module.js.map +1 -0
  594. package/dist/server/modules/realtime/services/noop-realtime-broadcast.adapter.d.ts +4 -0
  595. package/dist/server/modules/realtime/services/noop-realtime-broadcast.adapter.js +19 -0
  596. package/dist/server/modules/realtime/services/noop-realtime-broadcast.adapter.js.map +1 -0
  597. package/dist/server/modules/realtime/services/realtime-broadcast.service.d.ts +7 -0
  598. package/dist/server/modules/realtime/services/realtime-broadcast.service.js +33 -0
  599. package/dist/server/modules/realtime/services/realtime-broadcast.service.js.map +1 -0
  600. package/dist/server/modules/registry/controllers/registry.controller.d.ts +1 -30
  601. package/dist/server/modules/registry/controllers/registry.controller.js +2 -105
  602. package/dist/server/modules/registry/controllers/registry.controller.js.map +1 -1
  603. package/dist/server/modules/registry/index.d.ts +0 -1
  604. package/dist/server/modules/registry/index.js +0 -1
  605. package/dist/server/modules/registry/index.js.map +1 -1
  606. package/dist/server/modules/registry/registry.module.js +1 -5
  607. package/dist/server/modules/registry/registry.module.js.map +1 -1
  608. package/dist/server/modules/registry/services/registry-orchestration.service.d.ts +1 -29
  609. package/dist/server/modules/registry/services/registry-orchestration.service.js +2 -94
  610. package/dist/server/modules/registry/services/registry-orchestration.service.js.map +1 -1
  611. package/dist/server/modules/reviews/reviews.module.js +8 -4
  612. package/dist/server/modules/reviews/reviews.module.js.map +1 -1
  613. package/dist/server/modules/reviews/services/review-suggestion-applier.service.d.ts +29 -0
  614. package/dist/server/modules/reviews/services/review-suggestion-applier.service.js +116 -0
  615. package/dist/server/modules/reviews/services/review-suggestion-applier.service.js.map +1 -0
  616. package/dist/server/modules/reviews/services/reviews.service.js +11 -0
  617. package/dist/server/modules/reviews/services/reviews.service.js.map +1 -1
  618. package/dist/server/modules/reviews/subscribers/review-comment-notifier.subscriber.d.ts +16 -0
  619. package/dist/server/modules/{events → reviews}/subscribers/review-comment-notifier.subscriber.js +26 -75
  620. package/dist/server/modules/reviews/subscribers/review-comment-notifier.subscriber.js.map +1 -0
  621. package/dist/server/modules/seeders/seeders/0001_seed_compact_on_idle_watcher.d.ts +1 -1
  622. package/dist/server/modules/seeders/seeders/0002_seed_replace_permission_mode_plan.d.ts +1 -1
  623. package/dist/server/modules/seeders/seeders/0003_seed_preseed_jeffallan_claude_skills.d.ts +1 -1
  624. package/dist/server/modules/seeders/seeders/0004_seed_disable_microsoft_source_default.d.ts +1 -1
  625. package/dist/server/modules/seeders/seeders/0005_seed_renew_instructions_subscriber.d.ts +1 -1
  626. package/dist/server/modules/seeders/seeders/0006_seed_rename_template_slugs.d.ts +1 -1
  627. package/dist/server/modules/seeders/seeders/0007_seed_claude_no_flicker_env.d.ts +1 -1
  628. package/dist/server/modules/seeders/services/data-seeder.service.d.ts +2 -12
  629. package/dist/server/modules/seeders/services/data-seeder.service.js.map +1 -1
  630. package/dist/server/modules/seeders/types/seeder.types.d.ts +15 -0
  631. package/dist/server/modules/seeders/types/seeder.types.js +3 -0
  632. package/dist/server/modules/seeders/types/seeder.types.js.map +1 -0
  633. package/dist/server/modules/session-reader/adapters/codex-session-reader.adapter.d.ts +8 -0
  634. package/dist/server/modules/session-reader/adapters/codex-session-reader.adapter.js +63 -3
  635. package/dist/server/modules/session-reader/adapters/codex-session-reader.adapter.js.map +1 -1
  636. package/dist/server/modules/session-reader/controllers/session-reader.controller.d.ts +19 -410
  637. package/dist/server/modules/session-reader/controllers/session-reader.controller.js +159 -69
  638. package/dist/server/modules/session-reader/controllers/session-reader.controller.js.map +1 -1
  639. package/dist/server/modules/session-reader/data/pricing.json +19 -0
  640. package/dist/server/modules/session-reader/dtos/unified-chunk.types.d.ts +1 -2
  641. package/dist/server/modules/session-reader/dtos/unified-chunk.types.js.map +1 -1
  642. package/dist/server/modules/session-reader/dtos/unified-message.types.d.ts +66 -0
  643. package/dist/server/modules/session-reader/dtos/unified-message.types.js +3 -0
  644. package/dist/server/modules/session-reader/dtos/unified-message.types.js.map +1 -0
  645. package/dist/server/modules/session-reader/dtos/unified-session.types.d.ts +2 -66
  646. package/dist/server/modules/session-reader/dtos/unified-session.types.js.map +1 -1
  647. package/dist/server/modules/session-reader/services/codex-provider-session-id-backfill.service.d.ts +25 -0
  648. package/dist/server/modules/session-reader/services/codex-provider-session-id-backfill.service.js +175 -0
  649. package/dist/server/modules/session-reader/services/codex-provider-session-id-backfill.service.js.map +1 -0
  650. package/dist/server/modules/session-reader/services/session-cache.service.d.ts +9 -0
  651. package/dist/server/modules/session-reader/services/session-cache.service.js +15 -0
  652. package/dist/server/modules/session-reader/services/session-cache.service.js.map +1 -1
  653. package/dist/server/modules/session-reader/services/session-reader.service.d.ts +50 -4
  654. package/dist/server/modules/session-reader/services/session-reader.service.js +173 -116
  655. package/dist/server/modules/session-reader/services/session-reader.service.js.map +1 -1
  656. package/dist/server/modules/session-reader/services/transcript-cursor.d.ts +6 -0
  657. package/dist/server/modules/session-reader/services/transcript-cursor.js +27 -0
  658. package/dist/server/modules/session-reader/services/transcript-cursor.js.map +1 -0
  659. package/dist/server/modules/session-reader/services/transcript-persistence.listener.d.ts +45 -2
  660. package/dist/server/modules/session-reader/services/transcript-persistence.listener.js +472 -54
  661. package/dist/server/modules/session-reader/services/transcript-persistence.listener.js.map +1 -1
  662. package/dist/server/modules/session-reader/services/transcript-serialization.d.ts +4 -0
  663. package/dist/server/modules/session-reader/services/transcript-serialization.js +31 -0
  664. package/dist/server/modules/session-reader/services/transcript-serialization.js.map +1 -0
  665. package/dist/server/modules/session-reader/services/transcript-truncation.d.ts +6 -0
  666. package/dist/server/modules/session-reader/services/transcript-truncation.js +175 -0
  667. package/dist/server/modules/session-reader/services/transcript-truncation.js.map +1 -0
  668. package/dist/server/modules/session-reader/services/transcript-watcher.service.js +52 -2
  669. package/dist/server/modules/session-reader/services/transcript-watcher.service.js.map +1 -1
  670. package/dist/server/modules/session-reader/session-reader.module.js +6 -2
  671. package/dist/server/modules/session-reader/session-reader.module.js.map +1 -1
  672. package/dist/server/modules/sessions/controllers/sessions.controller.d.ts +9 -1
  673. package/dist/server/modules/sessions/controllers/sessions.controller.js +74 -4
  674. package/dist/server/modules/sessions/controllers/sessions.controller.js.map +1 -1
  675. package/dist/server/modules/sessions/dtos/active-session-info.dto.d.ts +21 -0
  676. package/dist/server/modules/sessions/dtos/active-session-info.dto.js +12 -0
  677. package/dist/server/modules/sessions/dtos/active-session-info.dto.js.map +1 -0
  678. package/dist/server/modules/sessions/dtos/sessions.dto.d.ts +2 -0
  679. package/dist/server/modules/sessions/dtos/sessions.dto.js.map +1 -1
  680. package/dist/server/modules/sessions/services/active-session-lookup.service.d.ts +9 -0
  681. package/dist/server/modules/sessions/services/active-session-lookup.service.js +70 -0
  682. package/dist/server/modules/sessions/services/active-session-lookup.service.js.map +1 -0
  683. package/dist/server/modules/sessions/services/agent-presence-aggregator.d.ts +13 -0
  684. package/dist/server/modules/sessions/services/agent-presence-aggregator.js +36 -0
  685. package/dist/server/modules/sessions/services/agent-presence-aggregator.js.map +1 -0
  686. package/dist/server/modules/sessions/services/delivery-failure-notifier.service.d.ts +9 -0
  687. package/dist/server/modules/sessions/services/delivery-failure-notifier.service.js +64 -0
  688. package/dist/server/modules/sessions/services/delivery-failure-notifier.service.js.map +1 -0
  689. package/dist/server/modules/sessions/services/message-activity-stream.service.d.ts +4 -4
  690. package/dist/server/modules/sessions/services/message-activity-stream.service.js +6 -6
  691. package/dist/server/modules/sessions/services/message-activity-stream.service.js.map +1 -1
  692. package/dist/server/modules/sessions/services/message-enqueue.service.d.ts +30 -0
  693. package/dist/server/modules/sessions/services/message-enqueue.service.js +55 -0
  694. package/dist/server/modules/sessions/services/message-enqueue.service.js.map +1 -0
  695. package/dist/server/modules/sessions/services/message-log.service.d.ts +24 -0
  696. package/dist/server/modules/sessions/services/message-log.service.js +110 -0
  697. package/dist/server/modules/sessions/services/message-log.service.js.map +1 -0
  698. package/dist/server/modules/sessions/services/message-pool.types.d.ts +69 -0
  699. package/dist/server/modules/sessions/services/message-pool.types.js +5 -0
  700. package/dist/server/modules/sessions/services/message-pool.types.js.map +1 -0
  701. package/dist/server/modules/sessions/services/provider-launch-config/index.d.ts +2 -0
  702. package/dist/server/modules/sessions/services/provider-launch-config/index.js +9 -0
  703. package/dist/server/modules/sessions/services/provider-launch-config/index.js.map +1 -0
  704. package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.d.ts +24 -0
  705. package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js +45 -0
  706. package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js.map +1 -0
  707. package/dist/server/modules/sessions/services/session-launcher-facade.service.d.ts +13 -0
  708. package/dist/server/modules/sessions/services/session-launcher-facade.service.js +73 -0
  709. package/dist/server/modules/sessions/services/session-launcher-facade.service.js.map +1 -0
  710. package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.d.ts +262 -0
  711. package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js +329 -0
  712. package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js.map +1 -0
  713. package/dist/server/modules/sessions/services/session-runtime/cleanup-stack.d.ts +11 -0
  714. package/dist/server/modules/sessions/services/session-runtime/cleanup-stack.js +27 -0
  715. package/dist/server/modules/sessions/services/session-runtime/cleanup-stack.js.map +1 -0
  716. package/dist/server/modules/sessions/services/session-runtime/index.d.ts +4 -0
  717. package/dist/server/modules/sessions/services/session-runtime/index.js +12 -0
  718. package/dist/server/modules/sessions/services/session-runtime/index.js.map +1 -0
  719. package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.d.ts +38 -0
  720. package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js +404 -0
  721. package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js.map +1 -0
  722. package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.d.ts +26 -0
  723. package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js +265 -0
  724. package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js.map +1 -0
  725. package/dist/server/modules/sessions/services/session-runtime/session-runtime.service.d.ts +10 -0
  726. package/dist/server/modules/sessions/services/session-runtime/session-runtime.service.js +34 -0
  727. package/dist/server/modules/sessions/services/session-runtime/session-runtime.service.js.map +1 -0
  728. package/dist/server/modules/sessions/services/sessions-message-pool.service.d.ts +11 -84
  729. package/dist/server/modules/sessions/services/sessions-message-pool.service.js +60 -185
  730. package/dist/server/modules/sessions/services/sessions-message-pool.service.js.map +1 -1
  731. package/dist/server/modules/sessions/services/sessions.service.d.ts +25 -52
  732. package/dist/server/modules/sessions/services/sessions.service.js +134 -840
  733. package/dist/server/modules/sessions/services/sessions.service.js.map +1 -1
  734. package/dist/server/modules/sessions/sessions-delivery.module.d.ts +2 -0
  735. package/dist/server/modules/sessions/sessions-delivery.module.js +26 -0
  736. package/dist/server/modules/sessions/sessions-delivery.module.js.map +1 -0
  737. package/dist/server/modules/sessions/sessions-read.module.d.ts +2 -0
  738. package/dist/server/modules/sessions/sessions-read.module.js +23 -0
  739. package/dist/server/modules/sessions/sessions-read.module.js.map +1 -0
  740. package/dist/server/modules/sessions/sessions.module.js +22 -5
  741. package/dist/server/modules/sessions/sessions.module.js.map +1 -1
  742. package/dist/server/modules/sessions/utils/claude-config.d.ts +1 -1
  743. package/dist/server/modules/sessions/utils/claude-config.js +2 -2
  744. package/dist/server/modules/sessions/utils/env-builder.d.ts +1 -1
  745. package/dist/server/modules/sessions/utils/env-builder.js +8 -3
  746. package/dist/server/modules/sessions/utils/env-builder.js.map +1 -1
  747. package/dist/server/modules/sessions/utils/tmux-naming.util.d.ts +1 -0
  748. package/dist/server/modules/sessions/utils/tmux-naming.util.js +10 -0
  749. package/dist/server/modules/sessions/utils/tmux-naming.util.js.map +1 -0
  750. package/dist/server/modules/settings/dtos/settings.dto.d.ts +14 -0
  751. package/dist/server/modules/settings/dtos/settings.dto.js +3 -3
  752. package/dist/server/modules/settings/dtos/settings.dto.js.map +1 -1
  753. package/dist/server/modules/settings/local/delegates/core-settings.delegate.d.ts +20 -0
  754. package/dist/server/modules/settings/local/delegates/core-settings.delegate.js +499 -0
  755. package/dist/server/modules/settings/local/delegates/core-settings.delegate.js.map +1 -0
  756. package/dist/server/modules/settings/local/delegates/message-pool-settings.delegate.d.ts +14 -0
  757. package/dist/server/modules/settings/local/delegates/message-pool-settings.delegate.js +67 -0
  758. package/dist/server/modules/settings/local/delegates/message-pool-settings.delegate.js.map +1 -0
  759. package/dist/server/modules/settings/local/delegates/preset-settings.delegate.d.ts +36 -0
  760. package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js +393 -0
  761. package/dist/server/modules/settings/local/delegates/preset-settings.delegate.js.map +1 -0
  762. package/dist/server/modules/settings/local/delegates/registry-settings.delegate.d.ts +20 -0
  763. package/dist/server/modules/settings/local/delegates/registry-settings.delegate.js +82 -0
  764. package/dist/server/modules/settings/local/delegates/registry-settings.delegate.js.map +1 -0
  765. package/dist/server/modules/settings/local/delegates/skills-settings.delegate.d.ts +16 -0
  766. package/dist/server/modules/settings/local/delegates/skills-settings.delegate.js +107 -0
  767. package/dist/server/modules/settings/local/delegates/skills-settings.delegate.js.map +1 -0
  768. package/dist/server/modules/settings/services/settings.constants.d.ts +31 -0
  769. package/dist/server/modules/settings/services/settings.constants.js +24 -0
  770. package/dist/server/modules/settings/services/settings.constants.js.map +1 -0
  771. package/dist/server/modules/settings/services/settings.service.d.ts +15 -54
  772. package/dist/server/modules/settings/services/settings.service.js +85 -897
  773. package/dist/server/modules/settings/services/settings.service.js.map +1 -1
  774. package/dist/server/modules/skills/services/skill-search.utils.d.ts +18 -0
  775. package/dist/server/modules/skills/services/skill-search.utils.js +87 -0
  776. package/dist/server/modules/skills/services/skill-search.utils.js.map +1 -0
  777. package/dist/server/modules/skills/services/skills.service.js +25 -27
  778. package/dist/server/modules/skills/services/skills.service.js.map +1 -1
  779. package/dist/server/modules/storage/db/schema.d.ts +81 -0
  780. package/dist/server/modules/storage/db/schema.js +10 -2
  781. package/dist/server/modules/storage/db/schema.js.map +1 -1
  782. package/dist/server/modules/storage/db/transaction-runner.d.ts +8 -0
  783. package/dist/server/modules/storage/db/transaction-runner.js +44 -0
  784. package/dist/server/modules/storage/db/transaction-runner.js.map +1 -0
  785. package/dist/server/modules/storage/interfaces/storage.interface.d.ts +4 -0
  786. package/dist/server/modules/storage/interfaces/storage.interface.js.map +1 -1
  787. package/dist/server/modules/storage/local/delegates/base-storage.delegate.d.ts +2 -0
  788. package/dist/server/modules/storage/local/delegates/base-storage.delegate.js +2 -0
  789. package/dist/server/modules/storage/local/delegates/base-storage.delegate.js.map +1 -1
  790. package/dist/server/modules/storage/local/delegates/epic.delegate.d.ts +2 -1
  791. package/dist/server/modules/storage/local/delegates/epic.delegate.js +36 -1
  792. package/dist/server/modules/storage/local/delegates/epic.delegate.js.map +1 -1
  793. package/dist/server/modules/storage/local/delegates/profile-provider-config.delegate.js +5 -35
  794. package/dist/server/modules/storage/local/delegates/profile-provider-config.delegate.js.map +1 -1
  795. package/dist/server/modules/storage/local/delegates/project.delegate.js +12 -20
  796. package/dist/server/modules/storage/local/delegates/project.delegate.js.map +1 -1
  797. package/dist/server/modules/storage/local/delegates/provider-model.delegate.js +2 -12
  798. package/dist/server/modules/storage/local/delegates/provider-model.delegate.js.map +1 -1
  799. package/dist/server/modules/storage/local/delegates/review.delegate.js +22 -38
  800. package/dist/server/modules/storage/local/delegates/review.delegate.js.map +1 -1
  801. package/dist/server/modules/storage/local/delegates/skill-source.delegate.js +2 -17
  802. package/dist/server/modules/storage/local/delegates/skill-source.delegate.js.map +1 -1
  803. package/dist/server/modules/storage/local/local-storage.service.d.ts +2 -1
  804. package/dist/server/modules/storage/local/local-storage.service.js +3 -0
  805. package/dist/server/modules/storage/local/local-storage.service.js.map +1 -1
  806. package/dist/server/modules/subscribers/actions/action.interface.d.ts +6 -6
  807. package/dist/server/modules/subscribers/actions/restart-agent.action.js +4 -3
  808. package/dist/server/modules/subscribers/actions/restart-agent.action.js.map +1 -1
  809. package/dist/server/modules/subscribers/actions/send-message.action.js +12 -7
  810. package/dist/server/modules/subscribers/actions/send-message.action.js.map +1 -1
  811. package/dist/server/modules/subscribers/events/event-fields-catalog.js +1 -0
  812. package/dist/server/modules/subscribers/events/event-fields-catalog.js.map +1 -1
  813. package/dist/server/modules/subscribers/services/automation-scheduler.service.d.ts +2 -13
  814. package/dist/server/modules/subscribers/services/automation-scheduler.service.js.map +1 -1
  815. package/dist/server/modules/subscribers/services/subscriber-executor.service.d.ts +9 -18
  816. package/dist/server/modules/subscribers/services/subscriber-executor.service.js +29 -24
  817. package/dist/server/modules/subscribers/services/subscriber-executor.service.js.map +1 -1
  818. package/dist/server/modules/subscribers/services/subscriber-scheduler.types.d.ts +23 -0
  819. package/dist/server/modules/subscribers/services/subscriber-scheduler.types.js +3 -0
  820. package/dist/server/modules/subscribers/services/subscriber-scheduler.types.js.map +1 -0
  821. package/dist/server/modules/subscribers/subscribers.module.js +7 -5
  822. package/dist/server/modules/subscribers/subscribers.module.js.map +1 -1
  823. package/dist/server/modules/teams/dtos/recipient-context.dto.d.ts +6 -0
  824. package/dist/server/modules/teams/dtos/recipient-context.dto.js +3 -0
  825. package/dist/server/modules/teams/dtos/recipient-context.dto.js.map +1 -0
  826. package/dist/server/modules/teams/services/teams.service.d.ts +4 -0
  827. package/dist/server/modules/teams/services/teams.service.js +68 -0
  828. package/dist/server/modules/teams/services/teams.service.js.map +1 -1
  829. package/dist/server/modules/teams/storage/teams.store.d.ts +2 -0
  830. package/dist/server/modules/teams/storage/teams.store.js +110 -167
  831. package/dist/server/modules/teams/storage/teams.store.js.map +1 -1
  832. package/dist/server/modules/teams/subscribers/team-config-updated-notifier.subscriber.d.ts +18 -0
  833. package/dist/server/modules/{events → teams}/subscribers/team-config-updated-notifier.subscriber.js +38 -43
  834. package/dist/server/modules/teams/subscribers/team-config-updated-notifier.subscriber.js.map +1 -0
  835. package/dist/server/modules/teams/subscribers/team-membership-changed-notifier.subscriber.d.ts +18 -0
  836. package/dist/server/modules/{events → teams}/subscribers/team-membership-changed-notifier.subscriber.js +29 -44
  837. package/dist/server/modules/teams/subscribers/team-membership-changed-notifier.subscriber.js.map +1 -0
  838. package/dist/server/modules/teams/teams.module.js +11 -3
  839. package/dist/server/modules/teams/teams.module.js.map +1 -1
  840. package/dist/server/modules/terminal/gateways/terminal.gateway.d.ts +25 -15
  841. package/dist/server/modules/terminal/gateways/terminal.gateway.js +328 -383
  842. package/dist/server/modules/terminal/gateways/terminal.gateway.js.map +1 -1
  843. package/dist/server/modules/terminal/services/guest-delivery.service.d.ts +7 -0
  844. package/dist/server/modules/terminal/services/guest-delivery.service.js +37 -0
  845. package/dist/server/modules/terminal/services/guest-delivery.service.js.map +1 -0
  846. package/dist/server/modules/terminal/services/process-executor/child-process-executor.d.ts +5 -0
  847. package/dist/server/modules/terminal/services/process-executor/child-process-executor.js +195 -0
  848. package/dist/server/modules/terminal/services/process-executor/child-process-executor.js.map +1 -0
  849. package/dist/server/modules/terminal/services/process-executor/fake-process-executor.d.ts +44 -0
  850. package/dist/server/modules/terminal/services/process-executor/fake-process-executor.js +106 -0
  851. package/dist/server/modules/terminal/services/process-executor/fake-process-executor.js.map +1 -0
  852. package/dist/server/modules/terminal/services/process-executor/process-executor.module.d.ts +2 -0
  853. package/dist/server/modules/terminal/services/process-executor/process-executor.module.js +31 -0
  854. package/dist/server/modules/terminal/services/process-executor/process-executor.module.js.map +1 -0
  855. package/dist/server/modules/terminal/services/process-executor/process-executor.port.d.ts +33 -0
  856. package/dist/server/modules/terminal/services/process-executor/process-executor.port.js +20 -0
  857. package/dist/server/modules/terminal/services/process-executor/process-executor.port.js.map +1 -0
  858. package/dist/server/modules/terminal/services/process-executor/pty-executor.d.ts +5 -0
  859. package/dist/server/modules/terminal/services/process-executor/pty-executor.js +157 -0
  860. package/dist/server/modules/terminal/services/process-executor/pty-executor.js.map +1 -0
  861. package/dist/server/modules/terminal/services/process-executor/routing-process-executor.d.ts +10 -0
  862. package/dist/server/modules/terminal/services/process-executor/routing-process-executor.js +36 -0
  863. package/dist/server/modules/terminal/services/process-executor/routing-process-executor.js.map +1 -0
  864. package/dist/server/modules/terminal/services/pty.service.d.ts +11 -14
  865. package/dist/server/modules/terminal/services/pty.service.js +43 -72
  866. package/dist/server/modules/terminal/services/pty.service.js.map +1 -1
  867. package/dist/server/modules/terminal/services/terminal-activity.service.d.ts +24 -0
  868. package/dist/server/modules/terminal/services/terminal-activity.service.js +164 -0
  869. package/dist/server/modules/terminal/services/terminal-activity.service.js.map +1 -0
  870. package/dist/server/modules/terminal/services/terminal-delivery-facade.service.d.ts +9 -0
  871. package/dist/server/modules/terminal/services/terminal-delivery-facade.service.js +47 -0
  872. package/dist/server/modules/terminal/services/terminal-delivery-facade.service.js.map +1 -0
  873. package/dist/server/modules/terminal/services/terminal-delivery.types.d.ts +10 -0
  874. package/dist/server/modules/terminal/services/terminal-delivery.types.js +3 -0
  875. package/dist/server/modules/terminal/services/terminal-delivery.types.js.map +1 -0
  876. package/dist/server/modules/terminal/services/terminal-io/capture.d.ts +6 -0
  877. package/dist/server/modules/terminal/services/terminal-io/capture.js +77 -0
  878. package/dist/server/modules/terminal/services/terminal-io/capture.js.map +1 -0
  879. package/dist/server/modules/terminal/services/terminal-io/delivery.d.ts +19 -0
  880. package/dist/server/modules/terminal/services/terminal-io/delivery.js +230 -0
  881. package/dist/server/modules/terminal/services/terminal-io/delivery.js.map +1 -0
  882. package/dist/server/modules/terminal/services/terminal-io/lifecycle.d.ts +7 -0
  883. package/dist/server/modules/terminal/services/terminal-io/lifecycle.js +87 -0
  884. package/dist/server/modules/terminal/services/terminal-io/lifecycle.js.map +1 -0
  885. package/dist/server/modules/terminal/services/terminal-io/monitoring.d.ts +4 -0
  886. package/dist/server/modules/terminal/services/terminal-io/monitoring.js +65 -0
  887. package/dist/server/modules/terminal/services/terminal-io/monitoring.js.map +1 -0
  888. package/dist/server/modules/terminal/services/terminal-io/quote-shell-arg.d.ts +1 -0
  889. package/dist/server/modules/terminal/services/terminal-io/quote-shell-arg.js +9 -0
  890. package/dist/server/modules/terminal/services/terminal-io/quote-shell-arg.js.map +1 -0
  891. package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.d.ts +35 -0
  892. package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js +210 -0
  893. package/dist/server/modules/terminal/services/terminal-io/terminal-io.service.js.map +1 -0
  894. package/dist/server/modules/terminal/services/terminal-io/types.d.ts +42 -0
  895. package/dist/server/modules/terminal/services/terminal-io/types.js +3 -0
  896. package/dist/server/modules/terminal/services/terminal-io/types.js.map +1 -0
  897. package/dist/server/modules/terminal/services/terminal-registry-rehydrator.service.d.ts +11 -0
  898. package/dist/server/modules/terminal/services/terminal-registry-rehydrator.service.js +63 -0
  899. package/dist/server/modules/terminal/services/terminal-registry-rehydrator.service.js.map +1 -0
  900. package/dist/server/modules/terminal/services/terminal-seed.service.d.ts +7 -5
  901. package/dist/server/modules/terminal/services/terminal-seed.service.js +46 -45
  902. package/dist/server/modules/terminal/services/terminal-seed.service.js.map +1 -1
  903. package/dist/server/modules/terminal/services/terminal-session/terminal-frame-stream.d.ts +11 -0
  904. package/dist/server/modules/terminal/services/terminal-session/terminal-frame-stream.js +17 -0
  905. package/dist/server/modules/terminal/services/terminal-session/terminal-frame-stream.js.map +1 -0
  906. package/dist/server/modules/terminal/services/terminal-session/terminal-session-registry.d.ts +15 -0
  907. package/dist/server/modules/terminal/services/terminal-session/terminal-session-registry.js +62 -0
  908. package/dist/server/modules/terminal/services/terminal-session/terminal-session-registry.js.map +1 -0
  909. package/dist/server/modules/terminal/services/terminal-session/terminal-session.d.ts +77 -0
  910. package/dist/server/modules/terminal/services/terminal-session/terminal-session.js +252 -0
  911. package/dist/server/modules/terminal/services/terminal-session/terminal-session.js.map +1 -0
  912. package/dist/server/modules/terminal/terminal-delivery.module.d.ts +2 -0
  913. package/dist/server/modules/terminal/terminal-delivery.module.js +26 -0
  914. package/dist/server/modules/terminal/terminal-delivery.module.js.map +1 -0
  915. package/dist/server/modules/terminal/terminal.module.js +29 -9
  916. package/dist/server/modules/terminal/terminal.module.js.map +1 -1
  917. package/dist/server/modules/terminal/utils/normalize-line-endings.d.ts +1 -0
  918. package/dist/server/modules/terminal/utils/normalize-line-endings.js +8 -0
  919. package/dist/server/modules/terminal/utils/normalize-line-endings.js.map +1 -0
  920. package/dist/server/modules/watchers/services/watcher-runner.service.d.ts +3 -3
  921. package/dist/server/modules/watchers/services/watcher-runner.service.js +20 -14
  922. package/dist/server/modules/watchers/services/watcher-runner.service.js.map +1 -1
  923. package/dist/server/modules/watchers/watchers.module.js +2 -2
  924. package/dist/server/modules/watchers/watchers.module.js.map +1 -1
  925. package/dist/server/templates/teams-dev.json +15 -14
  926. package/dist/server/tsconfig.tsbuildinfo +1 -1
  927. package/dist/server/ui/assets/{ReviewDetailPage-CoOg-QZq.js → ReviewDetailPage-CEqKCtbS.js} +1 -1
  928. package/dist/server/ui/assets/ReviewsPage-KUZqxdFY.js +6 -0
  929. package/dist/server/ui/assets/index-59euy2RV.css +32 -0
  930. package/dist/server/ui/assets/index-BFSzo9O6.js +1085 -0
  931. package/dist/server/ui/assets/{useReviewSubscription-CnFCUxkN.js → useReviewSubscription-q_e_8Dd4.js} +22 -27
  932. package/dist/server/ui/index.html +2 -2
  933. package/dist/templates/teams-dev.json +15 -14
  934. package/package.json +18 -2
  935. package/dist/server/modules/core/services/provider-mcp-ensure.service.js +0 -307
  936. package/dist/server/modules/core/services/provider-mcp-ensure.service.js.map +0 -1
  937. package/dist/server/modules/events/events-domain.module.d.ts +0 -2
  938. package/dist/server/modules/events/events-domain.module.js.map +0 -1
  939. package/dist/server/modules/events/subscribers/chat-message-broadcaster.subscriber.js +0 -47
  940. package/dist/server/modules/events/subscribers/chat-message-broadcaster.subscriber.js.map +0 -1
  941. package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.d.ts +0 -28
  942. package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js +0 -120
  943. package/dist/server/modules/events/subscribers/chat-message-delivery.subscriber.js.map +0 -1
  944. package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.d.ts +0 -29
  945. package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.js.map +0 -1
  946. package/dist/server/modules/events/subscribers/index.d.ts +0 -2
  947. package/dist/server/modules/events/subscribers/index.js +0 -28
  948. package/dist/server/modules/events/subscribers/index.js.map +0 -1
  949. package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.d.ts +0 -16
  950. package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.js +0 -101
  951. package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.js.map +0 -1
  952. package/dist/server/modules/events/subscribers/review-broadcaster.subscriber.d.ts +0 -16
  953. package/dist/server/modules/events/subscribers/review-broadcaster.subscriber.js +0 -163
  954. package/dist/server/modules/events/subscribers/review-broadcaster.subscriber.js.map +0 -1
  955. package/dist/server/modules/events/subscribers/review-comment-notifier.subscriber.d.ts +0 -24
  956. package/dist/server/modules/events/subscribers/review-comment-notifier.subscriber.js.map +0 -1
  957. package/dist/server/modules/events/subscribers/sub-epic-created-notifier.subscriber.d.ts +0 -18
  958. package/dist/server/modules/events/subscribers/sub-epic-created-notifier.subscriber.js.map +0 -1
  959. package/dist/server/modules/events/subscribers/team-config-updated-notifier.subscriber.d.ts +0 -18
  960. package/dist/server/modules/events/subscribers/team-config-updated-notifier.subscriber.js.map +0 -1
  961. package/dist/server/modules/events/subscribers/team-membership-changed-notifier.subscriber.d.ts +0 -18
  962. package/dist/server/modules/events/subscribers/team-membership-changed-notifier.subscriber.js.map +0 -1
  963. package/dist/server/modules/events/subscribers/transcript-broadcaster.subscriber.d.ts +0 -12
  964. package/dist/server/modules/events/subscribers/transcript-broadcaster.subscriber.js +0 -88
  965. package/dist/server/modules/events/subscribers/transcript-broadcaster.subscriber.js.map +0 -1
  966. package/dist/server/modules/events/subscribers/worktree-broadcaster.subscriber.d.ts +0 -8
  967. package/dist/server/modules/events/subscribers/worktree-broadcaster.subscriber.js +0 -48
  968. package/dist/server/modules/events/subscribers/worktree-broadcaster.subscriber.js.map +0 -1
  969. package/dist/server/modules/mcp/dtos/schema-registry.d.ts +0 -7
  970. package/dist/server/modules/mcp/dtos/schema-registry.js +0 -64
  971. package/dist/server/modules/mcp/dtos/schema-registry.js.map +0 -1
  972. package/dist/server/modules/mcp/mcp.module.d.ts +0 -2
  973. package/dist/server/modules/mcp/mcp.module.js.map +0 -1
  974. package/dist/server/modules/mcp/services/mcp-provider-registration.service.d.ts +0 -64
  975. package/dist/server/modules/mcp/services/mcp-provider-registration.service.js +0 -663
  976. package/dist/server/modules/mcp/services/mcp-provider-registration.service.js.map +0 -1
  977. package/dist/server/modules/mcp/services/terminal-activity.service.d.ts +0 -9
  978. package/dist/server/modules/mcp/services/terminal-activity.service.js +0 -68
  979. package/dist/server/modules/mcp/services/terminal-activity.service.js.map +0 -1
  980. package/dist/server/modules/mcp/tool-definitions.d.ts +0 -3077
  981. package/dist/server/modules/mcp/tool-definitions.js +0 -913
  982. package/dist/server/modules/mcp/tool-definitions.js.map +0 -1
  983. package/dist/server/modules/registry/services/template-upgrade.service.js.map +0 -1
  984. package/dist/server/modules/sessions/services/activity-tracker.service.d.ts +0 -17
  985. package/dist/server/modules/sessions/services/activity-tracker.service.js +0 -121
  986. package/dist/server/modules/sessions/services/activity-tracker.service.js.map +0 -1
  987. package/dist/server/modules/sessions/utils/template-renderer.d.ts +0 -33
  988. package/dist/server/modules/sessions/utils/template-renderer.js +0 -44
  989. package/dist/server/modules/sessions/utils/template-renderer.js.map +0 -1
  990. package/dist/server/modules/terminal/services/confirmed-delivery.helper.d.ts +0 -17
  991. package/dist/server/modules/terminal/services/confirmed-delivery.helper.js +0 -65
  992. package/dist/server/modules/terminal/services/confirmed-delivery.helper.js.map +0 -1
  993. package/dist/server/modules/terminal/services/terminal-send-coordinator.service.d.ts +0 -5
  994. package/dist/server/modules/terminal/services/terminal-send-coordinator.service.js +0 -36
  995. package/dist/server/modules/terminal/services/terminal-send-coordinator.service.js.map +0 -1
  996. package/dist/server/modules/terminal/services/tmux.service.d.ts +0 -78
  997. package/dist/server/modules/terminal/services/tmux.service.js +0 -548
  998. package/dist/server/modules/terminal/services/tmux.service.js.map +0 -1
  999. package/dist/server/templates/5-agents-dev.json +0 -1084
  1000. package/dist/server/ui/assets/ReviewsPage-DVBA6KIu.js +0 -6
  1001. package/dist/server/ui/assets/index-D6-SAeCU.css +0 -32
  1002. package/dist/server/ui/assets/index-DylwMbnX.js +0 -1032
  1003. 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 confirmed_delivery_helper_1 = require("../../terminal/services/confirmed-delivery.helper");
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("../../core/services/provider-mcp-ensure.service");
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 profile_options_1 = require("../utils/profile-options");
32
- const env_builder_1 = require("../utils/env-builder");
33
- const template_renderer_1 = require("../utils/template-renderer");
34
- const claude_config_1 = require("../utils/claude-config");
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, tmuxService, sendCoordinator, ptyService, preflightService, mcpEnsureService, sessionCoordinator, hooksConfigService, providerAdapterFactory, moduleRef) {
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.tmuxService = tmuxService;
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.moduleRef = moduleRef;
69
- this.sqlite = this.db.session?.client ?? this.db;
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.tmuxService.hasSession(session.tmuxSessionId);
67
+ const sessionExists = await this.terminalIO.sessionExists({ name: session.tmuxSessionId });
747
68
  if (sessionExists) {
748
- await this.tmuxService.destroySession(session.tmuxSessionId);
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.getEventsService().publish('session.stopped', { sessionId });
94
+ await this.eventsService.publish('session.stopped', { sessionId });
774
95
  if (session.agentId) {
775
96
  try {
776
- this.getTerminalGateway().broadcastEvent(`agent/${session.agentId}`, 'presence', {
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.tmuxService.hasSession(row.tmux_session_id);
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
- const result = await (0, confirmed_delivery_helper_1.deliverWithConfirmation)(this.tmuxService, this.sendCoordinator, {
1072
- tmuxSessionId: session.tmuxSessionId,
1073
- text,
1074
- submitKeys: ['Enter'],
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)(() => tmux_service_1.TmuxService))),
1209
- __param(3, (0, common_1.Inject)((0, common_1.forwardRef)(() => terminal_send_coordinator_service_1.TerminalSendCoordinatorService))),
1210
- __param(4, (0, common_1.Inject)((0, common_1.forwardRef)(() => pty_service_1.PtyService))),
1211
- __param(5, (0, common_1.Inject)((0, common_1.forwardRef)(() => preflight_service_1.PreflightService))),
1212
- __param(6, (0, common_1.Inject)((0, common_1.forwardRef)(() => provider_mcp_ensure_service_1.ProviderMcpEnsureService))),
1213
- __metadata("design:paramtypes", [better_sqlite3_1.BetterSQLite3Database, Object, tmux_service_1.TmuxService,
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
- core_1.ModuleRef])
514
+ events_service_1.EventsService,
515
+ terminal_session_registry_1.TerminalSessionRegistry])
1222
516
  ], SessionsService);
1223
517
  //# sourceMappingURL=sessions.service.js.map