subagent-cli 0.3.0 → 0.3.1

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 (2177) hide show
  1. package/dist/sa +0 -0
  2. package/package.json +2 -8
  3. package/_entry.ts +0 -2
  4. package/bunfig.toml +0 -2
  5. package/src/QueryEngine.ts +0 -1295
  6. package/src/Task.ts +0 -125
  7. package/src/Tool.ts +0 -792
  8. package/src/_stubs/bun-bundle.ts +0 -6
  9. package/src/assistant/AssistantSessionChooser.ts +0 -2
  10. package/src/assistant/gate.ts +0 -2
  11. package/src/assistant/index.ts +0 -2
  12. package/src/assistant/sessionDiscovery.ts +0 -1
  13. package/src/assistant/sessionHistory.ts +0 -87
  14. package/src/bootstrap/state.ts +0 -1762
  15. package/src/bridge/bridgeApi.ts +0 -539
  16. package/src/bridge/bridgeConfig.ts +0 -48
  17. package/src/bridge/bridgeDebug.ts +0 -135
  18. package/src/bridge/bridgeEnabled.ts +0 -202
  19. package/src/bridge/bridgeMain.ts +0 -2999
  20. package/src/bridge/bridgeMessaging.ts +0 -461
  21. package/src/bridge/bridgePermissionCallbacks.ts +0 -43
  22. package/src/bridge/bridgePointer.ts +0 -210
  23. package/src/bridge/bridgeStatusUtil.ts +0 -163
  24. package/src/bridge/bridgeUI.ts +0 -530
  25. package/src/bridge/capacityWake.ts +0 -56
  26. package/src/bridge/codeSessionApi.ts +0 -168
  27. package/src/bridge/createSession.ts +0 -384
  28. package/src/bridge/debugUtils.ts +0 -141
  29. package/src/bridge/envLessBridgeConfig.ts +0 -165
  30. package/src/bridge/flushGate.ts +0 -71
  31. package/src/bridge/inboundAttachments.ts +0 -175
  32. package/src/bridge/inboundMessages.ts +0 -80
  33. package/src/bridge/initReplBridge.ts +0 -569
  34. package/src/bridge/jwtUtils.ts +0 -256
  35. package/src/bridge/peerSessions.ts +0 -2
  36. package/src/bridge/pollConfig.ts +0 -110
  37. package/src/bridge/pollConfigDefaults.ts +0 -82
  38. package/src/bridge/remoteBridgeCore.ts +0 -1008
  39. package/src/bridge/replBridge.ts +0 -2406
  40. package/src/bridge/replBridgeHandle.ts +0 -36
  41. package/src/bridge/replBridgeTransport.ts +0 -370
  42. package/src/bridge/sessionIdCompat.ts +0 -57
  43. package/src/bridge/sessionRunner.ts +0 -550
  44. package/src/bridge/trustedDevice.ts +0 -210
  45. package/src/bridge/types.ts +0 -262
  46. package/src/bridge/webhookSanitizer.ts +0 -2
  47. package/src/bridge/workSecret.ts +0 -127
  48. package/src/buddy/CompanionSprite.tsx +0 -371
  49. package/src/buddy/companion.ts +0 -133
  50. package/src/buddy/prompt.ts +0 -36
  51. package/src/buddy/sprites.ts +0 -514
  52. package/src/buddy/types.ts +0 -148
  53. package/src/buddy/useBuddyNotification.tsx +0 -98
  54. package/src/cli/bg.ts +0 -2
  55. package/src/cli/exit.ts +0 -31
  56. package/src/cli/handlers/agents.ts +0 -70
  57. package/src/cli/handlers/ant.ts +0 -2
  58. package/src/cli/handlers/auth.ts +0 -330
  59. package/src/cli/handlers/autoMode.ts +0 -170
  60. package/src/cli/handlers/mcp.tsx +0 -362
  61. package/src/cli/handlers/plugins.ts +0 -878
  62. package/src/cli/handlers/templateJobs.ts +0 -2
  63. package/src/cli/handlers/util.tsx +0 -110
  64. package/src/cli/ndjsonSafeStringify.ts +0 -32
  65. package/src/cli/print.ts +0 -5594
  66. package/src/cli/remoteIO.ts +0 -255
  67. package/src/cli/rollback.ts +0 -3
  68. package/src/cli/structuredIO.ts +0 -859
  69. package/src/cli/transports/HybridTransport.ts +0 -282
  70. package/src/cli/transports/SSETransport.ts +0 -711
  71. package/src/cli/transports/SerialBatchEventUploader.ts +0 -275
  72. package/src/cli/transports/Transport.ts +0 -1
  73. package/src/cli/transports/WebSocketTransport.ts +0 -800
  74. package/src/cli/transports/WorkerStateUploader.ts +0 -131
  75. package/src/cli/transports/ccrClient.ts +0 -998
  76. package/src/cli/transports/transportUtils.ts +0 -45
  77. package/src/cli/up.ts +0 -3
  78. package/src/cli/update.ts +0 -422
  79. package/src/commands/add-dir/add-dir.tsx +0 -126
  80. package/src/commands/add-dir/index.ts +0 -11
  81. package/src/commands/add-dir/validation.ts +0 -110
  82. package/src/commands/advisor.ts +0 -109
  83. package/src/commands/agents/agents.tsx +0 -12
  84. package/src/commands/agents/index.ts +0 -10
  85. package/src/commands/agents-platform/index.ts +0 -1
  86. package/src/commands/ant-trace/index.js +0 -1
  87. package/src/commands/assistant/assistant.ts +0 -2
  88. package/src/commands/assistant/index.ts +0 -1
  89. package/src/commands/autofix-pr/index.js +0 -1
  90. package/src/commands/backfill-sessions/index.js +0 -1
  91. package/src/commands/branch/branch.ts +0 -296
  92. package/src/commands/branch/index.ts +0 -14
  93. package/src/commands/break-cache/index.js +0 -1
  94. package/src/commands/bridge/bridge.tsx +0 -509
  95. package/src/commands/bridge/index.ts +0 -26
  96. package/src/commands/bridge-kick.ts +0 -200
  97. package/src/commands/brief.ts +0 -130
  98. package/src/commands/btw/btw.tsx +0 -243
  99. package/src/commands/btw/index.ts +0 -13
  100. package/src/commands/buddy/index.ts +0 -2
  101. package/src/commands/bughunter/index.js +0 -1
  102. package/src/commands/chrome/chrome.tsx +0 -285
  103. package/src/commands/chrome/index.ts +0 -13
  104. package/src/commands/clear/caches.ts +0 -144
  105. package/src/commands/clear/clear.ts +0 -7
  106. package/src/commands/clear/conversation.ts +0 -251
  107. package/src/commands/clear/index.ts +0 -19
  108. package/src/commands/color/color.ts +0 -93
  109. package/src/commands/color/index.ts +0 -16
  110. package/src/commands/commit-push-pr.ts +0 -158
  111. package/src/commands/commit.ts +0 -92
  112. package/src/commands/compact/compact.ts +0 -287
  113. package/src/commands/compact/index.ts +0 -15
  114. package/src/commands/config/config.tsx +0 -7
  115. package/src/commands/config/index.ts +0 -11
  116. package/src/commands/context/context-noninteractive.ts +0 -325
  117. package/src/commands/context/context.tsx +0 -64
  118. package/src/commands/context/index.ts +0 -24
  119. package/src/commands/copy/copy.tsx +0 -371
  120. package/src/commands/copy/index.ts +0 -15
  121. package/src/commands/cost/cost.ts +0 -24
  122. package/src/commands/cost/index.ts +0 -23
  123. package/src/commands/createMovedToPluginCommand.ts +0 -65
  124. package/src/commands/ctx_viz/index.js +0 -1
  125. package/src/commands/debug-tool-call/index.js +0 -1
  126. package/src/commands/desktop/desktop.tsx +0 -9
  127. package/src/commands/desktop/index.ts +0 -26
  128. package/src/commands/diff/diff.tsx +0 -9
  129. package/src/commands/diff/index.ts +0 -8
  130. package/src/commands/doctor/doctor.tsx +0 -7
  131. package/src/commands/doctor/index.ts +0 -12
  132. package/src/commands/effort/effort.tsx +0 -183
  133. package/src/commands/effort/index.ts +0 -13
  134. package/src/commands/env/index.js +0 -1
  135. package/src/commands/exit/exit.tsx +0 -33
  136. package/src/commands/exit/index.ts +0 -12
  137. package/src/commands/export/export.tsx +0 -91
  138. package/src/commands/export/index.ts +0 -11
  139. package/src/commands/extra-usage/extra-usage-core.ts +0 -118
  140. package/src/commands/extra-usage/extra-usage-noninteractive.ts +0 -16
  141. package/src/commands/extra-usage/extra-usage.tsx +0 -17
  142. package/src/commands/extra-usage/index.ts +0 -31
  143. package/src/commands/fast/fast.tsx +0 -269
  144. package/src/commands/fast/index.ts +0 -26
  145. package/src/commands/feedback/feedback.tsx +0 -25
  146. package/src/commands/feedback/index.ts +0 -26
  147. package/src/commands/files/files.ts +0 -19
  148. package/src/commands/files/index.ts +0 -12
  149. package/src/commands/force-snip.ts +0 -1
  150. package/src/commands/fork/index.ts +0 -2
  151. package/src/commands/good-claude/index.js +0 -1
  152. package/src/commands/heapdump/heapdump.ts +0 -17
  153. package/src/commands/heapdump/index.ts +0 -12
  154. package/src/commands/help/help.tsx +0 -11
  155. package/src/commands/help/index.ts +0 -10
  156. package/src/commands/hooks/hooks.tsx +0 -13
  157. package/src/commands/hooks/index.ts +0 -11
  158. package/src/commands/ide/ide.tsx +0 -646
  159. package/src/commands/ide/index.ts +0 -11
  160. package/src/commands/init-verifiers.ts +0 -262
  161. package/src/commands/init.ts +0 -256
  162. package/src/commands/insights.ts +0 -3200
  163. package/src/commands/install-github-app/ApiKeyStep.tsx +0 -231
  164. package/src/commands/install-github-app/CheckExistingSecretStep.tsx +0 -190
  165. package/src/commands/install-github-app/CheckGitHubStep.tsx +0 -15
  166. package/src/commands/install-github-app/ChooseRepoStep.tsx +0 -211
  167. package/src/commands/install-github-app/CreatingStep.tsx +0 -65
  168. package/src/commands/install-github-app/ErrorStep.tsx +0 -85
  169. package/src/commands/install-github-app/ExistingWorkflowStep.tsx +0 -103
  170. package/src/commands/install-github-app/InstallAppStep.tsx +0 -94
  171. package/src/commands/install-github-app/OAuthFlowStep.tsx +0 -276
  172. package/src/commands/install-github-app/SuccessStep.tsx +0 -96
  173. package/src/commands/install-github-app/WarningsStep.tsx +0 -73
  174. package/src/commands/install-github-app/index.ts +0 -13
  175. package/src/commands/install-github-app/install-github-app.tsx +0 -587
  176. package/src/commands/install-github-app/setupGitHubActions.ts +0 -325
  177. package/src/commands/install-github-app/types.ts +0 -3
  178. package/src/commands/install-slack-app/index.ts +0 -12
  179. package/src/commands/install-slack-app/install-slack-app.ts +0 -30
  180. package/src/commands/install.tsx +0 -300
  181. package/src/commands/issue/index.js +0 -1
  182. package/src/commands/keybindings/index.ts +0 -13
  183. package/src/commands/keybindings/keybindings.ts +0 -53
  184. package/src/commands/login/index.ts +0 -14
  185. package/src/commands/login/login.tsx +0 -104
  186. package/src/commands/logout/index.ts +0 -10
  187. package/src/commands/logout/logout.tsx +0 -82
  188. package/src/commands/mcp/addCommand.ts +0 -280
  189. package/src/commands/mcp/index.ts +0 -12
  190. package/src/commands/mcp/mcp.tsx +0 -85
  191. package/src/commands/mcp/xaaIdpCommand.ts +0 -266
  192. package/src/commands/memory/index.ts +0 -10
  193. package/src/commands/memory/memory.tsx +0 -90
  194. package/src/commands/mobile/index.ts +0 -11
  195. package/src/commands/mobile/mobile.tsx +0 -274
  196. package/src/commands/mock-limits/index.js +0 -1
  197. package/src/commands/model/index.ts +0 -16
  198. package/src/commands/model/model.tsx +0 -297
  199. package/src/commands/oauth-refresh/index.js +0 -1
  200. package/src/commands/onboarding/index.js +0 -1
  201. package/src/commands/output-style/index.ts +0 -11
  202. package/src/commands/output-style/output-style.tsx +0 -7
  203. package/src/commands/passes/index.ts +0 -22
  204. package/src/commands/passes/passes.tsx +0 -24
  205. package/src/commands/peers/index.ts +0 -2
  206. package/src/commands/perf-issue/index.js +0 -1
  207. package/src/commands/permissions/index.ts +0 -11
  208. package/src/commands/permissions/permissions.tsx +0 -10
  209. package/src/commands/plan/index.ts +0 -11
  210. package/src/commands/plan/plan.tsx +0 -122
  211. package/src/commands/plugin/AddMarketplace.tsx +0 -162
  212. package/src/commands/plugin/BrowseMarketplace.tsx +0 -802
  213. package/src/commands/plugin/DiscoverPlugins.tsx +0 -781
  214. package/src/commands/plugin/ManageMarketplaces.tsx +0 -838
  215. package/src/commands/plugin/ManagePlugins.tsx +0 -2215
  216. package/src/commands/plugin/PluginErrors.tsx +0 -124
  217. package/src/commands/plugin/PluginOptionsDialog.tsx +0 -357
  218. package/src/commands/plugin/PluginOptionsFlow.tsx +0 -135
  219. package/src/commands/plugin/PluginSettings.tsx +0 -1072
  220. package/src/commands/plugin/PluginTrustWarning.tsx +0 -32
  221. package/src/commands/plugin/UnifiedInstalledCell.tsx +0 -565
  222. package/src/commands/plugin/ValidatePlugin.tsx +0 -98
  223. package/src/commands/plugin/index.tsx +0 -11
  224. package/src/commands/plugin/parseArgs.ts +0 -103
  225. package/src/commands/plugin/plugin.tsx +0 -7
  226. package/src/commands/plugin/pluginDetailsHelpers.tsx +0 -117
  227. package/src/commands/plugin/types.ts +0 -2
  228. package/src/commands/plugin/unifiedTypes.ts +0 -4
  229. package/src/commands/plugin/usePagination.ts +0 -171
  230. package/src/commands/pr_comments/index.ts +0 -50
  231. package/src/commands/privacy-settings/index.ts +0 -14
  232. package/src/commands/privacy-settings/privacy-settings.tsx +0 -58
  233. package/src/commands/proactive.ts +0 -1
  234. package/src/commands/rate-limit-options/index.ts +0 -19
  235. package/src/commands/rate-limit-options/rate-limit-options.tsx +0 -210
  236. package/src/commands/release-notes/index.ts +0 -11
  237. package/src/commands/release-notes/release-notes.ts +0 -50
  238. package/src/commands/reload-plugins/index.ts +0 -18
  239. package/src/commands/reload-plugins/reload-plugins.ts +0 -61
  240. package/src/commands/remote-env/index.ts +0 -15
  241. package/src/commands/remote-env/remote-env.tsx +0 -7
  242. package/src/commands/remote-setup/api.ts +0 -182
  243. package/src/commands/remote-setup/index.ts +0 -20
  244. package/src/commands/remote-setup/remote-setup.tsx +0 -187
  245. package/src/commands/remoteControlServer/index.ts +0 -1
  246. package/src/commands/rename/generateSessionName.ts +0 -67
  247. package/src/commands/rename/index.ts +0 -12
  248. package/src/commands/rename/rename.ts +0 -87
  249. package/src/commands/reset-limits/index.js +0 -4
  250. package/src/commands/resume/index.ts +0 -12
  251. package/src/commands/resume/resume.tsx +0 -275
  252. package/src/commands/review/UltrareviewOverageDialog.tsx +0 -96
  253. package/src/commands/review/reviewRemote.ts +0 -316
  254. package/src/commands/review/ultrareviewCommand.tsx +0 -58
  255. package/src/commands/review/ultrareviewEnabled.ts +0 -14
  256. package/src/commands/review.ts +0 -57
  257. package/src/commands/rewind/index.ts +0 -13
  258. package/src/commands/rewind/rewind.ts +0 -13
  259. package/src/commands/sandbox-toggle/index.ts +0 -50
  260. package/src/commands/sandbox-toggle/sandbox-toggle.tsx +0 -83
  261. package/src/commands/security-review.ts +0 -243
  262. package/src/commands/session/index.ts +0 -16
  263. package/src/commands/session/session.tsx +0 -140
  264. package/src/commands/share/index.js +0 -1
  265. package/src/commands/skills/index.ts +0 -10
  266. package/src/commands/skills/skills.tsx +0 -8
  267. package/src/commands/stats/index.ts +0 -10
  268. package/src/commands/stats/stats.tsx +0 -7
  269. package/src/commands/status/index.ts +0 -12
  270. package/src/commands/status/status.tsx +0 -8
  271. package/src/commands/statusline.tsx +0 -24
  272. package/src/commands/stickers/index.ts +0 -11
  273. package/src/commands/stickers/stickers.ts +0 -16
  274. package/src/commands/subscribe-pr.ts +0 -1
  275. package/src/commands/summary/index.js +0 -1
  276. package/src/commands/tag/index.ts +0 -12
  277. package/src/commands/tag/tag.tsx +0 -215
  278. package/src/commands/tasks/index.ts +0 -11
  279. package/src/commands/tasks/tasks.tsx +0 -8
  280. package/src/commands/teleport/index.js +0 -1
  281. package/src/commands/terminalSetup/index.ts +0 -23
  282. package/src/commands/terminalSetup/terminalSetup.tsx +0 -531
  283. package/src/commands/theme/index.ts +0 -10
  284. package/src/commands/theme/theme.tsx +0 -57
  285. package/src/commands/thinkback/index.ts +0 -13
  286. package/src/commands/thinkback/thinkback.tsx +0 -554
  287. package/src/commands/thinkback-play/index.ts +0 -17
  288. package/src/commands/thinkback-play/thinkback-play.ts +0 -43
  289. package/src/commands/torch.ts +0 -1
  290. package/src/commands/ultraplan.tsx +0 -471
  291. package/src/commands/upgrade/index.ts +0 -16
  292. package/src/commands/upgrade/upgrade.tsx +0 -38
  293. package/src/commands/usage/index.ts +0 -9
  294. package/src/commands/usage/usage.tsx +0 -7
  295. package/src/commands/version.ts +0 -22
  296. package/src/commands/vim/index.ts +0 -11
  297. package/src/commands/vim/vim.ts +0 -38
  298. package/src/commands/voice/index.ts +0 -20
  299. package/src/commands/voice/voice.ts +0 -150
  300. package/src/commands/workflows/index.ts +0 -2
  301. package/src/commands.ts +0 -754
  302. package/src/components/AgentProgressLine.tsx +0 -136
  303. package/src/components/App.tsx +0 -56
  304. package/src/components/ApproveApiKey.tsx +0 -123
  305. package/src/components/AutoModeOptInDialog.tsx +0 -142
  306. package/src/components/AutoUpdater.tsx +0 -198
  307. package/src/components/AutoUpdaterWrapper.tsx +0 -91
  308. package/src/components/AwsAuthStatusBox.tsx +0 -82
  309. package/src/components/BaseTextInput.tsx +0 -136
  310. package/src/components/BashModeProgress.tsx +0 -56
  311. package/src/components/BridgeDialog.tsx +0 -401
  312. package/src/components/BypassPermissionsModeDialog.tsx +0 -87
  313. package/src/components/ChannelDowngradeDialog.tsx +0 -102
  314. package/src/components/ClaudeCodeHint/PluginHintMenu.tsx +0 -78
  315. package/src/components/ClaudeInChromeOnboarding.tsx +0 -121
  316. package/src/components/ClaudeMdExternalIncludesDialog.tsx +0 -137
  317. package/src/components/ClickableImageRef.tsx +0 -73
  318. package/src/components/CompactSummary.tsx +0 -118
  319. package/src/components/ConfigurableShortcutHint.tsx +0 -57
  320. package/src/components/ConsoleOAuthFlow.tsx +0 -631
  321. package/src/components/ContextSuggestions.tsx +0 -47
  322. package/src/components/ContextVisualization.tsx +0 -489
  323. package/src/components/CoordinatorAgentStatus.tsx +0 -273
  324. package/src/components/CostThresholdDialog.tsx +0 -50
  325. package/src/components/CtrlOToExpand.tsx +0 -51
  326. package/src/components/CustomSelect/SelectMulti.tsx +0 -213
  327. package/src/components/CustomSelect/index.ts +0 -3
  328. package/src/components/CustomSelect/option-map.ts +0 -50
  329. package/src/components/CustomSelect/select-input-option.tsx +0 -488
  330. package/src/components/CustomSelect/select-option.tsx +0 -68
  331. package/src/components/CustomSelect/select.tsx +0 -690
  332. package/src/components/CustomSelect/use-multi-select-state.ts +0 -414
  333. package/src/components/CustomSelect/use-select-input.ts +0 -287
  334. package/src/components/CustomSelect/use-select-navigation.ts +0 -653
  335. package/src/components/CustomSelect/use-select-state.ts +0 -157
  336. package/src/components/DesktopHandoff.tsx +0 -193
  337. package/src/components/DesktopUpsell/DesktopUpsellStartup.tsx +0 -171
  338. package/src/components/DevBar.tsx +0 -49
  339. package/src/components/DevChannelsDialog.tsx +0 -105
  340. package/src/components/DiagnosticsDisplay.tsx +0 -95
  341. package/src/components/EffortCallout.tsx +0 -265
  342. package/src/components/EffortIndicator.ts +0 -42
  343. package/src/components/ExitFlow.tsx +0 -48
  344. package/src/components/ExportDialog.tsx +0 -128
  345. package/src/components/FallbackToolUseErrorMessage.tsx +0 -116
  346. package/src/components/FallbackToolUseRejectedMessage.tsx +0 -16
  347. package/src/components/FastIcon.tsx +0 -46
  348. package/src/components/Feedback.tsx +0 -592
  349. package/src/components/FeedbackSurvey/FeedbackSurvey.tsx +0 -174
  350. package/src/components/FeedbackSurvey/FeedbackSurveyView.tsx +0 -108
  351. package/src/components/FeedbackSurvey/TranscriptSharePrompt.tsx +0 -88
  352. package/src/components/FeedbackSurvey/submitTranscriptShare.ts +0 -112
  353. package/src/components/FeedbackSurvey/useDebouncedDigitInput.ts +0 -82
  354. package/src/components/FeedbackSurvey/useFeedbackSurvey.tsx +0 -296
  355. package/src/components/FeedbackSurvey/useFrustrationDetection.ts +0 -2
  356. package/src/components/FeedbackSurvey/useMemorySurvey.tsx +0 -213
  357. package/src/components/FeedbackSurvey/usePostCompactSurvey.tsx +0 -206
  358. package/src/components/FeedbackSurvey/useSurveyState.tsx +0 -100
  359. package/src/components/FeedbackSurvey/utils.ts +0 -2
  360. package/src/components/FileEditToolDiff.tsx +0 -181
  361. package/src/components/FileEditToolUpdatedMessage.tsx +0 -124
  362. package/src/components/FileEditToolUseRejectedMessage.tsx +0 -170
  363. package/src/components/FilePathLink.tsx +0 -43
  364. package/src/components/FullscreenLayout.tsx +0 -637
  365. package/src/components/GlobalSearchDialog.tsx +0 -343
  366. package/src/components/HelpV2/Commands.tsx +0 -82
  367. package/src/components/HelpV2/General.tsx +0 -23
  368. package/src/components/HelpV2/HelpV2.tsx +0 -184
  369. package/src/components/HighlightedCode/Fallback.tsx +0 -193
  370. package/src/components/HighlightedCode.tsx +0 -190
  371. package/src/components/HistorySearchDialog.tsx +0 -118
  372. package/src/components/IdeAutoConnectDialog.tsx +0 -154
  373. package/src/components/IdeOnboardingDialog.tsx +0 -167
  374. package/src/components/IdeStatusIndicator.tsx +0 -58
  375. package/src/components/IdleReturnDialog.tsx +0 -118
  376. package/src/components/InterruptedByUser.tsx +0 -15
  377. package/src/components/InvalidConfigDialog.tsx +0 -156
  378. package/src/components/InvalidSettingsDialog.tsx +0 -89
  379. package/src/components/KeybindingWarnings.tsx +0 -55
  380. package/src/components/LanguagePicker.tsx +0 -86
  381. package/src/components/LogSelector.tsx +0 -1575
  382. package/src/components/LogoV2/AnimatedAsterisk.tsx +0 -50
  383. package/src/components/LogoV2/AnimatedClawd.tsx +0 -124
  384. package/src/components/LogoV2/ChannelsNotice.tsx +0 -266
  385. package/src/components/LogoV2/Clawd.tsx +0 -25
  386. package/src/components/LogoV2/CondensedLogo.tsx +0 -161
  387. package/src/components/LogoV2/EmergencyTip.tsx +0 -58
  388. package/src/components/LogoV2/Feed.tsx +0 -112
  389. package/src/components/LogoV2/FeedColumn.tsx +0 -59
  390. package/src/components/LogoV2/GuestPassesUpsell.tsx +0 -70
  391. package/src/components/LogoV2/LogoV2.tsx +0 -543
  392. package/src/components/LogoV2/Opus1mMergeNotice.tsx +0 -55
  393. package/src/components/LogoV2/OverageCreditUpsell.tsx +0 -166
  394. package/src/components/LogoV2/VoiceModeNotice.tsx +0 -68
  395. package/src/components/LogoV2/WelcomeV2.tsx +0 -433
  396. package/src/components/LogoV2/feedConfigs.tsx +0 -92
  397. package/src/components/LspRecommendation/LspRecommendationMenu.tsx +0 -88
  398. package/src/components/MCPServerApprovalDialog.tsx +0 -115
  399. package/src/components/MCPServerDesktopImportDialog.tsx +0 -203
  400. package/src/components/MCPServerDialogCopy.tsx +0 -15
  401. package/src/components/MCPServerMultiselectDialog.tsx +0 -133
  402. package/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.tsx +0 -149
  403. package/src/components/ManagedSettingsSecurityDialog/utils.ts +0 -144
  404. package/src/components/Markdown.tsx +0 -236
  405. package/src/components/MarkdownTable.tsx +0 -322
  406. package/src/components/MemoryUsageIndicator.tsx +0 -37
  407. package/src/components/Message.tsx +0 -627
  408. package/src/components/MessageModel.tsx +0 -43
  409. package/src/components/MessageResponse.tsx +0 -78
  410. package/src/components/MessageRow.tsx +0 -383
  411. package/src/components/MessageSelector.tsx +0 -831
  412. package/src/components/MessageTimestamp.tsx +0 -63
  413. package/src/components/Messages.tsx +0 -834
  414. package/src/components/ModelPicker.tsx +0 -448
  415. package/src/components/NativeAutoUpdater.tsx +0 -193
  416. package/src/components/NotebookEditToolUseRejectedMessage.tsx +0 -92
  417. package/src/components/OffscreenFreeze.tsx +0 -44
  418. package/src/components/Onboarding.tsx +0 -244
  419. package/src/components/OutputStylePicker.tsx +0 -112
  420. package/src/components/PackageManagerAutoUpdater.tsx +0 -104
  421. package/src/components/Passes/Passes.tsx +0 -184
  422. package/src/components/PrBadge.tsx +0 -97
  423. package/src/components/PressEnterToContinue.tsx +0 -15
  424. package/src/components/PromptInput/HistorySearchInput.tsx +0 -51
  425. package/src/components/PromptInput/IssueFlagBanner.tsx +0 -12
  426. package/src/components/PromptInput/Notifications.tsx +0 -332
  427. package/src/components/PromptInput/PromptInput.tsx +0 -2339
  428. package/src/components/PromptInput/PromptInputFooter.tsx +0 -191
  429. package/src/components/PromptInput/PromptInputFooterLeftSide.tsx +0 -517
  430. package/src/components/PromptInput/PromptInputFooterSuggestions.tsx +0 -293
  431. package/src/components/PromptInput/PromptInputHelpMenu.tsx +0 -358
  432. package/src/components/PromptInput/PromptInputModeIndicator.tsx +0 -93
  433. package/src/components/PromptInput/PromptInputQueuedCommands.tsx +0 -117
  434. package/src/components/PromptInput/PromptInputStashNotice.tsx +0 -25
  435. package/src/components/PromptInput/SandboxPromptFooterHint.tsx +0 -64
  436. package/src/components/PromptInput/ShimmeredInput.tsx +0 -143
  437. package/src/components/PromptInput/VoiceIndicator.tsx +0 -137
  438. package/src/components/PromptInput/inputModes.ts +0 -33
  439. package/src/components/PromptInput/inputPaste.ts +0 -90
  440. package/src/components/PromptInput/useMaybeTruncateInput.ts +0 -58
  441. package/src/components/PromptInput/usePromptInputPlaceholder.ts +0 -76
  442. package/src/components/PromptInput/useShowFastIconHint.ts +0 -31
  443. package/src/components/PromptInput/useSwarmBanner.ts +0 -155
  444. package/src/components/PromptInput/utils.ts +0 -60
  445. package/src/components/QuickOpenDialog.tsx +0 -244
  446. package/src/components/RemoteCallout.tsx +0 -76
  447. package/src/components/RemoteEnvironmentDialog.tsx +0 -340
  448. package/src/components/ResumeTask.tsx +0 -268
  449. package/src/components/SandboxViolationExpandedView.tsx +0 -99
  450. package/src/components/ScrollKeybindingHandler.tsx +0 -1012
  451. package/src/components/SearchBox.tsx +0 -72
  452. package/src/components/SentryErrorBoundary.ts +0 -28
  453. package/src/components/SessionBackgroundHint.tsx +0 -108
  454. package/src/components/SessionPreview.tsx +0 -194
  455. package/src/components/Settings/Config.tsx +0 -1822
  456. package/src/components/Settings/Settings.tsx +0 -137
  457. package/src/components/Settings/Status.tsx +0 -241
  458. package/src/components/Settings/Usage.tsx +0 -377
  459. package/src/components/ShowInIDEPrompt.tsx +0 -170
  460. package/src/components/SkillImprovementSurvey.tsx +0 -152
  461. package/src/components/Spinner/FlashingChar.tsx +0 -61
  462. package/src/components/Spinner/GlimmerMessage.tsx +0 -328
  463. package/src/components/Spinner/ShimmerChar.tsx +0 -36
  464. package/src/components/Spinner/SpinnerAnimationRow.tsx +0 -265
  465. package/src/components/Spinner/SpinnerGlyph.tsx +0 -80
  466. package/src/components/Spinner/TeammateSpinnerLine.tsx +0 -233
  467. package/src/components/Spinner/TeammateSpinnerTree.tsx +0 -272
  468. package/src/components/Spinner/index.ts +0 -10
  469. package/src/components/Spinner/teammateSelectHint.ts +0 -1
  470. package/src/components/Spinner/types.ts +0 -2
  471. package/src/components/Spinner/useShimmerAnimation.ts +0 -31
  472. package/src/components/Spinner/useStalledAnimation.ts +0 -75
  473. package/src/components/Spinner/utils.ts +0 -84
  474. package/src/components/Spinner.tsx +0 -562
  475. package/src/components/Stats.tsx +0 -1228
  476. package/src/components/StatusLine.tsx +0 -324
  477. package/src/components/StatusNotices.tsx +0 -55
  478. package/src/components/StructuredDiff/Fallback.tsx +0 -487
  479. package/src/components/StructuredDiff/colorDiff.ts +0 -37
  480. package/src/components/StructuredDiff.tsx +0 -190
  481. package/src/components/StructuredDiffList.tsx +0 -30
  482. package/src/components/TagTabs.tsx +0 -139
  483. package/src/components/TaskListV2.tsx +0 -378
  484. package/src/components/TeammateViewHeader.tsx +0 -82
  485. package/src/components/TeleportError.tsx +0 -189
  486. package/src/components/TeleportProgress.tsx +0 -140
  487. package/src/components/TeleportRepoMismatchDialog.tsx +0 -104
  488. package/src/components/TeleportResumeWrapper.tsx +0 -167
  489. package/src/components/TeleportStash.tsx +0 -116
  490. package/src/components/TextInput.tsx +0 -124
  491. package/src/components/ThemePicker.tsx +0 -333
  492. package/src/components/ThinkingToggle.tsx +0 -153
  493. package/src/components/TokenWarning.tsx +0 -179
  494. package/src/components/ToolUseLoader.tsx +0 -42
  495. package/src/components/TrustDialog/TrustDialog.tsx +0 -290
  496. package/src/components/TrustDialog/utils.ts +0 -245
  497. package/src/components/ValidationErrorsList.tsx +0 -148
  498. package/src/components/VimTextInput.tsx +0 -140
  499. package/src/components/VirtualMessageList.tsx +0 -1082
  500. package/src/components/WorkflowMultiselectDialog.tsx +0 -128
  501. package/src/components/WorktreeExitDialog.tsx +0 -231
  502. package/src/components/agents/AgentDetail.tsx +0 -220
  503. package/src/components/agents/AgentEditor.tsx +0 -178
  504. package/src/components/agents/AgentNavigationFooter.tsx +0 -26
  505. package/src/components/agents/AgentsList.tsx +0 -440
  506. package/src/components/agents/AgentsMenu.tsx +0 -800
  507. package/src/components/agents/ColorPicker.tsx +0 -112
  508. package/src/components/agents/ModelSelector.tsx +0 -68
  509. package/src/components/agents/SnapshotUpdateDialog.ts +0 -2
  510. package/src/components/agents/ToolSelector.tsx +0 -562
  511. package/src/components/agents/agentFileUtils.ts +0 -272
  512. package/src/components/agents/generateAgent.ts +0 -197
  513. package/src/components/agents/new-agent-creation/CreateAgentWizard.tsx +0 -97
  514. package/src/components/agents/new-agent-creation/types.ts +0 -1
  515. package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.tsx +0 -84
  516. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.tsx +0 -378
  517. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.tsx +0 -74
  518. package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.tsx +0 -123
  519. package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.tsx +0 -143
  520. package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.tsx +0 -80
  521. package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.tsx +0 -113
  522. package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.tsx +0 -80
  523. package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.tsx +0 -52
  524. package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.tsx +0 -128
  525. package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.tsx +0 -61
  526. package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.tsx +0 -103
  527. package/src/components/agents/types.ts +0 -27
  528. package/src/components/agents/utils.ts +0 -18
  529. package/src/components/agents/validateAgent.ts +0 -109
  530. package/src/components/design-system/Byline.tsx +0 -77
  531. package/src/components/design-system/Dialog.tsx +0 -138
  532. package/src/components/design-system/Divider.tsx +0 -149
  533. package/src/components/design-system/FuzzyPicker.tsx +0 -312
  534. package/src/components/design-system/KeyboardShortcutHint.tsx +0 -81
  535. package/src/components/design-system/ListItem.tsx +0 -244
  536. package/src/components/design-system/LoadingState.tsx +0 -94
  537. package/src/components/design-system/Pane.tsx +0 -77
  538. package/src/components/design-system/ProgressBar.tsx +0 -86
  539. package/src/components/design-system/Ratchet.tsx +0 -80
  540. package/src/components/design-system/StatusIcon.tsx +0 -95
  541. package/src/components/design-system/Tabs.tsx +0 -340
  542. package/src/components/design-system/ThemeProvider.tsx +0 -170
  543. package/src/components/design-system/ThemedBox.tsx +0 -156
  544. package/src/components/design-system/ThemedText.tsx +0 -124
  545. package/src/components/design-system/color.ts +0 -30
  546. package/src/components/diff/DiffDetailView.tsx +0 -281
  547. package/src/components/diff/DiffDialog.tsx +0 -383
  548. package/src/components/diff/DiffFileList.tsx +0 -292
  549. package/src/components/grove/Grove.tsx +0 -463
  550. package/src/components/hooks/HooksConfigMenu.tsx +0 -578
  551. package/src/components/hooks/PromptDialog.tsx +0 -90
  552. package/src/components/hooks/SelectEventMode.tsx +0 -127
  553. package/src/components/hooks/SelectHookMode.tsx +0 -112
  554. package/src/components/hooks/SelectMatcherMode.tsx +0 -144
  555. package/src/components/hooks/ViewHookMode.tsx +0 -199
  556. package/src/components/mcp/CapabilitiesSection.tsx +0 -61
  557. package/src/components/mcp/ElicitationDialog.tsx +0 -1169
  558. package/src/components/mcp/MCPAgentServerMenu.tsx +0 -183
  559. package/src/components/mcp/MCPListPanel.tsx +0 -504
  560. package/src/components/mcp/MCPReconnect.tsx +0 -167
  561. package/src/components/mcp/MCPRemoteServerMenu.tsx +0 -649
  562. package/src/components/mcp/MCPSettings.tsx +0 -398
  563. package/src/components/mcp/MCPStdioServerMenu.tsx +0 -177
  564. package/src/components/mcp/MCPToolDetailView.tsx +0 -212
  565. package/src/components/mcp/MCPToolListView.tsx +0 -141
  566. package/src/components/mcp/McpParsingWarnings.tsx +0 -213
  567. package/src/components/mcp/index.ts +0 -9
  568. package/src/components/mcp/types.ts +0 -7
  569. package/src/components/mcp/utils/reconnectHelpers.tsx +0 -49
  570. package/src/components/memory/MemoryFileSelector.tsx +0 -438
  571. package/src/components/memory/MemoryUpdateNotification.tsx +0 -45
  572. package/src/components/messageActions.tsx +0 -450
  573. package/src/components/messages/AdvisorMessage.tsx +0 -158
  574. package/src/components/messages/AssistantRedactedThinkingMessage.tsx +0 -31
  575. package/src/components/messages/AssistantTextMessage.tsx +0 -270
  576. package/src/components/messages/AssistantThinkingMessage.tsx +0 -86
  577. package/src/components/messages/AssistantToolUseMessage.tsx +0 -368
  578. package/src/components/messages/AttachmentMessage.tsx +0 -536
  579. package/src/components/messages/CollapsedReadSearchContent.tsx +0 -484
  580. package/src/components/messages/CompactBoundaryMessage.tsx +0 -18
  581. package/src/components/messages/GroupedToolUseContent.tsx +0 -58
  582. package/src/components/messages/HighlightedThinkingText.tsx +0 -162
  583. package/src/components/messages/HookProgressMessage.tsx +0 -116
  584. package/src/components/messages/PlanApprovalMessage.tsx +0 -222
  585. package/src/components/messages/RateLimitMessage.tsx +0 -161
  586. package/src/components/messages/ShutdownMessage.tsx +0 -132
  587. package/src/components/messages/SnipBoundaryMessage.ts +0 -2
  588. package/src/components/messages/SystemAPIErrorMessage.tsx +0 -141
  589. package/src/components/messages/SystemTextMessage.tsx +0 -827
  590. package/src/components/messages/TaskAssignmentMessage.tsx +0 -76
  591. package/src/components/messages/UserAgentNotificationMessage.tsx +0 -83
  592. package/src/components/messages/UserBashInputMessage.tsx +0 -58
  593. package/src/components/messages/UserBashOutputMessage.tsx +0 -54
  594. package/src/components/messages/UserChannelMessage.tsx +0 -137
  595. package/src/components/messages/UserCommandMessage.tsx +0 -108
  596. package/src/components/messages/UserCrossSessionMessage.ts +0 -2
  597. package/src/components/messages/UserForkBoilerplateMessage.ts +0 -2
  598. package/src/components/messages/UserGitHubWebhookMessage.ts +0 -2
  599. package/src/components/messages/UserImageMessage.tsx +0 -59
  600. package/src/components/messages/UserLocalCommandOutputMessage.tsx +0 -167
  601. package/src/components/messages/UserMemoryInputMessage.tsx +0 -75
  602. package/src/components/messages/UserPlanMessage.tsx +0 -42
  603. package/src/components/messages/UserPromptMessage.tsx +0 -80
  604. package/src/components/messages/UserResourceUpdateMessage.tsx +0 -121
  605. package/src/components/messages/UserTeammateMessage.tsx +0 -206
  606. package/src/components/messages/UserTextMessage.tsx +0 -275
  607. package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.tsx +0 -31
  608. package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.tsx +0 -16
  609. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +0 -16
  610. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +0 -103
  611. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +0 -95
  612. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +0 -106
  613. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +0 -104
  614. package/src/components/messages/UserToolResultMessage/utils.tsx +0 -44
  615. package/src/components/messages/nullRenderingAttachments.ts +0 -70
  616. package/src/components/messages/teamMemCollapsed.tsx +0 -140
  617. package/src/components/messages/teamMemSaved.ts +0 -19
  618. package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.tsx +0 -645
  619. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.tsx +0 -229
  620. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.tsx +0 -328
  621. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.tsx +0 -178
  622. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.tsx +0 -465
  623. package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.tsx +0 -144
  624. package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.ts +0 -179
  625. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +0 -482
  626. package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.tsx +0 -147
  627. package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.tsx +0 -441
  628. package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.tsx +0 -122
  629. package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.tsx +0 -768
  630. package/src/components/permissions/FallbackPermissionRequest.tsx +0 -333
  631. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +0 -182
  632. package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.tsx +0 -204
  633. package/src/components/permissions/FilePermissionDialog/ideDiffConfig.ts +0 -42
  634. package/src/components/permissions/FilePermissionDialog/permissionOptions.tsx +0 -177
  635. package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.ts +0 -212
  636. package/src/components/permissions/FilePermissionDialog/usePermissionHandler.ts +0 -185
  637. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +0 -161
  638. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +0 -89
  639. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +0 -115
  640. package/src/components/permissions/MonitorPermissionRequest/MonitorPermissionRequest.ts +0 -2
  641. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.tsx +0 -166
  642. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.tsx +0 -235
  643. package/src/components/permissions/PermissionDecisionDebugInfo.tsx +0 -460
  644. package/src/components/permissions/PermissionDialog.tsx +0 -72
  645. package/src/components/permissions/PermissionExplanation.tsx +0 -272
  646. package/src/components/permissions/PermissionPrompt.tsx +0 -336
  647. package/src/components/permissions/PermissionRequest.tsx +0 -217
  648. package/src/components/permissions/PermissionRequestTitle.tsx +0 -66
  649. package/src/components/permissions/PermissionRuleExplanation.tsx +0 -121
  650. package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.tsx +0 -235
  651. package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.tsx +0 -91
  652. package/src/components/permissions/ReviewArtifactPermissionRequest/ReviewArtifactPermissionRequest.ts +0 -2
  653. package/src/components/permissions/SandboxPermissionRequest.tsx +0 -163
  654. package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.tsx +0 -230
  655. package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.tsx +0 -369
  656. package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.tsx +0 -258
  657. package/src/components/permissions/WorkerBadge.tsx +0 -49
  658. package/src/components/permissions/WorkerPendingPermission.tsx +0 -105
  659. package/src/components/permissions/hooks.ts +0 -209
  660. package/src/components/permissions/rules/AddPermissionRules.tsx +0 -180
  661. package/src/components/permissions/rules/AddWorkspaceDirectory.tsx +0 -340
  662. package/src/components/permissions/rules/PermissionRuleDescription.tsx +0 -76
  663. package/src/components/permissions/rules/PermissionRuleInput.tsx +0 -138
  664. package/src/components/permissions/rules/PermissionRuleList.tsx +0 -1179
  665. package/src/components/permissions/rules/RecentDenialsTab.tsx +0 -207
  666. package/src/components/permissions/rules/RemoveWorkspaceDirectory.tsx +0 -110
  667. package/src/components/permissions/rules/WorkspaceTab.tsx +0 -150
  668. package/src/components/permissions/shellPermissionHelpers.tsx +0 -164
  669. package/src/components/permissions/useShellPermissionFeedback.ts +0 -148
  670. package/src/components/permissions/utils.ts +0 -25
  671. package/src/components/sandbox/SandboxConfigTab.tsx +0 -45
  672. package/src/components/sandbox/SandboxDependenciesTab.tsx +0 -120
  673. package/src/components/sandbox/SandboxDoctorSection.tsx +0 -46
  674. package/src/components/sandbox/SandboxOverridesTab.tsx +0 -193
  675. package/src/components/sandbox/SandboxSettings.tsx +0 -296
  676. package/src/components/shell/ExpandShellOutputContext.tsx +0 -36
  677. package/src/components/shell/OutputLine.tsx +0 -118
  678. package/src/components/shell/ShellProgressMessage.tsx +0 -150
  679. package/src/components/shell/ShellTimeDisplay.tsx +0 -74
  680. package/src/components/skills/SkillsMenu.tsx +0 -237
  681. package/src/components/tasks/AsyncAgentDetailDialog.tsx +0 -229
  682. package/src/components/tasks/BackgroundTask.tsx +0 -345
  683. package/src/components/tasks/BackgroundTaskStatus.tsx +0 -429
  684. package/src/components/tasks/BackgroundTasksDialog.tsx +0 -652
  685. package/src/components/tasks/DreamDetailDialog.tsx +0 -251
  686. package/src/components/tasks/InProcessTeammateDetailDialog.tsx +0 -266
  687. package/src/components/tasks/MonitorMcpDetailDialog.ts +0 -2
  688. package/src/components/tasks/RemoteSessionDetailDialog.tsx +0 -904
  689. package/src/components/tasks/RemoteSessionProgress.tsx +0 -243
  690. package/src/components/tasks/ShellDetailDialog.tsx +0 -404
  691. package/src/components/tasks/ShellProgress.tsx +0 -87
  692. package/src/components/tasks/WorkflowDetailDialog.ts +0 -2
  693. package/src/components/tasks/renderToolActivity.tsx +0 -33
  694. package/src/components/tasks/taskStatusUtils.tsx +0 -107
  695. package/src/components/teams/TeamStatus.tsx +0 -80
  696. package/src/components/teams/TeamsDialog.tsx +0 -715
  697. package/src/components/ui/OrderedList.tsx +0 -71
  698. package/src/components/ui/OrderedListItem.tsx +0 -45
  699. package/src/components/ui/TreeSelect.tsx +0 -397
  700. package/src/components/ui/option.ts +0 -4
  701. package/src/components/wizard/WizardDialogLayout.tsx +0 -65
  702. package/src/components/wizard/WizardNavigationFooter.tsx +0 -24
  703. package/src/components/wizard/WizardProvider.tsx +0 -213
  704. package/src/components/wizard/index.ts +0 -9
  705. package/src/components/wizard/types.ts +0 -3
  706. package/src/components/wizard/useWizard.ts +0 -13
  707. package/src/constants/apiLimits.ts +0 -94
  708. package/src/constants/betas.ts +0 -52
  709. package/src/constants/common.ts +0 -33
  710. package/src/constants/cyberRiskInstruction.ts +0 -24
  711. package/src/constants/errorIds.ts +0 -15
  712. package/src/constants/figures.ts +0 -45
  713. package/src/constants/files.ts +0 -156
  714. package/src/constants/github-app.ts +0 -144
  715. package/src/constants/keys.ts +0 -11
  716. package/src/constants/messages.ts +0 -1
  717. package/src/constants/oauth.ts +0 -234
  718. package/src/constants/outputStyles.ts +0 -216
  719. package/src/constants/product.ts +0 -76
  720. package/src/constants/prompts.ts +0 -915
  721. package/src/constants/querySource.ts +0 -1
  722. package/src/constants/spinnerVerbs.ts +0 -204
  723. package/src/constants/system.ts +0 -95
  724. package/src/constants/systemPromptSections.ts +0 -68
  725. package/src/constants/toolLimits.ts +0 -56
  726. package/src/constants/tools.ts +0 -112
  727. package/src/constants/turnCompletionVerbs.ts +0 -12
  728. package/src/constants/xml.ts +0 -86
  729. package/src/context/QueuedMessageContext.tsx +0 -63
  730. package/src/context/fpsMetrics.tsx +0 -30
  731. package/src/context/mailbox.tsx +0 -38
  732. package/src/context/modalContext.tsx +0 -58
  733. package/src/context/notifications.tsx +0 -240
  734. package/src/context/overlayContext.tsx +0 -151
  735. package/src/context/promptOverlayContext.tsx +0 -125
  736. package/src/context/stats.tsx +0 -220
  737. package/src/context/voice.tsx +0 -88
  738. package/src/context.ts +0 -189
  739. package/src/coordinator/coordinatorMode.ts +0 -369
  740. package/src/coordinator/workerAgent.ts +0 -2
  741. package/src/cost-tracker.ts +0 -323
  742. package/src/costHook.ts +0 -22
  743. package/src/daemon/main.ts +0 -2
  744. package/src/daemon/workerRegistry.ts +0 -2
  745. package/src/dialogLaunchers.tsx +0 -133
  746. package/src/engine/CostMapper.ts +0 -57
  747. package/src/engine/MessageMapper.ts +0 -276
  748. package/src/engine/ModelResolver.ts +0 -153
  749. package/src/engine/PermissionBridge.ts +0 -114
  750. package/src/engine/PiAgentAdapter.ts +0 -299
  751. package/src/engine/SubagentTools.ts +0 -92
  752. package/src/engine/ToolAdapter.ts +0 -122
  753. package/src/engine/engine-backup/CostMapper.ts +0 -57
  754. package/src/engine/engine-backup/MessageMapper.ts +0 -276
  755. package/src/engine/engine-backup/ModelResolver.ts +0 -153
  756. package/src/engine/engine-backup/PermissionBridge.ts +0 -114
  757. package/src/engine/engine-backup/PiAgentAdapter.ts +0 -299
  758. package/src/engine/engine-backup/SubagentTools.ts +0 -92
  759. package/src/engine/engine-backup/ToolAdapter.ts +0 -122
  760. package/src/engine/engine-backup/index.ts +0 -14
  761. package/src/engine/engine-backup/piQueryBridge.ts +0 -396
  762. package/src/engine/index.ts +0 -14
  763. package/src/engine/piQueryBridge.ts +0 -396
  764. package/src/entrypoints/agentSdkTypes.ts +0 -443
  765. package/src/entrypoints/cli.tsx +0 -303
  766. package/src/entrypoints/init.ts +0 -340
  767. package/src/entrypoints/mcp.ts +0 -196
  768. package/src/entrypoints/sandboxTypes.ts +0 -156
  769. package/src/entrypoints/sdk/controlSchemas.ts +0 -663
  770. package/src/entrypoints/sdk/controlTypes.ts +0 -12
  771. package/src/entrypoints/sdk/coreSchemas.ts +0 -1889
  772. package/src/entrypoints/sdk/coreTypes.generated.ts +0 -1
  773. package/src/entrypoints/sdk/coreTypes.ts +0 -62
  774. package/src/entrypoints/sdk/runtimeTypes.ts +0 -18
  775. package/src/entrypoints/sdk/sdkUtilityTypes.ts +0 -1
  776. package/src/entrypoints/sdk/settingsTypes.generated.ts +0 -1
  777. package/src/entrypoints/sdk/toolTypes.ts +0 -2
  778. package/src/environment-runner/main.ts +0 -2
  779. package/src/history.ts +0 -464
  780. package/src/hooks/fileSuggestions.ts +0 -811
  781. package/src/hooks/notifs/useAntOrgWarningNotification.ts +0 -2
  782. package/src/hooks/notifs/useAutoModeUnavailableNotification.ts +0 -56
  783. package/src/hooks/notifs/useCanSwitchToExistingSubscription.tsx +0 -60
  784. package/src/hooks/notifs/useDeprecationWarningNotification.tsx +0 -44
  785. package/src/hooks/notifs/useFastModeNotification.tsx +0 -162
  786. package/src/hooks/notifs/useIDEStatusIndicator.tsx +0 -186
  787. package/src/hooks/notifs/useInstallMessages.tsx +0 -26
  788. package/src/hooks/notifs/useLspInitializationNotification.tsx +0 -143
  789. package/src/hooks/notifs/useMcpConnectivityStatus.tsx +0 -88
  790. package/src/hooks/notifs/useModelMigrationNotifications.tsx +0 -52
  791. package/src/hooks/notifs/useNpmDeprecationNotification.tsx +0 -25
  792. package/src/hooks/notifs/usePluginAutoupdateNotification.tsx +0 -83
  793. package/src/hooks/notifs/usePluginInstallationStatus.tsx +0 -128
  794. package/src/hooks/notifs/useRateLimitWarningNotification.tsx +0 -114
  795. package/src/hooks/notifs/useSettingsErrors.tsx +0 -69
  796. package/src/hooks/notifs/useStartupNotification.ts +0 -41
  797. package/src/hooks/notifs/useTeammateShutdownNotification.ts +0 -78
  798. package/src/hooks/renderPlaceholder.ts +0 -51
  799. package/src/hooks/toolPermission/PermissionContext.ts +0 -388
  800. package/src/hooks/toolPermission/handlers/coordinatorHandler.ts +0 -65
  801. package/src/hooks/toolPermission/handlers/interactiveHandler.ts +0 -536
  802. package/src/hooks/toolPermission/handlers/swarmWorkerHandler.ts +0 -159
  803. package/src/hooks/toolPermission/permissionLogging.ts +0 -238
  804. package/src/hooks/unifiedSuggestions.ts +0 -202
  805. package/src/hooks/useAfterFirstRender.ts +0 -17
  806. package/src/hooks/useApiKeyVerification.ts +0 -84
  807. package/src/hooks/useArrowKeyHistory.tsx +0 -229
  808. package/src/hooks/useAssistantHistory.ts +0 -250
  809. package/src/hooks/useAwaySummary.ts +0 -125
  810. package/src/hooks/useBackgroundTaskNavigation.ts +0 -251
  811. package/src/hooks/useBlink.ts +0 -34
  812. package/src/hooks/useCanUseTool.tsx +0 -204
  813. package/src/hooks/useCancelRequest.ts +0 -276
  814. package/src/hooks/useChromeExtensionNotification.tsx +0 -50
  815. package/src/hooks/useClaudeCodeHintRecommendation.tsx +0 -129
  816. package/src/hooks/useClipboardImageHint.ts +0 -77
  817. package/src/hooks/useCommandKeybindings.tsx +0 -108
  818. package/src/hooks/useCommandQueue.ts +0 -15
  819. package/src/hooks/useCopyOnSelect.ts +0 -98
  820. package/src/hooks/useDeferredHookMessages.ts +0 -46
  821. package/src/hooks/useDiffData.ts +0 -110
  822. package/src/hooks/useDiffInIDE.ts +0 -379
  823. package/src/hooks/useDirectConnect.ts +0 -229
  824. package/src/hooks/useDoublePress.ts +0 -62
  825. package/src/hooks/useDynamicConfig.ts +0 -22
  826. package/src/hooks/useElapsedTime.ts +0 -37
  827. package/src/hooks/useExitOnCtrlCD.ts +0 -95
  828. package/src/hooks/useExitOnCtrlCDWithKeybindings.ts +0 -24
  829. package/src/hooks/useFileHistorySnapshotInit.ts +0 -25
  830. package/src/hooks/useGlobalKeybindings.tsx +0 -249
  831. package/src/hooks/useHistorySearch.ts +0 -303
  832. package/src/hooks/useIDEIntegration.tsx +0 -70
  833. package/src/hooks/useIdeAtMentioned.ts +0 -76
  834. package/src/hooks/useIdeConnectionStatus.ts +0 -33
  835. package/src/hooks/useIdeLogging.ts +0 -41
  836. package/src/hooks/useIdeSelection.ts +0 -150
  837. package/src/hooks/useInboxPoller.ts +0 -969
  838. package/src/hooks/useInputBuffer.ts +0 -132
  839. package/src/hooks/useIssueFlagBanner.ts +0 -133
  840. package/src/hooks/useLogMessages.ts +0 -119
  841. package/src/hooks/useLspPluginRecommendation.tsx +0 -194
  842. package/src/hooks/useMailboxBridge.ts +0 -21
  843. package/src/hooks/useMainLoopModel.ts +0 -34
  844. package/src/hooks/useManagePlugins.ts +0 -304
  845. package/src/hooks/useMemoryUsage.ts +0 -39
  846. package/src/hooks/useMergedClients.ts +0 -23
  847. package/src/hooks/useMergedCommands.ts +0 -15
  848. package/src/hooks/useMergedTools.ts +0 -44
  849. package/src/hooks/useMinDisplayTime.ts +0 -35
  850. package/src/hooks/useNotifyAfterTimeout.ts +0 -65
  851. package/src/hooks/useOfficialMarketplaceNotification.tsx +0 -48
  852. package/src/hooks/usePasteHandler.ts +0 -285
  853. package/src/hooks/usePluginRecommendationBase.tsx +0 -105
  854. package/src/hooks/usePrStatus.ts +0 -106
  855. package/src/hooks/usePromptSuggestion.ts +0 -177
  856. package/src/hooks/usePromptsFromClaudeInChrome.tsx +0 -71
  857. package/src/hooks/useQueueProcessor.ts +0 -68
  858. package/src/hooks/useRemoteSession.ts +0 -605
  859. package/src/hooks/useReplBridge.tsx +0 -723
  860. package/src/hooks/useSSHSession.ts +0 -241
  861. package/src/hooks/useScheduledTasks.ts +0 -139
  862. package/src/hooks/useSearchInput.ts +0 -364
  863. package/src/hooks/useSessionBackgrounding.ts +0 -158
  864. package/src/hooks/useSettings.ts +0 -17
  865. package/src/hooks/useSettingsChange.ts +0 -25
  866. package/src/hooks/useSkillImprovementSurvey.ts +0 -105
  867. package/src/hooks/useSkillsChange.ts +0 -62
  868. package/src/hooks/useSwarmInitialization.ts +0 -81
  869. package/src/hooks/useSwarmPermissionPoller.ts +0 -330
  870. package/src/hooks/useTaskListWatcher.ts +0 -221
  871. package/src/hooks/useTasksV2.ts +0 -250
  872. package/src/hooks/useTeammateViewAutoExit.ts +0 -63
  873. package/src/hooks/useTeleportResume.tsx +0 -85
  874. package/src/hooks/useTerminalSize.ts +0 -15
  875. package/src/hooks/useTextInput.ts +0 -529
  876. package/src/hooks/useTimeout.ts +0 -14
  877. package/src/hooks/useTurnDiffs.ts +0 -213
  878. package/src/hooks/useTypeahead.tsx +0 -1385
  879. package/src/hooks/useUpdateNotification.ts +0 -34
  880. package/src/hooks/useVimInput.ts +0 -316
  881. package/src/hooks/useVirtualScroll.ts +0 -721
  882. package/src/hooks/useVoice.ts +0 -1144
  883. package/src/hooks/useVoiceEnabled.ts +0 -25
  884. package/src/hooks/useVoiceIntegration.tsx +0 -677
  885. package/src/hunter.ts +0 -1
  886. package/src/ink/Ansi.tsx +0 -292
  887. package/src/ink/bidi.ts +0 -139
  888. package/src/ink/clearTerminal.ts +0 -74
  889. package/src/ink/colorize.ts +0 -231
  890. package/src/ink/components/AlternateScreen.tsx +0 -80
  891. package/src/ink/components/App.tsx +0 -658
  892. package/src/ink/components/AppContext.ts +0 -21
  893. package/src/ink/components/Box.tsx +0 -214
  894. package/src/ink/components/Button.tsx +0 -192
  895. package/src/ink/components/ClockContext.tsx +0 -112
  896. package/src/ink/components/CursorDeclarationContext.ts +0 -32
  897. package/src/ink/components/ErrorOverview.tsx +0 -109
  898. package/src/ink/components/Link.tsx +0 -42
  899. package/src/ink/components/Newline.tsx +0 -39
  900. package/src/ink/components/NoSelect.tsx +0 -68
  901. package/src/ink/components/RawAnsi.tsx +0 -57
  902. package/src/ink/components/ScrollBox.tsx +0 -237
  903. package/src/ink/components/Spacer.tsx +0 -20
  904. package/src/ink/components/StdinContext.ts +0 -49
  905. package/src/ink/components/TerminalFocusContext.tsx +0 -52
  906. package/src/ink/components/TerminalSizeContext.tsx +0 -7
  907. package/src/ink/components/Text.tsx +0 -254
  908. package/src/ink/constants.ts +0 -2
  909. package/src/ink/cursor.ts +0 -1
  910. package/src/ink/devtools.ts +0 -2
  911. package/src/ink/dom.ts +0 -484
  912. package/src/ink/events/click-event.ts +0 -38
  913. package/src/ink/events/dispatcher.ts +0 -233
  914. package/src/ink/events/emitter.ts +0 -39
  915. package/src/ink/events/event-handlers.ts +0 -73
  916. package/src/ink/events/event.ts +0 -11
  917. package/src/ink/events/focus-event.ts +0 -21
  918. package/src/ink/events/input-event.ts +0 -205
  919. package/src/ink/events/keyboard-event.ts +0 -51
  920. package/src/ink/events/paste-event.ts +0 -1
  921. package/src/ink/events/resize-event.ts +0 -1
  922. package/src/ink/events/terminal-event.ts +0 -107
  923. package/src/ink/events/terminal-focus-event.ts +0 -19
  924. package/src/ink/focus.ts +0 -181
  925. package/src/ink/frame.ts +0 -124
  926. package/src/ink/get-max-width.ts +0 -27
  927. package/src/ink/global.d.ts +0 -1
  928. package/src/ink/hit-test.ts +0 -130
  929. package/src/ink/hooks/use-animation-frame.ts +0 -57
  930. package/src/ink/hooks/use-app.ts +0 -8
  931. package/src/ink/hooks/use-declared-cursor.ts +0 -73
  932. package/src/ink/hooks/use-input.ts +0 -92
  933. package/src/ink/hooks/use-interval.ts +0 -67
  934. package/src/ink/hooks/use-search-highlight.ts +0 -53
  935. package/src/ink/hooks/use-selection.ts +0 -104
  936. package/src/ink/hooks/use-stdin.ts +0 -8
  937. package/src/ink/hooks/use-tab-status.ts +0 -72
  938. package/src/ink/hooks/use-terminal-focus.ts +0 -16
  939. package/src/ink/hooks/use-terminal-title.ts +0 -31
  940. package/src/ink/hooks/use-terminal-viewport.ts +0 -96
  941. package/src/ink/ink.tsx +0 -1723
  942. package/src/ink/instances.ts +0 -10
  943. package/src/ink/layout/engine.ts +0 -6
  944. package/src/ink/layout/geometry.ts +0 -97
  945. package/src/ink/layout/node.ts +0 -152
  946. package/src/ink/layout/yoga.ts +0 -308
  947. package/src/ink/line-width-cache.ts +0 -24
  948. package/src/ink/log-update.ts +0 -773
  949. package/src/ink/measure-element.ts +0 -23
  950. package/src/ink/measure-text.ts +0 -47
  951. package/src/ink/node-cache.ts +0 -54
  952. package/src/ink/optimizer.ts +0 -93
  953. package/src/ink/output.ts +0 -797
  954. package/src/ink/parse-keypress.ts +0 -801
  955. package/src/ink/reconciler.ts +0 -512
  956. package/src/ink/render-border.ts +0 -231
  957. package/src/ink/render-node-to-output.ts +0 -1462
  958. package/src/ink/render-to-screen.ts +0 -231
  959. package/src/ink/renderer.ts +0 -178
  960. package/src/ink/root.ts +0 -184
  961. package/src/ink/screen.ts +0 -1486
  962. package/src/ink/searchHighlight.ts +0 -93
  963. package/src/ink/selection.ts +0 -917
  964. package/src/ink/squash-text-nodes.ts +0 -92
  965. package/src/ink/stringWidth.ts +0 -222
  966. package/src/ink/styles.ts +0 -771
  967. package/src/ink/supports-hyperlinks.ts +0 -57
  968. package/src/ink/tabstops.ts +0 -46
  969. package/src/ink/terminal-focus-state.ts +0 -47
  970. package/src/ink/terminal-querier.ts +0 -212
  971. package/src/ink/terminal.ts +0 -248
  972. package/src/ink/termio/ansi.ts +0 -75
  973. package/src/ink/termio/csi.ts +0 -319
  974. package/src/ink/termio/dec.ts +0 -60
  975. package/src/ink/termio/esc.ts +0 -67
  976. package/src/ink/termio/osc.ts +0 -493
  977. package/src/ink/termio/parser.ts +0 -394
  978. package/src/ink/termio/sgr.ts +0 -308
  979. package/src/ink/termio/tokenize.ts +0 -319
  980. package/src/ink/termio/types.ts +0 -236
  981. package/src/ink/termio.ts +0 -42
  982. package/src/ink/useTerminalNotification.ts +0 -126
  983. package/src/ink/warn.ts +0 -9
  984. package/src/ink/widest-line.ts +0 -19
  985. package/src/ink/wrap-text.ts +0 -74
  986. package/src/ink/wrapAnsi.ts +0 -20
  987. package/src/ink.ts +0 -85
  988. package/src/interactiveHelpers.tsx +0 -366
  989. package/src/jobs/classifier.ts +0 -2
  990. package/src/keybindings/KeybindingContext.tsx +0 -243
  991. package/src/keybindings/KeybindingProviderSetup.tsx +0 -308
  992. package/src/keybindings/defaultBindings.ts +0 -340
  993. package/src/keybindings/loadUserBindings.ts +0 -472
  994. package/src/keybindings/match.ts +0 -120
  995. package/src/keybindings/parser.ts +0 -203
  996. package/src/keybindings/reservedShortcuts.ts +0 -127
  997. package/src/keybindings/resolver.ts +0 -244
  998. package/src/keybindings/schema.ts +0 -236
  999. package/src/keybindings/shortcutFormat.ts +0 -63
  1000. package/src/keybindings/template.ts +0 -52
  1001. package/src/keybindings/types.ts +0 -3
  1002. package/src/keybindings/useKeybinding.ts +0 -196
  1003. package/src/keybindings/useShortcutDisplay.ts +0 -59
  1004. package/src/keybindings/validate.ts +0 -498
  1005. package/src/main.tsx +0 -4684
  1006. package/src/memdir/findRelevantMemories.ts +0 -141
  1007. package/src/memdir/memdir.ts +0 -507
  1008. package/src/memdir/memoryAge.ts +0 -53
  1009. package/src/memdir/memoryScan.ts +0 -94
  1010. package/src/memdir/memoryShapeTelemetry.ts +0 -2
  1011. package/src/memdir/memoryTypes.ts +0 -271
  1012. package/src/memdir/paths.ts +0 -278
  1013. package/src/memdir/teamMemPaths.ts +0 -292
  1014. package/src/memdir/teamMemPrompts.ts +0 -100
  1015. package/src/migrations/migrateAutoUpdatesToSettings.ts +0 -61
  1016. package/src/migrations/migrateBypassPermissionsAcceptedToSettings.ts +0 -40
  1017. package/src/migrations/migrateEnableAllProjectMcpServersToSettings.ts +0 -118
  1018. package/src/migrations/migrateFennecToOpus.ts +0 -45
  1019. package/src/migrations/migrateLegacyOpusToCurrent.ts +0 -57
  1020. package/src/migrations/migrateOpusToOpus1m.ts +0 -43
  1021. package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.ts +0 -22
  1022. package/src/migrations/migrateSonnet1mToSonnet45.ts +0 -48
  1023. package/src/migrations/migrateSonnet45ToSonnet46.ts +0 -67
  1024. package/src/migrations/resetAutoModeOptInForDefaultOffer.ts +0 -51
  1025. package/src/migrations/resetProToOpusDefault.ts +0 -51
  1026. package/src/moreright/useMoreRight.tsx +0 -26
  1027. package/src/native-ts/color-diff/index.ts +0 -1001
  1028. package/src/native-ts/file-index/index.ts +0 -370
  1029. package/src/native-ts/yoga-layout/enums.ts +0 -134
  1030. package/src/native-ts/yoga-layout/index.ts +0 -2578
  1031. package/src/outputStyles/loadOutputStylesDir.ts +0 -98
  1032. package/src/plugins/builtinPlugins.ts +0 -159
  1033. package/src/plugins/bundled/index.ts +0 -23
  1034. package/src/proactive/index.ts +0 -1
  1035. package/src/proactive/useProactive.ts +0 -1
  1036. package/src/projectOnboardingState.ts +0 -83
  1037. package/src/query/config.ts +0 -46
  1038. package/src/query/deps.ts +0 -33
  1039. package/src/query/stopHooks.ts +0 -473
  1040. package/src/query/tokenBudget.ts +0 -93
  1041. package/src/query/transitions.ts +0 -2
  1042. package/src/query.ts +0 -1729
  1043. package/src/remote/RemoteSessionManager.ts +0 -343
  1044. package/src/remote/SessionsWebSocket.ts +0 -404
  1045. package/src/remote/remotePermissionBridge.ts +0 -78
  1046. package/src/remote/sdkMessageAdapter.ts +0 -302
  1047. package/src/replLauncher.tsx +0 -23
  1048. package/src/schemas/hooks.ts +0 -222
  1049. package/src/screens/Doctor.tsx +0 -575
  1050. package/src/screens/REPL.tsx +0 -5006
  1051. package/src/screens/ResumeConversation.tsx +0 -399
  1052. package/src/self-hosted-runner/main.ts +0 -2
  1053. package/src/server/backends/dangerousBackend.ts +0 -2
  1054. package/src/server/connectHeadless.ts +0 -2
  1055. package/src/server/createDirectConnectSession.ts +0 -88
  1056. package/src/server/directConnectManager.ts +0 -213
  1057. package/src/server/lockfile.ts +0 -2
  1058. package/src/server/parseConnectUrl.ts +0 -2
  1059. package/src/server/server.ts +0 -2
  1060. package/src/server/serverBanner.ts +0 -2
  1061. package/src/server/serverLog.ts +0 -2
  1062. package/src/server/sessionManager.ts +0 -2
  1063. package/src/server/types.ts +0 -57
  1064. package/src/services/AgentSummary/agentSummary.ts +0 -179
  1065. package/src/services/MagicDocs/magicDocs.ts +0 -254
  1066. package/src/services/MagicDocs/prompts.ts +0 -127
  1067. package/src/services/PromptSuggestion/promptSuggestion.ts +0 -523
  1068. package/src/services/PromptSuggestion/speculation.ts +0 -991
  1069. package/src/services/SessionMemory/prompts.ts +0 -324
  1070. package/src/services/SessionMemory/sessionMemory.ts +0 -495
  1071. package/src/services/SessionMemory/sessionMemoryUtils.ts +0 -207
  1072. package/src/services/analytics/config.ts +0 -38
  1073. package/src/services/analytics/datadog.ts +0 -307
  1074. package/src/services/analytics/firstPartyEventLogger.ts +0 -449
  1075. package/src/services/analytics/firstPartyEventLoggingExporter.ts +0 -806
  1076. package/src/services/analytics/growthbook.ts +0 -1155
  1077. package/src/services/analytics/index.ts +0 -173
  1078. package/src/services/analytics/metadata.ts +0 -973
  1079. package/src/services/analytics/sink.ts +0 -114
  1080. package/src/services/analytics/sinkKillswitch.ts +0 -25
  1081. package/src/services/api/adminRequests.ts +0 -119
  1082. package/src/services/api/bootstrap.ts +0 -141
  1083. package/src/services/api/claude.ts +0 -3419
  1084. package/src/services/api/client.ts +0 -389
  1085. package/src/services/api/dumpPrompts.ts +0 -226
  1086. package/src/services/api/emptyUsage.ts +0 -22
  1087. package/src/services/api/errorUtils.ts +0 -260
  1088. package/src/services/api/errors.ts +0 -1205
  1089. package/src/services/api/filesApi.ts +0 -748
  1090. package/src/services/api/firstTokenDate.ts +0 -60
  1091. package/src/services/api/grove.ts +0 -357
  1092. package/src/services/api/logging.ts +0 -788
  1093. package/src/services/api/metricsOptOut.ts +0 -159
  1094. package/src/services/api/overageCreditGrant.ts +0 -137
  1095. package/src/services/api/promptCacheBreakDetection.ts +0 -727
  1096. package/src/services/api/referral.ts +0 -281
  1097. package/src/services/api/sessionIngress.ts +0 -514
  1098. package/src/services/api/ultrareviewQuota.ts +0 -38
  1099. package/src/services/api/usage.ts +0 -63
  1100. package/src/services/api/withRetry.ts +0 -818
  1101. package/src/services/autoDream/autoDream.ts +0 -324
  1102. package/src/services/autoDream/config.ts +0 -21
  1103. package/src/services/autoDream/consolidationLock.ts +0 -140
  1104. package/src/services/autoDream/consolidationPrompt.ts +0 -65
  1105. package/src/services/autoDream/dream.ts +0 -1
  1106. package/src/services/awaySummary.ts +0 -74
  1107. package/src/services/claudeAiLimits.ts +0 -515
  1108. package/src/services/claudeAiLimitsHook.ts +0 -23
  1109. package/src/services/compact/apiMicrocompact.ts +0 -153
  1110. package/src/services/compact/autoCompact.ts +0 -351
  1111. package/src/services/compact/cachedMCConfig.ts +0 -2
  1112. package/src/services/compact/cachedMicrocompact.ts +0 -2
  1113. package/src/services/compact/compact.ts +0 -1705
  1114. package/src/services/compact/compactWarningHook.ts +0 -16
  1115. package/src/services/compact/compactWarningState.ts +0 -18
  1116. package/src/services/compact/grouping.ts +0 -63
  1117. package/src/services/compact/microCompact.ts +0 -530
  1118. package/src/services/compact/postCompactCleanup.ts +0 -77
  1119. package/src/services/compact/prompt.ts +0 -374
  1120. package/src/services/compact/reactiveCompact.ts +0 -2
  1121. package/src/services/compact/sessionMemoryCompact.ts +0 -630
  1122. package/src/services/compact/snipCompact.ts +0 -1
  1123. package/src/services/compact/snipProjection.ts +0 -2
  1124. package/src/services/compact/timeBasedMCConfig.ts +0 -43
  1125. package/src/services/contextCollapse/index.ts +0 -2
  1126. package/src/services/contextCollapse/operations.ts +0 -2
  1127. package/src/services/contextCollapse/persist.ts +0 -2
  1128. package/src/services/diagnosticTracking.ts +0 -397
  1129. package/src/services/extractMemories/extractMemories.ts +0 -615
  1130. package/src/services/extractMemories/prompts.ts +0 -154
  1131. package/src/services/internalLogging.ts +0 -90
  1132. package/src/services/lsp/LSPClient.ts +0 -447
  1133. package/src/services/lsp/LSPDiagnosticRegistry.ts +0 -386
  1134. package/src/services/lsp/LSPServerInstance.ts +0 -511
  1135. package/src/services/lsp/LSPServerManager.ts +0 -420
  1136. package/src/services/lsp/config.ts +0 -79
  1137. package/src/services/lsp/manager.ts +0 -289
  1138. package/src/services/lsp/passiveFeedback.ts +0 -328
  1139. package/src/services/lsp/types.ts +0 -3
  1140. package/src/services/mcp/InProcessTransport.ts +0 -63
  1141. package/src/services/mcp/MCPConnectionManager.tsx +0 -73
  1142. package/src/services/mcp/SdkControlTransport.ts +0 -136
  1143. package/src/services/mcp/auth.ts +0 -2465
  1144. package/src/services/mcp/channelAllowlist.ts +0 -76
  1145. package/src/services/mcp/channelNotification.ts +0 -316
  1146. package/src/services/mcp/channelPermissions.ts +0 -240
  1147. package/src/services/mcp/claudeai.ts +0 -164
  1148. package/src/services/mcp/client.ts +0 -3348
  1149. package/src/services/mcp/config.ts +0 -1578
  1150. package/src/services/mcp/elicitationHandler.ts +0 -313
  1151. package/src/services/mcp/envExpansion.ts +0 -38
  1152. package/src/services/mcp/headersHelper.ts +0 -138
  1153. package/src/services/mcp/mcpStringUtils.ts +0 -106
  1154. package/src/services/mcp/normalization.ts +0 -23
  1155. package/src/services/mcp/oauthPort.ts +0 -78
  1156. package/src/services/mcp/officialRegistry.ts +0 -72
  1157. package/src/services/mcp/types.ts +0 -258
  1158. package/src/services/mcp/useManageMCPConnections.ts +0 -1141
  1159. package/src/services/mcp/utils.ts +0 -575
  1160. package/src/services/mcp/vscodeSdkMcp.ts +0 -112
  1161. package/src/services/mcp/xaa.ts +0 -511
  1162. package/src/services/mcp/xaaIdpLogin.ts +0 -487
  1163. package/src/services/mcpServerApproval.tsx +0 -41
  1164. package/src/services/mockRateLimits.ts +0 -882
  1165. package/src/services/notifier.ts +0 -156
  1166. package/src/services/oauth/auth-code-listener.ts +0 -211
  1167. package/src/services/oauth/client.ts +0 -566
  1168. package/src/services/oauth/crypto.ts +0 -23
  1169. package/src/services/oauth/getOauthProfile.ts +0 -53
  1170. package/src/services/oauth/index.ts +0 -198
  1171. package/src/services/oauth/types.ts +0 -7
  1172. package/src/services/plugins/PluginInstallationManager.ts +0 -184
  1173. package/src/services/plugins/pluginCliCommands.ts +0 -344
  1174. package/src/services/plugins/pluginOperations.ts +0 -1088
  1175. package/src/services/policyLimits/index.ts +0 -663
  1176. package/src/services/policyLimits/types.ts +0 -27
  1177. package/src/services/preventSleep.ts +0 -165
  1178. package/src/services/rateLimitMessages.ts +0 -344
  1179. package/src/services/rateLimitMocking.ts +0 -144
  1180. package/src/services/remoteManagedSettings/index.ts +0 -638
  1181. package/src/services/remoteManagedSettings/securityCheck.tsx +0 -74
  1182. package/src/services/remoteManagedSettings/syncCache.ts +0 -112
  1183. package/src/services/remoteManagedSettings/syncCacheState.ts +0 -96
  1184. package/src/services/remoteManagedSettings/types.ts +0 -31
  1185. package/src/services/sessionTranscript/sessionTranscript.ts +0 -2
  1186. package/src/services/settingsSync/index.ts +0 -581
  1187. package/src/services/settingsSync/types.ts +0 -67
  1188. package/src/services/skillSearch/featureCheck.ts +0 -2
  1189. package/src/services/skillSearch/localSearch.ts +0 -2
  1190. package/src/services/skillSearch/prefetch.ts +0 -2
  1191. package/src/services/skillSearch/remoteSkillLoader.ts +0 -2
  1192. package/src/services/skillSearch/remoteSkillState.ts +0 -2
  1193. package/src/services/skillSearch/signals.ts +0 -1
  1194. package/src/services/skillSearch/telemetry.ts +0 -2
  1195. package/src/services/teamMemorySync/index.ts +0 -1256
  1196. package/src/services/teamMemorySync/secretScanner.ts +0 -324
  1197. package/src/services/teamMemorySync/teamMemSecretGuard.ts +0 -44
  1198. package/src/services/teamMemorySync/types.ts +0 -156
  1199. package/src/services/teamMemorySync/watcher.ts +0 -387
  1200. package/src/services/tips/tipHistory.ts +0 -17
  1201. package/src/services/tips/tipRegistry.ts +0 -686
  1202. package/src/services/tips/tipScheduler.ts +0 -58
  1203. package/src/services/tips/types.ts +0 -5
  1204. package/src/services/tokenEstimation.ts +0 -495
  1205. package/src/services/toolUseSummary/toolUseSummaryGenerator.ts +0 -112
  1206. package/src/services/tools/StreamingToolExecutor.ts +0 -530
  1207. package/src/services/tools/toolExecution.ts +0 -1745
  1208. package/src/services/tools/toolHooks.ts +0 -650
  1209. package/src/services/tools/toolOrchestration.ts +0 -188
  1210. package/src/services/vcr.ts +0 -406
  1211. package/src/services/voice.ts +0 -525
  1212. package/src/services/voiceKeyterms.ts +0 -106
  1213. package/src/services/voiceStreamSTT.ts +0 -544
  1214. package/src/setup.ts +0 -477
  1215. package/src/shims/bun-bundle.ts +0 -18
  1216. package/src/shims/macro.ts +0 -12
  1217. package/src/skills/bundled/batch.ts +0 -124
  1218. package/src/skills/bundled/claude-api/SKILL.md +0 -1
  1219. package/src/skills/bundled/claude-api/SKILL.md.ts +0 -1
  1220. package/src/skills/bundled/claude-api/csharp/claude-api.md +0 -1
  1221. package/src/skills/bundled/claude-api/csharp/claude-api.md.ts +0 -1
  1222. package/src/skills/bundled/claude-api/curl/examples.md +0 -1
  1223. package/src/skills/bundled/claude-api/curl/examples.md.ts +0 -1
  1224. package/src/skills/bundled/claude-api/go/claude-api.md +0 -1
  1225. package/src/skills/bundled/claude-api/go/claude-api.md.ts +0 -1
  1226. package/src/skills/bundled/claude-api/java/claude-api.md +0 -1
  1227. package/src/skills/bundled/claude-api/java/claude-api.md.ts +0 -1
  1228. package/src/skills/bundled/claude-api/php/claude-api.md +0 -1
  1229. package/src/skills/bundled/claude-api/php/claude-api.md.ts +0 -1
  1230. package/src/skills/bundled/claude-api/python/agent-sdk/README.md +0 -1
  1231. package/src/skills/bundled/claude-api/python/agent-sdk/README.md.ts +0 -1
  1232. package/src/skills/bundled/claude-api/python/agent-sdk/patterns.md +0 -1
  1233. package/src/skills/bundled/claude-api/python/agent-sdk/patterns.md.ts +0 -1
  1234. package/src/skills/bundled/claude-api/python/claude-api/README.md +0 -1
  1235. package/src/skills/bundled/claude-api/python/claude-api/README.md.ts +0 -1
  1236. package/src/skills/bundled/claude-api/python/claude-api/batches.md +0 -1
  1237. package/src/skills/bundled/claude-api/python/claude-api/batches.md.ts +0 -1
  1238. package/src/skills/bundled/claude-api/python/claude-api/files-api.md +0 -1
  1239. package/src/skills/bundled/claude-api/python/claude-api/files-api.md.ts +0 -1
  1240. package/src/skills/bundled/claude-api/python/claude-api/streaming.md +0 -1
  1241. package/src/skills/bundled/claude-api/python/claude-api/streaming.md.ts +0 -1
  1242. package/src/skills/bundled/claude-api/python/claude-api/tool-use.md +0 -1
  1243. package/src/skills/bundled/claude-api/python/claude-api/tool-use.md.ts +0 -1
  1244. package/src/skills/bundled/claude-api/ruby/claude-api.md +0 -1
  1245. package/src/skills/bundled/claude-api/ruby/claude-api.md.ts +0 -1
  1246. package/src/skills/bundled/claude-api/shared/error-codes.md +0 -1
  1247. package/src/skills/bundled/claude-api/shared/error-codes.md.ts +0 -1
  1248. package/src/skills/bundled/claude-api/shared/live-sources.md +0 -1
  1249. package/src/skills/bundled/claude-api/shared/live-sources.md.ts +0 -1
  1250. package/src/skills/bundled/claude-api/shared/models.md +0 -1
  1251. package/src/skills/bundled/claude-api/shared/models.md.ts +0 -1
  1252. package/src/skills/bundled/claude-api/shared/prompt-caching.md +0 -1
  1253. package/src/skills/bundled/claude-api/shared/prompt-caching.md.ts +0 -1
  1254. package/src/skills/bundled/claude-api/shared/tool-use-concepts.md +0 -1
  1255. package/src/skills/bundled/claude-api/shared/tool-use-concepts.md.ts +0 -1
  1256. package/src/skills/bundled/claude-api/typescript/agent-sdk/README.md +0 -1
  1257. package/src/skills/bundled/claude-api/typescript/agent-sdk/README.md.ts +0 -1
  1258. package/src/skills/bundled/claude-api/typescript/agent-sdk/patterns.md +0 -1
  1259. package/src/skills/bundled/claude-api/typescript/agent-sdk/patterns.md.ts +0 -1
  1260. package/src/skills/bundled/claude-api/typescript/claude-api/README.md +0 -1
  1261. package/src/skills/bundled/claude-api/typescript/claude-api/README.md.ts +0 -1
  1262. package/src/skills/bundled/claude-api/typescript/claude-api/batches.md +0 -1
  1263. package/src/skills/bundled/claude-api/typescript/claude-api/batches.md.ts +0 -1
  1264. package/src/skills/bundled/claude-api/typescript/claude-api/files-api.md +0 -1
  1265. package/src/skills/bundled/claude-api/typescript/claude-api/files-api.md.ts +0 -1
  1266. package/src/skills/bundled/claude-api/typescript/claude-api/streaming.md +0 -1
  1267. package/src/skills/bundled/claude-api/typescript/claude-api/streaming.md.ts +0 -1
  1268. package/src/skills/bundled/claude-api/typescript/claude-api/tool-use.md +0 -1
  1269. package/src/skills/bundled/claude-api/typescript/claude-api/tool-use.md.ts +0 -1
  1270. package/src/skills/bundled/claudeApi.ts +0 -196
  1271. package/src/skills/bundled/claudeApiContent.ts +0 -75
  1272. package/src/skills/bundled/claudeInChrome.ts +0 -34
  1273. package/src/skills/bundled/debug.ts +0 -103
  1274. package/src/skills/bundled/dream.ts +0 -1
  1275. package/src/skills/bundled/hunter.ts +0 -1
  1276. package/src/skills/bundled/index.ts +0 -79
  1277. package/src/skills/bundled/keybindings.ts +0 -339
  1278. package/src/skills/bundled/loop.ts +0 -92
  1279. package/src/skills/bundled/loremIpsum.ts +0 -282
  1280. package/src/skills/bundled/remember.ts +0 -82
  1281. package/src/skills/bundled/runSkillGenerator.ts +0 -1
  1282. package/src/skills/bundled/scheduleRemoteAgents.ts +0 -447
  1283. package/src/skills/bundled/simplify.ts +0 -69
  1284. package/src/skills/bundled/skillify.ts +0 -197
  1285. package/src/skills/bundled/stuck.ts +0 -79
  1286. package/src/skills/bundled/updateConfig.ts +0 -475
  1287. package/src/skills/bundled/verify/SKILL.md +0 -1
  1288. package/src/skills/bundled/verify/SKILL.md.ts +0 -1
  1289. package/src/skills/bundled/verify/examples/cli.md +0 -1
  1290. package/src/skills/bundled/verify/examples/cli.md.ts +0 -1
  1291. package/src/skills/bundled/verify/examples/server.md +0 -1
  1292. package/src/skills/bundled/verify/examples/server.md.ts +0 -1
  1293. package/src/skills/bundled/verify.ts +0 -30
  1294. package/src/skills/bundled/verifyContent.ts +0 -13
  1295. package/src/skills/bundledSkills.ts +0 -220
  1296. package/src/skills/loadSkillsDir.ts +0 -1086
  1297. package/src/skills/mcpSkillBuilders.ts +0 -44
  1298. package/src/skills/mcpSkills.ts +0 -2
  1299. package/src/ssh/SSHSessionManager.ts +0 -1
  1300. package/src/ssh/createSSHSession.ts +0 -1
  1301. package/src/state/AppState.tsx +0 -200
  1302. package/src/state/AppStateStore.ts +0 -569
  1303. package/src/state/onChangeAppState.ts +0 -171
  1304. package/src/state/selectors.ts +0 -76
  1305. package/src/state/store.ts +0 -34
  1306. package/src/state/teammateViewHelpers.ts +0 -141
  1307. package/src/tasks/DreamTask/DreamTask.ts +0 -157
  1308. package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.tsx +0 -126
  1309. package/src/tasks/InProcessTeammateTask/types.ts +0 -121
  1310. package/src/tasks/LocalAgentTask/LocalAgentTask.tsx +0 -683
  1311. package/src/tasks/LocalMainSessionTask.ts +0 -479
  1312. package/src/tasks/LocalShellTask/LocalShellTask.tsx +0 -523
  1313. package/src/tasks/LocalShellTask/guards.ts +0 -41
  1314. package/src/tasks/LocalShellTask/killShellTasks.ts +0 -76
  1315. package/src/tasks/LocalWorkflowTask/LocalWorkflowTask.ts +0 -1
  1316. package/src/tasks/MonitorMcpTask/MonitorMcpTask.ts +0 -1
  1317. package/src/tasks/RemoteAgentTask/RemoteAgentTask.tsx +0 -856
  1318. package/src/tasks/pillLabel.ts +0 -82
  1319. package/src/tasks/stopTask.ts +0 -100
  1320. package/src/tasks/types.ts +0 -46
  1321. package/src/tasks.ts +0 -39
  1322. package/src/tools/AgentTool/AgentTool.tsx +0 -1398
  1323. package/src/tools/AgentTool/UI.tsx +0 -872
  1324. package/src/tools/AgentTool/agentColorManager.ts +0 -66
  1325. package/src/tools/AgentTool/agentDisplay.ts +0 -104
  1326. package/src/tools/AgentTool/agentMemory.ts +0 -177
  1327. package/src/tools/AgentTool/agentMemorySnapshot.ts +0 -197
  1328. package/src/tools/AgentTool/agentToolUtils.ts +0 -686
  1329. package/src/tools/AgentTool/built-in/claudeCodeGuideAgent.ts +0 -205
  1330. package/src/tools/AgentTool/built-in/exploreAgent.ts +0 -87
  1331. package/src/tools/AgentTool/built-in/generalPurposeAgent.ts +0 -34
  1332. package/src/tools/AgentTool/built-in/planAgent.ts +0 -92
  1333. package/src/tools/AgentTool/built-in/statuslineSetup.ts +0 -144
  1334. package/src/tools/AgentTool/built-in/verificationAgent.ts +0 -152
  1335. package/src/tools/AgentTool/built-in/warpGrepAgent.ts +0 -67
  1336. package/src/tools/AgentTool/builtInAgents.ts +0 -73
  1337. package/src/tools/AgentTool/constants.ts +0 -12
  1338. package/src/tools/AgentTool/forkSubagent.ts +0 -210
  1339. package/src/tools/AgentTool/loadAgentsDir.ts +0 -755
  1340. package/src/tools/AgentTool/prompt.ts +0 -288
  1341. package/src/tools/AgentTool/resumeAgent.ts +0 -265
  1342. package/src/tools/AgentTool/runAgent.ts +0 -973
  1343. package/src/tools/AskUserQuestionTool/AskUserQuestionTool.tsx +0 -266
  1344. package/src/tools/AskUserQuestionTool/prompt.ts +0 -44
  1345. package/src/tools/BashTool/BashTool.tsx +0 -1144
  1346. package/src/tools/BashTool/BashToolResultMessage.tsx +0 -191
  1347. package/src/tools/BashTool/UI.tsx +0 -185
  1348. package/src/tools/BashTool/bashCommandHelpers.ts +0 -265
  1349. package/src/tools/BashTool/bashPermissions.ts +0 -2621
  1350. package/src/tools/BashTool/bashSecurity.ts +0 -2592
  1351. package/src/tools/BashTool/commandSemantics.ts +0 -140
  1352. package/src/tools/BashTool/commentLabel.ts +0 -13
  1353. package/src/tools/BashTool/destructiveCommandWarning.ts +0 -102
  1354. package/src/tools/BashTool/modeValidation.ts +0 -115
  1355. package/src/tools/BashTool/pathValidation.ts +0 -1303
  1356. package/src/tools/BashTool/prompt.ts +0 -369
  1357. package/src/tools/BashTool/readOnlyValidation.ts +0 -1990
  1358. package/src/tools/BashTool/sedEditParser.ts +0 -322
  1359. package/src/tools/BashTool/sedValidation.ts +0 -684
  1360. package/src/tools/BashTool/shouldUseSandbox.ts +0 -153
  1361. package/src/tools/BashTool/toolName.ts +0 -2
  1362. package/src/tools/BashTool/utils.ts +0 -223
  1363. package/src/tools/BriefTool/BriefTool.ts +0 -204
  1364. package/src/tools/BriefTool/UI.tsx +0 -101
  1365. package/src/tools/BriefTool/attachments.ts +0 -110
  1366. package/src/tools/BriefTool/prompt.ts +0 -22
  1367. package/src/tools/BriefTool/upload.ts +0 -174
  1368. package/src/tools/ConfigTool/ConfigTool.ts +0 -467
  1369. package/src/tools/ConfigTool/UI.tsx +0 -38
  1370. package/src/tools/ConfigTool/constants.ts +0 -1
  1371. package/src/tools/ConfigTool/prompt.ts +0 -93
  1372. package/src/tools/ConfigTool/supportedSettings.ts +0 -211
  1373. package/src/tools/CtxInspectTool/CtxInspectTool.ts +0 -1
  1374. package/src/tools/DiscoverSkillsTool/prompt.ts +0 -2
  1375. package/src/tools/EnterPlanModeTool/EnterPlanModeTool.ts +0 -126
  1376. package/src/tools/EnterPlanModeTool/UI.tsx +0 -33
  1377. package/src/tools/EnterPlanModeTool/constants.ts +0 -1
  1378. package/src/tools/EnterPlanModeTool/prompt.ts +0 -170
  1379. package/src/tools/EnterWorktreeTool/EnterWorktreeTool.ts +0 -127
  1380. package/src/tools/EnterWorktreeTool/UI.tsx +0 -20
  1381. package/src/tools/EnterWorktreeTool/constants.ts +0 -1
  1382. package/src/tools/EnterWorktreeTool/prompt.ts +0 -30
  1383. package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.ts +0 -493
  1384. package/src/tools/ExitPlanModeTool/UI.tsx +0 -82
  1385. package/src/tools/ExitPlanModeTool/constants.ts +0 -2
  1386. package/src/tools/ExitPlanModeTool/prompt.ts +0 -29
  1387. package/src/tools/ExitWorktreeTool/ExitWorktreeTool.ts +0 -329
  1388. package/src/tools/ExitWorktreeTool/UI.tsx +0 -25
  1389. package/src/tools/ExitWorktreeTool/constants.ts +0 -1
  1390. package/src/tools/ExitWorktreeTool/prompt.ts +0 -32
  1391. package/src/tools/FileEditTool/FileEditTool.ts +0 -625
  1392. package/src/tools/FileEditTool/UI.tsx +0 -289
  1393. package/src/tools/FileEditTool/constants.ts +0 -11
  1394. package/src/tools/FileEditTool/prompt.ts +0 -28
  1395. package/src/tools/FileEditTool/types.ts +0 -85
  1396. package/src/tools/FileEditTool/utils.ts +0 -775
  1397. package/src/tools/FileReadTool/FileReadTool.ts +0 -1183
  1398. package/src/tools/FileReadTool/UI.tsx +0 -185
  1399. package/src/tools/FileReadTool/imageProcessor.ts +0 -94
  1400. package/src/tools/FileReadTool/limits.ts +0 -92
  1401. package/src/tools/FileReadTool/prompt.ts +0 -49
  1402. package/src/tools/FileWriteTool/FileWriteTool.ts +0 -434
  1403. package/src/tools/FileWriteTool/UI.tsx +0 -405
  1404. package/src/tools/FileWriteTool/prompt.ts +0 -18
  1405. package/src/tools/GlobTool/GlobTool.ts +0 -198
  1406. package/src/tools/GlobTool/UI.tsx +0 -63
  1407. package/src/tools/GlobTool/prompt.ts +0 -7
  1408. package/src/tools/GrepTool/GrepTool.ts +0 -577
  1409. package/src/tools/GrepTool/UI.tsx +0 -201
  1410. package/src/tools/GrepTool/prompt.ts +0 -18
  1411. package/src/tools/LSPTool/LSPTool.ts +0 -860
  1412. package/src/tools/LSPTool/UI.tsx +0 -228
  1413. package/src/tools/LSPTool/formatters.ts +0 -592
  1414. package/src/tools/LSPTool/prompt.ts +0 -21
  1415. package/src/tools/LSPTool/schemas.ts +0 -215
  1416. package/src/tools/LSPTool/symbolContext.ts +0 -90
  1417. package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.ts +0 -123
  1418. package/src/tools/ListMcpResourcesTool/UI.tsx +0 -29
  1419. package/src/tools/ListMcpResourcesTool/prompt.ts +0 -20
  1420. package/src/tools/ListPeersTool/ListPeersTool.ts +0 -1
  1421. package/src/tools/MCPTool/MCPTool.ts +0 -77
  1422. package/src/tools/MCPTool/UI.tsx +0 -403
  1423. package/src/tools/MCPTool/classifyForCollapse.ts +0 -604
  1424. package/src/tools/MCPTool/prompt.ts +0 -3
  1425. package/src/tools/McpAuthTool/McpAuthTool.ts +0 -215
  1426. package/src/tools/MonitorTool/MonitorTool.ts +0 -2
  1427. package/src/tools/NotebookEditTool/NotebookEditTool.ts +0 -490
  1428. package/src/tools/NotebookEditTool/UI.tsx +0 -93
  1429. package/src/tools/NotebookEditTool/constants.ts +0 -2
  1430. package/src/tools/NotebookEditTool/prompt.ts +0 -3
  1431. package/src/tools/OverflowTestTool/OverflowTestTool.ts +0 -2
  1432. package/src/tools/PowerShellTool/PowerShellTool.tsx +0 -1001
  1433. package/src/tools/PowerShellTool/UI.tsx +0 -131
  1434. package/src/tools/PowerShellTool/clmTypes.ts +0 -211
  1435. package/src/tools/PowerShellTool/commandSemantics.ts +0 -142
  1436. package/src/tools/PowerShellTool/commonParameters.ts +0 -30
  1437. package/src/tools/PowerShellTool/destructiveCommandWarning.ts +0 -109
  1438. package/src/tools/PowerShellTool/gitSafety.ts +0 -176
  1439. package/src/tools/PowerShellTool/modeValidation.ts +0 -404
  1440. package/src/tools/PowerShellTool/pathValidation.ts +0 -2049
  1441. package/src/tools/PowerShellTool/powershellPermissions.ts +0 -1648
  1442. package/src/tools/PowerShellTool/powershellSecurity.ts +0 -1090
  1443. package/src/tools/PowerShellTool/prompt.ts +0 -145
  1444. package/src/tools/PowerShellTool/readOnlyValidation.ts +0 -1823
  1445. package/src/tools/PowerShellTool/toolName.ts +0 -2
  1446. package/src/tools/PushNotificationTool/PushNotificationTool.ts +0 -1
  1447. package/src/tools/REPLTool/REPLTool.ts +0 -1
  1448. package/src/tools/REPLTool/constants.ts +0 -46
  1449. package/src/tools/REPLTool/primitiveTools.ts +0 -39
  1450. package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.ts +0 -158
  1451. package/src/tools/ReadMcpResourceTool/UI.tsx +0 -37
  1452. package/src/tools/ReadMcpResourceTool/prompt.ts +0 -16
  1453. package/src/tools/RemoteTriggerTool/RemoteTriggerTool.ts +0 -161
  1454. package/src/tools/RemoteTriggerTool/UI.tsx +0 -17
  1455. package/src/tools/RemoteTriggerTool/prompt.ts +0 -15
  1456. package/src/tools/ReviewArtifactTool/ReviewArtifactTool.ts +0 -2
  1457. package/src/tools/ScheduleCronTool/CronCreateTool.ts +0 -157
  1458. package/src/tools/ScheduleCronTool/CronDeleteTool.ts +0 -95
  1459. package/src/tools/ScheduleCronTool/CronListTool.ts +0 -97
  1460. package/src/tools/ScheduleCronTool/UI.tsx +0 -60
  1461. package/src/tools/ScheduleCronTool/prompt.ts +0 -135
  1462. package/src/tools/SendMessageTool/SendMessageTool.ts +0 -917
  1463. package/src/tools/SendMessageTool/UI.tsx +0 -31
  1464. package/src/tools/SendMessageTool/constants.ts +0 -1
  1465. package/src/tools/SendMessageTool/prompt.ts +0 -49
  1466. package/src/tools/SendUserFileTool/SendUserFileTool.ts +0 -1
  1467. package/src/tools/SendUserFileTool/prompt.ts +0 -2
  1468. package/src/tools/SkillTool/SkillTool.ts +0 -1108
  1469. package/src/tools/SkillTool/UI.tsx +0 -128
  1470. package/src/tools/SkillTool/constants.ts +0 -1
  1471. package/src/tools/SkillTool/prompt.ts +0 -241
  1472. package/src/tools/SleepTool/SleepTool.ts +0 -1
  1473. package/src/tools/SleepTool/prompt.ts +0 -17
  1474. package/src/tools/SnipTool/SnipTool.ts +0 -1
  1475. package/src/tools/SnipTool/prompt.ts +0 -2
  1476. package/src/tools/SubscribePRTool/SubscribePRTool.ts +0 -1
  1477. package/src/tools/SuggestBackgroundPRTool/SuggestBackgroundPRTool.ts +0 -1
  1478. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +0 -163
  1479. package/src/tools/TaskCreateTool/TaskCreateTool.ts +0 -138
  1480. package/src/tools/TaskCreateTool/constants.ts +0 -1
  1481. package/src/tools/TaskCreateTool/prompt.ts +0 -56
  1482. package/src/tools/TaskGetTool/TaskGetTool.ts +0 -128
  1483. package/src/tools/TaskGetTool/constants.ts +0 -1
  1484. package/src/tools/TaskGetTool/prompt.ts +0 -24
  1485. package/src/tools/TaskListTool/TaskListTool.ts +0 -116
  1486. package/src/tools/TaskListTool/constants.ts +0 -1
  1487. package/src/tools/TaskListTool/prompt.ts +0 -49
  1488. package/src/tools/TaskOutputTool/TaskOutputTool.tsx +0 -584
  1489. package/src/tools/TaskOutputTool/constants.ts +0 -1
  1490. package/src/tools/TaskStopTool/TaskStopTool.ts +0 -131
  1491. package/src/tools/TaskStopTool/UI.tsx +0 -41
  1492. package/src/tools/TaskStopTool/prompt.ts +0 -8
  1493. package/src/tools/TaskUpdateTool/TaskUpdateTool.ts +0 -406
  1494. package/src/tools/TaskUpdateTool/constants.ts +0 -1
  1495. package/src/tools/TaskUpdateTool/prompt.ts +0 -77
  1496. package/src/tools/TeamCreateTool/TeamCreateTool.ts +0 -240
  1497. package/src/tools/TeamCreateTool/UI.tsx +0 -6
  1498. package/src/tools/TeamCreateTool/constants.ts +0 -1
  1499. package/src/tools/TeamCreateTool/prompt.ts +0 -113
  1500. package/src/tools/TeamDeleteTool/TeamDeleteTool.ts +0 -139
  1501. package/src/tools/TeamDeleteTool/UI.tsx +0 -20
  1502. package/src/tools/TeamDeleteTool/constants.ts +0 -1
  1503. package/src/tools/TeamDeleteTool/prompt.ts +0 -16
  1504. package/src/tools/TerminalCaptureTool/TerminalCaptureTool.ts +0 -1
  1505. package/src/tools/TerminalCaptureTool/prompt.ts +0 -2
  1506. package/src/tools/TodoWriteTool/TodoWriteTool.ts +0 -115
  1507. package/src/tools/TodoWriteTool/constants.ts +0 -1
  1508. package/src/tools/TodoWriteTool/prompt.ts +0 -184
  1509. package/src/tools/ToolSearchTool/ToolSearchTool.ts +0 -471
  1510. package/src/tools/ToolSearchTool/constants.ts +0 -1
  1511. package/src/tools/ToolSearchTool/prompt.ts +0 -121
  1512. package/src/tools/TungstenTool/TungstenLiveMonitor.ts +0 -3
  1513. package/src/tools/TungstenTool/TungstenLiveMonitor.tsx +0 -6
  1514. package/src/tools/TungstenTool/TungstenTool.ts +0 -26
  1515. package/src/tools/VerifyPlanExecutionTool/VerifyPlanExecutionTool.ts +0 -1
  1516. package/src/tools/VerifyPlanExecutionTool/constants.ts +0 -2
  1517. package/src/tools/WarpGrepTool/WarpGrepTool.ts +0 -106
  1518. package/src/tools/WebBrowserTool/WebBrowserPanel.ts +0 -2
  1519. package/src/tools/WebBrowserTool/WebBrowserTool.ts +0 -1
  1520. package/src/tools/WebFetchTool/UI.tsx +0 -72
  1521. package/src/tools/WebFetchTool/WebFetchTool.ts +0 -318
  1522. package/src/tools/WebFetchTool/preapproved.ts +0 -166
  1523. package/src/tools/WebFetchTool/prompt.ts +0 -46
  1524. package/src/tools/WebFetchTool/utils.ts +0 -530
  1525. package/src/tools/WebSearchTool/UI.tsx +0 -101
  1526. package/src/tools/WebSearchTool/WebSearchTool.ts +0 -435
  1527. package/src/tools/WebSearchTool/prompt.ts +0 -34
  1528. package/src/tools/WorkflowTool/WorkflowPermissionRequest.ts +0 -2
  1529. package/src/tools/WorkflowTool/WorkflowTool.ts +0 -2
  1530. package/src/tools/WorkflowTool/bundled/index.ts +0 -1
  1531. package/src/tools/WorkflowTool/constants.ts +0 -1
  1532. package/src/tools/WorkflowTool/createWorkflowCommand.ts +0 -2
  1533. package/src/tools/shared/gitOperationTracking.ts +0 -277
  1534. package/src/tools/shared/spawnMultiAgent.ts +0 -1093
  1535. package/src/tools/testing/TestingPermissionTool.tsx +0 -74
  1536. package/src/tools/utils.ts +0 -40
  1537. package/src/tools.ts +0 -394
  1538. package/src/types/command.ts +0 -216
  1539. package/src/types/connectorText.ts +0 -3
  1540. package/src/types/declarations/bun-globals.d.ts +0 -19
  1541. package/src/types/declarations/external-modules.d.ts +0 -120
  1542. package/src/types/declarations/react-compiler.d.ts +0 -3
  1543. package/src/types/fileSuggestion.ts +0 -1
  1544. package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.ts +0 -865
  1545. package/src/types/generated/events_mono/common/v1/auth.ts +0 -100
  1546. package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.ts +0 -223
  1547. package/src/types/generated/google/protobuf/timestamp.ts +0 -187
  1548. package/src/types/hooks.ts +0 -290
  1549. package/src/types/ids.ts +0 -44
  1550. package/src/types/logs.ts +0 -330
  1551. package/src/types/message.ts +0 -40
  1552. package/src/types/messageQueueTypes.ts +0 -2
  1553. package/src/types/notebook.ts +0 -7
  1554. package/src/types/permissions.ts +0 -441
  1555. package/src/types/plugin.ts +0 -363
  1556. package/src/types/statusLine.ts +0 -1
  1557. package/src/types/textInputTypes.ts +0 -387
  1558. package/src/types/tools.ts +0 -11
  1559. package/src/types/utils.ts +0 -2
  1560. package/src/upstreamproxy/relay.ts +0 -455
  1561. package/src/upstreamproxy/upstreamproxy.ts +0 -285
  1562. package/src/utils/CircularBuffer.ts +0 -84
  1563. package/src/utils/Cursor.ts +0 -1530
  1564. package/src/utils/QueryGuard.ts +0 -121
  1565. package/src/utils/Shell.ts +0 -474
  1566. package/src/utils/ShellCommand.ts +0 -465
  1567. package/src/utils/abortController.ts +0 -99
  1568. package/src/utils/activityManager.ts +0 -164
  1569. package/src/utils/advisor.ts +0 -145
  1570. package/src/utils/agentContext.ts +0 -178
  1571. package/src/utils/agentId.ts +0 -99
  1572. package/src/utils/agentSwarmsEnabled.ts +0 -44
  1573. package/src/utils/agenticSessionSearch.ts +0 -307
  1574. package/src/utils/analyzeContext.ts +0 -1382
  1575. package/src/utils/ansiToPng.ts +0 -334
  1576. package/src/utils/ansiToSvg.ts +0 -272
  1577. package/src/utils/api.ts +0 -718
  1578. package/src/utils/apiPreconnect.ts +0 -71
  1579. package/src/utils/appleTerminalBackup.ts +0 -124
  1580. package/src/utils/argumentSubstitution.ts +0 -145
  1581. package/src/utils/array.ts +0 -13
  1582. package/src/utils/asciicast.ts +0 -239
  1583. package/src/utils/attachments.ts +0 -3997
  1584. package/src/utils/attribution.ts +0 -393
  1585. package/src/utils/attributionHooks.ts +0 -2
  1586. package/src/utils/attributionTrailer.ts +0 -2
  1587. package/src/utils/auth.ts +0 -2002
  1588. package/src/utils/authFileDescriptor.ts +0 -196
  1589. package/src/utils/authPortable.ts +0 -19
  1590. package/src/utils/autoModeDenials.ts +0 -26
  1591. package/src/utils/autoRunIssue.tsx +0 -122
  1592. package/src/utils/autoUpdater.ts +0 -561
  1593. package/src/utils/aws.ts +0 -74
  1594. package/src/utils/awsAuthStatusManager.ts +0 -81
  1595. package/src/utils/background/remote/preconditions.ts +0 -235
  1596. package/src/utils/background/remote/remoteSession.ts +0 -98
  1597. package/src/utils/backgroundHousekeeping.ts +0 -94
  1598. package/src/utils/bash/ParsedCommand.ts +0 -318
  1599. package/src/utils/bash/ShellSnapshot.ts +0 -582
  1600. package/src/utils/bash/ast.ts +0 -2679
  1601. package/src/utils/bash/bashParser.ts +0 -4436
  1602. package/src/utils/bash/bashPipeCommand.ts +0 -294
  1603. package/src/utils/bash/commands.ts +0 -1339
  1604. package/src/utils/bash/heredoc.ts +0 -733
  1605. package/src/utils/bash/parser.ts +0 -230
  1606. package/src/utils/bash/prefix.ts +0 -204
  1607. package/src/utils/bash/registry.ts +0 -53
  1608. package/src/utils/bash/shellCompletion.ts +0 -259
  1609. package/src/utils/bash/shellPrefix.ts +0 -28
  1610. package/src/utils/bash/shellQuote.ts +0 -304
  1611. package/src/utils/bash/shellQuoting.ts +0 -128
  1612. package/src/utils/bash/specs/alias.ts +0 -14
  1613. package/src/utils/bash/specs/index.ts +0 -18
  1614. package/src/utils/bash/specs/nohup.ts +0 -13
  1615. package/src/utils/bash/specs/pyright.ts +0 -91
  1616. package/src/utils/bash/specs/sleep.ts +0 -13
  1617. package/src/utils/bash/specs/srun.ts +0 -31
  1618. package/src/utils/bash/specs/time.ts +0 -13
  1619. package/src/utils/bash/specs/timeout.ts +0 -20
  1620. package/src/utils/bash/treeSitterAnalysis.ts +0 -506
  1621. package/src/utils/betas.ts +0 -434
  1622. package/src/utils/billing.ts +0 -78
  1623. package/src/utils/binaryCheck.ts +0 -53
  1624. package/src/utils/browser.ts +0 -68
  1625. package/src/utils/bufferedWriter.ts +0 -100
  1626. package/src/utils/bundledMode.ts +0 -22
  1627. package/src/utils/caCerts.ts +0 -115
  1628. package/src/utils/caCertsConfig.ts +0 -88
  1629. package/src/utils/cachePaths.ts +0 -38
  1630. package/src/utils/ccshareResume.ts +0 -2
  1631. package/src/utils/classifierApprovals.ts +0 -88
  1632. package/src/utils/classifierApprovalsHook.ts +0 -17
  1633. package/src/utils/claudeCodeHints.ts +0 -193
  1634. package/src/utils/claudeDesktop.ts +0 -152
  1635. package/src/utils/claudeInChrome/chromeNativeHost.ts +0 -527
  1636. package/src/utils/claudeInChrome/common.ts +0 -540
  1637. package/src/utils/claudeInChrome/mcpServer.ts +0 -293
  1638. package/src/utils/claudeInChrome/prompt.ts +0 -83
  1639. package/src/utils/claudeInChrome/setup.ts +0 -400
  1640. package/src/utils/claudeInChrome/setupPortable.ts +0 -233
  1641. package/src/utils/claudeInChrome/toolRendering.tsx +0 -262
  1642. package/src/utils/claudemd.ts +0 -1479
  1643. package/src/utils/cleanup.ts +0 -602
  1644. package/src/utils/cleanupRegistry.ts +0 -25
  1645. package/src/utils/cliArgs.ts +0 -60
  1646. package/src/utils/cliHighlight.ts +0 -54
  1647. package/src/utils/codeIndexing.ts +0 -206
  1648. package/src/utils/collapseBackgroundBashNotifications.ts +0 -84
  1649. package/src/utils/collapseHookSummaries.ts +0 -59
  1650. package/src/utils/collapseReadSearch.ts +0 -1109
  1651. package/src/utils/collapseTeammateShutdowns.ts +0 -55
  1652. package/src/utils/combinedAbortSignal.ts +0 -47
  1653. package/src/utils/commandLifecycle.ts +0 -21
  1654. package/src/utils/commitAttribution.ts +0 -961
  1655. package/src/utils/completionCache.ts +0 -166
  1656. package/src/utils/computerUse/appNames.ts +0 -196
  1657. package/src/utils/computerUse/cleanup.ts +0 -86
  1658. package/src/utils/computerUse/common.ts +0 -61
  1659. package/src/utils/computerUse/computerUseLock.ts +0 -215
  1660. package/src/utils/computerUse/drainRunLoop.ts +0 -79
  1661. package/src/utils/computerUse/escHotkey.ts +0 -54
  1662. package/src/utils/computerUse/executor.ts +0 -658
  1663. package/src/utils/computerUse/gates.ts +0 -72
  1664. package/src/utils/computerUse/hostAdapter.ts +0 -69
  1665. package/src/utils/computerUse/inputLoader.ts +0 -30
  1666. package/src/utils/computerUse/mcpServer.ts +0 -106
  1667. package/src/utils/computerUse/setup.ts +0 -53
  1668. package/src/utils/computerUse/swiftLoader.ts +0 -23
  1669. package/src/utils/computerUse/toolRendering.tsx +0 -125
  1670. package/src/utils/computerUse/wrapper.tsx +0 -336
  1671. package/src/utils/concurrentSessions.ts +0 -204
  1672. package/src/utils/config.ts +0 -1817
  1673. package/src/utils/configConstants.ts +0 -21
  1674. package/src/utils/contentArray.ts +0 -51
  1675. package/src/utils/context.ts +0 -221
  1676. package/src/utils/contextAnalysis.ts +0 -272
  1677. package/src/utils/contextSuggestions.ts +0 -235
  1678. package/src/utils/controlMessageCompat.ts +0 -32
  1679. package/src/utils/conversationRecovery.ts +0 -597
  1680. package/src/utils/cron.ts +0 -308
  1681. package/src/utils/cronJitterConfig.ts +0 -75
  1682. package/src/utils/cronScheduler.ts +0 -565
  1683. package/src/utils/cronTasks.ts +0 -458
  1684. package/src/utils/cronTasksLock.ts +0 -195
  1685. package/src/utils/crossProjectResume.ts +0 -75
  1686. package/src/utils/crypto.ts +0 -13
  1687. package/src/utils/cwd.ts +0 -32
  1688. package/src/utils/debug.ts +0 -268
  1689. package/src/utils/debugFilter.ts +0 -157
  1690. package/src/utils/deepLink/banner.ts +0 -123
  1691. package/src/utils/deepLink/parseDeepLink.ts +0 -170
  1692. package/src/utils/deepLink/protocolHandler.ts +0 -136
  1693. package/src/utils/deepLink/registerProtocol.ts +0 -348
  1694. package/src/utils/deepLink/terminalLauncher.ts +0 -557
  1695. package/src/utils/deepLink/terminalPreference.ts +0 -54
  1696. package/src/utils/desktopDeepLink.ts +0 -236
  1697. package/src/utils/detectRepository.ts +0 -178
  1698. package/src/utils/diagLogs.ts +0 -94
  1699. package/src/utils/diff.ts +0 -177
  1700. package/src/utils/directMemberMessage.ts +0 -69
  1701. package/src/utils/displayTags.ts +0 -51
  1702. package/src/utils/doctorContextWarnings.ts +0 -265
  1703. package/src/utils/doctorDiagnostic.ts +0 -625
  1704. package/src/utils/dxt/helpers.ts +0 -88
  1705. package/src/utils/dxt/zip.ts +0 -226
  1706. package/src/utils/earlyInput.ts +0 -191
  1707. package/src/utils/editor.ts +0 -183
  1708. package/src/utils/effort.ts +0 -329
  1709. package/src/utils/embeddedTools.ts +0 -29
  1710. package/src/utils/env.ts +0 -347
  1711. package/src/utils/envDynamic.ts +0 -151
  1712. package/src/utils/envUtils.ts +0 -183
  1713. package/src/utils/envValidation.ts +0 -38
  1714. package/src/utils/errorLogSink.ts +0 -235
  1715. package/src/utils/errors.ts +0 -238
  1716. package/src/utils/eventLoopStallDetector.ts +0 -2
  1717. package/src/utils/exampleCommands.ts +0 -184
  1718. package/src/utils/execFileNoThrow.ts +0 -150
  1719. package/src/utils/execFileNoThrowPortable.ts +0 -89
  1720. package/src/utils/execSyncWrapper.ts +0 -38
  1721. package/src/utils/exportRenderer.tsx +0 -98
  1722. package/src/utils/extraUsage.ts +0 -23
  1723. package/src/utils/fastMode.ts +0 -532
  1724. package/src/utils/file.ts +0 -584
  1725. package/src/utils/fileHistory.ts +0 -1115
  1726. package/src/utils/fileOperationAnalytics.ts +0 -71
  1727. package/src/utils/filePersistence/filePersistence.ts +0 -287
  1728. package/src/utils/filePersistence/outputsScanner.ts +0 -126
  1729. package/src/utils/filePersistence/types.ts +0 -33
  1730. package/src/utils/fileRead.ts +0 -102
  1731. package/src/utils/fileReadCache.ts +0 -96
  1732. package/src/utils/fileStateCache.ts +0 -142
  1733. package/src/utils/findExecutable.ts +0 -17
  1734. package/src/utils/fingerprint.ts +0 -76
  1735. package/src/utils/forkedAgent.ts +0 -689
  1736. package/src/utils/format.ts +0 -308
  1737. package/src/utils/formatBriefTimestamp.ts +0 -81
  1738. package/src/utils/fpsTracker.ts +0 -47
  1739. package/src/utils/frontmatterParser.ts +0 -370
  1740. package/src/utils/fsOperations.ts +0 -770
  1741. package/src/utils/fullscreen.ts +0 -202
  1742. package/src/utils/generatedFiles.ts +0 -136
  1743. package/src/utils/generators.ts +0 -88
  1744. package/src/utils/genericProcessUtils.ts +0 -184
  1745. package/src/utils/getWorktreePaths.ts +0 -70
  1746. package/src/utils/getWorktreePathsPortable.ts +0 -27
  1747. package/src/utils/ghPrStatus.ts +0 -106
  1748. package/src/utils/git/gitConfigParser.ts +0 -277
  1749. package/src/utils/git/gitFilesystem.ts +0 -699
  1750. package/src/utils/git/gitignore.ts +0 -99
  1751. package/src/utils/git.ts +0 -926
  1752. package/src/utils/gitDiff.ts +0 -532
  1753. package/src/utils/gitSettings.ts +0 -18
  1754. package/src/utils/github/ghAuthStatus.ts +0 -29
  1755. package/src/utils/githubRepoPathMapping.ts +0 -162
  1756. package/src/utils/glob.ts +0 -130
  1757. package/src/utils/gracefulShutdown.ts +0 -529
  1758. package/src/utils/groupToolUses.ts +0 -182
  1759. package/src/utils/handlePromptSubmit.ts +0 -610
  1760. package/src/utils/hash.ts +0 -46
  1761. package/src/utils/headlessProfiler.ts +0 -178
  1762. package/src/utils/heapDumpService.ts +0 -303
  1763. package/src/utils/heatmap.ts +0 -198
  1764. package/src/utils/highlightMatch.tsx +0 -28
  1765. package/src/utils/hooks/AsyncHookRegistry.ts +0 -309
  1766. package/src/utils/hooks/apiQueryHookHelper.ts +0 -141
  1767. package/src/utils/hooks/execAgentHook.ts +0 -339
  1768. package/src/utils/hooks/execHttpHook.ts +0 -242
  1769. package/src/utils/hooks/execPromptHook.ts +0 -211
  1770. package/src/utils/hooks/fileChangedWatcher.ts +0 -191
  1771. package/src/utils/hooks/hookEvents.ts +0 -192
  1772. package/src/utils/hooks/hookHelpers.ts +0 -83
  1773. package/src/utils/hooks/hooksConfigManager.ts +0 -400
  1774. package/src/utils/hooks/hooksConfigSnapshot.ts +0 -133
  1775. package/src/utils/hooks/hooksSettings.ts +0 -271
  1776. package/src/utils/hooks/postSamplingHooks.ts +0 -70
  1777. package/src/utils/hooks/registerFrontmatterHooks.ts +0 -67
  1778. package/src/utils/hooks/registerSkillHooks.ts +0 -64
  1779. package/src/utils/hooks/sessionHooks.ts +0 -447
  1780. package/src/utils/hooks/skillImprovement.ts +0 -267
  1781. package/src/utils/hooks/ssrfGuard.ts +0 -294
  1782. package/src/utils/hooks.ts +0 -5022
  1783. package/src/utils/horizontalScroll.ts +0 -137
  1784. package/src/utils/http.ts +0 -136
  1785. package/src/utils/hyperlink.ts +0 -39
  1786. package/src/utils/iTermBackup.ts +0 -73
  1787. package/src/utils/ide.ts +0 -1494
  1788. package/src/utils/idePathConversion.ts +0 -90
  1789. package/src/utils/idleTimeout.ts +0 -53
  1790. package/src/utils/imagePaste.ts +0 -416
  1791. package/src/utils/imageResizer.ts +0 -880
  1792. package/src/utils/imageStore.ts +0 -167
  1793. package/src/utils/imageValidation.ts +0 -104
  1794. package/src/utils/immediateCommand.ts +0 -15
  1795. package/src/utils/inProcessTeammateHelpers.ts +0 -102
  1796. package/src/utils/ink.ts +0 -26
  1797. package/src/utils/intl.ts +0 -94
  1798. package/src/utils/jetbrains.ts +0 -191
  1799. package/src/utils/json.ts +0 -277
  1800. package/src/utils/jsonRead.ts +0 -16
  1801. package/src/utils/keyboardShortcuts.ts +0 -14
  1802. package/src/utils/lazySchema.ts +0 -8
  1803. package/src/utils/listSessionsImpl.ts +0 -454
  1804. package/src/utils/localInstaller.ts +0 -162
  1805. package/src/utils/lockfile.ts +0 -43
  1806. package/src/utils/log.ts +0 -362
  1807. package/src/utils/logoV2Utils.ts +0 -350
  1808. package/src/utils/mailbox.ts +0 -73
  1809. package/src/utils/managedEnv.ts +0 -199
  1810. package/src/utils/managedEnvConstants.ts +0 -191
  1811. package/src/utils/markdown.ts +0 -381
  1812. package/src/utils/markdownConfigLoader.ts +0 -600
  1813. package/src/utils/mcp/dateTimeParser.ts +0 -121
  1814. package/src/utils/mcp/elicitationValidation.ts +0 -336
  1815. package/src/utils/mcpInstructionsDelta.ts +0 -130
  1816. package/src/utils/mcpOutputStorage.ts +0 -189
  1817. package/src/utils/mcpValidation.ts +0 -208
  1818. package/src/utils/mcpWebSocketTransport.ts +0 -200
  1819. package/src/utils/memoize.ts +0 -269
  1820. package/src/utils/memory/types.ts +0 -12
  1821. package/src/utils/memory/versions.ts +0 -8
  1822. package/src/utils/memoryFileDetection.ts +0 -289
  1823. package/src/utils/messagePredicates.ts +0 -8
  1824. package/src/utils/messageQueueManager.ts +0 -547
  1825. package/src/utils/messages/mappers.ts +0 -290
  1826. package/src/utils/messages/systemInit.ts +0 -96
  1827. package/src/utils/messages.ts +0 -5512
  1828. package/src/utils/model/agent.ts +0 -157
  1829. package/src/utils/model/aliases.ts +0 -25
  1830. package/src/utils/model/antModels.ts +0 -64
  1831. package/src/utils/model/bedrock.ts +0 -265
  1832. package/src/utils/model/check1mAccess.ts +0 -72
  1833. package/src/utils/model/configs.ts +0 -118
  1834. package/src/utils/model/contextWindowUpgradeCheck.ts +0 -47
  1835. package/src/utils/model/deprecation.ts +0 -101
  1836. package/src/utils/model/model.ts +0 -618
  1837. package/src/utils/model/modelAllowlist.ts +0 -170
  1838. package/src/utils/model/modelCapabilities.ts +0 -118
  1839. package/src/utils/model/modelOptions.ts +0 -540
  1840. package/src/utils/model/modelStrings.ts +0 -166
  1841. package/src/utils/model/modelSupportOverrides.ts +0 -50
  1842. package/src/utils/model/providers.ts +0 -40
  1843. package/src/utils/model/validateModel.ts +0 -159
  1844. package/src/utils/modelCost.ts +0 -231
  1845. package/src/utils/modifiers.ts +0 -41
  1846. package/src/utils/mtls.ts +0 -179
  1847. package/src/utils/nativeInstaller/download.ts +0 -523
  1848. package/src/utils/nativeInstaller/index.ts +0 -18
  1849. package/src/utils/nativeInstaller/installer.ts +0 -1708
  1850. package/src/utils/nativeInstaller/packageManagers.ts +0 -336
  1851. package/src/utils/nativeInstaller/pidLock.ts +0 -433
  1852. package/src/utils/notebook.ts +0 -224
  1853. package/src/utils/objectGroupBy.ts +0 -18
  1854. package/src/utils/pasteStore.ts +0 -104
  1855. package/src/utils/path.ts +0 -155
  1856. package/src/utils/pdf.ts +0 -300
  1857. package/src/utils/pdfUtils.ts +0 -70
  1858. package/src/utils/peerAddress.ts +0 -21
  1859. package/src/utils/permissions/PermissionMode.ts +0 -141
  1860. package/src/utils/permissions/PermissionPromptToolResultSchema.ts +0 -127
  1861. package/src/utils/permissions/PermissionResult.ts +0 -35
  1862. package/src/utils/permissions/PermissionRule.ts +0 -40
  1863. package/src/utils/permissions/PermissionUpdate.ts +0 -389
  1864. package/src/utils/permissions/PermissionUpdateSchema.ts +0 -78
  1865. package/src/utils/permissions/autoModeState.ts +0 -39
  1866. package/src/utils/permissions/bashClassifier.ts +0 -61
  1867. package/src/utils/permissions/bypassPermissionsKillswitch.ts +0 -155
  1868. package/src/utils/permissions/classifierDecision.ts +0 -98
  1869. package/src/utils/permissions/classifierShared.ts +0 -39
  1870. package/src/utils/permissions/dangerousPatterns.ts +0 -80
  1871. package/src/utils/permissions/denialTracking.ts +0 -45
  1872. package/src/utils/permissions/filesystem.ts +0 -1777
  1873. package/src/utils/permissions/getNextPermissionMode.ts +0 -101
  1874. package/src/utils/permissions/pathValidation.ts +0 -485
  1875. package/src/utils/permissions/permissionExplainer.ts +0 -250
  1876. package/src/utils/permissions/permissionRuleParser.ts +0 -198
  1877. package/src/utils/permissions/permissionSetup.ts +0 -1532
  1878. package/src/utils/permissions/permissions.ts +0 -1486
  1879. package/src/utils/permissions/permissionsLoader.ts +0 -296
  1880. package/src/utils/permissions/shadowedRuleDetection.ts +0 -234
  1881. package/src/utils/permissions/shellRuleMatching.ts +0 -228
  1882. package/src/utils/permissions/yolo-classifier-prompts/auto_mode_system_prompt.txt +0 -1
  1883. package/src/utils/permissions/yolo-classifier-prompts/permissions_anthropic.txt +0 -1
  1884. package/src/utils/permissions/yolo-classifier-prompts/permissions_external.txt +0 -1
  1885. package/src/utils/permissions/yoloClassifier.ts +0 -1495
  1886. package/src/utils/planModeV2.ts +0 -95
  1887. package/src/utils/plans.ts +0 -397
  1888. package/src/utils/platform.ts +0 -150
  1889. package/src/utils/plugins/addDirPluginSettings.ts +0 -71
  1890. package/src/utils/plugins/cacheUtils.ts +0 -196
  1891. package/src/utils/plugins/dependencyResolver.ts +0 -305
  1892. package/src/utils/plugins/fetchTelemetry.ts +0 -135
  1893. package/src/utils/plugins/gitAvailability.ts +0 -69
  1894. package/src/utils/plugins/headlessPluginInstall.ts +0 -174
  1895. package/src/utils/plugins/hintRecommendation.ts +0 -164
  1896. package/src/utils/plugins/installCounts.ts +0 -292
  1897. package/src/utils/plugins/installedPluginsManager.ts +0 -1268
  1898. package/src/utils/plugins/loadPluginAgents.ts +0 -348
  1899. package/src/utils/plugins/loadPluginCommands.ts +0 -946
  1900. package/src/utils/plugins/loadPluginHooks.ts +0 -287
  1901. package/src/utils/plugins/loadPluginOutputStyles.ts +0 -178
  1902. package/src/utils/plugins/lspPluginIntegration.ts +0 -387
  1903. package/src/utils/plugins/lspRecommendation.ts +0 -374
  1904. package/src/utils/plugins/managedPlugins.ts +0 -27
  1905. package/src/utils/plugins/marketplaceHelpers.ts +0 -592
  1906. package/src/utils/plugins/marketplaceManager.ts +0 -2643
  1907. package/src/utils/plugins/mcpPluginIntegration.ts +0 -634
  1908. package/src/utils/plugins/mcpbHandler.ts +0 -968
  1909. package/src/utils/plugins/officialMarketplace.ts +0 -25
  1910. package/src/utils/plugins/officialMarketplaceGcs.ts +0 -216
  1911. package/src/utils/plugins/officialMarketplaceStartupCheck.ts +0 -439
  1912. package/src/utils/plugins/orphanedPluginFilter.ts +0 -114
  1913. package/src/utils/plugins/parseMarketplaceInput.ts +0 -162
  1914. package/src/utils/plugins/performStartupChecks.tsx +0 -70
  1915. package/src/utils/plugins/pluginAutoupdate.ts +0 -284
  1916. package/src/utils/plugins/pluginBlocklist.ts +0 -127
  1917. package/src/utils/plugins/pluginDirectories.ts +0 -178
  1918. package/src/utils/plugins/pluginFlagging.ts +0 -208
  1919. package/src/utils/plugins/pluginIdentifier.ts +0 -123
  1920. package/src/utils/plugins/pluginInstallationHelpers.ts +0 -595
  1921. package/src/utils/plugins/pluginLoader.ts +0 -3302
  1922. package/src/utils/plugins/pluginOptionsStorage.ts +0 -400
  1923. package/src/utils/plugins/pluginPolicy.ts +0 -20
  1924. package/src/utils/plugins/pluginStartupCheck.ts +0 -341
  1925. package/src/utils/plugins/pluginVersioning.ts +0 -157
  1926. package/src/utils/plugins/reconciler.ts +0 -265
  1927. package/src/utils/plugins/refresh.ts +0 -215
  1928. package/src/utils/plugins/schemas.ts +0 -1681
  1929. package/src/utils/plugins/validatePlugin.ts +0 -903
  1930. package/src/utils/plugins/walkPluginMarkdown.ts +0 -69
  1931. package/src/utils/plugins/zipCache.ts +0 -406
  1932. package/src/utils/plugins/zipCacheAdapters.ts +0 -164
  1933. package/src/utils/postCommitAttribution.ts +0 -2
  1934. package/src/utils/powershell/dangerousCmdlets.ts +0 -185
  1935. package/src/utils/powershell/parser.ts +0 -1804
  1936. package/src/utils/powershell/staticPrefix.ts +0 -316
  1937. package/src/utils/preflightChecks.tsx +0 -151
  1938. package/src/utils/privacyLevel.ts +0 -55
  1939. package/src/utils/process.ts +0 -68
  1940. package/src/utils/processUserInput/processBashCommand.tsx +0 -140
  1941. package/src/utils/processUserInput/processSlashCommand.tsx +0 -922
  1942. package/src/utils/processUserInput/processTextPrompt.ts +0 -100
  1943. package/src/utils/processUserInput/processUserInput.ts +0 -605
  1944. package/src/utils/profilerBase.ts +0 -46
  1945. package/src/utils/promptCategory.ts +0 -49
  1946. package/src/utils/promptEditor.ts +0 -188
  1947. package/src/utils/promptShellExecution.ts +0 -183
  1948. package/src/utils/protectedNamespace.ts +0 -2
  1949. package/src/utils/proxy.ts +0 -426
  1950. package/src/utils/queryContext.ts +0 -179
  1951. package/src/utils/queryHelpers.ts +0 -552
  1952. package/src/utils/queryProfiler.ts +0 -301
  1953. package/src/utils/queueProcessor.ts +0 -95
  1954. package/src/utils/readEditContext.ts +0 -227
  1955. package/src/utils/readFileInRange.ts +0 -383
  1956. package/src/utils/releaseNotes.ts +0 -360
  1957. package/src/utils/renderOptions.ts +0 -77
  1958. package/src/utils/ripgrep.ts +0 -679
  1959. package/src/utils/sandbox/sandbox-adapter.ts +0 -985
  1960. package/src/utils/sandbox/sandbox-ui-utils.ts +0 -12
  1961. package/src/utils/sanitization.ts +0 -91
  1962. package/src/utils/screenshotClipboard.ts +0 -121
  1963. package/src/utils/sdkEventQueue.ts +0 -134
  1964. package/src/utils/sdkHeapDumpMonitor.ts +0 -2
  1965. package/src/utils/secureStorage/fallbackStorage.ts +0 -70
  1966. package/src/utils/secureStorage/index.ts +0 -17
  1967. package/src/utils/secureStorage/keychainPrefetch.ts +0 -116
  1968. package/src/utils/secureStorage/macOsKeychainHelpers.ts +0 -111
  1969. package/src/utils/secureStorage/macOsKeychainStorage.ts +0 -231
  1970. package/src/utils/secureStorage/plainTextStorage.ts +0 -84
  1971. package/src/utils/secureStorage/types.ts +0 -2
  1972. package/src/utils/semanticBoolean.ts +0 -29
  1973. package/src/utils/semanticNumber.ts +0 -36
  1974. package/src/utils/semver.ts +0 -59
  1975. package/src/utils/sequential.ts +0 -56
  1976. package/src/utils/sessionActivity.ts +0 -133
  1977. package/src/utils/sessionDataUploader.ts +0 -2
  1978. package/src/utils/sessionEnvVars.ts +0 -22
  1979. package/src/utils/sessionEnvironment.ts +0 -166
  1980. package/src/utils/sessionFileAccessHooks.ts +0 -250
  1981. package/src/utils/sessionIngressAuth.ts +0 -140
  1982. package/src/utils/sessionRestore.ts +0 -551
  1983. package/src/utils/sessionStart.ts +0 -232
  1984. package/src/utils/sessionState.ts +0 -150
  1985. package/src/utils/sessionStorage.ts +0 -5105
  1986. package/src/utils/sessionStoragePortable.ts +0 -793
  1987. package/src/utils/sessionTitle.ts +0 -129
  1988. package/src/utils/sessionUrl.ts +0 -64
  1989. package/src/utils/set.ts +0 -53
  1990. package/src/utils/settings/allErrors.ts +0 -32
  1991. package/src/utils/settings/applySettingsChange.ts +0 -92
  1992. package/src/utils/settings/changeDetector.ts +0 -488
  1993. package/src/utils/settings/constants.ts +0 -202
  1994. package/src/utils/settings/internalWrites.ts +0 -37
  1995. package/src/utils/settings/managedPath.ts +0 -34
  1996. package/src/utils/settings/mdm/constants.ts +0 -81
  1997. package/src/utils/settings/mdm/rawRead.ts +0 -130
  1998. package/src/utils/settings/mdm/settings.ts +0 -316
  1999. package/src/utils/settings/permissionValidation.ts +0 -262
  2000. package/src/utils/settings/pluginOnlyPolicy.ts +0 -60
  2001. package/src/utils/settings/schemaOutput.ts +0 -8
  2002. package/src/utils/settings/settings.ts +0 -1015
  2003. package/src/utils/settings/settingsCache.ts +0 -80
  2004. package/src/utils/settings/toolValidationConfig.ts +0 -103
  2005. package/src/utils/settings/types.ts +0 -1148
  2006. package/src/utils/settings/validateEditTool.ts +0 -45
  2007. package/src/utils/settings/validation.ts +0 -265
  2008. package/src/utils/settings/validationTips.ts +0 -164
  2009. package/src/utils/shell/bashProvider.ts +0 -255
  2010. package/src/utils/shell/outputLimits.ts +0 -14
  2011. package/src/utils/shell/powershellDetection.ts +0 -107
  2012. package/src/utils/shell/powershellProvider.ts +0 -123
  2013. package/src/utils/shell/prefix.ts +0 -367
  2014. package/src/utils/shell/readOnlyCommandValidation.ts +0 -1893
  2015. package/src/utils/shell/resolveDefaultShell.ts +0 -14
  2016. package/src/utils/shell/shellProvider.ts +0 -33
  2017. package/src/utils/shell/shellToolUtils.ts +0 -22
  2018. package/src/utils/shell/specPrefix.ts +0 -241
  2019. package/src/utils/shellConfig.ts +0 -167
  2020. package/src/utils/sideQuery.ts +0 -222
  2021. package/src/utils/sideQuestion.ts +0 -155
  2022. package/src/utils/signal.ts +0 -43
  2023. package/src/utils/sinks.ts +0 -16
  2024. package/src/utils/skills/skillChangeDetector.ts +0 -311
  2025. package/src/utils/slashCommandParsing.ts +0 -60
  2026. package/src/utils/sleep.ts +0 -84
  2027. package/src/utils/sliceAnsi.ts +0 -91
  2028. package/src/utils/slowOperations.ts +0 -286
  2029. package/src/utils/standaloneAgent.ts +0 -23
  2030. package/src/utils/startupProfiler.ts +0 -194
  2031. package/src/utils/staticRender.tsx +0 -116
  2032. package/src/utils/stats.ts +0 -1061
  2033. package/src/utils/statsCache.ts +0 -434
  2034. package/src/utils/status.tsx +0 -362
  2035. package/src/utils/statusNoticeDefinitions.tsx +0 -198
  2036. package/src/utils/statusNoticeHelpers.ts +0 -20
  2037. package/src/utils/stream.ts +0 -76
  2038. package/src/utils/streamJsonStdoutGuard.ts +0 -123
  2039. package/src/utils/streamlinedTransform.ts +0 -201
  2040. package/src/utils/stringUtils.ts +0 -235
  2041. package/src/utils/subprocessEnv.ts +0 -99
  2042. package/src/utils/suggestions/commandSuggestions.ts +0 -567
  2043. package/src/utils/suggestions/directoryCompletion.ts +0 -263
  2044. package/src/utils/suggestions/shellHistoryCompletion.ts +0 -119
  2045. package/src/utils/suggestions/skillUsageTracking.ts +0 -55
  2046. package/src/utils/suggestions/slackChannelSuggestions.ts +0 -209
  2047. package/src/utils/swarm/It2SetupPrompt.tsx +0 -380
  2048. package/src/utils/swarm/backends/ITermBackend.ts +0 -370
  2049. package/src/utils/swarm/backends/InProcessBackend.ts +0 -339
  2050. package/src/utils/swarm/backends/PaneBackendExecutor.ts +0 -354
  2051. package/src/utils/swarm/backends/TmuxBackend.ts +0 -764
  2052. package/src/utils/swarm/backends/detection.ts +0 -128
  2053. package/src/utils/swarm/backends/it2Setup.ts +0 -245
  2054. package/src/utils/swarm/backends/registry.ts +0 -464
  2055. package/src/utils/swarm/backends/teammateModeSnapshot.ts +0 -87
  2056. package/src/utils/swarm/backends/types.ts +0 -311
  2057. package/src/utils/swarm/constants.ts +0 -33
  2058. package/src/utils/swarm/inProcessRunner.ts +0 -1552
  2059. package/src/utils/swarm/leaderPermissionBridge.ts +0 -54
  2060. package/src/utils/swarm/permissionSync.ts +0 -928
  2061. package/src/utils/swarm/reconnection.ts +0 -119
  2062. package/src/utils/swarm/spawnInProcess.ts +0 -328
  2063. package/src/utils/swarm/spawnUtils.ts +0 -146
  2064. package/src/utils/swarm/teamHelpers.ts +0 -683
  2065. package/src/utils/swarm/teammateInit.ts +0 -129
  2066. package/src/utils/swarm/teammateLayoutManager.ts +0 -107
  2067. package/src/utils/swarm/teammateModel.ts +0 -10
  2068. package/src/utils/swarm/teammatePromptAddendum.ts +0 -18
  2069. package/src/utils/systemDirectories.ts +0 -74
  2070. package/src/utils/systemPrompt.ts +0 -123
  2071. package/src/utils/systemPromptType.ts +0 -14
  2072. package/src/utils/systemTheme.ts +0 -119
  2073. package/src/utils/systemThemeWatcher.ts +0 -2
  2074. package/src/utils/taggedId.ts +0 -54
  2075. package/src/utils/task/TaskOutput.ts +0 -390
  2076. package/src/utils/task/diskOutput.ts +0 -451
  2077. package/src/utils/task/framework.ts +0 -308
  2078. package/src/utils/task/outputFormatting.ts +0 -38
  2079. package/src/utils/task/sdkProgress.ts +0 -36
  2080. package/src/utils/taskSummary.ts +0 -2
  2081. package/src/utils/tasks.ts +0 -862
  2082. package/src/utils/teamDiscovery.ts +0 -81
  2083. package/src/utils/teamMemoryOps.ts +0 -88
  2084. package/src/utils/teammate.ts +0 -292
  2085. package/src/utils/teammateContext.ts +0 -96
  2086. package/src/utils/teammateMailbox.ts +0 -1183
  2087. package/src/utils/telemetry/betaSessionTracing.ts +0 -491
  2088. package/src/utils/telemetry/bigqueryExporter.ts +0 -252
  2089. package/src/utils/telemetry/events.ts +0 -75
  2090. package/src/utils/telemetry/instrumentation.ts +0 -825
  2091. package/src/utils/telemetry/logger.ts +0 -26
  2092. package/src/utils/telemetry/perfettoTracing.ts +0 -1120
  2093. package/src/utils/telemetry/pluginTelemetry.ts +0 -289
  2094. package/src/utils/telemetry/sessionTracing.ts +0 -927
  2095. package/src/utils/telemetry/skillLoadedEvent.ts +0 -39
  2096. package/src/utils/telemetryAttributes.ts +0 -71
  2097. package/src/utils/teleport/api.ts +0 -466
  2098. package/src/utils/teleport/environmentSelection.ts +0 -77
  2099. package/src/utils/teleport/environments.ts +0 -120
  2100. package/src/utils/teleport/gitBundle.ts +0 -292
  2101. package/src/utils/teleport.tsx +0 -1226
  2102. package/src/utils/tempfile.ts +0 -31
  2103. package/src/utils/terminal.ts +0 -131
  2104. package/src/utils/terminalPanel.ts +0 -191
  2105. package/src/utils/textHighlighting.ts +0 -166
  2106. package/src/utils/theme.ts +0 -639
  2107. package/src/utils/thinking.ts +0 -162
  2108. package/src/utils/timeouts.ts +0 -39
  2109. package/src/utils/tmuxSocket.ts +0 -427
  2110. package/src/utils/todo/types.ts +0 -18
  2111. package/src/utils/tokenBudget.ts +0 -73
  2112. package/src/utils/tokens.ts +0 -261
  2113. package/src/utils/toolErrors.ts +0 -132
  2114. package/src/utils/toolPool.ts +0 -79
  2115. package/src/utils/toolResultStorage.ts +0 -1040
  2116. package/src/utils/toolSchemaCache.ts +0 -26
  2117. package/src/utils/toolSearch.ts +0 -756
  2118. package/src/utils/transcriptSearch.ts +0 -202
  2119. package/src/utils/treeify.ts +0 -170
  2120. package/src/utils/truncate.ts +0 -179
  2121. package/src/utils/udsClient.ts +0 -2
  2122. package/src/utils/udsMessaging.ts +0 -2
  2123. package/src/utils/ultraplan/ccrSession.ts +0 -349
  2124. package/src/utils/ultraplan/keyword.ts +0 -127
  2125. package/src/utils/ultraplan/prompt.txt +0 -1
  2126. package/src/utils/unaryLogging.ts +0 -39
  2127. package/src/utils/undercover.ts +0 -89
  2128. package/src/utils/user.ts +0 -194
  2129. package/src/utils/userAgent.ts +0 -10
  2130. package/src/utils/userPromptKeywords.ts +0 -27
  2131. package/src/utils/uuid.ts +0 -27
  2132. package/src/utils/warningHandler.ts +0 -121
  2133. package/src/utils/which.ts +0 -82
  2134. package/src/utils/windowsPaths.ts +0 -173
  2135. package/src/utils/withResolvers.ts +0 -13
  2136. package/src/utils/words.ts +0 -800
  2137. package/src/utils/workloadContext.ts +0 -57
  2138. package/src/utils/worktree.ts +0 -1519
  2139. package/src/utils/worktreeModeEnabled.ts +0 -11
  2140. package/src/utils/xdg.ts +0 -65
  2141. package/src/utils/xml.ts +0 -16
  2142. package/src/utils/yaml.ts +0 -15
  2143. package/src/utils/zodToJsonSchema.ts +0 -23
  2144. package/src/vim/motions.ts +0 -82
  2145. package/src/vim/operators.ts +0 -556
  2146. package/src/vim/textObjects.ts +0 -186
  2147. package/src/vim/transitions.ts +0 -490
  2148. package/src/vim/types.ts +0 -199
  2149. package/src/voice/voiceModeEnabled.ts +0 -54
  2150. package/stubs/@ant/claude-for-chrome-mcp/index.js +0 -1
  2151. package/stubs/@ant/claude-for-chrome-mcp/index.ts +0 -4
  2152. package/stubs/@ant/claude-for-chrome-mcp/package.json +0 -6
  2153. package/stubs/@ant/computer-use-input/index.js +0 -2
  2154. package/stubs/@ant/computer-use-input/index.ts +0 -3
  2155. package/stubs/@ant/computer-use-input/package.json +0 -6
  2156. package/stubs/@ant/computer-use-mcp/index.js +0 -1
  2157. package/stubs/@ant/computer-use-mcp/index.ts +0 -1
  2158. package/stubs/@ant/computer-use-mcp/package.json +0 -11
  2159. package/stubs/@ant/computer-use-mcp/sentinelApps.js +0 -3
  2160. package/stubs/@ant/computer-use-mcp/sentinelApps.ts +0 -3
  2161. package/stubs/@ant/computer-use-mcp/types.js +0 -2
  2162. package/stubs/@ant/computer-use-mcp/types.ts +0 -6
  2163. package/stubs/@ant/computer-use-swift/index.js +0 -2
  2164. package/stubs/@ant/computer-use-swift/index.ts +0 -2
  2165. package/stubs/@ant/computer-use-swift/package.json +0 -6
  2166. package/stubs/@anthropic-ai/claude-agent-sdk/index.js +0 -2
  2167. package/stubs/@anthropic-ai/claude-agent-sdk/index.ts +0 -2
  2168. package/stubs/@anthropic-ai/claude-agent-sdk/package.json +0 -6
  2169. package/stubs/@anthropic-ai/mcpb/index.js +0 -2
  2170. package/stubs/@anthropic-ai/mcpb/index.ts +0 -3
  2171. package/stubs/@anthropic-ai/mcpb/package.json +0 -6
  2172. package/stubs/@anthropic-ai/sandbox-runtime/index.js +0 -4
  2173. package/stubs/@anthropic-ai/sandbox-runtime/index.ts +0 -49
  2174. package/stubs/@anthropic-ai/sandbox-runtime/package.json +0 -6
  2175. package/stubs/globals.ts +0 -11
  2176. package/stubs/macro.d.ts +0 -9
  2177. package/tsconfig.json +0 -28
@@ -1,2621 +0,0 @@
1
- import { feature } from 'src/_stubs/bun-bundle.js'
2
- import { APIUserAbortError } from '@anthropic-ai/sdk'
3
- import type { z } from 'zod/v4'
4
- import { getFeatureValue_CACHED_MAY_BE_STALE } from '../../services/analytics/growthbook.js'
5
- import {
6
- type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
7
- logEvent,
8
- } from '../../services/analytics/index.js'
9
- import type { ToolPermissionContext, ToolUseContext } from '../../Tool.js'
10
- import type { PendingClassifierCheck } from '../../types/permissions.js'
11
- import { count } from '../../utils/array.js'
12
- import {
13
- checkSemantics,
14
- nodeTypeId,
15
- type ParseForSecurityResult,
16
- parseForSecurityFromAst,
17
- type Redirect,
18
- type SimpleCommand,
19
- } from '../../utils/bash/ast.js'
20
- import {
21
- type CommandPrefixResult,
22
- extractOutputRedirections,
23
- getCommandSubcommandPrefix,
24
- splitCommand_DEPRECATED,
25
- } from '../../utils/bash/commands.js'
26
- import { parseCommandRaw } from '../../utils/bash/parser.js'
27
- import { tryParseShellCommand } from '../../utils/bash/shellQuote.js'
28
- import { getCwd } from '../../utils/cwd.js'
29
- import { logForDebugging } from '../../utils/debug.js'
30
- import { isEnvTruthy } from '../../utils/envUtils.js'
31
- import { AbortError } from '../../utils/errors.js'
32
- import type {
33
- ClassifierBehavior,
34
- ClassifierResult,
35
- } from '../../utils/permissions/bashClassifier.js'
36
- import {
37
- classifyBashCommand,
38
- getBashPromptAllowDescriptions,
39
- getBashPromptAskDescriptions,
40
- getBashPromptDenyDescriptions,
41
- isClassifierPermissionsEnabled,
42
- } from '../../utils/permissions/bashClassifier.js'
43
- import type {
44
- PermissionDecisionReason,
45
- PermissionResult,
46
- } from '../../utils/permissions/PermissionResult.js'
47
- import type {
48
- PermissionRule,
49
- PermissionRuleValue,
50
- } from '../../utils/permissions/PermissionRule.js'
51
- import { extractRules } from '../../utils/permissions/PermissionUpdate.js'
52
- import type { PermissionUpdate } from '../../utils/permissions/PermissionUpdateSchema.js'
53
- import { permissionRuleValueToString } from '../../utils/permissions/permissionRuleParser.js'
54
- import {
55
- createPermissionRequestMessage,
56
- getRuleByContentsForTool,
57
- } from '../../utils/permissions/permissions.js'
58
- import {
59
- parsePermissionRule,
60
- type ShellPermissionRule,
61
- matchWildcardPattern as sharedMatchWildcardPattern,
62
- permissionRuleExtractPrefix as sharedPermissionRuleExtractPrefix,
63
- suggestionForExactCommand as sharedSuggestionForExactCommand,
64
- suggestionForPrefix as sharedSuggestionForPrefix,
65
- } from '../../utils/permissions/shellRuleMatching.js'
66
- import { getPlatform } from '../../utils/platform.js'
67
- import { SandboxManager } from '../../utils/sandbox/sandbox-adapter.js'
68
- import { jsonStringify } from '../../utils/slowOperations.js'
69
- import { windowsPathToPosixPath } from '../../utils/windowsPaths.js'
70
- import { BashTool } from './BashTool.js'
71
- import { checkCommandOperatorPermissions } from './bashCommandHelpers.js'
72
- import {
73
- bashCommandIsSafeAsync_DEPRECATED,
74
- stripSafeHeredocSubstitutions,
75
- } from './bashSecurity.js'
76
- import { checkPermissionMode } from './modeValidation.js'
77
- import { checkPathConstraints } from './pathValidation.js'
78
- import { checkSedConstraints } from './sedValidation.js'
79
- import { shouldUseSandbox } from './shouldUseSandbox.js'
80
-
81
- // DCE cliff: Bun's feature() evaluator has a per-function complexity budget.
82
- // bashToolHasPermission is right at the limit. `import { X as Y }` aliases
83
- // inside the import block count toward this budget; when they push it over
84
- // the threshold Bun can no longer prove feature('BASH_CLASSIFIER') is a
85
- // constant and silently evaluates the ternaries to `false`, dropping every
86
- // pendingClassifierCheck spread. Keep aliases as top-level const rebindings
87
- // instead. (See also the comment on checkSemanticsDeny below.)
88
- const bashCommandIsSafeAsync = bashCommandIsSafeAsync_DEPRECATED
89
- const splitCommand = splitCommand_DEPRECATED
90
-
91
- // Env-var assignment prefix (VAR=value). Shared across three while-loops that
92
- // skip safe env vars before extracting the command name.
93
- const ENV_VAR_ASSIGN_RE = /^[A-Za-z_]\w*=/
94
-
95
- // CC-643: On complex compound commands, splitCommand_DEPRECATED can produce a
96
- // very large subcommands array (possible exponential growth; #21405's ReDoS fix
97
- // may have been incomplete). Each subcommand then runs tree-sitter parse +
98
- // ~20 validators + logEvent (bashSecurity.ts), and with memoized metadata the
99
- // resulting microtask chain starves the event loop — REPL freeze at 100% CPU,
100
- // strace showed /proc/self/stat reads at ~127Hz with no epoll_wait. Fifty is
101
- // generous: legitimate user commands don't split that wide. Above the cap we
102
- // fall back to 'ask' (safe default — we can't prove safety, so we prompt).
103
- export const MAX_SUBCOMMANDS_FOR_SECURITY_CHECK = 50
104
-
105
- // GH#11380: Cap the number of per-subcommand rules suggested for compound
106
- // commands. Beyond this, the "Yes, and don't ask again for X, Y, Z…" label
107
- // degrades to "similar commands" anyway, and saving 10+ rules from one prompt
108
- // is more likely noise than intent. Users chaining this many write commands
109
- // in one && list are rare; they can always approve once and add rules manually.
110
- export const MAX_SUGGESTED_RULES_FOR_COMPOUND = 5
111
-
112
- /**
113
- * [ANT-ONLY] Log classifier evaluation results for analysis.
114
- * This helps us understand which classifier rules are being evaluated
115
- * and how the classifier is deciding on commands.
116
- */
117
- function logClassifierResultForAnts(
118
- command: string,
119
- behavior: ClassifierBehavior,
120
- descriptions: string[],
121
- result: ClassifierResult,
122
- ): void {
123
- if (process.env.USER_TYPE !== 'ant') {
124
- return
125
- }
126
-
127
- logEvent('tengu_internal_bash_classifier_result', {
128
- behavior:
129
- behavior as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
130
- descriptions: jsonStringify(
131
- descriptions,
132
- ) as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
133
- matches: result.matches,
134
- matchedDescription: (result.matchedDescription ??
135
- '') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
136
- confidence:
137
- result.confidence as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
138
- reason:
139
- result.reason as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
140
- // Note: command contains code/filepaths - this is ANT-ONLY so it's OK
141
- command:
142
- command as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
143
- })
144
- }
145
-
146
- /**
147
- * Extract a stable command prefix (command + subcommand) from a raw command string.
148
- * Skips leading env var assignments only if they are in SAFE_ENV_VARS (or
149
- * ANT_ONLY_SAFE_ENV_VARS for ant users). Returns null if a non-safe env var is
150
- * encountered (to fall back to exact match), or if the second token doesn't look
151
- * like a subcommand (lowercase alphanumeric, e.g., "commit", "run").
152
- *
153
- * Examples:
154
- * 'git commit -m "fix typo"' → 'git commit'
155
- * 'NODE_ENV=prod npm run build' → 'npm run' (NODE_ENV is safe)
156
- * 'MY_VAR=val npm run build' → null (MY_VAR is not safe)
157
- * 'ls -la' → null (flag, not a subcommand)
158
- * 'cat file.txt' → null (filename, not a subcommand)
159
- * 'chmod 755 file' → null (number, not a subcommand)
160
- */
161
- export function getSimpleCommandPrefix(command: string): string | null {
162
- const tokens = command.trim().split(/\s+/).filter(Boolean)
163
- if (tokens.length === 0) return null
164
-
165
- // Skip env var assignments (VAR=value) at the start, but only if they are
166
- // in SAFE_ENV_VARS (or ANT_ONLY_SAFE_ENV_VARS for ant users). If a non-safe
167
- // env var is encountered, return null to fall back to exact match. This
168
- // prevents generating prefix rules like Bash(npm run:*) that can never match
169
- // at allow-rule check time, because stripSafeWrappers only strips safe vars.
170
- let i = 0
171
- while (i < tokens.length && ENV_VAR_ASSIGN_RE.test(tokens[i]!)) {
172
- const varName = tokens[i]!.split('=')[0]!
173
- const isAntOnlySafe =
174
- process.env.USER_TYPE === 'ant' && ANT_ONLY_SAFE_ENV_VARS.has(varName)
175
- if (!SAFE_ENV_VARS.has(varName) && !isAntOnlySafe) {
176
- return null
177
- }
178
- i++
179
- }
180
-
181
- const remaining = tokens.slice(i)
182
- if (remaining.length < 2) return null
183
- const subcmd = remaining[1]!
184
- // Second token must look like a subcommand (e.g., "commit", "run", "compose"),
185
- // not a flag (-rf), filename (file.txt), path (/tmp), URL, or number (755).
186
- if (!/^[a-z][a-z0-9]*(-[a-z0-9]+)*$/.test(subcmd)) return null
187
- return remaining.slice(0, 2).join(' ')
188
- }
189
-
190
- // Bare-prefix suggestions like `bash:*` or `sh:*` would allow arbitrary code
191
- // via `-c`. Wrapper suggestions like `env:*` or `sudo:*` would do the same:
192
- // `env` is NOT in SAFE_WRAPPER_PATTERNS, so `env bash -c "evil"` survives
193
- // stripSafeWrappers unchanged and hits the startsWith("env ") check at
194
- // the prefix-rule matcher. Shell list mirrors DANGEROUS_SHELL_PREFIXES in
195
- // src/utils/shell/prefix.ts which guarded the old Haiku extractor.
196
- const BARE_SHELL_PREFIXES = new Set([
197
- 'sh',
198
- 'bash',
199
- 'zsh',
200
- 'fish',
201
- 'csh',
202
- 'tcsh',
203
- 'ksh',
204
- 'dash',
205
- 'cmd',
206
- 'powershell',
207
- 'pwsh',
208
- // wrappers that exec their args as a command
209
- 'env',
210
- 'xargs',
211
- // SECURITY: checkSemantics (ast.ts) strips these wrappers to check the
212
- // wrapped command. Suggesting `Bash(nice:*)` would be ≈ `Bash(*)` — users
213
- // would add it after a prompt, then `nice rm -rf /` passes semantics while
214
- // deny/cd+git gates see 'nice' (SAFE_WRAPPER_PATTERNS below didn't strip
215
- // bare `nice` until this fix). Block these from ever being suggested.
216
- 'nice',
217
- 'stdbuf',
218
- 'nohup',
219
- 'timeout',
220
- 'time',
221
- // privilege escalation — sudo:* from `sudo -u foo ...` would auto-approve
222
- // any future sudo invocation
223
- 'sudo',
224
- 'doas',
225
- 'pkexec',
226
- ])
227
-
228
- /**
229
- * UI-only fallback: extract the first word alone when getSimpleCommandPrefix
230
- * declines. In external builds TREE_SITTER_BASH is off, so the async
231
- * tree-sitter refinement in BashPermissionRequest never fires — without this,
232
- * pipes and compounds (`python3 file.py 2>&1 | tail -20`) dump into the
233
- * editable field verbatim.
234
- *
235
- * Deliberately not used by suggestionForExactCommand: a backend-suggested
236
- * `Bash(rm:*)` is too broad to auto-generate, but as an editable starting
237
- * point it's what users expect (Slack C07VBSHV7EV/p1772670433193449).
238
- *
239
- * Reuses the same SAFE_ENV_VARS gate as getSimpleCommandPrefix — a rule like
240
- * `Bash(python3:*)` can never match `RUN=/path python3 ...` at check time
241
- * because stripSafeWrappers won't strip RUN.
242
- */
243
- export function getFirstWordPrefix(command: string): string | null {
244
- const tokens = command.trim().split(/\s+/).filter(Boolean)
245
-
246
- let i = 0
247
- while (i < tokens.length && ENV_VAR_ASSIGN_RE.test(tokens[i]!)) {
248
- const varName = tokens[i]!.split('=')[0]!
249
- const isAntOnlySafe =
250
- process.env.USER_TYPE === 'ant' && ANT_ONLY_SAFE_ENV_VARS.has(varName)
251
- if (!SAFE_ENV_VARS.has(varName) && !isAntOnlySafe) {
252
- return null
253
- }
254
- i++
255
- }
256
-
257
- const cmd = tokens[i]
258
- if (!cmd) return null
259
- // Same shape check as the subcommand regex in getSimpleCommandPrefix:
260
- // rejects paths (./script.sh, /usr/bin/python), flags, numbers, filenames.
261
- if (!/^[a-z][a-z0-9]*(-[a-z0-9]+)*$/.test(cmd)) return null
262
- if (BARE_SHELL_PREFIXES.has(cmd)) return null
263
- return cmd
264
- }
265
-
266
- function suggestionForExactCommand(command: string): PermissionUpdate[] {
267
- // Heredoc commands contain multi-line content that changes each invocation,
268
- // making exact-match rules useless (they'll never match again). Extract a
269
- // stable prefix before the heredoc operator and suggest a prefix rule instead.
270
- const heredocPrefix = extractPrefixBeforeHeredoc(command)
271
- if (heredocPrefix) {
272
- return sharedSuggestionForPrefix(BashTool.name, heredocPrefix)
273
- }
274
-
275
- // Multiline commands without heredoc also make poor exact-match rules.
276
- // Saving the full multiline text can produce patterns containing `:*` in
277
- // the middle, which fails permission validation and corrupts the settings
278
- // file. Use the first line as a prefix rule instead.
279
- if (command.includes('\n')) {
280
- const firstLine = command.split('\n')[0]!.trim()
281
- if (firstLine) {
282
- return sharedSuggestionForPrefix(BashTool.name, firstLine)
283
- }
284
- }
285
-
286
- // Single-line commands: extract a 2-word prefix for reusable rules.
287
- // Without this, exact-match rules are saved that never match future
288
- // invocations with different arguments.
289
- const prefix = getSimpleCommandPrefix(command)
290
- if (prefix) {
291
- return sharedSuggestionForPrefix(BashTool.name, prefix)
292
- }
293
-
294
- return sharedSuggestionForExactCommand(BashTool.name, command)
295
- }
296
-
297
- /**
298
- * If the command contains a heredoc (<<), extract the command prefix before it.
299
- * Returns the first word(s) before the heredoc operator as a stable prefix,
300
- * or null if the command doesn't contain a heredoc.
301
- *
302
- * Examples:
303
- * 'git commit -m "$(cat <<\'EOF\'\n...\nEOF\n)"' → 'git commit'
304
- * 'cat <<EOF\nhello\nEOF' → 'cat'
305
- * 'echo hello' → null (no heredoc)
306
- */
307
- function extractPrefixBeforeHeredoc(command: string): string | null {
308
- if (!command.includes('<<')) return null
309
-
310
- const idx = command.indexOf('<<')
311
- if (idx <= 0) return null
312
-
313
- const before = command.substring(0, idx).trim()
314
- if (!before) return null
315
-
316
- const prefix = getSimpleCommandPrefix(before)
317
- if (prefix) return prefix
318
-
319
- // Fallback: skip safe env var assignments and take up to 2 tokens.
320
- // This preserves flag tokens (e.g., "python3 -c" stays "python3 -c",
321
- // not just "python3") and skips safe env var prefixes like "NODE_ENV=test".
322
- // If a non-safe env var is encountered, return null to avoid generating
323
- // prefix rules that can never match (same rationale as getSimpleCommandPrefix).
324
- const tokens = before.split(/\s+/).filter(Boolean)
325
- let i = 0
326
- while (i < tokens.length && ENV_VAR_ASSIGN_RE.test(tokens[i]!)) {
327
- const varName = tokens[i]!.split('=')[0]!
328
- const isAntOnlySafe =
329
- process.env.USER_TYPE === 'ant' && ANT_ONLY_SAFE_ENV_VARS.has(varName)
330
- if (!SAFE_ENV_VARS.has(varName) && !isAntOnlySafe) {
331
- return null
332
- }
333
- i++
334
- }
335
- if (i >= tokens.length) return null
336
- return tokens.slice(i, i + 2).join(' ') || null
337
- }
338
-
339
- function suggestionForPrefix(prefix: string): PermissionUpdate[] {
340
- return sharedSuggestionForPrefix(BashTool.name, prefix)
341
- }
342
-
343
- /**
344
- * Extract prefix from legacy :* syntax (e.g., "npm:*" -> "npm")
345
- * Delegates to shared implementation.
346
- */
347
- export const permissionRuleExtractPrefix = sharedPermissionRuleExtractPrefix
348
-
349
- /**
350
- * Match a command against a wildcard pattern (case-sensitive for Bash).
351
- * Delegates to shared implementation.
352
- */
353
- export function matchWildcardPattern(
354
- pattern: string,
355
- command: string,
356
- ): boolean {
357
- return sharedMatchWildcardPattern(pattern, command)
358
- }
359
-
360
- /**
361
- * Parse a permission rule into a structured rule object.
362
- * Delegates to shared implementation.
363
- */
364
- export const bashPermissionRule: (
365
- permissionRule: string,
366
- ) => ShellPermissionRule = parsePermissionRule
367
-
368
- /**
369
- * Whitelist of environment variables that are safe to strip from commands.
370
- * These variables CANNOT execute code or load libraries.
371
- *
372
- * SECURITY: These must NEVER be added to the whitelist:
373
- * - PATH, LD_PRELOAD, LD_LIBRARY_PATH, DYLD_* (execution/library loading)
374
- * - PYTHONPATH, NODE_PATH, CLASSPATH, RUBYLIB (module loading)
375
- * - GOFLAGS, RUSTFLAGS, NODE_OPTIONS (can contain code execution flags)
376
- * - HOME, TMPDIR, SHELL, BASH_ENV (affect system behavior)
377
- */
378
- const SAFE_ENV_VARS = new Set([
379
- // Go - build/runtime settings only
380
- 'GOEXPERIMENT', // experimental features
381
- 'GOOS', // target OS
382
- 'GOARCH', // target architecture
383
- 'CGO_ENABLED', // enable/disable CGO
384
- 'GO111MODULE', // module mode
385
-
386
- // Rust - logging/debugging only
387
- 'RUST_BACKTRACE', // backtrace verbosity
388
- 'RUST_LOG', // logging filter
389
-
390
- // Node - environment name only (not NODE_OPTIONS!)
391
- 'NODE_ENV',
392
-
393
- // Python - behavior flags only (not PYTHONPATH!)
394
- 'PYTHONUNBUFFERED', // disable buffering
395
- 'PYTHONDONTWRITEBYTECODE', // no .pyc files
396
-
397
- // Pytest - test configuration
398
- 'PYTEST_DISABLE_PLUGIN_AUTOLOAD', // disable plugin loading
399
- 'PYTEST_DEBUG', // debug output
400
-
401
- // API keys and authentication
402
- 'ANTHROPIC_API_KEY', // API authentication
403
-
404
- // Locale and character encoding
405
- 'LANG', // default locale
406
- 'LANGUAGE', // language preference list
407
- 'LC_ALL', // override all locale settings
408
- 'LC_CTYPE', // character classification
409
- 'LC_TIME', // time format
410
- 'CHARSET', // character set preference
411
-
412
- // Terminal and display
413
- 'TERM', // terminal type
414
- 'COLORTERM', // color terminal indicator
415
- 'NO_COLOR', // disable color output (universal standard)
416
- 'FORCE_COLOR', // force color output
417
- 'TZ', // timezone
418
-
419
- // Color configuration for various tools
420
- 'LS_COLORS', // colors for ls (GNU)
421
- 'LSCOLORS', // colors for ls (BSD/macOS)
422
- 'GREP_COLOR', // grep match color (deprecated)
423
- 'GREP_COLORS', // grep color scheme
424
- 'GCC_COLORS', // GCC diagnostic colors
425
-
426
- // Display formatting
427
- 'TIME_STYLE', // time display format for ls
428
- 'BLOCK_SIZE', // block size for du/df
429
- 'BLOCKSIZE', // alternative block size
430
- ])
431
-
432
- /**
433
- * ANT-ONLY environment variables that are safe to strip from commands.
434
- * These are only enabled when USER_TYPE === 'ant'.
435
- *
436
- * SECURITY: These env vars are stripped before permission-rule matching, which
437
- * means `DOCKER_HOST=tcp://evil.com docker ps` matches a `Bash(docker ps:*)`
438
- * rule after stripping. This is INTENTIONALLY ANT-ONLY (gated at line ~380)
439
- * and MUST NEVER ship to external users. DOCKER_HOST redirects the Docker
440
- * daemon endpoint — stripping it defeats prefix-based permission restrictions
441
- * by hiding the network endpoint from the permission check. KUBECONFIG
442
- * similarly controls which cluster kubectl talks to. These are convenience
443
- * strippings for internal power users who accept the risk.
444
- *
445
- * Based on analysis of 30 days of tengu_internal_bash_tool_use_permission_request events.
446
- */
447
- const ANT_ONLY_SAFE_ENV_VARS = new Set([
448
- // Kubernetes and container config (config file pointers, not execution)
449
- 'KUBECONFIG', // kubectl config file path — controls which cluster kubectl uses
450
- 'DOCKER_HOST', // Docker daemon socket/endpoint — controls which daemon docker talks to
451
-
452
- // Cloud provider project/profile selection (just names/identifiers)
453
- 'AWS_PROFILE', // AWS profile name selection
454
- 'CLOUDSDK_CORE_PROJECT', // GCP project ID
455
- 'CLUSTER', // generic cluster name
456
-
457
- // Anthropic internal cluster selection (just names/identifiers)
458
- 'COO_CLUSTER', // coo cluster name
459
- 'COO_CLUSTER_NAME', // coo cluster name (alternate)
460
- 'COO_NAMESPACE', // coo namespace
461
- 'COO_LAUNCH_YAML_DRY_RUN', // dry run mode
462
-
463
- // Feature flags (boolean/string flags only)
464
- 'SKIP_NODE_VERSION_CHECK', // skip version check
465
- 'EXPECTTEST_ACCEPT', // accept test expectations
466
- 'CI', // CI environment indicator
467
- 'GIT_LFS_SKIP_SMUDGE', // skip LFS downloads
468
-
469
- // GPU/Device selection (just device IDs)
470
- 'CUDA_VISIBLE_DEVICES', // GPU device selection
471
- 'JAX_PLATFORMS', // JAX platform selection
472
-
473
- // Display/terminal settings
474
- 'COLUMNS', // terminal width
475
- 'TMUX', // TMUX socket info
476
-
477
- // Test/debug configuration
478
- 'POSTGRESQL_VERSION', // postgres version string
479
- 'FIRESTORE_EMULATOR_HOST', // emulator host:port
480
- 'HARNESS_QUIET', // quiet mode flag
481
- 'TEST_CROSSCHECK_LISTS_MATCH_UPDATE', // test update flag
482
- 'DBT_PER_DEVELOPER_ENVIRONMENTS', // DBT config
483
- 'STATSIG_FORD_DB_CHECKS', // statsig DB check flag
484
-
485
- // Build configuration
486
- 'ANT_ENVIRONMENT', // Anthropic environment name
487
- 'ANT_SERVICE', // Anthropic service name
488
- 'MONOREPO_ROOT_DIR', // monorepo root path
489
-
490
- // Version selectors
491
- 'PYENV_VERSION', // Python version selection
492
-
493
- // Credentials (approved subset - these don't change exfil risk)
494
- 'PGPASSWORD', // Postgres password
495
- 'GH_TOKEN', // GitHub token
496
- 'GROWTHBOOK_API_KEY', // self-hosted growthbook
497
- ])
498
-
499
- /**
500
- * Strips full-line comments from a command.
501
- * This handles cases where Claude adds comments in bash commands, e.g.:
502
- * "# Check the logs directory\nls /home/user/logs"
503
- * Should be stripped to: "ls /home/user/logs"
504
- *
505
- * Only strips full-line comments (lines where the entire line is a comment),
506
- * not inline comments that appear after a command on the same line.
507
- */
508
- function stripCommentLines(command: string): string {
509
- const lines = command.split('\n')
510
- const nonCommentLines = lines.filter(line => {
511
- const trimmed = line.trim()
512
- // Keep lines that are not empty and don't start with #
513
- return trimmed !== '' && !trimmed.startsWith('#')
514
- })
515
-
516
- // If all lines were comments/empty, return original
517
- if (nonCommentLines.length === 0) {
518
- return command
519
- }
520
-
521
- return nonCommentLines.join('\n')
522
- }
523
-
524
- export function stripSafeWrappers(command: string): string {
525
- // SECURITY: Use [ \t]+ not \s+ — \s matches \n/\r which are command
526
- // separators in bash. Matching across a newline would strip the wrapper from
527
- // one line and leave a different command on the next line for bash to execute.
528
- //
529
- // SECURITY: `(?:--[ \t]+)?` consumes the wrapper's own `--` so
530
- // `nohup -- rm -- -/../foo` strips to `rm -- -/../foo` (not `-- rm ...`
531
- // which would skip path validation with `--` as an unknown baseCmd).
532
- const SAFE_WRAPPER_PATTERNS = [
533
- // timeout: enumerate GNU long flags — no-value (--foreground,
534
- // --preserve-status, --verbose), value-taking in both =fused and
535
- // space-separated forms (--kill-after=5, --kill-after 5, --signal=TERM,
536
- // --signal TERM). Short: -v (no-arg), -k/-s with separate or fused value.
537
- // SECURITY: flag VALUES use allowlist [A-Za-z0-9_.+-] (signals are
538
- // TERM/KILL/9, durations are 5/5s/10.5). Previously [^ \t]+ matched
539
- // $ ( ) ` | ; & — `timeout -k$(id) 10 ls` stripped to `ls`, matched
540
- // Bash(ls:*), while bash expanded $(id) during word splitting BEFORE
541
- // timeout ran. Contrast ENV_VAR_PATTERN below which already allowlists.
542
- /^timeout[ \t]+(?:(?:--(?:foreground|preserve-status|verbose)|--(?:kill-after|signal)=[A-Za-z0-9_.+-]+|--(?:kill-after|signal)[ \t]+[A-Za-z0-9_.+-]+|-v|-[ks][ \t]+[A-Za-z0-9_.+-]+|-[ks][A-Za-z0-9_.+-]+)[ \t]+)*(?:--[ \t]+)?\d+(?:\.\d+)?[smhd]?[ \t]+/,
543
- /^time[ \t]+(?:--[ \t]+)?/,
544
- // SECURITY: keep in sync with checkSemantics wrapper-strip (ast.ts
545
- // ~:1990-2080) AND stripWrappersFromArgv (pathValidation.ts ~:1260).
546
- // Previously this pattern REQUIRED `-n N`; checkSemantics already handled
547
- // bare `nice` and legacy `-N`. Asymmetry meant checkSemantics exposed the
548
- // wrapped command to semantic checks but deny-rule matching and the cd+git
549
- // gate saw the wrapper name. `nice rm -rf /` with Bash(rm:*) deny became
550
- // ask instead of deny; `cd evil && nice git status` skipped the bare-repo
551
- // RCE gate. PR #21503 fixed stripWrappersFromArgv; this was missed.
552
- // Now matches: `nice cmd`, `nice -n N cmd`, `nice -N cmd` (all forms
553
- // checkSemantics strips).
554
- /^nice(?:[ \t]+-n[ \t]+-?\d+|[ \t]+-\d+)?[ \t]+(?:--[ \t]+)?/,
555
- // stdbuf: fused short flags only (-o0, -eL). checkSemantics handles more
556
- // (space-separated, long --output=MODE), but we fail-closed on those
557
- // above so not over-stripping here is safe. Main need: `stdbuf -o0 cmd`.
558
- /^stdbuf(?:[ \t]+-[ioe][LN0-9]+)+[ \t]+(?:--[ \t]+)?/,
559
- /^nohup[ \t]+(?:--[ \t]+)?/,
560
- ] as const
561
-
562
- // Pattern for environment variables:
563
- // ^([A-Za-z_][A-Za-z0-9_]*) - Variable name (standard identifier)
564
- // = - Equals sign
565
- // ([A-Za-z0-9_./:-]+) - Value: alphanumeric + safe punctuation only
566
- // [ \t]+ - Required HORIZONTAL whitespace after value
567
- //
568
- // SECURITY: Only matches unquoted values with safe characters (no $(), `, $var, ;|&).
569
- //
570
- // SECURITY: Trailing whitespace MUST be [ \t]+ (horizontal only), NOT \s+.
571
- // \s matches \n/\r. If reconstructCommand emits an unquoted newline between
572
- // `TZ=UTC` and `echo`, \s+ would match across it and strip `TZ=UTC<NL>`,
573
- // leaving `echo curl evil.com` to match Bash(echo:*). But bash treats the
574
- // newline as a command separator. Defense-in-depth with needsQuoting fix.
575
- const ENV_VAR_PATTERN = /^([A-Za-z_][A-Za-z0-9_]*)=([A-Za-z0-9_./:-]+)[ \t]+/
576
-
577
- let stripped = command
578
- let previousStripped = ''
579
-
580
- // Phase 1: Strip leading env vars and comments only.
581
- // In bash, env var assignments before a command (VAR=val cmd) are genuine
582
- // shell-level assignments. These are safe to strip for permission matching.
583
- while (stripped !== previousStripped) {
584
- previousStripped = stripped
585
- stripped = stripCommentLines(stripped)
586
-
587
- const envVarMatch = stripped.match(ENV_VAR_PATTERN)
588
- if (envVarMatch) {
589
- const varName = envVarMatch[1]!
590
- const isAntOnlySafe =
591
- process.env.USER_TYPE === 'ant' && ANT_ONLY_SAFE_ENV_VARS.has(varName)
592
- if (SAFE_ENV_VARS.has(varName) || isAntOnlySafe) {
593
- stripped = stripped.replace(ENV_VAR_PATTERN, '')
594
- }
595
- }
596
- }
597
-
598
- // Phase 2: Strip wrapper commands and comments only. Do NOT strip env vars.
599
- // Wrapper commands (timeout, time, nice, nohup) use execvp to run their
600
- // arguments, so VAR=val after a wrapper is treated as the COMMAND to execute,
601
- // not as an env var assignment. Stripping env vars here would create a
602
- // mismatch between what the parser sees and what actually executes.
603
- // (HackerOne #3543050)
604
- previousStripped = ''
605
- while (stripped !== previousStripped) {
606
- previousStripped = stripped
607
- stripped = stripCommentLines(stripped)
608
-
609
- for (const pattern of SAFE_WRAPPER_PATTERNS) {
610
- stripped = stripped.replace(pattern, '')
611
- }
612
- }
613
-
614
- return stripped.trim()
615
- }
616
-
617
- // SECURITY: allowlist for timeout flag VALUES (signals are TERM/KILL/9,
618
- // durations are 5/5s/10.5). Rejects $ ( ) ` | ; & and newlines that
619
- // previously matched via [^ \t]+ — `timeout -k$(id) 10 ls` must NOT strip.
620
- const TIMEOUT_FLAG_VALUE_RE = /^[A-Za-z0-9_.+-]+$/
621
-
622
- /**
623
- * Parse timeout's GNU flags (long + short, fused + space-separated) and
624
- * return the argv index of the DURATION token, or -1 if flags are unparseable.
625
- * Enumerates: --foreground/--preserve-status/--verbose (no value),
626
- * --kill-after/--signal (value, both =fused and space-separated), -v (no
627
- * value), -k/-s (value, both fused and space-separated).
628
- *
629
- * Extracted from stripWrappersFromArgv to keep bashToolHasPermission under
630
- * Bun's feature() DCE complexity threshold — inlining this breaks
631
- * feature('BASH_CLASSIFIER') evaluation in classifier tests.
632
- */
633
- function skipTimeoutFlags(a: readonly string[]): number {
634
- let i = 1
635
- while (i < a.length) {
636
- const arg = a[i]!
637
- const next = a[i + 1]
638
- if (
639
- arg === '--foreground' ||
640
- arg === '--preserve-status' ||
641
- arg === '--verbose'
642
- )
643
- i++
644
- else if (/^--(?:kill-after|signal)=[A-Za-z0-9_.+-]+$/.test(arg)) i++
645
- else if (
646
- (arg === '--kill-after' || arg === '--signal') &&
647
- next &&
648
- TIMEOUT_FLAG_VALUE_RE.test(next)
649
- )
650
- i += 2
651
- else if (arg === '--') {
652
- i++
653
- break
654
- } // end-of-options marker
655
- else if (arg.startsWith('--')) return -1
656
- else if (arg === '-v') i++
657
- else if (
658
- (arg === '-k' || arg === '-s') &&
659
- next &&
660
- TIMEOUT_FLAG_VALUE_RE.test(next)
661
- )
662
- i += 2
663
- else if (/^-[ks][A-Za-z0-9_.+-]+$/.test(arg)) i++
664
- else if (arg.startsWith('-')) return -1
665
- else break
666
- }
667
- return i
668
- }
669
-
670
- /**
671
- * Argv-level counterpart to stripSafeWrappers. Strips the same wrapper
672
- * commands (timeout, time, nice, nohup) from AST-derived argv. Env vars
673
- * are already separated into SimpleCommand.envVars so no env-var stripping.
674
- *
675
- * KEEP IN SYNC with SAFE_WRAPPER_PATTERNS above — if you add a wrapper
676
- * there, add it here too.
677
- */
678
- export function stripWrappersFromArgv(argv: string[]): string[] {
679
- // SECURITY: Consume optional `--` after wrapper options, matching what the
680
- // wrapper does. Otherwise `['nohup','--','rm','--','-/../foo']` yields `--`
681
- // as baseCmd and skips path validation. See SAFE_WRAPPER_PATTERNS comment.
682
- let a = argv
683
- for (;;) {
684
- if (a[0] === 'time' || a[0] === 'nohup') {
685
- a = a.slice(a[1] === '--' ? 2 : 1)
686
- } else if (a[0] === 'timeout') {
687
- const i = skipTimeoutFlags(a)
688
- if (i < 0 || !a[i] || !/^\d+(?:\.\d+)?[smhd]?$/.test(a[i]!)) return a
689
- a = a.slice(i + 1)
690
- } else if (
691
- a[0] === 'nice' &&
692
- a[1] === '-n' &&
693
- a[2] &&
694
- /^-?\d+$/.test(a[2])
695
- ) {
696
- a = a.slice(a[3] === '--' ? 4 : 3)
697
- } else {
698
- return a
699
- }
700
- }
701
- }
702
-
703
- /**
704
- * Env vars that make a *different binary* run (injection or resolution hijack).
705
- * Heuristic only — export-&& form bypasses this, and excludedCommands isn't a
706
- * security boundary anyway.
707
- */
708
- export const BINARY_HIJACK_VARS = /^(LD_|DYLD_|PATH$)/
709
-
710
- /**
711
- * Strip ALL leading env var prefixes from a command, regardless of whether the
712
- * var name is in the safe-list.
713
- *
714
- * Used for deny/ask rule matching: when a user denies `claude` or `rm`, the
715
- * command should stay blocked even if prefixed with arbitrary env vars like
716
- * `FOO=bar claude`. The safe-list restriction in stripSafeWrappers is correct
717
- * for allow rules (prevents `DOCKER_HOST=evil docker ps` from auto-matching
718
- * `Bash(docker ps:*)`), but deny rules must be harder to circumvent.
719
- *
720
- * Also used for sandbox.excludedCommands matching (not a security boundary —
721
- * permission prompts are), with BINARY_HIJACK_VARS as a blocklist.
722
- *
723
- * SECURITY: Uses a broader value pattern than stripSafeWrappers. The value
724
- * pattern excludes only actual shell injection characters ($, backtick, ;, |,
725
- * &, parens, redirects, quotes, backslash) and whitespace. Characters like
726
- * =, +, @, ~, , are harmless in unquoted env var assignment position and must
727
- * be matched to prevent trivial bypass via e.g. `FOO=a=b denied_command`.
728
- *
729
- * @param blocklist - optional regex tested against each var name; matching vars
730
- * are NOT stripped (and stripping stops there). Omit for deny rules; pass
731
- * BINARY_HIJACK_VARS for excludedCommands.
732
- */
733
- export function stripAllLeadingEnvVars(
734
- command: string,
735
- blocklist?: RegExp,
736
- ): string {
737
- // Broader value pattern for deny-rule stripping. Handles:
738
- //
739
- // - Standard assignment (FOO=bar), append (FOO+=bar), array (FOO[0]=bar)
740
- // - Single-quoted values: '[^'\n\r]*' — bash suppresses all expansion
741
- // - Double-quoted values with backslash escapes: "(?:\\.|[^"$`\\\n\r])*"
742
- // In bash double quotes, only \$, \`, \", \\, and \newline are special.
743
- // Other \x sequences are harmless, so we allow \. inside double quotes.
744
- // We still exclude raw $ and ` (without backslash) to block expansion.
745
- // - Unquoted values: excludes shell metacharacters, allows backslash escapes
746
- // - Concatenated segments: FOO='x'y"z" — bash concatenates adjacent segments
747
- //
748
- // SECURITY: Trailing whitespace MUST be [ \t]+ (horizontal only), NOT \s+.
749
- //
750
- // The outer * matches one atomic unit per iteration: a complete quoted
751
- // string, a backslash-escape pair, or a single unquoted safe character.
752
- // The inner double-quote alternation (?:...|...)* is bounded by the
753
- // closing ", so it cannot interact with the outer * for backtracking.
754
- //
755
- // Note: $ is excluded from unquoted/double-quoted value classes to block
756
- // dangerous forms like $(cmd), ${var}, and $((expr)). This means
757
- // FOO=$VAR is not stripped — adding $VAR matching creates ReDoS risk
758
- // (CodeQL #671) and $VAR bypasses are low-priority.
759
- const ENV_VAR_PATTERN =
760
- /^([A-Za-z_][A-Za-z0-9_]*(?:\[[^\]]*\])?)\+?=(?:'[^'\n\r]*'|"(?:\\.|[^"$`\\\n\r])*"|\\.|[^ \t\n\r$`;|&()<>\\\\'"])*[ \t]+/
761
-
762
- let stripped = command
763
- let previousStripped = ''
764
-
765
- while (stripped !== previousStripped) {
766
- previousStripped = stripped
767
- stripped = stripCommentLines(stripped)
768
-
769
- const m = stripped.match(ENV_VAR_PATTERN)
770
- if (!m) continue
771
- if (blocklist?.test(m[1]!)) break
772
- stripped = stripped.slice(m[0].length)
773
- }
774
-
775
- return stripped.trim()
776
- }
777
-
778
- function filterRulesByContentsMatchingInput(
779
- input: z.infer<typeof BashTool.inputSchema>,
780
- rules: Map<string, PermissionRule>,
781
- matchMode: 'exact' | 'prefix',
782
- {
783
- stripAllEnvVars = false,
784
- skipCompoundCheck = false,
785
- }: { stripAllEnvVars?: boolean; skipCompoundCheck?: boolean } = {},
786
- ): PermissionRule[] {
787
- const command = input.command.trim()
788
-
789
- // Strip output redirections for permission matching
790
- // This allows rules like Bash(python:*) to match "python script.py > output.txt"
791
- // Security validation of redirection targets happens separately in checkPathConstraints
792
- const commandWithoutRedirections =
793
- extractOutputRedirections(command).commandWithoutRedirections
794
-
795
- // For exact matching, try both the original command (to preserve quotes)
796
- // and the command without redirections (to allow rules without redirections to match)
797
- // For prefix matching, only use the command without redirections
798
- const commandsForMatching =
799
- matchMode === 'exact'
800
- ? [command, commandWithoutRedirections]
801
- : [commandWithoutRedirections]
802
-
803
- // Strip safe wrapper commands (timeout, time, nice, nohup) and env vars for matching
804
- // This allows rules like Bash(npm install:*) to match "timeout 10 npm install foo"
805
- // or "GOOS=linux go build"
806
- const commandsToTry = commandsForMatching.flatMap(cmd => {
807
- const strippedCommand = stripSafeWrappers(cmd)
808
- return strippedCommand !== cmd ? [cmd, strippedCommand] : [cmd]
809
- })
810
-
811
- // SECURITY: For deny/ask rules, also try matching after stripping ALL leading
812
- // env var prefixes. This prevents bypass via `FOO=bar denied_command` where
813
- // FOO is not in the safe-list. The safe-list restriction in stripSafeWrappers
814
- // is intentional for allow rules (see HackerOne #3543050), but deny rules
815
- // must be harder to circumvent — a denied command should stay denied
816
- // regardless of env var prefixes.
817
- //
818
- // We iteratively apply both stripping operations to all candidates until no
819
- // new candidates are produced (fixed-point). This handles interleaved patterns
820
- // like `nohup FOO=bar timeout 5 claude` where:
821
- // 1. stripSafeWrappers strips `nohup` → `FOO=bar timeout 5 claude`
822
- // 2. stripAllLeadingEnvVars strips `FOO=bar` → `timeout 5 claude`
823
- // 3. stripSafeWrappers strips `timeout 5` → `claude` (deny match)
824
- //
825
- // Without iteration, single-pass compositions miss multi-layer interleaving.
826
- if (stripAllEnvVars) {
827
- const seen = new Set(commandsToTry)
828
- let startIdx = 0
829
-
830
- // Iterate until no new candidates are produced (fixed-point)
831
- while (startIdx < commandsToTry.length) {
832
- const endIdx = commandsToTry.length
833
- for (let i = startIdx; i < endIdx; i++) {
834
- const cmd = commandsToTry[i]
835
- if (!cmd) {
836
- continue
837
- }
838
- // Try stripping env vars
839
- const envStripped = stripAllLeadingEnvVars(cmd)
840
- if (!seen.has(envStripped)) {
841
- commandsToTry.push(envStripped)
842
- seen.add(envStripped)
843
- }
844
- // Try stripping safe wrappers
845
- const wrapperStripped = stripSafeWrappers(cmd)
846
- if (!seen.has(wrapperStripped)) {
847
- commandsToTry.push(wrapperStripped)
848
- seen.add(wrapperStripped)
849
- }
850
- }
851
- startIdx = endIdx
852
- }
853
- }
854
-
855
- // Precompute compound-command status for each candidate to avoid re-parsing
856
- // inside the rule filter loop (which would scale splitCommand calls with
857
- // rules.length × commandsToTry.length). The compound check only applies to
858
- // prefix/wildcard matching in 'prefix' mode, and only for allow rules.
859
- // SECURITY: deny/ask rules must match compound commands so they can't be
860
- // bypassed by wrapping a denied command in a compound expression.
861
- const isCompoundCommand = new Map<string, boolean>()
862
- if (matchMode === 'prefix' && !skipCompoundCheck) {
863
- for (const cmd of commandsToTry) {
864
- if (!isCompoundCommand.has(cmd)) {
865
- isCompoundCommand.set(cmd, splitCommand(cmd).length > 1)
866
- }
867
- }
868
- }
869
-
870
- return Array.from(rules.entries())
871
- .filter(([ruleContent]) => {
872
- const bashRule = bashPermissionRule(ruleContent)
873
-
874
- return commandsToTry.some(cmdToMatch => {
875
- switch (bashRule.type) {
876
- case 'exact':
877
- return bashRule.command === cmdToMatch
878
- case 'prefix':
879
- switch (matchMode) {
880
- // In 'exact' mode, only return true if the command exactly matches the prefix rule
881
- case 'exact':
882
- return bashRule.prefix === cmdToMatch
883
- case 'prefix': {
884
- // SECURITY: Don't allow prefix rules to match compound commands.
885
- // e.g., Bash(cd:*) must NOT match "cd /path && python3 evil.py".
886
- // In the normal flow commands are split before reaching here, but
887
- // shell escaping can defeat the first splitCommand pass — e.g.,
888
- // cd src\&\& python3 hello.py → splitCommand → ["cd src&& python3 hello.py"]
889
- // which then looks like a single command that starts with "cd ".
890
- // Re-splitting the candidate here catches those cases.
891
- if (isCompoundCommand.get(cmdToMatch)) {
892
- return false
893
- }
894
- // Ensure word boundary: prefix must be followed by space or end of string
895
- // This prevents "ls:*" from matching "lsof" or "lsattr"
896
- if (cmdToMatch === bashRule.prefix) {
897
- return true
898
- }
899
- if (cmdToMatch.startsWith(bashRule.prefix + ' ')) {
900
- return true
901
- }
902
- // Also match "xargs <prefix>" for bare xargs with no flags.
903
- // This allows Bash(grep:*) to match "xargs grep pattern",
904
- // and deny rules like Bash(rm:*) to block "xargs rm file".
905
- // Natural word-boundary: "xargs -n1 grep" does NOT start with
906
- // "xargs grep " so flagged xargs invocations are not matched.
907
- const xargsPrefix = 'xargs ' + bashRule.prefix
908
- if (cmdToMatch === xargsPrefix) {
909
- return true
910
- }
911
- return cmdToMatch.startsWith(xargsPrefix + ' ')
912
- }
913
- }
914
- break
915
- case 'wildcard':
916
- // SECURITY FIX: In exact match mode, wildcards must NOT match because we're
917
- // checking the full unparsed command. Wildcard matching on unparsed commands
918
- // allows "foo *" to match "foo arg && curl evil.com" since .* matches operators.
919
- // Wildcards should only match after splitting into individual subcommands.
920
- if (matchMode === 'exact') {
921
- return false
922
- }
923
- // SECURITY: Same as for prefix rules, don't allow wildcard rules to match
924
- // compound commands in prefix mode. e.g., Bash(cd *) must not match
925
- // "cd /path && python3 evil.py" even though "cd *" pattern would match it.
926
- if (isCompoundCommand.get(cmdToMatch)) {
927
- return false
928
- }
929
- // In prefix mode (after splitting), wildcards can safely match subcommands
930
- return matchWildcardPattern(bashRule.pattern, cmdToMatch)
931
- }
932
- })
933
- })
934
- .map(([, rule]) => rule)
935
- }
936
-
937
- function matchingRulesForInput(
938
- input: z.infer<typeof BashTool.inputSchema>,
939
- toolPermissionContext: ToolPermissionContext,
940
- matchMode: 'exact' | 'prefix',
941
- { skipCompoundCheck = false }: { skipCompoundCheck?: boolean } = {},
942
- ) {
943
- const denyRuleByContents = getRuleByContentsForTool(
944
- toolPermissionContext,
945
- BashTool,
946
- 'deny',
947
- )
948
- // SECURITY: Deny/ask rules use aggressive env var stripping so that
949
- // `FOO=bar denied_command` still matches a deny rule for `denied_command`.
950
- const matchingDenyRules = filterRulesByContentsMatchingInput(
951
- input,
952
- denyRuleByContents,
953
- matchMode,
954
- { stripAllEnvVars: true, skipCompoundCheck: true },
955
- )
956
-
957
- const askRuleByContents = getRuleByContentsForTool(
958
- toolPermissionContext,
959
- BashTool,
960
- 'ask',
961
- )
962
- const matchingAskRules = filterRulesByContentsMatchingInput(
963
- input,
964
- askRuleByContents,
965
- matchMode,
966
- { stripAllEnvVars: true, skipCompoundCheck: true },
967
- )
968
-
969
- const allowRuleByContents = getRuleByContentsForTool(
970
- toolPermissionContext,
971
- BashTool,
972
- 'allow',
973
- )
974
- const matchingAllowRules = filterRulesByContentsMatchingInput(
975
- input,
976
- allowRuleByContents,
977
- matchMode,
978
- { skipCompoundCheck },
979
- )
980
-
981
- return {
982
- matchingDenyRules,
983
- matchingAskRules,
984
- matchingAllowRules,
985
- }
986
- }
987
-
988
- /**
989
- * Checks if the subcommand is an exact match for a permission rule
990
- */
991
- export const bashToolCheckExactMatchPermission = (
992
- input: z.infer<typeof BashTool.inputSchema>,
993
- toolPermissionContext: ToolPermissionContext,
994
- ): PermissionResult => {
995
- const command = input.command.trim()
996
- const { matchingDenyRules, matchingAskRules, matchingAllowRules } =
997
- matchingRulesForInput(input, toolPermissionContext, 'exact')
998
-
999
- // 1. Deny if exact command was denied
1000
- if (matchingDenyRules[0] !== undefined) {
1001
- return {
1002
- behavior: 'deny',
1003
- message: `Permission to use ${BashTool.name} with command ${command} has been denied.`,
1004
- decisionReason: {
1005
- type: 'rule',
1006
- rule: matchingDenyRules[0],
1007
- },
1008
- }
1009
- }
1010
-
1011
- // 2. Ask if exact command was in ask rules
1012
- if (matchingAskRules[0] !== undefined) {
1013
- return {
1014
- behavior: 'ask',
1015
- message: createPermissionRequestMessage(BashTool.name),
1016
- decisionReason: {
1017
- type: 'rule',
1018
- rule: matchingAskRules[0],
1019
- },
1020
- }
1021
- }
1022
-
1023
- // 3. Allow if exact command was allowed
1024
- if (matchingAllowRules[0] !== undefined) {
1025
- return {
1026
- behavior: 'allow',
1027
- updatedInput: input,
1028
- decisionReason: {
1029
- type: 'rule',
1030
- rule: matchingAllowRules[0],
1031
- },
1032
- }
1033
- }
1034
-
1035
- // 4. Otherwise, passthrough
1036
- const decisionReason = {
1037
- type: 'other' as const,
1038
- reason: 'This command requires approval',
1039
- }
1040
- return {
1041
- behavior: 'passthrough',
1042
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
1043
- decisionReason,
1044
- // Suggest exact match rule to user
1045
- // this may be overridden by prefix suggestions in `checkCommandAndSuggestRules()`
1046
- suggestions: suggestionForExactCommand(command),
1047
- }
1048
- }
1049
-
1050
- export const bashToolCheckPermission = (
1051
- input: z.infer<typeof BashTool.inputSchema>,
1052
- toolPermissionContext: ToolPermissionContext,
1053
- compoundCommandHasCd?: boolean,
1054
- astCommand?: SimpleCommand,
1055
- ): PermissionResult => {
1056
- const command = input.command.trim()
1057
-
1058
- // 1. Check exact match first
1059
- const exactMatchResult = bashToolCheckExactMatchPermission(
1060
- input,
1061
- toolPermissionContext,
1062
- )
1063
-
1064
- // 1a. Deny/ask if exact command has a rule
1065
- if (
1066
- exactMatchResult.behavior === 'deny' ||
1067
- exactMatchResult.behavior === 'ask'
1068
- ) {
1069
- return exactMatchResult
1070
- }
1071
-
1072
- // 2. Find all matching rules (prefix or exact)
1073
- // SECURITY FIX: Check Bash deny/ask rules BEFORE path constraints to prevent bypass
1074
- // via absolute paths outside the project directory (HackerOne report)
1075
- // When AST-parsed, the subcommand is already atomic — skip the legacy
1076
- // splitCommand re-check that misparses mid-word # as compound.
1077
- const { matchingDenyRules, matchingAskRules, matchingAllowRules } =
1078
- matchingRulesForInput(input, toolPermissionContext, 'prefix', {
1079
- skipCompoundCheck: astCommand !== undefined,
1080
- })
1081
-
1082
- // 2a. Deny if command has a deny rule
1083
- if (matchingDenyRules[0] !== undefined) {
1084
- return {
1085
- behavior: 'deny',
1086
- message: `Permission to use ${BashTool.name} with command ${command} has been denied.`,
1087
- decisionReason: {
1088
- type: 'rule',
1089
- rule: matchingDenyRules[0],
1090
- },
1091
- }
1092
- }
1093
-
1094
- // 2b. Ask if command has an ask rule
1095
- if (matchingAskRules[0] !== undefined) {
1096
- return {
1097
- behavior: 'ask',
1098
- message: createPermissionRequestMessage(BashTool.name),
1099
- decisionReason: {
1100
- type: 'rule',
1101
- rule: matchingAskRules[0],
1102
- },
1103
- }
1104
- }
1105
-
1106
- // 3. Check path constraints
1107
- // This check comes after deny/ask rules so explicit rules take precedence.
1108
- // SECURITY: When AST-derived argv is available for this subcommand, pass
1109
- // it through so checkPathConstraints uses it directly instead of re-parsing
1110
- // with shell-quote (which has a single-quote backslash bug that causes
1111
- // parseCommandArguments to return [] and silently skip path validation).
1112
- const pathResult = checkPathConstraints(
1113
- input,
1114
- getCwd(),
1115
- toolPermissionContext,
1116
- compoundCommandHasCd,
1117
- astCommand?.redirects,
1118
- astCommand ? [astCommand] : undefined,
1119
- )
1120
- if (pathResult.behavior !== 'passthrough') {
1121
- return pathResult
1122
- }
1123
-
1124
- // 4. Allow if command had an exact match allow
1125
- if (exactMatchResult.behavior === 'allow') {
1126
- return exactMatchResult
1127
- }
1128
-
1129
- // 5. Allow if command has an allow rule
1130
- if (matchingAllowRules[0] !== undefined) {
1131
- return {
1132
- behavior: 'allow',
1133
- updatedInput: input,
1134
- decisionReason: {
1135
- type: 'rule',
1136
- rule: matchingAllowRules[0],
1137
- },
1138
- }
1139
- }
1140
-
1141
- // 5b. Check sed constraints (blocks dangerous sed operations before mode auto-allow)
1142
- const sedConstraintResult = checkSedConstraints(input, toolPermissionContext)
1143
- if (sedConstraintResult.behavior !== 'passthrough') {
1144
- return sedConstraintResult
1145
- }
1146
-
1147
- // 6. Check for mode-specific permission handling
1148
- const modeResult = checkPermissionMode(input, toolPermissionContext)
1149
- if (modeResult.behavior !== 'passthrough') {
1150
- return modeResult
1151
- }
1152
-
1153
- // 7. Check read-only rules
1154
- if (BashTool.isReadOnly(input)) {
1155
- return {
1156
- behavior: 'allow',
1157
- updatedInput: input,
1158
- decisionReason: {
1159
- type: 'other',
1160
- reason: 'Read-only command is allowed',
1161
- },
1162
- }
1163
- }
1164
-
1165
- // 8. Passthrough since no rules match, will trigger permission prompt
1166
- const decisionReason = {
1167
- type: 'other' as const,
1168
- reason: 'This command requires approval',
1169
- }
1170
- return {
1171
- behavior: 'passthrough',
1172
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
1173
- decisionReason,
1174
- // Suggest exact match rule to user
1175
- // this may be overridden by prefix suggestions in `checkCommandAndSuggestRules()`
1176
- suggestions: suggestionForExactCommand(command),
1177
- }
1178
- }
1179
-
1180
- /**
1181
- * Processes an individual subcommand and applies prefix checks & suggestions
1182
- */
1183
- export async function checkCommandAndSuggestRules(
1184
- input: z.infer<typeof BashTool.inputSchema>,
1185
- toolPermissionContext: ToolPermissionContext,
1186
- commandPrefixResult: CommandPrefixResult | null | undefined,
1187
- compoundCommandHasCd?: boolean,
1188
- astParseSucceeded?: boolean,
1189
- ): Promise<PermissionResult> {
1190
- // 1. Check exact match first
1191
- const exactMatchResult = bashToolCheckExactMatchPermission(
1192
- input,
1193
- toolPermissionContext,
1194
- )
1195
- if (exactMatchResult.behavior !== 'passthrough') {
1196
- return exactMatchResult
1197
- }
1198
-
1199
- // 2. Check the command prefix
1200
- const permissionResult = bashToolCheckPermission(
1201
- input,
1202
- toolPermissionContext,
1203
- compoundCommandHasCd,
1204
- )
1205
- // 2a. Deny/ask if command was explictly denied/asked
1206
- if (
1207
- permissionResult.behavior === 'deny' ||
1208
- permissionResult.behavior === 'ask'
1209
- ) {
1210
- return permissionResult
1211
- }
1212
-
1213
- // 3. Ask for permission if command injection is detected. Skip when the
1214
- // AST parse already succeeded — tree-sitter has verified there are no
1215
- // hidden substitutions or structural tricks, so the legacy regex-based
1216
- // validators (backslash-escaped operators, etc.) would only add FPs.
1217
- if (
1218
- !astParseSucceeded &&
1219
- !isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_COMMAND_INJECTION_CHECK)
1220
- ) {
1221
- const safetyResult = await bashCommandIsSafeAsync(input.command)
1222
-
1223
- if (safetyResult.behavior !== 'passthrough') {
1224
- const decisionReason: PermissionDecisionReason = {
1225
- type: 'other' as const,
1226
- reason:
1227
- safetyResult.behavior === 'ask' && safetyResult.message
1228
- ? safetyResult.message
1229
- : 'This command contains patterns that could pose security risks and requires approval',
1230
- }
1231
-
1232
- return {
1233
- behavior: 'ask',
1234
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
1235
- decisionReason,
1236
- suggestions: [], // Don't suggest saving a potentially dangerous command
1237
- }
1238
- }
1239
- }
1240
-
1241
- // 4. Allow if command was allowed
1242
- if (permissionResult.behavior === 'allow') {
1243
- return permissionResult
1244
- }
1245
-
1246
- // 5. Suggest prefix if available, otherwise exact command
1247
- const suggestedUpdates = commandPrefixResult?.commandPrefix
1248
- ? suggestionForPrefix(commandPrefixResult.commandPrefix)
1249
- : suggestionForExactCommand(input.command)
1250
-
1251
- return {
1252
- ...permissionResult,
1253
- suggestions: suggestedUpdates,
1254
- }
1255
- }
1256
-
1257
- /**
1258
- * Checks if a command should be auto-allowed when sandboxed.
1259
- * Returns early if there are explicit deny/ask rules that should be respected.
1260
- *
1261
- * NOTE: This function should only be called when sandboxing and auto-allow are enabled.
1262
- *
1263
- * @param input - The bash tool input
1264
- * @param toolPermissionContext - The permission context
1265
- * @returns PermissionResult with:
1266
- * - deny/ask if explicit rule exists (exact or prefix)
1267
- * - allow if no explicit rules (sandbox auto-allow applies)
1268
- * - passthrough should not occur since we're in auto-allow mode
1269
- */
1270
- function checkSandboxAutoAllow(
1271
- input: z.infer<typeof BashTool.inputSchema>,
1272
- toolPermissionContext: ToolPermissionContext,
1273
- ): PermissionResult {
1274
- const command = input.command.trim()
1275
-
1276
- // Check for explicit deny/ask rules on the full command (exact + prefix)
1277
- const { matchingDenyRules, matchingAskRules } = matchingRulesForInput(
1278
- input,
1279
- toolPermissionContext,
1280
- 'prefix',
1281
- )
1282
-
1283
- // Return immediately if there's an explicit deny rule on the full command
1284
- if (matchingDenyRules[0] !== undefined) {
1285
- return {
1286
- behavior: 'deny',
1287
- message: `Permission to use ${BashTool.name} with command ${command} has been denied.`,
1288
- decisionReason: {
1289
- type: 'rule',
1290
- rule: matchingDenyRules[0],
1291
- },
1292
- }
1293
- }
1294
-
1295
- // SECURITY: For compound commands, check each subcommand against deny/ask
1296
- // rules. Prefix rules like Bash(rm:*) won't match the full compound command
1297
- // (e.g., "echo hello && rm -rf /" doesn't start with "rm"), so we must
1298
- // check each subcommand individually.
1299
- // IMPORTANT: Subcommand deny checks must run BEFORE full-command ask returns.
1300
- // Otherwise a wildcard ask rule matching the full command (e.g., Bash(*echo*))
1301
- // would return 'ask' before a prefix deny rule on a subcommand (e.g., Bash(rm:*))
1302
- // gets checked, downgrading a deny to an ask.
1303
- const subcommands = splitCommand(command)
1304
- if (subcommands.length > 1) {
1305
- let firstAskRule: PermissionRule | undefined
1306
- for (const sub of subcommands) {
1307
- const subResult = matchingRulesForInput(
1308
- { command: sub },
1309
- toolPermissionContext,
1310
- 'prefix',
1311
- )
1312
- // Deny takes priority — return immediately
1313
- if (subResult.matchingDenyRules[0] !== undefined) {
1314
- return {
1315
- behavior: 'deny',
1316
- message: `Permission to use ${BashTool.name} with command ${command} has been denied.`,
1317
- decisionReason: {
1318
- type: 'rule',
1319
- rule: subResult.matchingDenyRules[0],
1320
- },
1321
- }
1322
- }
1323
- // Stash first ask match; don't return yet (deny across all subs takes priority)
1324
- firstAskRule ??= subResult.matchingAskRules[0]
1325
- }
1326
- if (firstAskRule) {
1327
- return {
1328
- behavior: 'ask',
1329
- message: createPermissionRequestMessage(BashTool.name),
1330
- decisionReason: {
1331
- type: 'rule',
1332
- rule: firstAskRule,
1333
- },
1334
- }
1335
- }
1336
- }
1337
-
1338
- // Full-command ask check (after all deny sources have been exhausted)
1339
- if (matchingAskRules[0] !== undefined) {
1340
- return {
1341
- behavior: 'ask',
1342
- message: createPermissionRequestMessage(BashTool.name),
1343
- decisionReason: {
1344
- type: 'rule',
1345
- rule: matchingAskRules[0],
1346
- },
1347
- }
1348
- }
1349
- // No explicit rules, so auto-allow with sandbox
1350
-
1351
- return {
1352
- behavior: 'allow',
1353
- updatedInput: input,
1354
- decisionReason: {
1355
- type: 'other',
1356
- reason: 'Auto-allowed with sandbox (autoAllowBashIfSandboxed enabled)',
1357
- },
1358
- }
1359
- }
1360
-
1361
- /**
1362
- * Filter out `cd ${cwd}` prefix subcommands, keeping astCommands aligned.
1363
- * Extracted to keep bashToolHasPermission under Bun's feature() DCE
1364
- * complexity threshold — inlining this breaks pendingClassifierCheck
1365
- * attachment in ~10 classifier tests.
1366
- */
1367
- function filterCdCwdSubcommands(
1368
- rawSubcommands: string[],
1369
- astCommands: SimpleCommand[] | undefined,
1370
- cwd: string,
1371
- cwdMingw: string,
1372
- ): { subcommands: string[]; astCommandsByIdx: (SimpleCommand | undefined)[] } {
1373
- const subcommands: string[] = []
1374
- const astCommandsByIdx: (SimpleCommand | undefined)[] = []
1375
- for (let i = 0; i < rawSubcommands.length; i++) {
1376
- const cmd = rawSubcommands[i]!
1377
- if (cmd === `cd ${cwd}` || cmd === `cd ${cwdMingw}`) continue
1378
- subcommands.push(cmd)
1379
- astCommandsByIdx.push(astCommands?.[i])
1380
- }
1381
- return { subcommands, astCommandsByIdx }
1382
- }
1383
-
1384
- /**
1385
- * Early-exit deny enforcement for the AST too-complex and checkSemantics
1386
- * paths. Returns the exact-match result if non-passthrough (deny/ask/allow),
1387
- * then checks prefix/wildcard deny rules. Returns null if neither matched,
1388
- * meaning the caller should fall through to ask. Extracted to keep
1389
- * bashToolHasPermission under Bun's feature() DCE complexity threshold.
1390
- */
1391
- function checkEarlyExitDeny(
1392
- input: z.infer<typeof BashTool.inputSchema>,
1393
- toolPermissionContext: ToolPermissionContext,
1394
- ): PermissionResult | null {
1395
- const exactMatchResult = bashToolCheckExactMatchPermission(
1396
- input,
1397
- toolPermissionContext,
1398
- )
1399
- if (exactMatchResult.behavior !== 'passthrough') {
1400
- return exactMatchResult
1401
- }
1402
- const denyMatch = matchingRulesForInput(
1403
- input,
1404
- toolPermissionContext,
1405
- 'prefix',
1406
- ).matchingDenyRules[0]
1407
- if (denyMatch !== undefined) {
1408
- return {
1409
- behavior: 'deny',
1410
- message: `Permission to use ${BashTool.name} with command ${input.command} has been denied.`,
1411
- decisionReason: { type: 'rule', rule: denyMatch },
1412
- }
1413
- }
1414
- return null
1415
- }
1416
-
1417
- /**
1418
- * checkSemantics-path deny enforcement. Calls checkEarlyExitDeny (exact-match
1419
- * + full-command prefix deny), then checks each individual SimpleCommand .text
1420
- * span against prefix deny rules. The per-subcommand check is needed because
1421
- * filterRulesByContentsMatchingInput has a compound-command guard
1422
- * (splitCommand().length > 1 → prefix rules return false) that defeats
1423
- * `Bash(eval:*)` matching against a full pipeline like `echo foo | eval rm`.
1424
- * Each SimpleCommand span is a single command, so the guard doesn't fire.
1425
- *
1426
- * Separate helper (not folded into checkEarlyExitDeny or inlined at the call
1427
- * site) because bashToolHasPermission is tight against Bun's feature() DCE
1428
- * complexity threshold — adding even ~5 lines there breaks
1429
- * feature('BASH_CLASSIFIER') evaluation and drops pendingClassifierCheck.
1430
- */
1431
- function checkSemanticsDeny(
1432
- input: z.infer<typeof BashTool.inputSchema>,
1433
- toolPermissionContext: ToolPermissionContext,
1434
- commands: readonly { text: string }[],
1435
- ): PermissionResult | null {
1436
- const fullCmd = checkEarlyExitDeny(input, toolPermissionContext)
1437
- if (fullCmd !== null) return fullCmd
1438
- for (const cmd of commands) {
1439
- const subDeny = matchingRulesForInput(
1440
- { ...input, command: cmd.text },
1441
- toolPermissionContext,
1442
- 'prefix',
1443
- ).matchingDenyRules[0]
1444
- if (subDeny !== undefined) {
1445
- return {
1446
- behavior: 'deny',
1447
- message: `Permission to use ${BashTool.name} with command ${input.command} has been denied.`,
1448
- decisionReason: { type: 'rule', rule: subDeny },
1449
- }
1450
- }
1451
- }
1452
- return null
1453
- }
1454
-
1455
- /**
1456
- * Builds the pending classifier check metadata if classifier is enabled and has allow descriptions.
1457
- * Returns undefined if classifier is disabled, in auto mode, or no allow descriptions exist.
1458
- */
1459
- function buildPendingClassifierCheck(
1460
- command: string,
1461
- toolPermissionContext: ToolPermissionContext,
1462
- ): { command: string; cwd: string; descriptions: string[] } | undefined {
1463
- if (!isClassifierPermissionsEnabled()) {
1464
- return undefined
1465
- }
1466
- // Skip in auto mode - auto mode classifier handles all permission decisions
1467
- if (feature('TRANSCRIPT_CLASSIFIER') && toolPermissionContext.mode === 'auto')
1468
- return undefined
1469
- if (toolPermissionContext.mode === 'bypassPermissions') return undefined
1470
-
1471
- const allowDescriptions = getBashPromptAllowDescriptions(
1472
- toolPermissionContext,
1473
- )
1474
- if (allowDescriptions.length === 0) return undefined
1475
-
1476
- return {
1477
- command,
1478
- cwd: getCwd(),
1479
- descriptions: allowDescriptions,
1480
- }
1481
- }
1482
-
1483
- const speculativeChecks = new Map<string, Promise<ClassifierResult>>()
1484
-
1485
- /**
1486
- * Start a speculative bash allow classifier check early, so it runs in
1487
- * parallel with pre-tool hooks, deny/ask classifiers, and permission dialog setup.
1488
- * The result can be consumed later by executeAsyncClassifierCheck via
1489
- * consumeSpeculativeClassifierCheck.
1490
- */
1491
- export function peekSpeculativeClassifierCheck(
1492
- command: string,
1493
- ): Promise<ClassifierResult> | undefined {
1494
- return speculativeChecks.get(command)
1495
- }
1496
-
1497
- export function startSpeculativeClassifierCheck(
1498
- command: string,
1499
- toolPermissionContext: ToolPermissionContext,
1500
- signal: AbortSignal,
1501
- isNonInteractiveSession: boolean,
1502
- ): boolean {
1503
- // Same guards as buildPendingClassifierCheck
1504
- if (!isClassifierPermissionsEnabled()) return false
1505
- if (feature('TRANSCRIPT_CLASSIFIER') && toolPermissionContext.mode === 'auto')
1506
- return false
1507
- if (toolPermissionContext.mode === 'bypassPermissions') return false
1508
- const allowDescriptions = getBashPromptAllowDescriptions(
1509
- toolPermissionContext,
1510
- )
1511
- if (allowDescriptions.length === 0) return false
1512
-
1513
- const cwd = getCwd()
1514
- const promise = classifyBashCommand(
1515
- command,
1516
- cwd,
1517
- allowDescriptions,
1518
- 'allow',
1519
- signal,
1520
- isNonInteractiveSession,
1521
- )
1522
- // Prevent unhandled rejection if the signal aborts before this promise is consumed.
1523
- // The original promise (which may reject) is still stored in the Map for consumers to await.
1524
- promise.catch(() => {})
1525
- speculativeChecks.set(command, promise)
1526
- return true
1527
- }
1528
-
1529
- /**
1530
- * Consume a speculative classifier check result for the given command.
1531
- * Returns the promise if one exists (and removes it from the map), or undefined.
1532
- */
1533
- export function consumeSpeculativeClassifierCheck(
1534
- command: string,
1535
- ): Promise<ClassifierResult> | undefined {
1536
- const promise = speculativeChecks.get(command)
1537
- if (promise) {
1538
- speculativeChecks.delete(command)
1539
- }
1540
- return promise
1541
- }
1542
-
1543
- export function clearSpeculativeChecks(): void {
1544
- speculativeChecks.clear()
1545
- }
1546
-
1547
- /**
1548
- * Await a pending classifier check and return a PermissionDecisionReason if
1549
- * high-confidence allow, or undefined otherwise.
1550
- *
1551
- * Used by swarm agents (both tmux and in-process) to gate permission
1552
- * forwarding: run the classifier first, and only escalate to the leader
1553
- * if the classifier doesn't auto-approve.
1554
- */
1555
- export async function awaitClassifierAutoApproval(
1556
- pendingCheck: PendingClassifierCheck,
1557
- signal: AbortSignal,
1558
- isNonInteractiveSession: boolean,
1559
- ): Promise<PermissionDecisionReason | undefined> {
1560
- const { command, cwd, descriptions } = pendingCheck
1561
- const speculativeResult = consumeSpeculativeClassifierCheck(command)
1562
- const classifierResult = speculativeResult
1563
- ? await speculativeResult
1564
- : await classifyBashCommand(
1565
- command,
1566
- cwd,
1567
- descriptions,
1568
- 'allow',
1569
- signal,
1570
- isNonInteractiveSession,
1571
- )
1572
-
1573
- logClassifierResultForAnts(command, 'allow', descriptions, classifierResult)
1574
-
1575
- if (
1576
- feature('BASH_CLASSIFIER') &&
1577
- classifierResult.matches &&
1578
- classifierResult.confidence === 'high'
1579
- ) {
1580
- return {
1581
- type: 'classifier',
1582
- classifier: 'bash_allow',
1583
- reason: `Allowed by prompt rule: "${classifierResult.matchedDescription}"`,
1584
- }
1585
- }
1586
- return undefined
1587
- }
1588
-
1589
- type AsyncClassifierCheckCallbacks = {
1590
- shouldContinue: () => boolean
1591
- onAllow: (decisionReason: PermissionDecisionReason) => void
1592
- onComplete?: () => void
1593
- }
1594
-
1595
- /**
1596
- * Execute the bash allow classifier check asynchronously.
1597
- * This runs in the background while the permission prompt is shown.
1598
- * If the classifier allows with high confidence and the user hasn't interacted, auto-approves.
1599
- *
1600
- * @param pendingCheck - Classifier check metadata from bashToolHasPermission
1601
- * @param signal - Abort signal
1602
- * @param isNonInteractiveSession - Whether this is a non-interactive session
1603
- * @param callbacks - Callbacks to check if we should continue and handle approval
1604
- */
1605
- export async function executeAsyncClassifierCheck(
1606
- pendingCheck: { command: string; cwd: string; descriptions: string[] },
1607
- signal: AbortSignal,
1608
- isNonInteractiveSession: boolean,
1609
- callbacks: AsyncClassifierCheckCallbacks,
1610
- ): Promise<void> {
1611
- const { command, cwd, descriptions } = pendingCheck
1612
- const speculativeResult = consumeSpeculativeClassifierCheck(command)
1613
-
1614
- let classifierResult: ClassifierResult
1615
- try {
1616
- classifierResult = speculativeResult
1617
- ? await speculativeResult
1618
- : await classifyBashCommand(
1619
- command,
1620
- cwd,
1621
- descriptions,
1622
- 'allow',
1623
- signal,
1624
- isNonInteractiveSession,
1625
- )
1626
- } catch (error: unknown) {
1627
- // When the coordinator session is cancelled, the abort signal fires and the
1628
- // classifier API call rejects with APIUserAbortError. This is expected and
1629
- // should not surface as an unhandled promise rejection.
1630
- if (error instanceof APIUserAbortError || error instanceof AbortError) {
1631
- callbacks.onComplete?.()
1632
- return
1633
- }
1634
- callbacks.onComplete?.()
1635
- throw error
1636
- }
1637
-
1638
- logClassifierResultForAnts(command, 'allow', descriptions, classifierResult)
1639
-
1640
- // Don't auto-approve if user already made a decision or has interacted
1641
- // with the permission dialog (e.g., arrow keys, tab, typing)
1642
- if (!callbacks.shouldContinue()) return
1643
-
1644
- if (
1645
- feature('BASH_CLASSIFIER') &&
1646
- classifierResult.matches &&
1647
- classifierResult.confidence === 'high'
1648
- ) {
1649
- callbacks.onAllow({
1650
- type: 'classifier',
1651
- classifier: 'bash_allow',
1652
- reason: `Allowed by prompt rule: "${classifierResult.matchedDescription}"`,
1653
- })
1654
- } else {
1655
- // No match — notify so the checking indicator is cleared
1656
- callbacks.onComplete?.()
1657
- }
1658
- }
1659
-
1660
- /**
1661
- * The main implementation to check if we need to ask for user permission to call BashTool with a given input
1662
- */
1663
- export async function bashToolHasPermission(
1664
- input: z.infer<typeof BashTool.inputSchema>,
1665
- context: ToolUseContext,
1666
- getCommandSubcommandPrefixFn = getCommandSubcommandPrefix,
1667
- ): Promise<PermissionResult> {
1668
- let appState = context.getAppState()
1669
-
1670
- // 0. AST-based security parse. This replaces both tryParseShellCommand
1671
- // (the shell-quote pre-check) and the bashCommandIsSafe misparsing gate.
1672
- // tree-sitter produces either a clean SimpleCommand[] (quotes resolved,
1673
- // no hidden substitutions) or 'too-complex' — which is exactly the signal
1674
- // we need to decide whether splitCommand's output can be trusted.
1675
- //
1676
- // When tree-sitter WASM is unavailable OR the injection check is disabled
1677
- // via env var, we fall back to the old path (legacy gate at ~1370 runs).
1678
- const injectionCheckDisabled = isEnvTruthy(
1679
- process.env.CLAUDE_CODE_DISABLE_COMMAND_INJECTION_CHECK,
1680
- )
1681
- // GrowthBook killswitch for shadow mode — when off, skip the native parse
1682
- // entirely. Computed once; feature() must stay inline in the ternary below.
1683
- const shadowEnabled = feature('TREE_SITTER_BASH_SHADOW')
1684
- ? getFeatureValue_CACHED_MAY_BE_STALE('tengu_birch_trellis', true)
1685
- : false
1686
- // Parse once here; the resulting AST feeds both parseForSecurityFromAst
1687
- // and bashToolCheckCommandOperatorPermissions.
1688
- let astRoot = injectionCheckDisabled
1689
- ? null
1690
- : feature('TREE_SITTER_BASH_SHADOW') && !shadowEnabled
1691
- ? null
1692
- : await parseCommandRaw(input.command)
1693
- let astResult: ParseForSecurityResult = astRoot
1694
- ? parseForSecurityFromAst(input.command, astRoot)
1695
- : { kind: 'parse-unavailable' }
1696
- let astSubcommands: string[] | null = null
1697
- let astRedirects: Redirect[] | undefined
1698
- let astCommands: SimpleCommand[] | undefined
1699
- let shadowLegacySubs: string[] | undefined
1700
-
1701
- // Shadow-test tree-sitter: record its verdict, then force parse-unavailable
1702
- // so the legacy path stays authoritative. parseCommand stays gated on
1703
- // TREE_SITTER_BASH (not SHADOW) so legacy internals remain pure regex.
1704
- // One event per bash call captures both divergence AND unavailability
1705
- // reasons; module-load failures are separately covered by the
1706
- // session-scoped tengu_tree_sitter_load event.
1707
- if (feature('TREE_SITTER_BASH_SHADOW')) {
1708
- const available = astResult.kind !== 'parse-unavailable'
1709
- let tooComplex = false
1710
- let semanticFail = false
1711
- let subsDiffer = false
1712
- if (available) {
1713
- tooComplex = astResult.kind === 'too-complex'
1714
- semanticFail =
1715
- astResult.kind === 'simple' && !checkSemantics(astResult.commands).ok
1716
- const tsSubs =
1717
- astResult.kind === 'simple'
1718
- ? astResult.commands.map(c => c.text)
1719
- : undefined
1720
- const legacySubs = splitCommand(input.command)
1721
- shadowLegacySubs = legacySubs
1722
- subsDiffer =
1723
- tsSubs !== undefined &&
1724
- (tsSubs.length !== legacySubs.length ||
1725
- tsSubs.some((s, i) => s !== legacySubs[i]))
1726
- }
1727
- logEvent('tengu_tree_sitter_shadow', {
1728
- available,
1729
- astTooComplex: tooComplex,
1730
- astSemanticFail: semanticFail,
1731
- subsDiffer,
1732
- injectionCheckDisabled,
1733
- killswitchOff: !shadowEnabled,
1734
- cmdOverLength: input.command.length > 10000,
1735
- })
1736
- // Always force legacy — shadow mode is observational only.
1737
- astResult = { kind: 'parse-unavailable' }
1738
- astRoot = null
1739
- }
1740
-
1741
- if (astResult.kind === 'too-complex') {
1742
- // Parse succeeded but found structure we can't statically analyze
1743
- // (command substitution, expansion, control flow, parser differential).
1744
- // Respect exact-match deny/ask/allow, then prefix/wildcard deny. Only
1745
- // fall through to ask if no deny matched — don't downgrade deny to ask.
1746
- const earlyExit = checkEarlyExitDeny(input, appState.toolPermissionContext)
1747
- if (earlyExit !== null) return earlyExit
1748
- const decisionReason: PermissionDecisionReason = {
1749
- type: 'other' as const,
1750
- reason: astResult.reason,
1751
- }
1752
- logEvent('tengu_bash_ast_too_complex', {
1753
- nodeTypeId: nodeTypeId(astResult.nodeType),
1754
- })
1755
- return {
1756
- behavior: 'ask',
1757
- decisionReason,
1758
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
1759
- suggestions: [],
1760
- ...(feature('BASH_CLASSIFIER')
1761
- ? {
1762
- pendingClassifierCheck: buildPendingClassifierCheck(
1763
- input.command,
1764
- appState.toolPermissionContext,
1765
- ),
1766
- }
1767
- : {}),
1768
- }
1769
- }
1770
-
1771
- if (astResult.kind === 'simple') {
1772
- // Clean parse: check semantic-level concerns (zsh builtins, eval, etc.)
1773
- // that tokenize fine but are dangerous by name.
1774
- const sem = checkSemantics(astResult.commands)
1775
- if (!sem.ok) {
1776
- // Same deny-rule enforcement as the too-complex path: a user with
1777
- // `Bash(eval:*)` deny expects `eval "rm"` blocked, not downgraded.
1778
- const earlyExit = checkSemanticsDeny(
1779
- input,
1780
- appState.toolPermissionContext,
1781
- astResult.commands,
1782
- )
1783
- if (earlyExit !== null) return earlyExit
1784
- const decisionReason: PermissionDecisionReason = {
1785
- type: 'other' as const,
1786
- reason: sem.reason,
1787
- }
1788
- return {
1789
- behavior: 'ask',
1790
- decisionReason,
1791
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
1792
- suggestions: [],
1793
- }
1794
- }
1795
- // Stash the tokenized subcommands for use below. Downstream code (rule
1796
- // matching, path extraction, cd detection) still operates on strings, so
1797
- // we pass the original source span for each SimpleCommand. Downstream
1798
- // processing (stripSafeWrappers, parseCommandArguments) re-tokenizes
1799
- // these spans — that re-tokenization has known bugs (stripCommentLines
1800
- // mishandles newlines inside quotes), but checkSemantics already caught
1801
- // any argv element containing a newline, so those bugs can't bite here.
1802
- // Migrating downstream to operate on argv directly is a later commit.
1803
- astSubcommands = astResult.commands.map(c => c.text)
1804
- astRedirects = astResult.commands.flatMap(c => c.redirects)
1805
- astCommands = astResult.commands
1806
- }
1807
-
1808
- // Legacy shell-quote pre-check. Only reached on 'parse-unavailable'
1809
- // (tree-sitter not loaded OR TREE_SITTER_BASH feature gated off). Falls
1810
- // through to the full legacy path below.
1811
- if (astResult.kind === 'parse-unavailable') {
1812
- logForDebugging(
1813
- 'bashToolHasPermission: tree-sitter unavailable, using legacy shell-quote path',
1814
- )
1815
- const parseResult = tryParseShellCommand(input.command)
1816
- if (!parseResult.success) {
1817
- const decisionReason = {
1818
- type: 'other' as const,
1819
- reason: `Command contains malformed syntax that cannot be parsed: ${parseResult.error}`,
1820
- }
1821
- return {
1822
- behavior: 'ask',
1823
- decisionReason,
1824
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
1825
- }
1826
- }
1827
- }
1828
-
1829
- // Check sandbox auto-allow (which respects explicit deny/ask rules)
1830
- // Only call this if sandboxing and auto-allow are both enabled
1831
- if (
1832
- SandboxManager.isSandboxingEnabled() &&
1833
- SandboxManager.isAutoAllowBashIfSandboxedEnabled() &&
1834
- shouldUseSandbox(input)
1835
- ) {
1836
- const sandboxAutoAllowResult = checkSandboxAutoAllow(
1837
- input,
1838
- appState.toolPermissionContext,
1839
- )
1840
- if (sandboxAutoAllowResult.behavior !== 'passthrough') {
1841
- return sandboxAutoAllowResult
1842
- }
1843
- }
1844
-
1845
- // Check exact match first
1846
- const exactMatchResult = bashToolCheckExactMatchPermission(
1847
- input,
1848
- appState.toolPermissionContext,
1849
- )
1850
-
1851
- // Exact command was denied
1852
- if (exactMatchResult.behavior === 'deny') {
1853
- return exactMatchResult
1854
- }
1855
-
1856
- // Check Bash prompt deny and ask rules in parallel (both use Haiku).
1857
- // Deny takes precedence over ask, and both take precedence over allow rules.
1858
- // Skip when in auto mode - auto mode classifier handles all permission decisions
1859
- if (
1860
- isClassifierPermissionsEnabled() &&
1861
- !(
1862
- feature('TRANSCRIPT_CLASSIFIER') &&
1863
- appState.toolPermissionContext.mode === 'auto'
1864
- )
1865
- ) {
1866
- const denyDescriptions = getBashPromptDenyDescriptions(
1867
- appState.toolPermissionContext,
1868
- )
1869
- const askDescriptions = getBashPromptAskDescriptions(
1870
- appState.toolPermissionContext,
1871
- )
1872
- const hasDeny = denyDescriptions.length > 0
1873
- const hasAsk = askDescriptions.length > 0
1874
-
1875
- if (hasDeny || hasAsk) {
1876
- const [denyResult, askResult] = await Promise.all([
1877
- hasDeny
1878
- ? classifyBashCommand(
1879
- input.command,
1880
- getCwd(),
1881
- denyDescriptions,
1882
- 'deny',
1883
- context.abortController.signal,
1884
- context.options.isNonInteractiveSession,
1885
- )
1886
- : null,
1887
- hasAsk
1888
- ? classifyBashCommand(
1889
- input.command,
1890
- getCwd(),
1891
- askDescriptions,
1892
- 'ask',
1893
- context.abortController.signal,
1894
- context.options.isNonInteractiveSession,
1895
- )
1896
- : null,
1897
- ])
1898
-
1899
- if (context.abortController.signal.aborted) {
1900
- throw new AbortError()
1901
- }
1902
-
1903
- if (denyResult) {
1904
- logClassifierResultForAnts(
1905
- input.command,
1906
- 'deny',
1907
- denyDescriptions,
1908
- denyResult,
1909
- )
1910
- }
1911
- if (askResult) {
1912
- logClassifierResultForAnts(
1913
- input.command,
1914
- 'ask',
1915
- askDescriptions,
1916
- askResult,
1917
- )
1918
- }
1919
-
1920
- // Deny takes precedence
1921
- if (denyResult?.matches && denyResult.confidence === 'high') {
1922
- return {
1923
- behavior: 'deny',
1924
- message: `Denied by Bash prompt rule: "${denyResult.matchedDescription}"`,
1925
- decisionReason: {
1926
- type: 'other',
1927
- reason: `Denied by Bash prompt rule: "${denyResult.matchedDescription}"`,
1928
- },
1929
- }
1930
- }
1931
-
1932
- if (askResult?.matches && askResult.confidence === 'high') {
1933
- // Skip the Haiku call — the UI computes the prefix locally
1934
- // and lets the user edit it. Still call the injected function
1935
- // when tests override it.
1936
- let suggestions: PermissionUpdate[]
1937
- if (getCommandSubcommandPrefixFn === getCommandSubcommandPrefix) {
1938
- suggestions = suggestionForExactCommand(input.command)
1939
- } else {
1940
- const commandPrefixResult = await getCommandSubcommandPrefixFn(
1941
- input.command,
1942
- context.abortController.signal,
1943
- context.options.isNonInteractiveSession,
1944
- )
1945
- if (context.abortController.signal.aborted) {
1946
- throw new AbortError()
1947
- }
1948
- suggestions = commandPrefixResult?.commandPrefix
1949
- ? suggestionForPrefix(commandPrefixResult.commandPrefix)
1950
- : suggestionForExactCommand(input.command)
1951
- }
1952
- return {
1953
- behavior: 'ask',
1954
- message: createPermissionRequestMessage(BashTool.name),
1955
- decisionReason: {
1956
- type: 'other',
1957
- reason: `Required by Bash prompt rule: "${askResult.matchedDescription}"`,
1958
- },
1959
- suggestions,
1960
- ...(feature('BASH_CLASSIFIER')
1961
- ? {
1962
- pendingClassifierCheck: buildPendingClassifierCheck(
1963
- input.command,
1964
- appState.toolPermissionContext,
1965
- ),
1966
- }
1967
- : {}),
1968
- }
1969
- }
1970
- }
1971
- }
1972
-
1973
- // Check for non-subcommand Bash operators like `>`, `|`, etc.
1974
- // This must happen before dangerous path checks so that piped commands
1975
- // are handled by the operator logic (which generates "multiple operations" messages)
1976
- const commandOperatorResult = await checkCommandOperatorPermissions(
1977
- input,
1978
- (i: z.infer<typeof BashTool.inputSchema>) =>
1979
- bashToolHasPermission(i, context, getCommandSubcommandPrefixFn),
1980
- { isNormalizedCdCommand, isNormalizedGitCommand },
1981
- astRoot,
1982
- )
1983
- if (commandOperatorResult.behavior !== 'passthrough') {
1984
- // SECURITY FIX: When pipe segment processing returns 'allow', we must still validate
1985
- // the ORIGINAL command. The pipe segment processing strips redirections before
1986
- // checking each segment, so commands like:
1987
- // echo 'x' | xargs printf '%s' >> /tmp/file
1988
- // would have both segments allowed (echo and xargs printf) but the >> redirection
1989
- // would bypass validation. We must check:
1990
- // 1. Path constraints for output redirections
1991
- // 2. Command safety for dangerous patterns (backticks, etc.) in redirect targets
1992
- if (commandOperatorResult.behavior === 'allow') {
1993
- // Check for dangerous patterns (backticks, $(), etc.) in the original command
1994
- // This catches cases like: echo x | xargs echo > `pwd`/evil.txt
1995
- // where the backtick is in the redirect target (stripped from segments)
1996
- // Gate on AST: when astSubcommands is non-null, tree-sitter already
1997
- // validated structure (backticks/$() in redirect targets would have
1998
- // returned too-complex). Matches gating at ~1481, ~1706, ~1755.
1999
- // Avoids FP: `find -exec {} \; | grep x` tripping on backslash-;.
2000
- // bashCommandIsSafe runs the full legacy regex battery (~20 patterns) —
2001
- // only call it when we'll actually use the result.
2002
- const safetyResult =
2003
- astSubcommands === null
2004
- ? await bashCommandIsSafeAsync(input.command)
2005
- : null
2006
- if (
2007
- safetyResult !== null &&
2008
- safetyResult.behavior !== 'passthrough' &&
2009
- safetyResult.behavior !== 'allow'
2010
- ) {
2011
- // Attach pending classifier check - may auto-approve before user responds
2012
- appState = context.getAppState()
2013
- return {
2014
- behavior: 'ask',
2015
- message: createPermissionRequestMessage(BashTool.name, {
2016
- type: 'other',
2017
- reason:
2018
- safetyResult.message ??
2019
- 'Command contains patterns that require approval',
2020
- }),
2021
- decisionReason: {
2022
- type: 'other',
2023
- reason:
2024
- safetyResult.message ??
2025
- 'Command contains patterns that require approval',
2026
- },
2027
- ...(feature('BASH_CLASSIFIER')
2028
- ? {
2029
- pendingClassifierCheck: buildPendingClassifierCheck(
2030
- input.command,
2031
- appState.toolPermissionContext,
2032
- ),
2033
- }
2034
- : {}),
2035
- }
2036
- }
2037
-
2038
- appState = context.getAppState()
2039
- // SECURITY: Compute compoundCommandHasCd from the full command, NOT
2040
- // hardcode false. The pipe-handling path previously passed `false` here,
2041
- // disabling the cd+redirect check at pathValidation.ts:821. Appending
2042
- // `| echo done` to `cd .claude && echo x > settings.json` routed through
2043
- // this path with compoundCommandHasCd=false, letting the redirect write
2044
- // to .claude/settings.json without the cd+redirect block firing.
2045
- const pathResult = checkPathConstraints(
2046
- input,
2047
- getCwd(),
2048
- appState.toolPermissionContext,
2049
- commandHasAnyCd(input.command),
2050
- astRedirects,
2051
- astCommands,
2052
- )
2053
- if (pathResult.behavior !== 'passthrough') {
2054
- return pathResult
2055
- }
2056
- }
2057
-
2058
- // When pipe segments return 'ask' (individual segments not allowed by rules),
2059
- // attach pending classifier check - may auto-approve before user responds.
2060
- if (commandOperatorResult.behavior === 'ask') {
2061
- appState = context.getAppState()
2062
- return {
2063
- ...commandOperatorResult,
2064
- ...(feature('BASH_CLASSIFIER')
2065
- ? {
2066
- pendingClassifierCheck: buildPendingClassifierCheck(
2067
- input.command,
2068
- appState.toolPermissionContext,
2069
- ),
2070
- }
2071
- : {}),
2072
- }
2073
- }
2074
-
2075
- return commandOperatorResult
2076
- }
2077
-
2078
- // SECURITY: Legacy misparsing gate. Only runs when the tree-sitter module
2079
- // is not loaded. Timeout/abort is fail-closed via too-complex (returned
2080
- // early above), not routed here. When the AST parse succeeded,
2081
- // astSubcommands is non-null and we've already validated structure; this
2082
- // block is skipped entirely. The AST's 'too-complex' result subsumes
2083
- // everything isBashSecurityCheckForMisparsing covered — both answer the
2084
- // same question: "can splitCommand be trusted on this input?"
2085
- if (
2086
- astSubcommands === null &&
2087
- !isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_COMMAND_INJECTION_CHECK)
2088
- ) {
2089
- const originalCommandSafetyResult = await bashCommandIsSafeAsync(
2090
- input.command,
2091
- )
2092
- if (
2093
- originalCommandSafetyResult.behavior === 'ask' &&
2094
- originalCommandSafetyResult.isBashSecurityCheckForMisparsing
2095
- ) {
2096
- // Compound commands with safe heredoc patterns ($(cat <<'EOF'...EOF))
2097
- // trigger the $() check on the unsplit command. Strip the safe heredocs
2098
- // and re-check the remainder — if other misparsing patterns exist
2099
- // (e.g. backslash-escaped operators), they must still block.
2100
- const remainder = stripSafeHeredocSubstitutions(input.command)
2101
- const remainderResult =
2102
- remainder !== null ? await bashCommandIsSafeAsync(remainder) : null
2103
- if (
2104
- remainder === null ||
2105
- (remainderResult?.behavior === 'ask' &&
2106
- remainderResult.isBashSecurityCheckForMisparsing)
2107
- ) {
2108
- // Allow if the exact command has an explicit allow permission — the user
2109
- // made a conscious choice to permit this specific command.
2110
- appState = context.getAppState()
2111
- const exactMatchResult = bashToolCheckExactMatchPermission(
2112
- input,
2113
- appState.toolPermissionContext,
2114
- )
2115
- if (exactMatchResult.behavior === 'allow') {
2116
- return exactMatchResult
2117
- }
2118
- // Attach pending classifier check - may auto-approve before user responds
2119
- const decisionReason: PermissionDecisionReason = {
2120
- type: 'other' as const,
2121
- reason: originalCommandSafetyResult.message,
2122
- }
2123
- return {
2124
- behavior: 'ask',
2125
- message: createPermissionRequestMessage(
2126
- BashTool.name,
2127
- decisionReason,
2128
- ),
2129
- decisionReason,
2130
- suggestions: [], // Don't suggest saving a potentially dangerous command
2131
- ...(feature('BASH_CLASSIFIER')
2132
- ? {
2133
- pendingClassifierCheck: buildPendingClassifierCheck(
2134
- input.command,
2135
- appState.toolPermissionContext,
2136
- ),
2137
- }
2138
- : {}),
2139
- }
2140
- }
2141
- }
2142
- }
2143
-
2144
- // Split into subcommands. Prefer the AST-extracted spans; fall back to
2145
- // splitCommand only when tree-sitter was unavailable. The cd-cwd filter
2146
- // strips the `cd ${cwd}` prefix that models like to prepend.
2147
- const cwd = getCwd()
2148
- const cwdMingw =
2149
- getPlatform() === 'windows' ? windowsPathToPosixPath(cwd) : cwd
2150
- const rawSubcommands =
2151
- astSubcommands ?? shadowLegacySubs ?? splitCommand(input.command)
2152
- const { subcommands, astCommandsByIdx } = filterCdCwdSubcommands(
2153
- rawSubcommands,
2154
- astCommands,
2155
- cwd,
2156
- cwdMingw,
2157
- )
2158
-
2159
- // CC-643: Cap subcommand fanout. Only the legacy splitCommand path can
2160
- // explode — the AST path returns a bounded list (astSubcommands !== null)
2161
- // or short-circuits to 'too-complex' for structures it can't represent.
2162
- if (
2163
- astSubcommands === null &&
2164
- subcommands.length > MAX_SUBCOMMANDS_FOR_SECURITY_CHECK
2165
- ) {
2166
- logForDebugging(
2167
- `bashPermissions: ${subcommands.length} subcommands exceeds cap (${MAX_SUBCOMMANDS_FOR_SECURITY_CHECK}) — returning ask`,
2168
- { level: 'debug' },
2169
- )
2170
- const decisionReason = {
2171
- type: 'other' as const,
2172
- reason: `Command splits into ${subcommands.length} subcommands, too many to safety-check individually`,
2173
- }
2174
- return {
2175
- behavior: 'ask',
2176
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
2177
- decisionReason,
2178
- }
2179
- }
2180
-
2181
- // Ask if there are multiple `cd` commands
2182
- const cdCommands = subcommands.filter(subCommand =>
2183
- isNormalizedCdCommand(subCommand),
2184
- )
2185
- if (cdCommands.length > 1) {
2186
- const decisionReason = {
2187
- type: 'other' as const,
2188
- reason:
2189
- 'Multiple directory changes in one command require approval for clarity',
2190
- }
2191
- return {
2192
- behavior: 'ask',
2193
- decisionReason,
2194
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
2195
- }
2196
- }
2197
-
2198
- // Track if compound command contains cd for security validation
2199
- // This prevents bypassing path checks via: cd .claude/ && mv test.txt settings.json
2200
- const compoundCommandHasCd = cdCommands.length > 0
2201
-
2202
- // SECURITY: Block compound commands that have both cd AND git
2203
- // This prevents sandbox escape via: cd /malicious/dir && git status
2204
- // where the malicious directory contains a bare git repo with core.fsmonitor.
2205
- // This check must happen HERE (before subcommand-level permission checks)
2206
- // because bashToolCheckPermission checks each subcommand independently via
2207
- // BashTool.isReadOnly(), which would re-derive compoundCommandHasCd=false
2208
- // from just "git status" alone, bypassing the readOnlyValidation.ts check.
2209
- if (compoundCommandHasCd) {
2210
- const hasGitCommand = subcommands.some(cmd =>
2211
- isNormalizedGitCommand(cmd.trim()),
2212
- )
2213
- if (hasGitCommand) {
2214
- const decisionReason = {
2215
- type: 'other' as const,
2216
- reason:
2217
- 'Compound commands with cd and git require approval to prevent bare repository attacks',
2218
- }
2219
- return {
2220
- behavior: 'ask',
2221
- decisionReason,
2222
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
2223
- }
2224
- }
2225
- }
2226
-
2227
- appState = context.getAppState() // re-compute the latest in case the user hit shift+tab
2228
-
2229
- // SECURITY FIX: Check Bash deny/ask rules BEFORE path constraints
2230
- // This ensures that explicit deny rules like Bash(ls:*) take precedence over
2231
- // path constraint checks that return 'ask' for paths outside the project.
2232
- // Without this ordering, absolute paths outside the project (e.g., ls /home)
2233
- // would bypass deny rules because checkPathConstraints would return 'ask' first.
2234
- //
2235
- // Note: bashToolCheckPermission calls checkPathConstraints internally, which handles
2236
- // output redirection validation on each subcommand. However, since splitCommand strips
2237
- // redirections before we get here, we MUST validate output redirections on the ORIGINAL
2238
- // command AFTER checking deny rules but BEFORE returning results.
2239
- const subcommandPermissionDecisions = subcommands.map((command, i) =>
2240
- bashToolCheckPermission(
2241
- { command },
2242
- appState.toolPermissionContext,
2243
- compoundCommandHasCd,
2244
- astCommandsByIdx[i],
2245
- ),
2246
- )
2247
-
2248
- // Deny if any subcommands are denied
2249
- const deniedSubresult = subcommandPermissionDecisions.find(
2250
- _ => _.behavior === 'deny',
2251
- )
2252
- if (deniedSubresult !== undefined) {
2253
- return {
2254
- behavior: 'deny',
2255
- message: `Permission to use ${BashTool.name} with command ${input.command} has been denied.`,
2256
- decisionReason: {
2257
- type: 'subcommandResults',
2258
- reasons: new Map(
2259
- subcommandPermissionDecisions.map((result, i) => [
2260
- subcommands[i]!,
2261
- result,
2262
- ]),
2263
- ),
2264
- },
2265
- }
2266
- }
2267
-
2268
- // Validate output redirections on the ORIGINAL command (before splitCommand stripped them)
2269
- // This must happen AFTER checking deny rules but BEFORE returning results.
2270
- // Output redirections like "> /etc/passwd" are stripped by splitCommand, so the per-subcommand
2271
- // checkPathConstraints calls won't see them. We validate them here on the original input.
2272
- // SECURITY: When AST data is available, pass AST-derived redirects so
2273
- // checkPathConstraints uses them directly instead of re-parsing with
2274
- // shell-quote (which has a known single-quote backslash misparsing bug
2275
- // that can silently hide redirect operators).
2276
- const pathResult = checkPathConstraints(
2277
- input,
2278
- getCwd(),
2279
- appState.toolPermissionContext,
2280
- compoundCommandHasCd,
2281
- astRedirects,
2282
- astCommands,
2283
- )
2284
- if (pathResult.behavior === 'deny') {
2285
- return pathResult
2286
- }
2287
-
2288
- const askSubresult = subcommandPermissionDecisions.find(
2289
- _ => _.behavior === 'ask',
2290
- )
2291
- const nonAllowCount = count(
2292
- subcommandPermissionDecisions,
2293
- _ => _.behavior !== 'allow',
2294
- )
2295
-
2296
- // SECURITY (GH#28784): Only short-circuit on a path-constraint 'ask' when no
2297
- // subcommand independently produced an 'ask'. checkPathConstraints re-runs the
2298
- // path-command loop on the full input, so `cd <outside-project> && python3 foo.py`
2299
- // produces an ask with ONLY a Read(<dir>/**) suggestion — the UI renders it as
2300
- // "Yes, allow reading from <dir>/" and picking that option silently approves
2301
- // python3. When a subcommand has its own ask (e.g. the cd subcommand's own
2302
- // path-constraint ask), fall through: either the askSubresult short-circuit
2303
- // below fires (single non-allow subcommand) or the merge flow collects Bash
2304
- // rule suggestions for every non-allow subcommand. The per-subcommand
2305
- // checkPathConstraints call inside bashToolCheckPermission already captures
2306
- // the Read rule for the cd target in that path.
2307
- //
2308
- // When no subcommand asked (all allow, or all passthrough like `printf > file`),
2309
- // pathResult IS the only ask — return it so redirection checks surface.
2310
- if (pathResult.behavior === 'ask' && askSubresult === undefined) {
2311
- return pathResult
2312
- }
2313
-
2314
- // Ask if any subcommands require approval (e.g., ls/cd outside boundaries).
2315
- // Only short-circuit when exactly ONE subcommand needs approval — if multiple
2316
- // do (e.g. cd-outside-project ask + python3 passthrough), fall through to the
2317
- // merge flow so the prompt surfaces Bash rule suggestions for all of them
2318
- // instead of only the first ask's Read rule (GH#28784).
2319
- if (askSubresult !== undefined && nonAllowCount === 1) {
2320
- return {
2321
- ...askSubresult,
2322
- ...(feature('BASH_CLASSIFIER')
2323
- ? {
2324
- pendingClassifierCheck: buildPendingClassifierCheck(
2325
- input.command,
2326
- appState.toolPermissionContext,
2327
- ),
2328
- }
2329
- : {}),
2330
- }
2331
- }
2332
-
2333
- // Allow if exact command was allowed
2334
- if (exactMatchResult.behavior === 'allow') {
2335
- return exactMatchResult
2336
- }
2337
-
2338
- // If all subcommands are allowed via exact or prefix match, allow the
2339
- // command — but only if no command injection is possible. When the AST
2340
- // parse succeeded, each subcommand is already known-safe (no hidden
2341
- // substitutions, no structural tricks); the per-subcommand re-check is
2342
- // redundant. When on the legacy path, re-run bashCommandIsSafeAsync per sub.
2343
- let hasPossibleCommandInjection = false
2344
- if (
2345
- astSubcommands === null &&
2346
- !isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_COMMAND_INJECTION_CHECK)
2347
- ) {
2348
- // CC-643: Batch divergence telemetry into a single logEvent. The per-sub
2349
- // logEvent was the hot-path syscall driver (each call → /proc/self/stat
2350
- // via process.memoryUsage()). Aggregate count preserves the signal.
2351
- let divergenceCount = 0
2352
- const onDivergence = () => {
2353
- divergenceCount++
2354
- }
2355
- const results = await Promise.all(
2356
- subcommands.map(c => bashCommandIsSafeAsync(c, onDivergence)),
2357
- )
2358
- hasPossibleCommandInjection = results.some(
2359
- r => r.behavior !== 'passthrough',
2360
- )
2361
- if (divergenceCount > 0) {
2362
- logEvent('tengu_tree_sitter_security_divergence', {
2363
- quoteContextDivergence: true,
2364
- count: divergenceCount,
2365
- })
2366
- }
2367
- }
2368
- if (
2369
- subcommandPermissionDecisions.every(_ => _.behavior === 'allow') &&
2370
- !hasPossibleCommandInjection
2371
- ) {
2372
- return {
2373
- behavior: 'allow',
2374
- updatedInput: input,
2375
- decisionReason: {
2376
- type: 'subcommandResults',
2377
- reasons: new Map(
2378
- subcommandPermissionDecisions.map((result, i) => [
2379
- subcommands[i]!,
2380
- result,
2381
- ]),
2382
- ),
2383
- },
2384
- }
2385
- }
2386
-
2387
- // Query Haiku for command prefixes
2388
- // Skip the Haiku call — the UI computes the prefix locally and
2389
- // lets the user edit it. Still call when a custom fn is injected (tests).
2390
- let commandSubcommandPrefix: Awaited<
2391
- ReturnType<typeof getCommandSubcommandPrefixFn>
2392
- > = null
2393
- if (getCommandSubcommandPrefixFn !== getCommandSubcommandPrefix) {
2394
- commandSubcommandPrefix = await getCommandSubcommandPrefixFn(
2395
- input.command,
2396
- context.abortController.signal,
2397
- context.options.isNonInteractiveSession,
2398
- )
2399
- if (context.abortController.signal.aborted) {
2400
- throw new AbortError()
2401
- }
2402
- }
2403
-
2404
- // If there is only one command, no need to process subcommands
2405
- appState = context.getAppState() // re-compute the latest in case the user hit shift+tab
2406
- if (subcommands.length === 1) {
2407
- const result = await checkCommandAndSuggestRules(
2408
- { command: subcommands[0]! },
2409
- appState.toolPermissionContext,
2410
- commandSubcommandPrefix,
2411
- compoundCommandHasCd,
2412
- astSubcommands !== null,
2413
- )
2414
- // If command wasn't allowed, attach pending classifier check.
2415
- // At this point, 'ask' can only come from bashCommandIsSafe (security check inside
2416
- // checkCommandAndSuggestRules), NOT from explicit ask rules - those were already
2417
- // filtered out at step 13 (askSubresult check). The classifier can bypass security.
2418
- if (result.behavior === 'ask' || result.behavior === 'passthrough') {
2419
- return {
2420
- ...result,
2421
- ...(feature('BASH_CLASSIFIER')
2422
- ? {
2423
- pendingClassifierCheck: buildPendingClassifierCheck(
2424
- input.command,
2425
- appState.toolPermissionContext,
2426
- ),
2427
- }
2428
- : {}),
2429
- }
2430
- }
2431
- return result
2432
- }
2433
-
2434
- // Check subcommand permission results
2435
- const subcommandResults: Map<string, PermissionResult> = new Map()
2436
- for (const subcommand of subcommands) {
2437
- subcommandResults.set(
2438
- subcommand,
2439
- await checkCommandAndSuggestRules(
2440
- {
2441
- // Pass through input params like `sandbox`
2442
- ...input,
2443
- command: subcommand,
2444
- },
2445
- appState.toolPermissionContext,
2446
- commandSubcommandPrefix?.subcommandPrefixes.get(subcommand),
2447
- compoundCommandHasCd,
2448
- astSubcommands !== null,
2449
- ),
2450
- )
2451
- }
2452
-
2453
- // Allow if all subcommands are allowed
2454
- // Note that this is different than 6b because we are checking the command injection results.
2455
- if (
2456
- subcommands.every(subcommand => {
2457
- const permissionResult = subcommandResults.get(subcommand)
2458
- return permissionResult?.behavior === 'allow'
2459
- })
2460
- ) {
2461
- // Keep subcommandResults as PermissionResult for decisionReason
2462
- return {
2463
- behavior: 'allow',
2464
- updatedInput: input,
2465
- decisionReason: {
2466
- type: 'subcommandResults',
2467
- reasons: subcommandResults,
2468
- },
2469
- }
2470
- }
2471
-
2472
- // Otherwise, ask for permission
2473
- const collectedRules: Map<string, PermissionRuleValue> = new Map()
2474
-
2475
- for (const [subcommand, permissionResult] of subcommandResults) {
2476
- if (
2477
- permissionResult.behavior === 'ask' ||
2478
- permissionResult.behavior === 'passthrough'
2479
- ) {
2480
- const updates =
2481
- 'suggestions' in permissionResult
2482
- ? permissionResult.suggestions
2483
- : undefined
2484
-
2485
- const rules = extractRules(updates)
2486
- for (const rule of rules) {
2487
- // Use string representation as key for deduplication
2488
- const ruleKey = permissionRuleValueToString(rule)
2489
- collectedRules.set(ruleKey, rule)
2490
- }
2491
-
2492
- // GH#28784 follow-up: security-check asks (compound-cd+write, process
2493
- // substitution, etc.) carry no suggestions. In a compound command like
2494
- // `cd ~/out && rm -rf x`, that means only cd's Read rule gets collected
2495
- // and the UI labels the prompt "Yes, allow reading from <dir>/" — never
2496
- // mentioning rm. Synthesize a Bash(exact) rule so the UI shows the
2497
- // chained command. Skip explicit ask rules (decisionReason.type 'rule')
2498
- // where the user deliberately wants to review each time.
2499
- if (
2500
- permissionResult.behavior === 'ask' &&
2501
- rules.length === 0 &&
2502
- permissionResult.decisionReason?.type !== 'rule'
2503
- ) {
2504
- for (const rule of extractRules(
2505
- suggestionForExactCommand(subcommand),
2506
- )) {
2507
- const ruleKey = permissionRuleValueToString(rule)
2508
- collectedRules.set(ruleKey, rule)
2509
- }
2510
- }
2511
- // Note: We only collect rules, not other update types like mode changes
2512
- // This is appropriate for bash subcommands which primarily need rule suggestions
2513
- }
2514
- }
2515
-
2516
- const decisionReason = {
2517
- type: 'subcommandResults' as const,
2518
- reasons: subcommandResults,
2519
- }
2520
-
2521
- // GH#11380: Cap at MAX_SUGGESTED_RULES_FOR_COMPOUND. Map preserves insertion
2522
- // order (subcommand order), so slicing keeps the leftmost N.
2523
- const cappedRules = Array.from(collectedRules.values()).slice(
2524
- 0,
2525
- MAX_SUGGESTED_RULES_FOR_COMPOUND,
2526
- )
2527
- const suggestedUpdates: PermissionUpdate[] | undefined =
2528
- cappedRules.length > 0
2529
- ? [
2530
- {
2531
- type: 'addRules',
2532
- rules: cappedRules,
2533
- behavior: 'allow',
2534
- destination: 'localSettings',
2535
- },
2536
- ]
2537
- : undefined
2538
-
2539
- // Attach pending classifier check - may auto-approve before user responds.
2540
- // Behavior is 'ask' if any subcommand was 'ask' (e.g., path constraint or ask
2541
- // rule) — before the GH#28784 fix, ask subresults always short-circuited above
2542
- // so this path only saw 'passthrough' subcommands and hardcoded that.
2543
- return {
2544
- behavior: askSubresult !== undefined ? 'ask' : 'passthrough',
2545
- message: createPermissionRequestMessage(BashTool.name, decisionReason),
2546
- decisionReason,
2547
- suggestions: suggestedUpdates,
2548
- ...(feature('BASH_CLASSIFIER')
2549
- ? {
2550
- pendingClassifierCheck: buildPendingClassifierCheck(
2551
- input.command,
2552
- appState.toolPermissionContext,
2553
- ),
2554
- }
2555
- : {}),
2556
- }
2557
- }
2558
-
2559
- /**
2560
- * Checks if a subcommand is a git command after normalizing away safe wrappers
2561
- * (env vars, timeout, etc.) and shell quotes.
2562
- *
2563
- * SECURITY: Must normalize before matching to prevent bypasses like:
2564
- * 'git' status — shell quotes hide the command from a naive regex
2565
- * NO_COLOR=1 git status — env var prefix hides the command
2566
- */
2567
- export function isNormalizedGitCommand(command: string): boolean {
2568
- // Fast path: catch the most common case before any parsing
2569
- if (command.startsWith('git ') || command === 'git') {
2570
- return true
2571
- }
2572
- const stripped = stripSafeWrappers(command)
2573
- const parsed = tryParseShellCommand(stripped)
2574
- if (parsed.success && parsed.tokens.length > 0) {
2575
- // Direct git command
2576
- if (parsed.tokens[0] === 'git') {
2577
- return true
2578
- }
2579
- // "xargs git ..." — xargs runs git in the current directory,
2580
- // so it must be treated as a git command for cd+git security checks.
2581
- // This matches the xargs prefix handling in filterRulesByContentsMatchingInput.
2582
- if (parsed.tokens[0] === 'xargs' && parsed.tokens.includes('git')) {
2583
- return true
2584
- }
2585
- return false
2586
- }
2587
- return /^git(?:\s|$)/.test(stripped)
2588
- }
2589
-
2590
- /**
2591
- * Checks if a subcommand is a cd command after normalizing away safe wrappers
2592
- * (env vars, timeout, etc.) and shell quotes.
2593
- *
2594
- * SECURITY: Must normalize before matching to prevent bypasses like:
2595
- * FORCE_COLOR=1 cd sub — env var prefix hides the cd from a naive /^cd / regex
2596
- * This mirrors isNormalizedGitCommand to ensure symmetric normalization.
2597
- *
2598
- * Also matches pushd/popd — they change cwd just like cd, so
2599
- * pushd /tmp/bare-repo && git status
2600
- * must trigger the same cd+git guard. Mirrors PowerShell's
2601
- * DIRECTORY_CHANGE_ALIASES (src/utils/powershell/parser.ts).
2602
- */
2603
- export function isNormalizedCdCommand(command: string): boolean {
2604
- const stripped = stripSafeWrappers(command)
2605
- const parsed = tryParseShellCommand(stripped)
2606
- if (parsed.success && parsed.tokens.length > 0) {
2607
- const cmd = parsed.tokens[0]
2608
- return cmd === 'cd' || cmd === 'pushd' || cmd === 'popd'
2609
- }
2610
- return /^(?:cd|pushd|popd)(?:\s|$)/.test(stripped)
2611
- }
2612
-
2613
- /**
2614
- * Checks if a compound command contains any cd command,
2615
- * using normalized detection that handles env var prefixes and shell quotes.
2616
- */
2617
- export function commandHasAnyCd(command: string): boolean {
2618
- return splitCommand(command).some(subcmd =>
2619
- isNormalizedCdCommand(subcmd.trim()),
2620
- )
2621
- }