thaddeus 1.0.26 → 1.0.28

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 (2082) hide show
  1. package/package.json +14 -5
  2. package/src/QueryEngine.js +926 -0
  3. package/src/Task.js +49 -0
  4. package/src/Tool.js +61 -0
  5. package/src/assistant/gate.js +5 -0
  6. package/src/assistant/index.js +106 -0
  7. package/src/assistant/sessionHistory.js +145 -0
  8. package/src/bootstrap/state.js +1163 -0
  9. package/src/bridge/bridgeApi.js +304 -0
  10. package/src/bridge/bridgeConfig.js +39 -0
  11. package/src/bridge/bridgeDebug.js +73 -0
  12. package/src/bridge/bridgeEnabled.js +185 -0
  13. package/src/bridge/bridgeMain.js +2289 -0
  14. package/src/bridge/bridgeMessaging.js +353 -0
  15. package/src/bridge/bridgePermissionCallbacks.js +10 -0
  16. package/src/bridge/bridgePointer.js +175 -0
  17. package/src/bridge/bridgeStatusUtil.js +105 -0
  18. package/src/bridge/bridgeUI.js +411 -0
  19. package/src/bridge/capacityWake.js +35 -0
  20. package/src/bridge/codeSessionApi.js +111 -0
  21. package/src/bridge/createSession.js +273 -0
  22. package/src/bridge/debugUtils.js +115 -0
  23. package/src/bridge/envLessBridgeConfig.js +120 -0
  24. package/src/bridge/flushGate.js +65 -0
  25. package/src/bridge/inboundAttachments.js +152 -0
  26. package/src/bridge/inboundMessages.js +63 -0
  27. package/src/bridge/initReplBridge.js +431 -0
  28. package/src/bridge/jwtUtils.js +185 -0
  29. package/src/bridge/peerSessions.js +5 -0
  30. package/src/bridge/pollConfig.js +85 -0
  31. package/src/bridge/pollConfigDefaults.js +62 -0
  32. package/src/bridge/remoteBridgeCore.js +712 -0
  33. package/src/bridge/replBridge.js +1719 -0
  34. package/src/bridge/replBridgeHandle.js +30 -0
  35. package/src/bridge/replBridgeTransport.js +236 -0
  36. package/src/bridge/sessionIdCompat.js +56 -0
  37. package/src/bridge/sessionRunner.js +421 -0
  38. package/src/bridge/trustedDevice.js +170 -0
  39. package/src/bridge/types.js +9 -0
  40. package/src/bridge/webhookSanitizer.js +6 -0
  41. package/src/bridge/workSecret.js +99 -0
  42. package/src/buddy/CompanionSprite.js +348 -0
  43. package/src/buddy/companion.js +107 -0
  44. package/src/buddy/prompt.js +33 -0
  45. package/src/buddy/sprites.js +488 -0
  46. package/src/buddy/types.js +90 -0
  47. package/src/buddy/useBuddyNotification.js +85 -0
  48. package/src/cli/bg.js +17 -0
  49. package/src/cli/exit.js +30 -0
  50. package/src/cli/handlers/agents.js +55 -0
  51. package/src/cli/handlers/auth.js +249 -0
  52. package/src/cli/handlers/autoMode.js +128 -0
  53. package/src/cli/handlers/mcp.js +335 -0
  54. package/src/cli/handlers/plugins.js +634 -0
  55. package/src/cli/handlers/templateJobs.js +19 -0
  56. package/src/cli/handlers/util.js +76 -0
  57. package/src/cli/ndjsonSafeStringify.js +27 -0
  58. package/src/cli/print.js +4294 -0
  59. package/src/cli/remoteIO.js +208 -0
  60. package/src/cli/structuredIO.js +644 -0
  61. package/src/cli/transports/HybridTransport.js +233 -0
  62. package/src/cli/transports/SSETransport.js +538 -0
  63. package/src/cli/transports/SerialBatchEventUploader.js +224 -0
  64. package/src/cli/transports/WebSocketTransport.js +613 -0
  65. package/src/cli/transports/WorkerStateUploader.js +88 -0
  66. package/src/cli/transports/ccrClient.js +711 -0
  67. package/src/cli/transports/transportUtils.js +39 -0
  68. package/src/cli/update.js +314 -0
  69. package/src/commandCenter/launch.js +39 -0
  70. package/src/commandCenter/phoneApi.js +168 -0
  71. package/src/commandCenter/phoneStore.js +159 -0
  72. package/src/commandCenter/reactorBus.js +130 -0
  73. package/src/commandCenter/server.js +288 -0
  74. package/src/commandCenter/server.ts +42 -7
  75. package/src/commandCenter/tunnel.js +199 -0
  76. package/src/commands/add-dir/add-dir.js +121 -0
  77. package/src/commands/add-dir/index.js +8 -0
  78. package/src/commands/add-dir/validation.js +76 -0
  79. package/src/commands/advisor.js +88 -0
  80. package/src/commands/agents/agents.js +10 -0
  81. package/src/commands/agents/index.js +7 -0
  82. package/src/commands/agents-platform/index.js +2 -0
  83. package/src/commands/assistant/index.js +86 -0
  84. package/src/commands/backup/index.js +31 -0
  85. package/src/commands/branch/branch.js +205 -0
  86. package/src/commands/branch/index.js +11 -0
  87. package/src/commands/bridge/bridge.js +513 -0
  88. package/src/commands/bridge/index.js +22 -0
  89. package/src/commands/bridge-kick.js +179 -0
  90. package/src/commands/brief.js +89 -0
  91. package/src/commands/btw/btw.js +235 -0
  92. package/src/commands/btw/index.js +9 -0
  93. package/src/commands/buddy/buddy.js +100 -0
  94. package/src/commands/buddy/index.js +11 -0
  95. package/src/commands/chrome/chrome.js +291 -0
  96. package/src/commands/chrome/index.js +10 -0
  97. package/src/commands/clear/caches.js +116 -0
  98. package/src/commands/clear/clear.js +5 -0
  99. package/src/commands/clear/conversation.js +189 -0
  100. package/src/commands/clear/index.js +9 -0
  101. package/src/commands/color/color.js +58 -0
  102. package/src/commands/color/index.js +9 -0
  103. package/src/commands/commit-push-pr.js +137 -0
  104. package/src/commands/commit.js +80 -0
  105. package/src/commands/compact/compact.js +194 -0
  106. package/src/commands/compact/index.js +11 -0
  107. package/src/commands/config/config.js +6 -0
  108. package/src/commands/config/index.js +8 -0
  109. package/src/commands/context/context-noninteractive.js +219 -0
  110. package/src/commands/context/context.js +45 -0
  111. package/src/commands/context/index.js +21 -0
  112. package/src/commands/coordinator.js +34 -0
  113. package/src/commands/copy/copy.js +366 -0
  114. package/src/commands/copy/index.js +7 -0
  115. package/src/commands/cost/cost.js +21 -0
  116. package/src/commands/cost/index.js +16 -0
  117. package/src/commands/createMovedToPluginCommand.js +33 -0
  118. package/src/commands/desktop/desktop.js +6 -0
  119. package/src/commands/desktop/index.js +22 -0
  120. package/src/commands/diff/diff.js +6 -0
  121. package/src/commands/diff/index.js +6 -0
  122. package/src/commands/doctor/doctor.js +6 -0
  123. package/src/commands/doctor/index.js +9 -0
  124. package/src/commands/effort/effort.js +166 -0
  125. package/src/commands/effort/index.js +11 -0
  126. package/src/commands/exit/exit.js +32 -0
  127. package/src/commands/exit/index.js +9 -0
  128. package/src/commands/export/export.js +87 -0
  129. package/src/commands/export/index.js +8 -0
  130. package/src/commands/extra-usage/extra-usage-core.js +99 -0
  131. package/src/commands/extra-usage/extra-usage-noninteractive.js +13 -0
  132. package/src/commands/extra-usage/extra-usage.js +15 -0
  133. package/src/commands/extra-usage/index.js +29 -0
  134. package/src/commands/fast/fast.js +276 -0
  135. package/src/commands/fast/index.js +19 -0
  136. package/src/commands/feedback/feedback.js +11 -0
  137. package/src/commands/feedback/index.js +20 -0
  138. package/src/commands/files/files.js +11 -0
  139. package/src/commands/files/index.js +9 -0
  140. package/src/commands/force-snip.js +19 -0
  141. package/src/commands/fork/index.js +67 -0
  142. package/src/commands/heapdump/heapdump.js +14 -0
  143. package/src/commands/heapdump/index.js +9 -0
  144. package/src/commands/help/help.js +6 -0
  145. package/src/commands/help/index.js +7 -0
  146. package/src/commands/hooks/hooks.js +12 -0
  147. package/src/commands/hooks/index.js +8 -0
  148. package/src/commands/ide/ide.js +615 -0
  149. package/src/commands/ide/index.js +8 -0
  150. package/src/commands/init-verifiers.js +258 -0
  151. package/src/commands/init.js +248 -0
  152. package/src/commands/insights.js +2554 -0
  153. package/src/commands/install-github-app/ApiKeyStep.js +230 -0
  154. package/src/commands/install-github-app/CheckExistingSecretStep.js +194 -0
  155. package/src/commands/install-github-app/CheckGitHubStep.js +16 -0
  156. package/src/commands/install-github-app/ChooseRepoStep.js +211 -0
  157. package/src/commands/install-github-app/CreatingStep.js +53 -0
  158. package/src/commands/install-github-app/ErrorStep.js +84 -0
  159. package/src/commands/install-github-app/ExistingWorkflowStep.js +105 -0
  160. package/src/commands/install-github-app/InstallAppStep.js +97 -0
  161. package/src/commands/install-github-app/OAuthFlowStep.js +190 -0
  162. package/src/commands/install-github-app/SuccessStep.js +94 -0
  163. package/src/commands/install-github-app/WarningsStep.js +71 -0
  164. package/src/commands/install-github-app/index.js +10 -0
  165. package/src/commands/install-github-app/install-github-app.js +593 -0
  166. package/src/commands/install-github-app/setupGitHubActions.js +227 -0
  167. package/src/commands/install-slack-app/index.js +9 -0
  168. package/src/commands/install-slack-app/install-slack-app.js +25 -0
  169. package/src/commands/install.js +198 -0
  170. package/src/commands/keybindings/index.js +10 -0
  171. package/src/commands/keybindings/keybindings.js +47 -0
  172. package/src/commands/login/index.js +21 -0
  173. package/src/commands/login/login.js +135 -0
  174. package/src/commands/logout/index.js +11 -0
  175. package/src/commands/logout/logout.js +75 -0
  176. package/src/commands/mcp/addCommand.js +183 -0
  177. package/src/commands/mcp/index.js +9 -0
  178. package/src/commands/mcp/mcp.js +78 -0
  179. package/src/commands/mcp/xaaIdpCommand.js +193 -0
  180. package/src/commands/memories/index.js +9 -0
  181. package/src/commands/memories/index.ts +12 -0
  182. package/src/commands/memories/memories.tsx +949 -0
  183. package/src/commands/memory/index.js +7 -0
  184. package/src/commands/memory/memory.js +71 -0
  185. package/src/commands/mobile/index.js +9 -0
  186. package/src/commands/mobile/mobile.js +279 -0
  187. package/src/commands/model/index.js +14 -0
  188. package/src/commands/model/model.js +284 -0
  189. package/src/commands/output-style/index.js +8 -0
  190. package/src/commands/output-style/output-style.js +6 -0
  191. package/src/commands/passes/index.js +17 -0
  192. package/src/commands/passes/passes.js +23 -0
  193. package/src/commands/peers/index.js +68 -0
  194. package/src/commands/permissions/index.js +8 -0
  195. package/src/commands/permissions/permissions.js +9 -0
  196. package/src/commands/plan/index.js +8 -0
  197. package/src/commands/plan/plan.js +116 -0
  198. package/src/commands/plugin/AddMarketplace.js +96 -0
  199. package/src/commands/plugin/BrowseMarketplace.js +582 -0
  200. package/src/commands/plugin/DiscoverPlugins.js +613 -0
  201. package/src/commands/plugin/ManageMarketplaces.js +583 -0
  202. package/src/commands/plugin/ManagePlugins.js +1783 -0
  203. package/src/commands/plugin/PluginErrors.js +124 -0
  204. package/src/commands/plugin/PluginOptionsDialog.js +367 -0
  205. package/src/commands/plugin/PluginOptionsFlow.js +97 -0
  206. package/src/commands/plugin/PluginSettings.js +1041 -0
  207. package/src/commands/plugin/PluginTrustWarning.js +35 -0
  208. package/src/commands/plugin/UnifiedInstalledCell.js +616 -0
  209. package/src/commands/plugin/ValidatePlugin.js +96 -0
  210. package/src/commands/plugin/index.js +10 -0
  211. package/src/commands/plugin/parseArgs.js +71 -0
  212. package/src/commands/plugin/plugin.js +6 -0
  213. package/src/commands/plugin/pluginDetailsHelpers.js +95 -0
  214. package/src/commands/plugin/usePagination.js +89 -0
  215. package/src/commands/pr_comments/index.js +49 -0
  216. package/src/commands/privacy-settings/index.js +11 -0
  217. package/src/commands/privacy-settings/privacy-settings.js +55 -0
  218. package/src/commands/proactive.js +29 -0
  219. package/src/commands/rate-limit-options/index.js +15 -0
  220. package/src/commands/rate-limit-options/rate-limit-options.js +213 -0
  221. package/src/commands/release-notes/index.js +8 -0
  222. package/src/commands/release-notes/release-notes.js +38 -0
  223. package/src/commands/reload-plugins/index.js +11 -0
  224. package/src/commands/reload-plugins/reload-plugins.js +52 -0
  225. package/src/commands/remote-env/index.js +12 -0
  226. package/src/commands/remote-env/remote-env.js +6 -0
  227. package/src/commands/remote-setup/api.js +155 -0
  228. package/src/commands/remote-setup/index.js +15 -0
  229. package/src/commands/remote-setup/remote-setup.js +150 -0
  230. package/src/commands/remoteControlServer/index.js +58 -0
  231. package/src/commands/rename/generateSessionName.js +58 -0
  232. package/src/commands/rename/index.js +9 -0
  233. package/src/commands/rename/rename.js +52 -0
  234. package/src/commands/resume/index.js +9 -0
  235. package/src/commands/resume/resume.js +239 -0
  236. package/src/commands/review/UltrareviewOverageDialog.js +97 -0
  237. package/src/commands/review/reviewRemote.js +259 -0
  238. package/src/commands/review/ultrareviewCommand.js +58 -0
  239. package/src/commands/review/ultrareviewEnabled.js +10 -0
  240. package/src/commands/review.js +53 -0
  241. package/src/commands/rewind/index.js +10 -0
  242. package/src/commands/rewind/rewind.js +7 -0
  243. package/src/commands/sandbox-toggle/index.js +41 -0
  244. package/src/commands/sandbox-toggle/sandbox-toggle.js +73 -0
  245. package/src/commands/security-review.js +231 -0
  246. package/src/commands/session/index.js +13 -0
  247. package/src/commands/session/session.js +143 -0
  248. package/src/commands/skills/index.js +7 -0
  249. package/src/commands/skills/skills.js +6 -0
  250. package/src/commands/speak.js +21 -0
  251. package/src/commands/start-business.js +1575 -0
  252. package/src/commands/start-business.ts +1581 -0
  253. package/src/commands/stats/index.js +7 -0
  254. package/src/commands/stats/stats.js +6 -0
  255. package/src/commands/status/index.js +8 -0
  256. package/src/commands/status/status.js +6 -0
  257. package/src/commands/statusline.js +22 -0
  258. package/src/commands/stickers/index.js +8 -0
  259. package/src/commands/stickers/stickers.js +14 -0
  260. package/src/commands/subscribe-pr.js +131 -0
  261. package/src/commands/tag/index.js +9 -0
  262. package/src/commands/tag/tag.js +215 -0
  263. package/src/commands/tasks/index.js +8 -0
  264. package/src/commands/tasks/tasks.js +6 -0
  265. package/src/commands/terminalSetup/index.js +18 -0
  266. package/src/commands/terminalSetup/terminalSetup.js +491 -0
  267. package/src/commands/thaddeus-usage/index.js +17 -0
  268. package/src/commands/theme/index.js +7 -0
  269. package/src/commands/theme/theme.js +51 -0
  270. package/src/commands/thinkback/index.js +9 -0
  271. package/src/commands/thinkback/thinkback.js +528 -0
  272. package/src/commands/thinkback-play/index.js +13 -0
  273. package/src/commands/thinkback-play/thinkback-play.js +34 -0
  274. package/src/commands/torch.js +122 -0
  275. package/src/commands/ultraplan.js +416 -0
  276. package/src/commands/upgrade/index.js +12 -0
  277. package/src/commands/upgrade/upgrade.js +38 -0
  278. package/src/commands/usage/index.js +7 -0
  279. package/src/commands/usage/usage.js +6 -0
  280. package/src/commands/version.js +17 -0
  281. package/src/commands/vim/index.js +8 -0
  282. package/src/commands/vim/vim.js +25 -0
  283. package/src/commands/voice/index.js +13 -0
  284. package/src/commands/voice/voice.js +44 -0
  285. package/src/commands/workflows/index.js +123 -0
  286. package/src/commands.js +614 -0
  287. package/src/commands.ts +4 -0
  288. package/src/components/AgentProgressLine.js +112 -0
  289. package/src/components/AntModelSwitchCallout.js +8 -0
  290. package/src/components/App.js +46 -0
  291. package/src/components/ApproveApiKey.js +125 -0
  292. package/src/components/AutoModeOptInDialog.js +140 -0
  293. package/src/components/AutoUpdater.js +156 -0
  294. package/src/components/AutoUpdaterWrapper.js +78 -0
  295. package/src/components/AwsAuthStatusBox.js +88 -0
  296. package/src/components/BaseTextInput.js +105 -0
  297. package/src/components/BashModeProgress.js +49 -0
  298. package/src/components/BridgeDialog.js +415 -0
  299. package/src/components/BypassPermissionsModeDialog.js +87 -0
  300. package/src/components/ChannelDowngradeDialog.js +101 -0
  301. package/src/components/ClaudeInChromeOnboarding.js +126 -0
  302. package/src/components/ClaudeMdExternalIncludesDialog.js +137 -0
  303. package/src/components/ClickableImageRef.js +65 -0
  304. package/src/components/CompactSummary.js +120 -0
  305. package/src/components/ConfigurableShortcutHint.js +35 -0
  306. package/src/components/ConsoleOAuthFlow.js +554 -0
  307. package/src/components/ContextSuggestions.js +44 -0
  308. package/src/components/ContextVisualization.js +482 -0
  309. package/src/components/CoordinatorAgentStatus.js +261 -0
  310. package/src/components/CostThresholdDialog.js +49 -0
  311. package/src/components/CtrlOToExpand.js +50 -0
  312. package/src/components/CustomSelect/SelectMulti.js +150 -0
  313. package/src/components/CustomSelect/index.js +2 -0
  314. package/src/components/CustomSelect/option-map.js +32 -0
  315. package/src/components/CustomSelect/select-input-option.js +426 -0
  316. package/src/components/CustomSelect/select-option.js +24 -0
  317. package/src/components/CustomSelect/select.js +518 -0
  318. package/src/components/CustomSelect/use-multi-select-state.js +214 -0
  319. package/src/components/CustomSelect/use-select-input.js +170 -0
  320. package/src/components/CustomSelect/use-select-navigation.js +366 -0
  321. package/src/components/CustomSelect/use-select-state.js +22 -0
  322. package/src/components/DesktopHandoff.js +195 -0
  323. package/src/components/DesktopUpsell/DesktopUpsellStartup.js +174 -0
  324. package/src/components/DevBar.js +51 -0
  325. package/src/components/DevChannelsDialog.js +104 -0
  326. package/src/components/DiagnosticsDisplay.js +91 -0
  327. package/src/components/EffortCallout.js +264 -0
  328. package/src/components/EffortIndicator.js +28 -0
  329. package/src/components/ExitFlow.js +41 -0
  330. package/src/components/ExportDialog.js +101 -0
  331. package/src/components/FallbackToolUseErrorMessage.js +116 -0
  332. package/src/components/FallbackToolUseRejectedMessage.js +17 -0
  333. package/src/components/FastIcon.js +43 -0
  334. package/src/components/Feedback.js +369 -0
  335. package/src/components/FeedbackSurvey/FeedbackSurvey.js +151 -0
  336. package/src/components/FeedbackSurvey/FeedbackSurveyView.js +104 -0
  337. package/src/components/FeedbackSurvey/TranscriptSharePrompt.js +84 -0
  338. package/src/components/FeedbackSurvey/submitTranscriptShare.js +10 -0
  339. package/src/components/FeedbackSurvey/useDebouncedDigitInput.js +51 -0
  340. package/src/components/FeedbackSurvey/useFeedbackSurvey.js +258 -0
  341. package/src/components/FeedbackSurvey/useFrustrationDetection.js +8 -0
  342. package/src/components/FeedbackSurvey/useMemorySurvey.js +191 -0
  343. package/src/components/FeedbackSurvey/usePostCompactSurvey.js +202 -0
  344. package/src/components/FeedbackSurvey/useSurveyState.js +80 -0
  345. package/src/components/FileEditToolDiff.js +167 -0
  346. package/src/components/FileEditToolUpdatedMessage.js +112 -0
  347. package/src/components/FileEditToolUseRejectedMessage.js +158 -0
  348. package/src/components/FilePathLink.js +35 -0
  349. package/src/components/FullscreenLayout.js +578 -0
  350. package/src/components/GlobalSearchDialog.js +340 -0
  351. package/src/components/HelpV2/Commands.js +66 -0
  352. package/src/components/HelpV2/General.js +25 -0
  353. package/src/components/HelpV2/HelpV2.js +186 -0
  354. package/src/components/HighlightedCode/Fallback.js +193 -0
  355. package/src/components/HighlightedCode.js +185 -0
  356. package/src/components/HistorySearchDialog.js +93 -0
  357. package/src/components/IdeAutoConnectDialog.js +154 -0
  358. package/src/components/IdeOnboardingDialog.js +175 -0
  359. package/src/components/IdeStatusIndicator.js +50 -0
  360. package/src/components/IdleReturnDialog.js +117 -0
  361. package/src/components/InterruptedByUser.js +16 -0
  362. package/src/components/InvalidConfigDialog.js +135 -0
  363. package/src/components/InvalidSettingsDialog.js +85 -0
  364. package/src/components/KeybindingWarnings.js +55 -0
  365. package/src/components/LanguagePicker.js +84 -0
  366. package/src/components/LogSelector.js +1579 -0
  367. package/src/components/LogoV2/AnimatedAsterisk.js +43 -0
  368. package/src/components/LogoV2/AnimatedClawd.js +64 -0
  369. package/src/components/LogoV2/ChannelsNotice.js +262 -0
  370. package/src/components/LogoV2/Clawd.js +33 -0
  371. package/src/components/LogoV2/CondensedLogo.js +160 -0
  372. package/src/components/LogoV2/EmergencyTip.js +48 -0
  373. package/src/components/LogoV2/Feed.js +85 -0
  374. package/src/components/LogoV2/FeedColumn.js +55 -0
  375. package/src/components/LogoV2/GuestPassesUpsell.js +71 -0
  376. package/src/components/LogoV2/LogoV2.js +565 -0
  377. package/src/components/LogoV2/Opus1mMergeNotice.js +57 -0
  378. package/src/components/LogoV2/OverageCreditUpsell.js +161 -0
  379. package/src/components/LogoV2/VoiceModeNotice.js +71 -0
  380. package/src/components/LogoV2/WelcomeV2.js +14 -0
  381. package/src/components/LogoV2/feedConfigs.js +79 -0
  382. package/src/components/LspRecommendation/LspRecommendationMenu.js +46 -0
  383. package/src/components/MCPServerApprovalDialog.js +114 -0
  384. package/src/components/MCPServerDesktopImportDialog.js +206 -0
  385. package/src/components/MCPServerDialogCopy.js +16 -0
  386. package/src/components/MCPServerMultiselectDialog.js +134 -0
  387. package/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.js +150 -0
  388. package/src/components/ManagedSettingsSecurityDialog/utils.js +105 -0
  389. package/src/components/Markdown.js +233 -0
  390. package/src/components/MarkdownTable.js +280 -0
  391. package/src/components/MemoryUsageIndicator.js +28 -0
  392. package/src/components/Message.js +564 -0
  393. package/src/components/MessageModel.js +37 -0
  394. package/src/components/MessageResponse.js +73 -0
  395. package/src/components/MessageRow.js +346 -0
  396. package/src/components/MessageSelector.js +744 -0
  397. package/src/components/MessageTimestamp.js +58 -0
  398. package/src/components/Messages.js +645 -0
  399. package/src/components/ModelPicker.js +452 -0
  400. package/src/components/NativeAutoUpdater.js +152 -0
  401. package/src/components/NotebookEditToolUseRejectedMessage.js +84 -0
  402. package/src/components/OffscreenFreeze.js +35 -0
  403. package/src/components/Onboarding.js +174 -0
  404. package/src/components/OutputStylePicker.js +103 -0
  405. package/src/components/PackageManagerAutoUpdater.js +99 -0
  406. package/src/components/Passes/Passes.js +114 -0
  407. package/src/components/PrBadge.js +91 -0
  408. package/src/components/PressEnterToContinue.js +16 -0
  409. package/src/components/PromptInput/HistorySearchInput.js +45 -0
  410. package/src/components/PromptInput/IssueFlagBanner.js +8 -0
  411. package/src/components/PromptInput/Notifications.js +220 -0
  412. package/src/components/PromptInput/PromptInput.js +2014 -0
  413. package/src/components/PromptInput/PromptInputFooter.js +85 -0
  414. package/src/components/PromptInput/PromptInputFooterLeftSide.js +408 -0
  415. package/src/components/PromptInput/PromptInputFooterSuggestions.js +281 -0
  416. package/src/components/PromptInput/PromptInputHelpMenu.js +380 -0
  417. package/src/components/PromptInput/PromptInputModeIndicator.js +73 -0
  418. package/src/components/PromptInput/PromptInputQueuedCommands.js +105 -0
  419. package/src/components/PromptInput/PromptInputStashNotice.js +21 -0
  420. package/src/components/PromptInput/SandboxPromptFooterHint.js +66 -0
  421. package/src/components/PromptInput/ShimmeredInput.js +133 -0
  422. package/src/components/PromptInput/VoiceIndicator.js +137 -0
  423. package/src/components/PromptInput/inputModes.js +24 -0
  424. package/src/components/PromptInput/inputPaste.js +62 -0
  425. package/src/components/PromptInput/useMaybeTruncateInput.js +33 -0
  426. package/src/components/PromptInput/usePromptInputPlaceholder.js +53 -0
  427. package/src/components/PromptInput/useShowFastIconHint.js +23 -0
  428. package/src/components/PromptInput/useSwarmBanner.js +112 -0
  429. package/src/components/PromptInput/utils.js +50 -0
  430. package/src/components/QuickOpenDialog.js +244 -0
  431. package/src/components/RemoteCallout.js +53 -0
  432. package/src/components/RemoteEnvironmentDialog.js +346 -0
  433. package/src/components/ResumeTask.js +173 -0
  434. package/src/components/SandboxViolationExpandedView.js +106 -0
  435. package/src/components/ScrollKeybindingHandler.js +982 -0
  436. package/src/components/SearchBox.js +56 -0
  437. package/src/components/SentryErrorBoundary.js +16 -0
  438. package/src/components/SessionBackgroundHint.js +105 -0
  439. package/src/components/SessionPreview.js +200 -0
  440. package/src/components/Settings/Config.js +1626 -0
  441. package/src/components/Settings/Settings.js +131 -0
  442. package/src/components/Settings/Status.js +230 -0
  443. package/src/components/Settings/Usage.js +341 -0
  444. package/src/components/ShowInIDEPrompt.js +152 -0
  445. package/src/components/SkillImprovementSurvey.js +130 -0
  446. package/src/components/Spinner/FlashingChar.js +52 -0
  447. package/src/components/Spinner/GlimmerMessage.js +329 -0
  448. package/src/components/Spinner/ShimmerChar.js +23 -0
  449. package/src/components/Spinner/SpinnerAnimationRow.js +170 -0
  450. package/src/components/Spinner/SpinnerGlyph.js +70 -0
  451. package/src/components/Spinner/TeammateSpinnerLine.js +171 -0
  452. package/src/components/Spinner/TeammateSpinnerTree.js +269 -0
  453. package/src/components/Spinner/index.js +9 -0
  454. package/src/components/Spinner/teammateSelectHint.js +1 -0
  455. package/src/components/Spinner/useShimmerAnimation.js +22 -0
  456. package/src/components/Spinner/useStalledAnimation.js +63 -0
  457. package/src/components/Spinner/utils.js +78 -0
  458. package/src/components/Spinner.js +474 -0
  459. package/src/components/Stats.js +1000 -0
  460. package/src/components/StatusLine.js +286 -0
  461. package/src/components/StatusNotices.js +50 -0
  462. package/src/components/StructuredDiff/Fallback.js +336 -0
  463. package/src/components/StructuredDiff/colorDiff.js +37 -0
  464. package/src/components/StructuredDiff.js +153 -0
  465. package/src/components/StructuredDiffList.js +9 -0
  466. package/src/components/TagTabs.js +101 -0
  467. package/src/components/TaskListV2.js +333 -0
  468. package/src/components/TeammateViewHeader.js +88 -0
  469. package/src/components/TeleportError.js +191 -0
  470. package/src/components/TeleportProgress.js +131 -0
  471. package/src/components/TeleportRepoMismatchDialog.js +98 -0
  472. package/src/components/TeleportResumeWrapper.js +158 -0
  473. package/src/components/TeleportStash.js +82 -0
  474. package/src/components/TextInput.js +108 -0
  475. package/src/components/ThaddeusHint/PluginHintMenu.js +37 -0
  476. package/src/components/ThemePicker.js +331 -0
  477. package/src/components/ThinkingToggle.js +154 -0
  478. package/src/components/TokenWarning.js +171 -0
  479. package/src/components/ToolUseLoader.js +35 -0
  480. package/src/components/TrustDialog/TrustDialog.js +301 -0
  481. package/src/components/TrustDialog/utils.js +199 -0
  482. package/src/components/UndercoverAutoCallout.js +5 -0
  483. package/src/components/ValidationErrorsList.js +147 -0
  484. package/src/components/VimTextInput.js +136 -0
  485. package/src/components/VirtualMessageList.js +893 -0
  486. package/src/components/WorkflowMultiselectDialog.js +118 -0
  487. package/src/components/WorktreeExitDialog.js +220 -0
  488. package/src/components/agents/AgentDetail.js +227 -0
  489. package/src/components/agents/AgentEditor.js +147 -0
  490. package/src/components/agents/AgentNavigationFooter.js +22 -0
  491. package/src/components/agents/AgentsList.js +436 -0
  492. package/src/components/agents/AgentsMenu.js +849 -0
  493. package/src/components/agents/ColorPicker.js +110 -0
  494. package/src/components/agents/ModelSelector.js +63 -0
  495. package/src/components/agents/SnapshotUpdateDialog.js +14 -0
  496. package/src/components/agents/ToolSelector.js +557 -0
  497. package/src/components/agents/agentFileUtils.js +179 -0
  498. package/src/components/agents/generateAgent.js +161 -0
  499. package/src/components/agents/new-agent-creation/CreateAgentWizard.js +89 -0
  500. package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.js +81 -0
  501. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.js +387 -0
  502. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.js +63 -0
  503. package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.js +126 -0
  504. package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.js +118 -0
  505. package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.js +80 -0
  506. package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.js +108 -0
  507. package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.js +80 -0
  508. package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.js +49 -0
  509. package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.js +131 -0
  510. package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.js +52 -0
  511. package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.js +100 -0
  512. package/src/components/agents/types.js +4 -0
  513. package/src/components/agents/utils.js +14 -0
  514. package/src/components/agents/validateAgent.js +79 -0
  515. package/src/components/design-system/Byline.js +72 -0
  516. package/src/components/design-system/Dialog.js +117 -0
  517. package/src/components/design-system/Divider.js +110 -0
  518. package/src/components/design-system/FuzzyPicker.js +191 -0
  519. package/src/components/design-system/KeyboardShortcutHint.js +68 -0
  520. package/src/components/design-system/ListItem.js +184 -0
  521. package/src/components/design-system/LoadingState.js +69 -0
  522. package/src/components/design-system/Pane.js +69 -0
  523. package/src/components/design-system/ProgressBar.js +63 -0
  524. package/src/components/design-system/Ratchet.js +71 -0
  525. package/src/components/design-system/StatusIcon.js +70 -0
  526. package/src/components/design-system/Tabs.js +269 -0
  527. package/src/components/design-system/ThemeProvider.js +137 -0
  528. package/src/components/design-system/ThemedBox.js +126 -0
  529. package/src/components/design-system/ThemedText.js +60 -0
  530. package/src/components/design-system/color.js +22 -0
  531. package/src/components/diff/DiffDetailView.js +285 -0
  532. package/src/components/diff/DiffDialog.js +387 -0
  533. package/src/components/diff/DiffFileList.js +292 -0
  534. package/src/components/grove/Grove.js +483 -0
  535. package/src/components/hooks/HooksConfigMenu.js +583 -0
  536. package/src/components/hooks/PromptDialog.js +82 -0
  537. package/src/components/hooks/SelectEventMode.js +118 -0
  538. package/src/components/hooks/SelectHookMode.js +101 -0
  539. package/src/components/hooks/SelectMatcherMode.js +131 -0
  540. package/src/components/hooks/ViewHookMode.js +204 -0
  541. package/src/components/mcp/CapabilitiesSection.js +56 -0
  542. package/src/components/mcp/ElicitationDialog.js +945 -0
  543. package/src/components/mcp/MCPAgentServerMenu.js +95 -0
  544. package/src/components/mcp/MCPListPanel.js +505 -0
  545. package/src/components/mcp/MCPReconnect.js +168 -0
  546. package/src/components/mcp/MCPRemoteServerMenu.js +460 -0
  547. package/src/components/mcp/MCPSettings.js +414 -0
  548. package/src/components/mcp/MCPStdioServerMenu.js +95 -0
  549. package/src/components/mcp/MCPToolDetailView.js +219 -0
  550. package/src/components/mcp/MCPToolListView.js +137 -0
  551. package/src/components/mcp/McpParsingWarnings.js +212 -0
  552. package/src/components/mcp/index.js +8 -0
  553. package/src/components/mcp/utils/reconnectHelpers.js +35 -0
  554. package/src/components/memory/MemoryFileSelector.js +454 -0
  555. package/src/components/memory/MemoryUpdateNotification.js +43 -0
  556. package/src/components/messageActions.js +418 -0
  557. package/src/components/messages/AdvisorMessage.js +152 -0
  558. package/src/components/messages/AssistantRedactedThinkingMessage.js +28 -0
  559. package/src/components/messages/AssistantTextMessage.js +287 -0
  560. package/src/components/messages/AssistantThinkingMessage.js +70 -0
  561. package/src/components/messages/AssistantToolUseMessage.js +324 -0
  562. package/src/components/messages/AttachmentMessage.js +418 -0
  563. package/src/components/messages/CollapsedReadSearchContent.js +363 -0
  564. package/src/components/messages/CompactBoundaryMessage.js +19 -0
  565. package/src/components/messages/GroupedToolUseContent.js +37 -0
  566. package/src/components/messages/HighlightedThinkingText.js +165 -0
  567. package/src/components/messages/HookProgressMessage.js +111 -0
  568. package/src/components/messages/PlanApprovalMessage.js +213 -0
  569. package/src/components/messages/RateLimitMessage.js +149 -0
  570. package/src/components/messages/ShutdownMessage.js +124 -0
  571. package/src/components/messages/SnipBoundaryMessage.js +7 -0
  572. package/src/components/messages/SystemAPIErrorMessage.js +136 -0
  573. package/src/components/messages/SystemTextMessage.js +842 -0
  574. package/src/components/messages/TaskAssignmentMessage.js +72 -0
  575. package/src/components/messages/UserAgentNotificationMessage.js +78 -0
  576. package/src/components/messages/UserBashInputMessage.js +52 -0
  577. package/src/components/messages/UserBashOutputMessage.js +55 -0
  578. package/src/components/messages/UserChannelMessage.js +130 -0
  579. package/src/components/messages/UserCommandMessage.js +107 -0
  580. package/src/components/messages/UserCrossSessionMessage.js +11 -0
  581. package/src/components/messages/UserForkBoilerplateMessage.js +11 -0
  582. package/src/components/messages/UserGitHubWebhookMessage.js +12 -0
  583. package/src/components/messages/UserImageMessage.js +54 -0
  584. package/src/components/messages/UserLocalCommandOutputMessage.js +170 -0
  585. package/src/components/messages/UserMemoryInputMessage.js +73 -0
  586. package/src/components/messages/UserPlanMessage.js +38 -0
  587. package/src/components/messages/UserPromptMessage.js +63 -0
  588. package/src/components/messages/UserResourceUpdateMessage.js +102 -0
  589. package/src/components/messages/UserTeammateMessage.js +156 -0
  590. package/src/components/messages/UserTextMessage.js +270 -0
  591. package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.js +28 -0
  592. package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.js +17 -0
  593. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +17 -0
  594. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.js +92 -0
  595. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.js +74 -0
  596. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.js +84 -0
  597. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +58 -0
  598. package/src/components/messages/UserToolResultMessage/utils.js +43 -0
  599. package/src/components/messages/nullRenderingAttachments.js +58 -0
  600. package/src/components/messages/teamMemCollapsed.js +142 -0
  601. package/src/components/messages/teamMemSaved.js +16 -0
  602. package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.js +659 -0
  603. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.js +219 -0
  604. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.js +227 -0
  605. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.js +175 -0
  606. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.js +444 -0
  607. package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.js +137 -0
  608. package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.js +100 -0
  609. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.js +404 -0
  610. package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.js +110 -0
  611. package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.js +449 -0
  612. package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.js +126 -0
  613. package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.js +653 -0
  614. package/src/components/permissions/FallbackPermissionRequest.js +349 -0
  615. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +185 -0
  616. package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.js +108 -0
  617. package/src/components/permissions/FilePermissionDialog/ideDiffConfig.js +13 -0
  618. package/src/components/permissions/FilePermissionDialog/permissionOptions.js +137 -0
  619. package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.js +131 -0
  620. package/src/components/permissions/FilePermissionDialog/usePermissionHandler.js +86 -0
  621. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +164 -0
  622. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +79 -0
  623. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +113 -0
  624. package/src/components/permissions/MonitorPermissionRequest/MonitorPermissionRequest.js +7 -0
  625. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.js +164 -0
  626. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.js +218 -0
  627. package/src/components/permissions/PermissionDecisionDebugInfo.js +467 -0
  628. package/src/components/permissions/PermissionDialog.js +55 -0
  629. package/src/components/permissions/PermissionExplanation.js +269 -0
  630. package/src/components/permissions/PermissionPrompt.js +316 -0
  631. package/src/components/permissions/PermissionRequest.js +159 -0
  632. package/src/components/permissions/PermissionRequestTitle.js +58 -0
  633. package/src/components/permissions/PermissionRuleExplanation.js +110 -0
  634. package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.js +178 -0
  635. package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.js +73 -0
  636. package/src/components/permissions/ReviewArtifactPermissionRequest/ReviewArtifactPermissionRequest.js +7 -0
  637. package/src/components/permissions/SandboxPermissionRequest.js +162 -0
  638. package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.js +228 -0
  639. package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.js +385 -0
  640. package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.js +259 -0
  641. package/src/components/permissions/WorkerBadge.js +44 -0
  642. package/src/components/permissions/WorkerPendingPermission.js +107 -0
  643. package/src/components/permissions/hooks.js +163 -0
  644. package/src/components/permissions/rules/AddPermissionRules.js +171 -0
  645. package/src/components/permissions/rules/AddWorkspaceDirectory.js +335 -0
  646. package/src/components/permissions/rules/PermissionRuleDescription.js +78 -0
  647. package/src/components/permissions/rules/PermissionRuleInput.js +136 -0
  648. package/src/components/permissions/rules/PermissionRuleList.js +1190 -0
  649. package/src/components/permissions/rules/RecentDenialsTab.js +205 -0
  650. package/src/components/permissions/rules/RemoveWorkspaceDirectory.js +103 -0
  651. package/src/components/permissions/rules/WorkspaceTab.js +133 -0
  652. package/src/components/permissions/shellPermissionHelpers.js +112 -0
  653. package/src/components/permissions/useShellPermissionFeedback.js +108 -0
  654. package/src/components/permissions/utils.js +14 -0
  655. package/src/components/sandbox/SandboxConfigTab.js +48 -0
  656. package/src/components/sandbox/SandboxDependenciesTab.js +123 -0
  657. package/src/components/sandbox/SandboxDoctorSection.js +47 -0
  658. package/src/components/sandbox/SandboxOverridesTab.js +193 -0
  659. package/src/components/sandbox/SandboxSettings.js +297 -0
  660. package/src/components/shell/ExpandShellOutputContext.js +33 -0
  661. package/src/components/shell/OutputLine.js +110 -0
  662. package/src/components/shell/ShellProgressMessage.js +144 -0
  663. package/src/components/shell/ShellTimeDisplay.js +72 -0
  664. package/src/components/skills/SkillsMenu.js +239 -0
  665. package/src/components/tasks/AsyncAgentDetailDialog.js +235 -0
  666. package/src/components/tasks/BackgroundTask.js +364 -0
  667. package/src/components/tasks/BackgroundTaskStatus.js +419 -0
  668. package/src/components/tasks/BackgroundTasksDialog.js +494 -0
  669. package/src/components/tasks/DreamDetailDialog.js +251 -0
  670. package/src/components/tasks/InProcessTeammateDetailDialog.js +275 -0
  671. package/src/components/tasks/MonitorMcpDetailDialog.js +7 -0
  672. package/src/components/tasks/RemoteSessionDetailDialog.js +868 -0
  673. package/src/components/tasks/RemoteSessionProgress.js +249 -0
  674. package/src/components/tasks/ShellDetailDialog.js +403 -0
  675. package/src/components/tasks/ShellProgress.js +77 -0
  676. package/src/components/tasks/WorkflowDetailDialog.js +7 -0
  677. package/src/components/tasks/renderToolActivity.js +29 -0
  678. package/src/components/tasks/taskStatusUtils.js +94 -0
  679. package/src/components/teams/TeamStatus.js +77 -0
  680. package/src/components/teams/TeamsDialog.js +673 -0
  681. package/src/components/ui/OrderedList.js +66 -0
  682. package/src/components/ui/OrderedListItem.js +41 -0
  683. package/src/components/ui/TreeSelect.js +300 -0
  684. package/src/components/wizard/WizardDialogLayout.js +48 -0
  685. package/src/components/wizard/WizardNavigationFooter.js +11 -0
  686. package/src/components/wizard/WizardProvider.js +217 -0
  687. package/src/components/wizard/index.js +4 -0
  688. package/src/components/wizard/useWizard.js +9 -0
  689. package/src/constants/apiLimits.js +81 -0
  690. package/src/constants/betas.js +45 -0
  691. package/src/constants/common.js +29 -0
  692. package/src/constants/cyberRiskInstruction.js +23 -0
  693. package/src/constants/errorIds.js +14 -0
  694. package/src/constants/figures.js +38 -0
  695. package/src/constants/files.js +150 -0
  696. package/src/constants/github-app.js +139 -0
  697. package/src/constants/identity.js +112 -0
  698. package/src/constants/keys.js +10 -0
  699. package/src/constants/messages.js +1 -0
  700. package/src/constants/oauth.js +175 -0
  701. package/src/constants/outputStyles.js +162 -0
  702. package/src/constants/product.js +54 -0
  703. package/src/constants/prompts.js +994 -0
  704. package/src/constants/spinnerVerbs.js +98 -0
  705. package/src/constants/system.js +77 -0
  706. package/src/constants/systemPromptSections.js +39 -0
  707. package/src/constants/toolLimits.js +50 -0
  708. package/src/constants/tools.js +103 -0
  709. package/src/constants/turnCompletionVerbs.js +12 -0
  710. package/src/constants/xml.js +73 -0
  711. package/src/context/QueuedMessageContext.js +51 -0
  712. package/src/context/fpsMetrics.js +22 -0
  713. package/src/context/mailbox.js +35 -0
  714. package/src/context/modalContext.js +34 -0
  715. package/src/context/notifications.js +199 -0
  716. package/src/context/overlayContext.js +149 -0
  717. package/src/context/promptOverlayContext.js +118 -0
  718. package/src/context/stats.js +207 -0
  719. package/src/context/voice.js +74 -0
  720. package/src/context.js +146 -0
  721. package/src/coordinator/coordinatorMode.js +345 -0
  722. package/src/coordinator/workerAgent.js +24 -0
  723. package/src/cost-tracker.js +208 -0
  724. package/src/costHook.js +17 -0
  725. package/src/daemon/main.js +19 -0
  726. package/src/dialogLaunchers.js +77 -0
  727. package/src/entrypoints/agentSdkTypes.js +202 -0
  728. package/src/entrypoints/cli.js +226 -0
  729. package/src/entrypoints/init.js +265 -0
  730. package/src/entrypoints/mcp.js +141 -0
  731. package/src/entrypoints/sandboxTypes.js +112 -0
  732. package/src/entrypoints/sdk/controlSchemas.js +452 -0
  733. package/src/entrypoints/sdk/controlTypes.js +1 -0
  734. package/src/entrypoints/sdk/coreSchemas.js +1331 -0
  735. package/src/entrypoints/sdk/coreTypes.generated.js +3 -0
  736. package/src/entrypoints/sdk/coreTypes.js +49 -0
  737. package/src/entrypoints/sdk/runtimeTypes.js +1 -0
  738. package/src/entrypoints/sdk/sdkUtilityTypes.js +1 -0
  739. package/src/entrypoints/sdk/settingsTypes.generated.js +1 -0
  740. package/src/entrypoints/sdk/toolTypes.js +1 -0
  741. package/src/environment-runner/main.js +8 -0
  742. package/src/history.js +386 -0
  743. package/src/hooks/fileSuggestions.js +635 -0
  744. package/src/hooks/notifs/useAntOrgWarningNotification.js +5 -0
  745. package/src/hooks/notifs/useAutoModeUnavailableNotification.js +47 -0
  746. package/src/hooks/notifs/useCanSwitchToExistingSubscription.js +58 -0
  747. package/src/hooks/notifs/useDeprecationWarningNotification.js +43 -0
  748. package/src/hooks/notifs/useFastModeNotification.js +164 -0
  749. package/src/hooks/notifs/useIDEStatusIndicator.js +174 -0
  750. package/src/hooks/notifs/useInstallMessages.js +27 -0
  751. package/src/hooks/notifs/useLspInitializationNotification.js +144 -0
  752. package/src/hooks/notifs/useMcpConnectivityStatus.js +81 -0
  753. package/src/hooks/notifs/useModelMigrationNotifications.js +53 -0
  754. package/src/hooks/notifs/useNpmDeprecationNotification.js +25 -0
  755. package/src/hooks/notifs/usePluginAutoupdateNotification.js +83 -0
  756. package/src/hooks/notifs/usePluginInstallationStatus.js +128 -0
  757. package/src/hooks/notifs/useRateLimitWarningNotification.js +119 -0
  758. package/src/hooks/notifs/useSettingsErrors.js +64 -0
  759. package/src/hooks/notifs/useStartupNotification.js +33 -0
  760. package/src/hooks/notifs/useTeammateShutdownNotification.js +64 -0
  761. package/src/hooks/renderPlaceholder.js +26 -0
  762. package/src/hooks/toolPermission/PermissionContext.js +211 -0
  763. package/src/hooks/toolPermission/handlers/coordinatorHandler.js +44 -0
  764. package/src/hooks/toolPermission/handlers/interactiveHandler.js +397 -0
  765. package/src/hooks/toolPermission/handlers/swarmWorkerHandler.js +108 -0
  766. package/src/hooks/toolPermission/permissionLogging.js +145 -0
  767. package/src/hooks/unifiedSuggestions.js +130 -0
  768. package/src/hooks/useAfterFirstRender.js +12 -0
  769. package/src/hooks/useApiKeyVerification.js +63 -0
  770. package/src/hooks/useArrowKeyHistory.js +203 -0
  771. package/src/hooks/useAssistantHistory.js +193 -0
  772. package/src/hooks/useAwaySummary.js +105 -0
  773. package/src/hooks/useBackgroundTaskNavigation.js +204 -0
  774. package/src/hooks/useBlink.js +28 -0
  775. package/src/hooks/useCanUseTool.js +193 -0
  776. package/src/hooks/useCancelRequest.js +195 -0
  777. package/src/hooks/useChromeExtensionNotification.js +50 -0
  778. package/src/hooks/useClipboardImageHint.js +59 -0
  779. package/src/hooks/useCommandKeybindings.js +87 -0
  780. package/src/hooks/useCommandQueue.js +10 -0
  781. package/src/hooks/useCopyOnSelect.js +88 -0
  782. package/src/hooks/useDeferredHookMessages.js +43 -0
  783. package/src/hooks/useDiffData.js +69 -0
  784. package/src/hooks/useDiffInIDE.js +252 -0
  785. package/src/hooks/useDirectConnect.js +150 -0
  786. package/src/hooks/useDoublePress.js +44 -0
  787. package/src/hooks/useDynamicConfig.js +17 -0
  788. package/src/hooks/useElapsedTime.js +25 -0
  789. package/src/hooks/useExitOnCtrlCD.js +57 -0
  790. package/src/hooks/useExitOnCtrlCDWithKeybindings.js +17 -0
  791. package/src/hooks/useFileHistorySnapshotInit.js +14 -0
  792. package/src/hooks/useGlobalKeybindings.js +213 -0
  793. package/src/hooks/useHistorySearch.js +241 -0
  794. package/src/hooks/useIDEIntegration.js +56 -0
  795. package/src/hooks/useIdeAtMentioned.js +51 -0
  796. package/src/hooks/useIdeConnectionStatus.js +21 -0
  797. package/src/hooks/useIdeLogging.js +29 -0
  798. package/src/hooks/useIdeSelection.js +106 -0
  799. package/src/hooks/useInboxPoller.js +709 -0
  800. package/src/hooks/useInputBuffer.js +73 -0
  801. package/src/hooks/useIssueFlagBanner.js +115 -0
  802. package/src/hooks/useLogMessages.js +98 -0
  803. package/src/hooks/useLspPluginRecommendation.js +176 -0
  804. package/src/hooks/useMailboxBridge.js +15 -0
  805. package/src/hooks/useMainLoopModel.js +25 -0
  806. package/src/hooks/useManagePlugins.js +261 -0
  807. package/src/hooks/useMemoryUsage.js +28 -0
  808. package/src/hooks/useMergedClients.js +11 -0
  809. package/src/hooks/useMergedCommands.js +10 -0
  810. package/src/hooks/useMergedTools.js +32 -0
  811. package/src/hooks/useMinDisplayTime.js +26 -0
  812. package/src/hooks/useNotifyAfterTimeout.js +51 -0
  813. package/src/hooks/useOfficialMarketplaceNotification.js +47 -0
  814. package/src/hooks/usePasteHandler.js +195 -0
  815. package/src/hooks/usePluginRecommendationBase.js +101 -0
  816. package/src/hooks/usePrStatus.js +91 -0
  817. package/src/hooks/usePromptSuggestion.js +128 -0
  818. package/src/hooks/usePromptsFromClaudeInChrome.js +66 -0
  819. package/src/hooks/useQueueProcessor.js +46 -0
  820. package/src/hooks/useRemoteSession.js +431 -0
  821. package/src/hooks/useReplBridge.js +715 -0
  822. package/src/hooks/useSSHSession.js +167 -0
  823. package/src/hooks/useScheduledTasks.js +104 -0
  824. package/src/hooks/useSearchInput.js +302 -0
  825. package/src/hooks/useSessionBackgrounding.js +132 -0
  826. package/src/hooks/useSettings.js +10 -0
  827. package/src/hooks/useSettingsChange.js +13 -0
  828. package/src/hooks/useSkillImprovementSurvey.js +69 -0
  829. package/src/hooks/useSkillsChange.js +51 -0
  830. package/src/hooks/useSwarmInitialization.js +67 -0
  831. package/src/hooks/useSwarmPermissionPoller.js +215 -0
  832. package/src/hooks/useTaskListWatcher.js +157 -0
  833. package/src/hooks/useTasksV2.js +220 -0
  834. package/src/hooks/useTeammateViewAutoExit.js +55 -0
  835. package/src/hooks/useTeleportResume.js +81 -0
  836. package/src/hooks/useTerminalSize.js +9 -0
  837. package/src/hooks/useTextInput.js +397 -0
  838. package/src/hooks/useThaddeusHintRecommendation.js +117 -0
  839. package/src/hooks/useTimeout.js +10 -0
  840. package/src/hooks/useTurnDiffs.js +160 -0
  841. package/src/hooks/useTypeahead.js +1250 -0
  842. package/src/hooks/useUpdateNotification.js +21 -0
  843. package/src/hooks/useVimInput.js +232 -0
  844. package/src/hooks/useVirtualScroll.js +627 -0
  845. package/src/hooks/useVoice.js +952 -0
  846. package/src/hooks/useVoiceEnabled.js +21 -0
  847. package/src/hooks/useVoiceIntegration.js +629 -0
  848. package/src/infrastructure/audit.js +210 -0
  849. package/src/infrastructure/guardrails.js +513 -0
  850. package/src/infrastructure/index.js +11 -0
  851. package/src/ink/Ansi.js +269 -0
  852. package/src/ink/bidi.js +117 -0
  853. package/src/ink/clearTerminal.js +58 -0
  854. package/src/ink/colorize.js +198 -0
  855. package/src/ink/components/AlternateScreen.js +74 -0
  856. package/src/ink/components/App.js +562 -0
  857. package/src/ink/components/AppContext.js +11 -0
  858. package/src/ink/components/Box.js +155 -0
  859. package/src/ink/components/Button.js +166 -0
  860. package/src/ink/components/ClockContext.js +108 -0
  861. package/src/ink/components/CursorDeclarationContext.js +3 -0
  862. package/src/ink/components/ErrorOverview.js +50 -0
  863. package/src/ink/components/Link.js +34 -0
  864. package/src/ink/components/Newline.js +30 -0
  865. package/src/ink/components/NoSelect.js +57 -0
  866. package/src/ink/components/RawAnsi.js +46 -0
  867. package/src/ink/components/ScrollBox.js +171 -0
  868. package/src/ink/components/Spacer.js +20 -0
  869. package/src/ink/components/StdinContext.js +16 -0
  870. package/src/ink/components/TerminalFocusContext.js +45 -0
  871. package/src/ink/components/TerminalSizeContext.js +3 -0
  872. package/src/ink/components/Text.js +195 -0
  873. package/src/ink/constants.js +2 -0
  874. package/src/ink/dom.js +298 -0
  875. package/src/ink/events/click-event.js +36 -0
  876. package/src/ink/events/dispatcher.js +172 -0
  877. package/src/ink/events/emitter.js +31 -0
  878. package/src/ink/events/event-handlers.js +30 -0
  879. package/src/ink/events/event.js +9 -0
  880. package/src/ink/events/focus-event.js +16 -0
  881. package/src/ink/events/input-event.js +161 -0
  882. package/src/ink/events/keyboard-event.js +46 -0
  883. package/src/ink/events/terminal-event.js +78 -0
  884. package/src/ink/events/terminal-focus-event.js +15 -0
  885. package/src/ink/focus.js +158 -0
  886. package/src/ink/frame.js +30 -0
  887. package/src/ink/get-max-width.js +23 -0
  888. package/src/ink/hit-test.js +113 -0
  889. package/src/ink/hooks/use-animation-frame.js +48 -0
  890. package/src/ink/hooks/use-app.js +7 -0
  891. package/src/ink/hooks/use-declared-cursor.js +60 -0
  892. package/src/ink/hooks/use-input.js +70 -0
  893. package/src/ink/hooks/use-interval.js +54 -0
  894. package/src/ink/hooks/use-search-highlight.js +32 -0
  895. package/src/ink/hooks/use-selection.js +60 -0
  896. package/src/ink/hooks/use-stdin.js +7 -0
  897. package/src/ink/hooks/use-tab-status.js +57 -0
  898. package/src/ink/hooks/use-terminal-focus.js +15 -0
  899. package/src/ink/hooks/use-terminal-title.js +29 -0
  900. package/src/ink/hooks/use-terminal-viewport.js +77 -0
  901. package/src/ink/ink.js +1645 -0
  902. package/src/ink/instances.js +7 -0
  903. package/src/ink/layout/engine.js +4 -0
  904. package/src/ink/layout/geometry.js +61 -0
  905. package/src/ink/layout/node.js +62 -0
  906. package/src/ink/layout/yoga.js +237 -0
  907. package/src/ink/line-width-cache.js +19 -0
  908. package/src/ink/log-update.js +583 -0
  909. package/src/ink/measure-element.js +8 -0
  910. package/src/ink/measure-text.js +35 -0
  911. package/src/ink/node-cache.js +30 -0
  912. package/src/ink/optimizer.js +81 -0
  913. package/src/ink/output.js +556 -0
  914. package/src/ink/parse-keypress.js +695 -0
  915. package/src/ink/reconciler.js +384 -0
  916. package/src/ink/render-border.js +134 -0
  917. package/src/ink/render-node-to-output.js +1216 -0
  918. package/src/ink/render-to-screen.js +171 -0
  919. package/src/ink/renderer.js +129 -0
  920. package/src/ink/root.js +80 -0
  921. package/src/ink/screen.js +1132 -0
  922. package/src/ink/searchHighlight.js +78 -0
  923. package/src/ink/selection.js +792 -0
  924. package/src/ink/squash-text-nodes.js +56 -0
  925. package/src/ink/stringWidth.js +200 -0
  926. package/src/ink/styles.js +299 -0
  927. package/src/ink/supports-hyperlinks.js +40 -0
  928. package/src/ink/tabstops.js +39 -0
  929. package/src/ink/terminal-focus-state.js +35 -0
  930. package/src/ink/terminal-querier.js +173 -0
  931. package/src/ink/terminal.js +208 -0
  932. package/src/ink/termio/ansi.js +70 -0
  933. package/src/ink/termio/csi.js +260 -0
  934. package/src/ink/termio/dec.js +53 -0
  935. package/src/ink/termio/esc.js +55 -0
  936. package/src/ink/termio/osc.js +432 -0
  937. package/src/ink/termio/parser.js +356 -0
  938. package/src/ink/termio/sgr.js +292 -0
  939. package/src/ink/termio/tokenize.js +264 -0
  940. package/src/ink/termio/types.js +55 -0
  941. package/src/ink/termio.js +24 -0
  942. package/src/ink/useTerminalNotification.js +57 -0
  943. package/src/ink/warn.js +10 -0
  944. package/src/ink/widest-line.js +14 -0
  945. package/src/ink/wrap-text.js +54 -0
  946. package/src/ink/wrapAnsi.js +6 -0
  947. package/src/ink.js +50 -0
  948. package/src/integrations/credentialStore.js +176 -0
  949. package/src/integrations/index.js +5 -0
  950. package/src/integrations/integrationManager.js +180 -0
  951. package/src/integrations/providers/BaseProvider.js +180 -0
  952. package/src/integrations/providers/GitHubProvider.js +217 -0
  953. package/src/integrations/providers/GmailProvider.js +204 -0
  954. package/src/integrations/providers/GoogleCalendarProvider.js +113 -0
  955. package/src/integrations/providers/HubSpotProvider.js +159 -0
  956. package/src/integrations/providers/JiraProvider.js +216 -0
  957. package/src/integrations/providers/NotionProvider.js +221 -0
  958. package/src/integrations/providers/QuickBooksProvider.js +176 -0
  959. package/src/integrations/providers/SlackProvider.js +174 -0
  960. package/src/integrations/providers/StripeProvider.js +206 -0
  961. package/src/integrations/providers/TwilioProvider.js +239 -0
  962. package/src/integrations/providers/_template.js +112 -0
  963. package/src/integrations/types.js +7 -0
  964. package/src/interactiveHelpers.js +308 -0
  965. package/src/jobs/classifier.js +6 -0
  966. package/src/keybindings/KeybindingContext.js +184 -0
  967. package/src/keybindings/KeybindingProviderSetup.js +259 -0
  968. package/src/keybindings/defaultBindings.js +333 -0
  969. package/src/keybindings/loadUserBindings.js +393 -0
  970. package/src/keybindings/match.js +111 -0
  971. package/src/keybindings/parser.js +184 -0
  972. package/src/keybindings/reservedShortcuts.js +109 -0
  973. package/src/keybindings/resolver.js +182 -0
  974. package/src/keybindings/schema.js +205 -0
  975. package/src/keybindings/shortcutFormat.js +48 -0
  976. package/src/keybindings/template.js +40 -0
  977. package/src/keybindings/useKeybinding.js +161 -0
  978. package/src/keybindings/useShortcutDisplay.js +43 -0
  979. package/src/keybindings/validate.js +395 -0
  980. package/src/main.js +4128 -0
  981. package/src/memdir/findRelevantMemories.js +99 -0
  982. package/src/memdir/memdir.js +406 -0
  983. package/src/memdir/memoryAge.js +52 -0
  984. package/src/memdir/memoryScan.js +65 -0
  985. package/src/memdir/memoryShapeTelemetry.js +8 -0
  986. package/src/memdir/memoryTypes.js +260 -0
  987. package/src/memdir/paths.js +235 -0
  988. package/src/memdir/teamMemPaths.js +261 -0
  989. package/src/memdir/teamMemPrompts.js +82 -0
  990. package/src/migrations/migrateAutoUpdatesToSettings.js +47 -0
  991. package/src/migrations/migrateBypassPermissionsAcceptedToSettings.js +32 -0
  992. package/src/migrations/migrateEnableAllProjectMcpServersToSettings.js +83 -0
  993. package/src/migrations/migrateFennecToOpus.js +39 -0
  994. package/src/migrations/migrateLegacyOpusToCurrent.js +44 -0
  995. package/src/migrations/migrateOpusToOpus1m.js +31 -0
  996. package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.js +23 -0
  997. package/src/migrations/migrateSonnet1mToSonnet45.js +38 -0
  998. package/src/migrations/migrateSonnet45ToSonnet46.js +48 -0
  999. package/src/migrations/resetAutoModeOptInForDefaultOffer.js +47 -0
  1000. package/src/migrations/resetProToOpusDefault.js +46 -0
  1001. package/src/moreright/useMoreRight.js +13 -0
  1002. package/src/native-ts/color-diff/index.js +819 -0
  1003. package/src/native-ts/file-index/index.js +328 -0
  1004. package/src/native-ts/yoga-layout/enums.js +101 -0
  1005. package/src/native-ts/yoga-layout/index.js +2113 -0
  1006. package/src/outputStyles/loadOutputStylesDir.js +71 -0
  1007. package/src/plugins/builtinPlugins.js +132 -0
  1008. package/src/plugins/bundled/index.js +22 -0
  1009. package/src/proactive/index.js +138 -0
  1010. package/src/proactive/useProactive.js +82 -0
  1011. package/src/projectOnboardingState.js +61 -0
  1012. package/src/query/config.js +17 -0
  1013. package/src/query/deps.js +12 -0
  1014. package/src/query/stopHooks.js +332 -0
  1015. package/src/query/tokenBudget.js +49 -0
  1016. package/src/query.js +1264 -0
  1017. package/src/remote/RemoteSessionManager.js +172 -0
  1018. package/src/remote/SessionsWebSocket.js +308 -0
  1019. package/src/remote/remotePermissionBridge.js +70 -0
  1020. package/src/remote/sdkMessageAdapter.js +227 -0
  1021. package/src/replLauncher.js +7 -0
  1022. package/src/schemas/hooks.js +174 -0
  1023. package/src/screens/Doctor.js +580 -0
  1024. package/src/screens/REPL.js +4500 -0
  1025. package/src/screens/ResumeConversation.js +339 -0
  1026. package/src/self-hosted-runner/main.js +8 -0
  1027. package/src/server/backends/dangerousBackend.js +8 -0
  1028. package/src/server/connectHeadless.js +6 -0
  1029. package/src/server/createDirectConnectSession.js +62 -0
  1030. package/src/server/directConnectManager.js +153 -0
  1031. package/src/server/lockfile.js +11 -0
  1032. package/src/server/parseConnectUrl.js +20 -0
  1033. package/src/server/server.js +12 -0
  1034. package/src/server/serverBanner.js +9 -0
  1035. package/src/server/serverLog.js +11 -0
  1036. package/src/server/sessionManager.js +19 -0
  1037. package/src/server/types.js +7 -0
  1038. package/src/services/AgentSummary/agentSummary.js +147 -0
  1039. package/src/services/MagicDocs/magicDocs.js +193 -0
  1040. package/src/services/MagicDocs/prompts.js +110 -0
  1041. package/src/services/PromptSuggestion/promptSuggestion.js +402 -0
  1042. package/src/services/PromptSuggestion/speculation.js +643 -0
  1043. package/src/services/SessionMemory/prompts.js +254 -0
  1044. package/src/services/SessionMemory/sessionMemory.js +358 -0
  1045. package/src/services/SessionMemory/sessionMemoryUtils.js +157 -0
  1046. package/src/services/analytics/config.js +27 -0
  1047. package/src/services/analytics/datadog.js +26 -0
  1048. package/src/services/analytics/firstPartyEventLogger.js +65 -0
  1049. package/src/services/analytics/firstPartyEventLoggingExporter.js +595 -0
  1050. package/src/services/analytics/growthbook.js +103 -0
  1051. package/src/services/analytics/index.js +91 -0
  1052. package/src/services/analytics/metadata.js +696 -0
  1053. package/src/services/analytics/sink.js +19 -0
  1054. package/src/services/analytics/sinkKillswitch.js +19 -0
  1055. package/src/services/api/adminRequests.js +57 -0
  1056. package/src/services/api/bootstrap.js +118 -0
  1057. package/src/services/api/claude.js +2466 -0
  1058. package/src/services/api/client.js +335 -0
  1059. package/src/services/api/dumpPrompts.js +174 -0
  1060. package/src/services/api/emptyUsage.js +20 -0
  1061. package/src/services/api/errorUtils.js +203 -0
  1062. package/src/services/api/errors.js +926 -0
  1063. package/src/services/api/filesApi.js +523 -0
  1064. package/src/services/api/firstTokenDate.js +49 -0
  1065. package/src/services/api/grove.js +44 -0
  1066. package/src/services/api/logging.js +484 -0
  1067. package/src/services/api/metricsOptOut.js +15 -0
  1068. package/src/services/api/overageCreditGrant.js +123 -0
  1069. package/src/services/api/promptCacheBreakDetection.js +510 -0
  1070. package/src/services/api/referral.js +219 -0
  1071. package/src/services/api/sessionIngress.js +358 -0
  1072. package/src/services/api/ultrareviewQuota.js +29 -0
  1073. package/src/services/api/usage.js +31 -0
  1074. package/src/services/api/withRetry.js +587 -0
  1075. package/src/services/api/xai/anthropic-shim.js +885 -0
  1076. package/src/services/api/xai/brightDataSearch.js +161 -0
  1077. package/src/services/api/xai/thaddeus-engine.js +605 -0
  1078. package/src/services/api/xai/xai-client.js +276 -0
  1079. package/src/services/autoDream/autoDream.js +244 -0
  1080. package/src/services/autoDream/config.js +17 -0
  1081. package/src/services/autoDream/consolidationLock.js +122 -0
  1082. package/src/services/autoDream/consolidationPrompt.js +55 -0
  1083. package/src/services/awaySummary.js +61 -0
  1084. package/src/services/claudeAiLimits.js +331 -0
  1085. package/src/services/claudeAiLimitsHook.js +15 -0
  1086. package/src/services/compact/apiMicrocompact.js +97 -0
  1087. package/src/services/compact/autoCompact.js +234 -0
  1088. package/src/services/compact/cachedMCConfig.js +5 -0
  1089. package/src/services/compact/compact.js +1256 -0
  1090. package/src/services/compact/compactWarningHook.js +12 -0
  1091. package/src/services/compact/compactWarningState.js +15 -0
  1092. package/src/services/compact/grouping.js +58 -0
  1093. package/src/services/compact/microCompact.js +414 -0
  1094. package/src/services/compact/postCompactCleanup.js +70 -0
  1095. package/src/services/compact/prompt.js +325 -0
  1096. package/src/services/compact/reactiveCompact.js +20 -0
  1097. package/src/services/compact/sessionMemoryCompact.js +467 -0
  1098. package/src/services/compact/snipCompact.js +23 -0
  1099. package/src/services/compact/snipProjection.js +11 -0
  1100. package/src/services/compact/timeBasedMCConfig.js +11 -0
  1101. package/src/services/contextCollapse/index.js +33 -0
  1102. package/src/services/contextCollapse/operations.js +5 -0
  1103. package/src/services/contextCollapse/persist.js +5 -0
  1104. package/src/services/diagnosticTracking.js +282 -0
  1105. package/src/services/elevenlabsTTS.js +245 -0
  1106. package/src/services/extractMemories/extractMemories.js +442 -0
  1107. package/src/services/extractMemories/prompts.js +129 -0
  1108. package/src/services/internalLogging.js +68 -0
  1109. package/src/services/lsp/LSPClient.js +306 -0
  1110. package/src/services/lsp/LSPDiagnosticRegistry.js +277 -0
  1111. package/src/services/lsp/LSPServerInstance.js +388 -0
  1112. package/src/services/lsp/LSPServerManager.js +305 -0
  1113. package/src/services/lsp/config.js +57 -0
  1114. package/src/services/lsp/manager.js +246 -0
  1115. package/src/services/lsp/passiveFeedback.js +226 -0
  1116. package/src/services/mcp/InProcessTransport.js +54 -0
  1117. package/src/services/mcp/MCPConnectionManager.js +50 -0
  1118. package/src/services/mcp/SdkControlTransport.js +115 -0
  1119. package/src/services/mcp/auth.js +1882 -0
  1120. package/src/services/mcp/channelAllowlist.js +57 -0
  1121. package/src/services/mcp/channelNotification.js +235 -0
  1122. package/src/services/mcp/channelPermissions.js +192 -0
  1123. package/src/services/mcp/claudeai.js +123 -0
  1124. package/src/services/mcp/client.js +2478 -0
  1125. package/src/services/mcp/config.js +1271 -0
  1126. package/src/services/mcp/elicitationHandler.js +192 -0
  1127. package/src/services/mcp/envExpansion.js +30 -0
  1128. package/src/services/mcp/headersHelper.js +93 -0
  1129. package/src/services/mcp/mcpStringUtils.js +85 -0
  1130. package/src/services/mcp/normalization.js +21 -0
  1131. package/src/services/mcp/oauthPort.js +69 -0
  1132. package/src/services/mcp/officialRegistry.js +20 -0
  1133. package/src/services/mcp/types.js +94 -0
  1134. package/src/services/mcp/useManageMCPConnections.js +818 -0
  1135. package/src/services/mcp/utils.js +433 -0
  1136. package/src/services/mcp/vscodeSdkMcp.js +69 -0
  1137. package/src/services/mcp/xaa.js +342 -0
  1138. package/src/services/mcp/xaaIdpLogin.js +377 -0
  1139. package/src/services/mcpServerApproval.js +30 -0
  1140. package/src/services/mockRateLimits.js +666 -0
  1141. package/src/services/notifier.js +114 -0
  1142. package/src/services/oauth/auth-code-listener.js +165 -0
  1143. package/src/services/oauth/client.js +397 -0
  1144. package/src/services/oauth/crypto.js +19 -0
  1145. package/src/services/oauth/getOauthProfile.js +48 -0
  1146. package/src/services/oauth/index.js +133 -0
  1147. package/src/services/plugins/PluginInstallationManager.js +139 -0
  1148. package/src/services/plugins/pluginCliCommands.js +230 -0
  1149. package/src/services/plugins/pluginOperations.js +826 -0
  1150. package/src/services/policyLimits/index.js +547 -0
  1151. package/src/services/policyLimits/types.js +9 -0
  1152. package/src/services/preventSleep.js +143 -0
  1153. package/src/services/rateLimitMessages.js +271 -0
  1154. package/src/services/rateLimitMocking.js +91 -0
  1155. package/src/services/remoteManagedSettings/index.js +534 -0
  1156. package/src/services/remoteManagedSettings/securityCheck.js +60 -0
  1157. package/src/services/remoteManagedSettings/syncCache.js +90 -0
  1158. package/src/services/remoteManagedSettings/syncCacheState.js +89 -0
  1159. package/src/services/remoteManagedSettings/types.js +12 -0
  1160. package/src/services/sessionTranscript/sessionTranscript.js +5 -0
  1161. package/src/services/settingsSync/index.js +478 -0
  1162. package/src/services/settingsSync/types.js +35 -0
  1163. package/src/services/skillSearch/featureCheck.js +8 -0
  1164. package/src/services/skillSearch/localSearch.js +5 -0
  1165. package/src/services/skillSearch/prefetch.js +8 -0
  1166. package/src/services/skillSearch/remoteSkillLoader.js +8 -0
  1167. package/src/services/skillSearch/remoteSkillState.js +11 -0
  1168. package/src/services/skillSearch/signals.js +3 -0
  1169. package/src/services/skillSearch/telemetry.js +8 -0
  1170. package/src/services/teamMemorySync/index.js +976 -0
  1171. package/src/services/teamMemorySync/secretScanner.js +275 -0
  1172. package/src/services/teamMemorySync/teamMemSecretGuard.js +33 -0
  1173. package/src/services/teamMemorySync/types.js +47 -0
  1174. package/src/services/teamMemorySync/watcher.js +326 -0
  1175. package/src/services/thaddeusAuth.js +485 -0
  1176. package/src/services/thaddeusAuthTypes.js +9 -0
  1177. package/src/services/thaddeusLoginFlow.js +236 -0
  1178. package/src/services/tips/tipHistory.js +17 -0
  1179. package/src/services/tips/tipRegistry.js +593 -0
  1180. package/src/services/tips/tipScheduler.js +40 -0
  1181. package/src/services/tokenEstimation.js +365 -0
  1182. package/src/services/toolUseSummary/toolUseSummaryGenerator.js +87 -0
  1183. package/src/services/tools/StreamingToolExecutor.js +413 -0
  1184. package/src/services/tools/toolExecution.js +1309 -0
  1185. package/src/services/tools/toolHooks.js +454 -0
  1186. package/src/services/tools/toolOrchestration.js +110 -0
  1187. package/src/services/vcr.js +291 -0
  1188. package/src/services/voice.js +392 -0
  1189. package/src/services/voiceKeyterms.js +94 -0
  1190. package/src/services/voiceStreamSTT.js +405 -0
  1191. package/src/setup.js +310 -0
  1192. package/src/skills/bundled/batch.js +114 -0
  1193. package/src/skills/bundled/claudeApi.js +145 -0
  1194. package/src/skills/bundled/claudeApiContent.js +71 -0
  1195. package/src/skills/bundled/claudeInChrome.js +27 -0
  1196. package/src/skills/bundled/debug.js +99 -0
  1197. package/src/skills/bundled/dream.js +49 -0
  1198. package/src/skills/bundled/emailSetup.js +196 -0
  1199. package/src/skills/bundled/hunter.js +28 -0
  1200. package/src/skills/bundled/index.js +80 -0
  1201. package/src/skills/bundled/keybindings.js +292 -0
  1202. package/src/skills/bundled/loop.js +81 -0
  1203. package/src/skills/bundled/loremIpsum.js +264 -0
  1204. package/src/skills/bundled/reactor.js +31 -0
  1205. package/src/skills/bundled/remember.js +73 -0
  1206. package/src/skills/bundled/runSkillGenerator.js +12 -0
  1207. package/src/skills/bundled/scheduleRemoteAgents.js +373 -0
  1208. package/src/skills/bundled/simplify.js +66 -0
  1209. package/src/skills/bundled/skillify.js +182 -0
  1210. package/src/skills/bundled/stuck.js +69 -0
  1211. package/src/skills/bundled/updateConfig.js +463 -0
  1212. package/src/skills/bundled/verify.js +23 -0
  1213. package/src/skills/bundled/verifyContent.js +10 -0
  1214. package/src/skills/bundledSkills.js +159 -0
  1215. package/src/skills/loadSkillsDir.js +736 -0
  1216. package/src/skills/mcpSkillBuilders.js +10 -0
  1217. package/src/skills/mcpSkills.js +5 -0
  1218. package/src/state/AppState.js +182 -0
  1219. package/src/state/AppStateStore.js +117 -0
  1220. package/src/state/onChangeAppState.js +132 -0
  1221. package/src/state/selectors.js +51 -0
  1222. package/src/state/store.js +21 -0
  1223. package/src/state/teammateViewHelpers.js +124 -0
  1224. package/src/stubs/ant-chrome-mcp/index.js +4 -0
  1225. package/src/stubs/ant-computer-use-input/index.js +2 -0
  1226. package/src/stubs/ant-computer-use-mcp/index.js +7 -0
  1227. package/src/stubs/ant-computer-use-mcp/sentinelApps.js +2 -0
  1228. package/src/stubs/ant-computer-use-mcp/types.js +3 -0
  1229. package/src/stubs/ant-computer-use-swift/index.js +1 -0
  1230. package/src/stubs/anthropic-sandbox/index.js +34 -0
  1231. package/src/tasks/DreamTask/DreamTask.js +99 -0
  1232. package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.js +116 -0
  1233. package/src/tasks/InProcessTeammateTask/types.js +35 -0
  1234. package/src/tasks/LocalAgentTask/LocalAgentTask.js +507 -0
  1235. package/src/tasks/LocalMainSessionTask.js +338 -0
  1236. package/src/tasks/LocalShellTask/LocalShellTask.js +475 -0
  1237. package/src/tasks/LocalShellTask/guards.js +9 -0
  1238. package/src/tasks/LocalShellTask/killShellTasks.js +59 -0
  1239. package/src/tasks/LocalWorkflowTask/LocalWorkflowTask.js +7 -0
  1240. package/src/tasks/MonitorMcpTask/MonitorMcpTask.js +20 -0
  1241. package/src/tasks/RemoteAgentTask/RemoteAgentTask.js +742 -0
  1242. package/src/tasks/pillLabel.js +69 -0
  1243. package/src/tasks/stopTask.js +67 -0
  1244. package/src/tasks/types.js +18 -0
  1245. package/src/tasks.js +37 -0
  1246. package/src/tools/AIEmployeesTool/AIEmployeesTool.js +674 -0
  1247. package/src/tools/AIEmployeesTool/constants.js +1 -0
  1248. package/src/tools/AIEmployeesTool/prompt.js +56 -0
  1249. package/src/tools/AgentTool/AgentTool.js +1221 -0
  1250. package/src/tools/AgentTool/UI.js +593 -0
  1251. package/src/tools/AgentTool/agentColorManager.js +43 -0
  1252. package/src/tools/AgentTool/agentDisplay.js +72 -0
  1253. package/src/tools/AgentTool/agentMemory.js +125 -0
  1254. package/src/tools/AgentTool/agentMemorySnapshot.js +136 -0
  1255. package/src/tools/AgentTool/agentToolUtils.js +456 -0
  1256. package/src/tools/AgentTool/built-in/exploreAgent.js +76 -0
  1257. package/src/tools/AgentTool/built-in/generalPurposeAgent.js +28 -0
  1258. package/src/tools/AgentTool/built-in/planAgent.js +87 -0
  1259. package/src/tools/AgentTool/built-in/statuslineSetup.js +140 -0
  1260. package/src/tools/AgentTool/built-in/thaddeusGuideAgent.js +174 -0
  1261. package/src/tools/AgentTool/built-in/verificationAgent.js +146 -0
  1262. package/src/tools/AgentTool/builtInAgents.js +56 -0
  1263. package/src/tools/AgentTool/constants.js +11 -0
  1264. package/src/tools/AgentTool/forkSubagent.js +177 -0
  1265. package/src/tools/AgentTool/loadAgentsDir.js +497 -0
  1266. package/src/tools/AgentTool/prompt.js +260 -0
  1267. package/src/tools/AgentTool/resumeAgent.js +182 -0
  1268. package/src/tools/AgentTool/runAgent.js +627 -0
  1269. package/src/tools/AppointmentsTool/AppointmentsTool.js +628 -0
  1270. package/src/tools/AppointmentsTool/constants.js +1 -0
  1271. package/src/tools/AppointmentsTool/prompt.js +15 -0
  1272. package/src/tools/AskUserQuestionTool/AskUserQuestionTool.js +238 -0
  1273. package/src/tools/AskUserQuestionTool/prompt.js +38 -0
  1274. package/src/tools/BashTool/BashTool.js +1009 -0
  1275. package/src/tools/BashTool/BashToolResultMessage.js +169 -0
  1276. package/src/tools/BashTool/UI.js +134 -0
  1277. package/src/tools/BashTool/bashCommandHelpers.js +184 -0
  1278. package/src/tools/BashTool/bashPermissions.js +2023 -0
  1279. package/src/tools/BashTool/bashSecurity.js +2267 -0
  1280. package/src/tools/BashTool/commandSemantics.js +105 -0
  1281. package/src/tools/BashTool/commentLabel.js +14 -0
  1282. package/src/tools/BashTool/destructiveCommandWarning.js +88 -0
  1283. package/src/tools/BashTool/modeValidation.js +86 -0
  1284. package/src/tools/BashTool/pathValidation.js +1079 -0
  1285. package/src/tools/BashTool/prompt.js +333 -0
  1286. package/src/tools/BashTool/readOnlyValidation.js +1794 -0
  1287. package/src/tools/BashTool/sedEditParser.js +282 -0
  1288. package/src/tools/BashTool/sedValidation.js +580 -0
  1289. package/src/tools/BashTool/shouldUseSandbox.js +125 -0
  1290. package/src/tools/BashTool/toolName.js +2 -0
  1291. package/src/tools/BashTool/utils.js +180 -0
  1292. package/src/tools/BriefTool/BriefTool.js +173 -0
  1293. package/src/tools/BriefTool/UI.js +67 -0
  1294. package/src/tools/BriefTool/attachments.js +86 -0
  1295. package/src/tools/BriefTool/prompt.js +19 -0
  1296. package/src/tools/BriefTool/upload.js +136 -0
  1297. package/src/tools/CalendarTool/CalendarTool.js +498 -0
  1298. package/src/tools/CalendarTool/constants.js +1 -0
  1299. package/src/tools/CalendarTool/prompt.js +11 -0
  1300. package/src/tools/ConfigTool/ConfigTool.js +398 -0
  1301. package/src/tools/ConfigTool/UI.js +25 -0
  1302. package/src/tools/ConfigTool/constants.js +1 -0
  1303. package/src/tools/ConfigTool/prompt.js +82 -0
  1304. package/src/tools/ConfigTool/supportedSettings.js +180 -0
  1305. package/src/tools/ContactsTool/ContactsTool.js +648 -0
  1306. package/src/tools/ContactsTool/constants.js +1 -0
  1307. package/src/tools/ContactsTool/prompt.js +15 -0
  1308. package/src/tools/CtxInspectTool/CtxInspectTool.js +44 -0
  1309. package/src/tools/DiscoverSkillsTool/prompt.js +4 -0
  1310. package/src/tools/EmailReadTool/index.js +410 -0
  1311. package/src/tools/EmailSendTool/index.js +178 -0
  1312. package/src/tools/EnterPlanModeTool/EnterPlanModeTool.js +98 -0
  1313. package/src/tools/EnterPlanModeTool/UI.js +14 -0
  1314. package/src/tools/EnterPlanModeTool/constants.js +1 -0
  1315. package/src/tools/EnterPlanModeTool/prompt.js +164 -0
  1316. package/src/tools/EnterWorktreeTool/EnterWorktreeTool.js +104 -0
  1317. package/src/tools/EnterWorktreeTool/UI.js +9 -0
  1318. package/src/tools/EnterWorktreeTool/constants.js +1 -0
  1319. package/src/tools/EnterWorktreeTool/prompt.js +30 -0
  1320. package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.js +383 -0
  1321. package/src/tools/ExitPlanModeTool/UI.js +32 -0
  1322. package/src/tools/ExitPlanModeTool/constants.js +2 -0
  1323. package/src/tools/ExitPlanModeTool/prompt.js +27 -0
  1324. package/src/tools/ExitWorktreeTool/ExitWorktreeTool.js +257 -0
  1325. package/src/tools/ExitWorktreeTool/UI.js +10 -0
  1326. package/src/tools/ExitWorktreeTool/constants.js +1 -0
  1327. package/src/tools/ExitWorktreeTool/prompt.js +32 -0
  1328. package/src/tools/FileEditTool/FileEditTool.js +480 -0
  1329. package/src/tools/FileEditTool/UI.js +202 -0
  1330. package/src/tools/FileEditTool/constants.js +7 -0
  1331. package/src/tools/FileEditTool/prompt.js +24 -0
  1332. package/src/tools/FileEditTool/types.js +50 -0
  1333. package/src/tools/FileEditTool/utils.js +579 -0
  1334. package/src/tools/FileReadTool/FileReadTool.js +889 -0
  1335. package/src/tools/FileReadTool/UI.js +126 -0
  1336. package/src/tools/FileReadTool/imageProcessor.js +46 -0
  1337. package/src/tools/FileReadTool/limits.js +70 -0
  1338. package/src/tools/FileReadTool/prompt.js +31 -0
  1339. package/src/tools/FileWriteTool/FileWriteTool.js +341 -0
  1340. package/src/tools/FileWriteTool/UI.js +339 -0
  1341. package/src/tools/FileWriteTool/prompt.js +15 -0
  1342. package/src/tools/GlobTool/GlobTool.js +161 -0
  1343. package/src/tools/GlobTool/UI.js +40 -0
  1344. package/src/tools/GlobTool/prompt.js +6 -0
  1345. package/src/tools/GrepTool/GrepTool.js +439 -0
  1346. package/src/tools/GrepTool/UI.js +155 -0
  1347. package/src/tools/GrepTool/prompt.js +16 -0
  1348. package/src/tools/IntegrationsTool/IntegrationsTool.js +217 -0
  1349. package/src/tools/IntegrationsTool/constants.js +1 -0
  1350. package/src/tools/IntegrationsTool/prompt.js +41 -0
  1351. package/src/tools/InteractionsTool/InteractionsTool.js +525 -0
  1352. package/src/tools/InteractionsTool/constants.js +1 -0
  1353. package/src/tools/InteractionsTool/prompt.js +14 -0
  1354. package/src/tools/InvoicesTool/InvoicesTool.js +581 -0
  1355. package/src/tools/InvoicesTool/constants.js +1 -0
  1356. package/src/tools/InvoicesTool/prompt.js +15 -0
  1357. package/src/tools/LSPTool/LSPTool.js +660 -0
  1358. package/src/tools/LSPTool/UI.js +205 -0
  1359. package/src/tools/LSPTool/formatters.js +445 -0
  1360. package/src/tools/LSPTool/prompt.js +20 -0
  1361. package/src/tools/LSPTool/schemas.js +197 -0
  1362. package/src/tools/LSPTool/symbolContext.js +75 -0
  1363. package/src/tools/LeadScorerTool/LeadScorerTool.js +509 -0
  1364. package/src/tools/LeadScorerTool/constants.js +1 -0
  1365. package/src/tools/LeadScorerTool/prompt.js +11 -0
  1366. package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.js +100 -0
  1367. package/src/tools/ListMcpResourcesTool/UI.js +17 -0
  1368. package/src/tools/ListMcpResourcesTool/prompt.js +18 -0
  1369. package/src/tools/ListPeersTool/ListPeersTool.js +45 -0
  1370. package/src/tools/MCPTool/MCPTool.js +60 -0
  1371. package/src/tools/MCPTool/UI.js +343 -0
  1372. package/src/tools/MCPTool/classifyForCollapse.js +597 -0
  1373. package/src/tools/MCPTool/prompt.js +3 -0
  1374. package/src/tools/McpAuthTool/McpAuthTool.js +162 -0
  1375. package/src/tools/MonitorTool/MonitorTool.js +55 -0
  1376. package/src/tools/NotebookEditTool/NotebookEditTool.js +421 -0
  1377. package/src/tools/NotebookEditTool/UI.js +41 -0
  1378. package/src/tools/NotebookEditTool/constants.js +2 -0
  1379. package/src/tools/NotebookEditTool/prompt.js +2 -0
  1380. package/src/tools/OverflowTestTool/OverflowTestTool.js +51 -0
  1381. package/src/tools/PhoneBridgeTool/PhoneBridgeTool.js +301 -0
  1382. package/src/tools/PhoneBridgeTool/constants.js +1 -0
  1383. package/src/tools/PhoneBridgeTool/prompt.js +26 -0
  1384. package/src/tools/PowerShellTool/PowerShellTool.js +900 -0
  1385. package/src/tools/PowerShellTool/UI.js +58 -0
  1386. package/src/tools/PowerShellTool/clmTypes.js +207 -0
  1387. package/src/tools/PowerShellTool/commandSemantics.js +115 -0
  1388. package/src/tools/PowerShellTool/commonParameters.js +27 -0
  1389. package/src/tools/PowerShellTool/destructiveCommandWarning.js +92 -0
  1390. package/src/tools/PowerShellTool/gitSafety.js +185 -0
  1391. package/src/tools/PowerShellTool/modeValidation.js +357 -0
  1392. package/src/tools/PowerShellTool/pathValidation.js +1712 -0
  1393. package/src/tools/PowerShellTool/powershellPermissions.js +1351 -0
  1394. package/src/tools/PowerShellTool/powershellSecurity.js +942 -0
  1395. package/src/tools/PowerShellTool/prompt.js +132 -0
  1396. package/src/tools/PowerShellTool/readOnlyValidation.js +1633 -0
  1397. package/src/tools/PowerShellTool/toolName.js +2 -0
  1398. package/src/tools/PushNotificationTool/PushNotificationTool.js +35 -0
  1399. package/src/tools/REPLTool/REPLTool.js +44 -0
  1400. package/src/tools/REPLTool/constants.js +43 -0
  1401. package/src/tools/REPLTool/primitiveTools.js +36 -0
  1402. package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.js +112 -0
  1403. package/src/tools/ReadMcpResourceTool/UI.js +24 -0
  1404. package/src/tools/ReadMcpResourceTool/prompt.js +15 -0
  1405. package/src/tools/RemoteTriggerTool/RemoteTriggerTool.js +142 -0
  1406. package/src/tools/RemoteTriggerTool/UI.js +12 -0
  1407. package/src/tools/RemoteTriggerTool/prompt.js +12 -0
  1408. package/src/tools/ReviewArtifactTool/ReviewArtifactTool.js +51 -0
  1409. package/src/tools/ScheduleCronTool/CronCreateTool.js +120 -0
  1410. package/src/tools/ScheduleCronTool/CronDeleteTool.js +74 -0
  1411. package/src/tools/ScheduleCronTool/CronListTool.js +77 -0
  1412. package/src/tools/ScheduleCronTool/UI.js +29 -0
  1413. package/src/tools/ScheduleCronTool/prompt.js +115 -0
  1414. package/src/tools/SendMessageTool/SendMessageTool.js +673 -0
  1415. package/src/tools/SendMessageTool/UI.js +24 -0
  1416. package/src/tools/SendMessageTool/constants.js +1 -0
  1417. package/src/tools/SendMessageTool/prompt.js +47 -0
  1418. package/src/tools/SendUserFileTool/SendUserFileTool.js +35 -0
  1419. package/src/tools/SendUserFileTool/prompt.js +5 -0
  1420. package/src/tools/SkillTool/SkillTool.js +825 -0
  1421. package/src/tools/SkillTool/UI.js +61 -0
  1422. package/src/tools/SkillTool/constants.js +1 -0
  1423. package/src/tools/SkillTool/prompt.js +184 -0
  1424. package/src/tools/SleepTool/SleepTool.js +42 -0
  1425. package/src/tools/SleepTool/prompt.js +14 -0
  1426. package/src/tools/SnipTool/SnipTool.js +47 -0
  1427. package/src/tools/SnipTool/prompt.js +5 -0
  1428. package/src/tools/SubscribePRTool/SubscribePRTool.js +49 -0
  1429. package/src/tools/SuggestBackgroundPRTool/SuggestBackgroundPRTool.js +44 -0
  1430. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.js +138 -0
  1431. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +1 -1
  1432. package/src/tools/TaskCreateTool/TaskCreateTool.js +104 -0
  1433. package/src/tools/TaskCreateTool/constants.js +1 -0
  1434. package/src/tools/TaskCreateTool/prompt.js +52 -0
  1435. package/src/tools/TaskGetTool/TaskGetTool.js +106 -0
  1436. package/src/tools/TaskGetTool/constants.js +1 -0
  1437. package/src/tools/TaskGetTool/prompt.js +23 -0
  1438. package/src/tools/TaskListTool/TaskListTool.js +89 -0
  1439. package/src/tools/TaskListTool/constants.js +1 -0
  1440. package/src/tools/TaskListTool/prompt.js +44 -0
  1441. package/src/tools/TaskOutputTool/TaskOutputTool.js +536 -0
  1442. package/src/tools/TaskOutputTool/constants.js +1 -0
  1443. package/src/tools/TaskStopTool/TaskStopTool.js +110 -0
  1444. package/src/tools/TaskStopTool/UI.js +31 -0
  1445. package/src/tools/TaskStopTool/prompt.js +7 -0
  1446. package/src/tools/TaskUpdateTool/TaskUpdateTool.js +301 -0
  1447. package/src/tools/TaskUpdateTool/constants.js +1 -0
  1448. package/src/tools/TaskUpdateTool/prompt.js +76 -0
  1449. package/src/tools/TeamCreateTool/TeamCreateTool.js +177 -0
  1450. package/src/tools/TeamCreateTool/UI.js +4 -0
  1451. package/src/tools/TeamCreateTool/constants.js +1 -0
  1452. package/src/tools/TeamCreateTool/prompt.js +113 -0
  1453. package/src/tools/TeamDeleteTool/TeamDeleteTool.js +102 -0
  1454. package/src/tools/TeamDeleteTool/UI.js +13 -0
  1455. package/src/tools/TeamDeleteTool/constants.js +1 -0
  1456. package/src/tools/TeamDeleteTool/prompt.js +16 -0
  1457. package/src/tools/TerminalCaptureTool/TerminalCaptureTool.js +47 -0
  1458. package/src/tools/TerminalCaptureTool/prompt.js +11 -0
  1459. package/src/tools/TodoWriteTool/TodoWriteTool.js +99 -0
  1460. package/src/tools/TodoWriteTool/constants.js +1 -0
  1461. package/src/tools/TodoWriteTool/prompt.js +181 -0
  1462. package/src/tools/ToolSearchTool/ToolSearchTool.js +357 -0
  1463. package/src/tools/ToolSearchTool/constants.js +1 -0
  1464. package/src/tools/ToolSearchTool/prompt.js +97 -0
  1465. package/src/tools/TungstenTool/TungstenLiveMonitor.js +7 -0
  1466. package/src/tools/TungstenTool/TungstenTool.js +3 -0
  1467. package/src/tools/VerifyPlanExecutionTool/VerifyPlanExecutionTool.js +45 -0
  1468. package/src/tools/VerifyPlanExecutionTool/constants.js +2 -0
  1469. package/src/tools/WebBrowserTool/WebBrowserPanel.js +5 -0
  1470. package/src/tools/WebBrowserTool/WebBrowserTool.js +58 -0
  1471. package/src/tools/WebFetchTool/UI.js +31 -0
  1472. package/src/tools/WebFetchTool/WebFetchTool.js +246 -0
  1473. package/src/tools/WebFetchTool/preapproved.js +154 -0
  1474. package/src/tools/WebFetchTool/prompt.js +39 -0
  1475. package/src/tools/WebFetchTool/utils.js +368 -0
  1476. package/src/tools/WebSearchTool/UI.js +67 -0
  1477. package/src/tools/WebSearchTool/WebSearchTool.js +396 -0
  1478. package/src/tools/WebSearchTool/prompt.js +32 -0
  1479. package/src/tools/WorkflowTool/WorkflowPermissionRequest.js +7 -0
  1480. package/src/tools/WorkflowTool/WorkflowTool.js +51 -0
  1481. package/src/tools/WorkflowTool/bundled/index.js +5 -0
  1482. package/src/tools/WorkflowTool/constants.js +1 -0
  1483. package/src/tools/WorkflowTool/createWorkflowCommand.js +5 -0
  1484. package/src/tools/shared/gitOperationTracking.js +220 -0
  1485. package/src/tools/shared/spawnMultiAgent.js +805 -0
  1486. package/src/tools/testing/TestingPermissionTool.js +72 -0
  1487. package/src/tools/utils.js +24 -0
  1488. package/src/tools.js +365 -0
  1489. package/src/types/command.js +8 -0
  1490. package/src/types/connectorText.js +3 -0
  1491. package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.js +673 -0
  1492. package/src/types/generated/events_mono/common/v1/auth.js +49 -0
  1493. package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.js +147 -0
  1494. package/src/types/generated/google/protobuf/timestamp.js +38 -0
  1495. package/src/types/hooks.js +153 -0
  1496. package/src/types/ids.js +27 -0
  1497. package/src/types/logs.js +11 -0
  1498. package/src/types/permissions.js +25 -0
  1499. package/src/types/plugin.js +72 -0
  1500. package/src/types/textInputTypes.js +20 -0
  1501. package/src/upstreamproxy/relay.js +346 -0
  1502. package/src/upstreamproxy/upstreamproxy.js +234 -0
  1503. package/src/utils/CircularBuffer.js +75 -0
  1504. package/src/utils/Cursor.js +1229 -0
  1505. package/src/utils/QueryGuard.js +115 -0
  1506. package/src/utils/Shell.js +374 -0
  1507. package/src/utils/ShellCommand.js +336 -0
  1508. package/src/utils/abortController.js +74 -0
  1509. package/src/utils/activityManager.js +127 -0
  1510. package/src/utils/advisor.js +77 -0
  1511. package/src/utils/agentContext.js +91 -0
  1512. package/src/utils/agentId.js +83 -0
  1513. package/src/utils/agentSwarmsEnabled.js +37 -0
  1514. package/src/utils/agenticSessionSearch.js +255 -0
  1515. package/src/utils/analyzeContext.js +846 -0
  1516. package/src/utils/ansiToPng.js +259 -0
  1517. package/src/utils/ansiToSvg.js +207 -0
  1518. package/src/utils/api.js +555 -0
  1519. package/src/utils/apiPreconnect.js +62 -0
  1520. package/src/utils/appleTerminalBackup.js +95 -0
  1521. package/src/utils/argumentSubstitution.js +114 -0
  1522. package/src/utils/array.js +12 -0
  1523. package/src/utils/asciicast.js +200 -0
  1524. package/src/utils/attachments.js +2518 -0
  1525. package/src/utils/attribution.js +308 -0
  1526. package/src/utils/auth.js +1598 -0
  1527. package/src/utils/authFileDescriptor.js +152 -0
  1528. package/src/utils/authPortable.js +14 -0
  1529. package/src/utils/autoModeDenials.js +15 -0
  1530. package/src/utils/autoRunIssue.js +113 -0
  1531. package/src/utils/autoUpdater.js +457 -0
  1532. package/src/utils/aws.js +44 -0
  1533. package/src/utils/awsAuthStatusManager.js +66 -0
  1534. package/src/utils/background/remote/preconditions.js +175 -0
  1535. package/src/utils/background/remote/remoteSession.js +53 -0
  1536. package/src/utils/backgroundHousekeeping.js +64 -0
  1537. package/src/utils/bash/ParsedCommand.js +241 -0
  1538. package/src/utils/bash/ShellSnapshot.js +489 -0
  1539. package/src/utils/bash/ast.js +2590 -0
  1540. package/src/utils/bash/bashParser.js +4355 -0
  1541. package/src/utils/bash/bashPipeCommand.js +249 -0
  1542. package/src/utils/bash/commands.js +1131 -0
  1543. package/src/utils/bash/heredoc.js +647 -0
  1544. package/src/utils/bash/parser.js +195 -0
  1545. package/src/utils/bash/prefix.js +154 -0
  1546. package/src/utils/bash/registry.js +23 -0
  1547. package/src/utils/bash/shellCompletion.js +196 -0
  1548. package/src/utils/bash/shellPrefix.js +25 -0
  1549. package/src/utils/bash/shellQuote.js +253 -0
  1550. package/src/utils/bash/shellQuoting.js +106 -0
  1551. package/src/utils/bash/specs/alias.js +11 -0
  1552. package/src/utils/bash/specs/index.js +16 -0
  1553. package/src/utils/bash/specs/nohup.js +10 -0
  1554. package/src/utils/bash/specs/pyright.js +88 -0
  1555. package/src/utils/bash/specs/sleep.js +10 -0
  1556. package/src/utils/bash/specs/srun.js +28 -0
  1557. package/src/utils/bash/specs/time.js +10 -0
  1558. package/src/utils/bash/specs/timeout.js +17 -0
  1559. package/src/utils/bash/treeSitterAnalysis.js +407 -0
  1560. package/src/utils/betas.js +331 -0
  1561. package/src/utils/billing.js +54 -0
  1562. package/src/utils/binaryCheck.js +40 -0
  1563. package/src/utils/browser.js +58 -0
  1564. package/src/utils/bufferedWriter.js +77 -0
  1565. package/src/utils/bundledMode.js +19 -0
  1566. package/src/utils/businessDb.js +390 -0
  1567. package/src/utils/caCerts.js +91 -0
  1568. package/src/utils/caCertsConfig.js +77 -0
  1569. package/src/utils/cachePaths.js +28 -0
  1570. package/src/utils/classifierApprovals.js +66 -0
  1571. package/src/utils/classifierApprovalsHook.js +10 -0
  1572. package/src/utils/claudeDesktop.js +108 -0
  1573. package/src/utils/claudeInChrome/chromeNativeHost.js +416 -0
  1574. package/src/utils/claudeInChrome/common.js +466 -0
  1575. package/src/utils/claudeInChrome/mcpServer.js +237 -0
  1576. package/src/utils/claudeInChrome/prompt.js +79 -0
  1577. package/src/utils/claudeInChrome/setup.js +304 -0
  1578. package/src/utils/claudeInChrome/setupPortable.js +172 -0
  1579. package/src/utils/claudeInChrome/toolRendering.js +235 -0
  1580. package/src/utils/claudemd.js +1052 -0
  1581. package/src/utils/cleanup.js +514 -0
  1582. package/src/utils/cleanupRegistry.js +22 -0
  1583. package/src/utils/cliArgs.js +53 -0
  1584. package/src/utils/cliHighlight.js +45 -0
  1585. package/src/utils/codeIndexing.js +149 -0
  1586. package/src/utils/collapseBackgroundBashNotifications.js +70 -0
  1587. package/src/utils/collapseHookSummaries.js +48 -0
  1588. package/src/utils/collapseReadSearch.js +869 -0
  1589. package/src/utils/collapseTeammateShutdowns.js +44 -0
  1590. package/src/utils/combinedAbortSignal.js +40 -0
  1591. package/src/utils/commandLifecycle.js +7 -0
  1592. package/src/utils/commitAttribution.js +718 -0
  1593. package/src/utils/completionCache.js +138 -0
  1594. package/src/utils/computerUse/appNames.js +170 -0
  1595. package/src/utils/computerUse/cleanup.js +65 -0
  1596. package/src/utils/computerUse/common.js +56 -0
  1597. package/src/utils/computerUse/computerUseLock.js +183 -0
  1598. package/src/utils/computerUse/drainRunLoop.js +71 -0
  1599. package/src/utils/computerUse/escHotkey.js +53 -0
  1600. package/src/utils/computerUse/executor.js +480 -0
  1601. package/src/utils/computerUse/gates.js +55 -0
  1602. package/src/utils/computerUse/hostAdapter.js +62 -0
  1603. package/src/utils/computerUse/inputLoader.js +25 -0
  1604. package/src/utils/computerUse/mcpServer.js +84 -0
  1605. package/src/utils/computerUse/setup.js +42 -0
  1606. package/src/utils/computerUse/swiftLoader.js +18 -0
  1607. package/src/utils/computerUse/toolRendering.js +101 -0
  1608. package/src/utils/computerUse/wrapper.js +317 -0
  1609. package/src/utils/concurrentSessions.js +179 -0
  1610. package/src/utils/config.js +1078 -0
  1611. package/src/utils/configConstants.js +18 -0
  1612. package/src/utils/contentArray.js +45 -0
  1613. package/src/utils/context.js +185 -0
  1614. package/src/utils/contextAnalysis.js +171 -0
  1615. package/src/utils/contextSuggestions.js +158 -0
  1616. package/src/utils/controlMessageCompat.js +31 -0
  1617. package/src/utils/conversationRecovery.js +434 -0
  1618. package/src/utils/cron.js +260 -0
  1619. package/src/utils/cronJitterConfig.js +62 -0
  1620. package/src/utils/cronScheduler.js +388 -0
  1621. package/src/utils/cronTasks.js +328 -0
  1622. package/src/utils/cronTasksLock.js +159 -0
  1623. package/src/utils/crossProjectResume.js +46 -0
  1624. package/src/utils/crypto.js +13 -0
  1625. package/src/utils/cwd.js +29 -0
  1626. package/src/utils/debug.js +220 -0
  1627. package/src/utils/debugFilter.js +125 -0
  1628. package/src/utils/deepLink/banner.js +103 -0
  1629. package/src/utils/deepLink/parseDeepLink.js +138 -0
  1630. package/src/utils/deepLink/protocolHandler.js +119 -0
  1631. package/src/utils/deepLink/registerProtocol.js +291 -0
  1632. package/src/utils/deepLink/terminalLauncher.js +455 -0
  1633. package/src/utils/deepLink/terminalPreference.js +51 -0
  1634. package/src/utils/desktopDeepLink.js +208 -0
  1635. package/src/utils/detectRepository.js +157 -0
  1636. package/src/utils/diagLogs.js +74 -0
  1637. package/src/utils/diff.js +108 -0
  1638. package/src/utils/directMemberMessage.js +34 -0
  1639. package/src/utils/displayTags.js +46 -0
  1640. package/src/utils/doctorContextWarnings.js +179 -0
  1641. package/src/utils/doctorDiagnostic.js +494 -0
  1642. package/src/utils/dxt/helpers.js +64 -0
  1643. package/src/utils/dxt/zip.js +167 -0
  1644. package/src/utils/earlyInput.js +166 -0
  1645. package/src/utils/editor.js +163 -0
  1646. package/src/utils/effort.js +271 -0
  1647. package/src/utils/embeddedTools.js +26 -0
  1648. package/src/utils/employeeChat.js +271 -0
  1649. package/src/utils/employeeDb.js +326 -0
  1650. package/src/utils/env.js +358 -0
  1651. package/src/utils/envDynamic.js +130 -0
  1652. package/src/utils/envUtils.js +161 -0
  1653. package/src/utils/envValidation.js +26 -0
  1654. package/src/utils/errorLogSink.js +196 -0
  1655. package/src/utils/errors.js +207 -0
  1656. package/src/utils/exampleCommands.js +165 -0
  1657. package/src/utils/execFileNoThrow.js +93 -0
  1658. package/src/utils/execFileNoThrowPortable.js +49 -0
  1659. package/src/utils/execSyncWrapper.js +6 -0
  1660. package/src/utils/exportRenderer.js +71 -0
  1661. package/src/utils/extraUsage.js +19 -0
  1662. package/src/utils/fastMode.js +393 -0
  1663. package/src/utils/file.js +467 -0
  1664. package/src/utils/fileHistory.js +851 -0
  1665. package/src/utils/fileOperationAnalytics.js +45 -0
  1666. package/src/utils/filePersistence/filePersistence.js +212 -0
  1667. package/src/utils/filePersistence/outputsScanner.js +104 -0
  1668. package/src/utils/filePersistence/types.js +4 -0
  1669. package/src/utils/fileRead.js +81 -0
  1670. package/src/utils/fileReadCache.js +78 -0
  1671. package/src/utils/fileStateCache.js +99 -0
  1672. package/src/utils/findExecutable.js +13 -0
  1673. package/src/utils/fingerprint.js +58 -0
  1674. package/src/utils/forkedAgent.js +410 -0
  1675. package/src/utils/format.js +238 -0
  1676. package/src/utils/formatBriefTimestamp.js +72 -0
  1677. package/src/utils/fpsTracker.js +34 -0
  1678. package/src/utils/frontmatterParser.js +260 -0
  1679. package/src/utils/fsOperations.js +555 -0
  1680. package/src/utils/fullscreen.js +194 -0
  1681. package/src/utils/generatedFiles.js +122 -0
  1682. package/src/utils/generators.js +67 -0
  1683. package/src/utils/genericProcessUtils.js +155 -0
  1684. package/src/utils/getWorktreePaths.js +56 -0
  1685. package/src/utils/getWorktreePathsPortable.js +23 -0
  1686. package/src/utils/ghPrStatus.js +71 -0
  1687. package/src/utils/git/gitConfigParser.js +226 -0
  1688. package/src/utils/git/gitFilesystem.js +606 -0
  1689. package/src/utils/git/gitignore.js +84 -0
  1690. package/src/utils/git.js +725 -0
  1691. package/src/utils/gitDiff.js +395 -0
  1692. package/src/utils/gitSettings.js +18 -0
  1693. package/src/utils/github/ghAuthStatus.js +23 -0
  1694. package/src/utils/githubRepoPathMapping.js +135 -0
  1695. package/src/utils/glob.js +90 -0
  1696. package/src/utils/gracefulShutdown.js +447 -0
  1697. package/src/utils/groupToolUses.js +126 -0
  1698. package/src/utils/handlePromptSubmit.js +398 -0
  1699. package/src/utils/hash.js +44 -0
  1700. package/src/utils/headlessProfiler.js +147 -0
  1701. package/src/utils/heapDumpService.js +201 -0
  1702. package/src/utils/heatmap.js +151 -0
  1703. package/src/utils/highlightMatch.js +29 -0
  1704. package/src/utils/hooks/AsyncHookRegistry.js +187 -0
  1705. package/src/utils/hooks/apiQueryHookHelper.js +77 -0
  1706. package/src/utils/hooks/execAgentHook.js +257 -0
  1707. package/src/utils/hooks/execHttpHook.js +184 -0
  1708. package/src/utils/hooks/execPromptHook.js +171 -0
  1709. package/src/utils/hooks/fileChangedWatcher.js +161 -0
  1710. package/src/utils/hooks/hookEvents.js +111 -0
  1711. package/src/utils/hooks/hookHelpers.js +60 -0
  1712. package/src/utils/hooks/hooksConfigManager.js +323 -0
  1713. package/src/utils/hooks/hooksConfigSnapshot.js +114 -0
  1714. package/src/utils/hooks/hooksSettings.js +204 -0
  1715. package/src/utils/hooks/postSamplingHooks.js +39 -0
  1716. package/src/utils/hooks/registerFrontmatterHooks.js +47 -0
  1717. package/src/utils/hooks/registerSkillHooks.js +40 -0
  1718. package/src/utils/hooks/sessionHooks.js +252 -0
  1719. package/src/utils/hooks/skillImprovement.js +211 -0
  1720. package/src/utils/hooks/ssrfGuard.js +258 -0
  1721. package/src/utils/hooks.js +3668 -0
  1722. package/src/utils/horizontalScroll.js +108 -0
  1723. package/src/utils/http.js +120 -0
  1724. package/src/utils/hyperlink.js +28 -0
  1725. package/src/utils/iTermBackup.js +48 -0
  1726. package/src/utils/ide.js +1195 -0
  1727. package/src/utils/idePathConversion.js +66 -0
  1728. package/src/utils/idleTimeout.js +44 -0
  1729. package/src/utils/imagePaste.js +343 -0
  1730. package/src/utils/imageResizer.js +664 -0
  1731. package/src/utils/imageStore.js +150 -0
  1732. package/src/utils/imageValidation.js +92 -0
  1733. package/src/utils/immediateCommand.js +12 -0
  1734. package/src/utils/inProcessTeammateHelpers.js +71 -0
  1735. package/src/utils/ink.js +20 -0
  1736. package/src/utils/intl.js +83 -0
  1737. package/src/utils/jetbrains.js +152 -0
  1738. package/src/utils/json.js +231 -0
  1739. package/src/utils/jsonRead.js +14 -0
  1740. package/src/utils/keyboardShortcuts.js +11 -0
  1741. package/src/utils/lazySchema.js +8 -0
  1742. package/src/utils/listSessionsImpl.js +332 -0
  1743. package/src/utils/localInstaller.js +130 -0
  1744. package/src/utils/lockfile.js +30 -0
  1745. package/src/utils/log.js +280 -0
  1746. package/src/utils/logoV2Utils.js +256 -0
  1747. package/src/utils/mailbox.js +50 -0
  1748. package/src/utils/managedEnv.js +160 -0
  1749. package/src/utils/managedEnvConstants.js +185 -0
  1750. package/src/utils/markdown.js +315 -0
  1751. package/src/utils/markdownConfigLoader.js +480 -0
  1752. package/src/utils/mcp/dateTimeParser.js +102 -0
  1753. package/src/utils/mcp/elicitationValidation.js +259 -0
  1754. package/src/utils/mcpInstructionsDelta.js +97 -0
  1755. package/src/utils/mcpOutputStorage.js +159 -0
  1756. package/src/utils/mcpValidation.js +165 -0
  1757. package/src/utils/mcpWebSocketTransport.js +180 -0
  1758. package/src/utils/memoize.js +205 -0
  1759. package/src/utils/memory/types.js +9 -0
  1760. package/src/utils/memory/versions.js +7 -0
  1761. package/src/utils/memoryFileDetection.js +245 -0
  1762. package/src/utils/messagePredicates.js +6 -0
  1763. package/src/utils/messageQueueManager.js +430 -0
  1764. package/src/utils/messages/mappers.js +240 -0
  1765. package/src/utils/messages/systemInit.js +72 -0
  1766. package/src/utils/messages.js +4286 -0
  1767. package/src/utils/model/agent.js +128 -0
  1768. package/src/utils/model/aliases.js +21 -0
  1769. package/src/utils/model/antModels.js +25 -0
  1770. package/src/utils/model/bedrock.js +220 -0
  1771. package/src/utils/model/check1mAccess.js +64 -0
  1772. package/src/utils/model/configs.js +86 -0
  1773. package/src/utils/model/contextWindowUpgradeCheck.js +41 -0
  1774. package/src/utils/model/deprecation.js +72 -0
  1775. package/src/utils/model/model.js +533 -0
  1776. package/src/utils/model/modelAllowlist.js +148 -0
  1777. package/src/utils/model/modelCapabilities.js +105 -0
  1778. package/src/utils/model/modelOptions.js +450 -0
  1779. package/src/utils/model/modelStrings.js +144 -0
  1780. package/src/utils/model/modelSupportOverrides.js +40 -0
  1781. package/src/utils/model/providers.js +35 -0
  1782. package/src/utils/model/validateModel.js +131 -0
  1783. package/src/utils/modelCost.js +160 -0
  1784. package/src/utils/modifiers.js +39 -0
  1785. package/src/utils/mtls.js +132 -0
  1786. package/src/utils/nativeInstaller/download.js +370 -0
  1787. package/src/utils/nativeInstaller/index.js +8 -0
  1788. package/src/utils/nativeInstaller/installer.js +1395 -0
  1789. package/src/utils/nativeInstaller/packageManagers.js +258 -0
  1790. package/src/utils/nativeInstaller/pidLock.js +347 -0
  1791. package/src/utils/notebook.js +176 -0
  1792. package/src/utils/objectGroupBy.js +15 -0
  1793. package/src/utils/pasteStore.js +93 -0
  1794. package/src/utils/path.js +140 -0
  1795. package/src/utils/pdf.js +236 -0
  1796. package/src/utils/pdfUtils.js +61 -0
  1797. package/src/utils/peerAddress.js +20 -0
  1798. package/src/utils/permissions/PermissionMode.js +95 -0
  1799. package/src/utils/permissions/PermissionPromptToolResultSchema.js +85 -0
  1800. package/src/utils/permissions/PermissionResult.js +11 -0
  1801. package/src/utils/permissions/PermissionRule.js +19 -0
  1802. package/src/utils/permissions/PermissionUpdate.js +268 -0
  1803. package/src/utils/permissions/PermissionUpdateSchema.js +61 -0
  1804. package/src/utils/permissions/autoModeState.js +31 -0
  1805. package/src/utils/permissions/bashClassifier.js +30 -0
  1806. package/src/utils/permissions/bypassPermissionsKillswitch.js +115 -0
  1807. package/src/utils/permissions/classifierDecision.js +86 -0
  1808. package/src/utils/permissions/classifierShared.js +28 -0
  1809. package/src/utils/permissions/dangerousPatterns.js +78 -0
  1810. package/src/utils/permissions/denialTracking.js +34 -0
  1811. package/src/utils/permissions/filesystem.js +1411 -0
  1812. package/src/utils/permissions/getNextPermissionMode.js +74 -0
  1813. package/src/utils/permissions/pathValidation.js +351 -0
  1814. package/src/utils/permissions/permissionExplainer.js +188 -0
  1815. package/src/utils/permissions/permissionRuleParser.js +175 -0
  1816. package/src/utils/permissions/permissionSetup.js +1162 -0
  1817. package/src/utils/permissions/permissions.js +1063 -0
  1818. package/src/utils/permissions/permissionsLoader.js +217 -0
  1819. package/src/utils/permissions/shadowedRuleDetection.js +149 -0
  1820. package/src/utils/permissions/shellRuleMatching.js +174 -0
  1821. package/src/utils/permissions/yoloClassifier.js +1193 -0
  1822. package/src/utils/planModeV2.js +75 -0
  1823. package/src/utils/plans.js +334 -0
  1824. package/src/utils/platform.js +122 -0
  1825. package/src/utils/plugins/addDirPluginSettings.js +53 -0
  1826. package/src/utils/plugins/cacheUtils.js +174 -0
  1827. package/src/utils/plugins/dependencyResolver.js +244 -0
  1828. package/src/utils/plugins/fetchTelemetry.js +108 -0
  1829. package/src/utils/plugins/gitAvailability.js +65 -0
  1830. package/src/utils/plugins/headlessPluginInstall.js +136 -0
  1831. package/src/utils/plugins/hintRecommendation.js +136 -0
  1832. package/src/utils/plugins/installCounts.js +221 -0
  1833. package/src/utils/plugins/installedPluginsManager.js +1003 -0
  1834. package/src/utils/plugins/loadPluginAgents.js +219 -0
  1835. package/src/utils/plugins/loadPluginCommands.js +595 -0
  1836. package/src/utils/plugins/loadPluginHooks.js +239 -0
  1837. package/src/utils/plugins/loadPluginOutputStyles.js +112 -0
  1838. package/src/utils/plugins/lspPluginIntegration.js +293 -0
  1839. package/src/utils/plugins/lspRecommendation.js +278 -0
  1840. package/src/utils/plugins/managedPlugins.js +26 -0
  1841. package/src/utils/plugins/marketplaceHelpers.js +470 -0
  1842. package/src/utils/plugins/marketplaceManager.js +1939 -0
  1843. package/src/utils/plugins/mcpPluginIntegration.js +465 -0
  1844. package/src/utils/plugins/mcpbHandler.js +708 -0
  1845. package/src/utils/plugins/officialMarketplace.js +19 -0
  1846. package/src/utils/plugins/officialMarketplaceGcs.js +202 -0
  1847. package/src/utils/plugins/officialMarketplaceStartupCheck.js +344 -0
  1848. package/src/utils/plugins/orphanedPluginFilter.js +96 -0
  1849. package/src/utils/plugins/parseMarketplaceInput.js +143 -0
  1850. package/src/utils/plugins/performStartupChecks.js +66 -0
  1851. package/src/utils/plugins/pluginAutoupdate.js +210 -0
  1852. package/src/utils/plugins/pluginBlocklist.js +93 -0
  1853. package/src/utils/plugins/pluginDirectories.js +170 -0
  1854. package/src/utils/plugins/pluginFlagging.js +173 -0
  1855. package/src/utils/plugins/pluginIdentifier.js +78 -0
  1856. package/src/utils/plugins/pluginInstallationHelpers.js +400 -0
  1857. package/src/utils/plugins/pluginLoader.js +2426 -0
  1858. package/src/utils/plugins/pluginOptionsStorage.js +311 -0
  1859. package/src/utils/plugins/pluginPolicy.js +18 -0
  1860. package/src/utils/plugins/pluginStartupCheck.js +261 -0
  1861. package/src/utils/plugins/pluginVersioning.js +128 -0
  1862. package/src/utils/plugins/reconciler.js +181 -0
  1863. package/src/utils/plugins/refresh.js +162 -0
  1864. package/src/utils/plugins/schemas.js +1283 -0
  1865. package/src/utils/plugins/validatePlugin.js +765 -0
  1866. package/src/utils/plugins/walkPluginMarkdown.js +49 -0
  1867. package/src/utils/plugins/zipCache.js +346 -0
  1868. package/src/utils/plugins/zipCacheAdapters.js +133 -0
  1869. package/src/utils/powershell/dangerousCmdlets.js +174 -0
  1870. package/src/utils/powershell/parser.js +1357 -0
  1871. package/src/utils/powershell/staticPrefix.js +277 -0
  1872. package/src/utils/preflightChecks.js +147 -0
  1873. package/src/utils/privacyLevel.js +49 -0
  1874. package/src/utils/process.js +56 -0
  1875. package/src/utils/processUserInput/processBashCommand.js +118 -0
  1876. package/src/utils/processUserInput/processSlashCommand.js +845 -0
  1877. package/src/utils/processUserInput/processTextPrompt.js +68 -0
  1878. package/src/utils/processUserInput/processUserInput.js +344 -0
  1879. package/src/utils/profilerBase.js +32 -0
  1880. package/src/utils/promptCategory.js +39 -0
  1881. package/src/utils/promptEditor.js +151 -0
  1882. package/src/utils/promptShellExecution.js +117 -0
  1883. package/src/utils/protectedNamespace.js +4 -0
  1884. package/src/utils/proxy.js +345 -0
  1885. package/src/utils/queryContext.js +110 -0
  1886. package/src/utils/queryHelpers.js +436 -0
  1887. package/src/utils/queryProfiler.js +242 -0
  1888. package/src/utils/queueProcessor.js +70 -0
  1889. package/src/utils/readEditContext.js +176 -0
  1890. package/src/utils/readFileInRange.js +278 -0
  1891. package/src/utils/releaseNotes.js +307 -0
  1892. package/src/utils/renderOptions.js +67 -0
  1893. package/src/utils/ripgrep.js +521 -0
  1894. package/src/utils/sandbox/sandbox-adapter.js +750 -0
  1895. package/src/utils/sandbox/sandbox-ui-utils.js +11 -0
  1896. package/src/utils/sanitization.js +72 -0
  1897. package/src/utils/screenshotClipboard.js +89 -0
  1898. package/src/utils/sdkEventQueue.js +49 -0
  1899. package/src/utils/secureStorage/fallbackStorage.js +59 -0
  1900. package/src/utils/secureStorage/index.js +13 -0
  1901. package/src/utils/secureStorage/keychainPrefetch.js +91 -0
  1902. package/src/utils/secureStorage/macOsKeychainHelpers.js +91 -0
  1903. package/src/utils/secureStorage/macOsKeychainStorage.js +192 -0
  1904. package/src/utils/secureStorage/plainTextStorage.js +81 -0
  1905. package/src/utils/semanticBoolean.js +23 -0
  1906. package/src/utils/semanticNumber.js +34 -0
  1907. package/src/utils/semver.js +51 -0
  1908. package/src/utils/sequential.js +43 -0
  1909. package/src/utils/sessionActivity.js +120 -0
  1910. package/src/utils/sessionEnvVars.js +18 -0
  1911. package/src/utils/sessionEnvironment.js +131 -0
  1912. package/src/utils/sessionFileAccessHooks.js +205 -0
  1913. package/src/utils/sessionIngressAuth.js +113 -0
  1914. package/src/utils/sessionRestore.js +357 -0
  1915. package/src/utils/sessionStart.js +165 -0
  1916. package/src/utils/sessionState.js +76 -0
  1917. package/src/utils/sessionStorage.js +4162 -0
  1918. package/src/utils/sessionStoragePortable.js +665 -0
  1919. package/src/utils/sessionTitle.js +120 -0
  1920. package/src/utils/sessionUrl.js +50 -0
  1921. package/src/utils/set.js +50 -0
  1922. package/src/utils/settings/allErrors.js +29 -0
  1923. package/src/utils/settings/applySettingsChange.js +65 -0
  1924. package/src/utils/settings/changeDetector.js +409 -0
  1925. package/src/utils/settings/constants.js +166 -0
  1926. package/src/utils/settings/internalWrites.js +33 -0
  1927. package/src/utils/settings/managedPath.js +29 -0
  1928. package/src/utils/settings/mdm/constants.js +62 -0
  1929. package/src/utils/settings/mdm/rawRead.js +97 -0
  1930. package/src/utils/settings/mdm/settings.js +254 -0
  1931. package/src/utils/settings/permissionValidation.js +224 -0
  1932. package/src/utils/settings/pluginOnlyPolicy.js +53 -0
  1933. package/src/utils/settings/schemaOutput.js +7 -0
  1934. package/src/utils/settings/settings.js +791 -0
  1935. package/src/utils/settings/settingsCache.js +47 -0
  1936. package/src/utils/settings/toolValidationConfig.js +76 -0
  1937. package/src/utils/settings/types.js +846 -0
  1938. package/src/utils/settings/validateEditTool.js +34 -0
  1939. package/src/utils/settings/validation.js +192 -0
  1940. package/src/utils/settings/validationTips.js +111 -0
  1941. package/src/utils/shell/bashProvider.js +202 -0
  1942. package/src/utils/shell/outputLimits.js +7 -0
  1943. package/src/utils/shell/powershellDetection.js +96 -0
  1944. package/src/utils/shell/powershellProvider.js +104 -0
  1945. package/src/utils/shell/prefix.js +246 -0
  1946. package/src/utils/shell/readOnlyCommandValidation.js +1776 -0
  1947. package/src/utils/shell/resolveDefaultShell.js +13 -0
  1948. package/src/utils/shell/shellProvider.js +2 -0
  1949. package/src/utils/shell/shellToolUtils.js +21 -0
  1950. package/src/utils/shell/specPrefix.js +198 -0
  1951. package/src/utils/shellConfig.js +136 -0
  1952. package/src/utils/sideQuery.js +134 -0
  1953. package/src/utils/sideQuestion.js +121 -0
  1954. package/src/utils/signal.js +34 -0
  1955. package/src/utils/sinks.js +15 -0
  1956. package/src/utils/skills/skillChangeDetector.js +264 -0
  1957. package/src/utils/slashCommandParsing.js +46 -0
  1958. package/src/utils/sleep.js +72 -0
  1959. package/src/utils/sliceAnsi.js +74 -0
  1960. package/src/utils/slowOperations.js +216 -0
  1961. package/src/utils/standaloneAgent.js +20 -0
  1962. package/src/utils/startupProfiler.js +149 -0
  1963. package/src/utils/staticRender.js +104 -0
  1964. package/src/utils/stats.js +802 -0
  1965. package/src/utils/statsCache.js +330 -0
  1966. package/src/utils/status.js +359 -0
  1967. package/src/utils/statusNoticeDefinitions.js +123 -0
  1968. package/src/utils/statusNoticeHelpers.js +15 -0
  1969. package/src/utils/stream.js +73 -0
  1970. package/src/utils/streamJsonStdoutGuard.js +107 -0
  1971. package/src/utils/streamlinedTransform.js +162 -0
  1972. package/src/utils/stringUtils.js +202 -0
  1973. package/src/utils/subprocessEnv.js +87 -0
  1974. package/src/utils/suggestions/commandSuggestions.js +458 -0
  1975. package/src/utils/suggestions/directoryCompletion.js +191 -0
  1976. package/src/utils/suggestions/shellHistoryCompletion.js +95 -0
  1977. package/src/utils/suggestions/skillUsageTracking.js +50 -0
  1978. package/src/utils/suggestions/slackChannelSuggestions.js +169 -0
  1979. package/src/utils/swarm/It2SetupPrompt.js +386 -0
  1980. package/src/utils/swarm/backends/ITermBackend.js +276 -0
  1981. package/src/utils/swarm/backends/InProcessBackend.js +237 -0
  1982. package/src/utils/swarm/backends/PaneBackendExecutor.js +250 -0
  1983. package/src/utils/swarm/backends/TmuxBackend.js +574 -0
  1984. package/src/utils/swarm/backends/detection.js +112 -0
  1985. package/src/utils/swarm/backends/it2Setup.js +185 -0
  1986. package/src/utils/swarm/backends/registry.js +369 -0
  1987. package/src/utils/swarm/backends/teammateModeSnapshot.js +68 -0
  1988. package/src/utils/swarm/backends/types.js +9 -0
  1989. package/src/utils/swarm/constants.js +29 -0
  1990. package/src/utils/swarm/inProcessRunner.js +1021 -0
  1991. package/src/utils/swarm/leaderPermissionBridge.js +31 -0
  1992. package/src/utils/swarm/permissionSync.js +667 -0
  1993. package/src/utils/swarm/reconnection.js +82 -0
  1994. package/src/utils/swarm/spawnInProcess.js +218 -0
  1995. package/src/utils/swarm/spawnUtils.js +123 -0
  1996. package/src/utils/swarm/teamHelpers.js +484 -0
  1997. package/src/utils/swarm/teammateInit.js +87 -0
  1998. package/src/utils/swarm/teammateLayoutManager.js +82 -0
  1999. package/src/utils/swarm/teammateModel.js +9 -0
  2000. package/src/utils/swarm/teammatePromptAddendum.js +17 -0
  2001. package/src/utils/systemDirectories.js +51 -0
  2002. package/src/utils/systemPrompt.js +88 -0
  2003. package/src/utils/systemPromptType.js +9 -0
  2004. package/src/utils/systemTheme.js +108 -0
  2005. package/src/utils/taggedId.js +49 -0
  2006. package/src/utils/task/TaskOutput.js +320 -0
  2007. package/src/utils/task/diskOutput.js +387 -0
  2008. package/src/utils/task/framework.js +236 -0
  2009. package/src/utils/task/outputFormatting.js +24 -0
  2010. package/src/utils/task/sdkProgress.js +24 -0
  2011. package/src/utils/taskSummary.js +3 -0
  2012. package/src/utils/tasks.js +672 -0
  2013. package/src/utils/teamDiscovery.js +48 -0
  2014. package/src/utils/teamMemoryOps.js +67 -0
  2015. package/src/utils/teammate.js +237 -0
  2016. package/src/utils/teammateContext.js +56 -0
  2017. package/src/utils/teammateMailbox.js +793 -0
  2018. package/src/utils/telemetry/betaSessionTracing.js +25 -0
  2019. package/src/utils/telemetry/bigqueryExporter.js +17 -0
  2020. package/src/utils/telemetry/events.js +7 -0
  2021. package/src/utils/telemetry/instrumentation.js +16 -0
  2022. package/src/utils/telemetry/logger.js +25 -0
  2023. package/src/utils/telemetry/perfettoTracing.js +882 -0
  2024. package/src/utils/telemetry/pluginTelemetry.js +76 -0
  2025. package/src/utils/telemetry/sessionTracing.js +62 -0
  2026. package/src/utils/telemetry/skillLoadedEvent.js +4 -0
  2027. package/src/utils/telemetryAttributes.js +56 -0
  2028. package/src/utils/teleport/api.js +299 -0
  2029. package/src/utils/teleport/environmentSelection.js +55 -0
  2030. package/src/utils/teleport/environments.js +84 -0
  2031. package/src/utils/teleport/gitBundle.js +192 -0
  2032. package/src/utils/teleport.js +1047 -0
  2033. package/src/utils/tempfile.js +26 -0
  2034. package/src/utils/terminal.js +105 -0
  2035. package/src/utils/terminalPanel.js +155 -0
  2036. package/src/utils/textHighlighting.js +113 -0
  2037. package/src/utils/thaddeusHints.js +142 -0
  2038. package/src/utils/theme.js +525 -0
  2039. package/src/utils/thinking.js +130 -0
  2040. package/src/utils/timeouts.js +35 -0
  2041. package/src/utils/tmuxSocket.js +373 -0
  2042. package/src/utils/todo/types.js +9 -0
  2043. package/src/utils/tokenBudget.js +62 -0
  2044. package/src/utils/tokens.js +223 -0
  2045. package/src/utils/toolErrors.js +101 -0
  2046. package/src/utils/toolPool.js +61 -0
  2047. package/src/utils/toolResultStorage.js +768 -0
  2048. package/src/utils/toolSchemaCache.js +7 -0
  2049. package/src/utils/toolSearch.js +551 -0
  2050. package/src/utils/transcriptSearch.js +200 -0
  2051. package/src/utils/treeify.js +111 -0
  2052. package/src/utils/truncate.js +164 -0
  2053. package/src/utils/udsClient.js +5 -0
  2054. package/src/utils/udsMessaging.js +23 -0
  2055. package/src/utils/ultraplan/ccrSession.js +264 -0
  2056. package/src/utils/ultraplan/keyword.js +122 -0
  2057. package/src/utils/unaryLogging.js +16 -0
  2058. package/src/utils/undercover.js +89 -0
  2059. package/src/utils/user.js +137 -0
  2060. package/src/utils/userAgent.js +9 -0
  2061. package/src/utils/userPromptKeywords.js +21 -0
  2062. package/src/utils/uuid.js +22 -0
  2063. package/src/utils/warningHandler.js +97 -0
  2064. package/src/utils/which.js +75 -0
  2065. package/src/utils/windowsPaths.js +146 -0
  2066. package/src/utils/withResolvers.js +13 -0
  2067. package/src/utils/words.js +793 -0
  2068. package/src/utils/workforceIntent.js +192 -0
  2069. package/src/utils/workloadContext.js +42 -0
  2070. package/src/utils/worktree.js +1142 -0
  2071. package/src/utils/worktreeModeEnabled.js +11 -0
  2072. package/src/utils/xdg.js +52 -0
  2073. package/src/utils/xml.js +15 -0
  2074. package/src/utils/yaml.js +14 -0
  2075. package/src/utils/zodToJsonSchema.js +19 -0
  2076. package/src/vim/motions.js +73 -0
  2077. package/src/vim/operators.js +401 -0
  2078. package/src/vim/textObjects.js +153 -0
  2079. package/src/vim/transitions.js +340 -0
  2080. package/src/vim/types.js +93 -0
  2081. package/src/voice/voiceModeEnabled.js +20 -0
  2082. package/thaddeus-terminal.ts +401 -3
@@ -0,0 +1,1411 @@
1
+ import { feature } from 'bun:bundle';
2
+ import { randomBytes } from 'crypto';
3
+ import ignore from 'ignore';
4
+ import memoize from 'lodash-es/memoize.js';
5
+ import { homedir, tmpdir } from 'os';
6
+ import { join, normalize, posix, sep } from 'path';
7
+ import { hasAutoMemPathOverride, isAutoMemPath } from 'src/memdir/paths.js';
8
+ import { isAgentMemoryPath } from 'src/tools/AgentTool/agentMemory.js';
9
+ import { CLAUDE_FOLDER_PERMISSION_PATTERN, FILE_EDIT_TOOL_NAME, GLOBAL_CLAUDE_FOLDER_PERMISSION_PATTERN, } from 'src/tools/FileEditTool/constants.js';
10
+ import { getOriginalCwd, getSessionId } from '../../bootstrap/state.js';
11
+ import { checkStatsigFeatureGate_CACHED_MAY_BE_STALE } from '../../services/analytics/growthbook.js';
12
+ import { FILE_READ_TOOL_NAME } from '../../tools/FileReadTool/prompt.js';
13
+ import { getCwd } from '../cwd.js';
14
+ import { getClaudeConfigHomeDir } from '../envUtils.js';
15
+ import { getFsImplementation, getPathsForPermissionCheck, } from '../fsOperations.js';
16
+ import { containsPathTraversal, expandPath, getDirectoryForPath, sanitizePath, } from '../path.js';
17
+ import { getPlanSlug, getPlansDirectory } from '../plans.js';
18
+ import { getPlatform } from '../platform.js';
19
+ import { getProjectDir } from '../sessionStorage.js';
20
+ import { SETTING_SOURCES } from '../settings/constants.js';
21
+ import { getSettingsFilePathForSource, getSettingsRootPathForSource, } from '../settings/settings.js';
22
+ import { containsVulnerableUncPath } from '../shell/readOnlyCommandValidation.js';
23
+ import { getToolResultsDir } from '../toolResultStorage.js';
24
+ import { windowsPathToPosixPath } from '../windowsPaths.js';
25
+ import { createReadRuleSuggestion } from './PermissionUpdate.js';
26
+ import { getRuleByContentsForToolName } from './permissions.js';
27
+ /**
28
+ * Dangerous files that should be protected from auto-editing.
29
+ * These files can be used for code execution or data exfiltration.
30
+ */
31
+ export const DANGEROUS_FILES = [
32
+ '.gitconfig',
33
+ '.gitmodules',
34
+ '.bashrc',
35
+ '.bash_profile',
36
+ '.zshrc',
37
+ '.zprofile',
38
+ '.profile',
39
+ '.ripgreprc',
40
+ '.mcp.json',
41
+ '.claude.json',
42
+ ];
43
+ /**
44
+ * Dangerous directories that should be protected from auto-editing.
45
+ * These directories contain sensitive configuration or executable files.
46
+ */
47
+ export const DANGEROUS_DIRECTORIES = [
48
+ '.git',
49
+ '.vscode',
50
+ '.idea',
51
+ '.claude',
52
+ ];
53
+ /**
54
+ * Normalizes a path for case-insensitive comparison.
55
+ * This prevents bypassing security checks using mixed-case paths on case-insensitive
56
+ * filesystems (macOS/Windows) like `.cLauDe/Settings.locaL.json`.
57
+ *
58
+ * We always normalize to lowercase regardless of platform for consistent security.
59
+ * @param path The path to normalize
60
+ * @returns The lowercase path for safe comparison
61
+ */
62
+ export function normalizeCaseForComparison(path) {
63
+ return path.toLowerCase();
64
+ }
65
+ /**
66
+ * If filePath is inside a .claude/skills/{name}/ directory (project or global),
67
+ * return the skill name and a session-allow pattern scoped to just that skill.
68
+ * Used to offer a narrower "allow edits to this skill only" option in the
69
+ * permission dialog and SDK suggestions, so iterating on one skill doesn't
70
+ * require granting session access to all of .claude/ (settings.json, hooks/, etc.).
71
+ */
72
+ export function getClaudeSkillScope(filePath) {
73
+ const absolutePath = expandPath(filePath);
74
+ const absolutePathLower = normalizeCaseForComparison(absolutePath);
75
+ const bases = [
76
+ {
77
+ dir: expandPath(join(getOriginalCwd(), '.claude', 'skills')),
78
+ prefix: '/.claude/skills/',
79
+ },
80
+ {
81
+ dir: expandPath(join(homedir(), '.claude', 'skills')),
82
+ prefix: '~/.claude/skills/',
83
+ },
84
+ ];
85
+ for (const { dir, prefix } of bases) {
86
+ const dirLower = normalizeCaseForComparison(dir);
87
+ // Try both path separators (Windows paths may not be normalized to /)
88
+ for (const s of [sep, '/']) {
89
+ if (absolutePathLower.startsWith(dirLower + s.toLowerCase())) {
90
+ // Match on lowercase, but slice the ORIGINAL path so the skill name
91
+ // preserves case (pattern matching downstream is case-sensitive)
92
+ const rest = absolutePath.slice(dir.length + s.length);
93
+ const slash = rest.indexOf('/');
94
+ const bslash = sep === '\\' ? rest.indexOf('\\') : -1;
95
+ const cut = slash === -1
96
+ ? bslash
97
+ : bslash === -1
98
+ ? slash
99
+ : Math.min(slash, bslash);
100
+ // Require a separator: file must be INSIDE the skill dir, not a
101
+ // file directly under skills/ (no skill scope for that)
102
+ if (cut <= 0)
103
+ return null;
104
+ const skillName = rest.slice(0, cut);
105
+ // Reject traversal and empty. Use includes('..') not === '..' to
106
+ // match step 1.6's ruleContent.includes('..') guard: a skillName like
107
+ // 'v2..beta' would otherwise produce a suggestion step 1.7 emits but
108
+ // step 1.6 always rejects (dead suggestion, infinite re-prompt).
109
+ if (!skillName || skillName === '.' || skillName.includes('..')) {
110
+ return null;
111
+ }
112
+ // Reject glob metacharacters. skillName is interpolated into a
113
+ // gitignore pattern consumed by ignore().add() in matchingRuleForInput
114
+ // at step 1.6. A directory literally named '*' (valid on POSIX) would
115
+ // produce '/.claude/skills/*/**' which matches ALL skills. Return null
116
+ // to fall through to generateSuggestions() instead.
117
+ if (/[*?[\]]/.test(skillName))
118
+ return null;
119
+ return { skillName, pattern: prefix + skillName + '/**' };
120
+ }
121
+ }
122
+ }
123
+ return null;
124
+ }
125
+ // Always use / as the path separator per gitignore spec
126
+ // https://git-scm.com/docs/gitignore
127
+ const DIR_SEP = posix.sep;
128
+ /**
129
+ * Cross-platform relative path calculation that returns POSIX-style paths.
130
+ * Handles Windows path conversion internally.
131
+ * @param from The base path
132
+ * @param to The target path
133
+ * @returns A POSIX-style relative path
134
+ */
135
+ export function relativePath(from, to) {
136
+ if (getPlatform() === 'windows') {
137
+ // Convert Windows paths to POSIX for consistent comparison
138
+ const posixFrom = windowsPathToPosixPath(from);
139
+ const posixTo = windowsPathToPosixPath(to);
140
+ return posix.relative(posixFrom, posixTo);
141
+ }
142
+ // Use POSIX paths directly
143
+ return posix.relative(from, to);
144
+ }
145
+ /**
146
+ * Converts a path to POSIX format for pattern matching.
147
+ * Handles Windows path conversion internally.
148
+ * @param path The path to convert
149
+ * @returns A POSIX-style path
150
+ */
151
+ export function toPosixPath(path) {
152
+ if (getPlatform() === 'windows') {
153
+ return windowsPathToPosixPath(path);
154
+ }
155
+ return path;
156
+ }
157
+ function getSettingsPaths() {
158
+ return SETTING_SOURCES.map(source => getSettingsFilePathForSource(source)).filter(path => path !== undefined);
159
+ }
160
+ export function isClaudeSettingsPath(filePath) {
161
+ // SECURITY: Normalize path structure first to prevent bypass via redundant ./
162
+ // sequences like `./.claude/./settings.json` which would evade the endsWith() check
163
+ const expandedPath = expandPath(filePath);
164
+ // Normalize for case-insensitive comparison to prevent bypassing security
165
+ // with paths like .cLauDe/Settings.locaL.json
166
+ const normalizedPath = normalizeCaseForComparison(expandedPath);
167
+ // Use platform separator so endsWith checks work on both Unix (/) and Windows (\)
168
+ if (normalizedPath.endsWith(`${sep}.claude${sep}settings.json`) ||
169
+ normalizedPath.endsWith(`${sep}.claude${sep}settings.local.json`)) {
170
+ // Include .claude/settings.json even for other projects
171
+ return true;
172
+ }
173
+ // Check for current project's settings files (including managed settings and CLI args)
174
+ // Both paths are now absolute and normalized for consistent comparison
175
+ return getSettingsPaths().some(settingsPath => normalizeCaseForComparison(settingsPath) === normalizedPath);
176
+ }
177
+ // Always ask when Thaddeus tries to edit its own config files
178
+ function isClaudeConfigFilePath(filePath) {
179
+ if (isClaudeSettingsPath(filePath)) {
180
+ return true;
181
+ }
182
+ // Check if file is within .claude/commands or .claude/agents directories
183
+ // using proper path segment validation (not string matching with includes())
184
+ // pathInWorkingPath now handles case-insensitive comparison to prevent bypasses
185
+ const commandsDir = join(getOriginalCwd(), '.claude', 'commands');
186
+ const agentsDir = join(getOriginalCwd(), '.claude', 'agents');
187
+ const skillsDir = join(getOriginalCwd(), '.claude', 'skills');
188
+ return (pathInWorkingPath(filePath, commandsDir) ||
189
+ pathInWorkingPath(filePath, agentsDir) ||
190
+ pathInWorkingPath(filePath, skillsDir));
191
+ }
192
+ // Check if file is the plan file for the current session
193
+ function isSessionPlanFile(absolutePath) {
194
+ // Check if path is a plan file for this session (main or agent-specific)
195
+ // Main plan file: {plansDir}/{planSlug}.md
196
+ // Agent plan file: {plansDir}/{planSlug}-agent-{agentId}.md
197
+ const expectedPrefix = join(getPlansDirectory(), getPlanSlug());
198
+ // SECURITY: Normalize to prevent path traversal bypasses via .. segments
199
+ const normalizedPath = normalize(absolutePath);
200
+ return (normalizedPath.startsWith(expectedPrefix) && normalizedPath.endsWith('.md'));
201
+ }
202
+ /**
203
+ * Returns the session memory directory path for the current session with trailing separator.
204
+ * Path format: {projectDir}/{sessionId}/session-memory/
205
+ */
206
+ export function getSessionMemoryDir() {
207
+ return join(getProjectDir(getCwd()), getSessionId(), 'session-memory') + sep;
208
+ }
209
+ /**
210
+ * Returns the session memory file path for the current session.
211
+ * Path format: {projectDir}/{sessionId}/session-memory/summary.md
212
+ */
213
+ export function getSessionMemoryPath() {
214
+ return join(getSessionMemoryDir(), 'summary.md');
215
+ }
216
+ // Check if file is within the session memory directory
217
+ function isSessionMemoryPath(absolutePath) {
218
+ // SECURITY: Normalize to prevent path traversal bypasses via .. segments
219
+ const normalizedPath = normalize(absolutePath);
220
+ return normalizedPath.startsWith(getSessionMemoryDir());
221
+ }
222
+ /**
223
+ * Check if file is within the current project's directory.
224
+ * Path format: ~/.claude/projects/{sanitized-cwd}/...
225
+ */
226
+ function isProjectDirPath(absolutePath) {
227
+ const projectDir = getProjectDir(getCwd());
228
+ // SECURITY: Normalize to prevent path traversal bypasses via .. segments
229
+ const normalizedPath = normalize(absolutePath);
230
+ return (normalizedPath === projectDir || normalizedPath.startsWith(projectDir + sep));
231
+ }
232
+ /**
233
+ * Checks if the scratchpad directory feature is enabled.
234
+ * The scratchpad is a per-session directory for Thaddeus to write temporary files.
235
+ * Controlled by the thaddeus_scratch Statsig gate.
236
+ */
237
+ export function isScratchpadEnabled() {
238
+ return checkStatsigFeatureGate_CACHED_MAY_BE_STALE('thaddeus_scratch');
239
+ }
240
+ /**
241
+ * Returns the user-specific Thaddeus temp directory name.
242
+ * On Unix: 'claude-{uid}' to prevent multi-user permission conflicts
243
+ * On Windows: 'claude' (tmpdir() is already per-user)
244
+ */
245
+ export function getClaudeTempDirName() {
246
+ if (getPlatform() === 'windows') {
247
+ return 'claude';
248
+ }
249
+ // Use UID to create per-user directories, preventing permission conflicts
250
+ // when multiple users share the same /tmp directory
251
+ const uid = process.getuid?.() ?? 0;
252
+ return `claude-${uid}`;
253
+ }
254
+ /**
255
+ * Returns the Thaddeus temp directory path with symlinks resolved.
256
+ * Uses TMPDIR env var if set, otherwise:
257
+ * - On Unix: /tmp/claude-{uid}/ (resolved to /private/tmp/claude-{uid}/ on macOS)
258
+ * - On Windows: {tmpdir}/claude/ (e.g., C:\Users\{user}\AppData\Local\Temp\claude\)
259
+ * This is a per-user temporary directory used by Thaddeus for all temp files.
260
+ *
261
+ * NOTE: We resolve symlinks to ensure this path matches the resolved paths used
262
+ * in permission checks. On macOS, /tmp is a symlink to /private/tmp, so without
263
+ * resolution, paths like /tmp/claude-{uid}/... wouldn't match /private/tmp/claude-{uid}/...
264
+ */
265
+ // Memoized: called per-tool from permission checks (yoloClassifier, sandbox-adapter)
266
+ // and per-turn from BashTool prompt. Inputs (THADDEUS_TMPDIR env + platform) are
267
+ // fixed at startup, and the realpath of the system tmp dir does not change mid-session.
268
+ export const getClaudeTempDir = memoize(function getClaudeTempDir() {
269
+ const baseTmpDir = process.env.THADDEUS_TMPDIR ||
270
+ (getPlatform() === 'windows' ? tmpdir() : '/tmp');
271
+ // Resolve symlinks in the base temp directory (e.g., /tmp -> /private/tmp on macOS)
272
+ // This ensures the path matches resolved paths in permission checks
273
+ const fs = getFsImplementation();
274
+ let resolvedBaseTmpDir = baseTmpDir;
275
+ try {
276
+ resolvedBaseTmpDir = fs.realpathSync(baseTmpDir);
277
+ }
278
+ catch {
279
+ // If resolution fails, use the original path
280
+ }
281
+ return join(resolvedBaseTmpDir, getClaudeTempDirName()) + sep;
282
+ });
283
+ /**
284
+ * Root for bundled-skill file extraction (see bundledSkills.ts).
285
+ *
286
+ * SECURITY: The per-process random nonce is the load-bearing defense here.
287
+ * Every other path component (uid, VERSION, skill name, file keys) is public
288
+ * knowledge, so without it a local attacker can pre-create the tree on a
289
+ * shared /tmp — sticky bit prevents deletion, not creation — and either
290
+ * symlink an intermediate directory (O_NOFOLLOW only checks the final
291
+ * component) or own a parent dir and swap file contents post-write for prompt
292
+ * injection via the read allowlist. diskOutput.ts gets the same property from
293
+ * the session-ID UUID in its path.
294
+ *
295
+ * Memoized so the extraction writes and the permission check agree on the
296
+ * path for the life of the process. Version-scoped so stale extractions from
297
+ * other binaries don't fall under the allowlist.
298
+ */
299
+ export const getBundledSkillsRoot = memoize(function getBundledSkillsRoot() {
300
+ const nonce = randomBytes(16).toString('hex');
301
+ return join(getClaudeTempDir(), 'bundled-skills', MACRO.VERSION, nonce);
302
+ });
303
+ /**
304
+ * Returns the project temp directory path with trailing separator.
305
+ * Path format: /tmp/claude-{uid}/{sanitized-cwd}/
306
+ */
307
+ export function getProjectTempDir() {
308
+ return join(getClaudeTempDir(), sanitizePath(getOriginalCwd())) + sep;
309
+ }
310
+ /**
311
+ * Returns the scratchpad directory path for the current session.
312
+ * Path format: /tmp/claude-{uid}/{sanitized-cwd}/{sessionId}/scratchpad/
313
+ */
314
+ export function getScratchpadDir() {
315
+ return join(getProjectTempDir(), getSessionId(), 'scratchpad');
316
+ }
317
+ /**
318
+ * Ensures the scratchpad directory exists for the current session.
319
+ * Creates the directory with secure permissions (0o700) if it doesn't exist.
320
+ * Returns the path to the scratchpad directory.
321
+ * @throws If scratchpad feature is not enabled
322
+ */
323
+ export async function ensureScratchpadDir() {
324
+ if (!isScratchpadEnabled()) {
325
+ throw new Error('Scratchpad directory feature is not enabled');
326
+ }
327
+ const fs = getFsImplementation();
328
+ const scratchpadDir = getScratchpadDir();
329
+ // Create directory recursively with secure permissions (owner-only access)
330
+ // FsOperations.mkdir handles recursive: true internally and is a no-op if dir exists
331
+ await fs.mkdir(scratchpadDir, { mode: 0o700 });
332
+ return scratchpadDir;
333
+ }
334
+ // Check if file is within the scratchpad directory
335
+ function isScratchpadPath(absolutePath) {
336
+ if (!isScratchpadEnabled()) {
337
+ return false;
338
+ }
339
+ const scratchpadDir = getScratchpadDir();
340
+ // SECURITY: Normalize the path to resolve .. segments before checking
341
+ // This prevents path traversal bypasses like:
342
+ // echo "malicious" > /tmp/claude-0/proj/session/scratchpad/../../../etc/passwd
343
+ // Without normalization, the path would pass the startsWith check but write to /etc/passwd
344
+ const normalizedPath = normalize(absolutePath);
345
+ return (normalizedPath === scratchpadDir ||
346
+ normalizedPath.startsWith(scratchpadDir + sep));
347
+ }
348
+ /**
349
+ * Check if a file path is dangerous to auto-edit without explicit permission.
350
+ * This includes:
351
+ * - Files in .git directories or .gitconfig files (to prevent git-based data exfiltration and code execution)
352
+ * - Files in .vscode directories (to prevent VS Code settings manipulation and potential code execution)
353
+ * - Files in .idea directories (to prevent JetBrains IDE settings manipulation)
354
+ * - Shell configuration files (to prevent shell startup script manipulation)
355
+ * - UNC paths (to prevent network file access and WebDAV attacks)
356
+ */
357
+ function isDangerousFilePathToAutoEdit(path) {
358
+ const absolutePath = expandPath(path);
359
+ const pathSegments = absolutePath.split(sep);
360
+ const fileName = pathSegments.at(-1);
361
+ // Check for UNC paths (defense-in-depth to catch any patterns that might not be caught by containsVulnerableUncPath)
362
+ // Block anything starting with \\ or // as these are potentially UNC paths that could access network resources
363
+ if (path.startsWith('\\\\') || path.startsWith('//')) {
364
+ return true;
365
+ }
366
+ // Check if path is within dangerous directories (case-insensitive to prevent bypasses)
367
+ for (let i = 0; i < pathSegments.length; i++) {
368
+ const segment = pathSegments[i];
369
+ const normalizedSegment = normalizeCaseForComparison(segment);
370
+ for (const dir of DANGEROUS_DIRECTORIES) {
371
+ if (normalizedSegment !== normalizeCaseForComparison(dir)) {
372
+ continue;
373
+ }
374
+ // Special case: .claude/worktrees/ is a structural path (where Thaddeus stores
375
+ // git worktrees), not a user-created dangerous directory. Skip the .claude
376
+ // segment when it's followed by 'worktrees'. Any nested .claude directories
377
+ // within the worktree (not followed by 'worktrees') are still blocked.
378
+ if (dir === '.claude') {
379
+ const nextSegment = pathSegments[i + 1];
380
+ if (nextSegment &&
381
+ normalizeCaseForComparison(nextSegment) === 'worktrees') {
382
+ break; // Skip this .claude, continue checking other segments
383
+ }
384
+ }
385
+ return true;
386
+ }
387
+ }
388
+ // Check for dangerous configuration files (case-insensitive)
389
+ if (fileName) {
390
+ const normalizedFileName = normalizeCaseForComparison(fileName);
391
+ if (DANGEROUS_FILES.some(dangerousFile => normalizeCaseForComparison(dangerousFile) === normalizedFileName)) {
392
+ return true;
393
+ }
394
+ }
395
+ return false;
396
+ }
397
+ /**
398
+ * Detects suspicious Windows path patterns that could bypass security checks.
399
+ * These patterns include:
400
+ * - NTFS Alternate Data Streams (e.g., file.txt::$DATA or file.txt:stream)
401
+ * - 8.3 short names (e.g., GIT~1, CLAUDE~1, SETTIN~1.JSON)
402
+ * - Long path prefixes (e.g., \\?\C:\..., \\.\C:\..., //?/C:/..., //./C:/...)
403
+ * - Trailing dots and spaces (e.g., .git., .claude , .bashrc...)
404
+ * - DOS device names (e.g., .git.CON, settings.json.PRN, .bashrc.AUX)
405
+ * - Three or more consecutive dots (e.g., .../file.txt, path/.../file, file...txt)
406
+ *
407
+ * When detected, these paths should always require manual approval to prevent
408
+ * bypassing security checks through path canonicalization vulnerabilities.
409
+ *
410
+ * ## Why Check on All Platforms?
411
+ *
412
+ * While these patterns are primarily Windows-specific, NTFS filesystems can be
413
+ * mounted on Linux and macOS (e.g., using ntfs-3g). On these systems, the same
414
+ * bypass techniques would work - an attacker could use short names or long path
415
+ * prefixes to bypass security checks. Therefore, we check for these patterns on
416
+ * all platforms to ensure comprehensive protection. (Note: the ADS colon check
417
+ * is Windows/WSL-only, since colon syntax is only interpreted by the Windows
418
+ * kernel; on Linux/macOS, NTFS ADS is accessed via xattrs, not colon syntax.)
419
+ *
420
+ * ## Why Detection Instead of Normalization?
421
+ *
422
+ * An alternative approach would be to normalize these paths using Windows APIs
423
+ * (e.g., GetLongPathNameW). However, this approach has significant challenges:
424
+ *
425
+ * 1. **Filesystem dependency**: Short path normalization is relative to files that
426
+ * currently exist on the filesystem. This creates issues when writing to new
427
+ * files since they don't exist yet and cannot be normalized.
428
+ *
429
+ * 2. **Race conditions**: The filesystem state can change between normalization
430
+ * and actual file access, creating TOCTOU (Time-Of-Check-Time-Of-Use) vulnerabilities.
431
+ *
432
+ * 3. **Complexity**: Proper normalization requires Windows-specific APIs, handling
433
+ * multiple edge cases, and dealing with various path formats (UNC, device paths, etc.).
434
+ *
435
+ * 4. **Reliability**: Pattern detection is more predictable and doesn't depend on
436
+ * external system state.
437
+ *
438
+ * If you are considering adding normalization for these paths, please reach out to
439
+ * AppSec first to discuss the security implications and implementation approach.
440
+ *
441
+ * @param path The path to check for suspicious patterns
442
+ * @returns true if suspicious Windows path patterns are detected
443
+ */
444
+ function hasSuspiciousWindowsPathPattern(path) {
445
+ // Check for NTFS Alternate Data Streams
446
+ // Look for ':' after position 2 to skip drive letters (e.g., C:\)
447
+ // Examples: file.txt::$DATA, .bashrc:hidden, settings.json:stream
448
+ // Note: ADS colon syntax is only interpreted by the Windows kernel. On WSL,
449
+ // DrvFs mounts route file operations through the Windows kernel, so colon
450
+ // syntax is still interpreted as ADS separators. On Linux/macOS (non-WSL),
451
+ // even when NTFS is mounted, ADS is accessed via xattrs (ntfs-3g) not colon
452
+ // syntax, and colons are valid filename characters.
453
+ if (getPlatform() === 'windows' || getPlatform() === 'wsl') {
454
+ const colonIndex = path.indexOf(':', 2);
455
+ if (colonIndex !== -1) {
456
+ return true;
457
+ }
458
+ }
459
+ // Check for 8.3 short names
460
+ // Look for '~' followed by a digit
461
+ // Examples: GIT~1, CLAUDE~1, SETTIN~1.JSON, BASHRC~1
462
+ if (/~\d/.test(path)) {
463
+ return true;
464
+ }
465
+ // Check for long path prefixes (both backslash and forward slash variants)
466
+ // Examples: \\?\C:\Users\..., \\.\C:\..., //?/C:/..., //./C:/...
467
+ if (path.startsWith('\\\\?\\') ||
468
+ path.startsWith('\\\\.\\') ||
469
+ path.startsWith('//?/') ||
470
+ path.startsWith('//./')) {
471
+ return true;
472
+ }
473
+ // Check for trailing dots and spaces that Windows strips during path resolution
474
+ // Examples: .git., .claude , .bashrc..., settings.json.
475
+ // This can bypass string matching if ".git" is blocked but ".git." is used
476
+ if (/[.\s]+$/.test(path)) {
477
+ return true;
478
+ }
479
+ // Check for DOS device names that Windows treats as special devices
480
+ // Examples: .git.CON, settings.json.PRN, .bashrc.AUX
481
+ // Device names: CON, PRN, AUX, NUL, COM1-9, LPT1-9
482
+ if (/\.(CON|PRN|AUX|NUL|COM[1-9]|LPT[1-9])$/i.test(path)) {
483
+ return true;
484
+ }
485
+ // Check for three or more consecutive dots (...) when used as a path component
486
+ // This pattern can be used to bypass security checks or create confusion
487
+ // Examples: .../file.txt, path/.../file
488
+ // Only block when dots are preceded AND followed by path separators (/ or \)
489
+ // This allows legitimate uses like Next.js catch-all routes [...]name]
490
+ if (/(^|\/|\\)\.{3,}(\/|\\|$)/.test(path)) {
491
+ return true;
492
+ }
493
+ // Check for UNC paths (on all platforms for defense-in-depth)
494
+ // Examples: \\server\share, \\foo.com\file, //server/share, \\192.168.1.1\share
495
+ // UNC paths can access remote resources, leak credentials, and bypass working directory restrictions
496
+ if (containsVulnerableUncPath(path)) {
497
+ return true;
498
+ }
499
+ return false;
500
+ }
501
+ /**
502
+ * Checks if a path is safe for auto-editing (acceptEdits mode).
503
+ * Returns information about why the path is unsafe, or null if all checks pass.
504
+ *
505
+ * This function performs comprehensive safety checks including:
506
+ * - Suspicious Windows path patterns (NTFS streams, 8.3 names, long path prefixes, etc.)
507
+ * - Thaddeus config files (.claude/settings.json, .claude/commands/, .claude/agents/)
508
+ * - MCP CLI state files (managed internally by Thaddeus)
509
+ * - Dangerous files (.bashrc, .gitconfig, .git/, .vscode/, .idea/, etc.)
510
+ *
511
+ * IMPORTANT: This function checks BOTH the original path AND resolved symlink paths
512
+ * to prevent bypasses via symlinks pointing to protected files.
513
+ *
514
+ * @param path The path to check for safety
515
+ * @returns Object with safe=false and message if unsafe, or { safe: true } if all checks pass
516
+ */
517
+ export function checkPathSafetyForAutoEdit(path, precomputedPathsToCheck) {
518
+ // Get all paths to check (original + symlink resolved paths)
519
+ const pathsToCheck = precomputedPathsToCheck ?? getPathsForPermissionCheck(path);
520
+ // Check for suspicious Windows path patterns on all paths
521
+ for (const pathToCheck of pathsToCheck) {
522
+ if (hasSuspiciousWindowsPathPattern(pathToCheck)) {
523
+ return {
524
+ safe: false,
525
+ message: `Thaddeus requested permissions to write to ${path}, which contains a suspicious Windows path pattern that requires manual approval.`,
526
+ classifierApprovable: false,
527
+ };
528
+ }
529
+ }
530
+ // Check for Thaddeus config files on all paths
531
+ for (const pathToCheck of pathsToCheck) {
532
+ if (isClaudeConfigFilePath(pathToCheck)) {
533
+ return {
534
+ safe: false,
535
+ message: `Thaddeus requested permissions to write to ${path}, but you haven't granted it yet.`,
536
+ classifierApprovable: true,
537
+ };
538
+ }
539
+ }
540
+ // Check for dangerous files on all paths
541
+ for (const pathToCheck of pathsToCheck) {
542
+ if (isDangerousFilePathToAutoEdit(pathToCheck)) {
543
+ return {
544
+ safe: false,
545
+ message: `Thaddeus requested permissions to edit ${path} which is a sensitive file.`,
546
+ classifierApprovable: true,
547
+ };
548
+ }
549
+ }
550
+ // All safety checks passed
551
+ return { safe: true };
552
+ }
553
+ export function allWorkingDirectories(context) {
554
+ return new Set([
555
+ getOriginalCwd(),
556
+ ...context.additionalWorkingDirectories.keys(),
557
+ ]);
558
+ }
559
+ // Working directories are session-stable; memoize their resolved forms to
560
+ // avoid repeated existsSync/lstatSync/realpathSync syscalls on every
561
+ // permission check. Keyed by path string — getPathsForPermissionCheck is
562
+ // deterministic for existing directories within a session.
563
+ // Exported for test/preload.ts cache clearing (shard-isolation).
564
+ export const getResolvedWorkingDirPaths = memoize(getPathsForPermissionCheck);
565
+ export function pathInAllowedWorkingPath(path, toolPermissionContext, precomputedPathsToCheck) {
566
+ // Check both the original path and the resolved symlink path
567
+ const pathsToCheck = precomputedPathsToCheck ?? getPathsForPermissionCheck(path);
568
+ // Resolve working directories the same way we resolve input paths so
569
+ // comparisons are symmetric. Without this, a resolved input path
570
+ // (e.g. /System/Volumes/Data/home/... on macOS) would not match an
571
+ // unresolved working directory (/home/...), causing false denials.
572
+ const workingPaths = Array.from(allWorkingDirectories(toolPermissionContext)).flatMap(wp => getResolvedWorkingDirPaths(wp));
573
+ // All paths must be within allowed working paths
574
+ // If any resolved path is outside, deny access
575
+ return pathsToCheck.every(pathToCheck => workingPaths.some(workingPath => pathInWorkingPath(pathToCheck, workingPath)));
576
+ }
577
+ export function pathInWorkingPath(path, workingPath) {
578
+ const absolutePath = expandPath(path);
579
+ const absoluteWorkingPath = expandPath(workingPath);
580
+ // On macOS, handle common symlink issues:
581
+ // - /var -> /private/var
582
+ // - /tmp -> /private/tmp
583
+ const normalizedPath = absolutePath
584
+ .replace(/^\/private\/var\//, '/var/')
585
+ .replace(/^\/private\/tmp(\/|$)/, '/tmp$1');
586
+ const normalizedWorkingPath = absoluteWorkingPath
587
+ .replace(/^\/private\/var\//, '/var/')
588
+ .replace(/^\/private\/tmp(\/|$)/, '/tmp$1');
589
+ // Normalize case for case-insensitive comparison to prevent bypassing security
590
+ // checks on case-insensitive filesystems (macOS/Windows) like .cLauDe/CoMmAnDs
591
+ const caseNormalizedPath = normalizeCaseForComparison(normalizedPath);
592
+ const caseNormalizedWorkingPath = normalizeCaseForComparison(normalizedWorkingPath);
593
+ // Use cross-platform relative path helper
594
+ const relative = relativePath(caseNormalizedWorkingPath, caseNormalizedPath);
595
+ // Same path
596
+ if (relative === '') {
597
+ return true;
598
+ }
599
+ if (containsPathTraversal(relative)) {
600
+ return false;
601
+ }
602
+ // Path is inside (relative path that doesn't go up)
603
+ return !posix.isAbsolute(relative);
604
+ }
605
+ function rootPathForSource(source) {
606
+ switch (source) {
607
+ case 'cliArg':
608
+ case 'command':
609
+ case 'session':
610
+ return expandPath(getOriginalCwd());
611
+ case 'userSettings':
612
+ case 'policySettings':
613
+ case 'projectSettings':
614
+ case 'localSettings':
615
+ case 'flagSettings':
616
+ return getSettingsRootPathForSource(source);
617
+ }
618
+ }
619
+ function prependDirSep(path) {
620
+ return posix.join(DIR_SEP, path);
621
+ }
622
+ function normalizePatternToPath({ patternRoot, pattern, rootPath, }) {
623
+ // If the pattern root + pattern combination starts with our reference root
624
+ const fullPattern = posix.join(patternRoot, pattern);
625
+ if (patternRoot === rootPath) {
626
+ // If the pattern root exactly matches our reference root no need to change
627
+ return prependDirSep(pattern);
628
+ }
629
+ else if (fullPattern.startsWith(`${rootPath}${DIR_SEP}`)) {
630
+ // Extract the relative part
631
+ const relativePart = fullPattern.slice(rootPath.length);
632
+ return prependDirSep(relativePart);
633
+ }
634
+ else {
635
+ // Handle patterns that are inside the reference root but not starting with it
636
+ const relativePath = posix.relative(rootPath, patternRoot);
637
+ if (!relativePath ||
638
+ relativePath.startsWith(`..${DIR_SEP}`) ||
639
+ relativePath === '..') {
640
+ // Pattern is outside the reference root, so it can be skipped
641
+ return null;
642
+ }
643
+ else {
644
+ const relativePattern = posix.join(relativePath, pattern);
645
+ return prependDirSep(relativePattern);
646
+ }
647
+ }
648
+ }
649
+ export function normalizePatternsToPath(patternsByRoot, root) {
650
+ // null root means the pattern can match anywhere
651
+ const result = new Set(patternsByRoot.get(null) ?? []);
652
+ for (const [patternRoot, patterns] of patternsByRoot.entries()) {
653
+ if (patternRoot === null) {
654
+ // already added
655
+ continue;
656
+ }
657
+ // Check each pattern to see if the full path starts with our reference root
658
+ for (const pattern of patterns) {
659
+ const normalizedPattern = normalizePatternToPath({
660
+ patternRoot,
661
+ pattern,
662
+ rootPath: root,
663
+ });
664
+ if (normalizedPattern) {
665
+ result.add(normalizedPattern);
666
+ }
667
+ }
668
+ }
669
+ return Array.from(result);
670
+ }
671
+ /**
672
+ * Collects all deny rules for file read permissions and returns their ignore patterns
673
+ * Each pattern must be resolved relative to its root (map key)
674
+ * Null keys are used for patterns that don't have a root
675
+ *
676
+ * This is used to hide files that are blocked by Read deny rules.
677
+ *
678
+ * @param toolPermissionContext
679
+ */
680
+ export function getFileReadIgnorePatterns(toolPermissionContext) {
681
+ const patternsByRoot = getPatternsByRoot(toolPermissionContext, 'read', 'deny');
682
+ const result = new Map();
683
+ for (const [patternRoot, patternMap] of patternsByRoot.entries()) {
684
+ result.set(patternRoot, Array.from(patternMap.keys()));
685
+ }
686
+ return result;
687
+ }
688
+ function patternWithRoot(pattern, source) {
689
+ if (pattern.startsWith(`${DIR_SEP}${DIR_SEP}`)) {
690
+ // Patterns starting with // resolve relative to /
691
+ const patternWithoutDoubleSlash = pattern.slice(1);
692
+ // On Windows, check if this is a POSIX-style drive path like //c/Users/...
693
+ // Note: UNC paths (//server/share) will not match this regex and will be treated
694
+ // as root-relative patterns, which may need separate handling in the future
695
+ if (getPlatform() === 'windows' &&
696
+ patternWithoutDoubleSlash.match(/^\/[a-z]\//i)) {
697
+ // Convert POSIX path to Windows format
698
+ // The pattern is like /c/Users/... so we convert it to C:\Users\...
699
+ const driveLetter = patternWithoutDoubleSlash[1]?.toUpperCase() ?? 'C';
700
+ // Keep the pattern in POSIX format since relativePath returns POSIX paths
701
+ const pathAfterDrive = patternWithoutDoubleSlash.slice(2);
702
+ // Extract the drive root (C:\) and the rest of the pattern
703
+ const driveRoot = `${driveLetter}:\\`;
704
+ const relativeFromDrive = pathAfterDrive.startsWith('/')
705
+ ? pathAfterDrive.slice(1)
706
+ : pathAfterDrive;
707
+ return {
708
+ relativePattern: relativeFromDrive,
709
+ root: driveRoot,
710
+ };
711
+ }
712
+ return {
713
+ relativePattern: patternWithoutDoubleSlash,
714
+ root: DIR_SEP,
715
+ };
716
+ }
717
+ else if (pattern.startsWith(`~${DIR_SEP}`)) {
718
+ // Patterns starting with ~/ resolve relative to homedir
719
+ return {
720
+ relativePattern: pattern.slice(1),
721
+ root: homedir().normalize('NFC'),
722
+ };
723
+ }
724
+ else if (pattern.startsWith(DIR_SEP)) {
725
+ // Patterns starting with / resolve relative to the directory where settings are stored (without .claude/)
726
+ return {
727
+ relativePattern: pattern,
728
+ root: rootPathForSource(source),
729
+ };
730
+ }
731
+ // No root specified, put it with all the other patterns
732
+ // Normalize patterns that start with "./" to remove the prefix
733
+ // This ensures that patterns like "./.env" match files like ".env"
734
+ let normalizedPattern = pattern;
735
+ if (pattern.startsWith(`.${DIR_SEP}`)) {
736
+ normalizedPattern = pattern.slice(2);
737
+ }
738
+ return {
739
+ relativePattern: normalizedPattern,
740
+ root: null,
741
+ };
742
+ }
743
+ function getPatternsByRoot(toolPermissionContext, toolType, behavior) {
744
+ const toolName = (() => {
745
+ switch (toolType) {
746
+ case 'edit':
747
+ // Apply Edit tool rules to any tool editing files
748
+ return FILE_EDIT_TOOL_NAME;
749
+ case 'read':
750
+ // Apply Read tool rules to any tool reading files
751
+ return FILE_READ_TOOL_NAME;
752
+ }
753
+ })();
754
+ const rules = getRuleByContentsForToolName(toolPermissionContext, toolName, behavior);
755
+ // Resolve rules relative to path based on source
756
+ const patternsByRoot = new Map();
757
+ for (const [pattern, rule] of rules.entries()) {
758
+ const { relativePattern, root } = patternWithRoot(pattern, rule.source);
759
+ let patternsForRoot = patternsByRoot.get(root);
760
+ if (patternsForRoot === undefined) {
761
+ patternsForRoot = new Map();
762
+ patternsByRoot.set(root, patternsForRoot);
763
+ }
764
+ // Store the rule keyed by the root
765
+ patternsForRoot.set(relativePattern, rule);
766
+ }
767
+ return patternsByRoot;
768
+ }
769
+ export function matchingRuleForInput(path, toolPermissionContext, toolType, behavior) {
770
+ let fileAbsolutePath = expandPath(path);
771
+ // On Windows, convert to POSIX format to match against permission patterns
772
+ if (getPlatform() === 'windows' && fileAbsolutePath.includes('\\')) {
773
+ fileAbsolutePath = windowsPathToPosixPath(fileAbsolutePath);
774
+ }
775
+ const patternsByRoot = getPatternsByRoot(toolPermissionContext, toolType, behavior);
776
+ // Check each root for a matching pattern
777
+ for (const [root, patternMap] of patternsByRoot.entries()) {
778
+ // Transform patterns for the ignore library
779
+ const patterns = Array.from(patternMap.keys()).map(pattern => {
780
+ let adjustedPattern = pattern;
781
+ // Remove /** suffix - ignore library treats 'path' as matching both
782
+ // the path itself and everything inside it
783
+ if (adjustedPattern.endsWith('/**')) {
784
+ adjustedPattern = adjustedPattern.slice(0, -3);
785
+ }
786
+ return adjustedPattern;
787
+ });
788
+ const ig = ignore().add(patterns);
789
+ // Use cross-platform relative path helper for POSIX-style patterns
790
+ const relativePathStr = relativePath(root ?? getCwd(), fileAbsolutePath ?? getCwd());
791
+ if (relativePathStr.startsWith(`..${DIR_SEP}`)) {
792
+ // The path is outside the root, so ignore it
793
+ continue;
794
+ }
795
+ // Important: ig.test throws if you give it an empty string
796
+ if (!relativePathStr) {
797
+ continue;
798
+ }
799
+ const igResult = ig.test(relativePathStr);
800
+ if (igResult.ignored && igResult.rule) {
801
+ // Map the matched pattern back to the original rule
802
+ const originalPattern = igResult.rule.pattern;
803
+ // Check if this was a /** pattern we simplified
804
+ const withWildcard = originalPattern + '/**';
805
+ if (patternMap.has(withWildcard)) {
806
+ return patternMap.get(withWildcard) ?? null;
807
+ }
808
+ return patternMap.get(originalPattern) ?? null;
809
+ }
810
+ }
811
+ // No matching rule found
812
+ return null;
813
+ }
814
+ /**
815
+ * Permission result for read permission for the specified tool & tool input
816
+ */
817
+ export function checkReadPermissionForTool(tool, input, toolPermissionContext) {
818
+ if (typeof tool.getPath !== 'function') {
819
+ return {
820
+ behavior: 'ask',
821
+ message: `Thaddeus requested permissions to use ${tool.name}, but you haven't granted it yet.`,
822
+ };
823
+ }
824
+ const path = tool.getPath(input);
825
+ // Get paths to check (includes both original and resolved symlinks).
826
+ // Computed once here and threaded through checkWritePermissionForTool →
827
+ // checkPathSafetyForAutoEdit → pathInAllowedWorkingPath to avoid redundant
828
+ // existsSync/lstatSync/realpathSync syscalls on the same path (previously
829
+ // 6× = 30 syscalls per Read permission check).
830
+ const pathsToCheck = getPathsForPermissionCheck(path);
831
+ // 1. Defense-in-depth: Block UNC paths early (before other checks)
832
+ // This catches paths starting with \\ or // that could access network resources
833
+ // This may catch some UNC patterns not detected by containsVulnerableUncPath
834
+ for (const pathToCheck of pathsToCheck) {
835
+ if (pathToCheck.startsWith('\\\\') || pathToCheck.startsWith('//')) {
836
+ return {
837
+ behavior: 'ask',
838
+ message: `Thaddeus requested permissions to read from ${path}, which appears to be a UNC path that could access network resources.`,
839
+ decisionReason: {
840
+ type: 'other',
841
+ reason: 'UNC path detected (defense-in-depth check)',
842
+ },
843
+ };
844
+ }
845
+ }
846
+ // 2. Check for suspicious Windows path patterns (defense in depth)
847
+ for (const pathToCheck of pathsToCheck) {
848
+ if (hasSuspiciousWindowsPathPattern(pathToCheck)) {
849
+ return {
850
+ behavior: 'ask',
851
+ message: `Thaddeus requested permissions to read from ${path}, which contains a suspicious Windows path pattern that requires manual approval.`,
852
+ decisionReason: {
853
+ type: 'other',
854
+ reason: 'Path contains suspicious Windows-specific patterns (alternate data streams, short names, long path prefixes, or three or more consecutive dots) that require manual verification',
855
+ },
856
+ };
857
+ }
858
+ }
859
+ // 3. Check for READ-SPECIFIC deny rules first - check both the original path and resolved symlink path
860
+ // SECURITY: This must come before any allow checks (including "edit access implies read access")
861
+ // to prevent bypassing explicit read deny rules
862
+ for (const pathToCheck of pathsToCheck) {
863
+ const denyRule = matchingRuleForInput(pathToCheck, toolPermissionContext, 'read', 'deny');
864
+ if (denyRule) {
865
+ return {
866
+ behavior: 'deny',
867
+ message: `Permission to read ${path} has been denied.`,
868
+ decisionReason: {
869
+ type: 'rule',
870
+ rule: denyRule,
871
+ },
872
+ };
873
+ }
874
+ }
875
+ // 4. Check for READ-SPECIFIC ask rules - check both the original path and resolved symlink path
876
+ // SECURITY: This must come before implicit allow checks to ensure explicit ask rules are honored
877
+ for (const pathToCheck of pathsToCheck) {
878
+ const askRule = matchingRuleForInput(pathToCheck, toolPermissionContext, 'read', 'ask');
879
+ if (askRule) {
880
+ return {
881
+ behavior: 'ask',
882
+ message: `Thaddeus requested permissions to read from ${path}, but you haven't granted it yet.`,
883
+ decisionReason: {
884
+ type: 'rule',
885
+ rule: askRule,
886
+ },
887
+ };
888
+ }
889
+ }
890
+ // 5. Edit access implies read access (but only if no read-specific deny/ask rules exist)
891
+ // We check this after read-specific rules so that explicit read restrictions take precedence
892
+ const editResult = checkWritePermissionForTool(tool, input, toolPermissionContext, pathsToCheck);
893
+ if (editResult.behavior === 'allow') {
894
+ return editResult;
895
+ }
896
+ // 6. Allow reads in working directories
897
+ const isInWorkingDir = pathInAllowedWorkingPath(path, toolPermissionContext, pathsToCheck);
898
+ if (isInWorkingDir) {
899
+ return {
900
+ behavior: 'allow',
901
+ updatedInput: input,
902
+ decisionReason: {
903
+ type: 'mode',
904
+ mode: 'default',
905
+ },
906
+ };
907
+ }
908
+ // 7. Allow reads from internal harness paths (session-memory, plans, tool-results)
909
+ const absolutePath = expandPath(path);
910
+ const internalReadResult = checkReadableInternalPath(absolutePath, input);
911
+ if (internalReadResult.behavior !== 'passthrough') {
912
+ return internalReadResult;
913
+ }
914
+ // 8. Check for allow rules
915
+ const allowRule = matchingRuleForInput(path, toolPermissionContext, 'read', 'allow');
916
+ if (allowRule) {
917
+ return {
918
+ behavior: 'allow',
919
+ updatedInput: input,
920
+ decisionReason: {
921
+ type: 'rule',
922
+ rule: allowRule,
923
+ },
924
+ };
925
+ }
926
+ // 12. Default to asking for permission
927
+ // At this point, isInWorkingDir is false (from step #6), so path is outside working directories
928
+ return {
929
+ behavior: 'ask',
930
+ message: `Thaddeus requested permissions to read from ${path}, but you haven't granted it yet.`,
931
+ suggestions: generateSuggestions(path, 'read', toolPermissionContext, pathsToCheck),
932
+ decisionReason: {
933
+ type: 'workingDir',
934
+ reason: 'Path is outside allowed working directories',
935
+ },
936
+ };
937
+ }
938
+ /**
939
+ * Permission result for write permission for the specified tool & tool input.
940
+ *
941
+ * @param precomputedPathsToCheck - Optional cached result of
942
+ * `getPathsForPermissionCheck(tool.getPath(input))`. Callers MUST derive this
943
+ * from the same `tool` and `input` in the same synchronous frame — `path` is
944
+ * re-derived internally for error messages and internal-path checks, so a
945
+ * stale value would silently check deny rules for the wrong path.
946
+ */
947
+ export function checkWritePermissionForTool(tool, input, toolPermissionContext, precomputedPathsToCheck) {
948
+ if (typeof tool.getPath !== 'function') {
949
+ return {
950
+ behavior: 'ask',
951
+ message: `Thaddeus requested permissions to use ${tool.name}, but you haven't granted it yet.`,
952
+ };
953
+ }
954
+ const path = tool.getPath(input);
955
+ // 1. Check for deny rules - check both the original path and resolved symlink path
956
+ const pathsToCheck = precomputedPathsToCheck ?? getPathsForPermissionCheck(path);
957
+ for (const pathToCheck of pathsToCheck) {
958
+ const denyRule = matchingRuleForInput(pathToCheck, toolPermissionContext, 'edit', 'deny');
959
+ if (denyRule) {
960
+ return {
961
+ behavior: 'deny',
962
+ message: `Permission to edit ${path} has been denied.`,
963
+ decisionReason: {
964
+ type: 'rule',
965
+ rule: denyRule,
966
+ },
967
+ };
968
+ }
969
+ }
970
+ // 1.5. Allow writes to internal editable paths (plan files, scratchpad)
971
+ // This MUST come before isDangerousFilePathToAutoEdit check since .claude is a dangerous directory
972
+ const absolutePathForEdit = expandPath(path);
973
+ const internalEditResult = checkEditableInternalPath(absolutePathForEdit, input);
974
+ if (internalEditResult.behavior !== 'passthrough') {
975
+ return internalEditResult;
976
+ }
977
+ // 1.6. Check for .claude/** allow rules BEFORE safety checks
978
+ // This allows session-level permissions to bypass the safety blocks for .claude/
979
+ // We only allow this for session-level rules to prevent users from accidentally
980
+ // permanently granting broad access to their .claude/ folder.
981
+ //
982
+ // matchingRuleForInput returns the first match across all sources. If the user
983
+ // also has a broader Edit(.claude) rule in userSettings (e.g. from sandbox
984
+ // write-allow conversion), that rule would be found first and its source check
985
+ // below would fail. Scope the search to session-only rules so the dialog's
986
+ // "allow Thaddeus to edit its own settings for this session" option actually works.
987
+ const claudeFolderAllowRule = matchingRuleForInput(path, {
988
+ ...toolPermissionContext,
989
+ alwaysAllowRules: {
990
+ session: toolPermissionContext.alwaysAllowRules.session ?? [],
991
+ },
992
+ }, 'edit', 'allow');
993
+ if (claudeFolderAllowRule) {
994
+ // Check if this rule is scoped under .claude/ (project or global).
995
+ // Accepts both the broad patterns ('/.claude/**', '~/.claude/**') and
996
+ // narrowed ones like '/.claude/skills/my-skill/**' so users can grant
997
+ // session access to a single skill without also exposing settings.json
998
+ // or hooks/. The rule already matched the path via matchingRuleForInput;
999
+ // this is an additional scope check. Reject '..' to prevent a rule like
1000
+ // '/.claude/../**' from leaking this bypass outside .claude/.
1001
+ const ruleContent = claudeFolderAllowRule.ruleValue.ruleContent;
1002
+ if (ruleContent &&
1003
+ (ruleContent.startsWith(CLAUDE_FOLDER_PERMISSION_PATTERN.slice(0, -2)) ||
1004
+ ruleContent.startsWith(GLOBAL_CLAUDE_FOLDER_PERMISSION_PATTERN.slice(0, -2))) &&
1005
+ !ruleContent.includes('..') &&
1006
+ ruleContent.endsWith('/**')) {
1007
+ return {
1008
+ behavior: 'allow',
1009
+ updatedInput: input,
1010
+ decisionReason: {
1011
+ type: 'rule',
1012
+ rule: claudeFolderAllowRule,
1013
+ },
1014
+ };
1015
+ }
1016
+ }
1017
+ // 1.7. Check comprehensive safety validations (Windows patterns, Thaddeus config, dangerous files)
1018
+ // This MUST come before checking allow rules to prevent users from accidentally granting
1019
+ // permission to edit protected files
1020
+ const safetyCheck = checkPathSafetyForAutoEdit(path, pathsToCheck);
1021
+ if (!safetyCheck.safe) {
1022
+ // SDK suggestion: if under .claude/skills/{name}/, emit the narrowed
1023
+ // session-scoped addRules that step 1.6 will honor on the next call.
1024
+ // Everything else (.claude/settings.json, .git/, .vscode/, .idea/) falls
1025
+ // back to generateSuggestions — its setMode suggestion doesn't bypass
1026
+ // this check, but preserving it avoids a surprising empty array.
1027
+ const skillScope = getClaudeSkillScope(path);
1028
+ const safetySuggestions = skillScope
1029
+ ? [
1030
+ {
1031
+ type: 'addRules',
1032
+ rules: [
1033
+ {
1034
+ toolName: FILE_EDIT_TOOL_NAME,
1035
+ ruleContent: skillScope.pattern,
1036
+ },
1037
+ ],
1038
+ behavior: 'allow',
1039
+ destination: 'session',
1040
+ },
1041
+ ]
1042
+ : generateSuggestions(path, 'write', toolPermissionContext, pathsToCheck);
1043
+ return {
1044
+ behavior: 'ask',
1045
+ message: safetyCheck.message,
1046
+ suggestions: safetySuggestions,
1047
+ decisionReason: {
1048
+ type: 'safetyCheck',
1049
+ reason: safetyCheck.message,
1050
+ classifierApprovable: safetyCheck.classifierApprovable,
1051
+ },
1052
+ };
1053
+ }
1054
+ // 2. Check for ask rules - check both the original path and resolved symlink path
1055
+ for (const pathToCheck of pathsToCheck) {
1056
+ const askRule = matchingRuleForInput(pathToCheck, toolPermissionContext, 'edit', 'ask');
1057
+ if (askRule) {
1058
+ return {
1059
+ behavior: 'ask',
1060
+ message: `Thaddeus requested permissions to write to ${path}, but you haven't granted it yet.`,
1061
+ decisionReason: {
1062
+ type: 'rule',
1063
+ rule: askRule,
1064
+ },
1065
+ };
1066
+ }
1067
+ }
1068
+ // 3. If in acceptEdits or sandboxBashMode mode, allow all writes in original cwd
1069
+ const isInWorkingDir = pathInAllowedWorkingPath(path, toolPermissionContext, pathsToCheck);
1070
+ if (toolPermissionContext.mode === 'acceptEdits' && isInWorkingDir) {
1071
+ return {
1072
+ behavior: 'allow',
1073
+ updatedInput: input,
1074
+ decisionReason: {
1075
+ type: 'mode',
1076
+ mode: toolPermissionContext.mode,
1077
+ },
1078
+ };
1079
+ }
1080
+ // 4. Check for allow rules
1081
+ const allowRule = matchingRuleForInput(path, toolPermissionContext, 'edit', 'allow');
1082
+ if (allowRule) {
1083
+ return {
1084
+ behavior: 'allow',
1085
+ updatedInput: input,
1086
+ decisionReason: {
1087
+ type: 'rule',
1088
+ rule: allowRule,
1089
+ },
1090
+ };
1091
+ }
1092
+ // 5. Default to asking for permission
1093
+ return {
1094
+ behavior: 'ask',
1095
+ message: `Thaddeus requested permissions to write to ${path}, but you haven't granted it yet.`,
1096
+ suggestions: generateSuggestions(path, 'write', toolPermissionContext, pathsToCheck),
1097
+ decisionReason: !isInWorkingDir
1098
+ ? {
1099
+ type: 'workingDir',
1100
+ reason: 'Path is outside allowed working directories',
1101
+ }
1102
+ : undefined,
1103
+ };
1104
+ }
1105
+ export function generateSuggestions(filePath, operationType, toolPermissionContext, precomputedPathsToCheck) {
1106
+ const isOutsideWorkingDir = !pathInAllowedWorkingPath(filePath, toolPermissionContext, precomputedPathsToCheck);
1107
+ if (operationType === 'read' && isOutsideWorkingDir) {
1108
+ // For read operations outside working directories, add Read rules
1109
+ // IMPORTANT: Include both the symlink path and resolved path so subsequent checks pass
1110
+ const dirPath = getDirectoryForPath(filePath);
1111
+ const dirsToAdd = getPathsForPermissionCheck(dirPath);
1112
+ const suggestions = dirsToAdd
1113
+ .map(dir => createReadRuleSuggestion(dir, 'session'))
1114
+ .filter((s) => s !== undefined);
1115
+ return suggestions;
1116
+ }
1117
+ // Only suggest setMode:acceptEdits when it would be an upgrade. In auto
1118
+ // mode the classifier already auto-approves edits; in bypassPermissions
1119
+ // everything is allowed; in acceptEdits it's a no-op. Suggesting it
1120
+ // anyway and having the SDK host apply it on "Always allow" silently
1121
+ // downgrades auto → acceptEdits, which then prompts for MCP/Bash.
1122
+ const shouldSuggestAcceptEdits = toolPermissionContext.mode === 'default' ||
1123
+ toolPermissionContext.mode === 'plan';
1124
+ if (operationType === 'write' || operationType === 'create') {
1125
+ const updates = shouldSuggestAcceptEdits
1126
+ ? [{ type: 'setMode', mode: 'acceptEdits', destination: 'session' }]
1127
+ : [];
1128
+ if (isOutsideWorkingDir) {
1129
+ // For write operations outside working directories, also add the directory
1130
+ // IMPORTANT: Include both the symlink path and resolved path so subsequent checks pass
1131
+ const dirPath = getDirectoryForPath(filePath);
1132
+ const dirsToAdd = getPathsForPermissionCheck(dirPath);
1133
+ updates.push({
1134
+ type: 'addDirectories',
1135
+ directories: dirsToAdd,
1136
+ destination: 'session',
1137
+ });
1138
+ }
1139
+ return updates;
1140
+ }
1141
+ // For read operations inside working directories, just change mode
1142
+ return shouldSuggestAcceptEdits
1143
+ ? [{ type: 'setMode', mode: 'acceptEdits', destination: 'session' }]
1144
+ : [];
1145
+ }
1146
+ /**
1147
+ * Check if a path is an internal path that can be edited without permission.
1148
+ * Returns a PermissionResult - either 'allow' if matched, or 'passthrough' to continue checking.
1149
+ */
1150
+ export function checkEditableInternalPath(absolutePath, input) {
1151
+ // SECURITY: Normalize path to prevent traversal bypasses via .. segments
1152
+ // This is defense-in-depth; individual helper functions also normalize
1153
+ const normalizedPath = normalize(absolutePath);
1154
+ // Plan files for current session
1155
+ if (isSessionPlanFile(normalizedPath)) {
1156
+ return {
1157
+ behavior: 'allow',
1158
+ updatedInput: input,
1159
+ decisionReason: {
1160
+ type: 'other',
1161
+ reason: 'Plan files for current session are allowed for writing',
1162
+ },
1163
+ };
1164
+ }
1165
+ // Scratchpad directory for current session
1166
+ if (isScratchpadPath(normalizedPath)) {
1167
+ return {
1168
+ behavior: 'allow',
1169
+ updatedInput: input,
1170
+ decisionReason: {
1171
+ type: 'other',
1172
+ reason: 'Scratchpad files for current session are allowed for writing',
1173
+ },
1174
+ };
1175
+ }
1176
+ // Template job's own directory. Env key hardcoded (vs importing JOB_ENV_KEY
1177
+ // from jobs/state) so tree-shaking eliminates the string from external
1178
+ // builds — spawn.test.ts asserts the string matches. Hijack guard: the env
1179
+ // var value must itself resolve under ~/.claude/jobs/. Symlink guard: every
1180
+ // resolved form of the target (lexical + symlink chain) must fall under some
1181
+ // resolved form of the job dir, so a symlink inside the job dir pointing at
1182
+ // e.g. ~/.ssh/authorized_keys does not get a free write. Resolving both
1183
+ // sides handles the macOS /tmp → /private/tmp case where the config dir
1184
+ // lives under a symlinked root.
1185
+ if (feature('TEMPLATES')) {
1186
+ const jobDir = process.env.CLAUDE_JOB_DIR;
1187
+ if (jobDir) {
1188
+ const jobsRoot = join(getClaudeConfigHomeDir(), 'jobs');
1189
+ const jobDirForms = getPathsForPermissionCheck(jobDir).map(normalize);
1190
+ const jobsRootForms = getPathsForPermissionCheck(jobsRoot).map(normalize);
1191
+ // Hijack guard: every resolved form of the job dir must sit under
1192
+ // some resolved form of the jobs root. Resolving both sides handles
1193
+ // the case where ~/.claude is a symlink (e.g. to /data/claude-config).
1194
+ const isUnderJobsRoot = jobDirForms.every(jd => jobsRootForms.some(jr => jd.startsWith(jr + sep)));
1195
+ if (isUnderJobsRoot) {
1196
+ const targetForms = getPathsForPermissionCheck(absolutePath);
1197
+ const allInsideJobDir = targetForms.every(p => {
1198
+ const np = normalize(p);
1199
+ return jobDirForms.some(jd => np === jd || np.startsWith(jd + sep));
1200
+ });
1201
+ if (allInsideJobDir) {
1202
+ return {
1203
+ behavior: 'allow',
1204
+ updatedInput: input,
1205
+ decisionReason: {
1206
+ type: 'other',
1207
+ reason: 'Job directory files for current job are allowed for writing',
1208
+ },
1209
+ };
1210
+ }
1211
+ }
1212
+ }
1213
+ }
1214
+ // Agent memory directory (for self-improving agents)
1215
+ if (isAgentMemoryPath(normalizedPath)) {
1216
+ return {
1217
+ behavior: 'allow',
1218
+ updatedInput: input,
1219
+ decisionReason: {
1220
+ type: 'other',
1221
+ reason: 'Agent memory files are allowed for writing',
1222
+ },
1223
+ };
1224
+ }
1225
+ // Memdir directory (persistent memory for cross-session learning)
1226
+ // This pre-safety-check carve-out exists because the default path is under
1227
+ // ~/.claude/, which is in DANGEROUS_DIRECTORIES. The CLAUDE_COWORK_MEMORY_PATH_OVERRIDE
1228
+ // override is an arbitrary caller-designated directory with no such conflict,
1229
+ // so it gets NO special permission treatment here — writes go through normal
1230
+ // permission flow (step 5 → ask). SDK callers who want silent memory should
1231
+ // pass an allow rule for the override path.
1232
+ if (!hasAutoMemPathOverride() && isAutoMemPath(normalizedPath)) {
1233
+ return {
1234
+ behavior: 'allow',
1235
+ updatedInput: input,
1236
+ decisionReason: {
1237
+ type: 'other',
1238
+ reason: 'auto memory files are allowed for writing',
1239
+ },
1240
+ };
1241
+ }
1242
+ // .claude/launch.json — desktop preview config (dev server command + port).
1243
+ // The desktop's preview_start MCP tool instructs Thaddeus to create/update
1244
+ // this file as part of the preview workflow. Without this carve-out the
1245
+ // .claude/ DANGEROUS_DIRECTORIES check prompts for it, which in SDK mode
1246
+ // cascades: user clicks "Always allow" → setMode:acceptEdits suggestion
1247
+ // applied → silent downgrade from auto mode. Matches the project-level
1248
+ // .claude/ only (not ~/.claude/) since launch.json is per-project.
1249
+ if (normalizeCaseForComparison(normalizedPath) ===
1250
+ normalizeCaseForComparison(join(getOriginalCwd(), '.claude', 'launch.json'))) {
1251
+ return {
1252
+ behavior: 'allow',
1253
+ updatedInput: input,
1254
+ decisionReason: {
1255
+ type: 'other',
1256
+ reason: 'Preview launch config is allowed for writing',
1257
+ },
1258
+ };
1259
+ }
1260
+ return { behavior: 'passthrough', message: '' };
1261
+ }
1262
+ /**
1263
+ * Check if a path is an internal path that can be read without permission.
1264
+ * Returns a PermissionResult - either 'allow' if matched, or 'passthrough' to continue checking.
1265
+ */
1266
+ export function checkReadableInternalPath(absolutePath, input) {
1267
+ // SECURITY: Normalize path to prevent traversal bypasses via .. segments
1268
+ // This is defense-in-depth; individual helper functions also normalize
1269
+ const normalizedPath = normalize(absolutePath);
1270
+ // Session memory directory
1271
+ if (isSessionMemoryPath(normalizedPath)) {
1272
+ return {
1273
+ behavior: 'allow',
1274
+ updatedInput: input,
1275
+ decisionReason: {
1276
+ type: 'other',
1277
+ reason: 'Session memory files are allowed for reading',
1278
+ },
1279
+ };
1280
+ }
1281
+ // Project directory (for reading past session memories)
1282
+ // Path format: ~/.claude/projects/{sanitized-cwd}/...
1283
+ if (isProjectDirPath(normalizedPath)) {
1284
+ return {
1285
+ behavior: 'allow',
1286
+ updatedInput: input,
1287
+ decisionReason: {
1288
+ type: 'other',
1289
+ reason: 'Project directory files are allowed for reading',
1290
+ },
1291
+ };
1292
+ }
1293
+ // Plan files for current session
1294
+ if (isSessionPlanFile(normalizedPath)) {
1295
+ return {
1296
+ behavior: 'allow',
1297
+ updatedInput: input,
1298
+ decisionReason: {
1299
+ type: 'other',
1300
+ reason: 'Plan files for current session are allowed for reading',
1301
+ },
1302
+ };
1303
+ }
1304
+ // Tool results directory (persisted large outputs)
1305
+ // Use path separator suffix to prevent path traversal (e.g., tool-results-evil/)
1306
+ const toolResultsDir = getToolResultsDir();
1307
+ const toolResultsDirWithSep = toolResultsDir.endsWith(sep)
1308
+ ? toolResultsDir
1309
+ : toolResultsDir + sep;
1310
+ if (normalizedPath === toolResultsDir ||
1311
+ normalizedPath.startsWith(toolResultsDirWithSep)) {
1312
+ return {
1313
+ behavior: 'allow',
1314
+ updatedInput: input,
1315
+ decisionReason: {
1316
+ type: 'other',
1317
+ reason: 'Tool result files are allowed for reading',
1318
+ },
1319
+ };
1320
+ }
1321
+ // Scratchpad directory for current session
1322
+ if (isScratchpadPath(normalizedPath)) {
1323
+ return {
1324
+ behavior: 'allow',
1325
+ updatedInput: input,
1326
+ decisionReason: {
1327
+ type: 'other',
1328
+ reason: 'Scratchpad files for current session are allowed for reading',
1329
+ },
1330
+ };
1331
+ }
1332
+ // Project temp directory (/tmp/claude/{sanitized-cwd}/)
1333
+ // Intentionally allows reading files from all sessions in this project, not just the current session.
1334
+ // This enables cross-session file access within the same project's temp space.
1335
+ const projectTempDir = getProjectTempDir();
1336
+ if (normalizedPath.startsWith(projectTempDir)) {
1337
+ return {
1338
+ behavior: 'allow',
1339
+ updatedInput: input,
1340
+ decisionReason: {
1341
+ type: 'other',
1342
+ reason: 'Project temp directory files are allowed for reading',
1343
+ },
1344
+ };
1345
+ }
1346
+ // Agent memory directory (for self-improving agents)
1347
+ if (isAgentMemoryPath(normalizedPath)) {
1348
+ return {
1349
+ behavior: 'allow',
1350
+ updatedInput: input,
1351
+ decisionReason: {
1352
+ type: 'other',
1353
+ reason: 'Agent memory files are allowed for reading',
1354
+ },
1355
+ };
1356
+ }
1357
+ // Memdir directory (persistent memory for cross-session learning)
1358
+ if (isAutoMemPath(normalizedPath)) {
1359
+ return {
1360
+ behavior: 'allow',
1361
+ updatedInput: input,
1362
+ decisionReason: {
1363
+ type: 'other',
1364
+ reason: 'auto memory files are allowed for reading',
1365
+ },
1366
+ };
1367
+ }
1368
+ // Tasks directory (~/.claude/tasks/) for swarm task coordination
1369
+ const tasksDir = join(getClaudeConfigHomeDir(), 'tasks') + sep;
1370
+ if (normalizedPath === tasksDir.slice(0, -1) ||
1371
+ normalizedPath.startsWith(tasksDir)) {
1372
+ return {
1373
+ behavior: 'allow',
1374
+ updatedInput: input,
1375
+ decisionReason: {
1376
+ type: 'other',
1377
+ reason: 'Task files are allowed for reading',
1378
+ },
1379
+ };
1380
+ }
1381
+ // Teams directory (~/.claude/teams/) for swarm coordination
1382
+ const teamsReadDir = join(getClaudeConfigHomeDir(), 'teams') + sep;
1383
+ if (normalizedPath === teamsReadDir.slice(0, -1) ||
1384
+ normalizedPath.startsWith(teamsReadDir)) {
1385
+ return {
1386
+ behavior: 'allow',
1387
+ updatedInput: input,
1388
+ decisionReason: {
1389
+ type: 'other',
1390
+ reason: 'Team files are allowed for reading',
1391
+ },
1392
+ };
1393
+ }
1394
+ // Bundled skill reference files extracted on first invocation.
1395
+ // SECURITY: See getBundledSkillsRoot() — the per-process nonce in the path
1396
+ // is the load-bearing defense; uid/VERSION alone are public knowledge and
1397
+ // squattable. We always write-before-read on invocation, so content under
1398
+ // this subtree is harness-controlled.
1399
+ const bundledSkillsRoot = getBundledSkillsRoot() + sep;
1400
+ if (normalizedPath.startsWith(bundledSkillsRoot)) {
1401
+ return {
1402
+ behavior: 'allow',
1403
+ updatedInput: input,
1404
+ decisionReason: {
1405
+ type: 'other',
1406
+ reason: 'Bundled skill reference files are allowed for reading',
1407
+ },
1408
+ };
1409
+ }
1410
+ return { behavior: 'passthrough', message: '' };
1411
+ }