@pellux/goodvibes-tui 0.18.11 → 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 +22 -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,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
- }