@pellux/goodvibes-tui 0.18.10 → 0.18.12

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 (443) hide show
  1. package/CHANGELOG.md +56 -0
  2. package/README.md +1 -1
  3. package/docs/foundation-artifacts/operator-contract.json +1 -1
  4. package/package.json +2 -2
  5. package/src/core/conversation-rendering.ts +2 -2
  6. package/src/core/conversation.ts +5 -5
  7. package/src/core/orchestrator.ts +13 -11
  8. package/src/daemon/facade-composition.ts +8 -8
  9. package/src/daemon/facade.ts +8 -8
  10. package/src/daemon/types.ts +3 -3
  11. package/src/input/command-registry.ts +3 -3
  12. package/src/input/commands/session-content.ts +2 -2
  13. package/src/input/commands/session-workflow.ts +1 -1
  14. package/src/input/handler-feed.ts +1 -1
  15. package/src/input/session-picker-modal.ts +1 -1
  16. package/src/panels/builtin/agent.ts +1 -0
  17. package/src/panels/builtin/operations.ts +1 -0
  18. package/src/panels/builtin/session.ts +1 -1
  19. package/src/panels/builtin/shared.ts +2 -2
  20. package/src/panels/context-visualizer-panel.ts +4 -1
  21. package/src/panels/provider-health-domains.ts +5 -1
  22. package/src/panels/provider-health-panel.ts +5 -1
  23. package/src/panels/session-browser-panel.ts +1 -1
  24. package/src/panels/token-budget-panel.ts +6 -2
  25. package/src/plugins/loader.ts +2 -2
  26. package/src/runtime/bootstrap-command-context.ts +3 -3
  27. package/src/runtime/bootstrap-command-parts.ts +3 -3
  28. package/src/runtime/bootstrap-core.ts +2 -2
  29. package/src/runtime/bootstrap-hook-bridge.ts +1 -1
  30. package/src/runtime/bootstrap-shell.ts +1 -1
  31. package/src/runtime/bootstrap.ts +5 -4
  32. package/src/runtime/services.ts +2 -2
  33. package/src/runtime/ui-read-models-observability-security.ts +2 -2
  34. package/src/runtime/ui-read-models-observability-system.ts +1 -1
  35. package/src/runtime/ui-service-queries.ts +1 -1
  36. package/src/tools/index.ts +1 -1
  37. package/src/version.ts +1 -1
  38. package/src/acp/connection.ts +0 -447
  39. package/src/acp/index.ts +0 -7
  40. package/src/acp/manager.ts +0 -1
  41. package/src/adapters/bluebubbles/index.ts +0 -127
  42. package/src/adapters/discord/index.ts +0 -297
  43. package/src/adapters/github/index.ts +0 -73
  44. package/src/adapters/google-chat/index.ts +0 -119
  45. package/src/adapters/imessage/index.ts +0 -92
  46. package/src/adapters/index.ts +0 -15
  47. package/src/adapters/matrix/index.ts +0 -116
  48. package/src/adapters/mattermost/index.ts +0 -151
  49. package/src/adapters/msteams/index.ts +0 -180
  50. package/src/adapters/ntfy/index.ts +0 -118
  51. package/src/adapters/signal/index.ts +0 -92
  52. package/src/adapters/slack/index.ts +0 -323
  53. package/src/adapters/telegram/index.ts +0 -160
  54. package/src/adapters/types.ts +0 -97
  55. package/src/adapters/webhook/index.ts +0 -178
  56. package/src/adapters/whatsapp/index.ts +0 -135
  57. package/src/agents/message-bus-core.ts +0 -312
  58. package/src/agents/message-bus.ts +0 -2
  59. package/src/agents/orchestrator-prompts.ts +0 -351
  60. package/src/agents/orchestrator-runner.ts +0 -668
  61. package/src/agents/orchestrator.ts +0 -438
  62. package/src/agents/session.ts +0 -108
  63. package/src/agents/worktree.ts +0 -153
  64. package/src/agents/wrfc-config.ts +0 -47
  65. package/src/agents/wrfc-controller.ts +0 -747
  66. package/src/agents/wrfc-gate-runtime.ts +0 -75
  67. package/src/agents/wrfc-reporting.ts +0 -284
  68. package/src/agents/wrfc-runtime-events.ts +0 -150
  69. package/src/agents/wrfc-types.ts +0 -67
  70. package/src/automation/delivery-manager.ts +0 -368
  71. package/src/automation/index.ts +0 -72
  72. package/src/automation/manager-runtime-delivery.ts +0 -139
  73. package/src/automation/manager-runtime-events.ts +0 -131
  74. package/src/automation/manager-runtime-execution.ts +0 -511
  75. package/src/automation/manager-runtime-helpers.ts +0 -433
  76. package/src/automation/manager-runtime-job-mutations.ts +0 -175
  77. package/src/automation/manager-runtime-reconcile.ts +0 -148
  78. package/src/automation/manager-runtime-scheduling.ts +0 -189
  79. package/src/automation/manager-runtime-sync.ts +0 -54
  80. package/src/automation/manager-runtime.ts +0 -721
  81. package/src/automation/manager.ts +0 -10
  82. package/src/automation/service.ts +0 -242
  83. package/src/channels/builtin/account-actions.ts +0 -490
  84. package/src/channels/builtin/accounts.ts +0 -433
  85. package/src/channels/builtin/contracts.ts +0 -405
  86. package/src/channels/builtin/plugins.ts +0 -308
  87. package/src/channels/builtin/rendering.ts +0 -174
  88. package/src/channels/builtin/setup-schema.ts +0 -504
  89. package/src/channels/builtin/shared.ts +0 -96
  90. package/src/channels/builtin/surfaces.ts +0 -57
  91. package/src/channels/builtin/targets.ts +0 -693
  92. package/src/channels/builtin-runtime.ts +0 -443
  93. package/src/channels/delivery/shared.ts +0 -199
  94. package/src/channels/delivery/strategies-bridge.ts +0 -246
  95. package/src/channels/delivery/strategies-core.ts +0 -299
  96. package/src/channels/delivery/strategies-enterprise.ts +0 -178
  97. package/src/channels/delivery/types.ts +0 -59
  98. package/src/channels/delivery-router.ts +0 -127
  99. package/src/channels/index.ts +0 -77
  100. package/src/channels/plugin-registry.ts +0 -551
  101. package/src/channels/provider-runtime.ts +0 -330
  102. package/src/channels/reply-pipeline.ts +0 -522
  103. package/src/channels/route-manager.ts +0 -340
  104. package/src/channels/surface-registry.ts +0 -186
  105. package/src/config/helper-model.ts +0 -1
  106. package/src/config/manager.ts +0 -8
  107. package/src/config/subscription-auth.ts +0 -31
  108. package/src/config/tool-llm.ts +0 -110
  109. package/src/control-plane/approval-broker.ts +0 -351
  110. package/src/control-plane/gateway.ts +0 -1
  111. package/src/control-plane/index.ts +0 -54
  112. package/src/control-plane/media-contract-schemas.ts +0 -1
  113. package/src/control-plane/method-catalog-admin.ts +0 -1
  114. package/src/control-plane/method-catalog-channels.ts +0 -1
  115. package/src/control-plane/method-catalog-control-automation.ts +0 -1
  116. package/src/control-plane/method-catalog-control-core.ts +0 -1
  117. package/src/control-plane/method-catalog-control.ts +0 -1
  118. package/src/control-plane/method-catalog-events.ts +0 -1
  119. package/src/control-plane/method-catalog-knowledge.ts +0 -1
  120. package/src/control-plane/method-catalog-media.ts +0 -1
  121. package/src/control-plane/method-catalog-runtime.ts +0 -1
  122. package/src/control-plane/method-catalog-shared.ts +0 -1
  123. package/src/control-plane/method-catalog.ts +0 -1
  124. package/src/control-plane/operator-contract-schemas-admin.ts +0 -1
  125. package/src/control-plane/operator-contract-schemas-channels.ts +0 -1
  126. package/src/control-plane/operator-contract-schemas-control.ts +0 -1
  127. package/src/control-plane/operator-contract-schemas-domains.ts +0 -1
  128. package/src/control-plane/operator-contract-schemas-knowledge.ts +0 -1
  129. package/src/control-plane/operator-contract-schemas-media.ts +0 -1
  130. package/src/control-plane/operator-contract-schemas-permissions.ts +0 -1
  131. package/src/control-plane/operator-contract-schemas-remote.ts +0 -1
  132. package/src/control-plane/operator-contract-schemas-runtime.ts +0 -1
  133. package/src/control-plane/operator-contract-schemas-shared.ts +0 -1
  134. package/src/control-plane/operator-contract-schemas-telemetry.ts +0 -1
  135. package/src/control-plane/operator-contract-schemas.ts +0 -1
  136. package/src/control-plane/operator-contract.ts +0 -165
  137. package/src/control-plane/session-broker.ts +0 -780
  138. package/src/core/compaction-sections.ts +0 -492
  139. package/src/core/compaction-types.ts +0 -147
  140. package/src/core/context-compaction.ts +0 -542
  141. package/src/core/conversation-compaction.ts +0 -68
  142. package/src/core/conversation-diff.ts +0 -55
  143. package/src/core/conversation-utils.ts +0 -72
  144. package/src/core/event-replay.ts +0 -287
  145. package/src/core/orchestrator-context-runtime.ts +0 -407
  146. package/src/core/orchestrator-follow-up-runtime.ts +0 -134
  147. package/src/core/orchestrator-runtime.ts +0 -132
  148. package/src/core/orchestrator-tool-runtime.ts +0 -468
  149. package/src/core/orchestrator-turn-helpers.ts +0 -355
  150. package/src/core/orchestrator-turn-loop.ts +0 -443
  151. package/src/core/plan-command-handler.ts +0 -169
  152. package/src/core/transcript-events/classify.ts +0 -95
  153. package/src/core/transcript-events/index.ts +0 -15
  154. package/src/daemon/control-plane.ts +0 -522
  155. package/src/daemon/helpers.ts +0 -74
  156. package/src/daemon/http/router-route-contexts.ts +0 -370
  157. package/src/daemon/http/router.ts +0 -531
  158. package/src/daemon/http-listener.ts +0 -301
  159. package/src/daemon/index.ts +0 -1
  160. package/src/daemon/server.ts +0 -1
  161. package/src/daemon/service-manager.ts +0 -413
  162. package/src/daemon/surface-actions.ts +0 -183
  163. package/src/daemon/surface-delivery.ts +0 -530
  164. package/src/daemon/transport-events.ts +0 -110
  165. package/src/export/markdown.ts +0 -213
  166. package/src/export/session-export.ts +0 -1
  167. package/src/git/index.ts +0 -1
  168. package/src/git/service.ts +0 -414
  169. package/src/hooks/chain-engine.ts +0 -414
  170. package/src/hooks/dispatcher.ts +0 -414
  171. package/src/hooks/hook-api.ts +0 -170
  172. package/src/hooks/index.ts +0 -48
  173. package/src/hooks/runners/agent.ts +0 -93
  174. package/src/hooks/runners/prompt.ts +0 -69
  175. package/src/hooks/workbench.ts +0 -360
  176. package/src/integrations/index.ts +0 -42
  177. package/src/integrations/notifier.ts +0 -206
  178. package/src/integrations/webhooks.ts +0 -1
  179. package/src/knowledge/consolidation.ts +0 -346
  180. package/src/knowledge/graphql.ts +0 -324
  181. package/src/knowledge/index.ts +0 -60
  182. package/src/knowledge/ingest-compile.ts +0 -386
  183. package/src/knowledge/ingest-context.ts +0 -18
  184. package/src/knowledge/ingest-inputs.ts +0 -387
  185. package/src/knowledge/ingest.ts +0 -1
  186. package/src/knowledge/internal.ts +0 -257
  187. package/src/knowledge/knowledge-api.ts +0 -432
  188. package/src/knowledge/lint.ts +0 -121
  189. package/src/knowledge/memory-sync.ts +0 -62
  190. package/src/knowledge/packet.ts +0 -370
  191. package/src/knowledge/scheduling.ts +0 -283
  192. package/src/knowledge/service.ts +0 -715
  193. package/src/mcp/client.ts +0 -383
  194. package/src/mcp/index.ts +0 -12
  195. package/src/mcp/mcp-api.ts +0 -90
  196. package/src/mcp/registry.ts +0 -1
  197. package/src/media/builtin-image-understanding.ts +0 -303
  198. package/src/media/builtin-providers.ts +0 -26
  199. package/src/media/index.ts +0 -18
  200. package/src/multimodal/index.ts +0 -13
  201. package/src/multimodal/service.ts +0 -492
  202. package/src/permissions/briefs/build.ts +0 -88
  203. package/src/permissions/manager.ts +0 -1
  204. package/src/plugins/api.ts +0 -383
  205. package/src/plugins/manager.ts +0 -481
  206. package/src/profiles/shape.ts +0 -58
  207. package/src/providers/amazon-bedrock-mantle.ts +0 -50
  208. package/src/providers/amazon-bedrock.ts +0 -61
  209. package/src/providers/anthropic-compat.ts +0 -373
  210. package/src/providers/anthropic-sdk-provider.ts +0 -230
  211. package/src/providers/anthropic-vertex.ts +0 -59
  212. package/src/providers/anthropic.ts +0 -469
  213. package/src/providers/auto-register.ts +0 -417
  214. package/src/providers/builtin-catalog.ts +0 -326
  215. package/src/providers/builtin-registry.ts +0 -575
  216. package/src/providers/cache-planner.ts +0 -258
  217. package/src/providers/capabilities.ts +0 -1
  218. package/src/providers/custom-loader.ts +0 -425
  219. package/src/providers/discovered-compat.ts +0 -7
  220. package/src/providers/discovered-factory.ts +0 -61
  221. package/src/providers/discovered-traits.ts +0 -138
  222. package/src/providers/gemini.ts +0 -462
  223. package/src/providers/github-copilot.ts +0 -254
  224. package/src/providers/index.ts +0 -1
  225. package/src/providers/interface.ts +0 -185
  226. package/src/providers/llama-cpp.ts +0 -402
  227. package/src/providers/lm-studio-helpers.ts +0 -367
  228. package/src/providers/lm-studio.ts +0 -484
  229. package/src/providers/model-catalog-cache.ts +0 -221
  230. package/src/providers/model-catalog-notifications.ts +0 -97
  231. package/src/providers/model-catalog-synthetic.ts +0 -202
  232. package/src/providers/model-catalog.ts +0 -211
  233. package/src/providers/model-limits.ts +0 -1
  234. package/src/providers/ollama.ts +0 -469
  235. package/src/providers/openai-codex.ts +0 -472
  236. package/src/providers/openai-compat.ts +0 -615
  237. package/src/providers/openai.ts +0 -231
  238. package/src/providers/optimizer.ts +0 -1
  239. package/src/providers/provider-api.ts +0 -1
  240. package/src/providers/registry-helpers.ts +0 -34
  241. package/src/providers/registry-models.ts +0 -77
  242. package/src/providers/registry-types.ts +0 -67
  243. package/src/providers/registry.ts +0 -1
  244. package/src/providers/runtime-metadata.ts +0 -149
  245. package/src/providers/runtime-snapshot.ts +0 -130
  246. package/src/providers/synthetic.ts +0 -561
  247. package/src/providers/tier-prompts.ts +0 -84
  248. package/src/providers/tool-formats.ts +0 -414
  249. package/src/runtime/auth/inspection.ts +0 -125
  250. package/src/runtime/bootstrap-background.ts +0 -157
  251. package/src/runtime/bootstrap-helpers.ts +0 -88
  252. package/src/runtime/bootstrap-runtime-events.ts +0 -254
  253. package/src/runtime/bootstrap-services.ts +0 -197
  254. package/src/runtime/compaction/index.ts +0 -1
  255. package/src/runtime/compaction/lifecycle.ts +0 -1
  256. package/src/runtime/compaction/manager.ts +0 -474
  257. package/src/runtime/compaction/quality-score.ts +0 -1
  258. package/src/runtime/compaction/resume-repair.ts +0 -1
  259. package/src/runtime/compaction/strategies/autocompact.ts +0 -1
  260. package/src/runtime/compaction/strategies/boundary-commit.ts +0 -1
  261. package/src/runtime/compaction/strategies/collapse.ts +0 -1
  262. package/src/runtime/compaction/strategies/index.ts +0 -1
  263. package/src/runtime/compaction/strategies/microcompact.ts +0 -1
  264. package/src/runtime/compaction/strategies/reactive.ts +0 -1
  265. package/src/runtime/compaction/types.ts +0 -1
  266. package/src/runtime/ecosystem/recommendations.ts +0 -117
  267. package/src/runtime/emitters/agents.ts +0 -96
  268. package/src/runtime/emitters/automation.ts +0 -112
  269. package/src/runtime/emitters/communication.ts +0 -53
  270. package/src/runtime/emitters/compaction.ts +0 -161
  271. package/src/runtime/emitters/control-plane.ts +0 -65
  272. package/src/runtime/emitters/deliveries.ts +0 -65
  273. package/src/runtime/emitters/forensics.ts +0 -17
  274. package/src/runtime/emitters/index.ts +0 -59
  275. package/src/runtime/emitters/knowledge.ts +0 -129
  276. package/src/runtime/emitters/mcp.ts +0 -95
  277. package/src/runtime/emitters/ops.ts +0 -163
  278. package/src/runtime/emitters/orchestration.ts +0 -87
  279. package/src/runtime/emitters/permissions.ts +0 -98
  280. package/src/runtime/emitters/planner.ts +0 -23
  281. package/src/runtime/emitters/plugins.ts +0 -78
  282. package/src/runtime/emitters/providers.ts +0 -30
  283. package/src/runtime/emitters/routes.ts +0 -57
  284. package/src/runtime/emitters/security.ts +0 -53
  285. package/src/runtime/emitters/session.ts +0 -93
  286. package/src/runtime/emitters/surfaces.ts +0 -57
  287. package/src/runtime/emitters/tasks.ts +0 -69
  288. package/src/runtime/emitters/tools.ts +0 -140
  289. package/src/runtime/emitters/transport.ts +0 -78
  290. package/src/runtime/emitters/turn.ts +0 -155
  291. package/src/runtime/emitters/ui.ts +0 -57
  292. package/src/runtime/emitters/watchers.ts +0 -57
  293. package/src/runtime/emitters/workflows.ts +0 -79
  294. package/src/runtime/eval/index.ts +0 -48
  295. package/src/runtime/eval/runner.ts +0 -163
  296. package/src/runtime/eval/suites.ts +0 -264
  297. package/src/runtime/events/domain-map.ts +0 -148
  298. package/src/runtime/events/index.ts +0 -1
  299. package/src/runtime/events/turn.ts +0 -1
  300. package/src/runtime/events/workflows.ts +0 -1
  301. package/src/runtime/forensics/collector.ts +0 -693
  302. package/src/runtime/forensics/index.ts +0 -23
  303. package/src/runtime/foundation-clients.ts +0 -78
  304. package/src/runtime/foundation-services.ts +0 -96
  305. package/src/runtime/guidance.ts +0 -183
  306. package/src/runtime/health/effect-handlers.ts +0 -189
  307. package/src/runtime/health/index.ts +0 -70
  308. package/src/runtime/health/wiring.ts +0 -115
  309. package/src/runtime/integration/helpers.ts +0 -640
  310. package/src/runtime/lifecycle.ts +0 -107
  311. package/src/runtime/mcp/index.ts +0 -68
  312. package/src/runtime/mcp/manager.ts +0 -513
  313. package/src/runtime/network/inbound.ts +0 -131
  314. package/src/runtime/network/index.ts +0 -30
  315. package/src/runtime/network/outbound.ts +0 -292
  316. package/src/runtime/network/shared.ts +0 -82
  317. package/src/runtime/operator-client.ts +0 -235
  318. package/src/runtime/ops/control-plane.ts +0 -363
  319. package/src/runtime/ops/index.ts +0 -122
  320. package/src/runtime/ops/playbooks/index.ts +0 -10
  321. package/src/runtime/ops/playbooks/session-unrecoverable.ts +0 -196
  322. package/src/runtime/ops/playbooks/stuck-turn.ts +0 -197
  323. package/src/runtime/ops/runtime-context.ts +0 -100
  324. package/src/runtime/ops-api.ts +0 -27
  325. package/src/runtime/orchestration/spawn-policy.ts +0 -83
  326. package/src/runtime/peer-client.ts +0 -404
  327. package/src/runtime/perf/index.ts +0 -57
  328. package/src/runtime/perf/slo-collector.ts +0 -375
  329. package/src/runtime/permissions/index.ts +0 -190
  330. package/src/runtime/permissions/policy-runtime.ts +0 -1
  331. package/src/runtime/permissions/preflight.ts +0 -101
  332. package/src/runtime/permissions/rule-suggestions.ts +0 -36
  333. package/src/runtime/plugins/hot-reload.ts +0 -221
  334. package/src/runtime/plugins/index.ts +0 -84
  335. package/src/runtime/plugins/lifecycle.ts +0 -95
  336. package/src/runtime/plugins/manager.ts +0 -474
  337. package/src/runtime/plugins/manifest.ts +0 -167
  338. package/src/runtime/plugins/quarantine.ts +0 -202
  339. package/src/runtime/plugins/trust.ts +0 -291
  340. package/src/runtime/plugins/types.ts +0 -205
  341. package/src/runtime/provider-accounts/registry.ts +0 -326
  342. package/src/runtime/remote/distributed-runtime-contract-schemas.ts +0 -386
  343. package/src/runtime/remote/index.ts +0 -488
  344. package/src/runtime/remote/runner-registry.ts +0 -438
  345. package/src/runtime/remote/supervisor.ts +0 -70
  346. package/src/runtime/runtime-hook-api.ts +0 -5
  347. package/src/runtime/runtime-knowledge-api.ts +0 -14
  348. package/src/runtime/runtime-mcp-api.ts +0 -5
  349. package/src/runtime/runtime-ops-api.ts +0 -86
  350. package/src/runtime/runtime-provider-api.ts +0 -18
  351. package/src/runtime/session-maintenance.ts +0 -188
  352. package/src/runtime/session-persistence.ts +0 -288
  353. package/src/runtime/session-return-context.ts +0 -195
  354. package/src/runtime/settings/control-plane-store.ts +0 -258
  355. package/src/runtime/settings/control-plane.ts +0 -599
  356. package/src/runtime/shell-command-extensions.ts +0 -54
  357. package/src/runtime/shell-command-ops.ts +0 -207
  358. package/src/runtime/shell-command-platform.ts +0 -47
  359. package/src/runtime/shell-command-services.ts +0 -143
  360. package/src/runtime/shell-command-workspace.ts +0 -31
  361. package/src/runtime/tasks/adapters/acp-adapter.ts +0 -211
  362. package/src/runtime/tasks/adapters/agent-adapter.ts +0 -208
  363. package/src/runtime/tasks/adapters/index.ts +0 -16
  364. package/src/runtime/tasks/adapters/process-adapter.ts +0 -214
  365. package/src/runtime/tasks/adapters/scheduler-adapter.ts +0 -193
  366. package/src/runtime/tasks/index.ts +0 -68
  367. package/src/runtime/tasks/manager.ts +0 -415
  368. package/src/runtime/telemetry/api-helpers.ts +0 -517
  369. package/src/runtime/telemetry/api.ts +0 -768
  370. package/src/runtime/telemetry/index.ts +0 -178
  371. package/src/runtime/telemetry/instrumentation/domain-bridge-agent-session.ts +0 -440
  372. package/src/runtime/telemetry/instrumentation/domain-bridge-plugin-mcp.ts +0 -200
  373. package/src/runtime/telemetry/instrumentation/domain-bridge-shared.ts +0 -18
  374. package/src/runtime/telemetry/instrumentation/domain-bridge-transport-task.ts +0 -204
  375. package/src/runtime/telemetry/instrumentation/domain-bridge.ts +0 -125
  376. package/src/runtime/telemetry/instrumentation/index.ts +0 -67
  377. package/src/runtime/tools/context.ts +0 -114
  378. package/src/runtime/tools/index.ts +0 -46
  379. package/src/runtime/tools/phased-executor.ts +0 -448
  380. package/src/runtime/tools/phases/budget.ts +0 -130
  381. package/src/runtime/tools/phases/execute.ts +0 -69
  382. package/src/runtime/tools/phases/index.ts +0 -13
  383. package/src/runtime/tools/phases/map-output.ts +0 -98
  384. package/src/runtime/tools/phases/permission.ts +0 -133
  385. package/src/runtime/tools/phases/posthook.ts +0 -57
  386. package/src/runtime/tools/phases/prehook.ts +0 -68
  387. package/src/runtime/tools/phases/validate.ts +0 -53
  388. package/src/runtime/transports/direct.ts +0 -73
  389. package/src/runtime/transports/http-helpers.ts +0 -218
  390. package/src/runtime/transports/http-types.ts +0 -364
  391. package/src/runtime/transports/http.ts +0 -629
  392. package/src/runtime/transports/realtime.ts +0 -50
  393. package/src/runtime/transports/remote-events.ts +0 -16
  394. package/src/runtime/transports/shared.ts +0 -39
  395. package/src/runtime/transports/ui-runtime-events.ts +0 -35
  396. package/src/runtime/ui-events.ts +0 -46
  397. package/src/runtime/worktree/registry.ts +0 -252
  398. package/src/sessions/manager.ts +0 -14
  399. package/src/state/file-watcher.ts +0 -294
  400. package/src/state/index.ts +0 -56
  401. package/src/state/knowledge-injection.ts +0 -214
  402. package/src/state/memory-embedding-http.ts +0 -642
  403. package/src/state/memory-embeddings.ts +0 -312
  404. package/src/state/memory-ingest.ts +0 -132
  405. package/src/state/memory-registry.ts +0 -111
  406. package/src/state/memory-store-helpers.ts +0 -160
  407. package/src/state/memory-store.ts +0 -728
  408. package/src/state/memory-vector-store.ts +0 -418
  409. package/src/templates/manager.ts +0 -187
  410. package/src/tools/agent/index.ts +0 -610
  411. package/src/tools/agent/manager.ts +0 -476
  412. package/src/tools/analyze/git-modes.ts +0 -380
  413. package/src/tools/analyze/index.ts +0 -128
  414. package/src/tools/channel/agent-tools.ts +0 -16
  415. package/src/tools/channel/index.ts +0 -268
  416. package/src/tools/control/index.ts +0 -90
  417. package/src/tools/edit/core.ts +0 -619
  418. package/src/tools/edit/index.ts +0 -4
  419. package/src/tools/edit/phased.ts +0 -33
  420. package/src/tools/fetch/index.ts +0 -3
  421. package/src/tools/fetch/phased.ts +0 -34
  422. package/src/tools/fetch/runtime.ts +0 -499
  423. package/src/tools/mcp/index.ts +0 -190
  424. package/src/tools/remote-trigger/index.ts +0 -130
  425. package/src/tools/shared/auto-heal.ts +0 -282
  426. package/src/tools/state/index.ts +0 -688
  427. package/src/tools/web-search/index.ts +0 -38
  428. package/src/tools/write/index.ts +0 -604
  429. package/src/tools/write/phased.ts +0 -41
  430. package/src/types/generated/foundation-client-types.ts +0 -22
  431. package/src/watchers/index.ts +0 -11
  432. package/src/watchers/registry.ts +0 -517
  433. package/src/web-search/index.ts +0 -26
  434. package/src/web-search/provider-registry.ts +0 -64
  435. package/src/web-search/providers/brave.ts +0 -100
  436. package/src/web-search/providers/duckduckgo.ts +0 -270
  437. package/src/web-search/providers/exa.ts +0 -77
  438. package/src/web-search/providers/firecrawl.ts +0 -90
  439. package/src/web-search/providers/perplexity.ts +0 -86
  440. package/src/web-search/providers/searxng.ts +0 -88
  441. package/src/web-search/providers/shared.ts +0 -249
  442. package/src/web-search/providers/tavily.ts +0 -90
  443. package/src/web-search/service.ts +0 -142
@@ -1,107 +0,0 @@
1
- /**
2
- * Lifecycle management for the goodvibes-tui runtime.
3
- *
4
- * Handles ordered teardown: persist session, fire lifecycle hooks,
5
- * stop background managers. Terminal teardown remains in main.ts.
6
- */
7
- import type { HookDispatcher } from '@pellux/goodvibes-sdk/platform/hooks/index';
8
- import type { HookPhase, HookCategory, HookEventPath } from '@pellux/goodvibes-sdk/platform/hooks/types';
9
- import type { ScheduleManager } from '@pellux/goodvibes-sdk/platform/tools/workflow/index';
10
- import type { ProviderRegistry } from '@pellux/goodvibes-sdk/platform/providers/registry';
11
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
12
- export { saveSession } from '@pellux/goodvibes-sdk/platform/runtime/session-persistence';
13
- import { saveSession, type SessionPersistenceOptions, type SessionSnapshot } from '@pellux/goodvibes-sdk/platform/runtime/session-persistence';
14
- import type { CrossSessionTaskRegistry } from '@pellux/goodvibes-sdk/platform/sessions/orchestration/index';
15
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
16
-
17
- // ── Startup lifecycle ────────────────────────────────────────────────────────
18
-
19
- /**
20
- * Fire the session:start lifecycle hook.
21
- * Non-fatal: errors are logged and swallowed.
22
- */
23
- export function fireSessionStart(
24
- sessionId: string,
25
- hookDispatcher: Pick<HookDispatcher, 'fire'> | null,
26
- ): void {
27
- if (!hookDispatcher) return;
28
- try {
29
- hookDispatcher.fire({
30
- path: 'Lifecycle:session:start' as HookEventPath,
31
- phase: 'Lifecycle' as HookPhase,
32
- category: 'session' as HookCategory,
33
- specific: 'start',
34
- sessionId,
35
- timestamp: Date.now(),
36
- payload: { sessionId },
37
- }).catch((err: unknown) => {
38
- logger.debug('fireSessionStart hook error (non-fatal)', { error: summarizeError(err) });
39
- });
40
- } catch (err) {
41
- logger.debug('fireSessionStart sync error (non-fatal)', { error: summarizeError(err) });
42
- }
43
- }
44
-
45
- // ── Shutdown lifecycle ───────────────────────────────────────────────────────
46
-
47
- /**
48
- * Ordered logical shutdown of all background runtime subsystems.
49
- *
50
- * Sequence:
51
- * 1. Persist conversation to sessions store
52
- * 2. Fire session:end and session:save lifecycle hooks
53
- * 3. Destroy ScheduleManager (cancels pending scheduled tasks)
54
- * 4. Stop provider registry file-watcher
55
- *
56
- * This function does NOT touch the terminal (alt-screen, raw mode, etc.) —
57
- * that remains the responsibility of main.ts.
58
- *
59
- * @param sessionId - Active session identifier.
60
- * @param sessionData - Latest conversation to persist.
61
- * @param model - Active model identifier.
62
- * @param provider - Active provider identifier.
63
- * @param title - Conversation title (may be empty string).
64
- */
65
- export async function shutdownRuntime(
66
- sessionId: string,
67
- sessionData: SessionSnapshot,
68
- model: string,
69
- provider: string,
70
- title = '',
71
- scheduleManager?: ScheduleManager | null,
72
- hookDispatcher?: Pick<HookDispatcher, 'fire'> | null,
73
- providerRegistry?: Pick<ProviderRegistry, 'stopWatching'> | null,
74
- sessionOrchestration?: Pick<CrossSessionTaskRegistry, 'dispose'> | null,
75
- persistenceOptions?: SessionPersistenceOptions,
76
- ): Promise<void> {
77
- // Step 1: persist conversation
78
- saveSession(sessionId, sessionData, model, provider, title, persistenceOptions);
79
-
80
- // Step 2: lifecycle hooks (fire-and-forget, best-effort before process exit)
81
- const fireHook = (specific: string): void => {
82
- if (!hookDispatcher) return;
83
- try {
84
- hookDispatcher.fire({
85
- path: `Lifecycle:session:${specific}` as HookEventPath,
86
- phase: 'Lifecycle' as HookPhase,
87
- category: 'session' as HookCategory,
88
- specific,
89
- sessionId,
90
- timestamp: Date.now(),
91
- payload: { sessionId },
92
- }).catch((err: unknown) => { logger.debug('shutdownRuntime hook fire error (non-fatal)', { specific, error: summarizeError(err) }); });
93
- } catch (err) { logger.debug('shutdownRuntime hook sync error (non-fatal)', { specific, error: summarizeError(err) }); }
94
- };
95
-
96
- fireHook('end');
97
- fireHook('save');
98
-
99
- // Step 3: stop ScheduleManager
100
- try { scheduleManager?.destroy(); } catch (err) { logger.debug('ScheduleManager.destroy failed (non-fatal)', { error: summarizeError(err) }); }
101
-
102
- // Step 4: stop provider registry watcher
103
- try { providerRegistry?.stopWatching(); } catch (err) { logger.debug('providerRegistry.stopWatching failed (non-fatal)', { error: summarizeError(err) }); }
104
-
105
- // Step 5: dispose cross-session orchestration registry if it is app-owned in this runtime
106
- try { sessionOrchestration?.dispose(); } catch (err) { logger.debug('sessionOrchestration.dispose failed (non-fatal)', { error: summarizeError(err) }); }
107
- }
@@ -1,68 +0,0 @@
1
- /**
2
- * src/runtime/mcp — MCP lifecycle barrel.
3
- *
4
- * Gated by the `mcp-lifecycle` feature flag.
5
- *
6
- * Public API:
7
- * - `createMcpLifecycleManager()` — factory function
8
- * - All types from types.ts
9
- * - State machine helpers from lifecycle.ts
10
- * - Permission manager from permissions.ts
11
- * - Schema freshness tracker from schema-freshness.ts
12
- * - Manager from manager.ts
13
- */
14
-
15
- export { McpLifecycleManager, type McpEventHandler, type McpLifecycleManagerOptions } from '@pellux/goodvibes-sdk/platform/runtime/mcp/manager';
16
- export { McpPermissionManager, buildMcpAttackPathReview } from '@pellux/goodvibes-sdk/platform/runtime/mcp/permissions';
17
- export { McpSchemaFreshnessTracker } from '@pellux/goodvibes-sdk/platform/runtime/mcp/schema-freshness';
18
- export {
19
- canTransition,
20
- reachableFrom,
21
- applyTransition,
22
- isOperational,
23
- isTerminal,
24
- type TransitionResult,
25
- } from '@pellux/goodvibes-sdk/platform/runtime/mcp/lifecycle';
26
- export type {
27
- McpServerState,
28
- SchemaFreshness,
29
- McpSchemaRecord,
30
- QuarantineReason,
31
- QuarantineRecord,
32
- McpTrustLevel,
33
- McpTrustMode,
34
- McpServerRole,
35
- McpCapabilityClass,
36
- McpCoherenceVerdict,
37
- McpRiskLevel,
38
- McpPermission,
39
- McpTrustProfile,
40
- McpCoherenceAssessment,
41
- McpDecisionRecord,
42
- McpSecuritySnapshot,
43
- McpAttackPathFindingKind,
44
- McpAttackPathFinding,
45
- McpAttackPathReview,
46
- McpToolPermission,
47
- McpServerPermissions,
48
- McpServerEntry,
49
- McpReconnectConfig,
50
- } from '@pellux/goodvibes-sdk/platform/runtime/mcp/types';
51
- export { DEFAULT_RECONNECT_CONFIG } from '@pellux/goodvibes-sdk/platform/runtime/mcp/types';
52
-
53
- import { McpLifecycleManager } from '@pellux/goodvibes-sdk/platform/runtime/mcp/manager';
54
- import type { McpLifecycleManagerOptions } from '@pellux/goodvibes-sdk/platform/runtime/mcp/manager';
55
-
56
- /**
57
- * Factory function for creating a `McpLifecycleManager`.
58
- *
59
- * Check the `mcp-lifecycle` feature flag before calling this — when the
60
- * flag is disabled, the caller should use the standard MCP registry path.
61
- *
62
- * @param options - Optional configuration overrides
63
- */
64
- export function createMcpLifecycleManager(
65
- options?: McpLifecycleManagerOptions,
66
- ): McpLifecycleManager {
67
- return new McpLifecycleManager(options);
68
- }
@@ -1,513 +0,0 @@
1
- /**
2
- * McpLifecycleManager — drives the MCP server state machine.
3
- *
4
- * Gated by the `mcp-lifecycle` feature flag. When the flag is disabled
5
- * callers should use the standard MCP registry path instead.
6
- *
7
- * Responsibilities:
8
- * - Track per-server McpServerEntry state
9
- * - Orchestrate McpClient connect/disconnect
10
- * - Drive lifecycle state transitions via lifecycle.ts
11
- * - Emit McpEvent on every transition
12
- * - Schedule reconnects with exponential back-off
13
- * - Delegate permission checks to McpPermissionManager
14
- * - Delegate schema freshness to McpSchemaFreshnessTracker
15
- */
16
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
17
- import { McpClient } from '@pellux/goodvibes-sdk/platform/mcp/client';
18
- import type { McpServerConfig } from '@pellux/goodvibes-sdk/platform/mcp/config';
19
- import type { McpEvent } from '@pellux/goodvibes-sdk/platform/runtime/events/mcp';
20
- import {
21
- applyTransition,
22
- isOperational,
23
- } from '@pellux/goodvibes-sdk/platform/runtime/mcp/lifecycle';
24
- import { McpPermissionManager } from '@pellux/goodvibes-sdk/platform/runtime/mcp/permissions';
25
- import { McpSchemaFreshnessTracker } from '@pellux/goodvibes-sdk/platform/runtime/mcp/schema-freshness';
26
- import type {
27
- McpServerState,
28
- McpServerEntry,
29
- McpReconnectConfig,
30
- McpTrustLevel,
31
- McpPermission,
32
- SchemaFreshness,
33
- QuarantineReason,
34
- McpTrustMode,
35
- McpServerRole,
36
- McpServerPermissions,
37
- } from '@pellux/goodvibes-sdk/platform/runtime/mcp/types';
38
- import { DEFAULT_RECONNECT_CONFIG } from '@pellux/goodvibes-sdk/platform/runtime/mcp/types';
39
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
40
-
41
- /** Callback type for state-change notifications. */
42
- export type McpEventHandler = (event: McpEvent) => void;
43
-
44
- // ── Factory ───────────────────────────────────────────────────────────────────
45
-
46
- /** Options for constructing a McpLifecycleManager. */
47
- export interface McpLifecycleManagerOptions {
48
- /** Reconnect back-off configuration. Defaults to DEFAULT_RECONNECT_CONFIG. */
49
- reconnect?: Partial<McpReconnectConfig>;
50
- /** Schema freshness TTL in ms. Defaults to 5 minutes. */
51
- schemaTtlMs?: number;
52
- }
53
-
54
- // ── Manager ───────────────────────────────────────────────────────────────────
55
-
56
- /**
57
- * McpLifecycleManager — manages the full lifecycle of all configured MCP servers.
58
- *
59
- * Usage:
60
- * ```ts
61
- * const mgr = createMcpLifecycleManager();
62
- * mgr.onEvent((e) => store.dispatch(e));
63
- * await mgr.startAll(configs);
64
- * // ...
65
- * await mgr.stopAll();
66
- * ```
67
- */
68
- export class McpLifecycleManager {
69
- private readonly servers = new Map<string, McpServerEntry>();
70
- private readonly clients = new Map<string, McpClient>();
71
- private readonly permissions: McpPermissionManager;
72
- private readonly freshness: McpSchemaFreshnessTracker;
73
- private readonly reconnectConfig: McpReconnectConfig;
74
- private readonly eventHandlers: McpEventHandler[] = [];
75
- private readonly reconnectTimers = new Map<string, ReturnType<typeof setTimeout>>();
76
-
77
- constructor(options: McpLifecycleManagerOptions = {}) {
78
- this.reconnectConfig = {
79
- ...DEFAULT_RECONNECT_CONFIG,
80
- ...options.reconnect,
81
- };
82
- this.permissions = new McpPermissionManager();
83
- this.freshness = new McpSchemaFreshnessTracker(options.schemaTtlMs);
84
- }
85
-
86
- // ── Event subscription ────────────────────────────────────────────────────
87
-
88
- /**
89
- * Register an event handler called on every lifecycle transition.
90
- *
91
- * @param handler - Callback receiving McpEvent on each transition
92
- */
93
- onEvent(handler: McpEventHandler): void {
94
- this.eventHandlers.push(handler);
95
- }
96
-
97
- // ── Server management ─────────────────────────────────────────────────────
98
-
99
- /**
100
- * Register and start all provided server configs.
101
- *
102
- * Connection errors on individual servers are logged but do not abort the
103
- * overall startup.
104
- *
105
- * @param configs - Array of server configurations to start
106
- */
107
- async startAll(configs: McpServerConfig[]): Promise<void> {
108
- await Promise.allSettled(configs.map((c) => this._startServer(c)));
109
- }
110
-
111
- /**
112
- * Register and start a single server.
113
- *
114
- * @param config - Server configuration
115
- */
116
- async startServer(config: McpServerConfig): Promise<void> {
117
- await this._startServer(config);
118
- }
119
-
120
- /**
121
- * Disconnect all servers and cancel pending reconnect timers.
122
- */
123
- async stopAll(): Promise<void> {
124
- const names = Array.from(this.servers.keys());
125
- await Promise.allSettled(names.map((n) => this._stopServer(n, 'stopAll called')));
126
- }
127
-
128
- /**
129
- * Disconnect a single server by name.
130
- *
131
- * @param serverName - Server identifier
132
- * @param reason - Optional reason for disconnection
133
- */
134
- async stopServer(serverName: string, reason?: string): Promise<void> {
135
- await this._stopServer(serverName, reason);
136
- }
137
-
138
- // ── Permission delegation ─────────────────────────────────────────────────
139
-
140
- /**
141
- * Check whether a tool call is permitted for the given server.
142
- *
143
- * Quarantined schemas unconditionally block execution — the freshness check
144
- * runs before the permission check so a quarantined schema cannot be bypassed
145
- * by a permissive trust level.
146
- *
147
- * @param serverName - Server identifier
148
- * @param toolName - Tool name on the server (not qualified)
149
- */
150
- isToolAllowed(serverName: string, toolName: string): McpPermission {
151
- if (this.freshness.isQuarantined(serverName)) {
152
- const record = this.freshness.getRecord(serverName);
153
- const detail = record?.quarantine?.detail ?? 'schema is quarantined';
154
- return {
155
- allowed: false,
156
- reason: `Schema quarantined (${record?.quarantine?.reason ?? 'unknown'}): ${detail}. Refresh schema or request operator approval to proceed.`,
157
- };
158
- }
159
- return this.permissions.isToolAllowed(serverName, toolName);
160
- }
161
-
162
- /**
163
- * Update the trust level for a server.
164
- *
165
- * @param serverName - Server identifier
166
- * @param level - New trust level
167
- */
168
- setTrustLevel(serverName: string, level: McpTrustLevel): void {
169
- this.permissions.setTrustLevel(serverName, level);
170
- }
171
-
172
- setTrustMode(serverName: string, mode: McpTrustMode): void {
173
- this.permissions.setTrustMode(serverName, mode);
174
- }
175
-
176
- setServerRole(serverName: string, role: McpServerRole): void {
177
- this.permissions.setServerRole(serverName, role);
178
- }
179
-
180
- /**
181
- * Explicitly allow a tool for a server.
182
- *
183
- * @param serverName - Server identifier
184
- * @param toolName - Tool name
185
- * @param note - Optional note
186
- */
187
- allowTool(serverName: string, toolName: string, note?: string): void {
188
- this.permissions.allowTool(serverName, toolName, note);
189
- }
190
-
191
- /**
192
- * Explicitly deny a tool for a server.
193
- *
194
- * @param serverName - Server identifier
195
- * @param toolName - Tool name
196
- * @param note - Optional note
197
- */
198
- denyTool(serverName: string, toolName: string, note?: string): void {
199
- this.permissions.denyTool(serverName, toolName, note);
200
- }
201
-
202
- getServerPermissions(serverName: string): McpServerPermissions | null {
203
- return this.permissions.getServerPermissions(serverName);
204
- }
205
-
206
- listTrustProfiles(): Array<McpServerPermissions['profile']> {
207
- return this.permissions.listProfiles();
208
- }
209
-
210
- // ── Schema freshness ──────────────────────────────────────────────────────
211
-
212
- /**
213
- * Return the schema freshness for a server.
214
- *
215
- * @param serverName - Server identifier
216
- */
217
- getSchemaFreshness(serverName: string): SchemaFreshness {
218
- return this.freshness.getFreshness(serverName);
219
- }
220
-
221
- /**
222
- * Returns `true` if the server's schema is quarantined.
223
- *
224
- * When quarantined, `isToolAllowed` will block all tool execution until the
225
- * schema is refreshed (`markFresh` via a successful schema fetch) or an
226
- * operator approves a temporary override via `approveSchemaQuarantine`.
227
- *
228
- * @param serverName - Server identifier
229
- */
230
- isSchemaQuarantined(serverName: string): boolean {
231
- return this.freshness.isQuarantined(serverName);
232
- }
233
-
234
- /**
235
- * Manually quarantine a server's schema.
236
- *
237
- * Intended for operator-initiated quarantine (e.g. after detecting schema
238
- * incompatibility). Emits `MCP_SCHEMA_QUARANTINED`.
239
- *
240
- * @param serverName - Server identifier
241
- * @param reason - Why quarantine is being applied
242
- * @param detail - Optional detail for the MCP panel display
243
- */
244
- quarantineSchema(
245
- serverName: string,
246
- reason: QuarantineReason,
247
- detail?: string,
248
- ): void {
249
- this.freshness.markQuarantined(serverName, reason, detail);
250
- this._emit({
251
- type: 'MCP_SCHEMA_QUARANTINED',
252
- serverId: serverName,
253
- reason,
254
- detail,
255
- });
256
- logger.warn('McpLifecycleManager: schema quarantined', { server: serverName, reason, detail });
257
- }
258
-
259
- /**
260
- * Operator override: approve a quarantined schema so tool execution can
261
- * proceed temporarily without a full schema refresh.
262
- *
263
- * The quarantine record is preserved for audit purposes. Freshness transitions
264
- * to `stale`. Emits `MCP_SCHEMA_QUARANTINE_APPROVED`.
265
- *
266
- * @param serverName - Server identifier
267
- * @param operatorId - Identifier of the approving operator
268
- */
269
- approveSchemaQuarantine(serverName: string, operatorId: string): void {
270
- if (!this.freshness.isQuarantined(serverName)) {
271
- logger.debug('McpLifecycleManager: approveSchemaQuarantine called but not quarantined', { server: serverName });
272
- return;
273
- }
274
- this.freshness.approveQuarantine(serverName, operatorId);
275
- this._emit({
276
- type: 'MCP_SCHEMA_QUARANTINE_APPROVED',
277
- serverId: serverName,
278
- operatorId,
279
- });
280
- logger.warn('McpLifecycleManager: quarantine override approved', { server: serverName, operatorId });
281
- }
282
-
283
- // ── Inspection ────────────────────────────────────────────────────────────
284
-
285
- /** Return the current lifecycle state for a server, or `null` if unknown. */
286
- getState(serverName: string): McpServerState | null {
287
- return this.servers.get(serverName)?.state ?? null;
288
- }
289
-
290
- /** Return all server entries as a read-only snapshot. */
291
- getServers(): ReadonlyMap<string, McpServerEntry> {
292
- return this.servers;
293
- }
294
-
295
- /** Return the entry for a single server, or `null`. */
296
- getServer(serverName: string): McpServerEntry | null {
297
- return this.servers.get(serverName) ?? null;
298
- }
299
-
300
- /** Names of all servers currently in an operational state (connected/degraded). */
301
- get operationalServerNames(): string[] {
302
- return Array.from(this.servers.entries())
303
- .filter(([, entry]) => isOperational(entry.state))
304
- .map(([name]) => name);
305
- }
306
-
307
- // ── Private: start ────────────────────────────────────────────────────────
308
-
309
- private async _startServer(config: McpServerConfig): Promise<void> {
310
- const { name } = config;
311
-
312
- if (this.servers.has(name)) {
313
- logger.info('McpLifecycleManager: server already registered', { name });
314
- return;
315
- }
316
-
317
- // Register in subsystems
318
- this.permissions.registerServer(name, 'standard', {
319
- role: config.role ?? 'general',
320
- mode: config.trustMode ?? 'ask-on-risk',
321
- allowedPaths: config.allowedPaths ?? [],
322
- allowedHosts: config.allowedHosts ?? [],
323
- });
324
- this.freshness.registerServer(name);
325
-
326
- // Create entry in configured state
327
- const entry: McpServerEntry = {
328
- name,
329
- config,
330
- state: 'configured',
331
- reconnectAttempts: 0,
332
- reconnectPending: false,
333
- availableTools: [],
334
- availableResources: [],
335
- callCount: 0,
336
- errorCount: 0,
337
- };
338
- this.servers.set(name, entry);
339
- this._emit({ type: 'MCP_CONFIGURED', serverId: name, transport: 'stdio' });
340
-
341
- // Begin connection attempt
342
- await this._connect(name);
343
- }
344
-
345
- private async _connect(serverName: string): Promise<void> {
346
- const entry = this.servers.get(serverName);
347
- if (!entry) return;
348
-
349
- const toConnecting = applyTransition(entry.state, 'connecting');
350
- if (!toConnecting.success) {
351
- logger.debug('McpLifecycleManager: cannot transition to connecting', {
352
- server: serverName,
353
- reason: toConnecting.reason,
354
- });
355
- return;
356
- }
357
- this._setState(entry, 'connecting');
358
- this._emit({ type: 'MCP_CONNECTING', serverId: serverName });
359
-
360
- try {
361
- const client = new McpClient(entry.config);
362
- await client.connect();
363
- this.clients.set(serverName, client);
364
-
365
- // Load tool list
366
- const tools = await client.listTools().catch((err: unknown) => {
367
- logger.debug('McpLifecycleManager: listTools failed', { server: serverName, err: summarizeError(err) });
368
- return [];
369
- });
370
- entry.availableTools = tools.map((t) => t.name);
371
-
372
- entry.connectedAt = Date.now();
373
- entry.reconnectAttempts = 0;
374
- entry.reconnectPending = false;
375
-
376
- this._setState(entry, 'connected');
377
- this.freshness.markStale(serverName); // invalidate on (re)connect
378
-
379
- this._emit({
380
- type: 'MCP_CONNECTED',
381
- serverId: serverName,
382
- toolCount: entry.availableTools.length,
383
- resourceCount: entry.availableResources.length,
384
- });
385
-
386
- logger.info('McpLifecycleManager: server connected', {
387
- server: serverName,
388
- tools: entry.availableTools.length,
389
- });
390
- } catch (err) {
391
- const message = summarizeError(err);
392
- entry.lastError = message;
393
- logger.error('McpLifecycleManager: connection failed', { server: serverName, err: message });
394
- this._scheduleReconnect(serverName);
395
- }
396
- }
397
-
398
- // ── Private: stop ─────────────────────────────────────────────────────────
399
-
400
- private async _stopServer(serverName: string, reason?: string): Promise<void> {
401
- this._cancelReconnect(serverName);
402
-
403
- const entry = this.servers.get(serverName);
404
- if (!entry) return;
405
-
406
- const client = this.clients.get(serverName);
407
- if (client) {
408
- try {
409
- await client.disconnect();
410
- } catch (err) {
411
- // Non-fatal — we are stopping regardless
412
- logger.debug('McpLifecycleManager: disconnect error (suppressed)', { server: serverName, err: summarizeError(err) });
413
- }
414
- this.clients.delete(serverName);
415
- }
416
-
417
- entry.disconnectedAt = Date.now();
418
- entry.lastError = reason;
419
- this._setState(entry, 'disconnected');
420
- this._emit({ type: 'MCP_DISCONNECTED', serverId: serverName, reason, willRetry: false });
421
- }
422
-
423
- // ── Private: reconnect ────────────────────────────────────────────────────
424
-
425
- private _scheduleReconnect(serverName: string): void {
426
- const entry = this.servers.get(serverName);
427
- if (!entry) return;
428
-
429
- if (entry.reconnectAttempts >= this.reconnectConfig.maxAttempts) {
430
- logger.info('McpLifecycleManager: max reconnect attempts reached', {
431
- server: serverName,
432
- attempts: entry.reconnectAttempts,
433
- });
434
- entry.disconnectedAt = Date.now();
435
- this._setState(entry, 'disconnected');
436
- this._emit({
437
- type: 'MCP_DISCONNECTED',
438
- serverId: serverName,
439
- reason: `max reconnect attempts (${this.reconnectConfig.maxAttempts}) exceeded`,
440
- willRetry: false,
441
- });
442
- return;
443
- }
444
-
445
- const attempt = entry.reconnectAttempts + 1;
446
- const delay = Math.min(
447
- this.reconnectConfig.baseDelayMs * Math.pow(2, attempt - 1),
448
- this.reconnectConfig.maxDelayMs,
449
- );
450
-
451
- this._setState(entry, 'reconnecting');
452
- entry.reconnectPending = true;
453
- entry.reconnectAttempts = attempt;
454
-
455
- this._emit({
456
- type: 'MCP_RECONNECTING',
457
- serverId: serverName,
458
- attempt,
459
- maxAttempts: this.reconnectConfig.maxAttempts,
460
- });
461
-
462
- logger.info('McpLifecycleManager: scheduling reconnect', { server: serverName, attempt, delayMs: delay });
463
-
464
- const timer = setTimeout(() => {
465
- this.reconnectTimers.delete(serverName);
466
- const current = this.servers.get(serverName);
467
- if (!current || current.state !== 'reconnecting') return;
468
- current.reconnectPending = false;
469
- void this._connect(serverName);
470
- }, delay);
471
-
472
- this.reconnectTimers.set(serverName, timer);
473
- }
474
-
475
- private _cancelReconnect(serverName: string): void {
476
- const timer = this.reconnectTimers.get(serverName);
477
- if (timer !== undefined) {
478
- clearTimeout(timer);
479
- this.reconnectTimers.delete(serverName);
480
- const entry = this.servers.get(serverName);
481
- if (entry) entry.reconnectPending = false;
482
- }
483
- }
484
-
485
- // ── Private: state helpers ────────────────────────────────────────────────
486
-
487
- private _setState(entry: McpServerEntry, next: McpServerState): void {
488
- const result = applyTransition(entry.state, next);
489
- if (!result.success) {
490
- logger.debug('McpLifecycleManager: invalid transition (ignored)', {
491
- server: entry.name,
492
- from: entry.state,
493
- to: next,
494
- reason: result.reason,
495
- });
496
- return;
497
- }
498
- entry.state = next;
499
- }
500
-
501
- // ── Private: event emission ───────────────────────────────────────────────
502
-
503
- private _emit(event: McpEvent): void {
504
- for (const handler of this.eventHandlers) {
505
- try {
506
- handler(event);
507
- } catch (err) {
508
- // Non-fatal: handler errors must not crash the manager
509
- logger.debug('McpLifecycleManager: event handler threw', { event: event.type, err: summarizeError(err) });
510
- }
511
- }
512
- }
513
- }