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,2478 @@
1
+ import { feature } from 'bun:bundle';
2
+ import { Client } from '@modelcontextprotocol/sdk/client/index.js';
3
+ import { SSEClientTransport, } from '@modelcontextprotocol/sdk/client/sse.js';
4
+ import { StdioClientTransport } from '@modelcontextprotocol/sdk/client/stdio.js';
5
+ import { StreamableHTTPClientTransport, } from '@modelcontextprotocol/sdk/client/streamableHttp.js';
6
+ import { createFetchWithInit, } from '@modelcontextprotocol/sdk/shared/transport.js';
7
+ import { CallToolResultSchema, ElicitRequestSchema, ErrorCode, ListPromptsResultSchema, ListResourcesResultSchema, ListRootsRequestSchema, ListToolsResultSchema, McpError, } from '@modelcontextprotocol/sdk/types.js';
8
+ import mapValues from 'lodash-es/mapValues.js';
9
+ import memoize from 'lodash-es/memoize.js';
10
+ import zipObject from 'lodash-es/zipObject.js';
11
+ import pMap from 'p-map';
12
+ import { getOriginalCwd, getSessionId } from '../../bootstrap/state.js';
13
+ import { getOauthConfig } from '../../constants/oauth.js';
14
+ import { PRODUCT_URL } from '../../constants/product.js';
15
+ import { toolMatchesName, } from '../../Tool.js';
16
+ import { ListMcpResourcesTool } from '../../tools/ListMcpResourcesTool/ListMcpResourcesTool.js';
17
+ import { MCPTool } from '../../tools/MCPTool/MCPTool.js';
18
+ import { createMcpAuthTool } from '../../tools/McpAuthTool/McpAuthTool.js';
19
+ import { ReadMcpResourceTool } from '../../tools/ReadMcpResourceTool/ReadMcpResourceTool.js';
20
+ import { createAbortController } from '../../utils/abortController.js';
21
+ import { count } from '../../utils/array.js';
22
+ import { checkAndRefreshOAuthTokenIfNeeded, getClaudeAIOAuthTokens, handleOAuth401Error, } from '../../utils/auth.js';
23
+ import { registerCleanup } from '../../utils/cleanupRegistry.js';
24
+ import { detectCodeIndexingFromMcpServerName } from '../../utils/codeIndexing.js';
25
+ import { logForDebugging } from '../../utils/debug.js';
26
+ import { isEnvDefinedFalsy, isEnvTruthy } from '../../utils/envUtils.js';
27
+ import { errorMessage, TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, } from '../../utils/errors.js';
28
+ import { getMCPUserAgent } from '../../utils/http.js';
29
+ import { maybeNotifyIDEConnected } from '../../utils/ide.js';
30
+ import { maybeResizeAndDownsampleImageBuffer } from '../../utils/imageResizer.js';
31
+ import { logMCPDebug, logMCPError } from '../../utils/log.js';
32
+ import { getBinaryBlobSavedMessage, getFormatDescription, getLargeOutputInstructions, persistBinaryContent, } from '../../utils/mcpOutputStorage.js';
33
+ import { getContentSizeEstimate, mcpContentNeedsTruncation, truncateMcpContentIfNeeded, } from '../../utils/mcpValidation.js';
34
+ import { WebSocketTransport } from '../../utils/mcpWebSocketTransport.js';
35
+ import { memoizeWithLRU } from '../../utils/memoize.js';
36
+ import { getWebSocketTLSOptions } from '../../utils/mtls.js';
37
+ import { getProxyFetchOptions, getWebSocketProxyAgent, getWebSocketProxyUrl, } from '../../utils/proxy.js';
38
+ import { recursivelySanitizeUnicode } from '../../utils/sanitization.js';
39
+ import { getSessionIngressAuthToken } from '../../utils/sessionIngressAuth.js';
40
+ import { subprocessEnv } from '../../utils/subprocessEnv.js';
41
+ import { isPersistError, persistToolResult, } from '../../utils/toolResultStorage.js';
42
+ import { logEvent, } from '../analytics/index.js';
43
+ import { runElicitationHooks, runElicitationResultHooks, } from './elicitationHandler.js';
44
+ import { buildMcpToolName } from './mcpStringUtils.js';
45
+ import { normalizeNameForMCP } from './normalization.js';
46
+ import { getLoggingSafeMcpBaseUrl } from './utils.js';
47
+ /* eslint-disable @typescript-eslint/no-require-imports */
48
+ const fetchMcpSkillsForClient = feature('MCP_SKILLS')
49
+ ? require('../../skills/mcpSkills.js').fetchMcpSkillsForClient
50
+ : null;
51
+ import { UnauthorizedError } from '@modelcontextprotocol/sdk/client/auth.js';
52
+ /* eslint-enable @typescript-eslint/no-require-imports */
53
+ import { classifyMcpToolForCollapse } from '../../tools/MCPTool/classifyForCollapse.js';
54
+ import { clearKeychainCache } from '../../utils/secureStorage/macOsKeychainHelpers.js';
55
+ import { sleep } from '../../utils/sleep.js';
56
+ import { ClaudeAuthProvider, hasMcpDiscoveryButNoToken, wrapFetchWithStepUpDetection, } from './auth.js';
57
+ import { markClaudeAiMcpConnected } from './claudeai.js';
58
+ import { getAllMcpConfigs, isMcpServerDisabled } from './config.js';
59
+ import { getMcpServerHeaders } from './headersHelper.js';
60
+ import { SdkControlClientTransport } from './SdkControlTransport.js';
61
+ /**
62
+ * Custom error class to indicate that an MCP tool call failed due to
63
+ * authentication issues (e.g., expired OAuth token returning 401).
64
+ * This error should be caught at the tool execution layer to update
65
+ * the client's status to 'needs-auth'.
66
+ */
67
+ export class McpAuthError extends Error {
68
+ serverName;
69
+ constructor(serverName, message) {
70
+ super(message);
71
+ this.name = 'McpAuthError';
72
+ this.serverName = serverName;
73
+ }
74
+ }
75
+ /**
76
+ * Thrown when an MCP session has expired and the connection cache has been cleared.
77
+ * The caller should get a fresh client via ensureConnectedClient and retry.
78
+ */
79
+ class McpSessionExpiredError extends Error {
80
+ constructor(serverName) {
81
+ super(`MCP server "${serverName}" session expired`);
82
+ this.name = 'McpSessionExpiredError';
83
+ }
84
+ }
85
+ /**
86
+ * Thrown when an MCP tool returns `isError: true`. Carries the result's `_meta`
87
+ * so SDK consumers can still receive it — per the MCP spec, `_meta` is on the
88
+ * base Result type and is valid on error results.
89
+ */
90
+ export class McpToolCallError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS extends TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS {
91
+ mcpMeta;
92
+ constructor(message, telemetryMessage, mcpMeta) {
93
+ super(message, telemetryMessage);
94
+ this.mcpMeta = mcpMeta;
95
+ this.name = 'McpToolCallError';
96
+ }
97
+ }
98
+ /**
99
+ * Detects whether an error is an MCP "Session not found" error (HTTP 404 + JSON-RPC code -32001).
100
+ * Per the MCP spec, servers return 404 when a session ID is no longer valid.
101
+ * We check both signals to avoid false positives from generic 404s (wrong URL, server gone, etc.).
102
+ */
103
+ export function isMcpSessionExpiredError(error) {
104
+ const httpStatus = 'code' in error ? error.code : undefined;
105
+ if (httpStatus !== 404) {
106
+ return false;
107
+ }
108
+ // The SDK embeds the response body text in the error message.
109
+ // MCP servers return: {"error":{"code":-32001,"message":"Session not found"},...}
110
+ // Check for the JSON-RPC error code to distinguish from generic web server 404s.
111
+ return (error.message.includes('"code":-32001') ||
112
+ error.message.includes('"code": -32001'));
113
+ }
114
+ /**
115
+ * Default timeout for MCP tool calls (effectively infinite - ~27.8 hours).
116
+ */
117
+ const DEFAULT_MCP_TOOL_TIMEOUT_MS = 100_000_000;
118
+ /**
119
+ * Cap on MCP tool descriptions and server instructions sent to the model.
120
+ * OpenAPI-generated MCP servers have been observed dumping 15-60KB of endpoint
121
+ * docs into tool.description; this caps the p95 tail without losing the intent.
122
+ */
123
+ const MAX_MCP_DESCRIPTION_LENGTH = 2048;
124
+ /**
125
+ * Gets the timeout for MCP tool calls in milliseconds.
126
+ * Uses MCP_TOOL_TIMEOUT environment variable if set, otherwise defaults to ~27.8 hours.
127
+ */
128
+ function getMcpToolTimeoutMs() {
129
+ return (parseInt(process.env.MCP_TOOL_TIMEOUT || '', 10) ||
130
+ DEFAULT_MCP_TOOL_TIMEOUT_MS);
131
+ }
132
+ import { isClaudeInChromeMCPServer } from '../../utils/claudeInChrome/common.js';
133
+ // Lazy: toolRendering.tsx pulls React/ink; only needed when Claude-in-Chrome MCP server is connected
134
+ /* eslint-disable @typescript-eslint/no-require-imports */
135
+ const claudeInChromeToolRendering = () => require('../../utils/claudeInChrome/toolRendering.js');
136
+ // Lazy: wrapper.tsx → hostAdapter.ts → executor.ts pulls both native modules
137
+ // (@ant/computer-use-input + @ant/computer-use-swift). Runtime-gated by
138
+ // GrowthBook thaddeus_malort_pedway (see gates.ts).
139
+ const computerUseWrapper = feature('CHICAGO_MCP')
140
+ ? () => require('../../utils/computerUse/wrapper.js')
141
+ : undefined;
142
+ const isComputerUseMCPServer = feature('CHICAGO_MCP')
143
+ ? require('../../utils/computerUse/common.js').isComputerUseMCPServer
144
+ : undefined;
145
+ import { mkdir, readFile, unlink, writeFile } from 'fs/promises';
146
+ import { dirname, join } from 'path';
147
+ import { getClaudeConfigHomeDir } from '../../utils/envUtils.js';
148
+ /* eslint-enable @typescript-eslint/no-require-imports */
149
+ import { jsonParse, jsonStringify } from '../../utils/slowOperations.js';
150
+ const MCP_AUTH_CACHE_TTL_MS = 15 * 60 * 1000; // 15 min
151
+ function getMcpAuthCachePath() {
152
+ return join(getClaudeConfigHomeDir(), 'mcp-needs-auth-cache.json');
153
+ }
154
+ // Memoized so N concurrent isMcpAuthCached() calls during batched connection
155
+ // share a single file read instead of N reads of the same file. Invalidated
156
+ // on write (setMcpAuthCacheEntry) and clear (clearMcpAuthCache). Not using
157
+ // lodash memoize because we need to null out the cache, not delete by key.
158
+ let authCachePromise = null;
159
+ function getMcpAuthCache() {
160
+ if (!authCachePromise) {
161
+ authCachePromise = readFile(getMcpAuthCachePath(), 'utf-8')
162
+ .then(data => jsonParse(data))
163
+ .catch(() => ({}));
164
+ }
165
+ return authCachePromise;
166
+ }
167
+ async function isMcpAuthCached(serverId) {
168
+ const cache = await getMcpAuthCache();
169
+ const entry = cache[serverId];
170
+ if (!entry) {
171
+ return false;
172
+ }
173
+ return Date.now() - entry.timestamp < MCP_AUTH_CACHE_TTL_MS;
174
+ }
175
+ // Serialize cache writes through a promise chain to prevent concurrent
176
+ // read-modify-write races when multiple servers return 401 in the same batch
177
+ let writeChain = Promise.resolve();
178
+ function setMcpAuthCacheEntry(serverId) {
179
+ writeChain = writeChain
180
+ .then(async () => {
181
+ const cache = await getMcpAuthCache();
182
+ cache[serverId] = { timestamp: Date.now() };
183
+ const cachePath = getMcpAuthCachePath();
184
+ await mkdir(dirname(cachePath), { recursive: true });
185
+ await writeFile(cachePath, jsonStringify(cache));
186
+ // Invalidate the read cache so subsequent reads see the new entry.
187
+ // Safe because writeChain serializes writes: the next write's
188
+ // getMcpAuthCache() call will re-read the file with this entry present.
189
+ authCachePromise = null;
190
+ })
191
+ .catch(() => {
192
+ // Best-effort cache write
193
+ });
194
+ }
195
+ export function clearMcpAuthCache() {
196
+ authCachePromise = null;
197
+ void unlink(getMcpAuthCachePath()).catch(() => {
198
+ // Cache file may not exist
199
+ });
200
+ }
201
+ /**
202
+ * Spread-ready analytics field for the server's base URL. Calls
203
+ * getLoggingSafeMcpBaseUrl once (not twice like the inline ternary it replaces).
204
+ * Typed as AnalyticsMetadata since the URL is query-stripped and safe to log.
205
+ */
206
+ function mcpBaseUrlAnalytics(serverRef) {
207
+ const url = getLoggingSafeMcpBaseUrl(serverRef);
208
+ return url
209
+ ? {
210
+ mcpServerBaseUrl: url,
211
+ }
212
+ : {};
213
+ }
214
+ /**
215
+ * Shared handler for sse/http/claudeai-proxy auth failures during connect:
216
+ * emits thaddeus_mcp_server_needs_auth, caches the needs-auth entry, and returns
217
+ * the needs-auth connection result.
218
+ */
219
+ function handleRemoteAuthFailure(name, serverRef, transportType) {
220
+ logEvent('thaddeus_mcp_server_needs_auth', {
221
+ transportType: transportType,
222
+ ...mcpBaseUrlAnalytics(serverRef),
223
+ });
224
+ const label = {
225
+ sse: 'SSE',
226
+ http: 'HTTP',
227
+ 'claudeai-proxy': 'Delphi Labs proxy',
228
+ };
229
+ logMCPDebug(name, `Authentication required for ${label[transportType]} server`);
230
+ setMcpAuthCacheEntry(name);
231
+ return { name, type: 'needs-auth', config: serverRef };
232
+ }
233
+ /**
234
+ * Fetch wrapper for claude.ai proxy connections. Attaches the OAuth bearer
235
+ * token and retries once on 401 via handleOAuth401Error (force-refresh).
236
+ *
237
+ * The Anthropic API path has this retry (withRetry.ts, grove.ts) to handle
238
+ * memoize-cache staleness and clock drift. Without the same here, a single
239
+ * stale token mass-401s every claude.ai connector and sticks them all in the
240
+ * 15-min needs-auth cache.
241
+ */
242
+ export function createClaudeAiProxyFetch(innerFetch) {
243
+ return async (url, init) => {
244
+ const doRequest = async () => {
245
+ await checkAndRefreshOAuthTokenIfNeeded();
246
+ const currentTokens = getClaudeAIOAuthTokens();
247
+ if (!currentTokens) {
248
+ throw new Error('No claude.ai OAuth token available');
249
+ }
250
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
251
+ const headers = new Headers(init?.headers);
252
+ headers.set('Authorization', `Bearer ${currentTokens.accessToken}`);
253
+ const response = await innerFetch(url, { ...init, headers });
254
+ // Return the exact token that was sent. Reading getClaudeAIOAuthTokens()
255
+ // again after the request is wrong under concurrent 401s: another
256
+ // connector's handleOAuth401Error clears the memoize cache, so we'd read
257
+ // the NEW token from keychain, pass it to handleOAuth401Error, which
258
+ // finds same-as-keychain → returns false → skips retry. Same pattern as
259
+ // bridgeApi.ts withOAuthRetry (token passed as fn param).
260
+ return { response, sentToken: currentTokens.accessToken };
261
+ };
262
+ const { response, sentToken } = await doRequest();
263
+ if (response.status !== 401) {
264
+ return response;
265
+ }
266
+ // handleOAuth401Error returns true only if the token actually changed
267
+ // (keychain had a newer one, or force-refresh succeeded). Gate retry on
268
+ // that — otherwise we double round-trip time for every connector whose
269
+ // downstream service genuinely needs auth (the common case: 30+ servers
270
+ // with "MCP server requires authentication but no OAuth token configured").
271
+ const tokenChanged = await handleOAuth401Error(sentToken).catch(() => false);
272
+ logEvent('thaddeus_mcp_claudeai_proxy_401', {
273
+ tokenChanged: tokenChanged,
274
+ });
275
+ if (!tokenChanged) {
276
+ // ELOCKED contention: another connector may have won the lockfile and refreshed — check if token changed underneath us
277
+ const now = getClaudeAIOAuthTokens()?.accessToken;
278
+ if (!now || now === sentToken) {
279
+ return response;
280
+ }
281
+ }
282
+ try {
283
+ return (await doRequest()).response;
284
+ }
285
+ catch {
286
+ // Retry itself failed (network error). Return the original 401 so the
287
+ // outer handler can classify it.
288
+ return response;
289
+ }
290
+ };
291
+ }
292
+ /**
293
+ * Create a ws.WebSocket client with the MCP protocol.
294
+ * Bun's ws shim types lack the 3-arg constructor (url, protocols, options)
295
+ * that the real ws package supports, so we cast the constructor here.
296
+ */
297
+ async function createNodeWsClient(url, options) {
298
+ const wsModule = await import('ws');
299
+ const WS = wsModule.default;
300
+ return new WS(url, ['mcp'], options);
301
+ }
302
+ const IMAGE_MIME_TYPES = new Set([
303
+ 'image/jpeg',
304
+ 'image/png',
305
+ 'image/gif',
306
+ 'image/webp',
307
+ ]);
308
+ function getConnectionTimeoutMs() {
309
+ return parseInt(process.env.MCP_TIMEOUT || '', 10) || 30000;
310
+ }
311
+ /**
312
+ * Default timeout for individual MCP requests (auth, tool calls, etc.)
313
+ */
314
+ const MCP_REQUEST_TIMEOUT_MS = 60000;
315
+ /**
316
+ * MCP Streamable HTTP spec requires clients to advertise acceptance of both
317
+ * JSON and SSE on every POST. Servers that enforce this strictly reject
318
+ * requests without it (HTTP 406).
319
+ * https://modelcontextprotocol.io/specification/2025-03-26/basic/transports#sending-messages-to-the-server
320
+ */
321
+ const MCP_STREAMABLE_HTTP_ACCEPT = 'application/json, text/event-stream';
322
+ /**
323
+ * Wraps a fetch function to apply a fresh timeout signal to each request.
324
+ * This avoids the bug where a single AbortSignal.timeout() created at connection
325
+ * time becomes stale after 60 seconds, causing all subsequent requests to fail
326
+ * immediately with "The operation timed out." Uses a 60-second timeout.
327
+ *
328
+ * Also ensures the Accept header required by the MCP Streamable HTTP spec is
329
+ * present on POSTs. The MCP SDK sets this inside StreamableHTTPClientTransport.send(),
330
+ * but it is attached to a Headers instance that passes through an object spread here,
331
+ * and some runtimes/agents have been observed dropping it before it reaches the wire.
332
+ * See https://github.com/anthropics/claude-agent-sdk-typescript/issues/202.
333
+ * Normalizing here (the last wrapper before fetch()) guarantees it is sent.
334
+ *
335
+ * GET requests are excluded from the timeout since, for MCP transports, they are
336
+ * long-lived SSE streams meant to stay open indefinitely. (Auth-related GETs use
337
+ * a separate fetch wrapper with its own timeout in auth.ts.)
338
+ *
339
+ * @param baseFetch - The fetch function to wrap
340
+ */
341
+ export function wrapFetchWithTimeout(baseFetch) {
342
+ return async (url, init) => {
343
+ const method = (init?.method ?? 'GET').toUpperCase();
344
+ // Skip timeout for GET requests - in MCP transports, these are long-lived SSE streams.
345
+ // (OAuth discovery GETs in auth.ts use a separate createAuthFetch() with its own timeout.)
346
+ if (method === 'GET') {
347
+ return baseFetch(url, init);
348
+ }
349
+ // Normalize headers and guarantee the Streamable-HTTP Accept value. new Headers()
350
+ // accepts HeadersInit | undefined and copies from plain objects, tuple arrays,
351
+ // and existing Headers instances — so whatever shape the SDK handed us, the
352
+ // Accept value survives the spread below as an own property of a concrete object.
353
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
354
+ const headers = new Headers(init?.headers);
355
+ if (!headers.has('accept')) {
356
+ headers.set('accept', MCP_STREAMABLE_HTTP_ACCEPT);
357
+ }
358
+ // Use setTimeout instead of AbortSignal.timeout() so we can clearTimeout on
359
+ // completion. AbortSignal.timeout's internal timer is only released when the
360
+ // signal is GC'd, which in Bun is lazy — ~2.4KB of native memory per request
361
+ // lingers for the full 60s even when the request completes in milliseconds.
362
+ const controller = new AbortController();
363
+ const timer = setTimeout(c => c.abort(new DOMException('The operation timed out.', 'TimeoutError')), MCP_REQUEST_TIMEOUT_MS, controller);
364
+ timer.unref?.();
365
+ const parentSignal = init?.signal;
366
+ const abort = () => controller.abort(parentSignal?.reason);
367
+ parentSignal?.addEventListener('abort', abort);
368
+ if (parentSignal?.aborted) {
369
+ controller.abort(parentSignal.reason);
370
+ }
371
+ const cleanup = () => {
372
+ clearTimeout(timer);
373
+ parentSignal?.removeEventListener('abort', abort);
374
+ };
375
+ try {
376
+ const response = await baseFetch(url, {
377
+ ...init,
378
+ headers,
379
+ signal: controller.signal,
380
+ });
381
+ cleanup();
382
+ return response;
383
+ }
384
+ catch (error) {
385
+ cleanup();
386
+ throw error;
387
+ }
388
+ };
389
+ }
390
+ export function getMcpServerConnectionBatchSize() {
391
+ return parseInt(process.env.MCP_SERVER_CONNECTION_BATCH_SIZE || '', 10) || 3;
392
+ }
393
+ function getRemoteMcpServerConnectionBatchSize() {
394
+ return (parseInt(process.env.MCP_REMOTE_SERVER_CONNECTION_BATCH_SIZE || '', 10) ||
395
+ 20);
396
+ }
397
+ function isLocalMcpServer(config) {
398
+ return !config.type || config.type === 'stdio' || config.type === 'sdk';
399
+ }
400
+ // For the IDE MCP servers, we only include specific tools
401
+ const ALLOWED_IDE_TOOLS = ['mcp__ide__executeCode', 'mcp__ide__getDiagnostics'];
402
+ function isIncludedMcpTool(tool) {
403
+ return (!tool.name.startsWith('mcp__ide__') || ALLOWED_IDE_TOOLS.includes(tool.name));
404
+ }
405
+ /**
406
+ * Generates the cache key for a server connection
407
+ * @param name Server name
408
+ * @param serverRef Server configuration
409
+ * @returns Cache key string
410
+ */
411
+ export function getServerCacheKey(name, serverRef) {
412
+ return `${name}-${jsonStringify(serverRef)}`;
413
+ }
414
+ /**
415
+ * TODO (ollie): The memoization here increases complexity by a lot, and im not sure it really improves performance
416
+ * Attempts to connect to a single MCP server
417
+ * @param name Server name
418
+ * @param serverRef Scoped server configuration
419
+ * @returns A wrapped client (either connected or failed)
420
+ */
421
+ export const connectToServer = memoize(async (name, serverRef, serverStats) => {
422
+ const connectStartTime = Date.now();
423
+ let inProcessServer;
424
+ try {
425
+ let transport;
426
+ // If we have the session ingress JWT, we will connect via the session ingress rather than
427
+ // to remote MCP's directly.
428
+ const sessionIngressToken = getSessionIngressAuthToken();
429
+ if (serverRef.type === 'sse') {
430
+ // Create an auth provider for this server
431
+ const authProvider = new ClaudeAuthProvider(name, serverRef);
432
+ // Get combined headers (static + dynamic)
433
+ const combinedHeaders = await getMcpServerHeaders(name, serverRef);
434
+ // Use the auth provider with SSEClientTransport
435
+ const transportOptions = {
436
+ authProvider,
437
+ // Use fresh timeout per request to avoid stale AbortSignal bug.
438
+ // Step-up detection wraps innermost so the 403 is seen before the
439
+ // SDK's handler calls auth() → tokens().
440
+ fetch: wrapFetchWithTimeout(wrapFetchWithStepUpDetection(createFetchWithInit(), authProvider)),
441
+ requestInit: {
442
+ headers: {
443
+ 'User-Agent': getMCPUserAgent(),
444
+ ...combinedHeaders,
445
+ },
446
+ },
447
+ };
448
+ // IMPORTANT: Always set eventSourceInit with a fetch that does NOT use the
449
+ // timeout wrapper. The EventSource connection is long-lived (stays open indefinitely
450
+ // to receive server-sent events), so applying a 60-second timeout would kill it.
451
+ // The timeout is only meant for individual API requests (POST, auth refresh), not
452
+ // the persistent SSE stream.
453
+ transportOptions.eventSourceInit = {
454
+ fetch: async (url, init) => {
455
+ // Get auth headers from the auth provider
456
+ const authHeaders = {};
457
+ const tokens = await authProvider.tokens();
458
+ if (tokens) {
459
+ authHeaders.Authorization = `Bearer ${tokens.access_token}`;
460
+ }
461
+ const proxyOptions = getProxyFetchOptions();
462
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
463
+ return fetch(url, {
464
+ ...init,
465
+ ...proxyOptions,
466
+ headers: {
467
+ 'User-Agent': getMCPUserAgent(),
468
+ ...authHeaders,
469
+ ...init?.headers,
470
+ ...combinedHeaders,
471
+ Accept: 'text/event-stream',
472
+ },
473
+ });
474
+ },
475
+ };
476
+ transport = new SSEClientTransport(new URL(serverRef.url), transportOptions);
477
+ logMCPDebug(name, `SSE transport initialized, awaiting connection`);
478
+ }
479
+ else if (serverRef.type === 'sse-ide') {
480
+ logMCPDebug(name, `Setting up SSE-IDE transport to ${serverRef.url}`);
481
+ // IDE servers don't need authentication
482
+ // TODO: Use the auth token provided in the lockfile
483
+ const proxyOptions = getProxyFetchOptions();
484
+ const transportOptions = proxyOptions.dispatcher
485
+ ? {
486
+ eventSourceInit: {
487
+ fetch: async (url, init) => {
488
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
489
+ return fetch(url, {
490
+ ...init,
491
+ ...proxyOptions,
492
+ headers: {
493
+ 'User-Agent': getMCPUserAgent(),
494
+ ...init?.headers,
495
+ },
496
+ });
497
+ },
498
+ },
499
+ }
500
+ : {};
501
+ transport = new SSEClientTransport(new URL(serverRef.url), Object.keys(transportOptions).length > 0
502
+ ? transportOptions
503
+ : undefined);
504
+ }
505
+ else if (serverRef.type === 'ws-ide') {
506
+ const tlsOptions = getWebSocketTLSOptions();
507
+ const wsHeaders = {
508
+ 'User-Agent': getMCPUserAgent(),
509
+ ...(serverRef.authToken && {
510
+ 'X-Claude-Code-Ide-Authorization': serverRef.authToken,
511
+ }),
512
+ };
513
+ let wsClient;
514
+ if (typeof Bun !== 'undefined') {
515
+ // Bun's WebSocket supports headers/proxy/tls options but the DOM typings don't
516
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
517
+ wsClient = new globalThis.WebSocket(serverRef.url, {
518
+ protocols: ['mcp'],
519
+ headers: wsHeaders,
520
+ proxy: getWebSocketProxyUrl(serverRef.url),
521
+ tls: tlsOptions || undefined,
522
+ });
523
+ }
524
+ else {
525
+ wsClient = await createNodeWsClient(serverRef.url, {
526
+ headers: wsHeaders,
527
+ agent: getWebSocketProxyAgent(serverRef.url),
528
+ ...(tlsOptions || {}),
529
+ });
530
+ }
531
+ transport = new WebSocketTransport(wsClient);
532
+ }
533
+ else if (serverRef.type === 'ws') {
534
+ logMCPDebug(name, `Initializing WebSocket transport to ${serverRef.url}`);
535
+ const combinedHeaders = await getMcpServerHeaders(name, serverRef);
536
+ const tlsOptions = getWebSocketTLSOptions();
537
+ const wsHeaders = {
538
+ 'User-Agent': getMCPUserAgent(),
539
+ ...(sessionIngressToken && {
540
+ Authorization: `Bearer ${sessionIngressToken}`,
541
+ }),
542
+ ...combinedHeaders,
543
+ };
544
+ // Redact sensitive headers before logging
545
+ const wsHeadersForLogging = mapValues(wsHeaders, (value, key) => key.toLowerCase() === 'authorization' ? '[REDACTED]' : value);
546
+ logMCPDebug(name, `WebSocket transport options: ${jsonStringify({
547
+ url: serverRef.url,
548
+ headers: wsHeadersForLogging,
549
+ hasSessionAuth: !!sessionIngressToken,
550
+ })}`);
551
+ let wsClient;
552
+ if (typeof Bun !== 'undefined') {
553
+ // Bun's WebSocket supports headers/proxy/tls options but the DOM typings don't
554
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
555
+ wsClient = new globalThis.WebSocket(serverRef.url, {
556
+ protocols: ['mcp'],
557
+ headers: wsHeaders,
558
+ proxy: getWebSocketProxyUrl(serverRef.url),
559
+ tls: tlsOptions || undefined,
560
+ });
561
+ }
562
+ else {
563
+ wsClient = await createNodeWsClient(serverRef.url, {
564
+ headers: wsHeaders,
565
+ agent: getWebSocketProxyAgent(serverRef.url),
566
+ ...(tlsOptions || {}),
567
+ });
568
+ }
569
+ transport = new WebSocketTransport(wsClient);
570
+ }
571
+ else if (serverRef.type === 'http') {
572
+ logMCPDebug(name, `Initializing HTTP transport to ${serverRef.url}`);
573
+ logMCPDebug(name, `Node version: ${process.version}, Platform: ${process.platform}`);
574
+ logMCPDebug(name, `Environment: ${jsonStringify({
575
+ NODE_OPTIONS: process.env.NODE_OPTIONS || 'not set',
576
+ UV_THREADPOOL_SIZE: process.env.UV_THREADPOOL_SIZE || 'default',
577
+ HTTP_PROXY: process.env.HTTP_PROXY || 'not set',
578
+ HTTPS_PROXY: process.env.HTTPS_PROXY || 'not set',
579
+ NO_PROXY: process.env.NO_PROXY || 'not set',
580
+ })}`);
581
+ // Create an auth provider for this server
582
+ const authProvider = new ClaudeAuthProvider(name, serverRef);
583
+ // Get combined headers (static + dynamic)
584
+ const combinedHeaders = await getMcpServerHeaders(name, serverRef);
585
+ // Check if this server has stored OAuth tokens. If so, the SDK's
586
+ // authProvider will set Authorization — don't override with the
587
+ // session ingress token (SDK merges requestInit AFTER authProvider).
588
+ // CCR proxy URLs (ccr_shttp_mcp) have no stored OAuth, so they still
589
+ // get the ingress token. See PR #24454 discussion.
590
+ const hasOAuthTokens = !!(await authProvider.tokens());
591
+ // Use the auth provider with StreamableHTTPClientTransport
592
+ const proxyOptions = getProxyFetchOptions();
593
+ logMCPDebug(name, `Proxy options: ${proxyOptions.dispatcher ? 'custom dispatcher' : 'default'}`);
594
+ const transportOptions = {
595
+ authProvider,
596
+ // Use fresh timeout per request to avoid stale AbortSignal bug.
597
+ // Step-up detection wraps innermost so the 403 is seen before the
598
+ // SDK's handler calls auth() → tokens().
599
+ fetch: wrapFetchWithTimeout(wrapFetchWithStepUpDetection(createFetchWithInit(), authProvider)),
600
+ requestInit: {
601
+ ...proxyOptions,
602
+ headers: {
603
+ 'User-Agent': getMCPUserAgent(),
604
+ ...(sessionIngressToken &&
605
+ !hasOAuthTokens && {
606
+ Authorization: `Bearer ${sessionIngressToken}`,
607
+ }),
608
+ ...combinedHeaders,
609
+ },
610
+ },
611
+ };
612
+ // Redact sensitive headers before logging
613
+ const headersForLogging = transportOptions.requestInit?.headers
614
+ ? mapValues(transportOptions.requestInit.headers, (value, key) => key.toLowerCase() === 'authorization' ? '[REDACTED]' : value)
615
+ : undefined;
616
+ logMCPDebug(name, `HTTP transport options: ${jsonStringify({
617
+ url: serverRef.url,
618
+ headers: headersForLogging,
619
+ hasAuthProvider: !!authProvider,
620
+ timeoutMs: MCP_REQUEST_TIMEOUT_MS,
621
+ })}`);
622
+ transport = new StreamableHTTPClientTransport(new URL(serverRef.url), transportOptions);
623
+ logMCPDebug(name, `HTTP transport created successfully`);
624
+ }
625
+ else if (serverRef.type === 'sdk') {
626
+ throw new Error('SDK servers should be handled in print.ts');
627
+ }
628
+ else if (serverRef.type === 'claudeai-proxy') {
629
+ logMCPDebug(name, `Initializing claude.ai proxy transport for server ${serverRef.id}`);
630
+ const tokens = getClaudeAIOAuthTokens();
631
+ if (!tokens) {
632
+ throw new Error('No claude.ai OAuth token found');
633
+ }
634
+ const oauthConfig = getOauthConfig();
635
+ const proxyUrl = `${oauthConfig.MCP_PROXY_URL}${oauthConfig.MCP_PROXY_PATH.replace('{server_id}', serverRef.id)}`;
636
+ logMCPDebug(name, `Using claude.ai proxy at ${proxyUrl}`);
637
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
638
+ const fetchWithAuth = createClaudeAiProxyFetch(globalThis.fetch);
639
+ const proxyOptions = getProxyFetchOptions();
640
+ const transportOptions = {
641
+ // Wrap fetchWithAuth with fresh timeout per request
642
+ fetch: wrapFetchWithTimeout(fetchWithAuth),
643
+ requestInit: {
644
+ ...proxyOptions,
645
+ headers: {
646
+ 'User-Agent': getMCPUserAgent(),
647
+ 'X-Mcp-Client-Session-Id': getSessionId(),
648
+ },
649
+ },
650
+ };
651
+ transport = new StreamableHTTPClientTransport(new URL(proxyUrl), transportOptions);
652
+ logMCPDebug(name, `claude.ai proxy transport created successfully`);
653
+ }
654
+ else if ((serverRef.type === 'stdio' || !serverRef.type) &&
655
+ isClaudeInChromeMCPServer(name)) {
656
+ // Run the Chrome MCP server in-process to avoid spawning a ~325 MB subprocess
657
+ const { createChromeContext } = await import('../../utils/claudeInChrome/mcpServer.js');
658
+ const { createClaudeForChromeMcpServer } = await import('@ant/claude-for-chrome-mcp');
659
+ const { createLinkedTransportPair } = await import('./InProcessTransport.js');
660
+ const context = createChromeContext(serverRef.env);
661
+ inProcessServer = createClaudeForChromeMcpServer(context);
662
+ const [clientTransport, serverTransport] = createLinkedTransportPair();
663
+ await inProcessServer.connect(serverTransport);
664
+ transport = clientTransport;
665
+ logMCPDebug(name, `In-process Chrome MCP server started`);
666
+ }
667
+ else if (feature('CHICAGO_MCP') &&
668
+ (serverRef.type === 'stdio' || !serverRef.type) &&
669
+ isComputerUseMCPServer(name)) {
670
+ // Run the Computer Use MCP server in-process — same rationale as
671
+ // Chrome above. The package's CallTool handler is a stub; real
672
+ // dispatch goes through wrapper.tsx's .call() override.
673
+ const { createComputerUseMcpServerForCli } = await import('../../utils/computerUse/mcpServer.js');
674
+ const { createLinkedTransportPair } = await import('./InProcessTransport.js');
675
+ inProcessServer = await createComputerUseMcpServerForCli();
676
+ const [clientTransport, serverTransport] = createLinkedTransportPair();
677
+ await inProcessServer.connect(serverTransport);
678
+ transport = clientTransport;
679
+ logMCPDebug(name, `In-process Computer Use MCP server started`);
680
+ }
681
+ else if (serverRef.type === 'stdio' || !serverRef.type) {
682
+ const finalCommand = process.env.THADDEUS_SHELL_PREFIX || serverRef.command;
683
+ const finalArgs = process.env.THADDEUS_SHELL_PREFIX
684
+ ? [[serverRef.command, ...serverRef.args].join(' ')]
685
+ : serverRef.args;
686
+ transport = new StdioClientTransport({
687
+ command: finalCommand,
688
+ args: finalArgs,
689
+ env: {
690
+ ...subprocessEnv(),
691
+ ...serverRef.env,
692
+ },
693
+ stderr: 'pipe', // prevents error output from the MCP server from printing to the UI
694
+ });
695
+ }
696
+ else {
697
+ throw new Error(`Unsupported server type: ${serverRef.type}`);
698
+ }
699
+ // Set up stderr logging for stdio transport before connecting in case there are any stderr
700
+ // outputs emitted during the connection start (this can be useful for debugging failed connections).
701
+ // Store handler reference for cleanup to prevent memory leaks
702
+ let stderrHandler;
703
+ let stderrOutput = '';
704
+ if (serverRef.type === 'stdio' || !serverRef.type) {
705
+ const stdioTransport = transport;
706
+ if (stdioTransport.stderr) {
707
+ stderrHandler = (data) => {
708
+ // Cap stderr accumulation to prevent unbounded memory growth
709
+ if (stderrOutput.length < 64 * 1024 * 1024) {
710
+ try {
711
+ stderrOutput += data.toString();
712
+ }
713
+ catch {
714
+ // Ignore errors from exceeding max string length
715
+ }
716
+ }
717
+ };
718
+ stdioTransport.stderr.on('data', stderrHandler);
719
+ }
720
+ }
721
+ const client = new Client({
722
+ name: 'thaddeus',
723
+ title: 'Thaddeus',
724
+ version: MACRO.VERSION ?? 'unknown',
725
+ description: "Delphi Labs' agentic coding tool",
726
+ websiteUrl: PRODUCT_URL,
727
+ }, {
728
+ capabilities: {
729
+ roots: {},
730
+ // Empty object declares the capability. Sending {form:{},url:{}}
731
+ // breaks Java MCP SDK servers (Spring AI) whose Elicitation class
732
+ // has zero fields and fails on unknown properties.
733
+ elicitation: {},
734
+ },
735
+ });
736
+ // Add debug logging for client events if available
737
+ if (serverRef.type === 'http') {
738
+ logMCPDebug(name, `Client created, setting up request handler`);
739
+ }
740
+ client.setRequestHandler(ListRootsRequestSchema, async () => {
741
+ logMCPDebug(name, `Received ListRoots request from server`);
742
+ return {
743
+ roots: [
744
+ {
745
+ uri: `file://${getOriginalCwd()}`,
746
+ },
747
+ ],
748
+ };
749
+ });
750
+ // Add a timeout to connection attempts to prevent tests from hanging indefinitely
751
+ logMCPDebug(name, `Starting connection with timeout of ${getConnectionTimeoutMs()}ms`);
752
+ // For HTTP transport, try a basic connectivity test first
753
+ if (serverRef.type === 'http') {
754
+ logMCPDebug(name, `Testing basic HTTP connectivity to ${serverRef.url}`);
755
+ try {
756
+ const testUrl = new URL(serverRef.url);
757
+ logMCPDebug(name, `Parsed URL: host=${testUrl.hostname}, port=${testUrl.port || 'default'}, protocol=${testUrl.protocol}`);
758
+ // Log DNS resolution attempt
759
+ if (testUrl.hostname === '127.0.0.1' ||
760
+ testUrl.hostname === 'localhost') {
761
+ logMCPDebug(name, `Using loopback address: ${testUrl.hostname}`);
762
+ }
763
+ }
764
+ catch (urlError) {
765
+ logMCPDebug(name, `Failed to parse URL: ${urlError}`);
766
+ }
767
+ }
768
+ const connectPromise = client.connect(transport);
769
+ const timeoutPromise = new Promise((_, reject) => {
770
+ const timeoutId = setTimeout(() => {
771
+ const elapsed = Date.now() - connectStartTime;
772
+ logMCPDebug(name, `Connection timeout triggered after ${elapsed}ms (limit: ${getConnectionTimeoutMs()}ms)`);
773
+ if (inProcessServer) {
774
+ inProcessServer.close().catch(() => { });
775
+ }
776
+ transport.close().catch(() => { });
777
+ reject(new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(`MCP server "${name}" connection timed out after ${getConnectionTimeoutMs()}ms`, 'MCP connection timeout'));
778
+ }, getConnectionTimeoutMs());
779
+ // Clean up timeout if connect resolves or rejects
780
+ connectPromise.then(() => {
781
+ clearTimeout(timeoutId);
782
+ }, _error => {
783
+ clearTimeout(timeoutId);
784
+ });
785
+ });
786
+ try {
787
+ await Promise.race([connectPromise, timeoutPromise]);
788
+ if (stderrOutput) {
789
+ logMCPError(name, `Server stderr: ${stderrOutput}`);
790
+ stderrOutput = ''; // Release accumulated string to prevent memory growth
791
+ }
792
+ const elapsed = Date.now() - connectStartTime;
793
+ logMCPDebug(name, `Successfully connected (transport: ${serverRef.type || 'stdio'}) in ${elapsed}ms`);
794
+ }
795
+ catch (error) {
796
+ const elapsed = Date.now() - connectStartTime;
797
+ // SSE-specific error logging
798
+ if (serverRef.type === 'sse' && error instanceof Error) {
799
+ logMCPDebug(name, `SSE Connection failed after ${elapsed}ms: ${jsonStringify({
800
+ url: serverRef.url,
801
+ error: error.message,
802
+ errorType: error.constructor.name,
803
+ stack: error.stack,
804
+ })}`);
805
+ logMCPError(name, error);
806
+ if (error instanceof UnauthorizedError) {
807
+ return handleRemoteAuthFailure(name, serverRef, 'sse');
808
+ }
809
+ }
810
+ else if (serverRef.type === 'http' && error instanceof Error) {
811
+ const errorObj = error;
812
+ logMCPDebug(name, `HTTP Connection failed after ${elapsed}ms: ${error.message} (code: ${errorObj.code || 'none'}, errno: ${errorObj.errno || 'none'})`);
813
+ logMCPError(name, error);
814
+ if (error instanceof UnauthorizedError) {
815
+ return handleRemoteAuthFailure(name, serverRef, 'http');
816
+ }
817
+ }
818
+ else if (serverRef.type === 'claudeai-proxy' &&
819
+ error instanceof Error) {
820
+ logMCPDebug(name, `claude.ai proxy connection failed after ${elapsed}ms: ${error.message}`);
821
+ logMCPError(name, error);
822
+ // StreamableHTTPError has a `code` property with the HTTP status
823
+ const errorCode = error.code;
824
+ if (errorCode === 401) {
825
+ return handleRemoteAuthFailure(name, serverRef, 'claudeai-proxy');
826
+ }
827
+ }
828
+ else if (serverRef.type === 'sse-ide' ||
829
+ serverRef.type === 'ws-ide') {
830
+ logEvent('thaddeus_mcp_ide_server_connection_failed', {
831
+ connectionDurationMs: elapsed,
832
+ });
833
+ }
834
+ if (inProcessServer) {
835
+ inProcessServer.close().catch(() => { });
836
+ }
837
+ transport.close().catch(() => { });
838
+ if (stderrOutput) {
839
+ logMCPError(name, `Server stderr: ${stderrOutput}`);
840
+ }
841
+ throw error;
842
+ }
843
+ const capabilities = client.getServerCapabilities();
844
+ const serverVersion = client.getServerVersion();
845
+ const rawInstructions = client.getInstructions();
846
+ let instructions = rawInstructions;
847
+ if (rawInstructions &&
848
+ rawInstructions.length > MAX_MCP_DESCRIPTION_LENGTH) {
849
+ instructions =
850
+ rawInstructions.slice(0, MAX_MCP_DESCRIPTION_LENGTH) + '… [truncated]';
851
+ logMCPDebug(name, `Server instructions truncated from ${rawInstructions.length} to ${MAX_MCP_DESCRIPTION_LENGTH} chars`);
852
+ }
853
+ // Log successful connection details
854
+ logMCPDebug(name, `Connection established with capabilities: ${jsonStringify({
855
+ hasTools: !!capabilities?.tools,
856
+ hasPrompts: !!capabilities?.prompts,
857
+ hasResources: !!capabilities?.resources,
858
+ hasResourceSubscribe: !!capabilities?.resources?.subscribe,
859
+ serverVersion: serverVersion || 'unknown',
860
+ })}`);
861
+ logForDebugging(`[MCP] Server "${name}" connected with subscribe=${!!capabilities?.resources?.subscribe}`);
862
+ // Register default elicitation handler that returns cancel during the
863
+ // window before registerElicitationHandler overwrites it in
864
+ // onConnectionAttempt (useManageMCPConnections).
865
+ client.setRequestHandler(ElicitRequestSchema, async (request) => {
866
+ logMCPDebug(name, `Elicitation request received during initialization: ${jsonStringify(request)}`);
867
+ return { action: 'cancel' };
868
+ });
869
+ if (serverRef.type === 'sse-ide' || serverRef.type === 'ws-ide') {
870
+ const ideConnectionDurationMs = Date.now() - connectStartTime;
871
+ logEvent('thaddeus_mcp_ide_server_connection_succeeded', {
872
+ connectionDurationMs: ideConnectionDurationMs,
873
+ serverVersion: serverVersion,
874
+ });
875
+ try {
876
+ void maybeNotifyIDEConnected(client);
877
+ }
878
+ catch (error) {
879
+ logMCPError(name, `Failed to send ide_connected notification: ${error}`);
880
+ }
881
+ }
882
+ // Enhanced connection drop detection and logging for all transport types
883
+ const connectionStartTime = Date.now();
884
+ let hasErrorOccurred = false;
885
+ // Store original handlers
886
+ const originalOnerror = client.onerror;
887
+ const originalOnclose = client.onclose;
888
+ // The SDK's transport calls onerror on connection failures but doesn't call onclose,
889
+ // which CC uses to trigger reconnection. We bridge this gap by tracking consecutive
890
+ // terminal errors and manually closing after MAX_ERRORS_BEFORE_RECONNECT failures.
891
+ let consecutiveConnectionErrors = 0;
892
+ const MAX_ERRORS_BEFORE_RECONNECT = 3;
893
+ // Guard against re-entry: close() aborts in-flight streams which may fire
894
+ // onerror again before the close chain completes.
895
+ let hasTriggeredClose = false;
896
+ // client.close() → transport.close() → transport.onclose → SDK's _onclose():
897
+ // rejects all pending request handlers (so hung callTool() promises fail with
898
+ // McpError -32000 "Connection closed") and then invokes our client.onclose
899
+ // handler below (which clears the memo cache so the next call reconnects).
900
+ // Calling client.onclose?.() directly would only clear the cache — pending
901
+ // tool calls would stay hung.
902
+ const closeTransportAndRejectPending = (reason) => {
903
+ if (hasTriggeredClose)
904
+ return;
905
+ hasTriggeredClose = true;
906
+ logMCPDebug(name, `Closing transport (${reason})`);
907
+ void client.close().catch(e => {
908
+ logMCPDebug(name, `Error during close: ${errorMessage(e)}`);
909
+ });
910
+ };
911
+ const isTerminalConnectionError = (msg) => {
912
+ return (msg.includes('ECONNRESET') ||
913
+ msg.includes('ETIMEDOUT') ||
914
+ msg.includes('EPIPE') ||
915
+ msg.includes('EHOSTUNREACH') ||
916
+ msg.includes('ECONNREFUSED') ||
917
+ msg.includes('Body Timeout Error') ||
918
+ msg.includes('terminated') ||
919
+ // SDK SSE reconnection intermediate errors — may be wrapped around the
920
+ // actual network error, so the substrings above won't match
921
+ msg.includes('SSE stream disconnected') ||
922
+ msg.includes('Failed to reconnect SSE stream'));
923
+ };
924
+ // Enhanced error handler with detailed logging
925
+ client.onerror = (error) => {
926
+ const uptime = Date.now() - connectionStartTime;
927
+ hasErrorOccurred = true;
928
+ const transportType = serverRef.type || 'stdio';
929
+ // Log the connection drop with context
930
+ logMCPDebug(name, `${transportType.toUpperCase()} connection dropped after ${Math.floor(uptime / 1000)}s uptime`);
931
+ // Log specific error details for debugging
932
+ if (error.message) {
933
+ if (error.message.includes('ECONNRESET')) {
934
+ logMCPDebug(name, `Connection reset - server may have crashed or restarted`);
935
+ }
936
+ else if (error.message.includes('ETIMEDOUT')) {
937
+ logMCPDebug(name, `Connection timeout - network issue or server unresponsive`);
938
+ }
939
+ else if (error.message.includes('ECONNREFUSED')) {
940
+ logMCPDebug(name, `Connection refused - server may be down`);
941
+ }
942
+ else if (error.message.includes('EPIPE')) {
943
+ logMCPDebug(name, `Broken pipe - server closed connection unexpectedly`);
944
+ }
945
+ else if (error.message.includes('EHOSTUNREACH')) {
946
+ logMCPDebug(name, `Host unreachable - network connectivity issue`);
947
+ }
948
+ else if (error.message.includes('ESRCH')) {
949
+ logMCPDebug(name, `Process not found - stdio server process terminated`);
950
+ }
951
+ else if (error.message.includes('spawn')) {
952
+ logMCPDebug(name, `Failed to spawn process - check command and permissions`);
953
+ }
954
+ else {
955
+ logMCPDebug(name, `Connection error: ${error.message}`);
956
+ }
957
+ }
958
+ // For HTTP transports, detect session expiry (404 + JSON-RPC -32001)
959
+ // and close the transport so pending tool calls reject and the next
960
+ // call reconnects with a fresh session ID.
961
+ if ((transportType === 'http' || transportType === 'claudeai-proxy') &&
962
+ isMcpSessionExpiredError(error)) {
963
+ logMCPDebug(name, `MCP session expired (server returned 404 with session-not-found), triggering reconnection`);
964
+ closeTransportAndRejectPending('session expired');
965
+ if (originalOnerror) {
966
+ originalOnerror(error);
967
+ }
968
+ return;
969
+ }
970
+ // For remote transports (SSE/HTTP), track terminal connection errors
971
+ // and trigger reconnection via close if we see repeated failures.
972
+ if (transportType === 'sse' ||
973
+ transportType === 'http' ||
974
+ transportType === 'claudeai-proxy') {
975
+ // The SDK's StreamableHTTP transport fires this after exhausting its
976
+ // own SSE reconnect attempts (default maxRetries: 2) — but it never
977
+ // calls onclose, so pending callTool() promises hang indefinitely.
978
+ // This is the definitive "transport gave up" signal.
979
+ if (error.message.includes('Maximum reconnection attempts')) {
980
+ closeTransportAndRejectPending('SSE reconnection exhausted');
981
+ if (originalOnerror) {
982
+ originalOnerror(error);
983
+ }
984
+ return;
985
+ }
986
+ if (isTerminalConnectionError(error.message)) {
987
+ consecutiveConnectionErrors++;
988
+ logMCPDebug(name, `Terminal connection error ${consecutiveConnectionErrors}/${MAX_ERRORS_BEFORE_RECONNECT}`);
989
+ if (consecutiveConnectionErrors >= MAX_ERRORS_BEFORE_RECONNECT) {
990
+ consecutiveConnectionErrors = 0;
991
+ closeTransportAndRejectPending('max consecutive terminal errors');
992
+ }
993
+ }
994
+ else {
995
+ // Non-terminal error (e.g., transient issue), reset counter
996
+ consecutiveConnectionErrors = 0;
997
+ }
998
+ }
999
+ // Call original handler
1000
+ if (originalOnerror) {
1001
+ originalOnerror(error);
1002
+ }
1003
+ };
1004
+ // Enhanced close handler with connection drop context
1005
+ client.onclose = () => {
1006
+ const uptime = Date.now() - connectionStartTime;
1007
+ const transportType = serverRef.type ?? 'unknown';
1008
+ logMCPDebug(name, `${transportType.toUpperCase()} connection closed after ${Math.floor(uptime / 1000)}s (${hasErrorOccurred ? 'with errors' : 'cleanly'})`);
1009
+ // Clear the memoization cache so next operation reconnects
1010
+ const key = getServerCacheKey(name, serverRef);
1011
+ // Also clear fetch caches (keyed by server name). Reconnection
1012
+ // creates a new connection object; without clearing, the next
1013
+ // fetch would return stale tools/resources from the old connection.
1014
+ fetchToolsForClient.cache.delete(name);
1015
+ fetchResourcesForClient.cache.delete(name);
1016
+ fetchCommandsForClient.cache.delete(name);
1017
+ if (feature('MCP_SKILLS')) {
1018
+ fetchMcpSkillsForClient.cache.delete(name);
1019
+ }
1020
+ connectToServer.cache.delete(key);
1021
+ logMCPDebug(name, `Cleared connection cache for reconnection`);
1022
+ if (originalOnclose) {
1023
+ originalOnclose();
1024
+ }
1025
+ };
1026
+ const cleanup = async () => {
1027
+ // In-process servers (e.g. Chrome MCP) don't have child processes or stderr
1028
+ if (inProcessServer) {
1029
+ try {
1030
+ await inProcessServer.close();
1031
+ }
1032
+ catch (error) {
1033
+ logMCPDebug(name, `Error closing in-process server: ${error}`);
1034
+ }
1035
+ try {
1036
+ await client.close();
1037
+ }
1038
+ catch (error) {
1039
+ logMCPDebug(name, `Error closing client: ${error}`);
1040
+ }
1041
+ return;
1042
+ }
1043
+ // Remove stderr event listener to prevent memory leaks
1044
+ if (stderrHandler && (serverRef.type === 'stdio' || !serverRef.type)) {
1045
+ const stdioTransport = transport;
1046
+ stdioTransport.stderr?.off('data', stderrHandler);
1047
+ }
1048
+ // For stdio transports, explicitly terminate the child process with proper signals
1049
+ // NOTE: StdioClientTransport.close() only sends an abort signal, but many MCP servers
1050
+ // (especially Docker containers) need explicit SIGINT/SIGTERM signals to trigger graceful shutdown
1051
+ if (serverRef.type === 'stdio') {
1052
+ try {
1053
+ const stdioTransport = transport;
1054
+ const childPid = stdioTransport.pid;
1055
+ if (childPid) {
1056
+ logMCPDebug(name, 'Sending SIGINT to MCP server process');
1057
+ // First try SIGINT (like Ctrl+C)
1058
+ try {
1059
+ process.kill(childPid, 'SIGINT');
1060
+ }
1061
+ catch (error) {
1062
+ logMCPDebug(name, `Error sending SIGINT: ${error}`);
1063
+ return;
1064
+ }
1065
+ // Wait for graceful shutdown with rapid escalation (total 500ms to keep CLI responsive)
1066
+ await new Promise(async (resolve) => {
1067
+ let resolved = false;
1068
+ // Set up a timer to check if process still exists
1069
+ const checkInterval = setInterval(() => {
1070
+ try {
1071
+ // process.kill(pid, 0) checks if process exists without killing it
1072
+ process.kill(childPid, 0);
1073
+ }
1074
+ catch {
1075
+ // Process no longer exists
1076
+ if (!resolved) {
1077
+ resolved = true;
1078
+ clearInterval(checkInterval);
1079
+ clearTimeout(failsafeTimeout);
1080
+ logMCPDebug(name, 'MCP server process exited cleanly');
1081
+ resolve();
1082
+ }
1083
+ }
1084
+ }, 50);
1085
+ // Absolute failsafe: clear interval after 600ms no matter what
1086
+ const failsafeTimeout = setTimeout(() => {
1087
+ if (!resolved) {
1088
+ resolved = true;
1089
+ clearInterval(checkInterval);
1090
+ logMCPDebug(name, 'Cleanup timeout reached, stopping process monitoring');
1091
+ resolve();
1092
+ }
1093
+ }, 600);
1094
+ try {
1095
+ // Wait 100ms for SIGINT to work (usually much faster)
1096
+ await sleep(100);
1097
+ if (!resolved) {
1098
+ // Check if process still exists
1099
+ try {
1100
+ process.kill(childPid, 0);
1101
+ // Process still exists, SIGINT failed, try SIGTERM
1102
+ logMCPDebug(name, 'SIGINT failed, sending SIGTERM to MCP server process');
1103
+ try {
1104
+ process.kill(childPid, 'SIGTERM');
1105
+ }
1106
+ catch (termError) {
1107
+ logMCPDebug(name, `Error sending SIGTERM: ${termError}`);
1108
+ resolved = true;
1109
+ clearInterval(checkInterval);
1110
+ clearTimeout(failsafeTimeout);
1111
+ resolve();
1112
+ return;
1113
+ }
1114
+ }
1115
+ catch {
1116
+ // Process already exited
1117
+ resolved = true;
1118
+ clearInterval(checkInterval);
1119
+ clearTimeout(failsafeTimeout);
1120
+ resolve();
1121
+ return;
1122
+ }
1123
+ // Wait 400ms for SIGTERM to work (slower than SIGINT, often used for cleanup)
1124
+ await sleep(400);
1125
+ if (!resolved) {
1126
+ // Check if process still exists
1127
+ try {
1128
+ process.kill(childPid, 0);
1129
+ // Process still exists, SIGTERM failed, force kill with SIGKILL
1130
+ logMCPDebug(name, 'SIGTERM failed, sending SIGKILL to MCP server process');
1131
+ try {
1132
+ process.kill(childPid, 'SIGKILL');
1133
+ }
1134
+ catch (killError) {
1135
+ logMCPDebug(name, `Error sending SIGKILL: ${killError}`);
1136
+ }
1137
+ }
1138
+ catch {
1139
+ // Process already exited
1140
+ resolved = true;
1141
+ clearInterval(checkInterval);
1142
+ clearTimeout(failsafeTimeout);
1143
+ resolve();
1144
+ }
1145
+ }
1146
+ }
1147
+ // Final timeout - always resolve after 500ms max (total cleanup time)
1148
+ if (!resolved) {
1149
+ resolved = true;
1150
+ clearInterval(checkInterval);
1151
+ clearTimeout(failsafeTimeout);
1152
+ resolve();
1153
+ }
1154
+ }
1155
+ catch {
1156
+ // Handle any errors in the escalation sequence
1157
+ if (!resolved) {
1158
+ resolved = true;
1159
+ clearInterval(checkInterval);
1160
+ clearTimeout(failsafeTimeout);
1161
+ resolve();
1162
+ }
1163
+ }
1164
+ });
1165
+ }
1166
+ }
1167
+ catch (processError) {
1168
+ logMCPDebug(name, `Error terminating process: ${processError}`);
1169
+ }
1170
+ }
1171
+ // Close the client connection (which also closes the transport)
1172
+ try {
1173
+ await client.close();
1174
+ }
1175
+ catch (error) {
1176
+ logMCPDebug(name, `Error closing client: ${error}`);
1177
+ }
1178
+ };
1179
+ // Register cleanup for all transport types - even network transports might need cleanup
1180
+ // This ensures all MCP servers get properly terminated, not just stdio ones
1181
+ const cleanupUnregister = registerCleanup(cleanup);
1182
+ // Create the wrapped cleanup that includes unregistering
1183
+ const wrappedCleanup = async () => {
1184
+ cleanupUnregister?.();
1185
+ await cleanup();
1186
+ };
1187
+ const connectionDurationMs = Date.now() - connectStartTime;
1188
+ logEvent('thaddeus_mcp_server_connection_succeeded', {
1189
+ connectionDurationMs,
1190
+ transportType: (serverRef.type ??
1191
+ 'stdio'),
1192
+ totalServers: serverStats?.totalServers,
1193
+ stdioCount: serverStats?.stdioCount,
1194
+ sseCount: serverStats?.sseCount,
1195
+ httpCount: serverStats?.httpCount,
1196
+ sseIdeCount: serverStats?.sseIdeCount,
1197
+ wsIdeCount: serverStats?.wsIdeCount,
1198
+ ...mcpBaseUrlAnalytics(serverRef),
1199
+ });
1200
+ return {
1201
+ name,
1202
+ client,
1203
+ type: 'connected',
1204
+ capabilities: capabilities ?? {},
1205
+ serverInfo: serverVersion,
1206
+ instructions,
1207
+ config: serverRef,
1208
+ cleanup: wrappedCleanup,
1209
+ };
1210
+ }
1211
+ catch (error) {
1212
+ const connectionDurationMs = Date.now() - connectStartTime;
1213
+ logEvent('thaddeus_mcp_server_connection_failed', {
1214
+ connectionDurationMs,
1215
+ totalServers: serverStats?.totalServers || 1,
1216
+ stdioCount: serverStats?.stdioCount || (serverRef.type === 'stdio' ? 1 : 0),
1217
+ sseCount: serverStats?.sseCount || (serverRef.type === 'sse' ? 1 : 0),
1218
+ httpCount: serverStats?.httpCount || (serverRef.type === 'http' ? 1 : 0),
1219
+ sseIdeCount: serverStats?.sseIdeCount || (serverRef.type === 'sse-ide' ? 1 : 0),
1220
+ wsIdeCount: serverStats?.wsIdeCount || (serverRef.type === 'ws-ide' ? 1 : 0),
1221
+ transportType: (serverRef.type ??
1222
+ 'stdio'),
1223
+ ...mcpBaseUrlAnalytics(serverRef),
1224
+ });
1225
+ logMCPDebug(name, `Connection failed after ${connectionDurationMs}ms: ${errorMessage(error)}`);
1226
+ logMCPError(name, `Connection failed: ${errorMessage(error)}`);
1227
+ if (inProcessServer) {
1228
+ inProcessServer.close().catch(() => { });
1229
+ }
1230
+ return {
1231
+ name,
1232
+ type: 'failed',
1233
+ config: serverRef,
1234
+ error: errorMessage(error),
1235
+ };
1236
+ }
1237
+ }, getServerCacheKey);
1238
+ /**
1239
+ * Clears the memoize cache for a specific server
1240
+ * @param name Server name
1241
+ * @param serverRef Server configuration
1242
+ */
1243
+ export async function clearServerCache(name, serverRef) {
1244
+ const key = getServerCacheKey(name, serverRef);
1245
+ try {
1246
+ const wrappedClient = await connectToServer(name, serverRef);
1247
+ if (wrappedClient.type === 'connected') {
1248
+ await wrappedClient.cleanup();
1249
+ }
1250
+ }
1251
+ catch {
1252
+ // Ignore errors - server might have failed to connect
1253
+ }
1254
+ // Clear from cache (both connection and fetch caches so reconnect
1255
+ // fetches fresh tools/resources/commands instead of stale ones)
1256
+ connectToServer.cache.delete(key);
1257
+ fetchToolsForClient.cache.delete(name);
1258
+ fetchResourcesForClient.cache.delete(name);
1259
+ fetchCommandsForClient.cache.delete(name);
1260
+ if (feature('MCP_SKILLS')) {
1261
+ fetchMcpSkillsForClient.cache.delete(name);
1262
+ }
1263
+ }
1264
+ /**
1265
+ * Ensures a valid connected client for an MCP server.
1266
+ * For most server types, uses the memoization cache if available, or reconnects
1267
+ * if the cache was cleared (e.g., after onclose). This ensures tool/resource
1268
+ * calls always use a valid connection.
1269
+ *
1270
+ * SDK MCP servers run in-process and are handled separately via setupSdkMcpClients,
1271
+ * so they are returned as-is without going through connectToServer.
1272
+ *
1273
+ * @param client The connected MCP server client
1274
+ * @returns Connected MCP server client (same or reconnected)
1275
+ * @throws Error if server cannot be connected
1276
+ */
1277
+ export async function ensureConnectedClient(client) {
1278
+ // SDK MCP servers run in-process and are handled separately via setupSdkMcpClients
1279
+ if (client.config.type === 'sdk') {
1280
+ return client;
1281
+ }
1282
+ const connectedClient = await connectToServer(client.name, client.config);
1283
+ if (connectedClient.type !== 'connected') {
1284
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(`MCP server "${client.name}" is not connected`, 'MCP server not connected');
1285
+ }
1286
+ return connectedClient;
1287
+ }
1288
+ /**
1289
+ * Compares two MCP server configurations to determine if they are equivalent.
1290
+ * Used to detect when a server needs to be reconnected due to config changes.
1291
+ */
1292
+ export function areMcpConfigsEqual(a, b) {
1293
+ // Quick type check first
1294
+ if (a.type !== b.type)
1295
+ return false;
1296
+ // Compare by serializing - this handles all config variations
1297
+ // We exclude 'scope' from comparison since it's metadata, not connection config
1298
+ const { scope: _scopeA, ...configA } = a;
1299
+ const { scope: _scopeB, ...configB } = b;
1300
+ return jsonStringify(configA) === jsonStringify(configB);
1301
+ }
1302
+ // Max cache size for fetch* caches. Keyed by server name (stable across
1303
+ // reconnects), bounded to prevent unbounded growth with many MCP servers.
1304
+ const MCP_FETCH_CACHE_SIZE = 20;
1305
+ /**
1306
+ * Encode MCP tool input for the auto-mode security classifier.
1307
+ * Exported so the auto-mode eval scripts can mirror production encoding
1308
+ * for `mcp__*` tool stubs without duplicating this logic.
1309
+ */
1310
+ export function mcpToolInputToAutoClassifierInput(input, toolName) {
1311
+ const keys = Object.keys(input);
1312
+ return keys.length > 0
1313
+ ? keys.map(k => `${k}=${String(input[k])}`).join(' ')
1314
+ : toolName;
1315
+ }
1316
+ export const fetchToolsForClient = memoizeWithLRU(async (client) => {
1317
+ if (client.type !== 'connected')
1318
+ return [];
1319
+ try {
1320
+ if (!client.capabilities?.tools) {
1321
+ return [];
1322
+ }
1323
+ const result = (await client.client.request({ method: 'tools/list' }, ListToolsResultSchema));
1324
+ // Sanitize tool data from MCP server
1325
+ const toolsToProcess = recursivelySanitizeUnicode(result.tools);
1326
+ // Check if we should skip the mcp__ prefix for SDK MCP servers
1327
+ const skipPrefix = client.config.type === 'sdk' &&
1328
+ isEnvTruthy(process.env.CLAUDE_AGENT_SDK_MCP_NO_PREFIX);
1329
+ // Convert MCP tools to our Tool format
1330
+ return toolsToProcess
1331
+ .map((tool) => {
1332
+ const fullyQualifiedName = buildMcpToolName(client.name, tool.name);
1333
+ return {
1334
+ ...MCPTool,
1335
+ // In skip-prefix mode, use the original name for model invocation so MCP tools
1336
+ // can override builtins by name. mcpInfo is used for permission checking.
1337
+ name: skipPrefix ? tool.name : fullyQualifiedName,
1338
+ mcpInfo: { serverName: client.name, toolName: tool.name },
1339
+ isMcp: true,
1340
+ // Collapse whitespace: _meta is open to external MCP servers, and
1341
+ // a newline here would inject orphan lines into the deferred-tool
1342
+ // list (formatDeferredToolLine joins on '\n').
1343
+ searchHint: typeof tool._meta?.['anthropic/searchHint'] === 'string'
1344
+ ? tool._meta['anthropic/searchHint']
1345
+ .replace(/\s+/g, ' ')
1346
+ .trim() || undefined
1347
+ : undefined,
1348
+ alwaysLoad: tool._meta?.['anthropic/alwaysLoad'] === true,
1349
+ async description() {
1350
+ return tool.description ?? '';
1351
+ },
1352
+ async prompt() {
1353
+ const desc = tool.description ?? '';
1354
+ return desc.length > MAX_MCP_DESCRIPTION_LENGTH
1355
+ ? desc.slice(0, MAX_MCP_DESCRIPTION_LENGTH) + '… [truncated]'
1356
+ : desc;
1357
+ },
1358
+ isConcurrencySafe() {
1359
+ return tool.annotations?.readOnlyHint ?? false;
1360
+ },
1361
+ isReadOnly() {
1362
+ return tool.annotations?.readOnlyHint ?? false;
1363
+ },
1364
+ toAutoClassifierInput(input) {
1365
+ return mcpToolInputToAutoClassifierInput(input, tool.name);
1366
+ },
1367
+ isDestructive() {
1368
+ return tool.annotations?.destructiveHint ?? false;
1369
+ },
1370
+ isOpenWorld() {
1371
+ return tool.annotations?.openWorldHint ?? false;
1372
+ },
1373
+ isSearchOrReadCommand() {
1374
+ return classifyMcpToolForCollapse(client.name, tool.name);
1375
+ },
1376
+ inputJSONSchema: tool.inputSchema,
1377
+ async checkPermissions() {
1378
+ return {
1379
+ behavior: 'passthrough',
1380
+ message: 'MCPTool requires permission.',
1381
+ suggestions: [
1382
+ {
1383
+ type: 'addRules',
1384
+ rules: [
1385
+ {
1386
+ toolName: fullyQualifiedName,
1387
+ ruleContent: undefined,
1388
+ },
1389
+ ],
1390
+ behavior: 'allow',
1391
+ destination: 'localSettings',
1392
+ },
1393
+ ],
1394
+ };
1395
+ },
1396
+ async call(args, context, _canUseTool, parentMessage, onProgress) {
1397
+ const toolUseId = extractToolUseId(parentMessage);
1398
+ const meta = toolUseId
1399
+ ? { 'claudecode/toolUseId': toolUseId }
1400
+ : {};
1401
+ // Emit progress when tool starts
1402
+ if (onProgress && toolUseId) {
1403
+ onProgress({
1404
+ toolUseID: toolUseId,
1405
+ data: {
1406
+ type: 'mcp_progress',
1407
+ status: 'started',
1408
+ serverName: client.name,
1409
+ toolName: tool.name,
1410
+ },
1411
+ });
1412
+ }
1413
+ const startTime = Date.now();
1414
+ const MAX_SESSION_RETRIES = 1;
1415
+ for (let attempt = 0;; attempt++) {
1416
+ try {
1417
+ const connectedClient = await ensureConnectedClient(client);
1418
+ const mcpResult = await callMCPToolWithUrlElicitationRetry({
1419
+ client: connectedClient,
1420
+ clientConnection: client,
1421
+ tool: tool.name,
1422
+ args,
1423
+ meta,
1424
+ signal: context.abortController.signal,
1425
+ setAppState: context.setAppState,
1426
+ onProgress: onProgress && toolUseId
1427
+ ? progressData => {
1428
+ onProgress({
1429
+ toolUseID: toolUseId,
1430
+ data: progressData,
1431
+ });
1432
+ }
1433
+ : undefined,
1434
+ handleElicitation: context.handleElicitation,
1435
+ });
1436
+ // Emit progress when tool completes successfully
1437
+ if (onProgress && toolUseId) {
1438
+ onProgress({
1439
+ toolUseID: toolUseId,
1440
+ data: {
1441
+ type: 'mcp_progress',
1442
+ status: 'completed',
1443
+ serverName: client.name,
1444
+ toolName: tool.name,
1445
+ elapsedTimeMs: Date.now() - startTime,
1446
+ },
1447
+ });
1448
+ }
1449
+ return {
1450
+ data: mcpResult.content,
1451
+ ...((mcpResult._meta || mcpResult.structuredContent) && {
1452
+ mcpMeta: {
1453
+ ...(mcpResult._meta && {
1454
+ _meta: mcpResult._meta,
1455
+ }),
1456
+ ...(mcpResult.structuredContent && {
1457
+ structuredContent: mcpResult.structuredContent,
1458
+ }),
1459
+ },
1460
+ }),
1461
+ };
1462
+ }
1463
+ catch (error) {
1464
+ // Session expired — the connection cache has been
1465
+ // cleared, so retry with a fresh client.
1466
+ if (error instanceof McpSessionExpiredError &&
1467
+ attempt < MAX_SESSION_RETRIES) {
1468
+ logMCPDebug(client.name, `Retrying tool '${tool.name}' after session recovery`);
1469
+ continue;
1470
+ }
1471
+ // Emit progress when tool fails
1472
+ if (onProgress && toolUseId) {
1473
+ onProgress({
1474
+ toolUseID: toolUseId,
1475
+ data: {
1476
+ type: 'mcp_progress',
1477
+ status: 'failed',
1478
+ serverName: client.name,
1479
+ toolName: tool.name,
1480
+ elapsedTimeMs: Date.now() - startTime,
1481
+ },
1482
+ });
1483
+ }
1484
+ // Wrap MCP SDK errors so telemetry gets useful context
1485
+ // instead of just "Error" or "McpError" (the constructor
1486
+ // name). MCP SDK errors are protocol-level messages and
1487
+ // don't contain user file paths or code.
1488
+ if (error instanceof Error &&
1489
+ !(error instanceof
1490
+ TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)) {
1491
+ const name = error.constructor.name;
1492
+ if (name === 'Error') {
1493
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(error.message, error.message.slice(0, 200));
1494
+ }
1495
+ // McpError has a numeric `code` with the JSON-RPC error
1496
+ // code (e.g. -32000 ConnectionClosed, -32001 RequestTimeout)
1497
+ if (name === 'McpError' &&
1498
+ 'code' in error &&
1499
+ typeof error.code === 'number') {
1500
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(error.message, `McpError ${error.code}`);
1501
+ }
1502
+ }
1503
+ throw error;
1504
+ }
1505
+ }
1506
+ },
1507
+ userFacingName() {
1508
+ // Prefer title annotation if available, otherwise use tool name
1509
+ const displayName = tool.annotations?.title || tool.name;
1510
+ return `${client.name} - ${displayName} (MCP)`;
1511
+ },
1512
+ ...(isClaudeInChromeMCPServer(client.name) &&
1513
+ (client.config.type === 'stdio' || !client.config.type)
1514
+ ? claudeInChromeToolRendering().getClaudeInChromeMCPToolOverrides(tool.name)
1515
+ : {}),
1516
+ ...(feature('CHICAGO_MCP') &&
1517
+ (client.config.type === 'stdio' || !client.config.type) &&
1518
+ isComputerUseMCPServer(client.name)
1519
+ ? computerUseWrapper().getComputerUseMCPToolOverrides(tool.name)
1520
+ : {}),
1521
+ };
1522
+ })
1523
+ .filter(isIncludedMcpTool);
1524
+ }
1525
+ catch (error) {
1526
+ logMCPError(client.name, `Failed to fetch tools: ${errorMessage(error)}`);
1527
+ return [];
1528
+ }
1529
+ }, (client) => client.name, MCP_FETCH_CACHE_SIZE);
1530
+ export const fetchResourcesForClient = memoizeWithLRU(async (client) => {
1531
+ if (client.type !== 'connected')
1532
+ return [];
1533
+ try {
1534
+ if (!client.capabilities?.resources) {
1535
+ return [];
1536
+ }
1537
+ const result = await client.client.request({ method: 'resources/list' }, ListResourcesResultSchema);
1538
+ if (!result.resources)
1539
+ return [];
1540
+ // Add server name to each resource
1541
+ return result.resources.map(resource => ({
1542
+ ...resource,
1543
+ server: client.name,
1544
+ }));
1545
+ }
1546
+ catch (error) {
1547
+ logMCPError(client.name, `Failed to fetch resources: ${errorMessage(error)}`);
1548
+ return [];
1549
+ }
1550
+ }, (client) => client.name, MCP_FETCH_CACHE_SIZE);
1551
+ export const fetchCommandsForClient = memoizeWithLRU(async (client) => {
1552
+ if (client.type !== 'connected')
1553
+ return [];
1554
+ try {
1555
+ if (!client.capabilities?.prompts) {
1556
+ return [];
1557
+ }
1558
+ // Request prompts list from client
1559
+ const result = (await client.client.request({ method: 'prompts/list' }, ListPromptsResultSchema));
1560
+ if (!result.prompts)
1561
+ return [];
1562
+ // Sanitize prompt data from MCP server
1563
+ const promptsToProcess = recursivelySanitizeUnicode(result.prompts);
1564
+ // Convert MCP prompts to our Command format
1565
+ return promptsToProcess.map(prompt => {
1566
+ const argNames = Object.values(prompt.arguments ?? {}).map(k => k.name);
1567
+ return {
1568
+ type: 'prompt',
1569
+ name: 'mcp__' + normalizeNameForMCP(client.name) + '__' + prompt.name,
1570
+ description: prompt.description ?? '',
1571
+ hasUserSpecifiedDescription: !!prompt.description,
1572
+ contentLength: 0, // Dynamic MCP content
1573
+ isEnabled: () => true,
1574
+ isHidden: false,
1575
+ isMcp: true,
1576
+ progressMessage: 'running',
1577
+ userFacingName() {
1578
+ // Use prompt.name (programmatic identifier) not prompt.title (display name)
1579
+ // to avoid spaces breaking slash command parsing
1580
+ return `${client.name}:${prompt.name} (MCP)`;
1581
+ },
1582
+ argNames,
1583
+ source: 'mcp',
1584
+ async getPromptForCommand(args) {
1585
+ const argsArray = args.split(' ');
1586
+ try {
1587
+ const connectedClient = await ensureConnectedClient(client);
1588
+ const result = await connectedClient.client.getPrompt({
1589
+ name: prompt.name,
1590
+ arguments: zipObject(argNames, argsArray),
1591
+ });
1592
+ const transformed = await Promise.all(result.messages.map(message => transformResultContent(message.content, connectedClient.name)));
1593
+ return transformed.flat();
1594
+ }
1595
+ catch (error) {
1596
+ logMCPError(client.name, `Error running command '${prompt.name}': ${errorMessage(error)}`);
1597
+ throw error;
1598
+ }
1599
+ },
1600
+ };
1601
+ });
1602
+ }
1603
+ catch (error) {
1604
+ logMCPError(client.name, `Failed to fetch commands: ${errorMessage(error)}`);
1605
+ return [];
1606
+ }
1607
+ }, (client) => client.name, MCP_FETCH_CACHE_SIZE);
1608
+ /**
1609
+ * Call an IDE tool directly as an RPC
1610
+ * @param toolName The name of the tool to call
1611
+ * @param args The arguments to pass to the tool
1612
+ * @param client The IDE client to use for the RPC call
1613
+ * @returns The result of the tool call
1614
+ */
1615
+ export async function callIdeRpc(toolName, args, client) {
1616
+ const result = await callMCPTool({
1617
+ client,
1618
+ tool: toolName,
1619
+ args,
1620
+ signal: createAbortController().signal,
1621
+ });
1622
+ return result.content;
1623
+ }
1624
+ /**
1625
+ * Note: This should not be called by UI components directly, they should use the reconnectMcpServer
1626
+ * function from useManageMcpConnections.
1627
+ * @param name Server name
1628
+ * @param config Server configuration
1629
+ * @returns Object containing the client connection and its resources
1630
+ */
1631
+ export async function reconnectMcpServerImpl(name, config) {
1632
+ try {
1633
+ // Invalidate the keychain cache so we read fresh credentials from disk.
1634
+ // This is necessary when another process (e.g. the VS Code extension host)
1635
+ // has modified stored tokens (cleared auth, saved new OAuth tokens) and then
1636
+ // asks the CLI subprocess to reconnect. Without this, the subprocess would
1637
+ // use stale cached data and never notice the tokens were removed.
1638
+ clearKeychainCache();
1639
+ await clearServerCache(name, config);
1640
+ const client = await connectToServer(name, config);
1641
+ if (client.type !== 'connected') {
1642
+ return {
1643
+ client,
1644
+ tools: [],
1645
+ commands: [],
1646
+ };
1647
+ }
1648
+ if (config.type === 'claudeai-proxy') {
1649
+ markClaudeAiMcpConnected(name);
1650
+ }
1651
+ const supportsResources = !!client.capabilities?.resources;
1652
+ const [tools, mcpCommands, mcpSkills, resources] = await Promise.all([
1653
+ fetchToolsForClient(client),
1654
+ fetchCommandsForClient(client),
1655
+ feature('MCP_SKILLS') && supportsResources
1656
+ ? fetchMcpSkillsForClient(client)
1657
+ : Promise.resolve([]),
1658
+ supportsResources ? fetchResourcesForClient(client) : Promise.resolve([]),
1659
+ ]);
1660
+ const commands = [...mcpCommands, ...mcpSkills];
1661
+ // Check if we need to add resource tools
1662
+ const resourceTools = [];
1663
+ if (supportsResources) {
1664
+ // Only add resource tools if no other server has them
1665
+ const hasResourceTools = [ListMcpResourcesTool, ReadMcpResourceTool].some(tool => tools.some(t => toolMatchesName(t, tool.name)));
1666
+ if (!hasResourceTools) {
1667
+ resourceTools.push(ListMcpResourcesTool, ReadMcpResourceTool);
1668
+ }
1669
+ }
1670
+ return {
1671
+ client,
1672
+ tools: [...tools, ...resourceTools],
1673
+ commands,
1674
+ resources: resources.length > 0 ? resources : undefined,
1675
+ };
1676
+ }
1677
+ catch (error) {
1678
+ // Handle errors gracefully - connection might have closed during fetch
1679
+ logMCPError(name, `Error during reconnection: ${errorMessage(error)}`);
1680
+ // Return with failed status
1681
+ return {
1682
+ client: { name, type: 'failed', config },
1683
+ tools: [],
1684
+ commands: [],
1685
+ };
1686
+ }
1687
+ }
1688
+ // Replaced 2026-03: previous implementation ran fixed-size sequential batches
1689
+ // (await batch 1 fully, then start batch 2). That meant one slow server in
1690
+ // batch N held up ALL servers in batch N+1, even if the other 19 slots were
1691
+ // idle. pMap frees each slot as soon as its server completes, so a single
1692
+ // slow server only occupies one slot instead of blocking an entire batch
1693
+ // boundary. Same concurrency ceiling, same results, better scheduling.
1694
+ async function processBatched(items, concurrency, processor) {
1695
+ await pMap(items, processor, { concurrency });
1696
+ }
1697
+ export async function getMcpToolsCommandsAndResources(onConnectionAttempt, mcpConfigs) {
1698
+ let resourceToolsAdded = false;
1699
+ const allConfigEntries = Object.entries(mcpConfigs ?? (await getAllMcpConfigs()).servers);
1700
+ // Partition into disabled and active entries — disabled servers should
1701
+ // never generate HTTP connections or flow through batch processing
1702
+ const configEntries = [];
1703
+ for (const entry of allConfigEntries) {
1704
+ if (isMcpServerDisabled(entry[0])) {
1705
+ onConnectionAttempt({
1706
+ client: { name: entry[0], type: 'disabled', config: entry[1] },
1707
+ tools: [],
1708
+ commands: [],
1709
+ });
1710
+ }
1711
+ else {
1712
+ configEntries.push(entry);
1713
+ }
1714
+ }
1715
+ // Calculate transport counts for logging
1716
+ const totalServers = configEntries.length;
1717
+ const stdioCount = count(configEntries, ([_, c]) => c.type === 'stdio');
1718
+ const sseCount = count(configEntries, ([_, c]) => c.type === 'sse');
1719
+ const httpCount = count(configEntries, ([_, c]) => c.type === 'http');
1720
+ const sseIdeCount = count(configEntries, ([_, c]) => c.type === 'sse-ide');
1721
+ const wsIdeCount = count(configEntries, ([_, c]) => c.type === 'ws-ide');
1722
+ // Split servers by type: local (stdio/sdk) need lower concurrency due to
1723
+ // process spawning, remote servers can connect with higher concurrency
1724
+ const localServers = configEntries.filter(([_, config]) => isLocalMcpServer(config));
1725
+ const remoteServers = configEntries.filter(([_, config]) => !isLocalMcpServer(config));
1726
+ const serverStats = {
1727
+ totalServers,
1728
+ stdioCount,
1729
+ sseCount,
1730
+ httpCount,
1731
+ sseIdeCount,
1732
+ wsIdeCount,
1733
+ };
1734
+ const processServer = async ([name, config]) => {
1735
+ try {
1736
+ // Check if server is disabled - if so, just add it to state without connecting
1737
+ if (isMcpServerDisabled(name)) {
1738
+ onConnectionAttempt({
1739
+ client: {
1740
+ name,
1741
+ type: 'disabled',
1742
+ config,
1743
+ },
1744
+ tools: [],
1745
+ commands: [],
1746
+ });
1747
+ return;
1748
+ }
1749
+ // Skip connection for servers that recently returned 401 (15min TTL),
1750
+ // or that we have probed before but hold no token for. The second
1751
+ // check closes the gap the TTL leaves open: without it, every 15min
1752
+ // we re-probe servers that cannot succeed until the user runs /mcp.
1753
+ // Each probe is a network round-trip for connect-401 plus OAuth
1754
+ // discovery, and print mode awaits the whole batch (main.tsx:3503).
1755
+ if ((config.type === 'claudeai-proxy' ||
1756
+ config.type === 'http' ||
1757
+ config.type === 'sse') &&
1758
+ ((await isMcpAuthCached(name)) ||
1759
+ ((config.type === 'http' || config.type === 'sse') &&
1760
+ hasMcpDiscoveryButNoToken(name, config)))) {
1761
+ logMCPDebug(name, `Skipping connection (cached needs-auth)`);
1762
+ onConnectionAttempt({
1763
+ client: { name, type: 'needs-auth', config },
1764
+ tools: [createMcpAuthTool(name, config)],
1765
+ commands: [],
1766
+ });
1767
+ return;
1768
+ }
1769
+ const client = await connectToServer(name, config, serverStats);
1770
+ if (client.type !== 'connected') {
1771
+ onConnectionAttempt({
1772
+ client,
1773
+ tools: client.type === 'needs-auth'
1774
+ ? [createMcpAuthTool(name, config)]
1775
+ : [],
1776
+ commands: [],
1777
+ });
1778
+ return;
1779
+ }
1780
+ if (config.type === 'claudeai-proxy') {
1781
+ markClaudeAiMcpConnected(name);
1782
+ }
1783
+ const supportsResources = !!client.capabilities?.resources;
1784
+ const [tools, mcpCommands, mcpSkills, resources] = await Promise.all([
1785
+ fetchToolsForClient(client),
1786
+ fetchCommandsForClient(client),
1787
+ // Discover skills from skill:// resources
1788
+ feature('MCP_SKILLS') && supportsResources
1789
+ ? fetchMcpSkillsForClient(client)
1790
+ : Promise.resolve([]),
1791
+ // Fetch resources if supported
1792
+ supportsResources
1793
+ ? fetchResourcesForClient(client)
1794
+ : Promise.resolve([]),
1795
+ ]);
1796
+ const commands = [...mcpCommands, ...mcpSkills];
1797
+ // If this server resources and we haven't added resource tools yet,
1798
+ // include our resource tools with this client's tools
1799
+ const resourceTools = [];
1800
+ if (supportsResources && !resourceToolsAdded) {
1801
+ resourceToolsAdded = true;
1802
+ resourceTools.push(ListMcpResourcesTool, ReadMcpResourceTool);
1803
+ }
1804
+ onConnectionAttempt({
1805
+ client,
1806
+ tools: [...tools, ...resourceTools],
1807
+ commands,
1808
+ resources: resources.length > 0 ? resources : undefined,
1809
+ });
1810
+ }
1811
+ catch (error) {
1812
+ // Handle errors gracefully - connection might have closed during fetch
1813
+ logMCPError(name, `Error fetching tools/commands/resources: ${errorMessage(error)}`);
1814
+ // Still update with the client but no tools/commands
1815
+ onConnectionAttempt({
1816
+ client: { name, type: 'failed', config },
1817
+ tools: [],
1818
+ commands: [],
1819
+ });
1820
+ }
1821
+ };
1822
+ // Process both groups concurrently, each with their own concurrency limits:
1823
+ // - Local servers (stdio/sdk): lower concurrency to avoid process spawning resource contention
1824
+ // - Remote servers: higher concurrency since they're just network connections
1825
+ await Promise.all([
1826
+ processBatched(localServers, getMcpServerConnectionBatchSize(), processServer),
1827
+ processBatched(remoteServers, getRemoteMcpServerConnectionBatchSize(), processServer),
1828
+ ]);
1829
+ }
1830
+ // Not memoized: called only 2-3 times at startup/reconfig. The inner work
1831
+ // (connectToServer, fetch*ForClient) is already cached. Memoizing here by
1832
+ // mcpConfigs object ref leaked — main.tsx creates fresh config objects each call.
1833
+ export function prefetchAllMcpResources(mcpConfigs) {
1834
+ return new Promise(resolve => {
1835
+ let pendingCount = 0;
1836
+ let completedCount = 0;
1837
+ pendingCount = Object.keys(mcpConfigs).length;
1838
+ if (pendingCount === 0) {
1839
+ void resolve({
1840
+ clients: [],
1841
+ tools: [],
1842
+ commands: [],
1843
+ });
1844
+ return;
1845
+ }
1846
+ const clients = [];
1847
+ const tools = [];
1848
+ const commands = [];
1849
+ getMcpToolsCommandsAndResources(result => {
1850
+ clients.push(result.client);
1851
+ tools.push(...result.tools);
1852
+ commands.push(...result.commands);
1853
+ completedCount++;
1854
+ if (completedCount >= pendingCount) {
1855
+ const commandsMetadataLength = commands.reduce((sum, command) => {
1856
+ const commandMetadataLength = command.name.length +
1857
+ (command.description ?? '').length +
1858
+ (command.argumentHint ?? '').length;
1859
+ return sum + commandMetadataLength;
1860
+ }, 0);
1861
+ logEvent('thaddeus_mcp_tools_commands_loaded', {
1862
+ tools_count: tools.length,
1863
+ commands_count: commands.length,
1864
+ commands_metadata_length: commandsMetadataLength,
1865
+ });
1866
+ void resolve({
1867
+ clients,
1868
+ tools,
1869
+ commands,
1870
+ });
1871
+ }
1872
+ }, mcpConfigs).catch(error => {
1873
+ logMCPError('prefetchAllMcpResources', `Failed to get MCP resources: ${errorMessage(error)}`);
1874
+ // Still resolve with empty results
1875
+ void resolve({
1876
+ clients: [],
1877
+ tools: [],
1878
+ commands: [],
1879
+ });
1880
+ });
1881
+ });
1882
+ }
1883
+ /**
1884
+ * Transform result content from an MCP tool or MCP prompt into message blocks
1885
+ */
1886
+ export async function transformResultContent(resultContent, serverName) {
1887
+ switch (resultContent.type) {
1888
+ case 'text':
1889
+ return [
1890
+ {
1891
+ type: 'text',
1892
+ text: resultContent.text,
1893
+ },
1894
+ ];
1895
+ case 'audio': {
1896
+ const audioData = resultContent;
1897
+ return await persistBlobToTextBlock(Buffer.from(audioData.data, 'base64'), audioData.mimeType, serverName, `[Audio from ${serverName}] `);
1898
+ }
1899
+ case 'image': {
1900
+ // Resize and compress image data, enforcing API dimension limits
1901
+ const imageBuffer = Buffer.from(String(resultContent.data), 'base64');
1902
+ const ext = resultContent.mimeType?.split('/')[1] || 'png';
1903
+ const resized = await maybeResizeAndDownsampleImageBuffer(imageBuffer, imageBuffer.length, ext);
1904
+ return [
1905
+ {
1906
+ type: 'image',
1907
+ source: {
1908
+ data: resized.buffer.toString('base64'),
1909
+ media_type: `image/${resized.mediaType}`,
1910
+ type: 'base64',
1911
+ },
1912
+ },
1913
+ ];
1914
+ }
1915
+ case 'resource': {
1916
+ const resource = resultContent.resource;
1917
+ const prefix = `[Resource from ${serverName} at ${resource.uri}] `;
1918
+ if ('text' in resource) {
1919
+ return [
1920
+ {
1921
+ type: 'text',
1922
+ text: `${prefix}${resource.text}`,
1923
+ },
1924
+ ];
1925
+ }
1926
+ else if ('blob' in resource) {
1927
+ const isImage = IMAGE_MIME_TYPES.has(resource.mimeType ?? '');
1928
+ if (isImage) {
1929
+ // Resize and compress image blob, enforcing API dimension limits
1930
+ const imageBuffer = Buffer.from(resource.blob, 'base64');
1931
+ const ext = resource.mimeType?.split('/')[1] || 'png';
1932
+ const resized = await maybeResizeAndDownsampleImageBuffer(imageBuffer, imageBuffer.length, ext);
1933
+ const content = [];
1934
+ if (prefix) {
1935
+ content.push({
1936
+ type: 'text',
1937
+ text: prefix,
1938
+ });
1939
+ }
1940
+ content.push({
1941
+ type: 'image',
1942
+ source: {
1943
+ data: resized.buffer.toString('base64'),
1944
+ media_type: `image/${resized.mediaType}`,
1945
+ type: 'base64',
1946
+ },
1947
+ });
1948
+ return content;
1949
+ }
1950
+ else {
1951
+ return await persistBlobToTextBlock(Buffer.from(resource.blob, 'base64'), resource.mimeType, serverName, prefix);
1952
+ }
1953
+ }
1954
+ return [];
1955
+ }
1956
+ case 'resource_link': {
1957
+ const resourceLink = resultContent;
1958
+ let text = `[Resource link: ${resourceLink.name}] ${resourceLink.uri}`;
1959
+ if (resourceLink.description) {
1960
+ text += ` (${resourceLink.description})`;
1961
+ }
1962
+ return [
1963
+ {
1964
+ type: 'text',
1965
+ text,
1966
+ },
1967
+ ];
1968
+ }
1969
+ default:
1970
+ return [];
1971
+ }
1972
+ }
1973
+ /**
1974
+ * Decode base64 binary content, write it to disk with the proper extension,
1975
+ * and return a small text block with the file path. Replaces the old behavior
1976
+ * of dumping raw base64 into the context.
1977
+ */
1978
+ async function persistBlobToTextBlock(bytes, mimeType, serverName, sourceDescription) {
1979
+ const persistId = `mcp-${normalizeNameForMCP(serverName)}-blob-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`;
1980
+ const result = await persistBinaryContent(bytes, mimeType, persistId);
1981
+ if ('error' in result) {
1982
+ return [
1983
+ {
1984
+ type: 'text',
1985
+ text: `${sourceDescription}Binary content (${mimeType || 'unknown type'}, ${bytes.length} bytes) could not be saved to disk: ${result.error}`,
1986
+ },
1987
+ ];
1988
+ }
1989
+ return [
1990
+ {
1991
+ type: 'text',
1992
+ text: getBinaryBlobSavedMessage(result.filepath, mimeType, result.size, sourceDescription),
1993
+ },
1994
+ ];
1995
+ }
1996
+ /**
1997
+ * Generates a compact, jq-friendly type signature for a value.
1998
+ * e.g. "{title: string, items: [{id: number, name: string}]}"
1999
+ */
2000
+ export function inferCompactSchema(value, depth = 2) {
2001
+ if (value === null)
2002
+ return 'null';
2003
+ if (Array.isArray(value)) {
2004
+ if (value.length === 0)
2005
+ return '[]';
2006
+ return `[${inferCompactSchema(value[0], depth - 1)}]`;
2007
+ }
2008
+ if (typeof value === 'object') {
2009
+ if (depth <= 0)
2010
+ return '{...}';
2011
+ const entries = Object.entries(value).slice(0, 10);
2012
+ const props = entries.map(([k, v]) => `${k}: ${inferCompactSchema(v, depth - 1)}`);
2013
+ const suffix = Object.keys(value).length > 10 ? ', ...' : '';
2014
+ return `{${props.join(', ')}${suffix}}`;
2015
+ }
2016
+ return typeof value;
2017
+ }
2018
+ export async function transformMCPResult(result, tool, // Tool name for validation (e.g., "search")
2019
+ name) {
2020
+ if (result && typeof result === 'object') {
2021
+ if ('toolResult' in result) {
2022
+ return {
2023
+ content: String(result.toolResult),
2024
+ type: 'toolResult',
2025
+ };
2026
+ }
2027
+ if ('structuredContent' in result &&
2028
+ result.structuredContent !== undefined) {
2029
+ return {
2030
+ content: jsonStringify(result.structuredContent),
2031
+ type: 'structuredContent',
2032
+ schema: inferCompactSchema(result.structuredContent),
2033
+ };
2034
+ }
2035
+ if ('content' in result && Array.isArray(result.content)) {
2036
+ const transformedContent = (await Promise.all(result.content.map(item => transformResultContent(item, name)))).flat();
2037
+ return {
2038
+ content: transformedContent,
2039
+ type: 'contentArray',
2040
+ schema: inferCompactSchema(transformedContent),
2041
+ };
2042
+ }
2043
+ }
2044
+ const errorMessage = `MCP server "${name}" tool "${tool}": unexpected response format`;
2045
+ logMCPError(name, errorMessage);
2046
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(errorMessage, 'MCP tool unexpected response format');
2047
+ }
2048
+ /**
2049
+ * Check if MCP content contains any image blocks.
2050
+ * Used to decide whether to persist to file (images should use truncation instead
2051
+ * to preserve image compression and viewability).
2052
+ */
2053
+ function contentContainsImages(content) {
2054
+ if (!content || typeof content === 'string') {
2055
+ return false;
2056
+ }
2057
+ return content.some(block => block.type === 'image');
2058
+ }
2059
+ export async function processMCPResult(result, tool, // Tool name for validation (e.g., "search")
2060
+ name) {
2061
+ const { content, type, schema } = await transformMCPResult(result, tool, name);
2062
+ // IDE tools are not going to the model directly, so we don't need to
2063
+ // handle large output.
2064
+ if (name === 'ide') {
2065
+ return content;
2066
+ }
2067
+ // Check if content needs truncation (i.e., is too large)
2068
+ if (!(await mcpContentNeedsTruncation(content))) {
2069
+ return content;
2070
+ }
2071
+ const sizeEstimateTokens = getContentSizeEstimate(content);
2072
+ // If large output files feature is disabled, fall back to old truncation behavior
2073
+ if (isEnvDefinedFalsy(process.env.ENABLE_MCP_LARGE_OUTPUT_FILES)) {
2074
+ logEvent('thaddeus_mcp_large_result_handled', {
2075
+ outcome: 'truncated',
2076
+ reason: 'env_disabled',
2077
+ sizeEstimateTokens,
2078
+ });
2079
+ return await truncateMcpContentIfNeeded(content);
2080
+ }
2081
+ // Save large output to file and return instructions for reading it
2082
+ // Content is guaranteed to exist at this point (we checked mcpContentNeedsTruncation)
2083
+ if (!content) {
2084
+ return content;
2085
+ }
2086
+ // If content contains images, fall back to truncation - persisting images as JSON
2087
+ // defeats the image compression logic and makes them non-viewable
2088
+ if (contentContainsImages(content)) {
2089
+ logEvent('thaddeus_mcp_large_result_handled', {
2090
+ outcome: 'truncated',
2091
+ reason: 'contains_images',
2092
+ sizeEstimateTokens,
2093
+ });
2094
+ return await truncateMcpContentIfNeeded(content);
2095
+ }
2096
+ // Generate a unique ID for the persisted file (server__tool-timestamp)
2097
+ const timestamp = Date.now();
2098
+ const persistId = `mcp-${normalizeNameForMCP(name)}-${normalizeNameForMCP(tool)}-${timestamp}`;
2099
+ // Convert to string for persistence (persistToolResult expects string or specific block types)
2100
+ const contentStr = typeof content === 'string' ? content : jsonStringify(content, null, 2);
2101
+ const persistResult = await persistToolResult(contentStr, persistId);
2102
+ if (isPersistError(persistResult)) {
2103
+ // If file save failed, fall back to returning truncated content info
2104
+ const contentLength = contentStr.length;
2105
+ logEvent('thaddeus_mcp_large_result_handled', {
2106
+ outcome: 'truncated',
2107
+ reason: 'persist_failed',
2108
+ sizeEstimateTokens,
2109
+ });
2110
+ return `Error: result (${contentLength.toLocaleString()} characters) exceeds maximum allowed tokens. Failed to save output to file: ${persistResult.error}. If this MCP server provides pagination or filtering tools, use them to retrieve specific portions of the data.`;
2111
+ }
2112
+ logEvent('thaddeus_mcp_large_result_handled', {
2113
+ outcome: 'persisted',
2114
+ reason: 'file_saved',
2115
+ sizeEstimateTokens,
2116
+ persistedSizeChars: persistResult.originalSize,
2117
+ });
2118
+ const formatDescription = getFormatDescription(type, schema);
2119
+ return getLargeOutputInstructions(persistResult.filepath, persistResult.originalSize, formatDescription);
2120
+ }
2121
+ /** @internal Exported for testing. */
2122
+ export async function callMCPToolWithUrlElicitationRetry({ client: connectedClient, clientConnection, tool, args, meta, signal, setAppState, onProgress, callToolFn = callMCPTool, handleElicitation, }) {
2123
+ const MAX_URL_ELICITATION_RETRIES = 3;
2124
+ for (let attempt = 0;; attempt++) {
2125
+ try {
2126
+ return await callToolFn({
2127
+ client: connectedClient,
2128
+ tool,
2129
+ args,
2130
+ meta,
2131
+ signal,
2132
+ onProgress,
2133
+ });
2134
+ }
2135
+ catch (error) {
2136
+ // The MCP SDK's Protocol creates plain McpError (not UrlElicitationRequiredError)
2137
+ // for error responses, so we check the error code instead of instanceof.
2138
+ if (!(error instanceof McpError) ||
2139
+ error.code !== ErrorCode.UrlElicitationRequired) {
2140
+ throw error;
2141
+ }
2142
+ // Limit the number of URL elicitation retries
2143
+ if (attempt >= MAX_URL_ELICITATION_RETRIES) {
2144
+ throw error;
2145
+ }
2146
+ const errorData = error.data;
2147
+ const rawElicitations = errorData != null &&
2148
+ typeof errorData === 'object' &&
2149
+ 'elicitations' in errorData &&
2150
+ Array.isArray(errorData.elicitations)
2151
+ ? errorData.elicitations
2152
+ : [];
2153
+ // Validate each element has the required fields for ElicitRequestURLParams
2154
+ const elicitations = rawElicitations.filter((e) => {
2155
+ if (e == null || typeof e !== 'object')
2156
+ return false;
2157
+ const obj = e;
2158
+ return (obj.mode === 'url' &&
2159
+ typeof obj.url === 'string' &&
2160
+ typeof obj.elicitationId === 'string' &&
2161
+ typeof obj.message === 'string');
2162
+ });
2163
+ const serverName = clientConnection.type === 'connected'
2164
+ ? clientConnection.name
2165
+ : 'unknown';
2166
+ if (elicitations.length === 0) {
2167
+ logMCPDebug(serverName, `Tool '${tool}' returned -32042 but no valid elicitations in error data`);
2168
+ throw error;
2169
+ }
2170
+ logMCPDebug(serverName, `Tool '${tool}' requires URL elicitation (error -32042, attempt ${attempt + 1}), processing ${elicitations.length} elicitation(s)`);
2171
+ // Process each URL elicitation from the error.
2172
+ // The completion notification handler (in registerElicitationHandler) sets
2173
+ // `completed: true` on the matching queue event; the dialog reacts to this flag.
2174
+ for (const elicitation of elicitations) {
2175
+ const { elicitationId } = elicitation;
2176
+ // Run elicitation hooks — they can resolve URL elicitations programmatically
2177
+ const hookResponse = await runElicitationHooks(serverName, elicitation, signal);
2178
+ if (hookResponse) {
2179
+ logMCPDebug(serverName, `URL elicitation ${elicitationId} resolved by hook: ${jsonStringify(hookResponse)}`);
2180
+ if (hookResponse.action !== 'accept') {
2181
+ return {
2182
+ content: `URL elicitation was ${hookResponse.action === 'decline' ? 'declined' : hookResponse.action + 'ed'} by a hook. The tool "${tool}" could not complete because it requires the user to open a URL.`,
2183
+ };
2184
+ }
2185
+ // Hook accepted — skip the UI and proceed to retry
2186
+ continue;
2187
+ }
2188
+ // Resolve the URL elicitation via callback (print/SDK mode) or queue (REPL mode).
2189
+ let userResult;
2190
+ if (handleElicitation) {
2191
+ // Print/SDK mode: delegate to structuredIO which sends a control request
2192
+ userResult = await handleElicitation(serverName, elicitation, signal);
2193
+ }
2194
+ else {
2195
+ // REPL mode: queue for ElicitationDialog with two-phase consent/waiting flow
2196
+ const waitingState = {
2197
+ actionLabel: 'Retry now',
2198
+ showCancel: true,
2199
+ };
2200
+ userResult = await new Promise(resolve => {
2201
+ const onAbort = () => {
2202
+ void resolve({ action: 'cancel' });
2203
+ };
2204
+ if (signal.aborted) {
2205
+ onAbort();
2206
+ return;
2207
+ }
2208
+ signal.addEventListener('abort', onAbort, { once: true });
2209
+ setAppState(prev => ({
2210
+ ...prev,
2211
+ elicitation: {
2212
+ queue: [
2213
+ ...prev.elicitation.queue,
2214
+ {
2215
+ serverName,
2216
+ requestId: `error-elicit-${elicitationId}`,
2217
+ params: elicitation,
2218
+ signal,
2219
+ waitingState,
2220
+ respond: result => {
2221
+ // Phase 1 consent: accept is a no-op (doesn't resolve retry Promise)
2222
+ if (result.action === 'accept') {
2223
+ return;
2224
+ }
2225
+ // Decline or cancel: resolve the retry Promise
2226
+ signal.removeEventListener('abort', onAbort);
2227
+ void resolve(result);
2228
+ },
2229
+ onWaitingDismiss: action => {
2230
+ signal.removeEventListener('abort', onAbort);
2231
+ if (action === 'retry') {
2232
+ void resolve({ action: 'accept' });
2233
+ }
2234
+ else {
2235
+ void resolve({ action: 'cancel' });
2236
+ }
2237
+ },
2238
+ },
2239
+ ],
2240
+ },
2241
+ }));
2242
+ });
2243
+ }
2244
+ // Run ElicitationResult hooks — they can modify or block the response
2245
+ const finalResult = await runElicitationResultHooks(serverName, userResult, signal, 'url', elicitationId);
2246
+ if (finalResult.action !== 'accept') {
2247
+ logMCPDebug(serverName, `User ${finalResult.action === 'decline' ? 'declined' : finalResult.action + 'ed'} URL elicitation ${elicitationId}`);
2248
+ return {
2249
+ content: `URL elicitation was ${finalResult.action === 'decline' ? 'declined' : finalResult.action + 'ed'} by the user. The tool "${tool}" could not complete because it requires the user to open a URL.`,
2250
+ };
2251
+ }
2252
+ logMCPDebug(serverName, `Elicitation ${elicitationId} completed, retrying tool call`);
2253
+ }
2254
+ // Loop back to retry the tool call
2255
+ }
2256
+ }
2257
+ }
2258
+ async function callMCPTool({ client: { client, name, config }, tool, args, meta, signal, onProgress, }) {
2259
+ const toolStartTime = Date.now();
2260
+ let progressInterval;
2261
+ try {
2262
+ logMCPDebug(name, `Calling MCP tool: ${tool}`);
2263
+ // Set up progress logging for long-running tools (every 30 seconds)
2264
+ progressInterval = setInterval((startTime, name, tool) => {
2265
+ const elapsed = Date.now() - startTime;
2266
+ const elapsedSeconds = Math.floor(elapsed / 1000);
2267
+ const duration = `${elapsedSeconds}s`;
2268
+ logMCPDebug(name, `Tool '${tool}' still running (${duration} elapsed)`);
2269
+ }, 30000, // Log every 30 seconds
2270
+ toolStartTime, name, tool);
2271
+ // Use Promise.race with our own timeout to handle cases where SDK's
2272
+ // internal timeout doesn't work (e.g., SSE stream breaks mid-request)
2273
+ const timeoutMs = getMcpToolTimeoutMs();
2274
+ let timeoutId;
2275
+ const timeoutPromise = new Promise((_, reject) => {
2276
+ timeoutId = setTimeout((reject, name, tool, timeoutMs) => {
2277
+ reject(new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(`MCP server "${name}" tool "${tool}" timed out after ${Math.floor(timeoutMs / 1000)}s`, 'MCP tool timeout'));
2278
+ }, timeoutMs, reject, name, tool, timeoutMs);
2279
+ });
2280
+ const result = await Promise.race([
2281
+ client.callTool({
2282
+ name: tool,
2283
+ arguments: args,
2284
+ _meta: meta,
2285
+ }, CallToolResultSchema, {
2286
+ signal,
2287
+ timeout: timeoutMs,
2288
+ onprogress: onProgress
2289
+ ? sdkProgress => {
2290
+ onProgress({
2291
+ type: 'mcp_progress',
2292
+ status: 'progress',
2293
+ serverName: name,
2294
+ toolName: tool,
2295
+ progress: sdkProgress.progress,
2296
+ total: sdkProgress.total,
2297
+ progressMessage: sdkProgress.message,
2298
+ });
2299
+ }
2300
+ : undefined,
2301
+ }),
2302
+ timeoutPromise,
2303
+ ]).finally(() => {
2304
+ if (timeoutId) {
2305
+ clearTimeout(timeoutId);
2306
+ }
2307
+ });
2308
+ if ('isError' in result && result.isError) {
2309
+ let errorDetails = 'Unknown error';
2310
+ if ('content' in result &&
2311
+ Array.isArray(result.content) &&
2312
+ result.content.length > 0) {
2313
+ const firstContent = result.content[0];
2314
+ if (firstContent &&
2315
+ typeof firstContent === 'object' &&
2316
+ 'text' in firstContent) {
2317
+ errorDetails = firstContent.text;
2318
+ }
2319
+ }
2320
+ else if ('error' in result) {
2321
+ // Fallback for legacy error format
2322
+ errorDetails = String(result.error);
2323
+ }
2324
+ logMCPError(name, errorDetails);
2325
+ throw new McpToolCallError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(errorDetails, 'MCP tool returned error', '_meta' in result && result._meta ? { _meta: result._meta } : undefined);
2326
+ }
2327
+ const elapsed = Date.now() - toolStartTime;
2328
+ const duration = elapsed < 1000
2329
+ ? `${elapsed}ms`
2330
+ : elapsed < 60000
2331
+ ? `${Math.floor(elapsed / 1000)}s`
2332
+ : `${Math.floor(elapsed / 60000)}m ${Math.floor((elapsed % 60000) / 1000)}s`;
2333
+ logMCPDebug(name, `Tool '${tool}' completed successfully in ${duration}`);
2334
+ // Log code indexing tool usage
2335
+ const codeIndexingTool = detectCodeIndexingFromMcpServerName(name);
2336
+ if (codeIndexingTool) {
2337
+ logEvent('thaddeus_code_indexing_tool_used', {
2338
+ tool: codeIndexingTool,
2339
+ source: 'mcp',
2340
+ success: true,
2341
+ });
2342
+ }
2343
+ const content = await processMCPResult(result, tool, name);
2344
+ return {
2345
+ content,
2346
+ _meta: result._meta,
2347
+ structuredContent: result.structuredContent,
2348
+ };
2349
+ }
2350
+ catch (e) {
2351
+ // Clear intervals on error
2352
+ if (progressInterval !== undefined) {
2353
+ clearInterval(progressInterval);
2354
+ }
2355
+ const elapsed = Date.now() - toolStartTime;
2356
+ if (e instanceof Error && e.name !== 'AbortError') {
2357
+ logMCPDebug(name, `Tool '${tool}' failed after ${Math.floor(elapsed / 1000)}s: ${e.message}`);
2358
+ }
2359
+ // Check for 401 errors indicating expired/invalid OAuth tokens
2360
+ // The MCP SDK's StreamableHTTPError has a `code` property with the HTTP status
2361
+ if (e instanceof Error) {
2362
+ const errorCode = 'code' in e ? e.code : undefined;
2363
+ if (errorCode === 401 || e instanceof UnauthorizedError) {
2364
+ logMCPDebug(name, `Tool call returned 401 Unauthorized - token may have expired`);
2365
+ logEvent('thaddeus_mcp_tool_call_auth_error', {});
2366
+ throw new McpAuthError(name, `MCP server "${name}" requires re-authorization (token expired)`);
2367
+ }
2368
+ // Check for session expiry — two error shapes can surface here:
2369
+ // 1. Direct 404 + JSON-RPC -32001 from the server (StreamableHTTPError)
2370
+ // 2. -32000 "Connection closed" (McpError) — the SDK closes the transport
2371
+ // after the onerror handler fires, so the pending callTool() rejects
2372
+ // with this derived error instead of the original 404.
2373
+ // In both cases, clear the connection cache so the next tool call
2374
+ // creates a fresh session.
2375
+ const isSessionExpired = isMcpSessionExpiredError(e);
2376
+ const isConnectionClosedOnHttp = 'code' in e &&
2377
+ e.code === -32000 &&
2378
+ e.message.includes('Connection closed') &&
2379
+ (config.type === 'http' || config.type === 'claudeai-proxy');
2380
+ if (isSessionExpired || isConnectionClosedOnHttp) {
2381
+ logMCPDebug(name, `MCP session expired during tool call (${isSessionExpired ? '404/-32001' : 'connection closed'}), clearing connection cache for re-initialization`);
2382
+ logEvent('thaddeus_mcp_session_expired', {});
2383
+ await clearServerCache(name, config);
2384
+ throw new McpSessionExpiredError(name);
2385
+ }
2386
+ }
2387
+ // When the users hits esc, avoid logspew
2388
+ if (!(e instanceof Error) || e.name !== 'AbortError') {
2389
+ throw e;
2390
+ }
2391
+ return { content: undefined };
2392
+ }
2393
+ finally {
2394
+ // Always clear intervals
2395
+ if (progressInterval !== undefined) {
2396
+ clearInterval(progressInterval);
2397
+ }
2398
+ }
2399
+ }
2400
+ function extractToolUseId(message) {
2401
+ if (message.message.content[0]?.type !== 'tool_use') {
2402
+ return undefined;
2403
+ }
2404
+ return message.message.content[0].id;
2405
+ }
2406
+ /**
2407
+ * Sets up SDK MCP clients by creating transports and connecting them.
2408
+ * This is used for SDK MCP servers that run in the same process as the SDK.
2409
+ *
2410
+ * @param sdkMcpConfigs - The SDK MCP server configurations
2411
+ * @param sendMcpMessage - Callback to send MCP messages through the control channel
2412
+ * @returns Connected clients, their tools, and transport map for message routing
2413
+ */
2414
+ export async function setupSdkMcpClients(sdkMcpConfigs, sendMcpMessage) {
2415
+ const clients = [];
2416
+ const tools = [];
2417
+ // Connect to all servers in parallel
2418
+ const results = await Promise.allSettled(Object.entries(sdkMcpConfigs).map(async ([name, config]) => {
2419
+ const transport = new SdkControlClientTransport(name, sendMcpMessage);
2420
+ const client = new Client({
2421
+ name: 'thaddeus',
2422
+ title: 'Thaddeus',
2423
+ version: MACRO.VERSION ?? 'unknown',
2424
+ description: "Delphi Labs' agentic coding tool",
2425
+ websiteUrl: PRODUCT_URL,
2426
+ }, {
2427
+ capabilities: {},
2428
+ });
2429
+ try {
2430
+ // Connect the client
2431
+ await client.connect(transport);
2432
+ // Get capabilities from the server
2433
+ const capabilities = client.getServerCapabilities();
2434
+ // Create the connected client object
2435
+ const connectedClient = {
2436
+ type: 'connected',
2437
+ name,
2438
+ capabilities: capabilities || {},
2439
+ client,
2440
+ config: { ...config, scope: 'dynamic' },
2441
+ cleanup: async () => {
2442
+ await client.close();
2443
+ },
2444
+ };
2445
+ // Fetch tools if the server has them
2446
+ const serverTools = [];
2447
+ if (capabilities?.tools) {
2448
+ const sdkTools = await fetchToolsForClient(connectedClient);
2449
+ serverTools.push(...sdkTools);
2450
+ }
2451
+ return {
2452
+ client: connectedClient,
2453
+ tools: serverTools,
2454
+ };
2455
+ }
2456
+ catch (error) {
2457
+ // If connection fails, return failed server
2458
+ logMCPError(name, `Failed to connect SDK MCP server: ${error}`);
2459
+ return {
2460
+ client: {
2461
+ type: 'failed',
2462
+ name,
2463
+ config: { ...config, scope: 'user' },
2464
+ },
2465
+ tools: [],
2466
+ };
2467
+ }
2468
+ }));
2469
+ // Process results and collect clients and tools
2470
+ for (const result of results) {
2471
+ if (result.status === 'fulfilled') {
2472
+ clients.push(result.value.client);
2473
+ tools.push(...result.value.tools);
2474
+ }
2475
+ // If rejected (unexpected), the error was already logged inside the promise
2476
+ }
2477
+ return { clients, tools };
2478
+ }