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