@pellux/goodvibes-tui 0.18.10 → 0.18.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (443) hide show
  1. package/CHANGELOG.md +56 -0
  2. package/README.md +1 -1
  3. package/docs/foundation-artifacts/operator-contract.json +1 -1
  4. package/package.json +2 -2
  5. package/src/core/conversation-rendering.ts +2 -2
  6. package/src/core/conversation.ts +5 -5
  7. package/src/core/orchestrator.ts +13 -11
  8. package/src/daemon/facade-composition.ts +8 -8
  9. package/src/daemon/facade.ts +8 -8
  10. package/src/daemon/types.ts +3 -3
  11. package/src/input/command-registry.ts +3 -3
  12. package/src/input/commands/session-content.ts +2 -2
  13. package/src/input/commands/session-workflow.ts +1 -1
  14. package/src/input/handler-feed.ts +1 -1
  15. package/src/input/session-picker-modal.ts +1 -1
  16. package/src/panels/builtin/agent.ts +1 -0
  17. package/src/panels/builtin/operations.ts +1 -0
  18. package/src/panels/builtin/session.ts +1 -1
  19. package/src/panels/builtin/shared.ts +2 -2
  20. package/src/panels/context-visualizer-panel.ts +4 -1
  21. package/src/panels/provider-health-domains.ts +5 -1
  22. package/src/panels/provider-health-panel.ts +5 -1
  23. package/src/panels/session-browser-panel.ts +1 -1
  24. package/src/panels/token-budget-panel.ts +6 -2
  25. package/src/plugins/loader.ts +2 -2
  26. package/src/runtime/bootstrap-command-context.ts +3 -3
  27. package/src/runtime/bootstrap-command-parts.ts +3 -3
  28. package/src/runtime/bootstrap-core.ts +2 -2
  29. package/src/runtime/bootstrap-hook-bridge.ts +1 -1
  30. package/src/runtime/bootstrap-shell.ts +1 -1
  31. package/src/runtime/bootstrap.ts +5 -4
  32. package/src/runtime/services.ts +2 -2
  33. package/src/runtime/ui-read-models-observability-security.ts +2 -2
  34. package/src/runtime/ui-read-models-observability-system.ts +1 -1
  35. package/src/runtime/ui-service-queries.ts +1 -1
  36. package/src/tools/index.ts +1 -1
  37. package/src/version.ts +1 -1
  38. package/src/acp/connection.ts +0 -447
  39. package/src/acp/index.ts +0 -7
  40. package/src/acp/manager.ts +0 -1
  41. package/src/adapters/bluebubbles/index.ts +0 -127
  42. package/src/adapters/discord/index.ts +0 -297
  43. package/src/adapters/github/index.ts +0 -73
  44. package/src/adapters/google-chat/index.ts +0 -119
  45. package/src/adapters/imessage/index.ts +0 -92
  46. package/src/adapters/index.ts +0 -15
  47. package/src/adapters/matrix/index.ts +0 -116
  48. package/src/adapters/mattermost/index.ts +0 -151
  49. package/src/adapters/msteams/index.ts +0 -180
  50. package/src/adapters/ntfy/index.ts +0 -118
  51. package/src/adapters/signal/index.ts +0 -92
  52. package/src/adapters/slack/index.ts +0 -323
  53. package/src/adapters/telegram/index.ts +0 -160
  54. package/src/adapters/types.ts +0 -97
  55. package/src/adapters/webhook/index.ts +0 -178
  56. package/src/adapters/whatsapp/index.ts +0 -135
  57. package/src/agents/message-bus-core.ts +0 -312
  58. package/src/agents/message-bus.ts +0 -2
  59. package/src/agents/orchestrator-prompts.ts +0 -351
  60. package/src/agents/orchestrator-runner.ts +0 -668
  61. package/src/agents/orchestrator.ts +0 -438
  62. package/src/agents/session.ts +0 -108
  63. package/src/agents/worktree.ts +0 -153
  64. package/src/agents/wrfc-config.ts +0 -47
  65. package/src/agents/wrfc-controller.ts +0 -747
  66. package/src/agents/wrfc-gate-runtime.ts +0 -75
  67. package/src/agents/wrfc-reporting.ts +0 -284
  68. package/src/agents/wrfc-runtime-events.ts +0 -150
  69. package/src/agents/wrfc-types.ts +0 -67
  70. package/src/automation/delivery-manager.ts +0 -368
  71. package/src/automation/index.ts +0 -72
  72. package/src/automation/manager-runtime-delivery.ts +0 -139
  73. package/src/automation/manager-runtime-events.ts +0 -131
  74. package/src/automation/manager-runtime-execution.ts +0 -511
  75. package/src/automation/manager-runtime-helpers.ts +0 -433
  76. package/src/automation/manager-runtime-job-mutations.ts +0 -175
  77. package/src/automation/manager-runtime-reconcile.ts +0 -148
  78. package/src/automation/manager-runtime-scheduling.ts +0 -189
  79. package/src/automation/manager-runtime-sync.ts +0 -54
  80. package/src/automation/manager-runtime.ts +0 -721
  81. package/src/automation/manager.ts +0 -10
  82. package/src/automation/service.ts +0 -242
  83. package/src/channels/builtin/account-actions.ts +0 -490
  84. package/src/channels/builtin/accounts.ts +0 -433
  85. package/src/channels/builtin/contracts.ts +0 -405
  86. package/src/channels/builtin/plugins.ts +0 -308
  87. package/src/channels/builtin/rendering.ts +0 -174
  88. package/src/channels/builtin/setup-schema.ts +0 -504
  89. package/src/channels/builtin/shared.ts +0 -96
  90. package/src/channels/builtin/surfaces.ts +0 -57
  91. package/src/channels/builtin/targets.ts +0 -693
  92. package/src/channels/builtin-runtime.ts +0 -443
  93. package/src/channels/delivery/shared.ts +0 -199
  94. package/src/channels/delivery/strategies-bridge.ts +0 -246
  95. package/src/channels/delivery/strategies-core.ts +0 -299
  96. package/src/channels/delivery/strategies-enterprise.ts +0 -178
  97. package/src/channels/delivery/types.ts +0 -59
  98. package/src/channels/delivery-router.ts +0 -127
  99. package/src/channels/index.ts +0 -77
  100. package/src/channels/plugin-registry.ts +0 -551
  101. package/src/channels/provider-runtime.ts +0 -330
  102. package/src/channels/reply-pipeline.ts +0 -522
  103. package/src/channels/route-manager.ts +0 -340
  104. package/src/channels/surface-registry.ts +0 -186
  105. package/src/config/helper-model.ts +0 -1
  106. package/src/config/manager.ts +0 -8
  107. package/src/config/subscription-auth.ts +0 -31
  108. package/src/config/tool-llm.ts +0 -110
  109. package/src/control-plane/approval-broker.ts +0 -351
  110. package/src/control-plane/gateway.ts +0 -1
  111. package/src/control-plane/index.ts +0 -54
  112. package/src/control-plane/media-contract-schemas.ts +0 -1
  113. package/src/control-plane/method-catalog-admin.ts +0 -1
  114. package/src/control-plane/method-catalog-channels.ts +0 -1
  115. package/src/control-plane/method-catalog-control-automation.ts +0 -1
  116. package/src/control-plane/method-catalog-control-core.ts +0 -1
  117. package/src/control-plane/method-catalog-control.ts +0 -1
  118. package/src/control-plane/method-catalog-events.ts +0 -1
  119. package/src/control-plane/method-catalog-knowledge.ts +0 -1
  120. package/src/control-plane/method-catalog-media.ts +0 -1
  121. package/src/control-plane/method-catalog-runtime.ts +0 -1
  122. package/src/control-plane/method-catalog-shared.ts +0 -1
  123. package/src/control-plane/method-catalog.ts +0 -1
  124. package/src/control-plane/operator-contract-schemas-admin.ts +0 -1
  125. package/src/control-plane/operator-contract-schemas-channels.ts +0 -1
  126. package/src/control-plane/operator-contract-schemas-control.ts +0 -1
  127. package/src/control-plane/operator-contract-schemas-domains.ts +0 -1
  128. package/src/control-plane/operator-contract-schemas-knowledge.ts +0 -1
  129. package/src/control-plane/operator-contract-schemas-media.ts +0 -1
  130. package/src/control-plane/operator-contract-schemas-permissions.ts +0 -1
  131. package/src/control-plane/operator-contract-schemas-remote.ts +0 -1
  132. package/src/control-plane/operator-contract-schemas-runtime.ts +0 -1
  133. package/src/control-plane/operator-contract-schemas-shared.ts +0 -1
  134. package/src/control-plane/operator-contract-schemas-telemetry.ts +0 -1
  135. package/src/control-plane/operator-contract-schemas.ts +0 -1
  136. package/src/control-plane/operator-contract.ts +0 -165
  137. package/src/control-plane/session-broker.ts +0 -780
  138. package/src/core/compaction-sections.ts +0 -492
  139. package/src/core/compaction-types.ts +0 -147
  140. package/src/core/context-compaction.ts +0 -542
  141. package/src/core/conversation-compaction.ts +0 -68
  142. package/src/core/conversation-diff.ts +0 -55
  143. package/src/core/conversation-utils.ts +0 -72
  144. package/src/core/event-replay.ts +0 -287
  145. package/src/core/orchestrator-context-runtime.ts +0 -407
  146. package/src/core/orchestrator-follow-up-runtime.ts +0 -134
  147. package/src/core/orchestrator-runtime.ts +0 -132
  148. package/src/core/orchestrator-tool-runtime.ts +0 -468
  149. package/src/core/orchestrator-turn-helpers.ts +0 -355
  150. package/src/core/orchestrator-turn-loop.ts +0 -443
  151. package/src/core/plan-command-handler.ts +0 -169
  152. package/src/core/transcript-events/classify.ts +0 -95
  153. package/src/core/transcript-events/index.ts +0 -15
  154. package/src/daemon/control-plane.ts +0 -522
  155. package/src/daemon/helpers.ts +0 -74
  156. package/src/daemon/http/router-route-contexts.ts +0 -370
  157. package/src/daemon/http/router.ts +0 -531
  158. package/src/daemon/http-listener.ts +0 -301
  159. package/src/daemon/index.ts +0 -1
  160. package/src/daemon/server.ts +0 -1
  161. package/src/daemon/service-manager.ts +0 -413
  162. package/src/daemon/surface-actions.ts +0 -183
  163. package/src/daemon/surface-delivery.ts +0 -530
  164. package/src/daemon/transport-events.ts +0 -110
  165. package/src/export/markdown.ts +0 -213
  166. package/src/export/session-export.ts +0 -1
  167. package/src/git/index.ts +0 -1
  168. package/src/git/service.ts +0 -414
  169. package/src/hooks/chain-engine.ts +0 -414
  170. package/src/hooks/dispatcher.ts +0 -414
  171. package/src/hooks/hook-api.ts +0 -170
  172. package/src/hooks/index.ts +0 -48
  173. package/src/hooks/runners/agent.ts +0 -93
  174. package/src/hooks/runners/prompt.ts +0 -69
  175. package/src/hooks/workbench.ts +0 -360
  176. package/src/integrations/index.ts +0 -42
  177. package/src/integrations/notifier.ts +0 -206
  178. package/src/integrations/webhooks.ts +0 -1
  179. package/src/knowledge/consolidation.ts +0 -346
  180. package/src/knowledge/graphql.ts +0 -324
  181. package/src/knowledge/index.ts +0 -60
  182. package/src/knowledge/ingest-compile.ts +0 -386
  183. package/src/knowledge/ingest-context.ts +0 -18
  184. package/src/knowledge/ingest-inputs.ts +0 -387
  185. package/src/knowledge/ingest.ts +0 -1
  186. package/src/knowledge/internal.ts +0 -257
  187. package/src/knowledge/knowledge-api.ts +0 -432
  188. package/src/knowledge/lint.ts +0 -121
  189. package/src/knowledge/memory-sync.ts +0 -62
  190. package/src/knowledge/packet.ts +0 -370
  191. package/src/knowledge/scheduling.ts +0 -283
  192. package/src/knowledge/service.ts +0 -715
  193. package/src/mcp/client.ts +0 -383
  194. package/src/mcp/index.ts +0 -12
  195. package/src/mcp/mcp-api.ts +0 -90
  196. package/src/mcp/registry.ts +0 -1
  197. package/src/media/builtin-image-understanding.ts +0 -303
  198. package/src/media/builtin-providers.ts +0 -26
  199. package/src/media/index.ts +0 -18
  200. package/src/multimodal/index.ts +0 -13
  201. package/src/multimodal/service.ts +0 -492
  202. package/src/permissions/briefs/build.ts +0 -88
  203. package/src/permissions/manager.ts +0 -1
  204. package/src/plugins/api.ts +0 -383
  205. package/src/plugins/manager.ts +0 -481
  206. package/src/profiles/shape.ts +0 -58
  207. package/src/providers/amazon-bedrock-mantle.ts +0 -50
  208. package/src/providers/amazon-bedrock.ts +0 -61
  209. package/src/providers/anthropic-compat.ts +0 -373
  210. package/src/providers/anthropic-sdk-provider.ts +0 -230
  211. package/src/providers/anthropic-vertex.ts +0 -59
  212. package/src/providers/anthropic.ts +0 -469
  213. package/src/providers/auto-register.ts +0 -417
  214. package/src/providers/builtin-catalog.ts +0 -326
  215. package/src/providers/builtin-registry.ts +0 -575
  216. package/src/providers/cache-planner.ts +0 -258
  217. package/src/providers/capabilities.ts +0 -1
  218. package/src/providers/custom-loader.ts +0 -425
  219. package/src/providers/discovered-compat.ts +0 -7
  220. package/src/providers/discovered-factory.ts +0 -61
  221. package/src/providers/discovered-traits.ts +0 -138
  222. package/src/providers/gemini.ts +0 -462
  223. package/src/providers/github-copilot.ts +0 -254
  224. package/src/providers/index.ts +0 -1
  225. package/src/providers/interface.ts +0 -185
  226. package/src/providers/llama-cpp.ts +0 -402
  227. package/src/providers/lm-studio-helpers.ts +0 -367
  228. package/src/providers/lm-studio.ts +0 -484
  229. package/src/providers/model-catalog-cache.ts +0 -221
  230. package/src/providers/model-catalog-notifications.ts +0 -97
  231. package/src/providers/model-catalog-synthetic.ts +0 -202
  232. package/src/providers/model-catalog.ts +0 -211
  233. package/src/providers/model-limits.ts +0 -1
  234. package/src/providers/ollama.ts +0 -469
  235. package/src/providers/openai-codex.ts +0 -472
  236. package/src/providers/openai-compat.ts +0 -615
  237. package/src/providers/openai.ts +0 -231
  238. package/src/providers/optimizer.ts +0 -1
  239. package/src/providers/provider-api.ts +0 -1
  240. package/src/providers/registry-helpers.ts +0 -34
  241. package/src/providers/registry-models.ts +0 -77
  242. package/src/providers/registry-types.ts +0 -67
  243. package/src/providers/registry.ts +0 -1
  244. package/src/providers/runtime-metadata.ts +0 -149
  245. package/src/providers/runtime-snapshot.ts +0 -130
  246. package/src/providers/synthetic.ts +0 -561
  247. package/src/providers/tier-prompts.ts +0 -84
  248. package/src/providers/tool-formats.ts +0 -414
  249. package/src/runtime/auth/inspection.ts +0 -125
  250. package/src/runtime/bootstrap-background.ts +0 -157
  251. package/src/runtime/bootstrap-helpers.ts +0 -88
  252. package/src/runtime/bootstrap-runtime-events.ts +0 -254
  253. package/src/runtime/bootstrap-services.ts +0 -197
  254. package/src/runtime/compaction/index.ts +0 -1
  255. package/src/runtime/compaction/lifecycle.ts +0 -1
  256. package/src/runtime/compaction/manager.ts +0 -474
  257. package/src/runtime/compaction/quality-score.ts +0 -1
  258. package/src/runtime/compaction/resume-repair.ts +0 -1
  259. package/src/runtime/compaction/strategies/autocompact.ts +0 -1
  260. package/src/runtime/compaction/strategies/boundary-commit.ts +0 -1
  261. package/src/runtime/compaction/strategies/collapse.ts +0 -1
  262. package/src/runtime/compaction/strategies/index.ts +0 -1
  263. package/src/runtime/compaction/strategies/microcompact.ts +0 -1
  264. package/src/runtime/compaction/strategies/reactive.ts +0 -1
  265. package/src/runtime/compaction/types.ts +0 -1
  266. package/src/runtime/ecosystem/recommendations.ts +0 -117
  267. package/src/runtime/emitters/agents.ts +0 -96
  268. package/src/runtime/emitters/automation.ts +0 -112
  269. package/src/runtime/emitters/communication.ts +0 -53
  270. package/src/runtime/emitters/compaction.ts +0 -161
  271. package/src/runtime/emitters/control-plane.ts +0 -65
  272. package/src/runtime/emitters/deliveries.ts +0 -65
  273. package/src/runtime/emitters/forensics.ts +0 -17
  274. package/src/runtime/emitters/index.ts +0 -59
  275. package/src/runtime/emitters/knowledge.ts +0 -129
  276. package/src/runtime/emitters/mcp.ts +0 -95
  277. package/src/runtime/emitters/ops.ts +0 -163
  278. package/src/runtime/emitters/orchestration.ts +0 -87
  279. package/src/runtime/emitters/permissions.ts +0 -98
  280. package/src/runtime/emitters/planner.ts +0 -23
  281. package/src/runtime/emitters/plugins.ts +0 -78
  282. package/src/runtime/emitters/providers.ts +0 -30
  283. package/src/runtime/emitters/routes.ts +0 -57
  284. package/src/runtime/emitters/security.ts +0 -53
  285. package/src/runtime/emitters/session.ts +0 -93
  286. package/src/runtime/emitters/surfaces.ts +0 -57
  287. package/src/runtime/emitters/tasks.ts +0 -69
  288. package/src/runtime/emitters/tools.ts +0 -140
  289. package/src/runtime/emitters/transport.ts +0 -78
  290. package/src/runtime/emitters/turn.ts +0 -155
  291. package/src/runtime/emitters/ui.ts +0 -57
  292. package/src/runtime/emitters/watchers.ts +0 -57
  293. package/src/runtime/emitters/workflows.ts +0 -79
  294. package/src/runtime/eval/index.ts +0 -48
  295. package/src/runtime/eval/runner.ts +0 -163
  296. package/src/runtime/eval/suites.ts +0 -264
  297. package/src/runtime/events/domain-map.ts +0 -148
  298. package/src/runtime/events/index.ts +0 -1
  299. package/src/runtime/events/turn.ts +0 -1
  300. package/src/runtime/events/workflows.ts +0 -1
  301. package/src/runtime/forensics/collector.ts +0 -693
  302. package/src/runtime/forensics/index.ts +0 -23
  303. package/src/runtime/foundation-clients.ts +0 -78
  304. package/src/runtime/foundation-services.ts +0 -96
  305. package/src/runtime/guidance.ts +0 -183
  306. package/src/runtime/health/effect-handlers.ts +0 -189
  307. package/src/runtime/health/index.ts +0 -70
  308. package/src/runtime/health/wiring.ts +0 -115
  309. package/src/runtime/integration/helpers.ts +0 -640
  310. package/src/runtime/lifecycle.ts +0 -107
  311. package/src/runtime/mcp/index.ts +0 -68
  312. package/src/runtime/mcp/manager.ts +0 -513
  313. package/src/runtime/network/inbound.ts +0 -131
  314. package/src/runtime/network/index.ts +0 -30
  315. package/src/runtime/network/outbound.ts +0 -292
  316. package/src/runtime/network/shared.ts +0 -82
  317. package/src/runtime/operator-client.ts +0 -235
  318. package/src/runtime/ops/control-plane.ts +0 -363
  319. package/src/runtime/ops/index.ts +0 -122
  320. package/src/runtime/ops/playbooks/index.ts +0 -10
  321. package/src/runtime/ops/playbooks/session-unrecoverable.ts +0 -196
  322. package/src/runtime/ops/playbooks/stuck-turn.ts +0 -197
  323. package/src/runtime/ops/runtime-context.ts +0 -100
  324. package/src/runtime/ops-api.ts +0 -27
  325. package/src/runtime/orchestration/spawn-policy.ts +0 -83
  326. package/src/runtime/peer-client.ts +0 -404
  327. package/src/runtime/perf/index.ts +0 -57
  328. package/src/runtime/perf/slo-collector.ts +0 -375
  329. package/src/runtime/permissions/index.ts +0 -190
  330. package/src/runtime/permissions/policy-runtime.ts +0 -1
  331. package/src/runtime/permissions/preflight.ts +0 -101
  332. package/src/runtime/permissions/rule-suggestions.ts +0 -36
  333. package/src/runtime/plugins/hot-reload.ts +0 -221
  334. package/src/runtime/plugins/index.ts +0 -84
  335. package/src/runtime/plugins/lifecycle.ts +0 -95
  336. package/src/runtime/plugins/manager.ts +0 -474
  337. package/src/runtime/plugins/manifest.ts +0 -167
  338. package/src/runtime/plugins/quarantine.ts +0 -202
  339. package/src/runtime/plugins/trust.ts +0 -291
  340. package/src/runtime/plugins/types.ts +0 -205
  341. package/src/runtime/provider-accounts/registry.ts +0 -326
  342. package/src/runtime/remote/distributed-runtime-contract-schemas.ts +0 -386
  343. package/src/runtime/remote/index.ts +0 -488
  344. package/src/runtime/remote/runner-registry.ts +0 -438
  345. package/src/runtime/remote/supervisor.ts +0 -70
  346. package/src/runtime/runtime-hook-api.ts +0 -5
  347. package/src/runtime/runtime-knowledge-api.ts +0 -14
  348. package/src/runtime/runtime-mcp-api.ts +0 -5
  349. package/src/runtime/runtime-ops-api.ts +0 -86
  350. package/src/runtime/runtime-provider-api.ts +0 -18
  351. package/src/runtime/session-maintenance.ts +0 -188
  352. package/src/runtime/session-persistence.ts +0 -288
  353. package/src/runtime/session-return-context.ts +0 -195
  354. package/src/runtime/settings/control-plane-store.ts +0 -258
  355. package/src/runtime/settings/control-plane.ts +0 -599
  356. package/src/runtime/shell-command-extensions.ts +0 -54
  357. package/src/runtime/shell-command-ops.ts +0 -207
  358. package/src/runtime/shell-command-platform.ts +0 -47
  359. package/src/runtime/shell-command-services.ts +0 -143
  360. package/src/runtime/shell-command-workspace.ts +0 -31
  361. package/src/runtime/tasks/adapters/acp-adapter.ts +0 -211
  362. package/src/runtime/tasks/adapters/agent-adapter.ts +0 -208
  363. package/src/runtime/tasks/adapters/index.ts +0 -16
  364. package/src/runtime/tasks/adapters/process-adapter.ts +0 -214
  365. package/src/runtime/tasks/adapters/scheduler-adapter.ts +0 -193
  366. package/src/runtime/tasks/index.ts +0 -68
  367. package/src/runtime/tasks/manager.ts +0 -415
  368. package/src/runtime/telemetry/api-helpers.ts +0 -517
  369. package/src/runtime/telemetry/api.ts +0 -768
  370. package/src/runtime/telemetry/index.ts +0 -178
  371. package/src/runtime/telemetry/instrumentation/domain-bridge-agent-session.ts +0 -440
  372. package/src/runtime/telemetry/instrumentation/domain-bridge-plugin-mcp.ts +0 -200
  373. package/src/runtime/telemetry/instrumentation/domain-bridge-shared.ts +0 -18
  374. package/src/runtime/telemetry/instrumentation/domain-bridge-transport-task.ts +0 -204
  375. package/src/runtime/telemetry/instrumentation/domain-bridge.ts +0 -125
  376. package/src/runtime/telemetry/instrumentation/index.ts +0 -67
  377. package/src/runtime/tools/context.ts +0 -114
  378. package/src/runtime/tools/index.ts +0 -46
  379. package/src/runtime/tools/phased-executor.ts +0 -448
  380. package/src/runtime/tools/phases/budget.ts +0 -130
  381. package/src/runtime/tools/phases/execute.ts +0 -69
  382. package/src/runtime/tools/phases/index.ts +0 -13
  383. package/src/runtime/tools/phases/map-output.ts +0 -98
  384. package/src/runtime/tools/phases/permission.ts +0 -133
  385. package/src/runtime/tools/phases/posthook.ts +0 -57
  386. package/src/runtime/tools/phases/prehook.ts +0 -68
  387. package/src/runtime/tools/phases/validate.ts +0 -53
  388. package/src/runtime/transports/direct.ts +0 -73
  389. package/src/runtime/transports/http-helpers.ts +0 -218
  390. package/src/runtime/transports/http-types.ts +0 -364
  391. package/src/runtime/transports/http.ts +0 -629
  392. package/src/runtime/transports/realtime.ts +0 -50
  393. package/src/runtime/transports/remote-events.ts +0 -16
  394. package/src/runtime/transports/shared.ts +0 -39
  395. package/src/runtime/transports/ui-runtime-events.ts +0 -35
  396. package/src/runtime/ui-events.ts +0 -46
  397. package/src/runtime/worktree/registry.ts +0 -252
  398. package/src/sessions/manager.ts +0 -14
  399. package/src/state/file-watcher.ts +0 -294
  400. package/src/state/index.ts +0 -56
  401. package/src/state/knowledge-injection.ts +0 -214
  402. package/src/state/memory-embedding-http.ts +0 -642
  403. package/src/state/memory-embeddings.ts +0 -312
  404. package/src/state/memory-ingest.ts +0 -132
  405. package/src/state/memory-registry.ts +0 -111
  406. package/src/state/memory-store-helpers.ts +0 -160
  407. package/src/state/memory-store.ts +0 -728
  408. package/src/state/memory-vector-store.ts +0 -418
  409. package/src/templates/manager.ts +0 -187
  410. package/src/tools/agent/index.ts +0 -610
  411. package/src/tools/agent/manager.ts +0 -476
  412. package/src/tools/analyze/git-modes.ts +0 -380
  413. package/src/tools/analyze/index.ts +0 -128
  414. package/src/tools/channel/agent-tools.ts +0 -16
  415. package/src/tools/channel/index.ts +0 -268
  416. package/src/tools/control/index.ts +0 -90
  417. package/src/tools/edit/core.ts +0 -619
  418. package/src/tools/edit/index.ts +0 -4
  419. package/src/tools/edit/phased.ts +0 -33
  420. package/src/tools/fetch/index.ts +0 -3
  421. package/src/tools/fetch/phased.ts +0 -34
  422. package/src/tools/fetch/runtime.ts +0 -499
  423. package/src/tools/mcp/index.ts +0 -190
  424. package/src/tools/remote-trigger/index.ts +0 -130
  425. package/src/tools/shared/auto-heal.ts +0 -282
  426. package/src/tools/state/index.ts +0 -688
  427. package/src/tools/web-search/index.ts +0 -38
  428. package/src/tools/write/index.ts +0 -604
  429. package/src/tools/write/phased.ts +0 -41
  430. package/src/types/generated/foundation-client-types.ts +0 -22
  431. package/src/watchers/index.ts +0 -11
  432. package/src/watchers/registry.ts +0 -517
  433. package/src/web-search/index.ts +0 -26
  434. package/src/web-search/provider-registry.ts +0 -64
  435. package/src/web-search/providers/brave.ts +0 -100
  436. package/src/web-search/providers/duckduckgo.ts +0 -270
  437. package/src/web-search/providers/exa.ts +0 -77
  438. package/src/web-search/providers/firecrawl.ts +0 -90
  439. package/src/web-search/providers/perplexity.ts +0 -86
  440. package/src/web-search/providers/searxng.ts +0 -88
  441. package/src/web-search/providers/shared.ts +0 -249
  442. package/src/web-search/providers/tavily.ts +0 -90
  443. package/src/web-search/service.ts +0 -142
@@ -1,474 +0,0 @@
1
- /**
2
- * PluginLifecycleManager — plugin lifecycle and capability enforcement.
3
- *
4
- * Tracks all plugins through the 8-state lifecycle machine, resolves capability
5
- * manifests on load, and emits PluginEvents at every state transition.
6
- *
7
- * Gated by the `plugin-lifecycle` feature flag.
8
- */
9
-
10
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
11
- import type { PluginEvent } from '@pellux/goodvibes-sdk/platform/runtime/events/plugins';
12
- import { RuntimeEventBus } from '@pellux/goodvibes-sdk/platform/runtime/events/index';
13
- import type { RuntimeEventBus as RuntimeEventBusContract } from '@pellux/goodvibes-sdk/platform/runtime/events/index';
14
- import type { PluginLoaderDeps, LoadedPlugin } from '../../plugins/loader';
15
- import {
16
- discoverPlugins,
17
- loadPlugin,
18
- unloadPlugin,
19
- type PluginPathOptions,
20
- } from '../../plugins/loader';
21
- import type { PluginLifecycleState } from '@pellux/goodvibes-sdk/platform/runtime/store/domains/plugins';
22
- import {
23
- type PluginCapability,
24
- type PluginLifecycleManagerOptions,
25
- type PluginLifecycleRecord,
26
- type PluginManifestV2,
27
- type PluginTransition,
28
- MAX_TRANSITION_HISTORY,
29
- } from '@pellux/goodvibes-sdk/platform/runtime/plugins/types';
30
- import { applyTransition, isOperational } from '@pellux/goodvibes-sdk/platform/runtime/plugins/lifecycle';
31
- import { resolveCapabilityManifest } from '@pellux/goodvibes-sdk/platform/runtime/plugins/manifest';
32
- import { PluginTrustStore, type PluginTrustTier } from '@pellux/goodvibes-sdk/platform/runtime/plugins/trust';
33
- import { PluginQuarantineEngine } from '@pellux/goodvibes-sdk/platform/runtime/plugins/quarantine';
34
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
35
- import {
36
- emitPluginActive,
37
- emitPluginDegraded,
38
- emitPluginDisabled,
39
- emitPluginDiscovered,
40
- emitPluginError,
41
- emitPluginLoaded,
42
- emitPluginLoading,
43
- emitPluginUnloading,
44
- } from '@pellux/goodvibes-sdk/platform/runtime/emitters/plugins';
45
-
46
- /** Source label for emitted events. */
47
- const EVENT_SOURCE = 'plugin-lifecycle-manager';
48
-
49
- /**
50
- * PluginLifecycleManager tracks all plugins through structured lifecycle
51
- * transitions and emits typed PluginEvents at each state change.
52
- */
53
- export class PluginLifecycleManager {
54
- private readonly records = new Map<string, PluginLifecycleRecord>();
55
- private readonly sessionId: string;
56
- private readonly capabilityPolicy: (name: string, cap: PluginCapability) => boolean;
57
- private readonly trustTierResolver: (pluginName: string) => PluginTrustTier;
58
- private readonly runtimeBus: RuntimeEventBusContract;
59
-
60
- /** Trust store — manages tier records for all plugins. */
61
- readonly trustStore: PluginTrustStore = new PluginTrustStore();
62
- /** Quarantine engine — tracks and applies quarantine constraints. */
63
- readonly quarantine: PluginQuarantineEngine = new PluginQuarantineEngine();
64
-
65
- constructor(options: PluginLifecycleManagerOptions = {}) {
66
- this.sessionId = options.sessionId ?? '';
67
- this.capabilityPolicy = options.capabilityPolicy ?? (() => true);
68
- this.trustTierResolver = options.trustTierResolver ?? ((name) => this.trustStore.getTier(name));
69
- this.runtimeBus = options.runtimeBus ?? new RuntimeEventBus();
70
- }
71
-
72
- // ── Plugin record accessors ────────────────────────────────────────────────
73
-
74
- /** Returns the lifecycle record for a plugin, or undefined if unknown. */
75
- getRecord(name: string): Readonly<PluginLifecycleRecord> | undefined {
76
- return this.records.get(name);
77
- }
78
-
79
- /** Returns all plugin lifecycle records as an array. */
80
- getAllRecords(): ReadonlyArray<Readonly<PluginLifecycleRecord>> {
81
- return Array.from(this.records.values());
82
- }
83
-
84
- /** Returns names of all plugins in a given state. */
85
- getPluginsInState(state: PluginLifecycleState): string[] {
86
- const result: string[] = [];
87
- for (const [name, record] of this.records) {
88
- if (record.state === state) result.push(name);
89
- }
90
- return result;
91
- }
92
-
93
- /** Returns names of all currently operational plugins (active or degraded). */
94
- getOperationalPlugins(): string[] {
95
- const result: string[] = [];
96
- for (const [name, record] of this.records) {
97
- if (isOperational(record.state)) result.push(name);
98
- }
99
- return result;
100
- }
101
-
102
- // ── Lifecycle operations ──────────────────────────────────────────────────
103
-
104
- /**
105
- * Register a discovered plugin. Creates its lifecycle record in the
106
- * `discovered` state and emits PLUGIN_DISCOVERED.
107
- */
108
- registerDiscovered(manifest: PluginManifestV2, pluginDir: string): void {
109
- const name = manifest.name;
110
- if (this.records.has(name)) {
111
- logger.debug(`[plugin-lifecycle] ${name}: already registered, skipping re-registration`);
112
- return;
113
- }
114
-
115
- const tier = this.trustTierResolver(name);
116
- const capabilities = resolveCapabilityManifest(name, manifest, this.capabilityPolicy, tier);
117
-
118
- const record: PluginLifecycleRecord = {
119
- name,
120
- version: manifest.version,
121
- state: 'discovered',
122
- capabilities,
123
- transitions: [],
124
- reloading: false,
125
- trustTier: tier,
126
- quarantined: this.quarantine.isQuarantined(name),
127
- };
128
-
129
- this.records.set(name, record);
130
-
131
- this.emit({
132
- type: 'PLUGIN_DISCOVERED',
133
- pluginId: name,
134
- path: pluginDir,
135
- version: manifest.version,
136
- });
137
-
138
- logger.debug(`[plugin-lifecycle] ${name}@${manifest.version}: registered (discovered)`);
139
- }
140
-
141
- /**
142
- * Load a plugin using the existing loader infrastructure.
143
- *
144
- * Transitions: discovered/disabled → loading → loaded → active
145
- * On failure: loading → error
146
- */
147
- async loadPlugin(
148
- manifest: PluginManifestV2,
149
- pluginDir: string,
150
- deps: PluginLoaderDeps,
151
- cacheBust?: number,
152
- ): Promise<boolean> {
153
- const name = manifest.name;
154
- let record = this.records.get(name);
155
-
156
- if (!record) {
157
- this.registerDiscovered(manifest, pluginDir);
158
- record = this.records.get(name)!;
159
- }
160
-
161
- // discovered → loading (or disabled → loading for re-enable)
162
- const toLoadingResult = this.transition(name, 'loading');
163
- if (!toLoadingResult.ok) {
164
- logger.warn(`[plugin-lifecycle] ${name}: cannot start load — ${toLoadingResult.reason}`);
165
- return false;
166
- }
167
-
168
- this.emit({ type: 'PLUGIN_LOADING', pluginId: name, path: pluginDir });
169
-
170
- try {
171
- const loaded = await loadPlugin({ manifest, pluginDir }, deps, cacheBust);
172
-
173
- if (!loaded) {
174
- this.transition(name, 'error', 'loadPlugin returned null');
175
- this.updateRecord(name, { lastError: 'loadPlugin returned null', errorAt: Date.now() });
176
- this.emit({
177
- type: 'PLUGIN_ERROR',
178
- pluginId: name,
179
- error: 'loadPlugin returned null',
180
- fatal: false,
181
- });
182
- return false;
183
- }
184
-
185
- // loading → loaded
186
- this.transition(name, 'loaded');
187
-
188
- // loaded → active
189
- const toActiveResult = this.transition(name, 'active');
190
- if (!toActiveResult.ok) {
191
- logger.warn(`[plugin-lifecycle] ${name}: cannot transition to active — ${toActiveResult.reason}`);
192
- return false;
193
- }
194
-
195
- this.updateRecord(name, { activatedAt: Date.now() });
196
-
197
- this.emit({
198
- type: 'PLUGIN_LOADED',
199
- pluginId: name,
200
- version: manifest.version,
201
- capabilities: record.capabilities.granted as string[],
202
- });
203
- this.emit({ type: 'PLUGIN_ACTIVE', pluginId: name });
204
-
205
- logger.info(`[plugin-lifecycle] ${name}@${manifest.version}: active`);
206
- return true;
207
- } catch (err) {
208
- const errorMsg = summarizeError(err);
209
- this.transition(name, 'error', errorMsg);
210
- this.updateRecord(name, { lastError: errorMsg, errorAt: Date.now() });
211
- this.emit({
212
- type: 'PLUGIN_ERROR',
213
- pluginId: name,
214
- error: errorMsg,
215
- fatal: false,
216
- });
217
- logger.error(`[plugin-lifecycle] ${name}: load threw — ${errorMsg}`);
218
- return false;
219
- }
220
- }
221
-
222
- /**
223
- * Unload a plugin. Transitions active/loaded/degraded → unloading → disabled.
224
- */
225
- async unloadPlugin(
226
- name: string,
227
- reason?: string,
228
- loaderDeps?: { getLoadedPlugin?: (name: string) => LoadedPlugin | undefined },
229
- ): Promise<void> {
230
- const record = this.records.get(name);
231
- if (!record) {
232
- logger.debug(`[plugin-lifecycle] ${name}: unload requested but not tracked`);
233
- return;
234
- }
235
-
236
- const toUnloadingResult = this.transition(name, 'unloading', reason);
237
- if (!toUnloadingResult.ok) {
238
- logger.warn(`[plugin-lifecycle] ${name}: cannot unload — ${toUnloadingResult.reason}`);
239
- return;
240
- }
241
-
242
- this.emit({ type: 'PLUGIN_UNLOADING', pluginId: name, reason });
243
-
244
- // Delegate to the existing unloadPlugin function if a loaded instance is available.
245
- const loadedPlugin = loaderDeps?.getLoadedPlugin?.(name);
246
- if (loadedPlugin) {
247
- await unloadPlugin(loadedPlugin);
248
- }
249
-
250
- this.transition(name, 'disabled', reason);
251
- this.emit({
252
- type: 'PLUGIN_DISABLED',
253
- pluginId: name,
254
- reason: reason ?? 'unloaded',
255
- });
256
-
257
- logger.info(`[plugin-lifecycle] ${name}: disabled${reason ? ` (${reason})` : ''}`);
258
- }
259
-
260
- // ── Trust & Quarantine operations ────────────────────────────────────────
261
-
262
- /**
263
- * setTrustTier — Assign a trust tier to a plugin and re-sync the record.
264
- *
265
- * If the plugin has an active lifecycle record, the trust tier in the record
266
- * is updated immediately. Capability re-resolution requires a reload.
267
- */
268
- setTrustTier(name: string, tier: PluginTrustTier, note?: string): void {
269
- this.trustStore.setTier(name, tier, { note });
270
- const record = this.records.get(name);
271
- if (record) {
272
- record.trustTier = tier;
273
- }
274
- logger.info(`[plugin-lifecycle] ${name}: trust tier set to '${tier}'${note ? ` — ${note}` : ''}`);
275
- }
276
-
277
- /**
278
- * quarantinePlugin — Apply quarantine to a named plugin.
279
- *
280
- * Revokes high-risk capabilities from the live manifest and marks the record
281
- * as quarantined. Emits PLUGIN_DEGRADED to signal partial functionality.
282
- *
283
- * @returns true if quarantine was applied; false if not tracked or already quarantined.
284
- */
285
- quarantinePlugin(name: string, reason: string): boolean {
286
- const record = this.records.get(name);
287
- if (!record) {
288
- logger.warn(`[plugin-lifecycle] ${name}: quarantine requested but plugin not tracked`);
289
- return false;
290
- }
291
-
292
- const qRecord = this.quarantine.quarantine(name, record.capabilities, reason);
293
- if (!qRecord) return false;
294
-
295
- record.quarantined = true;
296
-
297
- this.emit({
298
- type: 'PLUGIN_DEGRADED',
299
- pluginId: name,
300
- reason: `quarantined: ${reason}`,
301
- affectedCapabilities: qRecord.revokedCapabilities as string[],
302
- });
303
-
304
- return true;
305
- }
306
-
307
- /**
308
- * liftQuarantine — Remove quarantine from a plugin.
309
- *
310
- * Capabilities are NOT restored here; the operator should reload the plugin
311
- * after lifting so that trust-aware re-resolution can grant capabilities
312
- * appropriate for the updated tier.
313
- *
314
- * @returns true if quarantine was lifted; false if no active quarantine.
315
- */
316
- liftQuarantine(name: string): boolean {
317
- const lifted = this.quarantine.lift(name);
318
- const record = this.records.get(name);
319
- if (record) {
320
- record.quarantined = false;
321
- }
322
- if (lifted) {
323
- logger.info(`[plugin-lifecycle] ${name}: quarantine lifted — reload to restore capabilities`);
324
- }
325
- return lifted;
326
- }
327
-
328
- /**
329
- * Mark a plugin as degraded (partial functionality). Only valid from active.
330
- */
331
- degradePlugin(name: string, reason: string, affectedCapabilities: string[] = []): void {
332
- const record = this.records.get(name);
333
- if (!record) return;
334
-
335
- const result = this.transition(name, 'degraded', reason);
336
- if (!result.ok) {
337
- logger.warn(`[plugin-lifecycle] ${name}: cannot degrade — ${result.reason}`);
338
- return;
339
- }
340
-
341
- this.emit({
342
- type: 'PLUGIN_DEGRADED',
343
- pluginId: name,
344
- reason,
345
- affectedCapabilities,
346
- });
347
-
348
- logger.warn(`[plugin-lifecycle] ${name}: degraded — ${reason}`);
349
- }
350
-
351
- /**
352
- * Record a non-fatal error without transitioning state.
353
- * If the plugin is active, it may optionally be moved to degraded.
354
- */
355
- recordError(name: string, error: string, fatal: boolean): void {
356
- const record = this.records.get(name);
357
- if (!record) return;
358
-
359
- this.updateRecord(name, { lastError: error, errorAt: Date.now() });
360
- this.emit({ type: 'PLUGIN_ERROR', pluginId: name, error, fatal });
361
-
362
- if (fatal && (record.state === 'active' || record.state === 'loaded' || record.state === 'degraded')) {
363
- this.transition(name, 'error', error);
364
- }
365
-
366
- logger.error(`[plugin-lifecycle] ${name}: error (fatal=${String(fatal)}) — ${error}`);
367
- }
368
-
369
- // ── Bulk operations ───────────────────────────────────────────────────────
370
-
371
- /**
372
- * Scan for plugins and register newly discovered ones.
373
- * Existing records are not modified.
374
- */
375
- scanAndRegister(pathOptions: PluginPathOptions): void {
376
- const discovered = discoverPlugins(pathOptions);
377
- for (const { manifest, pluginDir } of discovered) {
378
- if (!this.records.has(manifest.name)) {
379
- this.registerDiscovered(manifest as PluginManifestV2, pluginDir);
380
- }
381
- }
382
- logger.debug(`[plugin-lifecycle] Scan complete: ${discovered.length} plugin(s) found`);
383
- }
384
-
385
- // ── Private helpers ───────────────────────────────────────────────────────
386
-
387
- /**
388
- * Apply a state machine transition for a named plugin.
389
- * Records the transition in the plugin's history.
390
- * Returns the TransitionResult from the state machine.
391
- */
392
- private transition(
393
- name: string,
394
- to: PluginLifecycleState,
395
- reason?: string,
396
- ): { ok: boolean; reason?: string } {
397
- const record = this.records.get(name);
398
- if (!record) return { ok: false, reason: `Plugin '${name}' not tracked` };
399
-
400
- const result = applyTransition(record.state, to);
401
- if (!result.ok) return result;
402
-
403
- const entry: PluginTransition = {
404
- pluginName: name,
405
- from: result.from,
406
- to: result.to,
407
- ts: Date.now(),
408
- reason,
409
- };
410
-
411
- // Mutate the record in place — the record lives inside the Map.
412
- record.transitions.push(entry);
413
- if (record.transitions.length > MAX_TRANSITION_HISTORY) {
414
- record.transitions.shift();
415
- }
416
- record.state = to;
417
-
418
- logger.debug(`[plugin-lifecycle] ${name}: ${result.from} → ${to}${reason ? ` (${reason})` : ''}`);
419
- return { ok: true };
420
- }
421
-
422
- /**
423
- * Partially update a plugin record's mutable fields.
424
- */
425
- private updateRecord(
426
- name: string,
427
- patch: Partial<Pick<PluginLifecycleRecord, 'lastError' | 'errorAt' | 'activatedAt' | 'reloading' | 'trustTier' | 'quarantined'>>,
428
- ): void {
429
- const record = this.records.get(name);
430
- if (!record) return;
431
- if (patch.lastError !== undefined) record.lastError = patch.lastError;
432
- if (patch.errorAt !== undefined) record.errorAt = patch.errorAt;
433
- if (patch.activatedAt !== undefined) record.activatedAt = patch.activatedAt;
434
- if (patch.reloading !== undefined) record.reloading = patch.reloading;
435
- }
436
-
437
- private emit(event: PluginEvent): void {
438
- const ctx = {
439
- sessionId: this.sessionId,
440
- traceId: `plugin-lifecycle:${event.pluginId}`,
441
- source: EVENT_SOURCE,
442
- } as const;
443
- try {
444
- switch (event.type) {
445
- case 'PLUGIN_DISCOVERED':
446
- emitPluginDiscovered(this.runtimeBus, ctx, event);
447
- break;
448
- case 'PLUGIN_LOADING':
449
- emitPluginLoading(this.runtimeBus, ctx, event);
450
- break;
451
- case 'PLUGIN_LOADED':
452
- emitPluginLoaded(this.runtimeBus, ctx, event);
453
- break;
454
- case 'PLUGIN_ACTIVE':
455
- emitPluginActive(this.runtimeBus, ctx, event);
456
- break;
457
- case 'PLUGIN_DEGRADED':
458
- emitPluginDegraded(this.runtimeBus, ctx, event);
459
- break;
460
- case 'PLUGIN_ERROR':
461
- emitPluginError(this.runtimeBus, ctx, event);
462
- break;
463
- case 'PLUGIN_UNLOADING':
464
- emitPluginUnloading(this.runtimeBus, ctx, event);
465
- break;
466
- case 'PLUGIN_DISABLED':
467
- emitPluginDisabled(this.runtimeBus, ctx, event);
468
- break;
469
- }
470
- } catch (err) {
471
- logger.debug(`[plugin-lifecycle] runtime emit failed: ${summarizeError(err)}`);
472
- }
473
- }
474
- }
@@ -1,167 +0,0 @@
1
- /**
2
- * Plugin capability manifest validation and resolution.
3
- *
4
- * Implements deny-by-default capability enforcement:
5
- * 1. Parse raw manifest capabilities (unknown → typed)
6
- * 2. Validate that each requested capability is a known capability
7
- * 3. Run the runtime's capability policy to grant or deny each capability
8
- * 4. Return a resolved PluginCapabilityManifest
9
- */
10
-
11
- import { logger } from '@pellux/goodvibes-sdk/platform/utils/logger';
12
- import {
13
- ALL_CAPABILITIES,
14
- HIGH_RISK_CAPABILITIES,
15
- type PluginCapability,
16
- type PluginCapabilityManifest,
17
- type PluginManifestV2,
18
- } from '@pellux/goodvibes-sdk/platform/runtime/plugins/types';
19
- import { type PluginTrustTier, filterCapabilitiesByTrust } from '@pellux/goodvibes-sdk/platform/runtime/plugins/trust';
20
-
21
- /**
22
- * Default capability policy: grant all valid capabilities.
23
- *
24
- * Callers can supply a stricter policy via PluginLifecycleManagerOptions.
25
- */
26
- function defaultPolicy(_pluginName: string, _capability: PluginCapability): boolean {
27
- return true;
28
- }
29
-
30
- /**
31
- * Returns whether a string value is a known PluginCapability.
32
- */
33
- function isKnownCapability(value: string): value is PluginCapability {
34
- return (ALL_CAPABILITIES as ReadonlyArray<string>).includes(value);
35
- }
36
-
37
- /**
38
- * resolveCapabilityManifest — Parse and resolve the capability manifest for a
39
- * plugin, applying the runtime's capability policy and trust-tier constraints.
40
- *
41
- * Evaluation order:
42
- * 1. Unknown capability strings are filtered out (warn + ignore).
43
- * 2. Trust-tier constraints are applied — high-risk capabilities blocked
44
- * unless the plugin has the `trusted` tier.
45
- * 3. The runtime capability policy callback is applied to the remaining set.
46
- *
47
- * @param pluginName - Plugin name (for logging).
48
- * @param manifest - The raw plugin manifest (may have `capabilities` array).
49
- * @param policy - Capability grant/deny callback. Defaults to permissive.
50
- * @param trustTier - Effective trust tier for this plugin. Defaults to 'untrusted'.
51
- * @returns A fully-resolved PluginCapabilityManifest.
52
- */
53
- export function resolveCapabilityManifest(
54
- pluginName: string,
55
- manifest: PluginManifestV2,
56
- policy: (name: string, cap: PluginCapability) => boolean = defaultPolicy,
57
- trustTier: PluginTrustTier = 'untrusted',
58
- ): PluginCapabilityManifest {
59
- const rawRequested = manifest.capabilities ?? [];
60
-
61
- // Validate and filter unknown capability strings.
62
- const requested: PluginCapability[] = [];
63
- for (const raw of rawRequested) {
64
- if (isKnownCapability(raw)) {
65
- requested.push(raw);
66
- } else {
67
- logger.warn(
68
- `[plugin-lifecycle:${pluginName}] Unknown capability '${raw}' — ignored`,
69
- );
70
- }
71
- }
72
-
73
- // Apply trust-tier constraints before the policy callback.
74
- const trustResult = filterCapabilitiesByTrust(requested, trustTier);
75
- if (trustResult.blocked.length > 0) {
76
- logger.warn(
77
- `[plugin-lifecycle:${pluginName}] Trust tier '${trustTier}' blocks` +
78
- ` high-risk capabilities: [${trustResult.blocked.join(', ')}]` +
79
- ' — trust escalation required',
80
- );
81
- }
82
-
83
- // Only the trust-permitted capabilities proceed to policy evaluation.
84
- const afterTrust = trustResult.permitted;
85
-
86
- const granted: PluginCapability[] = [];
87
- const denied: PluginCapability[] = [...trustResult.blocked];
88
- const denialReasons: Partial<Record<PluginCapability, string>> = { ...trustResult.reasons };
89
-
90
- for (const cap of afterTrust) {
91
- if (policy(pluginName, cap)) {
92
- granted.push(cap);
93
- } else {
94
- denied.push(cap);
95
- denialReasons[cap] = `Capability '${cap}' denied by runtime policy`;
96
- logger.warn(
97
- `[plugin-lifecycle:${pluginName}] Capability '${cap}' denied by policy`,
98
- );
99
- }
100
- }
101
-
102
- logger.debug(
103
- `[plugin-lifecycle:${pluginName}] Capabilities resolved (trust=${trustTier})` +
104
- ` — granted: [${granted.join(', ')}]` +
105
- (denied.length > 0 ? `, denied: [${denied.join(', ')}]` : ''),
106
- );
107
-
108
- return {
109
- requested: Object.freeze(requested),
110
- granted,
111
- denied,
112
- denialReasons,
113
- };
114
- }
115
-
116
- /**
117
- * isHighRiskCapability — Returns whether a capability is classified as high-risk.
118
- * High-risk capabilities require the `trusted` tier to be granted.
119
- */
120
- export function isHighRiskCapability(capability: PluginCapability): boolean {
121
- return (HIGH_RISK_CAPABILITIES as ReadonlyArray<string>).includes(capability);
122
- }
123
-
124
- /**
125
- * hasCapability — Returns whether a plugin has been granted a specific
126
- * capability after manifest resolution.
127
- */
128
- export function hasCapability(
129
- manifest: PluginCapabilityManifest,
130
- capability: PluginCapability,
131
- ): boolean {
132
- return manifest.granted.includes(capability);
133
- }
134
-
135
- /**
136
- * validateManifestV2 — Light validation of the PluginManifestV2 shape.
137
- * Returns null on success or an error string on failure.
138
- */
139
- export function validateManifestV2(manifest: unknown): string | null {
140
- if (!manifest || typeof manifest !== 'object') {
141
- return 'manifest must be an object';
142
- }
143
- const m = manifest as Record<string, unknown>;
144
- if (typeof m['name'] !== 'string' || !m['name']) {
145
- return "manifest.name must be a non-empty string";
146
- }
147
- if (typeof m['version'] !== 'string' || !m['version']) {
148
- return "manifest.version must be a non-empty string";
149
- }
150
- if (typeof m['description'] !== 'string') {
151
- return "manifest.description must be a string";
152
- }
153
- if (m['capabilities'] !== undefined) {
154
- if (!Array.isArray(m['capabilities'])) {
155
- return "manifest.capabilities must be an array";
156
- }
157
- for (const cap of m['capabilities'] as unknown[]) {
158
- if (typeof cap !== 'string') {
159
- return `manifest.capabilities entries must be strings, got: ${typeof cap}`;
160
- }
161
- }
162
- }
163
- if (m['minRuntimeVersion'] !== undefined && typeof m['minRuntimeVersion'] !== 'string') {
164
- return "manifest.minRuntimeVersion must be a string";
165
- }
166
- return null;
167
- }