@machina.ai/cell-cli-core 1.22.5-rc1 → 1.25.0-rc1

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 (732) hide show
  1. package/dist/docs/AFTER_MERGE_PROMPT.md +26 -0
  2. package/dist/docs/CHANGES.md +124 -0
  3. package/dist/docs/api-proxy.md +27 -0
  4. package/dist/docs/architecture.md +80 -0
  5. package/dist/docs/assets/connected_devtools.png +0 -0
  6. package/dist/docs/assets/gemini-screenshot.png +0 -0
  7. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  8. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  9. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  10. package/dist/docs/assets/release_patch.png +0 -0
  11. package/dist/docs/assets/theme-ansi-light.png +0 -0
  12. package/dist/docs/assets/theme-ansi.png +0 -0
  13. package/dist/docs/assets/theme-atom-one.png +0 -0
  14. package/dist/docs/assets/theme-ayu-light.png +0 -0
  15. package/dist/docs/assets/theme-ayu.png +0 -0
  16. package/dist/docs/assets/theme-custom.png +0 -0
  17. package/dist/docs/assets/theme-default-light.png +0 -0
  18. package/dist/docs/assets/theme-default.png +0 -0
  19. package/dist/docs/assets/theme-dracula.png +0 -0
  20. package/dist/docs/assets/theme-github-light.png +0 -0
  21. package/dist/docs/assets/theme-github.png +0 -0
  22. package/dist/docs/assets/theme-google-light.png +0 -0
  23. package/dist/docs/assets/theme-xcode-light.png +0 -0
  24. package/dist/docs/changelogs/index.md +612 -0
  25. package/dist/docs/changelogs/latest.md +153 -0
  26. package/dist/docs/changelogs/preview.md +131 -0
  27. package/dist/docs/changelogs/releases.md +1162 -0
  28. package/dist/docs/cli/authentication.md +3 -0
  29. package/dist/docs/cli/checkpointing.md +94 -0
  30. package/dist/docs/cli/commands.md +357 -0
  31. package/dist/docs/cli/custom-commands.md +315 -0
  32. package/dist/docs/cli/enterprise.md +564 -0
  33. package/dist/docs/cli/gemini-ignore.md +71 -0
  34. package/dist/docs/cli/gemini-md.md +109 -0
  35. package/dist/docs/cli/generation-settings.md +210 -0
  36. package/dist/docs/cli/headless.md +388 -0
  37. package/dist/docs/cli/index.md +63 -0
  38. package/dist/docs/cli/keyboard-shortcuts.md +136 -0
  39. package/dist/docs/cli/model-routing.md +37 -0
  40. package/dist/docs/cli/model.md +62 -0
  41. package/dist/docs/cli/sandbox.md +171 -0
  42. package/dist/docs/cli/session-management.md +158 -0
  43. package/dist/docs/cli/settings.md +148 -0
  44. package/dist/docs/cli/skills.md +188 -0
  45. package/dist/docs/cli/system-prompt.md +94 -0
  46. package/dist/docs/cli/telemetry.md +813 -0
  47. package/dist/docs/cli/themes.md +237 -0
  48. package/dist/docs/cli/token-caching.md +20 -0
  49. package/dist/docs/cli/trusted-folders.md +95 -0
  50. package/dist/docs/cli/tutorials/skills-getting-started.md +124 -0
  51. package/dist/docs/cli/tutorials.md +87 -0
  52. package/dist/docs/cli/uninstall.md +47 -0
  53. package/dist/docs/core/index.md +101 -0
  54. package/dist/docs/core/memport.md +246 -0
  55. package/dist/docs/core/policy-engine.md +268 -0
  56. package/dist/docs/core/tools-api.md +131 -0
  57. package/dist/docs/examples/proxy-script.md +83 -0
  58. package/dist/docs/extensions/extension-releasing.md +183 -0
  59. package/dist/docs/extensions/getting-started-extensions.md +244 -0
  60. package/dist/docs/extensions/index.md +343 -0
  61. package/dist/docs/faq.md +153 -0
  62. package/dist/docs/get-started/authentication.md +321 -0
  63. package/dist/docs/get-started/configuration-v1.md +890 -0
  64. package/dist/docs/get-started/configuration.md +1643 -0
  65. package/dist/docs/get-started/examples.md +218 -0
  66. package/dist/docs/get-started/gemini-3.md +101 -0
  67. package/dist/docs/get-started/index.md +71 -0
  68. package/dist/docs/get-started/installation.md +141 -0
  69. package/dist/docs/hooks/best-practices.md +856 -0
  70. package/dist/docs/hooks/index.md +723 -0
  71. package/dist/docs/hooks/reference.md +178 -0
  72. package/dist/docs/hooks/writing-hooks.md +1044 -0
  73. package/dist/docs/ide-integration/ide-companion-spec.md +267 -0
  74. package/dist/docs/ide-integration/index.md +201 -0
  75. package/dist/docs/index.md +147 -0
  76. package/dist/docs/integration-tests.md +211 -0
  77. package/dist/docs/issue-and-pr-automation.md +134 -0
  78. package/dist/docs/local-development.md +128 -0
  79. package/dist/docs/mcp_integration.md +160 -0
  80. package/dist/docs/mermaid/context.mmd +103 -0
  81. package/dist/docs/mermaid/render-path.mmd +64 -0
  82. package/dist/docs/npm.md +62 -0
  83. package/dist/docs/quota-and-pricing.md +158 -0
  84. package/dist/docs/release-confidence.md +164 -0
  85. package/dist/docs/releases.md +540 -0
  86. package/dist/docs/sidebar.json +301 -0
  87. package/dist/docs/tools/file-system.md +217 -0
  88. package/dist/docs/tools/index.md +95 -0
  89. package/dist/docs/tools/mcp-server.md +1045 -0
  90. package/dist/docs/tools/memory.md +54 -0
  91. package/dist/docs/tools/shell.md +260 -0
  92. package/dist/docs/tools/todos.md +56 -0
  93. package/dist/docs/tools/web-fetch.md +59 -0
  94. package/dist/docs/tools/web-search.md +42 -0
  95. package/dist/docs/tos-privacy.md +96 -0
  96. package/dist/docs/troubleshooting.md +162 -0
  97. package/dist/package.json +7 -4
  98. package/dist/src/agents/a2a-client-manager.d.ts +82 -0
  99. package/dist/src/agents/a2a-client-manager.js +295 -0
  100. package/dist/src/agents/a2a-client-manager.js.map +1 -0
  101. package/dist/src/agents/a2a-client-manager.test.js +281 -0
  102. package/dist/src/agents/a2a-client-manager.test.js.map +1 -0
  103. package/dist/src/agents/a2aUtils.d.ts +29 -0
  104. package/dist/src/agents/a2aUtils.js +113 -0
  105. package/dist/src/agents/a2aUtils.js.map +1 -0
  106. package/dist/src/agents/a2aUtils.test.js +147 -0
  107. package/dist/src/agents/a2aUtils.test.js.map +1 -0
  108. package/dist/src/agents/agentLoader.d.ts +68 -0
  109. package/dist/src/agents/agentLoader.js +255 -0
  110. package/dist/src/agents/agentLoader.js.map +1 -0
  111. package/dist/src/agents/agentLoader.test.js +307 -0
  112. package/dist/src/agents/agentLoader.test.js.map +1 -0
  113. package/dist/src/agents/cli-help-agent.d.ts +24 -0
  114. package/dist/src/agents/cli-help-agent.js +85 -0
  115. package/dist/src/agents/cli-help-agent.js.map +1 -0
  116. package/dist/src/agents/cli-help-agent.test.js +65 -0
  117. package/dist/src/agents/cli-help-agent.test.js.map +1 -0
  118. package/dist/src/agents/codebase-investigator.d.ts +2 -2
  119. package/dist/src/agents/codebase-investigator.js +14 -8
  120. package/dist/src/agents/codebase-investigator.js.map +1 -1
  121. package/dist/src/agents/delegate-to-agent-tool.d.ts +2 -2
  122. package/dist/src/agents/delegate-to-agent-tool.js +25 -14
  123. package/dist/src/agents/delegate-to-agent-tool.js.map +1 -1
  124. package/dist/src/agents/delegate-to-agent-tool.test.js +101 -21
  125. package/dist/src/agents/delegate-to-agent-tool.test.js.map +1 -1
  126. package/dist/src/agents/{executor.d.ts → local-executor.d.ts} +5 -11
  127. package/dist/src/agents/{executor.js → local-executor.js} +123 -62
  128. package/dist/src/agents/local-executor.js.map +1 -0
  129. package/dist/src/agents/local-executor.test.d.ts +6 -0
  130. package/dist/src/agents/{executor.test.js → local-executor.test.js} +136 -58
  131. package/dist/src/agents/local-executor.test.js.map +1 -0
  132. package/dist/src/agents/{invocation.d.ts → local-invocation.d.ts} +6 -7
  133. package/dist/src/agents/{invocation.js → local-invocation.js} +9 -10
  134. package/dist/src/agents/local-invocation.js.map +1 -0
  135. package/dist/src/agents/local-invocation.test.d.ts +6 -0
  136. package/dist/src/agents/{invocation.test.js → local-invocation.test.js} +29 -20
  137. package/dist/src/agents/local-invocation.test.js.map +1 -0
  138. package/dist/src/agents/registry.d.ts +22 -1
  139. package/dist/src/agents/registry.js +192 -35
  140. package/dist/src/agents/registry.js.map +1 -1
  141. package/dist/src/agents/registry.test.js +407 -33
  142. package/dist/src/agents/registry.test.js.map +1 -1
  143. package/dist/src/agents/remote-invocation.d.ts +35 -0
  144. package/dist/src/agents/remote-invocation.js +126 -0
  145. package/dist/src/agents/remote-invocation.js.map +1 -0
  146. package/dist/src/agents/remote-invocation.test.d.ts +6 -0
  147. package/dist/src/agents/remote-invocation.test.js +201 -0
  148. package/dist/src/agents/remote-invocation.test.js.map +1 -0
  149. package/dist/src/agents/subagent-tool-wrapper.d.ts +2 -2
  150. package/dist/src/agents/subagent-tool-wrapper.js +11 -6
  151. package/dist/src/agents/subagent-tool-wrapper.js.map +1 -1
  152. package/dist/src/agents/subagent-tool-wrapper.test.js +33 -19
  153. package/dist/src/agents/subagent-tool-wrapper.test.js.map +1 -1
  154. package/dist/src/agents/types.d.ts +21 -15
  155. package/dist/src/agents/types.js.map +1 -1
  156. package/dist/src/availability/fallbackIntegration.test.d.ts +6 -0
  157. package/dist/src/availability/fallbackIntegration.test.js +58 -0
  158. package/dist/src/availability/fallbackIntegration.test.js.map +1 -0
  159. package/dist/src/availability/modelAvailabilityService.d.ts +2 -1
  160. package/dist/src/availability/policyHelpers.d.ts +4 -3
  161. package/dist/src/availability/policyHelpers.js +13 -22
  162. package/dist/src/availability/policyHelpers.js.map +1 -1
  163. package/dist/src/availability/policyHelpers.test.js +28 -18
  164. package/dist/src/availability/policyHelpers.test.js.map +1 -1
  165. package/dist/src/code_assist/experiments/experiments.d.ts +1 -1
  166. package/dist/src/code_assist/experiments/experiments.js +21 -0
  167. package/dist/src/code_assist/experiments/experiments.js.map +1 -1
  168. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +6 -0
  169. package/dist/src/code_assist/experiments/experiments_local.test.js +110 -0
  170. package/dist/src/code_assist/experiments/experiments_local.test.js.map +1 -0
  171. package/dist/src/code_assist/oauth-credential-storage.js +3 -4
  172. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -1
  173. package/dist/src/code_assist/oauth2.js +32 -2
  174. package/dist/src/code_assist/oauth2.js.map +1 -1
  175. package/dist/src/code_assist/oauth2.test.js +111 -16
  176. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  177. package/dist/src/code_assist/server.d.ts +9 -1
  178. package/dist/src/code_assist/server.js +74 -11
  179. package/dist/src/code_assist/server.js.map +1 -1
  180. package/dist/src/code_assist/server.test.js +199 -27
  181. package/dist/src/code_assist/server.test.js.map +1 -1
  182. package/dist/src/code_assist/setup.js +6 -4
  183. package/dist/src/code_assist/setup.js.map +1 -1
  184. package/dist/src/code_assist/setup.test.js +63 -0
  185. package/dist/src/code_assist/setup.test.js.map +1 -1
  186. package/dist/src/code_assist/telemetry.d.ts +14 -0
  187. package/dist/src/code_assist/telemetry.js +157 -0
  188. package/dist/src/code_assist/telemetry.js.map +1 -0
  189. package/dist/src/code_assist/telemetry.test.d.ts +6 -0
  190. package/dist/src/code_assist/telemetry.test.js +301 -0
  191. package/dist/src/code_assist/telemetry.test.js.map +1 -0
  192. package/dist/src/code_assist/types.d.ts +77 -1
  193. package/dist/src/code_assist/types.js +28 -0
  194. package/dist/src/code_assist/types.js.map +1 -1
  195. package/dist/src/commands/memory.d.ts +11 -0
  196. package/dist/src/commands/memory.js +80 -0
  197. package/dist/src/commands/memory.js.map +1 -0
  198. package/dist/src/commands/memory.test.d.ts +6 -0
  199. package/dist/src/commands/memory.test.js +155 -0
  200. package/dist/src/commands/memory.test.js.map +1 -0
  201. package/dist/src/config/config.d.ts +120 -26
  202. package/dist/src/config/config.js +241 -120
  203. package/dist/src/config/config.js.map +1 -1
  204. package/dist/src/config/config.test.js +215 -43
  205. package/dist/src/config/config.test.js.map +1 -1
  206. package/dist/src/config/flashFallback.test.js +11 -35
  207. package/dist/src/config/flashFallback.test.js.map +1 -1
  208. package/dist/src/config/models.d.ts +8 -9
  209. package/dist/src/config/models.js +18 -15
  210. package/dist/src/config/models.js.map +1 -1
  211. package/dist/src/config/models.test.js +52 -16
  212. package/dist/src/config/models.test.js.map +1 -1
  213. package/dist/src/config/storage.d.ts +5 -0
  214. package/dist/src/config/storage.js +17 -2
  215. package/dist/src/config/storage.js.map +1 -1
  216. package/dist/src/config/storage.test.js +16 -0
  217. package/dist/src/config/storage.test.js.map +1 -1
  218. package/dist/src/confirmation-bus/message-bus.js +2 -1
  219. package/dist/src/confirmation-bus/message-bus.js.map +1 -1
  220. package/dist/src/core/baseLlmClient.js +44 -43
  221. package/dist/src/core/baseLlmClient.js.map +1 -1
  222. package/dist/src/core/baseLlmClient.test.js +12 -19
  223. package/dist/src/core/baseLlmClient.test.js.map +1 -1
  224. package/dist/src/core/client.d.ts +7 -1
  225. package/dist/src/core/client.js +245 -114
  226. package/dist/src/core/client.js.map +1 -1
  227. package/dist/src/core/client.test.js +277 -74
  228. package/dist/src/core/client.test.js.map +1 -1
  229. package/dist/src/core/clientHookTriggers.js +2 -2
  230. package/dist/src/core/clientHookTriggers.js.map +1 -1
  231. package/dist/src/core/contentGenerator.js +3 -3
  232. package/dist/src/core/contentGenerator.js.map +1 -1
  233. package/dist/src/core/contentGenerator.test.js +1 -7
  234. package/dist/src/core/contentGenerator.test.js.map +1 -1
  235. package/dist/src/core/coreToolHookTriggers.d.ts +9 -5
  236. package/dist/src/core/coreToolHookTriggers.js +119 -21
  237. package/dist/src/core/coreToolHookTriggers.js.map +1 -1
  238. package/dist/src/core/coreToolHookTriggers.test.d.ts +6 -0
  239. package/dist/src/core/coreToolHookTriggers.test.js +191 -0
  240. package/dist/src/core/coreToolHookTriggers.test.js.map +1 -0
  241. package/dist/src/core/coreToolScheduler.d.ts +7 -93
  242. package/dist/src/core/coreToolScheduler.js +133 -369
  243. package/dist/src/core/coreToolScheduler.js.map +1 -1
  244. package/dist/src/core/coreToolScheduler.test.js +252 -394
  245. package/dist/src/core/coreToolScheduler.test.js.map +1 -1
  246. package/dist/src/core/geminiChat.d.ts +26 -1
  247. package/dist/src/core/geminiChat.js +112 -79
  248. package/dist/src/core/geminiChat.js.map +1 -1
  249. package/dist/src/core/geminiChat.test.js +125 -92
  250. package/dist/src/core/geminiChat.test.js.map +1 -1
  251. package/dist/src/core/geminiChatHookTriggers.d.ts +8 -4
  252. package/dist/src/core/geminiChatHookTriggers.js +34 -12
  253. package/dist/src/core/geminiChatHookTriggers.js.map +1 -1
  254. package/dist/src/core/geminiChatHookTriggers.test.d.ts +6 -0
  255. package/dist/src/core/geminiChatHookTriggers.test.js +153 -0
  256. package/dist/src/core/geminiChatHookTriggers.test.js.map +1 -0
  257. package/dist/src/core/geminiChat_network_retry.test.js +4 -6
  258. package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
  259. package/dist/src/core/loggingContentGenerator.js +19 -2
  260. package/dist/src/core/loggingContentGenerator.js.map +1 -1
  261. package/dist/src/core/loggingContentGenerator.test.js +30 -0
  262. package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
  263. package/dist/src/core/nonInteractiveToolExecutor.test.js +4 -4
  264. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -1
  265. package/dist/src/core/prompts.js +37 -13
  266. package/dist/src/core/prompts.js.map +1 -1
  267. package/dist/src/core/prompts.test.js +47 -3
  268. package/dist/src/core/prompts.test.js.map +1 -1
  269. package/dist/src/core/tokenLimits.js +6 -12
  270. package/dist/src/core/tokenLimits.js.map +1 -1
  271. package/dist/src/core/tokenLimits.test.js +8 -4
  272. package/dist/src/core/tokenLimits.test.js.map +1 -1
  273. package/dist/src/core/turn.d.ts +21 -22
  274. package/dist/src/core/turn.js +31 -21
  275. package/dist/src/core/turn.js.map +1 -1
  276. package/dist/src/core/turn.test.js +79 -5
  277. package/dist/src/core/turn.test.js.map +1 -1
  278. package/dist/src/fallback/handler.js +1 -7
  279. package/dist/src/fallback/handler.js.map +1 -1
  280. package/dist/src/fallback/handler.test.js +10 -29
  281. package/dist/src/fallback/handler.test.js.map +1 -1
  282. package/dist/src/generated/git-commit.d.ts +3 -3
  283. package/dist/src/generated/git-commit.js +3 -3
  284. package/dist/src/hooks/hookAggregator.js +7 -0
  285. package/dist/src/hooks/hookAggregator.js.map +1 -1
  286. package/dist/src/hooks/hookEventHandler.d.ts +9 -5
  287. package/dist/src/hooks/hookEventHandler.js +61 -15
  288. package/dist/src/hooks/hookEventHandler.js.map +1 -1
  289. package/dist/src/hooks/hookEventHandler.test.js +223 -8
  290. package/dist/src/hooks/hookEventHandler.test.js.map +1 -1
  291. package/dist/src/hooks/hookPlanner.d.ts +1 -5
  292. package/dist/src/hooks/hookPlanner.js +2 -7
  293. package/dist/src/hooks/hookPlanner.js.map +1 -1
  294. package/dist/src/hooks/hookPlanner.test.js +62 -2
  295. package/dist/src/hooks/hookPlanner.test.js.map +1 -1
  296. package/dist/src/hooks/hookRegistry.d.ts +6 -11
  297. package/dist/src/hooks/hookRegistry.js +41 -14
  298. package/dist/src/hooks/hookRegistry.js.map +1 -1
  299. package/dist/src/hooks/hookRegistry.test.js +166 -2
  300. package/dist/src/hooks/hookRegistry.test.js.map +1 -1
  301. package/dist/src/hooks/hookRunner.d.ts +5 -3
  302. package/dist/src/hooks/hookRunner.js +57 -17
  303. package/dist/src/hooks/hookRunner.js.map +1 -1
  304. package/dist/src/hooks/hookRunner.test.js +172 -35
  305. package/dist/src/hooks/hookRunner.test.js.map +1 -1
  306. package/dist/src/hooks/hookSystem.d.ts +12 -0
  307. package/dist/src/hooks/hookSystem.js +39 -1
  308. package/dist/src/hooks/hookSystem.js.map +1 -1
  309. package/dist/src/hooks/hookTranslator.js +2 -1
  310. package/dist/src/hooks/hookTranslator.js.map +1 -1
  311. package/dist/src/hooks/index.d.ts +1 -2
  312. package/dist/src/hooks/index.js +1 -3
  313. package/dist/src/hooks/index.js.map +1 -1
  314. package/dist/src/hooks/trustedHooks.d.ts +28 -0
  315. package/dist/src/hooks/trustedHooks.js +90 -0
  316. package/dist/src/hooks/trustedHooks.js.map +1 -0
  317. package/dist/src/hooks/trustedHooks.test.d.ts +6 -0
  318. package/dist/src/hooks/trustedHooks.test.js +154 -0
  319. package/dist/src/hooks/trustedHooks.test.js.map +1 -0
  320. package/dist/src/hooks/types.d.ts +41 -9
  321. package/dist/src/hooks/types.js +31 -41
  322. package/dist/src/hooks/types.js.map +1 -1
  323. package/dist/src/hooks/types.test.js +9 -52
  324. package/dist/src/hooks/types.test.js.map +1 -1
  325. package/dist/src/ide/detect-ide.d.ts +4 -0
  326. package/dist/src/ide/detect-ide.js +7 -2
  327. package/dist/src/ide/detect-ide.js.map +1 -1
  328. package/dist/src/ide/detect-ide.test.js +10 -0
  329. package/dist/src/ide/detect-ide.test.js.map +1 -1
  330. package/dist/src/ide/ide-client.js +4 -1
  331. package/dist/src/ide/ide-client.js.map +1 -1
  332. package/dist/src/ide/ide-installer.js +2 -2
  333. package/dist/src/ide/ide-installer.js.map +1 -1
  334. package/dist/src/ide/ide-installer.test.js +11 -2
  335. package/dist/src/ide/ide-installer.test.js.map +1 -1
  336. package/dist/src/index.d.ts +16 -2
  337. package/dist/src/index.js +18 -3
  338. package/dist/src/index.js.map +1 -1
  339. package/dist/src/mcp/oauth-provider.js +7 -3
  340. package/dist/src/mcp/oauth-provider.js.map +1 -1
  341. package/dist/src/mcp/oauth-provider.test.js +4 -1
  342. package/dist/src/mcp/oauth-provider.test.js.map +1 -1
  343. package/dist/src/mcp/oauth-utils.d.ts +8 -1
  344. package/dist/src/mcp/oauth-utils.js +31 -2
  345. package/dist/src/mcp/oauth-utils.js.map +1 -1
  346. package/dist/src/mcp/oauth-utils.test.js +42 -0
  347. package/dist/src/mcp/oauth-utils.test.js.map +1 -1
  348. package/dist/src/mcp/token-storage/file-token-storage.js +2 -2
  349. package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -1
  350. package/dist/src/mcp/token-storage/keychain-token-storage.js +1 -1
  351. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -1
  352. package/dist/src/policy/config.js +62 -23
  353. package/dist/src/policy/config.js.map +1 -1
  354. package/dist/src/policy/config.test.js +24 -2
  355. package/dist/src/policy/config.test.js.map +1 -1
  356. package/dist/src/policy/persistence.test.js +1 -1
  357. package/dist/src/policy/persistence.test.js.map +1 -1
  358. package/dist/src/policy/policies/agent.toml +1 -1
  359. package/dist/src/policy/policies/write.toml +5 -0
  360. package/dist/src/policy/policies/yolo.toml +1 -0
  361. package/dist/src/policy/policy-engine.d.ts +4 -0
  362. package/dist/src/policy/policy-engine.js +137 -53
  363. package/dist/src/policy/policy-engine.js.map +1 -1
  364. package/dist/src/policy/policy-engine.test.js +289 -1
  365. package/dist/src/policy/policy-engine.test.js.map +1 -1
  366. package/dist/src/policy/policy-updater.test.js +5 -5
  367. package/dist/src/policy/policy-updater.test.js.map +1 -1
  368. package/dist/src/policy/shell-safety.test.js +371 -8
  369. package/dist/src/policy/shell-safety.test.js.map +1 -1
  370. package/dist/src/policy/toml-loader.d.ts +0 -8
  371. package/dist/src/policy/toml-loader.js +13 -45
  372. package/dist/src/policy/toml-loader.js.map +1 -1
  373. package/dist/src/policy/toml-loader.test.js +13 -0
  374. package/dist/src/policy/toml-loader.test.js.map +1 -1
  375. package/dist/src/policy/types.d.ts +10 -0
  376. package/dist/src/policy/utils.d.ts +21 -0
  377. package/dist/src/policy/utils.js +45 -0
  378. package/dist/src/policy/utils.js.map +1 -0
  379. package/dist/src/policy/utils.test.d.ts +6 -0
  380. package/dist/src/policy/utils.test.js +92 -0
  381. package/dist/src/policy/utils.test.js.map +1 -0
  382. package/dist/src/routing/routingStrategy.d.ts +2 -0
  383. package/dist/src/routing/strategies/classifierStrategy.js +1 -1
  384. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -1
  385. package/dist/src/routing/strategies/classifierStrategy.test.js +16 -0
  386. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -1
  387. package/dist/src/routing/strategies/compositeStrategy.js +4 -2
  388. package/dist/src/routing/strategies/compositeStrategy.js.map +1 -1
  389. package/dist/src/routing/strategies/compositeStrategy.test.js +11 -10
  390. package/dist/src/routing/strategies/compositeStrategy.test.js.map +1 -1
  391. package/dist/src/routing/strategies/fallbackStrategy.d.ts +1 -1
  392. package/dist/src/routing/strategies/fallbackStrategy.js +2 -5
  393. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -1
  394. package/dist/src/routing/strategies/fallbackStrategy.test.js +13 -6
  395. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +1 -1
  396. package/dist/src/routing/strategies/overrideStrategy.d.ts +1 -1
  397. package/dist/src/routing/strategies/overrideStrategy.js +6 -6
  398. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -1
  399. package/dist/src/routing/strategies/overrideStrategy.test.js +14 -0
  400. package/dist/src/routing/strategies/overrideStrategy.test.js.map +1 -1
  401. package/dist/src/scheduler/tool-executor.d.ts +22 -0
  402. package/dist/src/scheduler/tool-executor.js +198 -0
  403. package/dist/src/scheduler/tool-executor.js.map +1 -0
  404. package/dist/src/scheduler/tool-executor.test.d.ts +6 -0
  405. package/dist/src/scheduler/tool-executor.test.js +231 -0
  406. package/dist/src/scheduler/tool-executor.test.js.map +1 -0
  407. package/dist/src/scheduler/tool-modifier.d.ts +23 -0
  408. package/dist/src/scheduler/tool-modifier.js +50 -0
  409. package/dist/src/scheduler/tool-modifier.js.map +1 -0
  410. package/dist/src/scheduler/tool-modifier.test.d.ts +6 -0
  411. package/dist/src/scheduler/tool-modifier.test.js +159 -0
  412. package/dist/src/scheduler/tool-modifier.test.js.map +1 -0
  413. package/dist/src/scheduler/types.d.ts +95 -0
  414. package/dist/src/scheduler/types.js +7 -0
  415. package/dist/src/scheduler/types.js.map +1 -0
  416. package/dist/src/services/chatCompressionService.js +3 -10
  417. package/dist/src/services/chatCompressionService.js.map +1 -1
  418. package/dist/src/services/chatCompressionService.test.js +1 -0
  419. package/dist/src/services/chatCompressionService.test.js.map +1 -1
  420. package/dist/src/services/chatRecordingService.d.ts +7 -1
  421. package/dist/src/services/chatRecordingService.js +20 -2
  422. package/dist/src/services/chatRecordingService.js.map +1 -1
  423. package/dist/src/services/chatRecordingService.test.js +43 -0
  424. package/dist/src/services/chatRecordingService.test.js.map +1 -1
  425. package/dist/src/services/contextManager.d.ts +5 -11
  426. package/dist/src/services/contextManager.js +20 -17
  427. package/dist/src/services/contextManager.js.map +1 -1
  428. package/dist/src/services/contextManager.test.js +40 -41
  429. package/dist/src/services/contextManager.test.js.map +1 -1
  430. package/dist/src/services/environmentSanitization.d.ts +15 -0
  431. package/dist/src/services/environmentSanitization.js +142 -0
  432. package/dist/src/services/environmentSanitization.js.map +1 -0
  433. package/dist/src/services/environmentSanitization.test.d.ts +6 -0
  434. package/dist/src/services/environmentSanitization.test.js +284 -0
  435. package/dist/src/services/environmentSanitization.test.js.map +1 -0
  436. package/dist/src/services/gitService.js +10 -1
  437. package/dist/src/services/gitService.js.map +1 -1
  438. package/dist/src/services/gitService.test.js +28 -2
  439. package/dist/src/services/gitService.test.js.map +1 -1
  440. package/dist/src/services/loopDetectionService.js +2 -1
  441. package/dist/src/services/loopDetectionService.js.map +1 -1
  442. package/dist/src/services/loopDetectionService.test.js +14 -8
  443. package/dist/src/services/loopDetectionService.test.js.map +1 -1
  444. package/dist/src/services/modelConfig.integration.test.js +3 -3
  445. package/dist/src/services/modelConfig.integration.test.js.map +1 -1
  446. package/dist/src/services/modelConfigService.d.ts +38 -4
  447. package/dist/src/services/modelConfigService.js +135 -76
  448. package/dist/src/services/modelConfigService.js.map +1 -1
  449. package/dist/src/services/modelConfigService.test.js +116 -0
  450. package/dist/src/services/modelConfigService.test.js.map +1 -1
  451. package/dist/src/services/shellExecutionService.d.ts +2 -0
  452. package/dist/src/services/shellExecutionService.js +6 -50
  453. package/dist/src/services/shellExecutionService.js.map +1 -1
  454. package/dist/src/services/shellExecutionService.test.js +68 -4
  455. package/dist/src/services/shellExecutionService.test.js.map +1 -1
  456. package/dist/src/skills/skillLoader.d.ts +31 -0
  457. package/dist/src/skills/skillLoader.js +77 -0
  458. package/dist/src/skills/skillLoader.js.map +1 -0
  459. package/dist/src/skills/skillLoader.test.d.ts +6 -0
  460. package/dist/src/skills/skillLoader.test.js +75 -0
  461. package/dist/src/skills/skillLoader.test.js.map +1 -0
  462. package/dist/src/skills/skillManager.d.ts +69 -0
  463. package/dist/src/skills/skillManager.js +127 -0
  464. package/dist/src/skills/skillManager.js.map +1 -0
  465. package/dist/src/skills/skillManager.test.d.ts +6 -0
  466. package/dist/src/skills/skillManager.test.js +210 -0
  467. package/dist/src/skills/skillManager.test.js.map +1 -0
  468. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +18 -9
  469. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +234 -160
  470. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
  471. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +162 -32
  472. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
  473. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +11 -3
  474. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +24 -5
  475. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
  476. package/dist/src/telemetry/loggers.d.ts +3 -3
  477. package/dist/src/telemetry/loggers.js +6 -5
  478. package/dist/src/telemetry/loggers.js.map +1 -1
  479. package/dist/src/telemetry/loggers.test.circular.js +1 -0
  480. package/dist/src/telemetry/loggers.test.circular.js.map +1 -1
  481. package/dist/src/telemetry/loggers.test.js +51 -10
  482. package/dist/src/telemetry/loggers.test.js.map +1 -1
  483. package/dist/src/telemetry/sdk.js +5 -6
  484. package/dist/src/telemetry/sdk.js.map +1 -1
  485. package/dist/src/telemetry/types.d.ts +7 -7
  486. package/dist/src/telemetry/types.js +14 -12
  487. package/dist/src/telemetry/types.js.map +1 -1
  488. package/dist/src/test-utils/mock-message-bus.d.ts +1 -0
  489. package/dist/src/test-utils/mock-message-bus.js +29 -0
  490. package/dist/src/test-utils/mock-message-bus.js.map +1 -1
  491. package/dist/src/test-utils/mock-tool.d.ts +5 -3
  492. package/dist/src/test-utils/mock-tool.js +11 -10
  493. package/dist/src/test-utils/mock-tool.js.map +1 -1
  494. package/dist/src/tools/activate-skill.d.ts +27 -0
  495. package/dist/src/tools/activate-skill.js +133 -0
  496. package/dist/src/tools/activate-skill.js.map +1 -0
  497. package/dist/src/tools/activate-skill.test.d.ts +6 -0
  498. package/dist/src/tools/activate-skill.test.js +113 -0
  499. package/dist/src/tools/activate-skill.test.js.map +1 -0
  500. package/dist/src/tools/confirmation-policy.test.js +3 -12
  501. package/dist/src/tools/confirmation-policy.test.js.map +1 -1
  502. package/dist/src/tools/edit.d.ts +27 -5
  503. package/dist/src/tools/edit.js +455 -136
  504. package/dist/src/tools/edit.js.map +1 -1
  505. package/dist/src/tools/edit.test.js +292 -526
  506. package/dist/src/tools/edit.test.js.map +1 -1
  507. package/dist/src/tools/get-internal-docs.d.ts +27 -0
  508. package/dist/src/tools/get-internal-docs.js +122 -0
  509. package/dist/src/tools/get-internal-docs.js.map +1 -0
  510. package/dist/src/tools/get-internal-docs.test.d.ts +6 -0
  511. package/dist/src/tools/get-internal-docs.test.js +57 -0
  512. package/dist/src/tools/get-internal-docs.test.js.map +1 -0
  513. package/dist/src/tools/glob.d.ts +2 -2
  514. package/dist/src/tools/glob.js +1 -1
  515. package/dist/src/tools/glob.js.map +1 -1
  516. package/dist/src/tools/glob.test.js +2 -1
  517. package/dist/src/tools/glob.test.js.map +1 -1
  518. package/dist/src/tools/grep.d.ts +2 -2
  519. package/dist/src/tools/grep.js +1 -1
  520. package/dist/src/tools/grep.js.map +1 -1
  521. package/dist/src/tools/grep.test.js +5 -4
  522. package/dist/src/tools/grep.test.js.map +1 -1
  523. package/dist/src/tools/ls.d.ts +2 -2
  524. package/dist/src/tools/ls.js +2 -2
  525. package/dist/src/tools/ls.js.map +1 -1
  526. package/dist/src/tools/ls.test.js +2 -1
  527. package/dist/src/tools/ls.test.js.map +1 -1
  528. package/dist/src/tools/mcp-client-manager.js +14 -7
  529. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  530. package/dist/src/tools/mcp-client-manager.test.js +28 -0
  531. package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
  532. package/dist/src/tools/mcp-client.d.ts +5 -4
  533. package/dist/src/tools/mcp-client.js +10 -8
  534. package/dist/src/tools/mcp-client.js.map +1 -1
  535. package/dist/src/tools/mcp-client.test.js +47 -42
  536. package/dist/src/tools/mcp-client.test.js.map +1 -1
  537. package/dist/src/tools/mcp-tool.d.ts +20 -5
  538. package/dist/src/tools/mcp-tool.js +8 -8
  539. package/dist/src/tools/mcp-tool.js.map +1 -1
  540. package/dist/src/tools/mcp-tool.test.js +11 -6
  541. package/dist/src/tools/mcp-tool.test.js.map +1 -1
  542. package/dist/src/tools/memoryTool.d.ts +3 -3
  543. package/dist/src/tools/memoryTool.js +2 -4
  544. package/dist/src/tools/memoryTool.js.map +1 -1
  545. package/dist/src/tools/memoryTool.test.js +5 -2
  546. package/dist/src/tools/memoryTool.test.js.map +1 -1
  547. package/dist/src/tools/message-bus-integration.test.js +10 -37
  548. package/dist/src/tools/message-bus-integration.test.js.map +1 -1
  549. package/dist/src/tools/read-file.d.ts +2 -2
  550. package/dist/src/tools/read-file.js +1 -1
  551. package/dist/src/tools/read-file.js.map +1 -1
  552. package/dist/src/tools/read-file.test.js +3 -2
  553. package/dist/src/tools/read-file.test.js.map +1 -1
  554. package/dist/src/tools/read-many-files.d.ts +2 -2
  555. package/dist/src/tools/read-many-files.js +2 -3
  556. package/dist/src/tools/read-many-files.js.map +1 -1
  557. package/dist/src/tools/read-many-files.test.js +3 -2
  558. package/dist/src/tools/read-many-files.test.js.map +1 -1
  559. package/dist/src/tools/ripGrep.d.ts +3 -2
  560. package/dist/src/tools/ripGrep.js +18 -7
  561. package/dist/src/tools/ripGrep.js.map +1 -1
  562. package/dist/src/tools/ripGrep.test.js +60 -4
  563. package/dist/src/tools/ripGrep.test.js.map +1 -1
  564. package/dist/src/tools/shell.d.ts +3 -6
  565. package/dist/src/tools/shell.js +21 -49
  566. package/dist/src/tools/shell.js.map +1 -1
  567. package/dist/src/tools/shell.test.js +35 -59
  568. package/dist/src/tools/shell.test.js.map +1 -1
  569. package/dist/src/tools/tool-error.d.ts +6 -1
  570. package/dist/src/tools/tool-error.js +6 -0
  571. package/dist/src/tools/tool-error.js.map +1 -1
  572. package/dist/src/tools/tool-names.d.ts +15 -0
  573. package/dist/src/tools/tool-names.js +57 -0
  574. package/dist/src/tools/tool-names.js.map +1 -1
  575. package/dist/src/tools/tool-names.test.d.ts +6 -0
  576. package/dist/src/tools/tool-names.test.js +43 -0
  577. package/dist/src/tools/tool-names.test.js.map +1 -0
  578. package/dist/src/tools/tool-registry.d.ts +11 -7
  579. package/dist/src/tools/tool-registry.js +15 -10
  580. package/dist/src/tools/tool-registry.js.map +1 -1
  581. package/dist/src/tools/tool-registry.test.js +16 -11
  582. package/dist/src/tools/tool-registry.test.js.map +1 -1
  583. package/dist/src/tools/tools.d.ts +8 -6
  584. package/dist/src/tools/tools.js +16 -18
  585. package/dist/src/tools/tools.js.map +1 -1
  586. package/dist/src/tools/tools.test.js +3 -1
  587. package/dist/src/tools/tools.test.js.map +1 -1
  588. package/dist/src/tools/web-fetch.d.ts +2 -2
  589. package/dist/src/tools/web-fetch.js +4 -4
  590. package/dist/src/tools/web-fetch.js.map +1 -1
  591. package/dist/src/tools/web-fetch.test.js +17 -19
  592. package/dist/src/tools/web-fetch.test.js.map +1 -1
  593. package/dist/src/tools/web-search.d.ts +2 -2
  594. package/dist/src/tools/web-search.js +5 -5
  595. package/dist/src/tools/web-search.js.map +1 -1
  596. package/dist/src/tools/web-search.test.js +2 -1
  597. package/dist/src/tools/web-search.test.js.map +1 -1
  598. package/dist/src/tools/write-file.d.ts +2 -2
  599. package/dist/src/tools/write-file.js +9 -6
  600. package/dist/src/tools/write-file.js.map +1 -1
  601. package/dist/src/tools/write-file.test.js +49 -7
  602. package/dist/src/tools/write-file.test.js.map +1 -1
  603. package/dist/src/tools/write-todos.d.ts +2 -2
  604. package/dist/src/tools/write-todos.js +5 -4
  605. package/dist/src/tools/write-todos.js.map +1 -1
  606. package/dist/src/tools/write-todos.test.js +2 -1
  607. package/dist/src/tools/write-todos.test.js.map +1 -1
  608. package/dist/src/utils/apiConversionUtils.d.ts +12 -0
  609. package/dist/src/utils/apiConversionUtils.js +46 -0
  610. package/dist/src/utils/apiConversionUtils.js.map +1 -0
  611. package/dist/src/utils/apiConversionUtils.test.d.ts +6 -0
  612. package/dist/src/utils/apiConversionUtils.test.js +150 -0
  613. package/dist/src/utils/apiConversionUtils.test.js.map +1 -0
  614. package/dist/src/utils/checkpointUtils.d.ts +1 -1
  615. package/dist/src/utils/checkpointUtils.js +1 -1
  616. package/dist/src/utils/checkpointUtils.js.map +1 -1
  617. package/dist/src/utils/checkpointUtils.test.js +1 -1
  618. package/dist/src/utils/checkpointUtils.test.js.map +1 -1
  619. package/dist/src/utils/debugLogger.js +1 -0
  620. package/dist/src/utils/debugLogger.js.map +1 -1
  621. package/dist/src/utils/editCorrector.d.ts +3 -3
  622. package/dist/src/utils/editCorrector.js +27 -10
  623. package/dist/src/utils/editCorrector.js.map +1 -1
  624. package/dist/src/utils/editCorrector.test.js +23 -23
  625. package/dist/src/utils/editCorrector.test.js.map +1 -1
  626. package/dist/src/utils/editor.d.ts +3 -2
  627. package/dist/src/utils/editor.js +26 -6
  628. package/dist/src/utils/editor.js.map +1 -1
  629. package/dist/src/utils/editor.test.js +27 -4
  630. package/dist/src/utils/editor.test.js.map +1 -1
  631. package/dist/src/utils/environmentContext.d.ts +1 -0
  632. package/dist/src/utils/environmentContext.js +4 -0
  633. package/dist/src/utils/environmentContext.js.map +1 -1
  634. package/dist/src/utils/environmentContext.test.js +2 -0
  635. package/dist/src/utils/environmentContext.test.js.map +1 -1
  636. package/dist/src/utils/errorReporting.d.ts +1 -1
  637. package/dist/src/utils/errorReporting.js +13 -12
  638. package/dist/src/utils/errorReporting.js.map +1 -1
  639. package/dist/src/utils/errorReporting.test.js +17 -14
  640. package/dist/src/utils/errorReporting.test.js.map +1 -1
  641. package/dist/src/utils/events.d.ts +71 -19
  642. package/dist/src/utils/events.js +35 -9
  643. package/dist/src/utils/events.js.map +1 -1
  644. package/dist/src/utils/events.test.js +25 -0
  645. package/dist/src/utils/events.test.js.map +1 -1
  646. package/dist/src/utils/fileDiffUtils.d.ts +18 -0
  647. package/dist/src/utils/fileDiffUtils.js +37 -0
  648. package/dist/src/utils/fileDiffUtils.js.map +1 -0
  649. package/dist/src/utils/fileDiffUtils.test.d.ts +6 -0
  650. package/dist/src/utils/fileDiffUtils.test.js +84 -0
  651. package/dist/src/utils/fileDiffUtils.test.js.map +1 -0
  652. package/dist/src/utils/fileUtils.d.ts +4 -0
  653. package/dist/src/utils/fileUtils.js +53 -0
  654. package/dist/src/utils/fileUtils.js.map +1 -1
  655. package/dist/src/utils/fileUtils.test.js +112 -1
  656. package/dist/src/utils/fileUtils.test.js.map +1 -1
  657. package/dist/src/utils/geminiIgnoreParser.d.ts +11 -0
  658. package/dist/src/utils/geminiIgnoreParser.js +20 -0
  659. package/dist/src/utils/geminiIgnoreParser.js.map +1 -1
  660. package/dist/src/utils/geminiIgnoreParser.test.js +48 -0
  661. package/dist/src/utils/geminiIgnoreParser.test.js.map +1 -1
  662. package/dist/src/utils/generateContentResponseUtilities.d.ts +3 -1
  663. package/dist/src/utils/generateContentResponseUtilities.js +106 -0
  664. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -1
  665. package/dist/src/utils/generateContentResponseUtilities.test.js +279 -2
  666. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -1
  667. package/dist/src/utils/getFolderStructure.js +7 -2
  668. package/dist/src/utils/getFolderStructure.js.map +1 -1
  669. package/dist/src/utils/gitIgnoreParser.js +9 -10
  670. package/dist/src/utils/gitIgnoreParser.js.map +1 -1
  671. package/dist/src/utils/installationManager.test.js +11 -3
  672. package/dist/src/utils/installationManager.test.js.map +1 -1
  673. package/dist/src/utils/memoryDiscovery.js +3 -4
  674. package/dist/src/utils/memoryDiscovery.js.map +1 -1
  675. package/dist/src/utils/memoryDiscovery.test.js +12 -1
  676. package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
  677. package/dist/src/utils/partUtils.js +1 -1
  678. package/dist/src/utils/partUtils.js.map +1 -1
  679. package/dist/src/utils/paths.d.ts +10 -0
  680. package/dist/src/utils/paths.js +20 -1
  681. package/dist/src/utils/paths.js.map +1 -1
  682. package/dist/src/utils/retry.d.ts +1 -0
  683. package/dist/src/utils/retry.js +17 -5
  684. package/dist/src/utils/retry.js.map +1 -1
  685. package/dist/src/utils/retry.test.js +11 -11
  686. package/dist/src/utils/retry.test.js.map +1 -1
  687. package/dist/src/utils/shell-utils.d.ts +6 -0
  688. package/dist/src/utils/shell-utils.js +97 -12
  689. package/dist/src/utils/shell-utils.js.map +1 -1
  690. package/dist/src/utils/shell-utils.test.js +99 -1
  691. package/dist/src/utils/shell-utils.test.js.map +1 -1
  692. package/dist/src/utils/summarizer.test.js +3 -2
  693. package/dist/src/utils/summarizer.test.js.map +1 -1
  694. package/dist/src/utils/terminal.d.ts +4 -0
  695. package/dist/src/utils/terminal.js +12 -0
  696. package/dist/src/utils/terminal.js.map +1 -1
  697. package/dist/src/utils/tokenCalculation.js +20 -5
  698. package/dist/src/utils/tokenCalculation.js.map +1 -1
  699. package/dist/src/utils/tokenCalculation.test.js +11 -2
  700. package/dist/src/utils/tokenCalculation.test.js.map +1 -1
  701. package/dist/src/utils/tool-utils.d.ts +9 -0
  702. package/dist/src/utils/tool-utils.js +29 -0
  703. package/dist/src/utils/tool-utils.js.map +1 -1
  704. package/dist/src/utils/tool-utils.test.js +17 -2
  705. package/dist/src/utils/tool-utils.test.js.map +1 -1
  706. package/dist/src/utils/userAccountManager.test.js +5 -5
  707. package/dist/src/utils/userAccountManager.test.js.map +1 -1
  708. package/dist/src/utils/workspaceContext.test.js +1 -1
  709. package/dist/src/utils/workspaceContext.test.js.map +1 -1
  710. package/dist/tsconfig.tsbuildinfo +1 -1
  711. package/package.json +8 -6
  712. package/dist/src/agents/executor.js.map +0 -1
  713. package/dist/src/agents/executor.test.js.map +0 -1
  714. package/dist/src/agents/invocation.js.map +0 -1
  715. package/dist/src/agents/invocation.test.js.map +0 -1
  716. package/dist/src/core/sessionHookTriggers.d.ts +0 -28
  717. package/dist/src/core/sessionHookTriggers.js +0 -68
  718. package/dist/src/core/sessionHookTriggers.js.map +0 -1
  719. package/dist/src/tools/smart-edit.d.ts +0 -78
  720. package/dist/src/tools/smart-edit.js +0 -722
  721. package/dist/src/tools/smart-edit.js.map +0 -1
  722. package/dist/src/tools/smart-edit.test.js +0 -592
  723. package/dist/src/tools/smart-edit.test.js.map +0 -1
  724. package/dist/src/utils/shell-permissions.d.ts +0 -52
  725. package/dist/src/utils/shell-permissions.js +0 -188
  726. package/dist/src/utils/shell-permissions.js.map +0 -1
  727. package/dist/src/utils/shell-permissions.test.js +0 -347
  728. package/dist/src/utils/shell-permissions.test.js.map +0 -1
  729. /package/dist/src/agents/{executor.test.d.ts → a2a-client-manager.test.d.ts} +0 -0
  730. /package/dist/src/agents/{invocation.test.d.ts → a2aUtils.test.d.ts} +0 -0
  731. /package/dist/src/{tools/smart-edit.test.d.ts → agents/agentLoader.test.d.ts} +0 -0
  732. /package/dist/src/{utils/shell-permissions.test.d.ts → agents/cli-help-agent.test.d.ts} +0 -0
@@ -4,8 +4,10 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  import { spawn } from 'node:child_process';
7
- import { HookEventName } from './types.js';
7
+ import { HookEventName, ConfigSource } from './types.js';
8
8
  import { debugLogger } from '../utils/debugLogger.js';
9
+ import { sanitizeEnvironment } from '../services/environmentSanitization.js';
10
+ import { escapeShellArg, getShellConfiguration, } from '../utils/shell-utils.js';
9
11
  /**
10
12
  * Default timeout for hook execution (60 seconds)
11
13
  */
@@ -20,19 +22,35 @@ const EXIT_CODE_NON_BLOCKING_ERROR = 1;
20
22
  * Hook runner that executes command hooks
21
23
  */
22
24
  export class HookRunner {
23
- constructor() { }
25
+ config;
26
+ constructor(config) {
27
+ this.config = config;
28
+ }
24
29
  /**
25
30
  * Execute a single hook
26
31
  */
27
32
  async executeHook(hookConfig, eventName, input) {
28
33
  const startTime = Date.now();
34
+ // Secondary security check: Ensure project hooks are not executed in untrusted folders
35
+ if (hookConfig.source === ConfigSource.Project &&
36
+ !this.config.isTrustedFolder()) {
37
+ const errorMessage = 'Security: Blocked execution of project hook in untrusted folder';
38
+ debugLogger.warn(errorMessage);
39
+ return {
40
+ hookConfig,
41
+ eventName,
42
+ success: false,
43
+ error: new Error(errorMessage),
44
+ duration: 0,
45
+ };
46
+ }
29
47
  try {
30
48
  return await this.executeCommandHook(hookConfig, eventName, input, startTime);
31
49
  }
32
50
  catch (error) {
33
51
  const duration = Date.now() - startTime;
34
- const hookSource = hookConfig.command || 'unknown';
35
- const errorMessage = `Hook execution failed for event '${eventName}' (source: ${hookSource}): ${error}`;
52
+ const hookId = hookConfig.name || hookConfig.command || 'unknown';
53
+ const errorMessage = `Hook execution failed for event '${eventName}' (hook: ${hookId}): ${error}`;
36
54
  debugLogger.warn(`Hook execution error (non-fatal): ${errorMessage}`);
37
55
  return {
38
56
  hookConfig,
@@ -46,18 +64,26 @@ export class HookRunner {
46
64
  /**
47
65
  * Execute multiple hooks in parallel
48
66
  */
49
- async executeHooksParallel(hookConfigs, eventName, input) {
50
- const promises = hookConfigs.map((config) => this.executeHook(config, eventName, input));
67
+ async executeHooksParallel(hookConfigs, eventName, input, onHookStart, onHookEnd) {
68
+ const promises = hookConfigs.map(async (config, index) => {
69
+ onHookStart?.(config, index);
70
+ const result = await this.executeHook(config, eventName, input);
71
+ onHookEnd?.(config, result);
72
+ return result;
73
+ });
51
74
  return Promise.all(promises);
52
75
  }
53
76
  /**
54
77
  * Execute multiple hooks sequentially
55
78
  */
56
- async executeHooksSequential(hookConfigs, eventName, input) {
79
+ async executeHooksSequential(hookConfigs, eventName, input, onHookStart, onHookEnd) {
57
80
  const results = [];
58
81
  let currentInput = input;
59
- for (const config of hookConfigs) {
82
+ for (let i = 0; i < hookConfigs.length; i++) {
83
+ const config = hookConfigs[i];
84
+ onHookStart?.(config, i);
60
85
  const result = await this.executeHook(config, eventName, currentInput);
86
+ onHookEnd?.(config, result);
61
87
  results.push(result);
62
88
  // If the hook succeeded and has output, use it to modify the input for the next hook
63
89
  if (result.success && result.output) {
@@ -103,6 +129,17 @@ export class HookRunner {
103
129
  }
104
130
  }
105
131
  break;
132
+ case HookEventName.BeforeTool:
133
+ if ('tool_input' in hookOutput.hookSpecificOutput) {
134
+ const newToolInput = hookOutput.hookSpecificOutput['tool_input'];
135
+ if (newToolInput && 'tool_input' in modifiedInput) {
136
+ modifiedInput.tool_input = {
137
+ ...modifiedInput.tool_input,
138
+ ...newToolInput,
139
+ };
140
+ }
141
+ }
142
+ break;
106
143
  default:
107
144
  // For other events, no special input modification is needed
108
145
  break;
@@ -131,18 +168,19 @@ export class HookRunner {
131
168
  let stdout = '';
132
169
  let stderr = '';
133
170
  let timedOut = false;
134
- const command = this.expandCommand(hookConfig.command, input);
171
+ const shellConfig = getShellConfiguration();
172
+ const command = this.expandCommand(hookConfig.command, input, shellConfig.shell);
135
173
  // Set up environment variables
136
174
  const env = {
137
- ...process.env,
175
+ ...sanitizeEnvironment(process.env, this.config.sanitizationConfig),
138
176
  GEMINI_PROJECT_DIR: input.cwd,
139
177
  CLAUDE_PROJECT_DIR: input.cwd, // For compatibility
140
178
  };
141
- const child = spawn(command, {
179
+ const child = spawn(shellConfig.executable, [...shellConfig.argsPrefix, command], {
142
180
  env,
143
181
  cwd: input.cwd,
144
182
  stdio: ['pipe', 'pipe', 'pipe'],
145
- shell: true,
183
+ shell: false,
146
184
  });
147
185
  // Set up timeout
148
186
  const timeoutHandle = setTimeout(() => {
@@ -160,7 +198,7 @@ export class HookRunner {
160
198
  child.stdin.on('error', (err) => {
161
199
  // Ignore EPIPE errors which happen when the child process closes stdin early
162
200
  if (err.code !== 'EPIPE') {
163
- debugLogger.warn(`Hook stdin error: ${err}`);
201
+ debugLogger.debug(`Hook stdin error: ${err}`);
164
202
  }
165
203
  });
166
204
  // Wrap write operations in try-catch to handle synchronous EPIPE errors
@@ -172,7 +210,7 @@ export class HookRunner {
172
210
  catch (err) {
173
211
  // Ignore EPIPE errors which happen when the child process closes stdin early
174
212
  if (err instanceof Error && 'code' in err && err.code !== 'EPIPE') {
175
- debugLogger.warn(`Hook stdin write error: ${err}`);
213
+ debugLogger.debug(`Hook stdin write error: ${err}`);
176
214
  }
177
215
  }
178
216
  }
@@ -253,10 +291,12 @@ export class HookRunner {
253
291
  /**
254
292
  * Expand command with environment variables and input context
255
293
  */
256
- expandCommand(command, input) {
294
+ expandCommand(command, input, shellType) {
295
+ debugLogger.debug(`Expanding hook command: ${command} (cwd: ${input.cwd})`);
296
+ const escapedCwd = escapeShellArg(input.cwd, shellType);
257
297
  return command
258
- .replace(/\$GEMINI_PROJECT_DIR/g, input.cwd)
259
- .replace(/\$CLAUDE_PROJECT_DIR/g, input.cwd); // For compatibility
298
+ .replace(/\$GEMINI_PROJECT_DIR/g, () => escapedCwd)
299
+ .replace(/\$CLAUDE_PROJECT_DIR/g, () => escapedCwd); // For compatibility
260
300
  }
261
301
  /**
262
302
  * Convert plain text output to structured HookOutput
@@ -1 +1 @@
1
- {"version":3,"file":"hookRunner.js","sourceRoot":"","sources":["../../../src/hooks/hookRunner.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"hookRunner.js","sourceRoot":"","sources":["../../../src/hooks/hookRunner.ts"],"names":[],"mappings":"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"}
@@ -6,7 +6,7 @@
6
6
  import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
7
7
  import { spawn } from 'node:child_process';
8
8
  import { HookRunner } from './hookRunner.js';
9
- import { HookEventName, HookType } from './types.js';
9
+ import { HookEventName, HookType, ConfigSource } from './types.js';
10
10
  // Mock child_process with importOriginal for partial mocking
11
11
  vi.mock('node:child_process', async (importOriginal) => {
12
12
  const actual = await importOriginal();
@@ -15,6 +15,16 @@ vi.mock('node:child_process', async (importOriginal) => {
15
15
  spawn: vi.fn(),
16
16
  };
17
17
  });
18
+ // Mock debugLogger using vi.hoisted
19
+ const mockDebugLogger = vi.hoisted(() => ({
20
+ log: vi.fn(),
21
+ warn: vi.fn(),
22
+ error: vi.fn(),
23
+ debug: vi.fn(),
24
+ }));
25
+ vi.mock('../utils/debugLogger.js', () => ({
26
+ debugLogger: mockDebugLogger,
27
+ }));
18
28
  // Mock console methods
19
29
  const mockConsole = {
20
30
  log: vi.fn(),
@@ -26,6 +36,7 @@ vi.stubGlobal('console', mockConsole);
26
36
  describe('HookRunner', () => {
27
37
  let hookRunner;
28
38
  let mockSpawn;
39
+ let mockConfig;
29
40
  const mockInput = {
30
41
  session_id: 'test-session',
31
42
  transcript_path: '/path/to/transcript',
@@ -35,7 +46,13 @@ describe('HookRunner', () => {
35
46
  };
36
47
  beforeEach(() => {
37
48
  vi.resetAllMocks();
38
- hookRunner = new HookRunner();
49
+ mockConfig = {
50
+ isTrustedFolder: vi.fn().mockReturnValue(true),
51
+ sanitizationConfig: {
52
+ enableEnvironmentVariableRedaction: true,
53
+ },
54
+ };
55
+ hookRunner = new HookRunner(mockConfig);
39
56
  // Mock spawn with accessible mock functions
40
57
  const mockStdoutOn = vi.fn();
41
58
  const mockStderrOn = vi.fn();
@@ -65,6 +82,55 @@ describe('HookRunner', () => {
65
82
  vi.restoreAllMocks();
66
83
  });
67
84
  describe('executeHook', () => {
85
+ describe('security checks', () => {
86
+ it('should block project hooks in untrusted folders', async () => {
87
+ vi.mocked(mockConfig.isTrustedFolder).mockReturnValue(false);
88
+ const projectHookConfig = {
89
+ type: HookType.Command,
90
+ command: './hooks/test.sh',
91
+ source: ConfigSource.Project,
92
+ };
93
+ const result = await hookRunner.executeHook(projectHookConfig, HookEventName.BeforeTool, mockInput);
94
+ expect(result.success).toBe(false);
95
+ expect(result.error?.message).toContain('Security: Blocked execution of project hook in untrusted folder');
96
+ expect(mockDebugLogger.warn).toHaveBeenCalledWith(expect.stringContaining('Security: Blocked execution'));
97
+ expect(spawn).not.toHaveBeenCalled();
98
+ });
99
+ it('should allow project hooks in trusted folders', async () => {
100
+ vi.mocked(mockConfig.isTrustedFolder).mockReturnValue(true);
101
+ const projectHookConfig = {
102
+ type: HookType.Command,
103
+ command: './hooks/test.sh',
104
+ source: ConfigSource.Project,
105
+ };
106
+ // Mock successful execution
107
+ mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
108
+ if (event === 'close') {
109
+ setTimeout(() => callback(0), 10);
110
+ }
111
+ });
112
+ const result = await hookRunner.executeHook(projectHookConfig, HookEventName.BeforeTool, mockInput);
113
+ expect(result.success).toBe(true);
114
+ expect(spawn).toHaveBeenCalled();
115
+ });
116
+ it('should allow non-project hooks even in untrusted folders', async () => {
117
+ vi.mocked(mockConfig.isTrustedFolder).mockReturnValue(false);
118
+ const systemHookConfig = {
119
+ type: HookType.Command,
120
+ command: './hooks/test.sh',
121
+ source: ConfigSource.System,
122
+ };
123
+ // Mock successful execution
124
+ mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
125
+ if (event === 'close') {
126
+ setTimeout(() => callback(0), 10);
127
+ }
128
+ });
129
+ const result = await hookRunner.executeHook(systemHookConfig, HookEventName.BeforeTool, mockInput);
130
+ expect(result.success).toBe(true);
131
+ expect(spawn).toHaveBeenCalled();
132
+ });
133
+ });
68
134
  describe('command hooks', () => {
69
135
  const commandConfig = {
70
136
  type: HookType.Command,
@@ -76,12 +142,12 @@ describe('HookRunner', () => {
76
142
  // Mock successful execution
77
143
  mockSpawn.mockStdoutOn.mockImplementation((event, callback) => {
78
144
  if (event === 'data') {
79
- setTimeout(() => callback(Buffer.from(JSON.stringify(mockOutput))), 10);
145
+ setImmediate(() => callback(Buffer.from(JSON.stringify(mockOutput))));
80
146
  }
81
147
  });
82
148
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
83
149
  if (event === 'close') {
84
- setTimeout(() => callback(0), 20);
150
+ setImmediate(() => callback(0));
85
151
  }
86
152
  });
87
153
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);
@@ -94,12 +160,12 @@ describe('HookRunner', () => {
94
160
  const errorMessage = 'Command failed';
95
161
  mockSpawn.mockStderrOn.mockImplementation((event, callback) => {
96
162
  if (event === 'data') {
97
- setTimeout(() => callback(Buffer.from(errorMessage)), 10);
163
+ setImmediate(() => callback(Buffer.from(errorMessage)));
98
164
  }
99
165
  });
100
166
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
101
167
  if (event === 'close') {
102
- setTimeout(() => callback(1), 20);
168
+ setImmediate(() => callback(1));
103
169
  }
104
170
  });
105
171
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);
@@ -107,6 +173,19 @@ describe('HookRunner', () => {
107
173
  expect(result.exitCode).toBe(1);
108
174
  expect(result.stderr).toBe(errorMessage);
109
175
  });
176
+ it('should use hook name in error messages if available', async () => {
177
+ const namedConfig = {
178
+ name: 'my-friendly-hook',
179
+ type: HookType.Command,
180
+ command: './hooks/fail.sh',
181
+ };
182
+ // Mock error during spawn
183
+ vi.mocked(spawn).mockImplementationOnce(() => {
184
+ throw new Error('Spawn error');
185
+ });
186
+ await hookRunner.executeHook(namedConfig, HookEventName.BeforeTool, mockInput);
187
+ expect(mockDebugLogger.warn).toHaveBeenCalledWith(expect.stringContaining('(hook: my-friendly-hook): Error: Spawn error'));
188
+ });
110
189
  it('should handle command hook timeout', async () => {
111
190
  const shortTimeoutConfig = {
112
191
  type: HookType.Command,
@@ -126,9 +205,9 @@ describe('HookRunner', () => {
126
205
  killWasCalled = true;
127
206
  // Simulate that killing the process triggers the close event
128
207
  if (closeCallback) {
129
- setTimeout(() => {
208
+ setImmediate(() => {
130
209
  closeCallback(128); // Exit code 128 indicates process was killed by signal
131
- }, 5);
210
+ });
132
211
  }
133
212
  return true;
134
213
  });
@@ -145,18 +224,42 @@ describe('HookRunner', () => {
145
224
  };
146
225
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
147
226
  if (event === 'close') {
148
- setTimeout(() => callback(0), 10);
227
+ setImmediate(() => callback(0));
149
228
  }
150
229
  });
151
230
  await hookRunner.executeHook(configWithEnvVar, HookEventName.BeforeTool, mockInput);
152
- expect(spawn).toHaveBeenCalledWith('/test/project/hooks/test.sh', expect.objectContaining({
153
- shell: true,
231
+ expect(spawn).toHaveBeenCalledWith(expect.stringMatching(/bash|powershell/), expect.arrayContaining([
232
+ expect.stringMatching(/['"]?\/test\/project['"]?\/hooks\/test\.sh/),
233
+ ]), expect.objectContaining({
234
+ shell: false,
154
235
  env: expect.objectContaining({
155
236
  GEMINI_PROJECT_DIR: '/test/project',
156
237
  CLAUDE_PROJECT_DIR: '/test/project',
157
238
  }),
158
239
  }));
159
240
  });
241
+ it('should not allow command injection via GEMINI_PROJECT_DIR', async () => {
242
+ const maliciousCwd = '/test/project; echo "pwned" > /tmp/pwned';
243
+ const mockMaliciousInput = {
244
+ ...mockInput,
245
+ cwd: maliciousCwd,
246
+ };
247
+ const config = {
248
+ type: HookType.Command,
249
+ command: 'ls $GEMINI_PROJECT_DIR',
250
+ };
251
+ // Mock the process closing immediately
252
+ mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
253
+ if (event === 'close') {
254
+ setImmediate(() => callback(0));
255
+ }
256
+ });
257
+ await hookRunner.executeHook(config, HookEventName.BeforeTool, mockMaliciousInput);
258
+ // If secure, spawn will be called with the shell executable and escaped command
259
+ expect(spawn).toHaveBeenCalledWith(expect.stringMatching(/bash|powershell/), expect.arrayContaining([
260
+ expect.stringMatching(/ls (['"]).*echo.*pwned.*\1/),
261
+ ]), expect.objectContaining({ shell: false }));
262
+ });
160
263
  });
161
264
  });
162
265
  describe('executeHooksParallel', () => {
@@ -168,7 +271,7 @@ describe('HookRunner', () => {
168
271
  // Mock both commands to succeed
169
272
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
170
273
  if (event === 'close') {
171
- setTimeout(() => callback(0), 10);
274
+ setImmediate(() => callback(0));
172
275
  }
173
276
  });
174
277
  const results = await hookRunner.executeHooksParallel(configs, HookEventName.BeforeTool, mockInput);
@@ -176,6 +279,21 @@ describe('HookRunner', () => {
176
279
  expect(results.every((r) => r.success)).toBe(true);
177
280
  expect(spawn).toHaveBeenCalledTimes(2);
178
281
  });
282
+ it('should call onHookStart and onHookEnd callbacks', async () => {
283
+ const configs = [
284
+ { name: 'hook1', type: HookType.Command, command: './hook1.sh' },
285
+ ];
286
+ mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
287
+ if (event === 'close') {
288
+ setImmediate(() => callback(0));
289
+ }
290
+ });
291
+ const onStart = vi.fn();
292
+ const onEnd = vi.fn();
293
+ await hookRunner.executeHooksParallel(configs, HookEventName.BeforeTool, mockInput, onStart, onEnd);
294
+ expect(onStart).toHaveBeenCalledWith(configs[0], 0);
295
+ expect(onEnd).toHaveBeenCalledWith(configs[0], expect.objectContaining({ success: true }));
296
+ });
179
297
  it('should handle mixed success and failure', async () => {
180
298
  const configs = [
181
299
  { type: HookType.Command, command: './hook1.sh' },
@@ -185,7 +303,7 @@ describe('HookRunner', () => {
185
303
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
186
304
  if (event === 'close') {
187
305
  const exitCode = callCount++ === 0 ? 0 : 1; // First succeeds, second fails
188
- setTimeout(() => callback(exitCode), 10);
306
+ setImmediate(() => callback(exitCode));
189
307
  }
190
308
  });
191
309
  const results = await hookRunner.executeHooksParallel(configs, HookEventName.BeforeTool, mockInput);
@@ -204,9 +322,10 @@ describe('HookRunner', () => {
204
322
  // Mock both commands to succeed
205
323
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
206
324
  if (event === 'close') {
207
- const command = vi.mocked(spawn).mock.calls[executionOrder.length][0];
325
+ const args = vi.mocked(spawn).mock.calls[executionOrder.length][1];
326
+ const command = args[args.length - 1];
208
327
  executionOrder.push(command);
209
- setTimeout(() => callback(0), 10);
328
+ setImmediate(() => callback(0));
210
329
  }
211
330
  });
212
331
  const results = await hookRunner.executeHooksSequential(configs, HookEventName.BeforeTool, mockInput);
@@ -216,6 +335,24 @@ describe('HookRunner', () => {
216
335
  // Verify they were called sequentially
217
336
  expect(executionOrder).toEqual(['./hook1.sh', './hook2.sh']);
218
337
  });
338
+ it('should call onHookStart and onHookEnd callbacks sequentially', async () => {
339
+ const configs = [
340
+ { name: 'hook1', type: HookType.Command, command: './hook1.sh' },
341
+ { name: 'hook2', type: HookType.Command, command: './hook2.sh' },
342
+ ];
343
+ mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
344
+ if (event === 'close') {
345
+ setImmediate(() => callback(0));
346
+ }
347
+ });
348
+ const onStart = vi.fn();
349
+ const onEnd = vi.fn();
350
+ await hookRunner.executeHooksSequential(configs, HookEventName.BeforeTool, mockInput, onStart, onEnd);
351
+ expect(onStart).toHaveBeenCalledTimes(2);
352
+ expect(onEnd).toHaveBeenCalledTimes(2);
353
+ expect(onStart).toHaveBeenNthCalledWith(1, configs[0], 0);
354
+ expect(onStart).toHaveBeenNthCalledWith(2, configs[1], 1);
355
+ });
219
356
  it('should continue execution even if a hook fails', async () => {
220
357
  const configs = [
221
358
  { type: HookType.Command, command: './hook1.sh' },
@@ -226,13 +363,13 @@ describe('HookRunner', () => {
226
363
  mockSpawn.mockStderrOn.mockImplementation((event, callback) => {
227
364
  if (event === 'data' && callCount === 1) {
228
365
  // Second hook fails
229
- setTimeout(() => callback(Buffer.from('Hook 2 failed')), 10);
366
+ setImmediate(() => callback(Buffer.from('Hook 2 failed')));
230
367
  }
231
368
  });
232
369
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
233
370
  if (event === 'close') {
234
371
  const exitCode = callCount++ === 1 ? 1 : 0; // Second fails, others succeed
235
- setTimeout(() => callback(exitCode), 20);
372
+ setImmediate(() => callback(exitCode));
236
373
  }
237
374
  });
238
375
  const results = await hookRunner.executeHooksSequential(configs, HookEventName.BeforeTool, mockInput);
@@ -261,14 +398,14 @@ describe('HookRunner', () => {
261
398
  mockSpawn.mockStdoutOn.mockImplementation((event, callback) => {
262
399
  if (event === 'data') {
263
400
  if (hookCallCount === 0) {
264
- setTimeout(() => callback(Buffer.from(JSON.stringify(mockOutput1))), 10);
401
+ setImmediate(() => callback(Buffer.from(JSON.stringify(mockOutput1))));
265
402
  }
266
403
  }
267
404
  });
268
405
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
269
406
  if (event === 'close') {
270
407
  hookCallCount++;
271
- setTimeout(() => callback(0), 20);
408
+ setImmediate(() => callback(0));
272
409
  }
273
410
  });
274
411
  const results = await hookRunner.executeHooksSequential(configs, HookEventName.BeforeAgent, mockBeforeAgentInput);
@@ -304,14 +441,14 @@ describe('HookRunner', () => {
304
441
  mockSpawn.mockStdoutOn.mockImplementation((event, callback) => {
305
442
  if (event === 'data') {
306
443
  if (hookCallCount === 0) {
307
- setTimeout(() => callback(Buffer.from(JSON.stringify(mockOutput1))), 10);
444
+ setImmediate(() => callback(Buffer.from(JSON.stringify(mockOutput1))));
308
445
  }
309
446
  }
310
447
  });
311
448
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
312
449
  if (event === 'close') {
313
450
  hookCallCount++;
314
- setTimeout(() => callback(0), 20);
451
+ setImmediate(() => callback(0));
315
452
  }
316
453
  });
317
454
  const results = await hookRunner.executeHooksSequential(configs, HookEventName.BeforeModel, mockBeforeModelInput);
@@ -329,12 +466,12 @@ describe('HookRunner', () => {
329
466
  ];
330
467
  mockSpawn.mockStderrOn.mockImplementation((event, callback) => {
331
468
  if (event === 'data') {
332
- setTimeout(() => callback(Buffer.from('Hook failed')), 10);
469
+ setImmediate(() => callback(Buffer.from('Hook failed')));
333
470
  }
334
471
  });
335
472
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
336
473
  if (event === 'close') {
337
- setTimeout(() => callback(1), 20); // All hooks fail
474
+ setImmediate(() => callback(1)); // All hooks fail
338
475
  }
339
476
  });
340
477
  const results = await hookRunner.executeHooksSequential(configs, HookEventName.BeforeTool, mockInput);
@@ -355,12 +492,12 @@ describe('HookRunner', () => {
355
492
  const invalidJson = '{ "decision": "allow", incomplete';
356
493
  mockSpawn.mockStdoutOn.mockImplementation((event, callback) => {
357
494
  if (event === 'data') {
358
- setTimeout(() => callback(Buffer.from(invalidJson)), 10);
495
+ setImmediate(() => callback(Buffer.from(invalidJson)));
359
496
  }
360
497
  });
361
498
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
362
499
  if (event === 'close') {
363
- setTimeout(() => callback(0), 20);
500
+ setImmediate(() => callback(0));
364
501
  }
365
502
  });
366
503
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);
@@ -376,12 +513,12 @@ describe('HookRunner', () => {
376
513
  const malformedJson = 'not json at all';
377
514
  mockSpawn.mockStdoutOn.mockImplementation((event, callback) => {
378
515
  if (event === 'data') {
379
- setTimeout(() => callback(Buffer.from(malformedJson)), 10);
516
+ setImmediate(() => callback(Buffer.from(malformedJson)));
380
517
  }
381
518
  });
382
519
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
383
520
  if (event === 'close') {
384
- setTimeout(() => callback(0), 20);
521
+ setImmediate(() => callback(0));
385
522
  }
386
523
  });
387
524
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);
@@ -395,12 +532,12 @@ describe('HookRunner', () => {
395
532
  const invalidJson = '{ broken json';
396
533
  mockSpawn.mockStderrOn.mockImplementation((event, callback) => {
397
534
  if (event === 'data') {
398
- setTimeout(() => callback(Buffer.from(invalidJson)), 10);
535
+ setImmediate(() => callback(Buffer.from(invalidJson)));
399
536
  }
400
537
  });
401
538
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
402
539
  if (event === 'close') {
403
- setTimeout(() => callback(1), 20);
540
+ setImmediate(() => callback(1));
404
541
  }
405
542
  });
406
543
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);
@@ -415,12 +552,12 @@ describe('HookRunner', () => {
415
552
  const invalidJson = '{ "error": incomplete';
416
553
  mockSpawn.mockStderrOn.mockImplementation((event, callback) => {
417
554
  if (event === 'data') {
418
- setTimeout(() => callback(Buffer.from(invalidJson)), 10);
555
+ setImmediate(() => callback(Buffer.from(invalidJson)));
419
556
  }
420
557
  });
421
558
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
422
559
  if (event === 'close') {
423
- setTimeout(() => callback(2), 20);
560
+ setImmediate(() => callback(2));
424
561
  }
425
562
  });
426
563
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);
@@ -434,12 +571,12 @@ describe('HookRunner', () => {
434
571
  it('should handle empty JSON output', async () => {
435
572
  mockSpawn.mockStdoutOn.mockImplementation((event, callback) => {
436
573
  if (event === 'data') {
437
- setTimeout(() => callback(Buffer.from('')), 10);
574
+ setImmediate(() => callback(Buffer.from('')));
438
575
  }
439
576
  });
440
577
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
441
578
  if (event === 'close') {
442
- setTimeout(() => callback(0), 20);
579
+ setImmediate(() => callback(0));
443
580
  }
444
581
  });
445
582
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);
@@ -452,12 +589,12 @@ describe('HookRunner', () => {
452
589
  const doubleEncodedJson = JSON.stringify(JSON.stringify(mockOutput));
453
590
  mockSpawn.mockStdoutOn.mockImplementation((event, callback) => {
454
591
  if (event === 'data') {
455
- setTimeout(() => callback(Buffer.from(doubleEncodedJson)), 10);
592
+ setImmediate(() => callback(Buffer.from(doubleEncodedJson)));
456
593
  }
457
594
  });
458
595
  mockSpawn.mockProcessOn.mockImplementation((event, callback) => {
459
596
  if (event === 'close') {
460
- setTimeout(() => callback(0), 20);
597
+ setImmediate(() => callback(0));
461
598
  }
462
599
  });
463
600
  const result = await hookRunner.executeHook(commandConfig, HookEventName.BeforeTool, mockInput);