@pellux/goodvibes-tui 0.18.8 → 0.18.9

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 (555) hide show
  1. package/CHANGELOG.md +36 -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/acp/connection.ts +5 -5
  6. package/src/acp/index.ts +1 -1
  7. package/src/acp/manager.ts +1 -133
  8. package/src/adapters/bluebubbles/index.ts +1 -1
  9. package/src/adapters/discord/index.ts +2 -2
  10. package/src/adapters/github/index.ts +1 -1
  11. package/src/adapters/google-chat/index.ts +1 -1
  12. package/src/adapters/imessage/index.ts +1 -1
  13. package/src/adapters/index.ts +15 -15
  14. package/src/adapters/matrix/index.ts +1 -1
  15. package/src/adapters/mattermost/index.ts +1 -1
  16. package/src/adapters/msteams/index.ts +2 -2
  17. package/src/adapters/ntfy/index.ts +1 -1
  18. package/src/adapters/signal/index.ts +1 -1
  19. package/src/adapters/slack/index.ts +2 -2
  20. package/src/adapters/telegram/index.ts +1 -1
  21. package/src/adapters/types.ts +4 -4
  22. package/src/adapters/webhook/index.ts +1 -1
  23. package/src/adapters/whatsapp/index.ts +1 -1
  24. package/src/agents/message-bus-core.ts +2 -2
  25. package/src/agents/message-bus.ts +2 -2
  26. package/src/agents/orchestrator-prompts.ts +4 -4
  27. package/src/agents/orchestrator-runner.ts +11 -11
  28. package/src/agents/orchestrator.ts +14 -13
  29. package/src/agents/session.ts +1 -1
  30. package/src/agents/worktree.ts +1 -1
  31. package/src/agents/wrfc-config.ts +2 -2
  32. package/src/agents/wrfc-controller.ts +12 -12
  33. package/src/agents/wrfc-gate-runtime.ts +5 -5
  34. package/src/agents/wrfc-reporting.ts +1 -1
  35. package/src/agents/wrfc-runtime-events.ts +3 -3
  36. package/src/agents/wrfc-types.ts +1 -1
  37. package/src/automation/delivery-manager.ts +4 -4
  38. package/src/automation/index.ts +4 -4
  39. package/src/automation/manager-runtime-delivery.ts +1 -1
  40. package/src/automation/manager-runtime-events.ts +3 -3
  41. package/src/automation/manager-runtime-execution.ts +5 -5
  42. package/src/automation/manager-runtime-helpers.ts +2 -2
  43. package/src/automation/manager-runtime-job-mutations.ts +3 -3
  44. package/src/automation/manager-runtime-reconcile.ts +4 -4
  45. package/src/automation/manager-runtime-scheduling.ts +2 -2
  46. package/src/automation/manager-runtime.ts +18 -18
  47. package/src/automation/manager.ts +2 -2
  48. package/src/automation/service.ts +2 -2
  49. package/src/channels/builtin/account-actions.ts +5 -5
  50. package/src/channels/builtin/accounts.ts +2 -2
  51. package/src/channels/builtin/contracts.ts +3 -3
  52. package/src/channels/builtin/plugins.ts +5 -5
  53. package/src/channels/builtin/rendering.ts +4 -4
  54. package/src/channels/builtin/setup-schema.ts +1 -1
  55. package/src/channels/builtin/shared.ts +7 -7
  56. package/src/channels/builtin/surfaces.ts +2 -2
  57. package/src/channels/builtin/targets.ts +3 -3
  58. package/src/channels/builtin-runtime.ts +11 -11
  59. package/src/channels/delivery/shared.ts +2 -2
  60. package/src/channels/delivery/strategies-bridge.ts +3 -3
  61. package/src/channels/delivery/strategies-core.ts +5 -5
  62. package/src/channels/delivery/strategies-enterprise.ts +3 -3
  63. package/src/channels/delivery/types.ts +2 -2
  64. package/src/channels/delivery-router.ts +9 -9
  65. package/src/channels/index.ts +12 -12
  66. package/src/channels/plugin-registry.ts +1 -1
  67. package/src/channels/provider-runtime.ts +3 -3
  68. package/src/channels/reply-pipeline.ts +3 -3
  69. package/src/channels/route-manager.ts +2 -2
  70. package/src/channels/surface-registry.ts +2 -2
  71. package/src/config/helper-model.ts +1 -233
  72. package/src/config/index.ts +3 -3
  73. package/src/config/manager.ts +8 -404
  74. package/src/config/secrets.ts +21 -542
  75. package/src/config/service-registry.ts +1 -329
  76. package/src/config/tool-llm.ts +3 -3
  77. package/src/control-plane/approval-broker.ts +1 -1
  78. package/src/control-plane/gateway.ts +1 -713
  79. package/src/control-plane/index.ts +7 -7
  80. package/src/control-plane/media-contract-schemas.ts +1 -208
  81. package/src/control-plane/method-catalog-admin.ts +1 -136
  82. package/src/control-plane/method-catalog-channels.ts +1 -591
  83. package/src/control-plane/method-catalog-control-automation.ts +1 -475
  84. package/src/control-plane/method-catalog-control-core.ts +1 -594
  85. package/src/control-plane/method-catalog-control.ts +1 -8
  86. package/src/control-plane/method-catalog-events.ts +1 -74
  87. package/src/control-plane/method-catalog-knowledge.ts +1 -531
  88. package/src/control-plane/method-catalog-media.ts +1 -279
  89. package/src/control-plane/method-catalog-runtime.ts +1 -304
  90. package/src/control-plane/method-catalog-shared.ts +1 -223
  91. package/src/control-plane/method-catalog.ts +1 -242
  92. package/src/control-plane/operator-contract-schemas-admin.ts +1 -639
  93. package/src/control-plane/operator-contract-schemas-channels.ts +1 -375
  94. package/src/control-plane/operator-contract-schemas-control.ts +1 -226
  95. package/src/control-plane/operator-contract-schemas-domains.ts +1 -4
  96. package/src/control-plane/operator-contract-schemas-knowledge.ts +1 -582
  97. package/src/control-plane/operator-contract-schemas-media.ts +1 -297
  98. package/src/control-plane/operator-contract-schemas-permissions.ts +1 -100
  99. package/src/control-plane/operator-contract-schemas-remote.ts +1 -38
  100. package/src/control-plane/operator-contract-schemas-runtime.ts +1 -563
  101. package/src/control-plane/operator-contract-schemas-shared.ts +1 -85
  102. package/src/control-plane/operator-contract-schemas-telemetry.ts +1 -349
  103. package/src/control-plane/operator-contract-schemas.ts +1 -6
  104. package/src/control-plane/operator-contract.ts +5 -3
  105. package/src/control-plane/session-broker.ts +1 -1
  106. package/src/core/compaction-sections.ts +5 -5
  107. package/src/core/compaction-types.ts +3 -3
  108. package/src/core/composer-state.ts +1 -1
  109. package/src/core/context-compaction.ts +7 -7
  110. package/src/core/conversation-compaction.ts +4 -4
  111. package/src/core/conversation-diff.ts +1 -1
  112. package/src/core/conversation-rendering.ts +5 -5
  113. package/src/core/conversation-utils.ts +2 -2
  114. package/src/core/conversation.ts +10 -10
  115. package/src/core/event-replay.ts +1 -1
  116. package/src/core/orchestrator-context-runtime.ts +8 -8
  117. package/src/core/orchestrator-follow-up-runtime.ts +2 -2
  118. package/src/core/orchestrator-runtime.ts +4 -4
  119. package/src/core/orchestrator-tool-runtime.ts +7 -7
  120. package/src/core/orchestrator-turn-helpers.ts +7 -7
  121. package/src/core/orchestrator-turn-loop.ts +10 -10
  122. package/src/core/orchestrator.ts +17 -17
  123. package/src/core/plan-command-handler.ts +2 -2
  124. package/src/core/system-message-router.ts +2 -2
  125. package/src/core/transcript-events/classify.ts +1 -1
  126. package/src/core/transcript-events/index.ts +3 -3
  127. package/src/daemon/cli.ts +6 -6
  128. package/src/daemon/control-plane.ts +7 -7
  129. package/src/daemon/facade-composition.ts +16 -15
  130. package/src/daemon/facade.ts +17 -17
  131. package/src/daemon/helpers.ts +2 -2
  132. package/src/daemon/http/router-route-contexts.ts +11 -11
  133. package/src/daemon/http/router.ts +25 -25
  134. package/src/daemon/http-listener.ts +3 -3
  135. package/src/daemon/index.ts +1 -3
  136. package/src/daemon/service-manager.ts +1 -1
  137. package/src/daemon/surface-actions.ts +8 -8
  138. package/src/daemon/surface-delivery.ts +7 -7
  139. package/src/daemon/surface-policy.ts +1 -1
  140. package/src/daemon/transport-events.ts +4 -4
  141. package/src/daemon/types.ts +24 -24
  142. package/src/export/markdown.ts +1 -1
  143. package/src/export/session-export.ts +1 -633
  144. package/src/git/index.ts +1 -1
  145. package/src/git/service.ts +1 -1
  146. package/src/hooks/chain-engine.ts +1 -1
  147. package/src/hooks/dispatcher.ts +4 -4
  148. package/src/hooks/hook-api.ts +1 -1
  149. package/src/hooks/index.ts +8 -8
  150. package/src/hooks/runners/agent.ts +1 -1
  151. package/src/hooks/runners/prompt.ts +1 -1
  152. package/src/hooks/workbench.ts +2 -2
  153. package/src/input/command-registry.ts +24 -17
  154. package/src/input/commands/config.ts +1 -1
  155. package/src/input/commands/control-room-runtime.ts +2 -2
  156. package/src/input/commands/conversation-runtime.ts +1 -1
  157. package/src/input/commands/eval.ts +2 -2
  158. package/src/input/commands/git-runtime.ts +1 -1
  159. package/src/input/commands/guidance-runtime.ts +3 -3
  160. package/src/input/commands/health-runtime.ts +7 -7
  161. package/src/input/commands/incident-runtime.ts +1 -1
  162. package/src/input/commands/integration-runtime.ts +3 -3
  163. package/src/input/commands/local-provider-runtime.ts +1 -1
  164. package/src/input/commands/local-runtime.ts +1 -1
  165. package/src/input/commands/local-setup-review.ts +1 -1
  166. package/src/input/commands/local-setup.ts +1 -1
  167. package/src/input/commands/managed-runtime.ts +2 -2
  168. package/src/input/commands/marketplace-runtime.ts +1 -1
  169. package/src/input/commands/platform-access-runtime.ts +1 -1
  170. package/src/input/commands/policy-dispatch.ts +2 -2
  171. package/src/input/commands/product-runtime.ts +2 -2
  172. package/src/input/commands/profile-sync-runtime.ts +1 -1
  173. package/src/input/commands/provider-accounts-runtime.ts +1 -1
  174. package/src/input/commands/provider.ts +3 -3
  175. package/src/input/commands/quit-shared.ts +1 -1
  176. package/src/input/commands/recall-bundle.ts +1 -1
  177. package/src/input/commands/recall-capture.ts +2 -2
  178. package/src/input/commands/recall-query.ts +2 -2
  179. package/src/input/commands/recall-shared.ts +1 -1
  180. package/src/input/commands/remote-runtime-setup.ts +1 -1
  181. package/src/input/commands/remote-runtime.ts +1 -1
  182. package/src/input/commands/runtime-services.ts +13 -11
  183. package/src/input/commands/schedule-runtime.ts +2 -2
  184. package/src/input/commands/session-content.ts +1 -1
  185. package/src/input/commands/session-workflow.ts +4 -4
  186. package/src/input/commands/settings-sync-runtime.ts +1 -1
  187. package/src/input/commands/share-runtime.ts +9 -4
  188. package/src/input/commands/shell-core.ts +1 -1
  189. package/src/input/commands/skills-runtime.ts +1 -1
  190. package/src/input/commands/subscription-runtime.ts +1 -1
  191. package/src/input/commands/tasks-runtime.ts +1 -1
  192. package/src/input/commands/teamwork-runtime.ts +1 -1
  193. package/src/input/commands/worktree-runtime.ts +1 -1
  194. package/src/input/handler-command-route.ts +1 -1
  195. package/src/input/handler-content-actions.ts +3 -3
  196. package/src/input/handler-feed-routes.ts +2 -2
  197. package/src/input/handler-feed.ts +1 -1
  198. package/src/input/handler-shortcuts.ts +1 -1
  199. package/src/input/handler.ts +1 -1
  200. package/src/input/keybindings.ts +5 -0
  201. package/src/input/model-picker.ts +2 -2
  202. package/src/input/profile-picker-modal.ts +1 -1
  203. package/src/input/session-picker-modal.ts +1 -1
  204. package/src/input/settings-modal.ts +4 -4
  205. package/src/integrations/index.ts +1 -1
  206. package/src/integrations/notifier.ts +1 -1
  207. package/src/integrations/webhooks.ts +1 -177
  208. package/src/knowledge/consolidation.ts +2 -2
  209. package/src/knowledge/graphql.ts +1 -1
  210. package/src/knowledge/index.ts +5 -5
  211. package/src/knowledge/ingest-compile.ts +3 -3
  212. package/src/knowledge/ingest-context.ts +1 -1
  213. package/src/knowledge/ingest-inputs.ts +4 -4
  214. package/src/knowledge/ingest.ts +1 -20
  215. package/src/knowledge/internal.ts +1 -1
  216. package/src/knowledge/knowledge-api.ts +7 -7
  217. package/src/knowledge/lint.ts +3 -3
  218. package/src/knowledge/memory-sync.ts +2 -2
  219. package/src/knowledge/packet.ts +3 -3
  220. package/src/knowledge/scheduling.ts +2 -2
  221. package/src/knowledge/service.ts +10 -10
  222. package/src/main.ts +11 -10
  223. package/src/mcp/index.ts +4 -4
  224. package/src/mcp/mcp-api.ts +1 -1
  225. package/src/mcp/registry.ts +1 -506
  226. package/src/media/builtin-image-understanding.ts +2 -2
  227. package/src/media/builtin-providers.ts +2 -2
  228. package/src/media/index.ts +1 -1
  229. package/src/multimodal/index.ts +1 -1
  230. package/src/multimodal/service.ts +2 -2
  231. package/src/panels/agent-inspector-panel.ts +2 -2
  232. package/src/panels/agent-logs-panel.ts +3 -3
  233. package/src/panels/approval-panel.ts +2 -2
  234. package/src/panels/builtin/operations.ts +3 -1
  235. package/src/panels/builtin/shared.ts +13 -13
  236. package/src/panels/context-visualizer-panel.ts +2 -2
  237. package/src/panels/cost-tracker-panel.ts +2 -2
  238. package/src/panels/debug-panel.ts +3 -3
  239. package/src/panels/git-panel.ts +1 -1
  240. package/src/panels/hooks-panel.ts +4 -4
  241. package/src/panels/knowledge-panel.ts +1 -1
  242. package/src/panels/marketplace-panel.ts +1 -1
  243. package/src/panels/mcp-panel.ts +1 -1
  244. package/src/panels/memory-panel.ts +2 -2
  245. package/src/panels/ops-control-panel.ts +2 -2
  246. package/src/panels/ops-strategy-panel.ts +2 -2
  247. package/src/panels/plugins-panel.ts +1 -1
  248. package/src/panels/policy-panel.ts +1 -1
  249. package/src/panels/provider-health-panel.ts +3 -3
  250. package/src/panels/provider-stats-panel.ts +2 -2
  251. package/src/panels/sandbox-panel.ts +1 -1
  252. package/src/panels/schedule-panel.ts +1 -1
  253. package/src/panels/settings-sync-panel.ts +1 -1
  254. package/src/panels/system-messages-panel.ts +1 -1
  255. package/src/panels/tasks-panel.ts +1 -1
  256. package/src/panels/thinking-panel.ts +2 -2
  257. package/src/panels/token-budget-panel.ts +1 -1
  258. package/src/panels/tool-inspector-panel.ts +2 -2
  259. package/src/panels/worktree-panel.ts +1 -1
  260. package/src/panels/wrfc-panel.ts +4 -4
  261. package/src/permissions/briefs/build.ts +1 -1
  262. package/src/permissions/manager.ts +1 -356
  263. package/src/permissions/prompt.ts +1 -1
  264. package/src/plugins/api.ts +9 -9
  265. package/src/plugins/loader.ts +8 -8
  266. package/src/plugins/manager.ts +5 -5
  267. package/src/providers/amazon-bedrock-mantle.ts +1 -1
  268. package/src/providers/amazon-bedrock.ts +1 -1
  269. package/src/providers/anthropic-compat.ts +4 -4
  270. package/src/providers/anthropic-sdk-provider.ts +5 -5
  271. package/src/providers/anthropic-vertex.ts +1 -1
  272. package/src/providers/anthropic.ts +4 -4
  273. package/src/providers/auto-register.ts +6 -6
  274. package/src/providers/builtin-catalog.ts +2 -2
  275. package/src/providers/builtin-registry.ts +15 -15
  276. package/src/providers/cache-planner.ts +2 -2
  277. package/src/providers/capabilities.ts +1 -601
  278. package/src/providers/custom-loader.ts +6 -6
  279. package/src/providers/discovered-compat.ts +7 -18
  280. package/src/providers/discovered-factory.ts +7 -7
  281. package/src/providers/discovered-traits.ts +1 -1
  282. package/src/providers/gemini.ts +4 -4
  283. package/src/providers/github-copilot.ts +4 -4
  284. package/src/providers/index.ts +1 -47
  285. package/src/providers/interface.ts +1 -1
  286. package/src/providers/llama-cpp.ts +4 -4
  287. package/src/providers/lm-studio-helpers.ts +1 -1
  288. package/src/providers/lm-studio.ts +4 -4
  289. package/src/providers/model-catalog-cache.ts +1 -1
  290. package/src/providers/model-catalog-notifications.ts +1 -1
  291. package/src/providers/model-catalog-synthetic.ts +2 -2
  292. package/src/providers/model-catalog.ts +7 -7
  293. package/src/providers/model-limits.ts +1 -280
  294. package/src/providers/ollama.ts +4 -4
  295. package/src/providers/openai-codex.ts +2 -2
  296. package/src/providers/openai-compat.ts +4 -4
  297. package/src/providers/openai.ts +3 -3
  298. package/src/providers/optimizer.ts +1 -381
  299. package/src/providers/provider-api.ts +1 -553
  300. package/src/providers/registry-helpers.ts +1 -1
  301. package/src/providers/registry-models.ts +2 -2
  302. package/src/providers/registry-types.ts +5 -5
  303. package/src/providers/registry.ts +1 -729
  304. package/src/providers/runtime-metadata.ts +1 -1
  305. package/src/providers/runtime-snapshot.ts +3 -3
  306. package/src/providers/synthetic.ts +3 -3
  307. package/src/providers/tier-prompts.ts +1 -1
  308. package/src/providers/tool-formats.ts +1 -1
  309. package/src/renderer/agent-detail-modal.ts +2 -2
  310. package/src/renderer/block-actions.ts +1 -1
  311. package/src/renderer/context-inspector.ts +1 -1
  312. package/src/renderer/conversation-layout.ts +1 -1
  313. package/src/renderer/conversation-overlays.ts +1 -1
  314. package/src/renderer/git-status.ts +1 -1
  315. package/src/renderer/live-tail-modal.ts +1 -1
  316. package/src/renderer/process-modal.ts +2 -2
  317. package/src/runtime/bootstrap-background.ts +4 -4
  318. package/src/runtime/bootstrap-command-context.ts +23 -23
  319. package/src/runtime/bootstrap-command-parts.ts +23 -23
  320. package/src/runtime/bootstrap-core.ts +12 -10
  321. package/src/runtime/bootstrap-helpers.ts +2 -2
  322. package/src/runtime/bootstrap-hook-bridge.ts +9 -9
  323. package/src/runtime/bootstrap-runtime-events.ts +4 -4
  324. package/src/runtime/bootstrap-services.ts +4 -4
  325. package/src/runtime/bootstrap-shell.ts +11 -11
  326. package/src/runtime/bootstrap.ts +28 -10
  327. package/src/runtime/compaction/index.ts +1 -90
  328. package/src/runtime/compaction/lifecycle.ts +1 -167
  329. package/src/runtime/compaction/manager.ts +11 -11
  330. package/src/runtime/compaction/quality-score.ts +1 -279
  331. package/src/runtime/compaction/resume-repair.ts +1 -183
  332. package/src/runtime/compaction/strategies/autocompact.ts +1 -65
  333. package/src/runtime/compaction/strategies/boundary-commit.ts +1 -106
  334. package/src/runtime/compaction/strategies/collapse.ts +1 -90
  335. package/src/runtime/compaction/strategies/index.ts +1 -23
  336. package/src/runtime/compaction/strategies/microcompact.ts +1 -74
  337. package/src/runtime/compaction/strategies/reactive.ts +1 -89
  338. package/src/runtime/compaction/types.ts +1 -221
  339. package/src/runtime/context.ts +9 -9
  340. package/src/runtime/diagnostics/actions.ts +1 -1
  341. package/src/runtime/diagnostics/index.ts +5 -5
  342. package/src/runtime/diagnostics/panels/agents.ts +2 -2
  343. package/src/runtime/diagnostics/panels/events.ts +2 -2
  344. package/src/runtime/diagnostics/panels/health.ts +2 -2
  345. package/src/runtime/diagnostics/panels/ops.ts +2 -2
  346. package/src/runtime/diagnostics/panels/policy.ts +2 -2
  347. package/src/runtime/diagnostics/panels/tasks.ts +2 -2
  348. package/src/runtime/diagnostics/panels/tool-calls.ts +2 -2
  349. package/src/runtime/diagnostics/provider.ts +1 -1
  350. package/src/runtime/ecosystem/recommendations.ts +1 -1
  351. package/src/runtime/emitters/agents.ts +2 -2
  352. package/src/runtime/emitters/automation.ts +2 -2
  353. package/src/runtime/emitters/communication.ts +2 -2
  354. package/src/runtime/emitters/compaction.ts +2 -2
  355. package/src/runtime/emitters/control-plane.ts +2 -2
  356. package/src/runtime/emitters/deliveries.ts +2 -2
  357. package/src/runtime/emitters/forensics.ts +2 -2
  358. package/src/runtime/emitters/index.ts +27 -27
  359. package/src/runtime/emitters/knowledge.ts +2 -2
  360. package/src/runtime/emitters/mcp.ts +2 -2
  361. package/src/runtime/emitters/ops.ts +2 -2
  362. package/src/runtime/emitters/orchestration.ts +2 -2
  363. package/src/runtime/emitters/permissions.ts +2 -2
  364. package/src/runtime/emitters/planner.ts +2 -2
  365. package/src/runtime/emitters/plugins.ts +2 -2
  366. package/src/runtime/emitters/providers.ts +2 -2
  367. package/src/runtime/emitters/routes.ts +2 -2
  368. package/src/runtime/emitters/security.ts +2 -2
  369. package/src/runtime/emitters/session.ts +2 -2
  370. package/src/runtime/emitters/surfaces.ts +2 -2
  371. package/src/runtime/emitters/tasks.ts +2 -2
  372. package/src/runtime/emitters/tools.ts +2 -2
  373. package/src/runtime/emitters/transport.ts +2 -2
  374. package/src/runtime/emitters/turn.ts +3 -3
  375. package/src/runtime/emitters/ui.ts +2 -2
  376. package/src/runtime/emitters/watchers.ts +2 -2
  377. package/src/runtime/emitters/workflows.ts +3 -3
  378. package/src/runtime/eval/index.ts +3 -3
  379. package/src/runtime/eval/runner.ts +1 -1
  380. package/src/runtime/eval/suites.ts +1 -1
  381. package/src/runtime/events/domain-map.ts +2 -2
  382. package/src/runtime/events/index.ts +1 -194
  383. package/src/runtime/events/turn.ts +1 -60
  384. package/src/runtime/events/workflows.ts +1 -17
  385. package/src/runtime/forensics/collector.ts +4 -4
  386. package/src/runtime/forensics/index.ts +1 -1
  387. package/src/runtime/foundation-clients.ts +14 -14
  388. package/src/runtime/foundation-services.ts +8 -8
  389. package/src/runtime/guidance.ts +3 -3
  390. package/src/runtime/health/effect-handlers.ts +3 -3
  391. package/src/runtime/health/index.ts +4 -4
  392. package/src/runtime/health/wiring.ts +2 -2
  393. package/src/runtime/index.ts +29 -29
  394. package/src/runtime/integration/helpers.ts +12 -12
  395. package/src/runtime/lifecycle.ts +4 -4
  396. package/src/runtime/mcp/index.ts +3 -3
  397. package/src/runtime/mcp/manager.ts +1 -1
  398. package/src/runtime/network/inbound.ts +2 -2
  399. package/src/runtime/network/index.ts +5 -5
  400. package/src/runtime/network/outbound.ts +2 -2
  401. package/src/runtime/network/shared.ts +1 -1
  402. package/src/runtime/operator-client.ts +9 -9
  403. package/src/runtime/ops/control-plane.ts +2 -2
  404. package/src/runtime/ops/index.ts +3 -3
  405. package/src/runtime/ops/playbooks/index.ts +2 -2
  406. package/src/runtime/ops/playbooks/session-unrecoverable.ts +2 -2
  407. package/src/runtime/ops/playbooks/stuck-turn.ts +1 -1
  408. package/src/runtime/ops/runtime-context.ts +1 -1
  409. package/src/runtime/orchestration/spawn-policy.ts +1 -1
  410. package/src/runtime/peer-client.ts +3 -3
  411. package/src/runtime/perf/index.ts +1 -1
  412. package/src/runtime/perf/slo-collector.ts +1 -1
  413. package/src/runtime/permissions/index.ts +5 -5
  414. package/src/runtime/permissions/policy-runtime.ts +1 -175
  415. package/src/runtime/permissions/rule-suggestions.ts +1 -1
  416. package/src/runtime/plugins/hot-reload.ts +4 -4
  417. package/src/runtime/plugins/index.ts +13 -13
  418. package/src/runtime/plugins/lifecycle.ts +1 -1
  419. package/src/runtime/plugins/manager.ts +10 -10
  420. package/src/runtime/plugins/manifest.ts +2 -2
  421. package/src/runtime/plugins/quarantine.ts +2 -2
  422. package/src/runtime/plugins/trust.ts +2 -2
  423. package/src/runtime/plugins/types.ts +1 -1
  424. package/src/runtime/provider-accounts/registry.ts +2 -2
  425. package/src/runtime/remote/distributed-runtime-contract-schemas.ts +3 -3
  426. package/src/runtime/remote/index.ts +3 -3
  427. package/src/runtime/remote/runner-registry.ts +2 -2
  428. package/src/runtime/remote/supervisor.ts +1 -1
  429. package/src/runtime/runtime-hook-api.ts +1 -1
  430. package/src/runtime/runtime-knowledge-api.ts +1 -1
  431. package/src/runtime/runtime-mcp-api.ts +1 -1
  432. package/src/runtime/runtime-ops-api.ts +2 -2
  433. package/src/runtime/runtime-provider-api.ts +1 -1
  434. package/src/runtime/services.ts +35 -32
  435. package/src/runtime/session-maintenance.ts +1 -1
  436. package/src/runtime/session-persistence.ts +2 -2
  437. package/src/runtime/session-return-context.ts +3 -3
  438. package/src/runtime/settings/control-plane-store.ts +1 -1
  439. package/src/runtime/settings/control-plane.ts +2 -2
  440. package/src/runtime/shell-command-extensions.ts +7 -7
  441. package/src/runtime/shell-command-ops.ts +6 -6
  442. package/src/runtime/shell-command-platform.ts +1 -1
  443. package/src/runtime/shell-command-services.ts +17 -17
  444. package/src/runtime/shell-command-workspace.ts +1 -1
  445. package/src/runtime/store/domains/conversation.ts +1 -1
  446. package/src/runtime/store/domains/index.ts +4 -4
  447. package/src/runtime/store/domains/permissions.ts +1 -1
  448. package/src/runtime/store/helpers/reducers/conversation.ts +3 -3
  449. package/src/runtime/store/helpers/reducers/lifecycle.ts +3 -3
  450. package/src/runtime/store/helpers/reducers/shared.ts +2 -2
  451. package/src/runtime/store/helpers/reducers/sync.ts +1 -1
  452. package/src/runtime/store/helpers/reducers.ts +4 -4
  453. package/src/runtime/store/index.ts +4 -4
  454. package/src/runtime/store/selectors/index.ts +2 -2
  455. package/src/runtime/store/state.ts +4 -4
  456. package/src/runtime/tasks/adapters/acp-adapter.ts +1 -1
  457. package/src/runtime/tasks/adapters/index.ts +6 -6
  458. package/src/runtime/tasks/index.ts +3 -3
  459. package/src/runtime/tasks/manager.ts +3 -3
  460. package/src/runtime/telemetry/api-helpers.ts +2 -2
  461. package/src/runtime/telemetry/api.ts +2 -2
  462. package/src/runtime/telemetry/index.ts +5 -5
  463. package/src/runtime/telemetry/instrumentation/domain-bridge-agent-session.ts +1 -1
  464. package/src/runtime/telemetry/instrumentation/domain-bridge-plugin-mcp.ts +1 -1
  465. package/src/runtime/telemetry/instrumentation/domain-bridge-shared.ts +1 -1
  466. package/src/runtime/telemetry/instrumentation/domain-bridge-transport-task.ts +1 -1
  467. package/src/runtime/telemetry/instrumentation/domain-bridge.ts +5 -5
  468. package/src/runtime/telemetry/instrumentation/index.ts +3 -3
  469. package/src/runtime/tools/context.ts +3 -3
  470. package/src/runtime/tools/index.ts +4 -4
  471. package/src/runtime/tools/phased-executor.ts +3 -3
  472. package/src/runtime/tools/phases/budget.ts +1 -1
  473. package/src/runtime/tools/phases/execute.ts +1 -1
  474. package/src/runtime/tools/phases/index.ts +7 -7
  475. package/src/runtime/tools/phases/map-output.ts +1 -1
  476. package/src/runtime/tools/phases/permission.ts +2 -2
  477. package/src/runtime/tools/phases/posthook.ts +1 -1
  478. package/src/runtime/tools/phases/prehook.ts +1 -1
  479. package/src/runtime/tools/phases/validate.ts +1 -1
  480. package/src/runtime/transports/direct.ts +4 -4
  481. package/src/runtime/transports/http-helpers.ts +3 -3
  482. package/src/runtime/transports/http-types.ts +6 -6
  483. package/src/runtime/transports/http.ts +8 -8
  484. package/src/runtime/transports/realtime.ts +4 -4
  485. package/src/runtime/transports/remote-events.ts +1 -1
  486. package/src/runtime/transports/shared.ts +2 -2
  487. package/src/runtime/transports/ui-runtime-events.ts +2 -2
  488. package/src/runtime/ui/index.ts +7 -7
  489. package/src/runtime/ui/model-picker/data-provider.ts +4 -4
  490. package/src/runtime/ui/model-picker/health-enrichment.ts +3 -3
  491. package/src/runtime/ui/model-picker/index.ts +8 -8
  492. package/src/runtime/ui/provider-health/data-provider.ts +2 -2
  493. package/src/runtime/ui/provider-health/fallback-visualizer.ts +1 -1
  494. package/src/runtime/ui/provider-health/index.ts +5 -5
  495. package/src/runtime/ui-events.ts +1 -1
  496. package/src/runtime/ui-read-models-core.ts +2 -2
  497. package/src/runtime/ui-read-models-observability-maintenance.ts +4 -4
  498. package/src/runtime/ui-read-models-observability-options.ts +1 -1
  499. package/src/runtime/ui-read-models-observability-remote.ts +2 -2
  500. package/src/runtime/ui-read-models-observability-security.ts +3 -3
  501. package/src/runtime/ui-read-models-observability-system.ts +6 -6
  502. package/src/runtime/ui-read-models-observability.ts +10 -10
  503. package/src/runtime/ui-read-models-operations.ts +2 -2
  504. package/src/runtime/ui-read-models.ts +7 -7
  505. package/src/runtime/ui-service-queries.ts +2 -2
  506. package/src/runtime/ui-services.ts +7 -7
  507. package/src/runtime/worktree/registry.ts +1 -1
  508. package/src/scripts/process-messages.ts +1 -1
  509. package/src/sessions/manager.ts +9 -383
  510. package/src/shell/blocking-input.ts +3 -3
  511. package/src/shell/ui-openers.ts +3 -3
  512. package/src/state/file-watcher.ts +1 -1
  513. package/src/state/index.ts +10 -10
  514. package/src/state/knowledge-injection.ts +2 -2
  515. package/src/state/memory-embedding-http.ts +2 -2
  516. package/src/state/memory-embeddings.ts +1 -1
  517. package/src/state/memory-ingest.ts +3 -3
  518. package/src/state/memory-registry.ts +3 -3
  519. package/src/state/memory-store-helpers.ts +1 -1
  520. package/src/state/memory-store.ts +4 -4
  521. package/src/state/memory-vector-store.ts +3 -3
  522. package/src/tools/agent/index.ts +7 -7
  523. package/src/tools/agent/manager.ts +8 -8
  524. package/src/tools/analyze/git-modes.ts +2 -2
  525. package/src/tools/analyze/index.ts +2 -2
  526. package/src/tools/channel/agent-tools.ts +1 -1
  527. package/src/tools/channel/index.ts +2 -2
  528. package/src/tools/edit/core.ts +3 -3
  529. package/src/tools/edit/index.ts +2 -2
  530. package/src/tools/edit/phased.ts +2 -2
  531. package/src/tools/fetch/index.ts +2 -2
  532. package/src/tools/fetch/phased.ts +1 -1
  533. package/src/tools/index.ts +21 -21
  534. package/src/tools/mcp/index.ts +1 -1
  535. package/src/tools/remote-trigger/index.ts +1 -1
  536. package/src/tools/shared/auto-heal.ts +2 -2
  537. package/src/tools/state/index.ts +1 -1
  538. package/src/tools/web-search/index.ts +1 -1
  539. package/src/tools/write/index.ts +3 -3
  540. package/src/tools/write/phased.ts +1 -1
  541. package/src/version.ts +1 -1
  542. package/src/watchers/index.ts +2 -2
  543. package/src/watchers/registry.ts +2 -2
  544. package/src/web-search/index.ts +10 -10
  545. package/src/web-search/provider-registry.ts +8 -8
  546. package/src/web-search/providers/brave.ts +1 -1
  547. package/src/web-search/providers/duckduckgo.ts +1 -1
  548. package/src/web-search/providers/exa.ts +1 -1
  549. package/src/web-search/providers/firecrawl.ts +1 -1
  550. package/src/web-search/providers/perplexity.ts +1 -1
  551. package/src/web-search/providers/searxng.ts +1 -1
  552. package/src/web-search/providers/shared.ts +1 -1
  553. package/src/web-search/providers/tavily.ts +1 -1
  554. package/src/web-search/service.ts +2 -2
  555. package/src/runtime/ecosystem/catalog.ts +0 -606
@@ -1,8 +1,8 @@
1
1
  import { getNextAutomationOccurrence, normalizeCronSchedule, normalizeEverySchedule, type AutomationScheduleDefinition } from '@pellux/goodvibes-sdk/platform/automation/schedules';
2
2
  import type { KnowledgeStore } from '@pellux/goodvibes-sdk/platform/knowledge/store';
3
3
  import type { KnowledgeJobMode, KnowledgeJobRecord, KnowledgeJobRunRecord, KnowledgeScheduleRecord } from '@pellux/goodvibes-sdk/platform/knowledge/types';
4
- import { emitKnowledgeJobCompleted, emitKnowledgeJobFailed, emitKnowledgeJobQueued, emitKnowledgeJobStarted } from '../runtime/emitters/index.ts';
5
- import type { RuntimeEventBus } from '../runtime/events/index.ts';
4
+ import { emitKnowledgeJobCompleted, emitKnowledgeJobFailed, emitKnowledgeJobQueued, emitKnowledgeJobStarted } from '@pellux/goodvibes-sdk/platform/runtime/emitters/index';
5
+ import type { RuntimeEventBus } from '@pellux/goodvibes-sdk/platform/runtime/events/index';
6
6
  import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
7
7
 
8
8
  export interface KnowledgeSchedulingContext {
@@ -3,8 +3,8 @@ import {
3
3
  type AutomationScheduleDefinition,
4
4
  } from '@pellux/goodvibes-sdk/platform/automation/schedules';
5
5
  import { ArtifactStore } from '@pellux/goodvibes-sdk/platform/artifacts/index';
6
- import type { MemoryRegistry } from '../state/index.ts';
7
- import type { RuntimeEventBus } from '../runtime/events/index.ts';
6
+ import type { MemoryRegistry } from '@pellux/goodvibes-sdk/platform/state/index';
7
+ import type { RuntimeEventBus } from '@pellux/goodvibes-sdk/platform/runtime/events/index';
8
8
  import { createDefaultKnowledgeConnectorRegistry, KnowledgeConnectorRegistry } from '@pellux/goodvibes-sdk/platform/knowledge/connectors';
9
9
  import { KnowledgeProjectionService } from '@pellux/goodvibes-sdk/platform/knowledge/projections';
10
10
  import { KnowledgeStore } from '@pellux/goodvibes-sdk/platform/knowledge/store';
@@ -42,7 +42,7 @@ import {
42
42
  buildKnowledgePromptPacket,
43
43
  buildKnowledgePromptPacketSync,
44
44
  searchKnowledge,
45
- } from './packet.ts';
45
+ } from '@pellux/goodvibes-sdk/platform/knowledge/packet';
46
46
  import {
47
47
  ingestKnowledgeArtifact,
48
48
  ingestKnowledgeBookmarkSeeds,
@@ -54,14 +54,14 @@ import {
54
54
  refreshKnowledgeSources,
55
55
  pickKnowledgeRefreshCandidates,
56
56
  recompileKnowledgeSource,
57
- } from './ingest.ts';
57
+ } from '@pellux/goodvibes-sdk/platform/knowledge/ingest';
58
58
  import {
59
59
  decideKnowledgeConsolidationCandidate,
60
60
  runKnowledgeConsolidation,
61
- } from './consolidation.ts';
62
- import { KnowledgeScheduleService } from './scheduling.ts';
63
- import { lintKnowledgeStore } from './lint.ts';
64
- import { syncKnowledgeMemoryNodes } from './memory-sync.ts';
61
+ } from '@pellux/goodvibes-sdk/platform/knowledge/consolidation';
62
+ import { KnowledgeScheduleService } from '@pellux/goodvibes-sdk/platform/knowledge/scheduling';
63
+ import { lintKnowledgeStore } from '@pellux/goodvibes-sdk/platform/knowledge/lint';
64
+ import { syncKnowledgeMemoryNodes } from '@pellux/goodvibes-sdk/platform/knowledge/memory-sync';
65
65
  import {
66
66
  emitKnowledgeExtractionCompleted,
67
67
  emitKnowledgeExtractionFailed,
@@ -71,7 +71,7 @@ import {
71
71
  emitKnowledgePacketBuilt,
72
72
  emitKnowledgeProjectionMaterialized,
73
73
  emitKnowledgeProjectionRendered,
74
- } from '../runtime/emitters/index.ts';
74
+ } from '@pellux/goodvibes-sdk/platform/runtime/emitters/index';
75
75
  import { extractKnowledgeArtifact } from '@pellux/goodvibes-sdk/platform/knowledge/extractors';
76
76
  import {
77
77
  canonicalizeUri as internalCanonicalizeUri,
@@ -80,7 +80,7 @@ import {
80
80
  isHttpUri as internalIsHttpUri,
81
81
  isSourcePastRefreshWindow as internalIsSourcePastRefreshWindow,
82
82
  tokenize as internalTokenize,
83
- } from './internal.ts';
83
+ } from '@pellux/goodvibes-sdk/platform/knowledge/internal';
84
84
 
85
85
  const DEFAULT_PACKET_LIMIT = internalDefaultPacketLimit;
86
86
  const DEFAULT_PACKET_BUDGET = internalDefaultPacketBudget;
package/src/main.ts CHANGED
@@ -6,25 +6,25 @@ import { join } from 'node:path';
6
6
  import { Compositor } from './renderer/compositor.ts';
7
7
  import { type Line } from '@pellux/goodvibes-sdk/platform/types/grid';
8
8
  import { UIFactory } from './renderer/ui-factory.ts';
9
- import { Orchestrator } from './core/orchestrator.ts';
9
+ import { Orchestrator } from './core/orchestrator';
10
10
  import { InputHandler } from './input/handler.ts';
11
11
  import { SelectionManager } from './input/selection.ts';
12
12
  import { ConfigManager } from './config/index.ts';
13
- import type { ContentPart } from './providers/interface.ts';
13
+ import type { ContentPart } from '@pellux/goodvibes-sdk/platform/providers/interface';
14
14
  import { ToolRegistry } from '@pellux/goodvibes-sdk/platform/tools/registry';
15
- import { registerAllTools } from './tools/index.ts';
15
+ import { registerAllTools } from '@pellux/goodvibes-sdk/platform/tools/index';
16
16
  import { FileUndoManager } from '@pellux/goodvibes-sdk/platform/state/file-undo';
17
- import { PermissionManager } from './permissions/manager.ts';
18
- import { AcpManager } from './acp/manager.ts';
17
+ import { PermissionManager } from '@pellux/goodvibes-sdk/platform/permissions/manager';
18
+ import { AcpManager } from '@pellux/goodvibes-sdk/platform/acp/manager';
19
19
  import { PermissionPromptUI } from './permissions/prompt.ts';
20
20
  import { CommandRegistry } from './input/command-registry.ts';
21
21
  import type { CommandContext } from './input/command-registry.ts';
22
22
  import { renderProcessIndicator } from './renderer/process-indicator.ts';
23
- import { WrfcController } from './agents/wrfc-controller.ts';
23
+ import { WrfcController } from '@pellux/goodvibes-sdk/platform/agents/wrfc-controller';
24
24
  import { registerBuiltinCommands } from './input/commands.ts';
25
25
  import { ScheduleManager } from '@pellux/goodvibes-sdk/platform/tools/workflow/index';
26
26
  import { InputHistory } from './input/input-history.ts';
27
- import { getTierPromptSupplement, getTierForContextWindow } from './providers/tier-prompts.ts';
27
+ import { getTierPromptSupplement, getTierForContextWindow } from '@pellux/goodvibes-sdk/platform/providers/tier-prompts';
28
28
  import { GitStatusProvider } from './renderer/git-status.ts';
29
29
  import type { GitHeaderInfo } from './renderer/git-status.ts';
30
30
  import { createShellLayout } from './renderer/layout-engine.ts';
@@ -47,12 +47,12 @@ import {
47
47
  loadRecoveryConversation,
48
48
  persistConversation,
49
49
  writeRecoveryFile,
50
- } from './runtime/session-persistence.ts';
50
+ } from '@pellux/goodvibes-sdk/platform/runtime/session-persistence';
51
51
  import { handleBlockingShellInput, type PendingPermissionState } from './shell/blocking-input.ts';
52
52
  import { wireShellUiOpeners } from './shell/ui-openers.ts';
53
53
  import { deriveComposerState } from './core/composer-state.ts';
54
- import { buildPersistedSessionContext, formatReturnContextForDisplay, getReturnContextMode, maybeAssistReturnContextSummary } from './runtime/session-return-context.ts';
55
- import { GlobalNetworkTransportInstaller } from './runtime/network/index.ts';
54
+ import { buildPersistedSessionContext, formatReturnContextForDisplay, getReturnContextMode, maybeAssistReturnContextSummary } from '@pellux/goodvibes-sdk/platform/runtime/session-return-context';
55
+ import { GlobalNetworkTransportInstaller } from '@pellux/goodvibes-sdk/platform/runtime/network/index';
56
56
  import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
57
57
 
58
58
 
@@ -91,6 +91,7 @@ async function main() {
91
91
  const configManager = new ConfigManager({
92
92
  workingDir: bootstrapWorkingDir,
93
93
  homeDir: bootstrapHomeDirectory,
94
+ surfaceRoot: 'tui',
94
95
  });
95
96
  new GlobalNetworkTransportInstaller().install(configManager);
96
97
 
package/src/mcp/index.ts CHANGED
@@ -1,12 +1,12 @@
1
- export { McpRegistry } from './registry.ts';
2
- export type { RegisteredTool } from './registry.ts';
3
- export { createMcpApi } from './mcp-api.ts';
1
+ export { McpRegistry } from '@pellux/goodvibes-sdk/platform/mcp/registry';
2
+ export type { RegisteredTool } from '@pellux/goodvibes-sdk/platform/mcp/registry';
3
+ export { createMcpApi } from '@pellux/goodvibes-sdk/platform/mcp/mcp-api';
4
4
  export type {
5
5
  McpApi,
6
6
  McpApiRegistry,
7
7
  McpSandboxBindingRecord,
8
8
  McpServerRecord,
9
9
  McpServerSecurityRecord,
10
- } from './mcp-api.ts';
10
+ } from '@pellux/goodvibes-sdk/platform/mcp/mcp-api';
11
11
  export { loadMcpConfig } from '@pellux/goodvibes-sdk/platform/mcp/config';
12
12
  export type { McpConfig, McpConfigRoots, McpServerConfig } from '@pellux/goodvibes-sdk/platform/mcp/config';
@@ -1,4 +1,4 @@
1
- import type { RegisteredTool } from './registry.ts';
1
+ import type { RegisteredTool } from '@pellux/goodvibes-sdk/platform/mcp/registry';
2
2
  import type { McpDecisionRecord, McpServerRole, McpTrustMode, QuarantineReason, SchemaFreshness } from '@pellux/goodvibes-sdk/platform/runtime/mcp/types';
3
3
 
4
4
  export interface McpServerRecord {
@@ -1,506 +1 @@
1
- /**
2
- * McpRegistry — manages all connected MCP servers.
3
- *
4
- * Progressive loading strategy:
5
- * - On connect: load tool names + descriptions only (F2)
6
- * - On first callTool: fetch full JSON schema for that tool and cache it
7
- *
8
- * Tool namespace: mcp:<server-name>:<tool-name>
9
- */
10
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
11
- import { loadMcpConfig } from '@pellux/goodvibes-sdk/platform/mcp/config';
12
- import { McpClient } from './client.ts';
13
- import type { McpProcessSpec } from './client.ts';
14
- import type { McpToolInfo, McpToolSchema } from './client.ts';
15
- import type { McpServerConfig } from '@pellux/goodvibes-sdk/platform/mcp/config';
16
- import type { HookDispatcher } from '../hooks/dispatcher.ts';
17
- import type { HookEvent } from '@pellux/goodvibes-sdk/platform/hooks/types';
18
- import { McpPermissionManager } from '@pellux/goodvibes-sdk/platform/runtime/mcp/permissions';
19
- import { McpSchemaFreshnessTracker } from '@pellux/goodvibes-sdk/platform/runtime/mcp/schema-freshness';
20
- import type { McpDecisionRecord, QuarantineReason, SchemaFreshness } from '@pellux/goodvibes-sdk/platform/runtime/mcp/types';
21
- import type { RuntimeEventBus } from '../runtime/events/index.ts';
22
- import {
23
- emitMcpConfigured,
24
- emitMcpPolicyUpdated,
25
- emitMcpSchemaQuarantineApproved,
26
- emitMcpSchemaQuarantined,
27
- } from '../runtime/emitters/mcp.ts';
28
- import type { ConfigManager } from '../config/manager.ts';
29
- import type { McpConfigRoots } from '@pellux/goodvibes-sdk/platform/mcp/config';
30
- import { getSandboxConfigSnapshot } from '@pellux/goodvibes-sdk/platform/runtime/sandbox/manager';
31
- import type { SandboxSessionRegistry } from '@pellux/goodvibes-sdk/platform/runtime/sandbox/session-registry';
32
- import { resolveSandboxCommandPlan } from '@pellux/goodvibes-sdk/platform/runtime/sandbox/backend';
33
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
34
-
35
- function compactEnv(env: NodeJS.ProcessEnv | Record<string, string>): Record<string, string> {
36
- return Object.fromEntries(
37
- Object.entries(env).filter((entry): entry is [string, string] => typeof entry[1] === 'string'),
38
- );
39
- }
40
-
41
- export interface RegisteredTool {
42
- /** Fully-qualified tool name: mcp:<server>:<tool> */
43
- qualifiedName: string;
44
- serverName: string;
45
- toolName: string;
46
- description: string;
47
- }
48
-
49
- export class McpRegistry {
50
- private clients = new Map<string, McpClient>();
51
- private permissions = new McpPermissionManager();
52
- private freshness = new McpSchemaFreshnessTracker();
53
- private runtimeBus: RuntimeEventBus | null = null;
54
- private sandboxConfigManager: ConfigManager | null = null;
55
- private sandboxSessions: SandboxSessionRegistry;
56
- private sandboxSessionByServer = new Map<string, string>();
57
- private readonly hookDispatcher: Pick<HookDispatcher, 'fire'>;
58
-
59
- constructor(options: {
60
- readonly hookDispatcher: Pick<HookDispatcher, 'fire'>;
61
- readonly sandboxSessions: SandboxSessionRegistry;
62
- }) {
63
- this.hookDispatcher = options.hookDispatcher;
64
- this.sandboxSessions = options.sandboxSessions;
65
- }
66
-
67
- setRuntimeBus(runtimeBus: RuntimeEventBus | null): void {
68
- this.runtimeBus = runtimeBus;
69
- }
70
-
71
- setSandboxRuntime(configManager: ConfigManager, sessions: SandboxSessionRegistry): void {
72
- this.sandboxConfigManager = configManager;
73
- this.sandboxSessions = sessions;
74
- }
75
-
76
- /**
77
- * connectAll — Load config from .goodvibes/mcp.json and connect to all servers.
78
- * Errors on individual servers are logged but do not abort the whole startup.
79
- */
80
- async connectAll(roots: McpConfigRoots): Promise<void> {
81
- const mcpConfig = loadMcpConfig(roots);
82
- await Promise.allSettled(
83
- mcpConfig.servers.map((serverConfig) => this._connectServer(serverConfig)),
84
- );
85
- }
86
-
87
- /**
88
- * connectServer — Connect a single MCP server by config.
89
- * Exposed for programmatic use (testing, dynamic registration).
90
- */
91
- async connectServer(serverConfig: McpServerConfig): Promise<void> {
92
- await this._connectServer(serverConfig);
93
- }
94
-
95
- /**
96
- * listAllTools — Return all registered tools (name + description) from all connected servers.
97
- * Only loads tool names and descriptions — full schemas are NOT fetched here.
98
- */
99
- async listAllTools(): Promise<RegisteredTool[]> {
100
- const results: RegisteredTool[] = [];
101
- for (const [serverName, client] of this.clients) {
102
- if (!client.isConnected) continue;
103
- try {
104
- const tools: McpToolInfo[] = await client.listTools();
105
- for (const tool of tools) {
106
- results.push({
107
- qualifiedName: `mcp:${serverName}:${tool.name}`,
108
- serverName,
109
- toolName: tool.name,
110
- description: tool.description,
111
- });
112
- }
113
- } catch (err) {
114
- logger.info('McpRegistry: failed to list tools from server', { server: serverName, err: summarizeError(err) });
115
- }
116
- }
117
- return results;
118
- }
119
-
120
- /**
121
- * getToolSchema — Fetch full JSON schema for a qualified tool name.
122
- * Triggers lazy schema load and caches within McpClient.
123
- */
124
- async getToolSchema(qualifiedName: string): Promise<McpToolSchema | null> {
125
- const parsed = this._parseQualifiedName(qualifiedName);
126
- if (!parsed) return null;
127
- const client = this.clients.get(parsed.serverName);
128
- if (!client || !client.isConnected) return null;
129
- return client.getToolSchema(parsed.toolName);
130
- }
131
-
132
- /**
133
- * callTool — Execute a tool by its qualified name.
134
- * Fetches full schema on first use (progressive loading — F2).
135
- */
136
- async callTool(qualifiedName: string, args: Record<string, unknown>): Promise<unknown> {
137
- const parsed = this._parseQualifiedName(qualifiedName);
138
- if (!parsed) {
139
- throw new Error(`McpRegistry: invalid qualified tool name '${qualifiedName}'`);
140
- }
141
- const client = this.clients.get(parsed.serverName);
142
- if (!client) {
143
- throw new Error(`McpRegistry: no server named '${parsed.serverName}'`);
144
- }
145
- if (!client.isConnected) {
146
- throw new Error(`McpRegistry: server '${parsed.serverName}' is not connected`);
147
- }
148
- if (this.freshness.isQuarantined(parsed.serverName)) {
149
- const record = this.freshness.getRecord(parsed.serverName);
150
- throw new Error(
151
- `MCP call '${qualifiedName}' blocked: schema quarantined (${record?.quarantine?.reason ?? 'unknown'})${record?.quarantine?.detail ? ` — ${record.quarantine.detail}` : ''}`,
152
- );
153
- }
154
-
155
- const permission = this.permissions.evaluateToolCall(parsed.serverName, parsed.toolName, args);
156
- if (permission.verdict === 'deny') {
157
- throw new Error(`MCP call '${qualifiedName}' denied: ${permission.reason}`);
158
- }
159
- if (permission.verdict === 'ask') {
160
- throw new Error(`MCP call '${qualifiedName}' requires approval: ${permission.reason}`);
161
- }
162
-
163
- // Pre:mcp:call hook
164
- const dispatcher = this.hookDispatcher;
165
- const preEvent: HookEvent = {
166
- path: 'Pre:mcp:call',
167
- phase: 'Pre',
168
- category: 'mcp',
169
- specific: 'call',
170
- sessionId: '', timestamp: Date.now(),
171
- payload: { tool: qualifiedName, args },
172
- };
173
- const preResult = await dispatcher.fire(preEvent).catch(() => ({ ok: true, decision: undefined as string | undefined }));
174
- if (preResult.decision === 'deny') {
175
- throw new Error(`MCP call '${qualifiedName}' denied by hook: ${(preResult as { reason?: string }).reason ?? 'no reason'}`);
176
- }
177
-
178
- try {
179
- const result = await client.callTool(parsed.toolName, args);
180
- this.freshness.markFresh(parsed.serverName);
181
- // Post:mcp:call hook (fire-and-forget)
182
- const postEvent: HookEvent = {
183
- path: 'Post:mcp:call',
184
- phase: 'Post',
185
- category: 'mcp',
186
- specific: 'call',
187
- sessionId: '', timestamp: Date.now(),
188
- payload: { tool: qualifiedName, args },
189
- };
190
- dispatcher.fire(postEvent).catch((err: unknown) => { logger.debug('Post:mcp:call hook error', { error: summarizeError(err) }); });
191
- return result;
192
- } catch (err) {
193
- this.freshness.markFailed(parsed.serverName, summarizeError(err));
194
- // Fail:mcp:call hook (fire-and-forget)
195
- const failEvent: HookEvent = {
196
- path: 'Fail:mcp:call',
197
- phase: 'Fail',
198
- category: 'mcp',
199
- specific: 'call',
200
- sessionId: '', timestamp: Date.now(),
201
- payload: { tool: qualifiedName, args, error: summarizeError(err) },
202
- };
203
- dispatcher.fire(failEvent).catch((hookErr: unknown) => { logger.debug('Fail:mcp:call hook error', { error: String(hookErr) }); });
204
- throw err;
205
- }
206
- }
207
-
208
- /**
209
- * disconnectAll — Stop all connected MCP server processes.
210
- */
211
- async disconnectAll(): Promise<void> {
212
- // Lifecycle:mcp:disconnected hooks (fire-and-forget for each server)
213
- const dispatcher = this.hookDispatcher;
214
- for (const name of this.clients.keys()) {
215
- const disconnectedEvent: HookEvent = {
216
- path: 'Lifecycle:mcp:disconnected',
217
- phase: 'Lifecycle',
218
- category: 'mcp',
219
- specific: 'disconnected',
220
- sessionId: '', timestamp: Date.now(),
221
- payload: { server: name },
222
- };
223
- dispatcher.fire(disconnectedEvent).catch((err: unknown) => { logger.debug('Lifecycle:mcp:disconnected hook error', { error: summarizeError(err) }); });
224
- }
225
- await Promise.allSettled(
226
- Array.from(this.clients.values()).map((client) => client.disconnect()),
227
- );
228
- this.clients.clear();
229
- for (const sessionId of this.sandboxSessionByServer.values()) {
230
- this.sandboxSessions.stop(sessionId);
231
- }
232
- this.sandboxSessionByServer.clear();
233
- }
234
-
235
- /**
236
- * getClient — Get the McpClient for a given server name (for advanced use).
237
- */
238
- getClient(serverName: string): McpClient | undefined {
239
- return this.clients.get(serverName);
240
- }
241
-
242
- /** Connected server names. */
243
- get serverNames(): string[] {
244
- return Array.from(this.clients.keys());
245
- }
246
-
247
- /**
248
- * listServers — Return status info for all known servers (connected or not).
249
- */
250
- listServers(): Array<{ name: string; connected: boolean }> {
251
- return Array.from(this.clients.entries()).map(([name, client]) => ({
252
- name,
253
- connected: client.isConnected,
254
- }));
255
- }
256
-
257
- listServerSecurity(): Array<{
258
- name: string;
259
- connected: boolean;
260
- role: import('@pellux/goodvibes-sdk/platform/runtime/mcp/types').McpServerRole;
261
- trustMode: import('@pellux/goodvibes-sdk/platform/runtime/mcp/types').McpTrustMode;
262
- allowedPaths: string[];
263
- allowedHosts: string[];
264
- schemaFreshness: SchemaFreshness;
265
- quarantineReason?: QuarantineReason;
266
- quarantineDetail?: string;
267
- quarantineApprovedBy?: string;
268
- }> {
269
- return this.listServers().map((server) => {
270
- const permissions = this.permissions.getServerPermissions(server.name);
271
- const freshnessRecord = this.freshness.getRecord(server.name);
272
- return {
273
- name: server.name,
274
- connected: server.connected,
275
- role: permissions?.profile.role ?? 'general',
276
- trustMode: permissions?.profile.mode ?? 'ask-on-risk',
277
- allowedPaths: permissions?.profile.allowedPaths ?? [],
278
- allowedHosts: permissions?.profile.allowedHosts ?? [],
279
- schemaFreshness: this.freshness.getFreshness(server.name),
280
- quarantineReason: freshnessRecord?.quarantine?.reason,
281
- quarantineDetail: freshnessRecord?.quarantine?.detail,
282
- quarantineApprovedBy: freshnessRecord?.quarantine?.overrideAcknowledgedBy,
283
- };
284
- });
285
- }
286
-
287
- listServerSandboxBindings(): Array<{
288
- name: string;
289
- sessionId?: string;
290
- profileId?: 'mcp-shared' | 'mcp-per-server';
291
- state?: import('@pellux/goodvibes-sdk/platform/runtime/sandbox/types').SandboxSessionState;
292
- backend?: import('@pellux/goodvibes-sdk/platform/runtime/sandbox/types').SandboxResolvedBackend | import('@pellux/goodvibes-sdk/platform/runtime/sandbox/types').SandboxVmBackend;
293
- startupStatus?: 'verified' | 'planned' | 'failed';
294
- }> {
295
- return this.serverNames.map((name) => {
296
- const sessionId = this.sandboxSessionByServer.get(name);
297
- const session = sessionId ? this.sandboxSessions.get(sessionId) : null;
298
- return {
299
- name,
300
- sessionId: sessionId ?? undefined,
301
- profileId: session?.profileId === 'mcp-shared' || session?.profileId === 'mcp-per-server'
302
- ? session.profileId
303
- : undefined,
304
- state: session?.state,
305
- backend: session?.resolvedBackend ?? session?.backend,
306
- startupStatus: session?.startupStatus,
307
- };
308
- });
309
- }
310
-
311
- setServerTrustMode(serverName: string, mode: import('@pellux/goodvibes-sdk/platform/runtime/mcp/types').McpTrustMode): void {
312
- this.permissions.setTrustMode(serverName, mode);
313
- this._emitPolicyUpdate(serverName);
314
- }
315
-
316
- setServerRole(serverName: string, role: import('@pellux/goodvibes-sdk/platform/runtime/mcp/types').McpServerRole): void {
317
- this.permissions.setServerRole(serverName, role);
318
- this._emitPolicyUpdate(serverName);
319
- }
320
-
321
- listRecentSecurityDecisions(limit = 8): McpDecisionRecord[] {
322
- return this.permissions.listRecentDecisions(limit);
323
- }
324
-
325
- quarantineSchema(serverName: string, reason: QuarantineReason, detail?: string): void {
326
- this.freshness.markQuarantined(serverName, reason, detail);
327
- if (this.runtimeBus) {
328
- emitMcpSchemaQuarantined(this.runtimeBus, {
329
- sessionId: 'mcp-registry',
330
- traceId: `mcp-registry:${serverName}:schema-quarantined`,
331
- source: 'mcp-registry',
332
- }, { serverId: serverName, reason, ...(detail ? { detail } : {}) });
333
- }
334
- }
335
-
336
- approveSchemaQuarantine(serverName: string, operatorId: string): void {
337
- this.freshness.approveQuarantine(serverName, operatorId);
338
- if (this.runtimeBus) {
339
- emitMcpSchemaQuarantineApproved(this.runtimeBus, {
340
- sessionId: 'mcp-registry',
341
- traceId: `mcp-registry:${serverName}:schema-approved`,
342
- source: 'mcp-registry',
343
- }, { serverId: serverName, operatorId });
344
- }
345
- }
346
-
347
- // ---------------------------------------------------------------------------
348
- // Private helpers
349
- // ---------------------------------------------------------------------------
350
-
351
- private async _connectServer(serverConfig: McpServerConfig): Promise<void> {
352
- const { name } = serverConfig;
353
- if (this.clients.has(name)) {
354
- logger.info('McpRegistry: server already registered', { name });
355
- return;
356
- }
357
- let sandboxSessionId: string | null = null;
358
- let processSpec: McpProcessSpec | undefined;
359
- if (this.sandboxConfigManager) {
360
- const resolved = await this._resolveSandboxProcessSpec(serverConfig);
361
- sandboxSessionId = resolved?.sessionId ?? null;
362
- processSpec = resolved?.processSpec;
363
- }
364
- const client = new McpClient(serverConfig, processSpec ? { processSpec } : undefined);
365
- this.freshness.registerServer(name);
366
- try {
367
- await client.connect();
368
- this.permissions.registerServer(name, 'standard', {
369
- role: serverConfig.role ?? 'general',
370
- mode: serverConfig.trustMode ?? 'ask-on-risk',
371
- allowedPaths: serverConfig.allowedPaths ?? [],
372
- allowedHosts: serverConfig.allowedHosts ?? [],
373
- });
374
- this.clients.set(name, client);
375
- if (sandboxSessionId) {
376
- this.sandboxSessionByServer.set(name, sandboxSessionId);
377
- }
378
- this.freshness.markFresh(name);
379
- logger.info('McpRegistry: server connected', { name });
380
- if (this.runtimeBus) {
381
- emitMcpConfigured(this.runtimeBus, {
382
- sessionId: 'mcp-registry',
383
- traceId: `mcp-registry:${name}:configured`,
384
- source: 'mcp-registry',
385
- }, {
386
- serverId: name,
387
- transport: 'stdio',
388
- role: serverConfig.role ?? 'general',
389
- trustMode: serverConfig.trustMode ?? 'ask-on-risk',
390
- allowedPaths: serverConfig.allowedPaths ?? [],
391
- allowedHosts: serverConfig.allowedHosts ?? [],
392
- });
393
- }
394
- // Lifecycle:mcp:connected hook (fire-and-forget)
395
- const connectedEvent: HookEvent = {
396
- path: 'Lifecycle:mcp:connected',
397
- phase: 'Lifecycle',
398
- category: 'mcp',
399
- specific: 'connected',
400
- sessionId: '', timestamp: Date.now(),
401
- payload: { server: name },
402
- };
403
- this.hookDispatcher.fire(connectedEvent).catch((err: unknown) => { logger.debug('Lifecycle:mcp:connected hook error', { error: summarizeError(err) }); });
404
- } catch (err) {
405
- if (sandboxSessionId) {
406
- this.sandboxSessions.stop(sandboxSessionId);
407
- this.sandboxSessionByServer.delete(name);
408
- }
409
- this.freshness.markFailed(name, summarizeError(err));
410
- logger.error('McpRegistry: failed to connect server', { name, err: summarizeError(err) });
411
- // Don't register the client — it's not usable
412
- }
413
- }
414
-
415
- private async _resolveSandboxProcessSpec(
416
- serverConfig: McpServerConfig,
417
- ): Promise<{ sessionId: string; processSpec: McpProcessSpec } | null> {
418
- const configManager = this.sandboxConfigManager;
419
- if (!configManager) return null;
420
- const sandbox = getSandboxConfigSnapshot(configManager);
421
- if (sandbox.mcpIsolation === 'disabled') return null;
422
-
423
- const profileId = this._selectSandboxProfile(serverConfig);
424
- const label = `${serverConfig.name} MCP`;
425
- const session = await this.sandboxSessions.start(profileId, label, configManager);
426
- if (!session.launchPlan) {
427
- throw new Error(`Sandbox session ${session.id} for MCP server '${serverConfig.name}' is missing a launch plan.`);
428
- }
429
- const resolvedPlan = resolveSandboxCommandPlan(
430
- session.launchPlan,
431
- serverConfig.command,
432
- serverConfig.args ?? [],
433
- configManager,
434
- );
435
- return {
436
- sessionId: session.id,
437
- processSpec: {
438
- command: resolvedPlan.command,
439
- args: [...resolvedPlan.args],
440
- env: compactEnv({ ...(serverConfig.env ?? {}), ...(resolvedPlan.env ?? {}) }),
441
- cwd: session.launchPlan.workspaceRoot,
442
- summary: resolvedPlan.summary,
443
- sandboxSessionId: session.id,
444
- },
445
- };
446
- }
447
-
448
- private _selectSandboxProfile(serverConfig: McpServerConfig): 'mcp-shared' | 'mcp-per-server' {
449
- const configManager = this.sandboxConfigManager;
450
- if (!configManager) return 'mcp-shared';
451
- const sandbox = getSandboxConfigSnapshot(configManager);
452
- switch (sandbox.mcpIsolation) {
453
- case 'per-server-vm':
454
- return 'mcp-per-server';
455
- case 'shared-vm':
456
- return 'mcp-shared';
457
- case 'hybrid':
458
- return this._requiresDedicatedMcpSandbox(serverConfig) ? 'mcp-per-server' : 'mcp-shared';
459
- case 'disabled':
460
- default:
461
- return 'mcp-shared';
462
- }
463
- }
464
-
465
- private _requiresDedicatedMcpSandbox(serverConfig: McpServerConfig): boolean {
466
- return Boolean(
467
- (serverConfig.allowedHosts?.length ?? 0) > 0
468
- || (serverConfig.allowedPaths?.length ?? 0) > 0
469
- || serverConfig.role === 'automation'
470
- || serverConfig.role === 'browser'
471
- || serverConfig.role === 'ops'
472
- || serverConfig.role === 'remote',
473
- );
474
- }
475
-
476
- /**
477
- * Parse mcp:<server>:<tool> qualified name.
478
- * Returns null if the name doesn't match the expected format.
479
- */
480
- private _parseQualifiedName(qualifiedName: string): { serverName: string; toolName: string } | null {
481
- const parts = qualifiedName.split(':');
482
- if (parts.length < 3 || parts[0] !== 'mcp') return null;
483
- // serverName is parts[1], toolName is the rest joined (tools can have colons)
484
- const serverName = parts[1];
485
- const toolName = parts.slice(2).join(':');
486
- if (!serverName || !toolName) return null;
487
- return { serverName, toolName };
488
- }
489
-
490
- private _emitPolicyUpdate(serverName: string): void {
491
- if (!this.runtimeBus) return;
492
- const permissions = this.permissions.getServerPermissions(serverName);
493
- if (!permissions) return;
494
- emitMcpPolicyUpdated(this.runtimeBus, {
495
- sessionId: 'mcp-registry',
496
- traceId: `mcp-registry:${serverName}:policy`,
497
- source: 'mcp-registry',
498
- }, {
499
- serverId: serverName,
500
- role: permissions.profile.role,
501
- trustMode: permissions.profile.mode,
502
- allowedPaths: [...permissions.profile.allowedPaths],
503
- allowedHosts: [...permissions.profile.allowedHosts],
504
- });
505
- }
506
- }
1
+ export * from '@pellux/goodvibes-sdk/platform/mcp/registry';
@@ -1,6 +1,6 @@
1
1
  import { ArtifactStore } from '@pellux/goodvibes-sdk/platform/artifacts/index';
2
- import type { ContentPart, LLMProvider, ProviderMessage } from '../providers/interface.ts';
3
- import type { ModelDefinition, ProviderRegistry } from '../providers/registry.ts';
2
+ import type { ContentPart, LLMProvider, ProviderMessage } from '@pellux/goodvibes-sdk/platform/providers/interface';
3
+ import type { ModelDefinition, ProviderRegistry } from '@pellux/goodvibes-sdk/platform/providers/registry';
4
4
  import type {
5
5
  MediaAnalysisRequest,
6
6
  MediaAnalysisResult,