@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,130 +0,0 @@
1
- import type { Tool, ToolCall } from '@pellux/goodvibes-sdk/platform/types/tools';
2
- import type { ToolRuntimeContext } from '@pellux/goodvibes-sdk/platform/runtime/tools/context';
3
- import type { BudgetExceedReason, PhaseResult, ToolExecutionPhase, ToolExecutionRecord } from '@pellux/goodvibes-sdk/platform/runtime/tools/types';
4
-
5
- /**
6
- * budget — Budget enforcement phase for the tool execution pipeline.
7
- *
8
- * This phase is inserted at two points:
9
- * - "entry": just before execute (checks elapsed wall-clock time).
10
- * - "exit": just after mapOutput (checks token and cost budgets).
11
- *
12
- * When a hard budget is exceeded the phase returns `abort: true` with a
13
- * typed `budgetExceedReason` so the executor can surface a diagnostic
14
- * event before terminating the pipeline.
15
- *
16
- * All budget fields are optional in ToolRuntimeContext.budget — an absent
17
- * field means "unlimited" and the corresponding check is skipped.
18
- */
19
-
20
- /** The point in the pipeline at which the budget check fires. */
21
- export type BudgetCheckPoint = 'entry' | 'exit';
22
-
23
- export async function budgetPhase(
24
- _call: ToolCall,
25
- _tool: Tool,
26
- context: ToolRuntimeContext,
27
- record: ToolExecutionRecord,
28
- checkpoint: BudgetCheckPoint,
29
- ): Promise<PhaseResult> {
30
- const start = performance.now();
31
- const phaseName = checkpoint === 'entry' ? 'budget-entry' : 'budget-exit';
32
-
33
- const budget = context.budget;
34
-
35
- // No budget constraints — fast path
36
- if (!budget) {
37
- return ok(start, phaseName);
38
- }
39
-
40
- const elapsedMs = performance.now() - record.startedAt;
41
-
42
- // ── Time budget (checked at both entry and exit) ────────────────────────
43
- // All budget comparisons use strict > so that a value exactly at the limit is
44
- // still allowed — enforcement fires only when the limit is truly exceeded.
45
- if (budget.maxMs !== undefined && elapsedMs > budget.maxMs) {
46
- return exceed(start, phaseName, 'BUDGET_EXCEEDED_MS', {
47
- limitMs: budget.maxMs,
48
- elapsedMs,
49
- });
50
- }
51
-
52
- // ── Token and cost budgets (only meaningful at exit after execute ran) ──
53
- if (checkpoint === 'exit') {
54
- // Token budget: the tool result may carry a `tokenCount` annotation.
55
- // We check it if present; if absent we skip (cannot enforce unknown usage).
56
- const tokenCount = getTokenCount(record);
57
- if (budget.maxTokens !== undefined && tokenCount !== undefined && tokenCount > budget.maxTokens) {
58
- return exceed(start, phaseName, 'BUDGET_EXCEEDED_TOKENS', {
59
- limitTokens: budget.maxTokens,
60
- usedTokens: tokenCount,
61
- });
62
- }
63
-
64
- // Cost budget: same — only enforce when the tool result carries a cost.
65
- const costUsd = getCostUsd(record);
66
- if (budget.maxCostUsd !== undefined && costUsd !== undefined && costUsd > budget.maxCostUsd) {
67
- return exceed(start, phaseName, 'BUDGET_EXCEEDED_COST', {
68
- limitCostUsd: budget.maxCostUsd,
69
- usedCostUsd: costUsd,
70
- });
71
- }
72
- }
73
-
74
- return ok(start, phaseName);
75
- }
76
-
77
- // ---------------------------------------------------------------------------
78
- // Helpers
79
- // ---------------------------------------------------------------------------
80
-
81
- function ok(start: number, phase: ToolExecutionPhase): PhaseResult {
82
- return {
83
- phase,
84
- success: true,
85
- durationMs: performance.now() - start,
86
- };
87
- }
88
-
89
- function exceed(
90
- start: number,
91
- phase: ToolExecutionPhase,
92
- reason: BudgetExceedReason,
93
- meta: Record<string, number>,
94
- ): PhaseResult {
95
- const parts = Object.entries(meta)
96
- .map(([k, v]) => `${k}=${v}`)
97
- .join(', ');
98
- return {
99
- phase,
100
- success: false,
101
- durationMs: performance.now() - start,
102
- error: `Budget exceeded [${reason}]: ${parts}`,
103
- abort: true,
104
- budgetExceedReason: reason,
105
- budgetMeta: meta,
106
- };
107
- }
108
-
109
- /**
110
- * Extracts a token count from the tool execution record result, if available.
111
- * Tools may annotate their result with `tokenCount` as a numeric field.
112
- */
113
- function getTokenCount(record: ToolExecutionRecord): number | undefined {
114
- if (!record.result) return undefined;
115
- // Double cast needed: ToolResult has no index signature, but tool implementations
116
- // may annotate results with extra numeric fields like `tokenCount`.
117
- const raw = (record.result as unknown as Record<string, unknown>)['tokenCount'];
118
- return typeof raw === 'number' ? raw : undefined;
119
- }
120
-
121
- /**
122
- * Extracts a cost annotation from the tool execution record result, if available.
123
- * Tools may annotate their result with `costUsd` as a numeric field.
124
- */
125
- function getCostUsd(record: ToolExecutionRecord): number | undefined {
126
- if (!record.result) return undefined;
127
- // Double cast needed: same reason as getTokenCount above.
128
- const raw = (record.result as unknown as Record<string, unknown>)['costUsd'];
129
- return typeof raw === 'number' ? raw : undefined;
130
- }
@@ -1,69 +0,0 @@
1
- import type { Tool, ToolCall, ToolResult } from '@pellux/goodvibes-sdk/platform/types/tools';
2
- import type { ToolRuntimeContext } from '@pellux/goodvibes-sdk/platform/runtime/tools/context';
3
- import type { ExecutorConfig, PhaseResult, ToolExecutionRecord } from '@pellux/goodvibes-sdk/platform/runtime/tools/types';
4
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
5
-
6
- /** Default per-call execution timeout (30 seconds). */
7
- const DEFAULT_EXECUTE_TIMEOUT_MS = 30_000;
8
-
9
- /**
10
- * execute — Phase 4 of the tool execution pipeline.
11
- *
12
- * Calls `tool.execute(args)` and injects the callId into the result.
13
- * Respects the phase timeout and the budget.maxMs constraint.
14
- * Caught errors produce a failed PhaseResult (not thrown) so the
15
- * executor can record the failure trace cleanly.
16
- *
17
- * The resolved args honour any prehook-modified input stored as
18
- * `_updatedArgs` on the record.
19
- */
20
- export async function executePhase(
21
- call: ToolCall,
22
- tool: Tool,
23
- context: ToolRuntimeContext,
24
- record: ToolExecutionRecord,
25
- config?: ExecutorConfig,
26
- ): Promise<PhaseResult & { toolResult?: ToolResult }> {
27
- const start = performance.now();
28
-
29
- const effectiveArgs = record._updatedArgs ?? call.arguments;
30
-
31
- // Resolve timeout: per-phase override → budget → default
32
- const timeoutMs =
33
- config?.phaseTimeouts?.['executing'] ?? context.budget?.maxMs ?? DEFAULT_EXECUTE_TIMEOUT_MS;
34
-
35
- let timer: ReturnType<typeof setTimeout> | undefined;
36
-
37
- try {
38
- // Race between the tool and a timeout; clear the timer regardless of outcome
39
- const rawResult = await Promise.race([
40
- tool.execute(effectiveArgs),
41
- new Promise<never>((_, reject) => {
42
- timer = setTimeout(
43
- () => reject(new Error(`Tool '${call.name}' timed out after ${timeoutMs}ms`)),
44
- timeoutMs,
45
- );
46
- }),
47
- ]);
48
- clearTimeout(timer);
49
-
50
- const toolResult: ToolResult = { ...rawResult, callId: call.id };
51
-
52
- return {
53
- phase: 'executing',
54
- success: true,
55
- durationMs: performance.now() - start,
56
- toolResult,
57
- };
58
- } catch (err) {
59
- clearTimeout(timer);
60
- const message = summarizeError(err);
61
- return {
62
- phase: 'executing',
63
- success: false,
64
- durationMs: performance.now() - start,
65
- error: message,
66
- abort: true,
67
- };
68
- }
69
- }
@@ -1,13 +0,0 @@
1
- /**
2
- * phases/index.ts — barrel export for all tool execution phase functions.
3
- *
4
- * Each export is a pure async function conforming to PhaseFunction.
5
- * The pipeline is assembled in phased-executor.ts.
6
- */
7
- export { validatePhase } from '@pellux/goodvibes-sdk/platform/runtime/tools/phases/validate';
8
- export { prehookPhase } from '@pellux/goodvibes-sdk/platform/runtime/tools/phases/prehook';
9
- export { permissionPhase } from '@pellux/goodvibes-sdk/platform/runtime/tools/phases/permission';
10
- export { budgetPhase } from '@pellux/goodvibes-sdk/platform/runtime/tools/phases/budget';
11
- export { executePhase } from '@pellux/goodvibes-sdk/platform/runtime/tools/phases/execute';
12
- export { mapOutputPhase } from '@pellux/goodvibes-sdk/platform/runtime/tools/phases/map-output';
13
- export { posthookPhase } from '@pellux/goodvibes-sdk/platform/runtime/tools/phases/posthook';
@@ -1,98 +0,0 @@
1
- import type { Tool, ToolCall } from '@pellux/goodvibes-sdk/platform/types/tools';
2
- import { repairToolCall } from '@pellux/goodvibes-sdk/platform/tools/auto-repair';
3
- import type { ToolRuntimeContext } from '@pellux/goodvibes-sdk/platform/runtime/tools/context';
4
- import type { PhaseResult, ToolExecutionRecord } from '@pellux/goodvibes-sdk/platform/runtime/tools/types';
5
- import type { PhasedTool } from '@pellux/goodvibes-sdk/platform/runtime/tools/adapter';
6
- import type { ToolClass } from '@pellux/goodvibes-sdk/platform/runtime/tools/output-policy';
7
- import { applyOutputPolicy, getPolicy } from '@pellux/goodvibes-sdk/platform/runtime/tools/output-policy';
8
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
9
-
10
- /**
11
- * mapOutput — Phase 5 of the tool execution pipeline.
12
- *
13
- * Transforms/annotates the raw tool result before it reaches the LLM:
14
- *
15
- * 1. Applies auto-repair annotation: if args were repaired during
16
- * execution, prepends a `[Auto-repaired: ...]` note to the output
17
- * so the LLM knows what was corrected.
18
- * 2. Applies output policy enforcement: byte limits, truncation, and spill
19
- * handling are applied per tool class via `applyOutputPolicy`.
20
- * 3. No-ops cleanly when there is no result to map (defensive guard).
21
- */
22
- /** Type guard — true when `tool` carries phased execution metadata. */
23
- function isPhasedTool(tool: Tool): tool is PhasedTool {
24
- return 'category' in tool && typeof (tool as PhasedTool).category === 'string';
25
- }
26
-
27
- /**
28
- * Maps a PhasedTool category to the ToolClass used by output-policy.
29
- * `delegate` has no direct output-policy class; treat as `analyze`.
30
- */
31
- function resolveToolClass(tool: Tool): ToolClass {
32
- if (!isPhasedTool(tool)) return 'read';
33
- switch (tool.category) {
34
- case 'read': return 'read';
35
- case 'write': return 'write';
36
- case 'execute': return 'execute';
37
- case 'network': return 'network';
38
- case 'delegate': return 'analyze';
39
- default: return 'read';
40
- }
41
- }
42
-
43
- export async function mapOutputPhase(
44
- call: ToolCall,
45
- tool: Tool,
46
- _context: ToolRuntimeContext,
47
- record: ToolExecutionRecord,
48
- ): Promise<PhaseResult> {
49
- const start = performance.now();
50
-
51
- if (!record.result) {
52
- // No result to map — this is a no-op (execute phase may have failed)
53
- return {
54
- phase: 'mapped',
55
- success: true,
56
- durationMs: performance.now() - start,
57
- };
58
- }
59
-
60
- try {
61
- // Re-run repair check to determine if the original args were patched
62
- const effectiveArgs = record._updatedArgs ?? call.arguments;
63
- const repairResult = repairToolCall(call.name, effectiveArgs, tool.definition);
64
-
65
- if (repairResult.repaired) {
66
- const repairNote = `[Auto-repaired: ${repairResult.repairs.join(', ')}]`;
67
- if (typeof record.result.output === 'string') {
68
- record.result.output = `${repairNote}\n${record.result.output}`;
69
- } else {
70
- record.result.output = repairNote;
71
- }
72
- }
73
-
74
- // Apply output policy enforcement after auto-repair annotation
75
- const toolClass = resolveToolClass(tool);
76
- const policy = getPolicy(toolClass);
77
- const auditedResult = applyOutputPolicy(record.result, policy, _context.overflowHandler!);
78
- record.result = auditedResult.result;
79
-
80
- // Surface spill backend in phase metadata when overflow occurred
81
- const spillBackend = auditedResult.audit.spillBackend;
82
- return {
83
- phase: 'mapped',
84
- success: true,
85
- durationMs: performance.now() - start,
86
- ...(spillBackend ? { spillBackend } : {}),
87
- };
88
- } catch (err) {
89
- // Mapping failure is non-fatal — pass through unmapped result
90
- const message = summarizeError(err);
91
- return {
92
- phase: 'mapped',
93
- success: true,
94
- durationMs: performance.now() - start,
95
- error: `Output mapping failed (non-fatal): ${message}`,
96
- };
97
- }
98
- }
@@ -1,133 +0,0 @@
1
- import type { Tool, ToolCall } from '@pellux/goodvibes-sdk/platform/types/tools';
2
- import type { ToolRuntimeContext } from '@pellux/goodvibes-sdk/platform/runtime/tools/context';
3
- import type { PhaseResult, ToolExecutionRecord } from '@pellux/goodvibes-sdk/platform/runtime/tools/types';
4
- import {
5
- emitPermissionDecision,
6
- emitPermissionRequested,
7
- } from '@pellux/goodvibes-sdk/platform/runtime/emitters/permissions';
8
- import type { PermissionCheckResult } from '@pellux/goodvibes-sdk/platform/permissions/types';
9
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
10
-
11
- /**
12
- * permission — Phase 3 of the tool execution pipeline.
13
- *
14
- * Delegates to PermissionManager.check(). If permission is denied,
15
- * the phase aborts and no further phases are run.
16
- *
17
- * The resolved args used here account for any input updates from the
18
- * prehook phase (stored as `_updatedArgs` on the record).
19
- */
20
- export async function permissionPhase(
21
- call: ToolCall,
22
- _tool: Tool,
23
- context: ToolRuntimeContext,
24
- record: ToolExecutionRecord,
25
- ): Promise<PhaseResult> {
26
- const start = performance.now();
27
-
28
- // Use updated args from prehook if present
29
- const effectiveArgs = record._updatedArgs ?? call.arguments;
30
-
31
- const resolvePermissionResult = async (): Promise<PermissionCheckResult> => {
32
- const manager = context.permissionManager as unknown as {
33
- checkDetailed?: (toolName: string, args: Record<string, unknown>) => Promise<PermissionCheckResult>;
34
- check?: (toolName: string, args: Record<string, unknown>) => Promise<boolean>;
35
- getCategory: (toolName: string) => string;
36
- };
37
-
38
- if (typeof manager.checkDetailed === 'function') {
39
- return manager.checkDetailed(call.name, effectiveArgs);
40
- }
41
-
42
- if (typeof manager.check === 'function') {
43
- const approved = await manager.check(call.name, effectiveArgs);
44
- return {
45
- approved,
46
- persisted: false,
47
- sourceLayer: approved ? 'config_policy' : 'user_prompt',
48
- reasonCode: approved ? 'config_allow' : 'user_denied',
49
- analysis: {
50
- classification: 'generic',
51
- riskLevel: 'medium',
52
- summary: `Permission ${approved ? 'approved' : 'denied'} for ${call.name}`,
53
- reasons: [],
54
- },
55
- };
56
- }
57
-
58
- throw new Error('PermissionManager is missing both checkDetailed() and check()');
59
- };
60
-
61
- try {
62
- if (context.runtimeBus) {
63
- const analysis = await resolvePermissionResult();
64
- emitPermissionRequested(context.runtimeBus, {
65
- sessionId: context.ids.sessionId,
66
- traceId: context.ids.traceId,
67
- source: 'permission-manager',
68
- }, {
69
- callId: call.id,
70
- tool: call.name,
71
- args: effectiveArgs,
72
- category: context.permissionManager.getCategory(call.name),
73
- classification: analysis.analysis.classification,
74
- riskLevel: analysis.analysis.riskLevel,
75
- summary: analysis.analysis.summary,
76
- reasons: analysis.analysis.reasons,
77
- });
78
-
79
- emitPermissionDecision(context.runtimeBus, {
80
- sessionId: context.ids.sessionId,
81
- traceId: context.ids.traceId,
82
- source: 'permission-manager',
83
- }, {
84
- callId: call.id,
85
- tool: call.name,
86
- approved: analysis.approved,
87
- source: 'permission-manager',
88
- sourceLayer: analysis.sourceLayer,
89
- persisted: analysis.persisted,
90
- reasonCode: analysis.reasonCode,
91
- classification: analysis.analysis.classification,
92
- riskLevel: analysis.analysis.riskLevel,
93
- summary: analysis.analysis.summary,
94
- });
95
-
96
- if (!analysis.approved) {
97
- return {
98
- phase: 'permissioned',
99
- success: false,
100
- durationMs: performance.now() - start,
101
- error: `Permission denied for tool '${call.name}'`,
102
- abort: true,
103
- };
104
- }
105
- } else {
106
- const analysis = await resolvePermissionResult();
107
- if (!analysis.approved) {
108
- return {
109
- phase: 'permissioned',
110
- success: false,
111
- durationMs: performance.now() - start,
112
- error: `Permission denied for tool '${call.name}'`,
113
- abort: true,
114
- };
115
- }
116
- }
117
-
118
- return {
119
- phase: 'permissioned',
120
- success: true,
121
- durationMs: performance.now() - start,
122
- };
123
- } catch (err) {
124
- const message = summarizeError(err);
125
- return {
126
- phase: 'permissioned',
127
- success: false,
128
- durationMs: performance.now() - start,
129
- error: `Permission check threw: ${message}`,
130
- abort: true,
131
- };
132
- }
133
- }
@@ -1,57 +0,0 @@
1
- import type { Tool, ToolCall } from '@pellux/goodvibes-sdk/platform/types/tools';
2
- import type { ToolRuntimeContext } from '@pellux/goodvibes-sdk/platform/runtime/tools/context';
3
- import type { PhaseResult, ToolExecutionRecord } from '@pellux/goodvibes-sdk/platform/runtime/tools/types';
4
- import { summarizeError } from '@pellux/goodvibes-sdk/platform/utils/error-display';
5
-
6
- /**
7
- * posthook — Phase 6 of the tool execution pipeline.
8
- *
9
- * Fires `Post:tool:<toolName>` hook via the HookDispatcher.
10
- *
11
- * Post-hooks are non-blocking in the following sense: a hook failure does
12
- * NOT fail the tool call. The phase always returns success=true so the
13
- * executor can proceed to `succeeded`. Hook errors are captured in the
14
- * PhaseResult.error field for observability without aborting the call.
15
- */
16
- export async function posthookPhase(
17
- call: ToolCall,
18
- _tool: Tool,
19
- context: ToolRuntimeContext,
20
- record: ToolExecutionRecord,
21
- ): Promise<PhaseResult> {
22
- const start = performance.now();
23
-
24
- try {
25
- await context.hookDispatcher.fire({
26
- path: `Post:tool:${call.name}`,
27
- phase: 'Post',
28
- category: 'tool',
29
- specific: call.name,
30
- sessionId: context.ids.sessionId,
31
- timestamp: Date.now(),
32
- payload: {
33
- callId: call.id,
34
- toolName: call.name,
35
- args: record._updatedArgs ?? call.arguments,
36
- result: record.result,
37
- success: record.result?.success ?? false,
38
- },
39
- agentId: context.agent?.agentId,
40
- });
41
-
42
- return {
43
- phase: 'posthooked',
44
- success: true,
45
- durationMs: performance.now() - start,
46
- };
47
- } catch (err) {
48
- // Post-hook failure must not fail the tool call
49
- const message = summarizeError(err);
50
- return {
51
- phase: 'posthooked',
52
- success: true,
53
- durationMs: performance.now() - start,
54
- error: `Post-hook threw (non-fatal): ${message}`,
55
- };
56
- }
57
- }
@@ -1,68 +0,0 @@
1
- import type { Tool, ToolCall } from '@pellux/goodvibes-sdk/platform/types/tools';
2
- import type { ToolRuntimeContext } from '@pellux/goodvibes-sdk/platform/runtime/tools/context';
3
- import type { PhaseResult, ToolExecutionRecord } from '@pellux/goodvibes-sdk/platform/runtime/tools/types';
4
-
5
- /**
6
- * prehook — Phase 2 of the tool execution pipeline.
7
- *
8
- * Fires `Pre:tool:<toolName>` hook via the HookDispatcher.
9
- * If the hook returns a `deny` decision, execution is aborted.
10
- * If the hook returns `updatedInput`, the record's args are updated
11
- * in-place so subsequent phases see the modified arguments.
12
- *
13
- * Hook failures (network, timeout, etc.) are treated as allow to avoid
14
- * blocking tool execution on non-critical infrastructure errors.
15
- */
16
- export async function prehookPhase(
17
- call: ToolCall,
18
- _tool: Tool,
19
- context: ToolRuntimeContext,
20
- record: ToolExecutionRecord,
21
- ): Promise<PhaseResult> {
22
- const start = performance.now();
23
-
24
- try {
25
- const hookResult = await context.hookDispatcher.fire({
26
- path: `Pre:tool:${call.name}`,
27
- phase: 'Pre',
28
- category: 'tool',
29
- specific: call.name,
30
- sessionId: context.ids.sessionId,
31
- timestamp: Date.now(),
32
- payload: {
33
- callId: call.id,
34
- toolName: call.name,
35
- args: call.arguments,
36
- },
37
- agentId: context.agent?.agentId,
38
- });
39
-
40
- if (hookResult.decision === 'deny') {
41
- return {
42
- phase: 'prehooked',
43
- success: false,
44
- durationMs: performance.now() - start,
45
- error: hookResult.reason ?? 'Pre-hook denied tool execution',
46
- abort: true,
47
- };
48
- }
49
-
50
- // Allow hooks to modify input arguments for subsequent phases
51
- if (hookResult.updatedInput) {
52
- record._updatedArgs = hookResult.updatedInput;
53
- }
54
-
55
- return {
56
- phase: 'prehooked',
57
- success: true,
58
- durationMs: performance.now() - start,
59
- };
60
- } catch (_err) {
61
- // Hook infrastructure failure — allow execution to proceed
62
- return {
63
- phase: 'prehooked',
64
- success: true,
65
- durationMs: performance.now() - start,
66
- };
67
- }
68
- }
@@ -1,53 +0,0 @@
1
- import type { Tool, ToolCall } from '@pellux/goodvibes-sdk/platform/types/tools';
2
- import type { ToolRuntimeContext } from '@pellux/goodvibes-sdk/platform/runtime/tools/context';
3
- import type { PhaseResult, ToolExecutionRecord } from '@pellux/goodvibes-sdk/platform/runtime/tools/types';
4
-
5
- /**
6
- * validate — Phase 1 of the tool execution pipeline.
7
- *
8
- * Performs lightweight pre-flight checks:
9
- * - The call has a non-empty id
10
- * - The call has a non-empty tool name
11
- * - Args is a plain object (not null)
12
- * - The tool object is present
13
- *
14
- * Heavy schema validation (JSON Schema against parameters) is intentionally
15
- * left to a future tier — this phase acts as a guard against programmer
16
- * errors and malformed LLM payloads.
17
- */
18
- export async function validatePhase(
19
- call: ToolCall,
20
- tool: Tool,
21
- _context: ToolRuntimeContext,
22
- _record: ToolExecutionRecord,
23
- ): Promise<PhaseResult> {
24
- const start = performance.now();
25
-
26
- if (!call.id || call.id.trim().length === 0) {
27
- return result(start, false, 'Tool call is missing a valid id');
28
- }
29
-
30
- if (!call.name || call.name.trim().length === 0) {
31
- return result(start, false, 'Tool call is missing a tool name');
32
- }
33
-
34
- if (call.arguments === null || typeof call.arguments !== 'object' || Array.isArray(call.arguments)) {
35
- return result(start, false, `Tool call args must be a plain object, got: ${typeof call.arguments}`);
36
- }
37
-
38
- if (!tool || typeof tool.execute !== 'function') {
39
- return result(start, false, `Tool '${call.name}' is not a valid tool implementation`);
40
- }
41
-
42
- return result(start, true);
43
- }
44
-
45
- function result(start: number, success: boolean, error?: string): PhaseResult {
46
- return {
47
- phase: 'validated',
48
- success,
49
- durationMs: performance.now() - start,
50
- error,
51
- abort: success ? undefined : true,
52
- };
53
- }