@pellux/goodvibes-tui 0.18.11 → 0.18.13

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 (570) hide show
  1. package/CHANGELOG.md +72 -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/config/index.ts +1 -138
  6. package/src/config/subscription-providers.ts +1 -127
  7. package/src/core/conversation-rendering.ts +5 -5
  8. package/src/core/conversation.ts +177 -424
  9. package/src/core/history.ts +45 -0
  10. package/src/core/orchestrator.ts +3 -733
  11. package/src/core/system-message-router.ts +19 -58
  12. package/src/input/command-registry.ts +3 -3
  13. package/src/input/commands/session-content.ts +2 -2
  14. package/src/input/commands/session-workflow.ts +1 -1
  15. package/src/input/handler-content-actions.ts +2 -2
  16. package/src/input/handler-feed.ts +2 -2
  17. package/src/input/handler-modal-token-routes.ts +1 -1
  18. package/src/input/handler-ui-state.ts +1 -1
  19. package/src/input/handler.ts +1 -1
  20. package/src/input/search.ts +1 -1
  21. package/src/input/selection.ts +2 -2
  22. package/src/input/session-picker-modal.ts +1 -1
  23. package/src/main.ts +1 -1
  24. package/src/panels/agent-inspector-panel.ts +3 -3
  25. package/src/panels/agent-logs-panel.ts +3 -3
  26. package/src/panels/approval-panel.ts +2 -2
  27. package/src/panels/automation-control-panel.ts +3 -3
  28. package/src/panels/base-panel.ts +14 -14
  29. package/src/panels/builtin/agent.ts +1 -0
  30. package/src/panels/builtin/operations.ts +2 -1
  31. package/src/panels/builtin/session.ts +2 -2
  32. package/src/panels/builtin/shared.ts +5 -5
  33. package/src/panels/cockpit-panel.ts +2 -2
  34. package/src/panels/communication-panel.ts +3 -3
  35. package/src/panels/context-visualizer-panel.ts +6 -3
  36. package/src/panels/control-plane-panel.ts +3 -3
  37. package/src/panels/cost-tracker-panel.ts +3 -3
  38. package/src/panels/debug-panel.ts +2 -2
  39. package/src/panels/diff-panel.ts +2 -2
  40. package/src/panels/docs-panel.ts +1 -1
  41. package/src/panels/eval-panel.ts +2 -2
  42. package/src/panels/file-explorer-panel.ts +3 -3
  43. package/src/panels/file-preview-panel.ts +3 -3
  44. package/src/panels/forensics-panel.ts +2 -2
  45. package/src/panels/git-panel.ts +1 -1
  46. package/src/panels/hooks-panel.ts +3 -3
  47. package/src/panels/incident-review-panel.ts +1 -1
  48. package/src/panels/intelligence-panel.ts +2 -2
  49. package/src/panels/knowledge-panel.ts +1 -1
  50. package/src/panels/local-auth-panel.ts +2 -2
  51. package/src/panels/marketplace-panel.ts +1 -1
  52. package/src/panels/mcp-panel.ts +3 -3
  53. package/src/panels/memory-panel.ts +1 -1
  54. package/src/panels/ops-control-panel.ts +3 -3
  55. package/src/panels/ops-strategy-panel.ts +2 -2
  56. package/src/panels/orchestration-panel.ts +2 -2
  57. package/src/panels/panel-list-panel.ts +6 -6
  58. package/src/panels/plan-dashboard-panel.ts +1 -1
  59. package/src/panels/plugins-panel.ts +2 -2
  60. package/src/panels/policy-panel.ts +2 -2
  61. package/src/panels/polish.ts +3 -3
  62. package/src/panels/provider-accounts-panel.ts +2 -2
  63. package/src/panels/provider-health-domains.ts +5 -1
  64. package/src/panels/provider-health-panel.ts +7 -3
  65. package/src/panels/provider-stats-panel.ts +3 -3
  66. package/src/panels/remote-panel.ts +3 -3
  67. package/src/panels/routes-panel.ts +3 -3
  68. package/src/panels/sandbox-panel.ts +2 -2
  69. package/src/panels/schedule-panel.ts +1 -1
  70. package/src/panels/security-panel.ts +2 -2
  71. package/src/panels/services-panel.ts +2 -2
  72. package/src/panels/session-browser-panel.ts +3 -3
  73. package/src/panels/settings-sync-panel.ts +2 -2
  74. package/src/panels/skills-panel.ts +6 -6
  75. package/src/panels/subscription-panel.ts +2 -2
  76. package/src/panels/symbol-outline-panel.ts +3 -3
  77. package/src/panels/system-messages-panel.ts +4 -4
  78. package/src/panels/tasks-panel.ts +2 -2
  79. package/src/panels/thinking-panel.ts +3 -3
  80. package/src/panels/token-budget-panel.ts +7 -3
  81. package/src/panels/tool-inspector-panel.ts +3 -3
  82. package/src/panels/types.ts +5 -5
  83. package/src/panels/watchers-panel.ts +3 -3
  84. package/src/panels/welcome-panel.ts +1 -1
  85. package/src/panels/worktree-panel.ts +2 -2
  86. package/src/panels/wrfc-panel.ts +3 -3
  87. package/src/permissions/prompt.ts +3 -22
  88. package/src/plugins/loader.ts +15 -304
  89. package/src/renderer/agent-detail-modal.ts +1 -1
  90. package/src/renderer/autocomplete-overlay.ts +2 -2
  91. package/src/renderer/bookmark-modal.ts +1 -1
  92. package/src/renderer/bottom-bar.ts +2 -2
  93. package/src/renderer/buffer.ts +1 -1
  94. package/src/renderer/code-block.ts +2 -2
  95. package/src/renderer/compositor.ts +2 -2
  96. package/src/renderer/context-inspector.ts +1 -1
  97. package/src/renderer/conversation-layout.ts +2 -2
  98. package/src/renderer/conversation-overlays.ts +1 -1
  99. package/src/renderer/conversation-surface.ts +2 -2
  100. package/src/renderer/diff-view.ts +2 -2
  101. package/src/renderer/diff.ts +1 -1
  102. package/src/renderer/file-picker-overlay.ts +2 -2
  103. package/src/renderer/file-tree.ts +2 -2
  104. package/src/renderer/help-overlay.ts +1 -1
  105. package/src/renderer/history-search-overlay.ts +2 -2
  106. package/src/renderer/live-tail-modal.ts +1 -1
  107. package/src/renderer/markdown.ts +2 -2
  108. package/src/renderer/modal-factory.ts +3 -3
  109. package/src/renderer/model-picker-overlay.ts +2 -2
  110. package/src/renderer/overlay-box.ts +2 -2
  111. package/src/renderer/panel-composite.ts +1 -1
  112. package/src/renderer/panel-picker-overlay.ts +2 -2
  113. package/src/renderer/panel-tab-bar.ts +1 -1
  114. package/src/renderer/panel-workspace-bar.ts +1 -1
  115. package/src/renderer/process-indicator.ts +2 -2
  116. package/src/renderer/process-modal.ts +1 -1
  117. package/src/renderer/profile-picker-modal.ts +2 -2
  118. package/src/renderer/progress.ts +2 -2
  119. package/src/renderer/search-overlay.ts +2 -2
  120. package/src/renderer/selection-modal-overlay.ts +2 -2
  121. package/src/renderer/session-picker-modal.ts +2 -2
  122. package/src/renderer/settings-modal.ts +2 -2
  123. package/src/renderer/shell-surface.ts +1 -1
  124. package/src/renderer/system-message.ts +1 -1
  125. package/src/renderer/tab-strip.ts +2 -2
  126. package/src/renderer/text-layout.ts +1 -1
  127. package/src/renderer/thinking.ts +1 -1
  128. package/src/renderer/tool-call.ts +2 -2
  129. package/src/renderer/ui-factory.ts +2 -2
  130. package/src/runtime/bootstrap-command-context.ts +7 -8
  131. package/src/runtime/bootstrap-command-parts.ts +4 -6
  132. package/src/runtime/bootstrap-core.ts +5 -4
  133. package/src/runtime/bootstrap-hook-bridge.ts +16 -175
  134. package/src/runtime/bootstrap-shell.ts +5 -5
  135. package/src/runtime/bootstrap.ts +6 -5
  136. package/src/runtime/context.ts +4 -20
  137. package/src/runtime/diagnostics/panels/index.ts +1 -1
  138. package/src/runtime/diagnostics/panels/ops.ts +1 -1
  139. package/src/runtime/diagnostics/panels/panel-resources.ts +118 -0
  140. package/src/runtime/perf/panel-contracts.ts +32 -0
  141. package/src/runtime/perf/panel-health-monitor.ts +18 -0
  142. package/src/runtime/services.ts +6 -6
  143. package/src/runtime/store/domains/conversation.ts +1 -181
  144. package/src/runtime/store/domains/permissions.ts +1 -143
  145. package/src/runtime/store/helpers/reducers/conversation.ts +1 -228
  146. package/src/runtime/store/helpers/reducers/lifecycle.ts +1 -440
  147. package/src/runtime/store/selectors/index.ts +11 -6
  148. package/src/runtime/store/state.ts +12 -4
  149. package/src/runtime/ui-read-models-observability-security.ts +2 -2
  150. package/src/runtime/ui-read-models-observability-system.ts +1 -1
  151. package/src/runtime/ui-service-queries.ts +1 -1
  152. package/src/runtime/ui-services.ts +1 -1
  153. package/src/shell/ui-openers.ts +1 -1
  154. package/src/tools/index.ts +1 -186
  155. package/src/types/grid.ts +48 -0
  156. package/src/utils/clipboard.ts +21 -0
  157. package/src/utils/splash-lines.ts +1 -1
  158. package/src/utils/terminal-width.ts +185 -0
  159. package/src/version.ts +1 -1
  160. package/src/acp/connection.ts +0 -447
  161. package/src/acp/index.ts +0 -7
  162. package/src/acp/manager.ts +0 -1
  163. package/src/adapters/bluebubbles/index.ts +0 -127
  164. package/src/adapters/discord/index.ts +0 -297
  165. package/src/adapters/github/index.ts +0 -73
  166. package/src/adapters/google-chat/index.ts +0 -119
  167. package/src/adapters/imessage/index.ts +0 -92
  168. package/src/adapters/index.ts +0 -15
  169. package/src/adapters/matrix/index.ts +0 -116
  170. package/src/adapters/mattermost/index.ts +0 -151
  171. package/src/adapters/msteams/index.ts +0 -180
  172. package/src/adapters/ntfy/index.ts +0 -118
  173. package/src/adapters/signal/index.ts +0 -92
  174. package/src/adapters/slack/index.ts +0 -323
  175. package/src/adapters/telegram/index.ts +0 -160
  176. package/src/adapters/types.ts +0 -97
  177. package/src/adapters/webhook/index.ts +0 -178
  178. package/src/adapters/whatsapp/index.ts +0 -135
  179. package/src/agents/message-bus-core.ts +0 -312
  180. package/src/agents/message-bus.ts +0 -2
  181. package/src/agents/orchestrator-prompts.ts +0 -351
  182. package/src/agents/orchestrator-runner.ts +0 -668
  183. package/src/agents/orchestrator.ts +0 -438
  184. package/src/agents/session.ts +0 -108
  185. package/src/agents/worktree.ts +0 -153
  186. package/src/agents/wrfc-config.ts +0 -47
  187. package/src/agents/wrfc-controller.ts +0 -747
  188. package/src/agents/wrfc-gate-runtime.ts +0 -75
  189. package/src/agents/wrfc-reporting.ts +0 -284
  190. package/src/agents/wrfc-runtime-events.ts +0 -150
  191. package/src/agents/wrfc-types.ts +0 -67
  192. package/src/automation/delivery-manager.ts +0 -368
  193. package/src/automation/index.ts +0 -72
  194. package/src/automation/manager-runtime-delivery.ts +0 -139
  195. package/src/automation/manager-runtime-events.ts +0 -131
  196. package/src/automation/manager-runtime-execution.ts +0 -511
  197. package/src/automation/manager-runtime-helpers.ts +0 -433
  198. package/src/automation/manager-runtime-job-mutations.ts +0 -175
  199. package/src/automation/manager-runtime-reconcile.ts +0 -148
  200. package/src/automation/manager-runtime-scheduling.ts +0 -189
  201. package/src/automation/manager-runtime-sync.ts +0 -54
  202. package/src/automation/manager-runtime.ts +0 -721
  203. package/src/automation/manager.ts +0 -10
  204. package/src/automation/service.ts +0 -242
  205. package/src/channels/builtin/account-actions.ts +0 -490
  206. package/src/channels/builtin/accounts.ts +0 -433
  207. package/src/channels/builtin/contracts.ts +0 -405
  208. package/src/channels/builtin/plugins.ts +0 -308
  209. package/src/channels/builtin/rendering.ts +0 -174
  210. package/src/channels/builtin/setup-schema.ts +0 -504
  211. package/src/channels/builtin/shared.ts +0 -96
  212. package/src/channels/builtin/surfaces.ts +0 -57
  213. package/src/channels/builtin/targets.ts +0 -693
  214. package/src/channels/builtin-runtime.ts +0 -443
  215. package/src/channels/delivery/shared.ts +0 -199
  216. package/src/channels/delivery/strategies-bridge.ts +0 -246
  217. package/src/channels/delivery/strategies-core.ts +0 -299
  218. package/src/channels/delivery/strategies-enterprise.ts +0 -178
  219. package/src/channels/delivery/types.ts +0 -59
  220. package/src/channels/delivery-router.ts +0 -127
  221. package/src/channels/index.ts +0 -77
  222. package/src/channels/plugin-registry.ts +0 -551
  223. package/src/channels/provider-runtime.ts +0 -330
  224. package/src/channels/reply-pipeline.ts +0 -522
  225. package/src/channels/route-manager.ts +0 -340
  226. package/src/channels/surface-registry.ts +0 -186
  227. package/src/config/helper-model.ts +0 -1
  228. package/src/config/manager.ts +0 -8
  229. package/src/config/subscription-auth.ts +0 -31
  230. package/src/config/tool-llm.ts +0 -110
  231. package/src/control-plane/approval-broker.ts +0 -351
  232. package/src/control-plane/gateway.ts +0 -1
  233. package/src/control-plane/index.ts +0 -54
  234. package/src/control-plane/media-contract-schemas.ts +0 -1
  235. package/src/control-plane/method-catalog-admin.ts +0 -1
  236. package/src/control-plane/method-catalog-channels.ts +0 -1
  237. package/src/control-plane/method-catalog-control-automation.ts +0 -1
  238. package/src/control-plane/method-catalog-control-core.ts +0 -1
  239. package/src/control-plane/method-catalog-control.ts +0 -1
  240. package/src/control-plane/method-catalog-events.ts +0 -1
  241. package/src/control-plane/method-catalog-knowledge.ts +0 -1
  242. package/src/control-plane/method-catalog-media.ts +0 -1
  243. package/src/control-plane/method-catalog-runtime.ts +0 -1
  244. package/src/control-plane/method-catalog-shared.ts +0 -1
  245. package/src/control-plane/method-catalog.ts +0 -1
  246. package/src/control-plane/operator-contract-schemas-admin.ts +0 -1
  247. package/src/control-plane/operator-contract-schemas-channels.ts +0 -1
  248. package/src/control-plane/operator-contract-schemas-control.ts +0 -1
  249. package/src/control-plane/operator-contract-schemas-domains.ts +0 -1
  250. package/src/control-plane/operator-contract-schemas-knowledge.ts +0 -1
  251. package/src/control-plane/operator-contract-schemas-media.ts +0 -1
  252. package/src/control-plane/operator-contract-schemas-permissions.ts +0 -1
  253. package/src/control-plane/operator-contract-schemas-remote.ts +0 -1
  254. package/src/control-plane/operator-contract-schemas-runtime.ts +0 -1
  255. package/src/control-plane/operator-contract-schemas-shared.ts +0 -1
  256. package/src/control-plane/operator-contract-schemas-telemetry.ts +0 -1
  257. package/src/control-plane/operator-contract-schemas.ts +0 -1
  258. package/src/control-plane/operator-contract.ts +0 -165
  259. package/src/control-plane/session-broker.ts +0 -780
  260. package/src/core/compaction-sections.ts +0 -492
  261. package/src/core/compaction-types.ts +0 -147
  262. package/src/core/context-compaction.ts +0 -542
  263. package/src/core/conversation-compaction.ts +0 -68
  264. package/src/core/conversation-diff.ts +0 -55
  265. package/src/core/conversation-utils.ts +0 -72
  266. package/src/core/event-replay.ts +0 -287
  267. package/src/core/orchestrator-context-runtime.ts +0 -407
  268. package/src/core/orchestrator-follow-up-runtime.ts +0 -134
  269. package/src/core/orchestrator-runtime.ts +0 -132
  270. package/src/core/orchestrator-tool-runtime.ts +0 -468
  271. package/src/core/orchestrator-turn-helpers.ts +0 -355
  272. package/src/core/orchestrator-turn-loop.ts +0 -443
  273. package/src/core/plan-command-handler.ts +0 -169
  274. package/src/core/transcript-events/classify.ts +0 -95
  275. package/src/core/transcript-events/index.ts +0 -15
  276. package/src/daemon/control-plane.ts +0 -522
  277. package/src/daemon/facade-composition.ts +0 -398
  278. package/src/daemon/facade.ts +0 -638
  279. package/src/daemon/helpers.ts +0 -74
  280. package/src/daemon/http/router-route-contexts.ts +0 -370
  281. package/src/daemon/http/router.ts +0 -531
  282. package/src/daemon/http-listener.ts +0 -301
  283. package/src/daemon/index.ts +0 -1
  284. package/src/daemon/server.ts +0 -1
  285. package/src/daemon/service-manager.ts +0 -413
  286. package/src/daemon/surface-actions.ts +0 -183
  287. package/src/daemon/surface-delivery.ts +0 -530
  288. package/src/daemon/surface-policy.ts +0 -60
  289. package/src/daemon/transport-events.ts +0 -110
  290. package/src/daemon/types.ts +0 -191
  291. package/src/export/markdown.ts +0 -213
  292. package/src/export/session-export.ts +0 -1
  293. package/src/git/index.ts +0 -1
  294. package/src/git/service.ts +0 -414
  295. package/src/hooks/chain-engine.ts +0 -414
  296. package/src/hooks/dispatcher.ts +0 -414
  297. package/src/hooks/hook-api.ts +0 -170
  298. package/src/hooks/index.ts +0 -48
  299. package/src/hooks/runners/agent.ts +0 -93
  300. package/src/hooks/runners/prompt.ts +0 -69
  301. package/src/hooks/workbench.ts +0 -360
  302. package/src/integrations/index.ts +0 -42
  303. package/src/integrations/notifier.ts +0 -206
  304. package/src/integrations/webhooks.ts +0 -1
  305. package/src/knowledge/consolidation.ts +0 -346
  306. package/src/knowledge/graphql.ts +0 -324
  307. package/src/knowledge/index.ts +0 -60
  308. package/src/knowledge/ingest-compile.ts +0 -386
  309. package/src/knowledge/ingest-context.ts +0 -18
  310. package/src/knowledge/ingest-inputs.ts +0 -387
  311. package/src/knowledge/ingest.ts +0 -1
  312. package/src/knowledge/internal.ts +0 -257
  313. package/src/knowledge/knowledge-api.ts +0 -432
  314. package/src/knowledge/lint.ts +0 -121
  315. package/src/knowledge/memory-sync.ts +0 -62
  316. package/src/knowledge/packet.ts +0 -370
  317. package/src/knowledge/scheduling.ts +0 -283
  318. package/src/knowledge/service.ts +0 -715
  319. package/src/mcp/client.ts +0 -383
  320. package/src/mcp/index.ts +0 -12
  321. package/src/mcp/mcp-api.ts +0 -90
  322. package/src/mcp/registry.ts +0 -1
  323. package/src/media/builtin-image-understanding.ts +0 -303
  324. package/src/media/builtin-providers.ts +0 -26
  325. package/src/media/index.ts +0 -18
  326. package/src/multimodal/index.ts +0 -13
  327. package/src/multimodal/service.ts +0 -492
  328. package/src/permissions/briefs/build.ts +0 -88
  329. package/src/permissions/manager.ts +0 -1
  330. package/src/plugins/api.ts +0 -383
  331. package/src/plugins/manager.ts +0 -481
  332. package/src/profiles/shape.ts +0 -58
  333. package/src/providers/amazon-bedrock-mantle.ts +0 -50
  334. package/src/providers/amazon-bedrock.ts +0 -61
  335. package/src/providers/anthropic-compat.ts +0 -373
  336. package/src/providers/anthropic-sdk-provider.ts +0 -230
  337. package/src/providers/anthropic-vertex.ts +0 -59
  338. package/src/providers/anthropic.ts +0 -469
  339. package/src/providers/auto-register.ts +0 -417
  340. package/src/providers/builtin-catalog.ts +0 -326
  341. package/src/providers/builtin-registry.ts +0 -575
  342. package/src/providers/cache-planner.ts +0 -258
  343. package/src/providers/capabilities.ts +0 -1
  344. package/src/providers/custom-loader.ts +0 -425
  345. package/src/providers/discovered-compat.ts +0 -7
  346. package/src/providers/discovered-factory.ts +0 -61
  347. package/src/providers/discovered-traits.ts +0 -138
  348. package/src/providers/gemini.ts +0 -462
  349. package/src/providers/github-copilot.ts +0 -254
  350. package/src/providers/index.ts +0 -1
  351. package/src/providers/interface.ts +0 -185
  352. package/src/providers/llama-cpp.ts +0 -402
  353. package/src/providers/lm-studio-helpers.ts +0 -367
  354. package/src/providers/lm-studio.ts +0 -484
  355. package/src/providers/model-catalog-cache.ts +0 -221
  356. package/src/providers/model-catalog-notifications.ts +0 -97
  357. package/src/providers/model-catalog-synthetic.ts +0 -202
  358. package/src/providers/model-catalog.ts +0 -211
  359. package/src/providers/model-limits.ts +0 -1
  360. package/src/providers/ollama.ts +0 -469
  361. package/src/providers/openai-codex.ts +0 -472
  362. package/src/providers/openai-compat.ts +0 -615
  363. package/src/providers/openai.ts +0 -231
  364. package/src/providers/optimizer.ts +0 -1
  365. package/src/providers/provider-api.ts +0 -1
  366. package/src/providers/registry-helpers.ts +0 -34
  367. package/src/providers/registry-models.ts +0 -77
  368. package/src/providers/registry-types.ts +0 -67
  369. package/src/providers/registry.ts +0 -1
  370. package/src/providers/runtime-metadata.ts +0 -149
  371. package/src/providers/runtime-snapshot.ts +0 -130
  372. package/src/providers/synthetic.ts +0 -561
  373. package/src/providers/tier-prompts.ts +0 -84
  374. package/src/providers/tool-formats.ts +0 -414
  375. package/src/runtime/auth/inspection.ts +0 -125
  376. package/src/runtime/bootstrap-background.ts +0 -157
  377. package/src/runtime/bootstrap-helpers.ts +0 -88
  378. package/src/runtime/bootstrap-runtime-events.ts +0 -254
  379. package/src/runtime/bootstrap-services.ts +0 -197
  380. package/src/runtime/compaction/index.ts +0 -1
  381. package/src/runtime/compaction/lifecycle.ts +0 -1
  382. package/src/runtime/compaction/manager.ts +0 -474
  383. package/src/runtime/compaction/quality-score.ts +0 -1
  384. package/src/runtime/compaction/resume-repair.ts +0 -1
  385. package/src/runtime/compaction/strategies/autocompact.ts +0 -1
  386. package/src/runtime/compaction/strategies/boundary-commit.ts +0 -1
  387. package/src/runtime/compaction/strategies/collapse.ts +0 -1
  388. package/src/runtime/compaction/strategies/index.ts +0 -1
  389. package/src/runtime/compaction/strategies/microcompact.ts +0 -1
  390. package/src/runtime/compaction/strategies/reactive.ts +0 -1
  391. package/src/runtime/compaction/types.ts +0 -1
  392. package/src/runtime/ecosystem/recommendations.ts +0 -117
  393. package/src/runtime/emitters/agents.ts +0 -96
  394. package/src/runtime/emitters/automation.ts +0 -112
  395. package/src/runtime/emitters/communication.ts +0 -53
  396. package/src/runtime/emitters/compaction.ts +0 -161
  397. package/src/runtime/emitters/control-plane.ts +0 -65
  398. package/src/runtime/emitters/deliveries.ts +0 -65
  399. package/src/runtime/emitters/forensics.ts +0 -17
  400. package/src/runtime/emitters/index.ts +0 -59
  401. package/src/runtime/emitters/knowledge.ts +0 -129
  402. package/src/runtime/emitters/mcp.ts +0 -95
  403. package/src/runtime/emitters/ops.ts +0 -163
  404. package/src/runtime/emitters/orchestration.ts +0 -87
  405. package/src/runtime/emitters/permissions.ts +0 -98
  406. package/src/runtime/emitters/planner.ts +0 -23
  407. package/src/runtime/emitters/plugins.ts +0 -78
  408. package/src/runtime/emitters/providers.ts +0 -30
  409. package/src/runtime/emitters/routes.ts +0 -57
  410. package/src/runtime/emitters/security.ts +0 -53
  411. package/src/runtime/emitters/session.ts +0 -93
  412. package/src/runtime/emitters/surfaces.ts +0 -57
  413. package/src/runtime/emitters/tasks.ts +0 -69
  414. package/src/runtime/emitters/tools.ts +0 -140
  415. package/src/runtime/emitters/transport.ts +0 -78
  416. package/src/runtime/emitters/turn.ts +0 -155
  417. package/src/runtime/emitters/ui.ts +0 -57
  418. package/src/runtime/emitters/watchers.ts +0 -57
  419. package/src/runtime/emitters/workflows.ts +0 -79
  420. package/src/runtime/eval/index.ts +0 -48
  421. package/src/runtime/eval/runner.ts +0 -163
  422. package/src/runtime/eval/suites.ts +0 -264
  423. package/src/runtime/events/domain-map.ts +0 -148
  424. package/src/runtime/events/index.ts +0 -1
  425. package/src/runtime/events/turn.ts +0 -1
  426. package/src/runtime/events/workflows.ts +0 -1
  427. package/src/runtime/forensics/collector.ts +0 -693
  428. package/src/runtime/forensics/index.ts +0 -23
  429. package/src/runtime/foundation-clients.ts +0 -78
  430. package/src/runtime/foundation-services.ts +0 -96
  431. package/src/runtime/guidance.ts +0 -183
  432. package/src/runtime/health/effect-handlers.ts +0 -189
  433. package/src/runtime/health/index.ts +0 -70
  434. package/src/runtime/health/wiring.ts +0 -115
  435. package/src/runtime/integration/helpers.ts +0 -640
  436. package/src/runtime/lifecycle.ts +0 -107
  437. package/src/runtime/mcp/index.ts +0 -68
  438. package/src/runtime/mcp/manager.ts +0 -513
  439. package/src/runtime/network/inbound.ts +0 -131
  440. package/src/runtime/network/index.ts +0 -30
  441. package/src/runtime/network/outbound.ts +0 -292
  442. package/src/runtime/network/shared.ts +0 -82
  443. package/src/runtime/operator-client.ts +0 -235
  444. package/src/runtime/ops/control-plane.ts +0 -363
  445. package/src/runtime/ops/index.ts +0 -122
  446. package/src/runtime/ops/playbooks/index.ts +0 -10
  447. package/src/runtime/ops/playbooks/session-unrecoverable.ts +0 -196
  448. package/src/runtime/ops/playbooks/stuck-turn.ts +0 -197
  449. package/src/runtime/ops/runtime-context.ts +0 -100
  450. package/src/runtime/ops-api.ts +0 -27
  451. package/src/runtime/orchestration/spawn-policy.ts +0 -83
  452. package/src/runtime/peer-client.ts +0 -404
  453. package/src/runtime/perf/index.ts +0 -57
  454. package/src/runtime/perf/slo-collector.ts +0 -375
  455. package/src/runtime/permissions/index.ts +0 -190
  456. package/src/runtime/permissions/policy-runtime.ts +0 -1
  457. package/src/runtime/permissions/preflight.ts +0 -101
  458. package/src/runtime/permissions/rule-suggestions.ts +0 -36
  459. package/src/runtime/plugins/hot-reload.ts +0 -221
  460. package/src/runtime/plugins/index.ts +0 -84
  461. package/src/runtime/plugins/lifecycle.ts +0 -95
  462. package/src/runtime/plugins/manager.ts +0 -474
  463. package/src/runtime/plugins/manifest.ts +0 -167
  464. package/src/runtime/plugins/quarantine.ts +0 -202
  465. package/src/runtime/plugins/trust.ts +0 -291
  466. package/src/runtime/plugins/types.ts +0 -205
  467. package/src/runtime/provider-accounts/registry.ts +0 -326
  468. package/src/runtime/remote/distributed-runtime-contract-schemas.ts +0 -386
  469. package/src/runtime/remote/index.ts +0 -488
  470. package/src/runtime/remote/runner-registry.ts +0 -438
  471. package/src/runtime/remote/supervisor.ts +0 -70
  472. package/src/runtime/runtime-hook-api.ts +0 -5
  473. package/src/runtime/runtime-knowledge-api.ts +0 -14
  474. package/src/runtime/runtime-mcp-api.ts +0 -5
  475. package/src/runtime/runtime-ops-api.ts +0 -86
  476. package/src/runtime/runtime-provider-api.ts +0 -18
  477. package/src/runtime/session-maintenance.ts +0 -188
  478. package/src/runtime/session-persistence.ts +0 -288
  479. package/src/runtime/session-return-context.ts +0 -195
  480. package/src/runtime/settings/control-plane-store.ts +0 -258
  481. package/src/runtime/settings/control-plane.ts +0 -599
  482. package/src/runtime/shell-command-extensions.ts +0 -54
  483. package/src/runtime/shell-command-ops.ts +0 -207
  484. package/src/runtime/shell-command-platform.ts +0 -47
  485. package/src/runtime/shell-command-services.ts +0 -143
  486. package/src/runtime/shell-command-workspace.ts +0 -31
  487. package/src/runtime/tasks/adapters/acp-adapter.ts +0 -211
  488. package/src/runtime/tasks/adapters/agent-adapter.ts +0 -208
  489. package/src/runtime/tasks/adapters/index.ts +0 -16
  490. package/src/runtime/tasks/adapters/process-adapter.ts +0 -214
  491. package/src/runtime/tasks/adapters/scheduler-adapter.ts +0 -193
  492. package/src/runtime/tasks/index.ts +0 -68
  493. package/src/runtime/tasks/manager.ts +0 -415
  494. package/src/runtime/telemetry/api-helpers.ts +0 -517
  495. package/src/runtime/telemetry/api.ts +0 -768
  496. package/src/runtime/telemetry/index.ts +0 -178
  497. package/src/runtime/telemetry/instrumentation/domain-bridge-agent-session.ts +0 -440
  498. package/src/runtime/telemetry/instrumentation/domain-bridge-plugin-mcp.ts +0 -200
  499. package/src/runtime/telemetry/instrumentation/domain-bridge-shared.ts +0 -18
  500. package/src/runtime/telemetry/instrumentation/domain-bridge-transport-task.ts +0 -204
  501. package/src/runtime/telemetry/instrumentation/domain-bridge.ts +0 -125
  502. package/src/runtime/telemetry/instrumentation/index.ts +0 -67
  503. package/src/runtime/tools/context.ts +0 -114
  504. package/src/runtime/tools/index.ts +0 -46
  505. package/src/runtime/tools/phased-executor.ts +0 -448
  506. package/src/runtime/tools/phases/budget.ts +0 -130
  507. package/src/runtime/tools/phases/execute.ts +0 -69
  508. package/src/runtime/tools/phases/index.ts +0 -13
  509. package/src/runtime/tools/phases/map-output.ts +0 -98
  510. package/src/runtime/tools/phases/permission.ts +0 -133
  511. package/src/runtime/tools/phases/posthook.ts +0 -57
  512. package/src/runtime/tools/phases/prehook.ts +0 -68
  513. package/src/runtime/tools/phases/validate.ts +0 -53
  514. package/src/runtime/transports/direct.ts +0 -73
  515. package/src/runtime/transports/http-helpers.ts +0 -218
  516. package/src/runtime/transports/http-types.ts +0 -364
  517. package/src/runtime/transports/http.ts +0 -629
  518. package/src/runtime/transports/realtime.ts +0 -50
  519. package/src/runtime/transports/remote-events.ts +0 -16
  520. package/src/runtime/transports/shared.ts +0 -39
  521. package/src/runtime/transports/ui-runtime-events.ts +0 -35
  522. package/src/runtime/ui-read-models-core.ts +0 -95
  523. package/src/runtime/ui-read-models-operations.ts +0 -203
  524. package/src/runtime/worktree/registry.ts +0 -252
  525. package/src/sessions/manager.ts +0 -14
  526. package/src/state/file-watcher.ts +0 -294
  527. package/src/state/index.ts +0 -56
  528. package/src/state/knowledge-injection.ts +0 -214
  529. package/src/state/memory-embedding-http.ts +0 -642
  530. package/src/state/memory-embeddings.ts +0 -312
  531. package/src/state/memory-ingest.ts +0 -132
  532. package/src/state/memory-registry.ts +0 -111
  533. package/src/state/memory-store-helpers.ts +0 -160
  534. package/src/state/memory-store.ts +0 -728
  535. package/src/state/memory-vector-store.ts +0 -418
  536. package/src/templates/manager.ts +0 -187
  537. package/src/tools/agent/index.ts +0 -610
  538. package/src/tools/agent/manager.ts +0 -476
  539. package/src/tools/analyze/git-modes.ts +0 -380
  540. package/src/tools/analyze/index.ts +0 -128
  541. package/src/tools/channel/agent-tools.ts +0 -16
  542. package/src/tools/channel/index.ts +0 -268
  543. package/src/tools/control/index.ts +0 -90
  544. package/src/tools/edit/core.ts +0 -619
  545. package/src/tools/edit/index.ts +0 -4
  546. package/src/tools/edit/phased.ts +0 -33
  547. package/src/tools/fetch/index.ts +0 -3
  548. package/src/tools/fetch/phased.ts +0 -34
  549. package/src/tools/fetch/runtime.ts +0 -499
  550. package/src/tools/mcp/index.ts +0 -190
  551. package/src/tools/remote-trigger/index.ts +0 -130
  552. package/src/tools/shared/auto-heal.ts +0 -282
  553. package/src/tools/state/index.ts +0 -688
  554. package/src/tools/web-search/index.ts +0 -38
  555. package/src/tools/write/index.ts +0 -604
  556. package/src/tools/write/phased.ts +0 -41
  557. package/src/types/generated/foundation-client-types.ts +0 -22
  558. package/src/watchers/index.ts +0 -11
  559. package/src/watchers/registry.ts +0 -517
  560. package/src/web-search/index.ts +0 -26
  561. package/src/web-search/provider-registry.ts +0 -64
  562. package/src/web-search/providers/brave.ts +0 -100
  563. package/src/web-search/providers/duckduckgo.ts +0 -270
  564. package/src/web-search/providers/exa.ts +0 -77
  565. package/src/web-search/providers/firecrawl.ts +0 -90
  566. package/src/web-search/providers/perplexity.ts +0 -86
  567. package/src/web-search/providers/searxng.ts +0 -88
  568. package/src/web-search/providers/shared.ts +0 -249
  569. package/src/web-search/providers/tavily.ts +0 -90
  570. package/src/web-search/service.ts +0 -142
@@ -1,202 +0,0 @@
1
- /**
2
- * Plugin quarantine engine.
3
- *
4
- * Quarantine removes a plugin's unsafe contribution effects without fully
5
- * unloading it. This allows the operator to isolate a suspicious plugin,
6
- * inspect it, then either restore or permanently disable it.
7
- *
8
- * Quarantine effects:
9
- * - All high-risk capabilities are revoked in the resolved manifest.
10
- * - The plugin is moved to a `quarantined` lifecycle bucket in the store.
11
- * - A quarantine record is created with a timestamp and reason.
12
- *
13
- * Restore path:
14
- * - `lift()` — Restores previously revoked capabilities (if trust was upgraded).
15
- * - The caller is responsible for reloading the plugin after lifting.
16
- */
17
-
18
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
19
- import type { PluginCapability, PluginCapabilityManifest } from '@pellux/goodvibes-sdk/platform/runtime/plugins/types';
20
- import { isHighRiskCapability } from '@pellux/goodvibes-sdk/platform/runtime/plugins/manifest';
21
-
22
- // ── Quarantine Record ─────────────────────────────────────────────────────────
23
-
24
- /**
25
- * A record describing a plugin currently in quarantine.
26
- */
27
- export interface QuarantineRecord {
28
- /** Plugin name. */
29
- readonly pluginName: string;
30
- /** Unix epoch ms when quarantine was applied. */
31
- readonly quarantinedAt: number;
32
- /** Human-readable reason for quarantine. */
33
- readonly reason: string;
34
- /** The capabilities that were revoked when quarantine was applied. */
35
- readonly revokedCapabilities: ReadonlyArray<PluginCapability>;
36
- /** Whether the quarantine has been lifted. */
37
- lifted: boolean;
38
- /** Unix epoch ms when quarantine was lifted, if applicable. */
39
- liftedAt?: number;
40
- }
41
-
42
- // ── Quarantine Engine ─────────────────────────────────────────────────────────
43
-
44
- /**
45
- * PluginQuarantineEngine — Tracks quarantined plugins and applies/revokes
46
- * capability restrictions.
47
- *
48
- * This is intentionally separate from the PluginLifecycleManager so that
49
- * quarantine can be applied without triggering a full state machine transition.
50
- * The lifecycle manager delegates to this engine when quarantine is requested.
51
- */
52
- export class PluginQuarantineEngine {
53
- private readonly records = new Map<string, QuarantineRecord>();
54
-
55
- /**
56
- * quarantine — Apply quarantine to a plugin.
57
- *
58
- * Revokes all high-risk capabilities from the plugin's resolved manifest
59
- * and creates a quarantine record. The plugin remains in memory but its
60
- * unsafe contributions are neutralised.
61
- *
62
- * @param pluginName - Plugin identifier.
63
- * @param capabilityManifest - The plugin's live capability manifest (mutated in place).
64
- * @param reason - Human-readable reason for quarantine.
65
- * @returns The quarantine record, or null if already quarantined.
66
- */
67
- quarantine(
68
- pluginName: string,
69
- capabilityManifest: PluginCapabilityManifest,
70
- reason: string,
71
- ): QuarantineRecord | null {
72
- if (this.isQuarantined(pluginName)) {
73
- logger.warn(`[plugin-quarantine] ${pluginName}: already quarantined — skipping`);
74
- return null;
75
- }
76
-
77
- // Identify which currently-granted capabilities are high-risk.
78
- const revokedCapabilities: PluginCapability[] = capabilityManifest.granted.filter(
79
- (cap) => isHighRiskCapability(cap),
80
- );
81
-
82
- // Strip high-risk capabilities from the live manifest.
83
- capabilityManifest.granted = capabilityManifest.granted.filter(
84
- (cap) => !isHighRiskCapability(cap),
85
- );
86
-
87
- // Record denied reason for each revoked cap. Collect first, then assign once.
88
- const newDenied: PluginCapability[] = [];
89
- for (const cap of revokedCapabilities) {
90
- newDenied.push(cap);
91
- capabilityManifest.denialReasons[cap] = `Capability '${cap}' revoked: plugin quarantined — ${reason}`;
92
- }
93
- capabilityManifest.denied = [...capabilityManifest.denied, ...newDenied];
94
-
95
- const record: QuarantineRecord = {
96
- pluginName,
97
- quarantinedAt: Date.now(),
98
- reason,
99
- revokedCapabilities: Object.freeze(revokedCapabilities),
100
- lifted: false,
101
- };
102
-
103
- this.records.set(pluginName, record);
104
-
105
- logger.warn(
106
- `[plugin-quarantine] ${pluginName}: quarantined — ${reason}` +
107
- (revokedCapabilities.length > 0
108
- ? ` (revoked: [${revokedCapabilities.join(', ')}])`
109
- : ' (no high-risk capabilities were granted)'),
110
- );
111
-
112
- return record;
113
- }
114
-
115
- /**
116
- * lift — Lift quarantine for a plugin.
117
- *
118
- * Previously revoked capabilities are NOT automatically restored here;
119
- * the caller should trigger a re-resolve of the capability manifest
120
- * (e.g. by reloading the plugin) after lifting so that trust-tier
121
- * constraints are re-evaluated with the new tier.
122
- *
123
- * @returns true if quarantine was successfully lifted; false if not found.
124
- */
125
- lift(pluginName: string): boolean {
126
- const record = this.records.get(pluginName);
127
- if (!record) {
128
- logger.debug(`[plugin-quarantine] ${pluginName}: no quarantine record found — nothing to lift`);
129
- return false;
130
- }
131
- if (record.lifted) {
132
- logger.debug(`[plugin-quarantine] ${pluginName}: quarantine already lifted`);
133
- return false;
134
- }
135
-
136
- record.lifted = true;
137
- record.liftedAt = Date.now();
138
-
139
- logger.info(`[plugin-quarantine] ${pluginName}: quarantine lifted`);
140
- return true;
141
- }
142
-
143
- /** Returns whether a plugin is currently quarantined (and not lifted). */
144
- isQuarantined(pluginName: string): boolean {
145
- const record = this.records.get(pluginName);
146
- return record !== undefined && !record.lifted;
147
- }
148
-
149
- /** Returns the quarantine record for a plugin, or undefined. */
150
- getRecord(pluginName: string): Readonly<QuarantineRecord> | undefined {
151
- return this.records.get(pluginName);
152
- }
153
-
154
- /** Returns all quarantine records (including lifted ones). */
155
- getAllRecords(): ReadonlyArray<Readonly<QuarantineRecord>> {
156
- return Array.from(this.records.values());
157
- }
158
-
159
- /** Returns only active (not-lifted) quarantine records. */
160
- getActiveQuarantines(): ReadonlyArray<Readonly<QuarantineRecord>> {
161
- return Array.from(this.records.values()).filter((r) => !r.lifted);
162
- }
163
-
164
- /**
165
- * applyToNewManifest — Apply quarantine constraints to a freshly-resolved
166
- * capability manifest. Used when a plugin is reloaded while under quarantine.
167
- *
168
- * Unlike `quarantine()`, this does not create a new record — it reuses the
169
- * existing one. Call this during manifest re-resolution if `isQuarantined()`
170
- * is true.
171
- */
172
- applyToNewManifest(
173
- pluginName: string,
174
- capabilityManifest: PluginCapabilityManifest,
175
- ): void {
176
- if (!this.isQuarantined(pluginName)) return;
177
-
178
- const toRevoke: PluginCapability[] = capabilityManifest.granted.filter(
179
- (cap) => isHighRiskCapability(cap),
180
- );
181
-
182
- if (toRevoke.length === 0) return;
183
-
184
- capabilityManifest.granted = capabilityManifest.granted.filter(
185
- (cap) => !isHighRiskCapability(cap),
186
- );
187
-
188
- // Collect all denied caps first, then assign once to avoid quadratic churn.
189
- const reason = this.records.get(pluginName)?.reason ?? 'quarantined';
190
- const newDenied: PluginCapability[] = [];
191
- for (const cap of toRevoke) {
192
- newDenied.push(cap);
193
- capabilityManifest.denialReasons[cap] = `Capability '${cap}' blocked: plugin is quarantined — ${reason}`;
194
- }
195
- capabilityManifest.denied = [...capabilityManifest.denied, ...newDenied];
196
-
197
- logger.debug(
198
- `[plugin-quarantine] ${pluginName}: quarantine re-applied to reloaded manifest` +
199
- ` (blocked: [${toRevoke.join(', ')}])`,
200
- );
201
- }
202
- }
@@ -1,291 +0,0 @@
1
- /**
2
- * Plugin extension trust framework.
3
- *
4
- * Defines trust tiers (untrusted, limited, trusted), signed manifest
5
- * validation for the trusted tier, and the PluginTrustStore that manages
6
- * trust records with persistence support.
7
- *
8
- * Trust tiers gate access to high-risk capabilities:
9
- * - untrusted — only safe, read-only capabilities allowed
10
- * - limited — moderate capabilities; high-risk capabilities blocked
11
- * - trusted — full capability set; requires signed manifest validation
12
- */
13
-
14
- import { createHmac, timingSafeEqual } from 'node:crypto';
15
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
16
- import type { PluginCapability } from '@pellux/goodvibes-sdk/platform/runtime/plugins/types';
17
- import { isHighRiskCapability } from '@pellux/goodvibes-sdk/platform/runtime/plugins/manifest';
18
-
19
- // ── Trust Tier ────────────────────────────────────────────────────────────────
20
-
21
- /**
22
- * The three trust tiers available to a plugin.
23
- *
24
- * - `untrusted` — Default for newly discovered plugins. Only safe capabilities
25
- * are accessible. The plugin may not have been reviewed.
26
- * - `limited` — Operator-reviewed plugin. Moderate capabilities granted.
27
- * High-risk capabilities (shell.exec, filesystem.write, network.outbound)
28
- * remain blocked without explicit trust escalation.
29
- * - `trusted` — Fully trusted plugin. Requires a valid signed manifest.
30
- * All declared capabilities may be granted (subject to runtime policy).
31
- */
32
- export type PluginTrustTier = 'untrusted' | 'limited' | 'trusted';
33
-
34
- // ── Trust Record ──────────────────────────────────────────────────────────────
35
-
36
- /**
37
- * A persisted trust record for a single plugin.
38
- */
39
- export interface PluginTrustRecord {
40
- /** Plugin identifier (manifest name). */
41
- readonly pluginName: string;
42
- /** Current trust tier. */
43
- tier: PluginTrustTier;
44
- /** Unix epoch ms when the trust record was last updated. */
45
- updatedAt: number;
46
- /** Who or what granted this trust level. */
47
- grantedBy: 'operator' | 'signed-manifest';
48
- /**
49
- * Fingerprint of the verified signature for trusted-tier plugins.
50
- * Undefined for untrusted/limited plugins.
51
- */
52
- signatureFingerprint?: string;
53
- /** Optional human-readable note attached by the operator. */
54
- note?: string;
55
- }
56
-
57
- // ── Signature Validation ──────────────────────────────────────────────────────
58
-
59
- /**
60
- * Result of validating a plugin's signed manifest.
61
- */
62
- export interface SignatureValidationResult {
63
- /** Whether the signature is valid. */
64
- valid: boolean;
65
- /** A stable fingerprint derived from the signature (e.g. hex digest prefix). */
66
- fingerprint?: string;
67
- /** Human-readable failure reason. Only set when `valid` is false. */
68
- reason?: string;
69
- }
70
-
71
- /**
72
- * validatePluginSignature — Validates the manifest signature for a plugin
73
- * seeking the `trusted` tier.
74
- *
75
- * The signature field in PluginManifestV2 is expected to be a base64-encoded
76
- * HMAC-SHA256 of the canonical manifest JSON (name + version + capabilities
77
- * sorted and serialised). For production use, callers should supply a real
78
- * key; this implementation uses a structural check so external tooling can
79
- * provide real crypto without requiring Node.js crypto APIs at import time.
80
- *
81
- * @param manifest - The raw manifest object containing the `signature` field.
82
- * @param publicKey - Optional verification key. When omitted, structural
83
- * validity only is checked (suitable for CI/test).
84
- */
85
- export function validatePluginSignature(
86
- manifest: { name: string; version: string; capabilities?: string[]; signature?: string },
87
- publicKey?: string,
88
- ): SignatureValidationResult {
89
- const { name, version, capabilities = [], signature } = manifest;
90
-
91
- if (!signature || typeof signature !== 'string' || signature.trim().length === 0) {
92
- return { valid: false, reason: 'No signature field present in manifest' };
93
- }
94
-
95
- // Structural check: signature must be a non-empty hex or base64 string.
96
- const isStructurallyValid = /^[A-Za-z0-9+/=]{32,}$/.test(signature.trim());
97
- if (!isStructurallyValid) {
98
- return { valid: false, reason: 'Signature field does not match expected format (base64/hex, min 32 chars)' };
99
- }
100
-
101
- // Canonical payload that should have been signed.
102
- const sortedCapabilities = [...capabilities].sort();
103
- const payload = JSON.stringify({ name, version, capabilities: sortedCapabilities });
104
-
105
- // When a public key is provided, perform full HMAC verification.
106
- if (publicKey) {
107
- const expected = createHmac('sha256', publicKey)
108
- .update(payload)
109
- .digest('base64');
110
- const sigBuf = Buffer.from(signature.trim(), 'base64');
111
- const expBuf = Buffer.from(expected, 'base64');
112
- if (sigBuf.length !== expBuf.length || !timingSafeEqual(sigBuf, expBuf)) {
113
- return { valid: false, reason: 'HMAC mismatch' };
114
- }
115
- }
116
-
117
- // Derive a short fingerprint for record keeping.
118
- const fingerprint = signature.trim().slice(0, 16);
119
-
120
- logger.debug(
121
- `[plugin-trust] Manifest signature validated — plugin=${name} fingerprint=${fingerprint}` +
122
- (publicKey ? ' (full HMAC)' : ' (structural only)'),
123
- );
124
-
125
- return { valid: true, fingerprint };
126
- }
127
-
128
- // ── Capability filtering by trust tier ───────────────────────────────────────
129
-
130
- /**
131
- * Capabilities that are safe for any trust tier (including untrusted).
132
- */
133
- export const SAFE_CAPABILITIES: ReadonlyArray<PluginCapability> = [
134
- 'register.tool',
135
- 'register.provider',
136
- 'register.panel',
137
- 'register.hook',
138
- 'filesystem.read',
139
- ] as const;
140
-
141
- /**
142
- * filterCapabilitiesByTrust — Returns the subset of `requested` capabilities
143
- * that are permitted for the given trust tier.
144
- *
145
- * - `untrusted`: only SAFE_CAPABILITIES
146
- * - `limited`: all capabilities except HIGH_RISK_CAPABILITIES
147
- * - `trusted`: all capabilities (HIGH_RISK_CAPABILITIES included)
148
- */
149
- export function filterCapabilitiesByTrust(
150
- requested: ReadonlyArray<PluginCapability>,
151
- tier: PluginTrustTier,
152
- ): { permitted: PluginCapability[]; blocked: PluginCapability[]; reasons: Partial<Record<PluginCapability, string>> } {
153
- const permitted: PluginCapability[] = [];
154
- const blocked: PluginCapability[] = [];
155
- const reasons: Partial<Record<PluginCapability, string>> = {};
156
-
157
- for (const cap of requested) {
158
- if (tier === 'trusted') {
159
- permitted.push(cap);
160
- } else if (tier === 'limited') {
161
- if (isHighRiskCapability(cap)) {
162
- blocked.push(cap);
163
- reasons[cap] = `Capability '${cap}' requires trust tier 'trusted' (current: limited)`;
164
- } else {
165
- permitted.push(cap);
166
- }
167
- } else {
168
- // untrusted
169
- if ((SAFE_CAPABILITIES as ReadonlyArray<string>).includes(cap)) {
170
- permitted.push(cap);
171
- } else {
172
- blocked.push(cap);
173
- reasons[cap] = `Capability '${cap}' requires trust tier 'limited' or higher (current: untrusted)`;
174
- }
175
- }
176
- }
177
-
178
- return { permitted, blocked, reasons };
179
- }
180
-
181
- // ── Trust Store ───────────────────────────────────────────────────────────────
182
-
183
- /**
184
- * PluginTrustStore — In-memory trust registry for all plugins.
185
- *
186
- * Callers are responsible for persistence (serialise/deserialise via
187
- * `exportRecords` / `importRecords`). The PluginManager bridges this to
188
- * the plugins.json state file.
189
- */
190
- export class PluginTrustStore {
191
- private readonly records = new Map<string, PluginTrustRecord>();
192
-
193
- /**
194
- * Returns the trust record for a plugin, or `undefined` if not yet assessed.
195
- * Callers should treat `undefined` as implicitly `untrusted`.
196
- */
197
- getRecord(pluginName: string): Readonly<PluginTrustRecord> | undefined {
198
- return this.records.get(pluginName);
199
- }
200
-
201
- /**
202
- * Returns the trust tier for a plugin.
203
- * Plugins without an explicit record are treated as `untrusted`.
204
- */
205
- getTier(pluginName: string): PluginTrustTier {
206
- return this.records.get(pluginName)?.tier ?? 'untrusted';
207
- }
208
-
209
- /**
210
- * setTier — Explicitly assign a trust tier to a plugin.
211
- *
212
- * Intended for operator use via `/plugin trust`.
213
- * For the `trusted` tier, prefer `trustSigned()` which also validates the signature.
214
- */
215
- setTier(
216
- pluginName: string,
217
- tier: PluginTrustTier,
218
- options: { note?: string } = {},
219
- ): PluginTrustRecord {
220
- const record: PluginTrustRecord = {
221
- pluginName,
222
- tier,
223
- updatedAt: Date.now(),
224
- grantedBy: 'operator',
225
- note: options.note,
226
- };
227
- this.records.set(pluginName, record);
228
- logger.info(`[plugin-trust] ${pluginName}: tier set to '${tier}'${options.note ? ` — ${options.note}` : ''}`);
229
- return record;
230
- }
231
-
232
- /**
233
- * trustSigned — Elevate a plugin to the `trusted` tier after verifying its
234
- * signed manifest. Returns `{ ok: false, reason }` if validation fails.
235
- */
236
- trustSigned(
237
- pluginName: string,
238
- manifest: { name: string; version: string; capabilities?: string[]; signature?: string },
239
- publicKey?: string,
240
- ): { ok: true; record: PluginTrustRecord } | { ok: false; reason: string } {
241
- const validation = validatePluginSignature(manifest, publicKey);
242
- if (!validation.valid) {
243
- logger.warn(`[plugin-trust] ${pluginName}: signature validation failed — ${validation.reason}`);
244
- return { ok: false, reason: validation.reason! };
245
- }
246
-
247
- const record: PluginTrustRecord = {
248
- pluginName,
249
- tier: 'trusted',
250
- updatedAt: Date.now(),
251
- grantedBy: 'signed-manifest',
252
- signatureFingerprint: validation.fingerprint,
253
- };
254
- this.records.set(pluginName, record);
255
- logger.info(`[plugin-trust] ${pluginName}: elevated to 'trusted' via signed manifest (fingerprint=${validation.fingerprint})`);
256
- return { ok: true, record };
257
- }
258
-
259
- /**
260
- * verify — Verify the current signature on a plugin manifest without
261
- * changing its tier. Useful for `/plugin verify` inspection.
262
- */
263
- verify(
264
- manifest: { name: string; version: string; capabilities?: string[]; signature?: string },
265
- publicKey?: string,
266
- ): SignatureValidationResult {
267
- return validatePluginSignature(manifest, publicKey);
268
- }
269
-
270
- /** Returns all trust records as an array. */
271
- getAllRecords(): ReadonlyArray<Readonly<PluginTrustRecord>> {
272
- return Array.from(this.records.values());
273
- }
274
-
275
- /** Export all records for persistence. */
276
- exportRecords(): Record<string, PluginTrustRecord> {
277
- const out: Record<string, PluginTrustRecord> = {};
278
- for (const [name, record] of this.records) {
279
- out[name] = { ...record };
280
- }
281
- return out;
282
- }
283
-
284
- /** Import records from persisted state. Merges into existing records. */
285
- importRecords(records: Record<string, PluginTrustRecord>): void {
286
- for (const [name, record] of Object.entries(records)) {
287
- this.records.set(name, record);
288
- }
289
- logger.debug(`[plugin-trust] Imported ${Object.keys(records).length} trust record(s)`);
290
- }
291
- }
@@ -1,205 +0,0 @@
1
- /**
2
- * Plugin lifecycle system types.
3
- *
4
- * Types here extend the store domain types with the richer capability
5
- * manifest and transition models used by the PluginLifecycleManager.
6
- */
7
-
8
- import type { PluginLifecycleState } from '@pellux/goodvibes-sdk/platform/runtime/store/domains/plugins';
9
- import type { PluginManifest } from '../../plugins/loader';
10
-
11
- // Re-export so consumers only need to import from this module.
12
- export type { PluginLifecycleState } from '@pellux/goodvibes-sdk/platform/runtime/store/domains/plugins';
13
-
14
- // ── Capability manifest ───────────────────────────────────────────────────────
15
-
16
- /**
17
- * The set of capabilities a plugin can declare in its manifest.
18
- *
19
- * All capabilities are **deny-by-default**: a plugin must explicitly request
20
- * each capability and the runtime must grant it before the capability is
21
- * exercisable.
22
- */
23
- export type PluginCapability =
24
- | 'filesystem.read'
25
- | 'filesystem.write'
26
- | 'network.outbound'
27
- | 'shell.exec'
28
- | 'register.tool'
29
- | 'register.provider'
30
- | 'register.panel'
31
- | 'register.hook';
32
-
33
- /** All defined capability strings as a readonly array. */
34
- export const ALL_CAPABILITIES: ReadonlyArray<PluginCapability> = [
35
- 'filesystem.read',
36
- 'filesystem.write',
37
- 'network.outbound',
38
- 'shell.exec',
39
- 'register.tool',
40
- 'register.provider',
41
- 'register.panel',
42
- 'register.hook',
43
- ] as const;
44
-
45
- /**
46
- * High-risk capabilities that require the `trusted` tier to be granted.
47
- * These capabilities can have significant side-effects outside the process.
48
- */
49
- export const HIGH_RISK_CAPABILITIES: ReadonlyArray<PluginCapability> = [
50
- 'filesystem.write',
51
- 'network.outbound',
52
- 'shell.exec',
53
- ] as const;
54
-
55
- /**
56
- * Capability manifest embedded in (or derived from) a plugin's manifest.json.
57
- *
58
- * `requested` lists every capability the plugin declares it needs.
59
- * `granted` is resolved by the runtime after validation — it may be a strict
60
- * subset of `requested` if some capabilities are denied by policy.
61
- */
62
- export interface PluginCapabilityManifest {
63
- /** Capabilities declared by the plugin author. */
64
- readonly requested: ReadonlyArray<PluginCapability>;
65
- /** Capabilities actually granted by the runtime. Populated after resolution. */
66
- granted: PluginCapability[];
67
- /** Capabilities that were requested but explicitly denied by runtime policy. */
68
- denied: PluginCapability[];
69
- /** Human-readable denial reasons keyed by capability. */
70
- denialReasons: Partial<Record<PluginCapability, string>>;
71
- }
72
-
73
- // ── Extended plugin manifest ──────────────────────────────────────────────────
74
-
75
- /**
76
- * PluginManifestV2 extends the loader's PluginManifest with capability
77
- * declarations and trust framework fields.
78
- * Stored inside manifest.json under the `capabilities` key.
79
- * Omitting the key is equivalent to requesting no capabilities.
80
- */
81
- export interface PluginManifestV2 extends PluginManifest {
82
- /** Optional capability list declared by the plugin. */
83
- capabilities?: PluginCapability[];
84
- /**
85
- * Minimum runtime version this plugin requires.
86
- * Semver string (e.g. "0.9.0"). Unset = no constraint.
87
- */
88
- minRuntimeVersion?: string;
89
- /**
90
- * Base64-encoded HMAC-SHA256 signature of the canonical manifest payload.
91
- * Required for plugins that want to operate at the `trusted` tier.
92
- */
93
- signature?: string;
94
- /**
95
- * Declared trust tier hint from the plugin author.
96
- * The runtime validates this against the actual trust record; it does not
97
- * grant trust by itself.
98
- */
99
- trustTier?: import('./trust.ts').PluginTrustTier;
100
- }
101
-
102
- // ── State machine ─────────────────────────────────────────────────────────────
103
-
104
- /**
105
- * A single recorded state transition for a plugin.
106
- */
107
- export interface PluginTransition {
108
- /** The plugin name this transition applies to. */
109
- readonly pluginName: string;
110
- /** State before the transition. */
111
- readonly from: PluginLifecycleState;
112
- /** State after the transition. */
113
- readonly to: PluginLifecycleState;
114
- /** Unix timestamp (ms) when the transition occurred. */
115
- readonly ts: number;
116
- /** Optional human-readable reason (e.g. error message, disable reason). */
117
- readonly reason?: string;
118
- }
119
-
120
- /**
121
- * Result of a state machine transition attempt.
122
- */
123
- export type TransitionResult =
124
- | { ok: true; from: PluginLifecycleState; to: PluginLifecycleState }
125
- | { ok: false; reason: string };
126
-
127
- // ── Health check ─────────────────────────────────────────────────────────────
128
-
129
- /**
130
- * Result of a plugin health check (used during hot-reload).
131
- */
132
- export interface PluginHealthCheckResult {
133
- /** Whether the plugin is considered healthy after the check. */
134
- readonly healthy: boolean;
135
- /** Human-readable status message. */
136
- readonly message: string;
137
- /** Duration of the health check in milliseconds. */
138
- readonly durationMs: number;
139
- }
140
-
141
- // ── Runtime plugin record ─────────────────────────────────────────────────────
142
-
143
- /**
144
- * PluginLifecycleRecord — full runtime record for a plugin tracked by the
145
- * PluginLifecycleManager. Extends the basic RuntimePlugin from the store
146
- * domain with the capability manifest and transition history.
147
- */
148
- export interface PluginLifecycleRecord {
149
- /** Plugin name (filesystem identifier). */
150
- readonly name: string;
151
- /** Plugin version string. */
152
- readonly version: string;
153
- /** Current lifecycle state. */
154
- state: PluginLifecycleState;
155
- /** Resolved capability manifest. */
156
- capabilities: PluginCapabilityManifest;
157
- /** Last N state transitions (capped at MAX_TRANSITION_HISTORY). */
158
- transitions: PluginTransition[];
159
- /** Epoch ms when the plugin was last successfully activated. */
160
- activatedAt?: number;
161
- /** Epoch ms when the plugin last transitioned to error. */
162
- errorAt?: number;
163
- /** Last error message, if any. */
164
- lastError?: string;
165
- /** Whether a hot-reload is currently in progress for this plugin. */
166
- reloading: boolean;
167
- /** Trust tier assigned to this plugin. Defaults to 'untrusted'. */
168
- trustTier: import('./trust.ts').PluginTrustTier;
169
- /** Whether this plugin is currently quarantined. */
170
- quarantined: boolean;
171
- }
172
-
173
- /** Maximum transition history entries kept per plugin. */
174
- export const MAX_TRANSITION_HISTORY = 50;
175
-
176
- // ── Manager options ───────────────────────────────────────────────────────────
177
-
178
- /**
179
- * Options accepted by `createPluginLifecycleManager()`.
180
- */
181
- export interface PluginLifecycleManagerOptions {
182
- /**
183
- * Session ID injected into emitted events.
184
- * Defaults to an empty string when not provided.
185
- */
186
- sessionId?: string;
187
- /**
188
- * Optional policy callback invoked during capability resolution.
189
- * Return `true` to grant the capability, `false` to deny.
190
- * Defaults to a permissive policy that grants all valid capabilities.
191
- */
192
- capabilityPolicy?: (pluginName: string, capability: PluginCapability) => boolean;
193
- /**
194
- * Optional trust tier resolver. Called during capability resolution to
195
- * determine the effective trust tier for capability filtering.
196
- * Return the tier for the given plugin name.
197
- * Defaults to 'untrusted' for all plugins when not provided.
198
- */
199
- trustTierResolver?: (pluginName: string) => import('./trust.ts').PluginTrustTier;
200
- /**
201
- * Runtime event bus used for lifecycle emission.
202
- * When omitted, the manager creates an isolated in-memory bus.
203
- */
204
- runtimeBus?: import('../events/index.ts').RuntimeEventBus;
205
- }