@iaforged/context-code 1.0.72 → 1.0.74

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 (2050) hide show
  1. package/context-bootstrap.js +7 -8
  2. package/dist/src/QueryEngine.js +928 -0
  3. package/dist/src/Task.js +49 -0
  4. package/dist/src/Tool.js +56 -0
  5. package/dist/src/assistant/AssistantSessionChooser.js +16 -0
  6. package/dist/src/assistant/index.js +16 -0
  7. package/dist/src/assistant/sessionDiscovery.js +16 -0
  8. package/dist/src/assistant/sessionHistory.js +47 -0
  9. package/dist/src/bootstrap/state.js +1165 -0
  10. package/dist/src/bridge/bridgeApi.js +304 -0
  11. package/dist/src/bridge/bridgeConfig.js +39 -0
  12. package/dist/src/bridge/bridgeDebug.js +73 -0
  13. package/dist/src/bridge/bridgeEnabled.js +187 -0
  14. package/dist/src/bridge/bridgeMain.js +2289 -0
  15. package/dist/src/bridge/bridgeMessaging.js +353 -0
  16. package/dist/src/bridge/bridgePermissionCallbacks.js +10 -0
  17. package/dist/src/bridge/bridgePointer.js +175 -0
  18. package/dist/src/bridge/bridgeStatusUtil.js +105 -0
  19. package/dist/src/bridge/bridgeUI.js +412 -0
  20. package/dist/src/bridge/capacityWake.js +35 -0
  21. package/dist/src/bridge/codeSessionApi.js +111 -0
  22. package/dist/src/bridge/createSession.js +273 -0
  23. package/dist/src/bridge/debugUtils.js +115 -0
  24. package/dist/src/bridge/envLessBridgeConfig.js +121 -0
  25. package/dist/src/bridge/flushGate.js +65 -0
  26. package/dist/src/bridge/inboundAttachments.js +152 -0
  27. package/dist/src/bridge/inboundMessages.js +63 -0
  28. package/dist/src/bridge/initReplBridge.js +428 -0
  29. package/dist/src/bridge/jwtUtils.js +185 -0
  30. package/dist/src/bridge/pollConfig.js +85 -0
  31. package/dist/src/bridge/pollConfigDefaults.js +62 -0
  32. package/dist/src/bridge/remoteBridgeCore.js +712 -0
  33. package/dist/src/bridge/replBridge.js +1720 -0
  34. package/dist/src/bridge/replBridgeHandle.js +30 -0
  35. package/dist/src/bridge/replBridgeTransport.js +236 -0
  36. package/dist/src/bridge/sessionIdCompat.js +56 -0
  37. package/dist/src/bridge/sessionRunner.js +421 -0
  38. package/dist/src/bridge/trustedDevice.js +172 -0
  39. package/dist/src/bridge/types.js +9 -0
  40. package/dist/src/bridge/workSecret.js +99 -0
  41. package/dist/src/buddy/CompanionSprite.js +349 -0
  42. package/dist/src/buddy/companion.js +107 -0
  43. package/dist/src/buddy/prompt.js +33 -0
  44. package/dist/src/buddy/sprites.js +488 -0
  45. package/dist/src/buddy/types.js +90 -0
  46. package/dist/src/buddy/useBuddyNotification.js +90 -0
  47. package/dist/src/cli/bg.js +16 -0
  48. package/dist/src/cli/exit.js +30 -0
  49. package/dist/src/cli/handlers/agents.js +55 -0
  50. package/dist/src/cli/handlers/ant.js +16 -0
  51. package/dist/src/cli/handlers/auth.js +315 -0
  52. package/dist/src/cli/handlers/autoMode.js +128 -0
  53. package/dist/src/cli/handlers/mcp.js +334 -0
  54. package/dist/src/cli/handlers/plugins.js +634 -0
  55. package/dist/src/cli/handlers/projects_bridge.js +40 -0
  56. package/dist/src/cli/handlers/provider.js +42 -0
  57. package/dist/src/cli/handlers/templateJobs.js +16 -0
  58. package/dist/src/cli/handlers/util.js +76 -0
  59. package/dist/src/cli/ndjsonSafeStringify.js +27 -0
  60. package/dist/src/cli/print.js +4225 -0
  61. package/dist/src/cli/remoteIO.js +208 -0
  62. package/dist/src/cli/rollback.js +16 -0
  63. package/dist/src/cli/structuredIO.js +644 -0
  64. package/dist/src/cli/transports/HybridTransport.js +233 -0
  65. package/dist/src/cli/transports/SSETransport.js +538 -0
  66. package/dist/src/cli/transports/SerialBatchEventUploader.js +224 -0
  67. package/dist/src/cli/transports/Transport.js +1 -0
  68. package/dist/src/cli/transports/WebSocketTransport.js +613 -0
  69. package/dist/src/cli/transports/WorkerStateUploader.js +88 -0
  70. package/dist/src/cli/transports/ccrClient.js +711 -0
  71. package/dist/src/cli/transports/transportUtils.js +39 -0
  72. package/dist/src/cli/up.js +16 -0
  73. package/dist/src/cli/update.js +315 -0
  74. package/dist/src/commands/add-dir/add-dir.js +121 -0
  75. package/dist/src/commands/add-dir/index.js +8 -0
  76. package/dist/src/commands/add-dir/validation.js +76 -0
  77. package/dist/src/commands/advisor.js +88 -0
  78. package/dist/src/commands/agent/agent.js +283 -0
  79. package/dist/src/commands/agent/agentStore.js +120 -0
  80. package/dist/src/commands/agent/index.js +9 -0
  81. package/dist/src/commands/agents/agents.js +9 -0
  82. package/dist/src/commands/agents/index.js +7 -0
  83. package/dist/src/commands/ant-trace/index.js +1 -0
  84. package/dist/src/commands/assistant/assistant.js +16 -0
  85. package/dist/src/commands/autofix-pr/index.js +1 -0
  86. package/dist/src/commands/backfill-sessions/index.js +1 -0
  87. package/dist/src/commands/branch/branch.js +205 -0
  88. package/dist/src/commands/branch/index.js +11 -0
  89. package/dist/src/commands/break-cache/index.js +1 -0
  90. package/dist/src/commands/bridge/bridge.js +512 -0
  91. package/dist/src/commands/bridge/index.js +22 -0
  92. package/dist/src/commands/bridge-kick.js +179 -0
  93. package/dist/src/commands/brief.js +94 -0
  94. package/dist/src/commands/btw/btw.js +234 -0
  95. package/dist/src/commands/btw/index.js +9 -0
  96. package/dist/src/commands/bughunter/index.js +1 -0
  97. package/dist/src/commands/chrome/chrome.js +291 -0
  98. package/dist/src/commands/chrome/index.js +11 -0
  99. package/dist/src/commands/clear/caches.js +116 -0
  100. package/dist/src/commands/clear/clear.js +5 -0
  101. package/dist/src/commands/clear/conversation.js +191 -0
  102. package/dist/src/commands/clear/index.js +9 -0
  103. package/dist/src/commands/color/color.js +58 -0
  104. package/dist/src/commands/color/index.js +9 -0
  105. package/dist/src/commands/commit-push-pr.js +137 -0
  106. package/dist/src/commands/commit.js +80 -0
  107. package/dist/src/commands/compact/compact.js +196 -0
  108. package/dist/src/commands/compact/index.js +11 -0
  109. package/dist/src/commands/config/config.js +5 -0
  110. package/dist/src/commands/config/index.js +8 -0
  111. package/dist/src/commands/context/context-noninteractive.js +221 -0
  112. package/dist/src/commands/context/context.js +46 -0
  113. package/dist/src/commands/context/index.js +21 -0
  114. package/dist/src/commands/copy/copy.js +366 -0
  115. package/dist/src/commands/copy/index.js +7 -0
  116. package/dist/src/commands/cost/cost.js +21 -0
  117. package/dist/src/commands/cost/index.js +16 -0
  118. package/dist/src/commands/createMovedToPluginCommand.js +33 -0
  119. package/dist/src/commands/ctx_viz/index.js +1 -0
  120. package/dist/src/commands/debug-tool-call/index.js +1 -0
  121. package/dist/src/commands/desktop/desktop.js +5 -0
  122. package/dist/src/commands/desktop/index.js +22 -0
  123. package/dist/src/commands/diff/diff.js +5 -0
  124. package/dist/src/commands/diff/index.js +6 -0
  125. package/dist/src/commands/doctor/doctor.js +5 -0
  126. package/dist/src/commands/doctor/index.js +9 -0
  127. package/dist/src/commands/effort/effort.js +166 -0
  128. package/dist/src/commands/effort/index.js +11 -0
  129. package/dist/src/commands/env/index.js +1 -0
  130. package/dist/src/commands/exit/exit.js +31 -0
  131. package/dist/src/commands/exit/index.js +9 -0
  132. package/dist/src/commands/export/export.js +86 -0
  133. package/dist/src/commands/export/index.js +8 -0
  134. package/dist/src/commands/extra-usage/extra-usage-core.js +99 -0
  135. package/dist/src/commands/extra-usage/extra-usage-noninteractive.js +13 -0
  136. package/dist/src/commands/extra-usage/extra-usage.js +14 -0
  137. package/dist/src/commands/extra-usage/index.js +27 -0
  138. package/dist/src/commands/fast/fast.js +275 -0
  139. package/dist/src/commands/fast/index.js +20 -0
  140. package/dist/src/commands/feedback/feedback.js +10 -0
  141. package/dist/src/commands/feedback/index.js +21 -0
  142. package/dist/src/commands/files/files.js +11 -0
  143. package/dist/src/commands/files/index.js +9 -0
  144. package/dist/src/commands/good-claude/index.js +1 -0
  145. package/dist/src/commands/heapdump/heapdump.js +14 -0
  146. package/dist/src/commands/heapdump/index.js +9 -0
  147. package/dist/src/commands/help/help.js +5 -0
  148. package/dist/src/commands/help/index.js +7 -0
  149. package/dist/src/commands/hooks/hooks.js +11 -0
  150. package/dist/src/commands/hooks/index.js +8 -0
  151. package/dist/src/commands/ide/ide.js +615 -0
  152. package/dist/src/commands/ide/index.js +8 -0
  153. package/dist/src/commands/init-verifiers.js +258 -0
  154. package/dist/src/commands/init.js +249 -0
  155. package/dist/src/commands/insights.js +2555 -0
  156. package/dist/src/commands/install-github-app/ApiKeyStep.js +230 -0
  157. package/dist/src/commands/install-github-app/CheckExistingSecretStep.js +194 -0
  158. package/dist/src/commands/install-github-app/CheckGitHubStep.js +15 -0
  159. package/dist/src/commands/install-github-app/ChooseRepoStep.js +211 -0
  160. package/dist/src/commands/install-github-app/CreatingStep.js +52 -0
  161. package/dist/src/commands/install-github-app/ErrorStep.js +83 -0
  162. package/dist/src/commands/install-github-app/ExistingWorkflowStep.js +104 -0
  163. package/dist/src/commands/install-github-app/InstallAppStep.js +96 -0
  164. package/dist/src/commands/install-github-app/OAuthFlowStep.js +190 -0
  165. package/dist/src/commands/install-github-app/SuccessStep.js +93 -0
  166. package/dist/src/commands/install-github-app/WarningsStep.js +70 -0
  167. package/dist/src/commands/install-github-app/index.js +10 -0
  168. package/dist/src/commands/install-github-app/install-github-app.js +593 -0
  169. package/dist/src/commands/install-github-app/setupGitHubActions.js +227 -0
  170. package/dist/src/commands/install-slack-app/index.js +9 -0
  171. package/dist/src/commands/install-slack-app/install-slack-app.js +25 -0
  172. package/dist/src/commands/install.js +118 -0
  173. package/dist/src/commands/issue/index.js +1 -0
  174. package/dist/src/commands/keybindings/index.js +10 -0
  175. package/dist/src/commands/keybindings/keybindings.js +47 -0
  176. package/dist/src/commands/limites/index.js +8 -0
  177. package/dist/src/commands/limites/limites.js +214 -0
  178. package/dist/src/commands/login/index.js +11 -0
  179. package/dist/src/commands/login/login.js +120 -0
  180. package/dist/src/commands/login-openai/index.js +7 -0
  181. package/dist/src/commands/login-openai/login-openai.js +54 -0
  182. package/dist/src/commands/logout/index.js +8 -0
  183. package/dist/src/commands/logout/logout.js +72 -0
  184. package/dist/src/commands/mcp/addCommand.js +183 -0
  185. package/dist/src/commands/mcp/index.js +9 -0
  186. package/dist/src/commands/mcp/mcp.js +78 -0
  187. package/dist/src/commands/mcp/xaaIdpCommand.js +193 -0
  188. package/dist/src/commands/memory/index.js +7 -0
  189. package/dist/src/commands/memory/memory.js +71 -0
  190. package/dist/src/commands/mobile/index.js +9 -0
  191. package/dist/src/commands/mobile/mobile.js +278 -0
  192. package/dist/src/commands/mock-limits/index.js +1 -0
  193. package/dist/src/commands/model/index.js +14 -0
  194. package/dist/src/commands/model/model.js +297 -0
  195. package/dist/src/commands/oauth-refresh/index.js +1 -0
  196. package/dist/src/commands/onboarding/index.js +1 -0
  197. package/dist/src/commands/orchestrate/index.js +8 -0
  198. package/dist/src/commands/orchestrate/orchestrate.js +542 -0
  199. package/dist/src/commands/output-style/index.js +8 -0
  200. package/dist/src/commands/output-style/output-style.js +6 -0
  201. package/dist/src/commands/passes/index.js +17 -0
  202. package/dist/src/commands/passes/passes.js +22 -0
  203. package/dist/src/commands/perf-issue/index.js +1 -0
  204. package/dist/src/commands/permissions/index.js +8 -0
  205. package/dist/src/commands/permissions/permissions.js +8 -0
  206. package/dist/src/commands/plan/index.js +8 -0
  207. package/dist/src/commands/plan/plan.js +115 -0
  208. package/dist/src/commands/plugin/AddMarketplace.js +95 -0
  209. package/dist/src/commands/plugin/BrowseMarketplace.js +576 -0
  210. package/dist/src/commands/plugin/DiscoverPlugins.js +613 -0
  211. package/dist/src/commands/plugin/ManageMarketplaces.js +582 -0
  212. package/dist/src/commands/plugin/ManagePlugins.js +1783 -0
  213. package/dist/src/commands/plugin/PluginErrors.js +124 -0
  214. package/dist/src/commands/plugin/PluginOptionsDialog.js +367 -0
  215. package/dist/src/commands/plugin/PluginOptionsFlow.js +97 -0
  216. package/dist/src/commands/plugin/PluginSettings.js +1042 -0
  217. package/dist/src/commands/plugin/PluginTrustWarning.js +34 -0
  218. package/dist/src/commands/plugin/UnifiedInstalledCell.js +615 -0
  219. package/dist/src/commands/plugin/ValidatePlugin.js +95 -0
  220. package/dist/src/commands/plugin/index.js +10 -0
  221. package/dist/src/commands/plugin/parseArgs.js +71 -0
  222. package/dist/src/commands/plugin/plugin.js +5 -0
  223. package/dist/src/commands/plugin/pluginDetailsHelpers.js +89 -0
  224. package/dist/src/commands/plugin/usePagination.js +89 -0
  225. package/dist/src/commands/policy/index.js +9 -0
  226. package/dist/src/commands/policy/policy.js +84 -0
  227. package/dist/src/commands/pr_comments/index.js +49 -0
  228. package/dist/src/commands/privacy-settings/index.js +11 -0
  229. package/dist/src/commands/privacy-settings/privacy-settings.js +54 -0
  230. package/dist/src/commands/profile/index.js +9 -0
  231. package/dist/src/commands/profile/profile.js +482 -0
  232. package/dist/src/commands/provider/index.js +8 -0
  233. package/dist/src/commands/provider/provider.js +457 -0
  234. package/dist/src/commands/rate-limit-options/index.js +15 -0
  235. package/dist/src/commands/rate-limit-options/rate-limit-options.js +213 -0
  236. package/dist/src/commands/release-notes/index.js +9 -0
  237. package/dist/src/commands/release-notes/release-notes.js +38 -0
  238. package/dist/src/commands/reload-plugins/index.js +11 -0
  239. package/dist/src/commands/reload-plugins/reload-plugins.js +52 -0
  240. package/dist/src/commands/remote-env/index.js +12 -0
  241. package/dist/src/commands/remote-env/remote-env.js +5 -0
  242. package/dist/src/commands/remote-setup/api.js +155 -0
  243. package/dist/src/commands/remote-setup/index.js +15 -0
  244. package/dist/src/commands/remote-setup/remote-setup.js +149 -0
  245. package/dist/src/commands/rename/generateSessionName.js +58 -0
  246. package/dist/src/commands/rename/index.js +9 -0
  247. package/dist/src/commands/rename/rename.js +52 -0
  248. package/dist/src/commands/reset-limits/index.js +4 -0
  249. package/dist/src/commands/resume/index.js +9 -0
  250. package/dist/src/commands/resume/resume.js +239 -0
  251. package/dist/src/commands/review/UltrareviewOverageDialog.js +97 -0
  252. package/dist/src/commands/review/reviewRemote.js +259 -0
  253. package/dist/src/commands/review/ultrareviewCommand.js +57 -0
  254. package/dist/src/commands/review/ultrareviewEnabled.js +10 -0
  255. package/dist/src/commands/review.js +50 -0
  256. package/dist/src/commands/rewind/index.js +10 -0
  257. package/dist/src/commands/rewind/rewind.js +7 -0
  258. package/dist/src/commands/run/index.js +9 -0
  259. package/dist/src/commands/run/run.js +1126 -0
  260. package/dist/src/commands/sandbox-toggle/index.js +41 -0
  261. package/dist/src/commands/sandbox-toggle/sandbox-toggle.js +72 -0
  262. package/dist/src/commands/security-review.js +231 -0
  263. package/dist/src/commands/session/index.js +13 -0
  264. package/dist/src/commands/session/session.js +142 -0
  265. package/dist/src/commands/share/index.js +1 -0
  266. package/dist/src/commands/skills/index.js +8 -0
  267. package/dist/src/commands/skills/skills.js +97 -0
  268. package/dist/src/commands/stats/index.js +7 -0
  269. package/dist/src/commands/stats/stats.js +5 -0
  270. package/dist/src/commands/status/index.js +8 -0
  271. package/dist/src/commands/status/status.js +5 -0
  272. package/dist/src/commands/statusline.js +22 -0
  273. package/dist/src/commands/stickers/index.js +9 -0
  274. package/dist/src/commands/stickers/stickers.js +14 -0
  275. package/dist/src/commands/summary/index.js +1 -0
  276. package/dist/src/commands/tag/index.js +9 -0
  277. package/dist/src/commands/tag/tag.js +215 -0
  278. package/dist/src/commands/tasks/index.js +8 -0
  279. package/dist/src/commands/tasks/tasks.js +5 -0
  280. package/dist/src/commands/team/index.js +9 -0
  281. package/dist/src/commands/team/team.js +582 -0
  282. package/dist/src/commands/team-auto/index.js +9 -0
  283. package/dist/src/commands/team-auto/teamAuto.js +340 -0
  284. package/dist/src/commands/telegram/index.js +9 -0
  285. package/dist/src/commands/telegram/telegram.js +118 -0
  286. package/dist/src/commands/teleport/index.js +1 -0
  287. package/dist/src/commands/terminalSetup/index.js +18 -0
  288. package/dist/src/commands/terminalSetup/terminalSetup.js +491 -0
  289. package/dist/src/commands/theme/index.js +7 -0
  290. package/dist/src/commands/theme/theme.js +50 -0
  291. package/dist/src/commands/thinkback/index.js +9 -0
  292. package/dist/src/commands/thinkback/thinkback.js +527 -0
  293. package/dist/src/commands/thinkback-play/index.js +13 -0
  294. package/dist/src/commands/thinkback-play/thinkback-play.js +34 -0
  295. package/dist/src/commands/ultraplan.js +418 -0
  296. package/dist/src/commands/upgrade/index.js +12 -0
  297. package/dist/src/commands/upgrade/upgrade.js +37 -0
  298. package/dist/src/commands/version.js +18 -0
  299. package/dist/src/commands/vim/index.js +8 -0
  300. package/dist/src/commands/vim/vim.js +25 -0
  301. package/dist/src/commands/voice/index.js +14 -0
  302. package/dist/src/commands/voice/voice.js +130 -0
  303. package/dist/src/commands/whatsapp/index.js +9 -0
  304. package/dist/src/commands/whatsapp/whatsapp.js +326 -0
  305. package/dist/src/commands/workspace/index.js +9 -0
  306. package/dist/src/commands/workspace/workspace.js +701 -0
  307. package/dist/src/commands.js +635 -0
  308. package/dist/src/components/AgentProgressLine.js +111 -0
  309. package/dist/src/components/App.js +45 -0
  310. package/dist/src/components/ApproveApiKey.js +124 -0
  311. package/dist/src/components/AutoModeOptInDialog.js +140 -0
  312. package/dist/src/components/AutoUpdater.js +157 -0
  313. package/dist/src/components/AutoUpdaterWrapper.js +78 -0
  314. package/dist/src/components/AwsAuthStatusBox.js +88 -0
  315. package/dist/src/components/BaseTextInput.js +105 -0
  316. package/dist/src/components/BashModeProgress.js +48 -0
  317. package/dist/src/components/BridgeDialog.js +414 -0
  318. package/dist/src/components/BypassPermissionsModeDialog.js +87 -0
  319. package/dist/src/components/ChannelDowngradeDialog.js +100 -0
  320. package/dist/src/components/ClaudeCodeHint/PluginHintMenu.js +37 -0
  321. package/dist/src/components/ClaudeInChromeOnboarding.js +126 -0
  322. package/dist/src/components/ClaudeMdExternalIncludesDialog.js +137 -0
  323. package/dist/src/components/ClickableImageRef.js +64 -0
  324. package/dist/src/components/CompactSummary.js +119 -0
  325. package/dist/src/components/ConfigurableShortcutHint.js +34 -0
  326. package/dist/src/components/ConsoleOAuthFlow.js +758 -0
  327. package/dist/src/components/ContextSuggestions.js +43 -0
  328. package/dist/src/components/ContextVisualization.js +483 -0
  329. package/dist/src/components/CoordinatorAgentStatus.js +261 -0
  330. package/dist/src/components/CostThresholdDialog.js +48 -0
  331. package/dist/src/components/CtrlOToExpand.js +50 -0
  332. package/dist/src/components/CustomSelect/SelectMulti.js +149 -0
  333. package/dist/src/components/CustomSelect/index.js +2 -0
  334. package/dist/src/components/CustomSelect/option-map.js +32 -0
  335. package/dist/src/components/CustomSelect/select-input-option.js +426 -0
  336. package/dist/src/components/CustomSelect/select-option.js +23 -0
  337. package/dist/src/components/CustomSelect/select.js +518 -0
  338. package/dist/src/components/CustomSelect/use-multi-select-state.js +214 -0
  339. package/dist/src/components/CustomSelect/use-select-input.js +170 -0
  340. package/dist/src/components/CustomSelect/use-select-navigation.js +366 -0
  341. package/dist/src/components/CustomSelect/use-select-state.js +22 -0
  342. package/dist/src/components/DesktopHandoff.js +195 -0
  343. package/dist/src/components/DesktopUpsell/DesktopUpsellStartup.js +173 -0
  344. package/dist/src/components/DevBar.js +50 -0
  345. package/dist/src/components/DevChannelsDialog.js +103 -0
  346. package/dist/src/components/DiagnosticsDisplay.js +91 -0
  347. package/dist/src/components/EffortCallout.js +264 -0
  348. package/dist/src/components/EffortIndicator.js +29 -0
  349. package/dist/src/components/ExitFlow.js +40 -0
  350. package/dist/src/components/ExportDialog.js +101 -0
  351. package/dist/src/components/FallbackToolUseErrorMessage.js +115 -0
  352. package/dist/src/components/FallbackToolUseRejectedMessage.js +16 -0
  353. package/dist/src/components/FastIcon.js +42 -0
  354. package/dist/src/components/Feedback.js +439 -0
  355. package/dist/src/components/FeedbackSurvey/FeedbackSurvey.js +150 -0
  356. package/dist/src/components/FeedbackSurvey/FeedbackSurveyView.js +103 -0
  357. package/dist/src/components/FeedbackSurvey/TranscriptSharePrompt.js +83 -0
  358. package/dist/src/components/FeedbackSurvey/submitTranscriptShare.js +81 -0
  359. package/dist/src/components/FeedbackSurvey/useDebouncedDigitInput.js +51 -0
  360. package/dist/src/components/FeedbackSurvey/useFeedbackSurvey.js +258 -0
  361. package/dist/src/components/FeedbackSurvey/useMemorySurvey.js +191 -0
  362. package/dist/src/components/FeedbackSurvey/usePostCompactSurvey.js +202 -0
  363. package/dist/src/components/FeedbackSurvey/useSurveyState.js +80 -0
  364. package/dist/src/components/FileEditToolDiff.js +166 -0
  365. package/dist/src/components/FileEditToolUpdatedMessage.js +111 -0
  366. package/dist/src/components/FileEditToolUseRejectedMessage.js +157 -0
  367. package/dist/src/components/FilePathLink.js +34 -0
  368. package/dist/src/components/FullscreenLayout.js +578 -0
  369. package/dist/src/components/GlobalSearchDialog.js +339 -0
  370. package/dist/src/components/HelpV2/Commands.js +65 -0
  371. package/dist/src/components/HelpV2/General.js +24 -0
  372. package/dist/src/components/HelpV2/HelpV2.js +186 -0
  373. package/dist/src/components/HighlightedCode/Fallback.js +193 -0
  374. package/dist/src/components/HighlightedCode.js +184 -0
  375. package/dist/src/components/HistorySearchDialog.js +92 -0
  376. package/dist/src/components/IdeAutoConnectDialog.js +153 -0
  377. package/dist/src/components/IdeOnboardingDialog.js +174 -0
  378. package/dist/src/components/IdeStatusIndicator.js +49 -0
  379. package/dist/src/components/IdleReturnDialog.js +116 -0
  380. package/dist/src/components/InterruptedByUser.js +15 -0
  381. package/dist/src/components/InvalidConfigDialog.js +134 -0
  382. package/dist/src/components/InvalidSettingsDialog.js +84 -0
  383. package/dist/src/components/KeybindingWarnings.js +54 -0
  384. package/dist/src/components/LanguagePicker.js +84 -0
  385. package/dist/src/components/LogSelector.js +1579 -0
  386. package/dist/src/components/LogoV2/AnimatedAsterisk.js +42 -0
  387. package/dist/src/components/LogoV2/AnimatedClawd.js +111 -0
  388. package/dist/src/components/LogoV2/ChannelsNotice.js +258 -0
  389. package/dist/src/components/LogoV2/Clawd.js +12 -0
  390. package/dist/src/components/LogoV2/CondensedLogo.js +144 -0
  391. package/dist/src/components/LogoV2/EmergencyTip.js +47 -0
  392. package/dist/src/components/LogoV2/Feed.js +84 -0
  393. package/dist/src/components/LogoV2/FeedColumn.js +55 -0
  394. package/dist/src/components/LogoV2/GuestPassesUpsell.js +71 -0
  395. package/dist/src/components/LogoV2/LogoV2.js +564 -0
  396. package/dist/src/components/LogoV2/Opus1mMergeNotice.js +56 -0
  397. package/dist/src/components/LogoV2/OverageCreditUpsell.js +160 -0
  398. package/dist/src/components/LogoV2/VoiceModeNotice.js +70 -0
  399. package/dist/src/components/LogoV2/WelcomeV2.js +8 -0
  400. package/dist/src/components/LogoV2/feedConfigs.js +78 -0
  401. package/dist/src/components/LspRecommendation/LspRecommendationMenu.js +46 -0
  402. package/dist/src/components/MCPServerApprovalDialog.js +113 -0
  403. package/dist/src/components/MCPServerDesktopImportDialog.js +206 -0
  404. package/dist/src/components/MCPServerDialogCopy.js +15 -0
  405. package/dist/src/components/MCPServerMultiselectDialog.js +133 -0
  406. package/dist/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.js +149 -0
  407. package/dist/src/components/ManagedSettingsSecurityDialog/utils.js +105 -0
  408. package/dist/src/components/Markdown.js +217 -0
  409. package/dist/src/components/MarkdownTable.js +279 -0
  410. package/dist/src/components/MemoryUsageIndicator.js +27 -0
  411. package/dist/src/components/Message.js +566 -0
  412. package/dist/src/components/MessageModel.js +36 -0
  413. package/dist/src/components/MessageResponse.js +73 -0
  414. package/dist/src/components/MessageRow.js +346 -0
  415. package/dist/src/components/MessageSelector.js +743 -0
  416. package/dist/src/components/MessageTimestamp.js +57 -0
  417. package/dist/src/components/Messages.js +637 -0
  418. package/dist/src/components/ModelPicker.js +493 -0
  419. package/dist/src/components/NativeAutoUpdater.js +153 -0
  420. package/dist/src/components/NotebookEditToolUseRejectedMessage.js +83 -0
  421. package/dist/src/components/OffscreenFreeze.js +35 -0
  422. package/dist/src/components/Onboarding.js +174 -0
  423. package/dist/src/components/OutputStylePicker.js +102 -0
  424. package/dist/src/components/PackageManagerAutoUpdater.js +100 -0
  425. package/dist/src/components/Passes/Passes.js +113 -0
  426. package/dist/src/components/PrBadge.js +90 -0
  427. package/dist/src/components/PressEnterToContinue.js +15 -0
  428. package/dist/src/components/PromptInput/HistorySearchInput.js +44 -0
  429. package/dist/src/components/PromptInput/IssueFlagBanner.js +8 -0
  430. package/dist/src/components/PromptInput/Notifications.js +221 -0
  431. package/dist/src/components/PromptInput/PromptInput.js +1998 -0
  432. package/dist/src/components/PromptInput/PromptInputFooter.js +84 -0
  433. package/dist/src/components/PromptInput/PromptInputFooterLeftSide.js +409 -0
  434. package/dist/src/components/PromptInput/PromptInputFooterSuggestions.js +280 -0
  435. package/dist/src/components/PromptInput/PromptInputHelpMenu.js +379 -0
  436. package/dist/src/components/PromptInput/PromptInputModeIndicator.js +72 -0
  437. package/dist/src/components/PromptInput/PromptInputQueuedCommands.js +105 -0
  438. package/dist/src/components/PromptInput/PromptInputStashNotice.js +20 -0
  439. package/dist/src/components/PromptInput/SandboxPromptFooterHint.js +65 -0
  440. package/dist/src/components/PromptInput/ShimmeredInput.js +132 -0
  441. package/dist/src/components/PromptInput/VoiceIndicator.js +136 -0
  442. package/dist/src/components/PromptInput/inputModes.js +24 -0
  443. package/dist/src/components/PromptInput/inputPaste.js +62 -0
  444. package/dist/src/components/PromptInput/useMaybeTruncateInput.js +33 -0
  445. package/dist/src/components/PromptInput/usePromptInputPlaceholder.js +55 -0
  446. package/dist/src/components/PromptInput/useShowFastIconHint.js +23 -0
  447. package/dist/src/components/PromptInput/useSwarmBanner.js +112 -0
  448. package/dist/src/components/PromptInput/utils.js +50 -0
  449. package/dist/src/components/QuickOpenDialog.js +243 -0
  450. package/dist/src/components/RemoteCallout.js +53 -0
  451. package/dist/src/components/RemoteEnvironmentDialog.js +345 -0
  452. package/dist/src/components/ResumeTask.js +173 -0
  453. package/dist/src/components/SandboxViolationExpandedView.js +102 -0
  454. package/dist/src/components/ScrollKeybindingHandler.js +982 -0
  455. package/dist/src/components/SearchBox.js +55 -0
  456. package/dist/src/components/SentryErrorBoundary.js +16 -0
  457. package/dist/src/components/SessionBackgroundHint.js +104 -0
  458. package/dist/src/components/SessionPreview.js +200 -0
  459. package/dist/src/components/Settings/Config.js +1628 -0
  460. package/dist/src/components/Settings/Settings.js +129 -0
  461. package/dist/src/components/Settings/Status.js +239 -0
  462. package/dist/src/components/Settings/Usage.js +341 -0
  463. package/dist/src/components/ShowInIDEPrompt.js +151 -0
  464. package/dist/src/components/SkillImprovementSurvey.js +130 -0
  465. package/dist/src/components/Spinner/FlashingChar.js +51 -0
  466. package/dist/src/components/Spinner/GlimmerMessage.js +328 -0
  467. package/dist/src/components/Spinner/ShimmerChar.js +22 -0
  468. package/dist/src/components/Spinner/SpinnerAnimationRow.js +169 -0
  469. package/dist/src/components/Spinner/SpinnerGlyph.js +69 -0
  470. package/dist/src/components/Spinner/TeammateSpinnerLine.js +170 -0
  471. package/dist/src/components/Spinner/TeammateSpinnerTree.js +268 -0
  472. package/dist/src/components/Spinner/index.js +11 -0
  473. package/dist/src/components/Spinner/teammateSelectHint.js +1 -0
  474. package/dist/src/components/Spinner/useShimmerAnimation.js +22 -0
  475. package/dist/src/components/Spinner/useStalledAnimation.js +63 -0
  476. package/dist/src/components/Spinner/utils.js +77 -0
  477. package/dist/src/components/Spinner.js +470 -0
  478. package/dist/src/components/Stats.js +1000 -0
  479. package/dist/src/components/StatusLine.js +288 -0
  480. package/dist/src/components/StatusNotices.js +50 -0
  481. package/dist/src/components/StructuredDiff/Fallback.js +335 -0
  482. package/dist/src/components/StructuredDiff/colorDiff.js +26 -0
  483. package/dist/src/components/StructuredDiff.js +152 -0
  484. package/dist/src/components/StructuredDiffList.js +8 -0
  485. package/dist/src/components/TagTabs.js +100 -0
  486. package/dist/src/components/TaskListV2.js +333 -0
  487. package/dist/src/components/TeammateViewHeader.js +87 -0
  488. package/dist/src/components/TeleportError.js +191 -0
  489. package/dist/src/components/TeleportProgress.js +130 -0
  490. package/dist/src/components/TeleportRepoMismatchDialog.js +98 -0
  491. package/dist/src/components/TeleportResumeWrapper.js +158 -0
  492. package/dist/src/components/TeleportStash.js +82 -0
  493. package/dist/src/components/TextInput.js +108 -0
  494. package/dist/src/components/ThemePicker.js +330 -0
  495. package/dist/src/components/ThinkingToggle.js +153 -0
  496. package/dist/src/components/TokenWarning.js +172 -0
  497. package/dist/src/components/ToolUseLoader.js +34 -0
  498. package/dist/src/components/TrustDialog/TrustDialog.js +113 -0
  499. package/dist/src/components/TrustDialog/utils.js +199 -0
  500. package/dist/src/components/ValidationErrorsList.js +146 -0
  501. package/dist/src/components/VimTextInput.js +136 -0
  502. package/dist/src/components/VirtualMessageList.js +892 -0
  503. package/dist/src/components/WorkflowMultiselectDialog.js +118 -0
  504. package/dist/src/components/WorktreeExitDialog.js +222 -0
  505. package/dist/src/components/agents/AgentDetail.js +226 -0
  506. package/dist/src/components/agents/AgentEditor.js +146 -0
  507. package/dist/src/components/agents/AgentNavigationFooter.js +21 -0
  508. package/dist/src/components/agents/AgentsList.js +436 -0
  509. package/dist/src/components/agents/AgentsMenu.js +848 -0
  510. package/dist/src/components/agents/ColorPicker.js +110 -0
  511. package/dist/src/components/agents/ModelSelector.js +62 -0
  512. package/dist/src/components/agents/SnapshotUpdateDialog.js +16 -0
  513. package/dist/src/components/agents/ToolSelector.js +557 -0
  514. package/dist/src/components/agents/agentFileUtils.js +187 -0
  515. package/dist/src/components/agents/generateAgent.js +161 -0
  516. package/dist/src/components/agents/new-agent-creation/CreateAgentWizard.js +88 -0
  517. package/dist/src/components/agents/new-agent-creation/wizard-steps/ColorStep.js +80 -0
  518. package/dist/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.js +386 -0
  519. package/dist/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.js +63 -0
  520. package/dist/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.js +126 -0
  521. package/dist/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.js +118 -0
  522. package/dist/src/components/agents/new-agent-creation/wizard-steps/LocationStep.js +92 -0
  523. package/dist/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.js +120 -0
  524. package/dist/src/components/agents/new-agent-creation/wizard-steps/MethodStep.js +79 -0
  525. package/dist/src/components/agents/new-agent-creation/wizard-steps/ModelStep.js +48 -0
  526. package/dist/src/components/agents/new-agent-creation/wizard-steps/PromptStep.js +131 -0
  527. package/dist/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.js +51 -0
  528. package/dist/src/components/agents/new-agent-creation/wizard-steps/TypeStep.js +100 -0
  529. package/dist/src/components/agents/types.js +4 -0
  530. package/dist/src/components/agents/utils.js +14 -0
  531. package/dist/src/components/agents/validateAgent.js +79 -0
  532. package/dist/src/components/design-system/Byline.js +72 -0
  533. package/dist/src/components/design-system/Dialog.js +116 -0
  534. package/dist/src/components/design-system/Divider.js +109 -0
  535. package/dist/src/components/design-system/FuzzyPicker.js +187 -0
  536. package/dist/src/components/design-system/KeyboardShortcutHint.js +67 -0
  537. package/dist/src/components/design-system/ListItem.js +183 -0
  538. package/dist/src/components/design-system/LoadingState.js +68 -0
  539. package/dist/src/components/design-system/Pane.js +68 -0
  540. package/dist/src/components/design-system/ProgressBar.js +62 -0
  541. package/dist/src/components/design-system/Ratchet.js +71 -0
  542. package/dist/src/components/design-system/StatusIcon.js +69 -0
  543. package/dist/src/components/design-system/Tabs.js +269 -0
  544. package/dist/src/components/design-system/ThemeProvider.js +137 -0
  545. package/dist/src/components/design-system/ThemedBox.js +125 -0
  546. package/dist/src/components/design-system/ThemedText.js +60 -0
  547. package/dist/src/components/design-system/color.js +22 -0
  548. package/dist/src/components/diff/DiffDetailView.js +284 -0
  549. package/dist/src/components/diff/DiffDialog.js +387 -0
  550. package/dist/src/components/diff/DiffFileList.js +291 -0
  551. package/dist/src/components/grove/Grove.js +483 -0
  552. package/dist/src/components/hooks/HooksConfigMenu.js +570 -0
  553. package/dist/src/components/hooks/PromptDialog.js +81 -0
  554. package/dist/src/components/hooks/SelectEventMode.js +117 -0
  555. package/dist/src/components/hooks/SelectHookMode.js +93 -0
  556. package/dist/src/components/hooks/SelectMatcherMode.js +124 -0
  557. package/dist/src/components/hooks/ViewHookMode.js +197 -0
  558. package/dist/src/components/mcp/CapabilitiesSection.js +55 -0
  559. package/dist/src/components/mcp/ElicitationDialog.js +945 -0
  560. package/dist/src/components/mcp/MCPAgentServerMenu.js +95 -0
  561. package/dist/src/components/mcp/MCPListPanel.js +504 -0
  562. package/dist/src/components/mcp/MCPReconnect.js +168 -0
  563. package/dist/src/components/mcp/MCPRemoteServerMenu.js +460 -0
  564. package/dist/src/components/mcp/MCPSettings.js +414 -0
  565. package/dist/src/components/mcp/MCPStdioServerMenu.js +95 -0
  566. package/dist/src/components/mcp/MCPToolDetailView.js +219 -0
  567. package/dist/src/components/mcp/MCPToolListView.js +136 -0
  568. package/dist/src/components/mcp/McpParsingWarnings.js +211 -0
  569. package/dist/src/components/mcp/index.js +8 -0
  570. package/dist/src/components/mcp/types.js +3 -0
  571. package/dist/src/components/mcp/utils/reconnectHelpers.js +35 -0
  572. package/dist/src/components/memory/MemoryFileSelector.js +455 -0
  573. package/dist/src/components/memory/MemoryUpdateNotification.js +42 -0
  574. package/dist/src/components/messageActions.js +418 -0
  575. package/dist/src/components/messages/AdvisorMessage.js +151 -0
  576. package/dist/src/components/messages/AssistantRedactedThinkingMessage.js +27 -0
  577. package/dist/src/components/messages/AssistantTextMessage.js +274 -0
  578. package/dist/src/components/messages/AssistantThinkingMessage.js +69 -0
  579. package/dist/src/components/messages/AssistantToolUseMessage.js +323 -0
  580. package/dist/src/components/messages/AttachmentMessage.js +418 -0
  581. package/dist/src/components/messages/CollapsedReadSearchContent.js +362 -0
  582. package/dist/src/components/messages/CompactBoundaryMessage.js +18 -0
  583. package/dist/src/components/messages/GroupedToolUseContent.js +37 -0
  584. package/dist/src/components/messages/HighlightedThinkingText.js +164 -0
  585. package/dist/src/components/messages/HookProgressMessage.js +110 -0
  586. package/dist/src/components/messages/PlanApprovalMessage.js +212 -0
  587. package/dist/src/components/messages/RateLimitMessage.js +149 -0
  588. package/dist/src/components/messages/ShutdownMessage.js +123 -0
  589. package/dist/src/components/messages/SystemAPIErrorMessage.js +135 -0
  590. package/dist/src/components/messages/SystemTextMessage.js +843 -0
  591. package/dist/src/components/messages/TaskAssignmentMessage.js +71 -0
  592. package/dist/src/components/messages/UserAgentNotificationMessage.js +77 -0
  593. package/dist/src/components/messages/UserBashInputMessage.js +51 -0
  594. package/dist/src/components/messages/UserBashOutputMessage.js +54 -0
  595. package/dist/src/components/messages/UserChannelMessage.js +129 -0
  596. package/dist/src/components/messages/UserCommandMessage.js +106 -0
  597. package/dist/src/components/messages/UserImageMessage.js +53 -0
  598. package/dist/src/components/messages/UserLocalCommandOutputMessage.js +169 -0
  599. package/dist/src/components/messages/UserMemoryInputMessage.js +72 -0
  600. package/dist/src/components/messages/UserPlanMessage.js +37 -0
  601. package/dist/src/components/messages/UserPromptMessage.js +63 -0
  602. package/dist/src/components/messages/UserResourceUpdateMessage.js +101 -0
  603. package/dist/src/components/messages/UserTeammateMessage.js +156 -0
  604. package/dist/src/components/messages/UserTextMessage.js +271 -0
  605. package/dist/src/components/messages/UserToolResultMessage/RejectedPlanMessage.js +27 -0
  606. package/dist/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.js +16 -0
  607. package/dist/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +16 -0
  608. package/dist/src/components/messages/UserToolResultMessage/UserToolErrorMessage.js +91 -0
  609. package/dist/src/components/messages/UserToolResultMessage/UserToolRejectMessage.js +73 -0
  610. package/dist/src/components/messages/UserToolResultMessage/UserToolResultMessage.js +83 -0
  611. package/dist/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +58 -0
  612. package/dist/src/components/messages/UserToolResultMessage/utils.js +43 -0
  613. package/dist/src/components/messages/nullRenderingAttachments.js +58 -0
  614. package/dist/src/components/messages/teamMemCollapsed.js +142 -0
  615. package/dist/src/components/messages/teamMemSaved.js +17 -0
  616. package/dist/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.js +654 -0
  617. package/dist/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.js +219 -0
  618. package/dist/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.js +227 -0
  619. package/dist/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.js +174 -0
  620. package/dist/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.js +444 -0
  621. package/dist/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.js +136 -0
  622. package/dist/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.js +100 -0
  623. package/dist/src/components/permissions/BashPermissionRequest/BashPermissionRequest.js +404 -0
  624. package/dist/src/components/permissions/BashPermissionRequest/bashToolUseOptions.js +110 -0
  625. package/dist/src/components/permissions/ComputerUseApproval/ComputerUseApproval.js +448 -0
  626. package/dist/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.js +125 -0
  627. package/dist/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.js +649 -0
  628. package/dist/src/components/permissions/FallbackPermissionRequest.js +348 -0
  629. package/dist/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +184 -0
  630. package/dist/src/components/permissions/FilePermissionDialog/FilePermissionDialog.js +108 -0
  631. package/dist/src/components/permissions/FilePermissionDialog/ideDiffConfig.js +13 -0
  632. package/dist/src/components/permissions/FilePermissionDialog/permissionOptions.js +136 -0
  633. package/dist/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.js +131 -0
  634. package/dist/src/components/permissions/FilePermissionDialog/usePermissionHandler.js +86 -0
  635. package/dist/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +163 -0
  636. package/dist/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +78 -0
  637. package/dist/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +112 -0
  638. package/dist/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.js +163 -0
  639. package/dist/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.js +217 -0
  640. package/dist/src/components/permissions/PermissionDecisionDebugInfo.js +466 -0
  641. package/dist/src/components/permissions/PermissionDialog.js +54 -0
  642. package/dist/src/components/permissions/PermissionExplanation.js +269 -0
  643. package/dist/src/components/permissions/PermissionPrompt.js +316 -0
  644. package/dist/src/components/permissions/PermissionRequest.js +160 -0
  645. package/dist/src/components/permissions/PermissionRequestTitle.js +57 -0
  646. package/dist/src/components/permissions/PermissionRuleExplanation.js +116 -0
  647. package/dist/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.js +178 -0
  648. package/dist/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.js +73 -0
  649. package/dist/src/components/permissions/SandboxPermissionRequest.js +161 -0
  650. package/dist/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.js +228 -0
  651. package/dist/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.js +384 -0
  652. package/dist/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.js +258 -0
  653. package/dist/src/components/permissions/WorkerBadge.js +43 -0
  654. package/dist/src/components/permissions/WorkerPendingPermission.js +106 -0
  655. package/dist/src/components/permissions/hooks.js +163 -0
  656. package/dist/src/components/permissions/rules/AddPermissionRules.js +172 -0
  657. package/dist/src/components/permissions/rules/AddWorkspaceDirectory.js +334 -0
  658. package/dist/src/components/permissions/rules/PermissionRuleDescription.js +77 -0
  659. package/dist/src/components/permissions/rules/PermissionRuleInput.js +135 -0
  660. package/dist/src/components/permissions/rules/PermissionRuleList.js +1189 -0
  661. package/dist/src/components/permissions/rules/RecentDenialsTab.js +204 -0
  662. package/dist/src/components/permissions/rules/RemoveWorkspaceDirectory.js +102 -0
  663. package/dist/src/components/permissions/rules/WorkspaceTab.js +132 -0
  664. package/dist/src/components/permissions/shellPermissionHelpers.js +111 -0
  665. package/dist/src/components/permissions/useShellPermissionFeedback.js +108 -0
  666. package/dist/src/components/permissions/utils.js +14 -0
  667. package/dist/src/components/sandbox/SandboxConfigTab.js +47 -0
  668. package/dist/src/components/sandbox/SandboxDependenciesTab.js +122 -0
  669. package/dist/src/components/sandbox/SandboxDoctorSection.js +46 -0
  670. package/dist/src/components/sandbox/SandboxOverridesTab.js +192 -0
  671. package/dist/src/components/sandbox/SandboxSettings.js +296 -0
  672. package/dist/src/components/shell/ExpandShellOutputContext.js +33 -0
  673. package/dist/src/components/shell/OutputLine.js +110 -0
  674. package/dist/src/components/shell/ShellProgressMessage.js +143 -0
  675. package/dist/src/components/shell/ShellTimeDisplay.js +71 -0
  676. package/dist/src/components/skills/SkillsMenu.js +238 -0
  677. package/dist/src/components/tasks/AsyncAgentDetailDialog.js +234 -0
  678. package/dist/src/components/tasks/BackgroundTask.js +363 -0
  679. package/dist/src/components/tasks/BackgroundTaskStatus.js +419 -0
  680. package/dist/src/components/tasks/BackgroundTasksDialog.js +496 -0
  681. package/dist/src/components/tasks/DreamDetailDialog.js +250 -0
  682. package/dist/src/components/tasks/InProcessTeammateDetailDialog.js +274 -0
  683. package/dist/src/components/tasks/RemoteSessionDetailDialog.js +868 -0
  684. package/dist/src/components/tasks/RemoteSessionProgress.js +249 -0
  685. package/dist/src/components/tasks/ShellDetailDialog.js +403 -0
  686. package/dist/src/components/tasks/ShellProgress.js +76 -0
  687. package/dist/src/components/tasks/renderToolActivity.js +28 -0
  688. package/dist/src/components/tasks/taskStatusUtils.js +94 -0
  689. package/dist/src/components/teams/TeamStatus.js +76 -0
  690. package/dist/src/components/teams/TeamsDialog.js +672 -0
  691. package/dist/src/components/ui/ContextCard.js +5 -0
  692. package/dist/src/components/ui/OrderedList.js +66 -0
  693. package/dist/src/components/ui/OrderedListItem.js +41 -0
  694. package/dist/src/components/ui/TreeSelect.js +300 -0
  695. package/dist/src/components/wizard/WizardDialogLayout.js +47 -0
  696. package/dist/src/components/wizard/WizardNavigationFooter.js +10 -0
  697. package/dist/src/components/wizard/WizardProvider.js +217 -0
  698. package/dist/src/components/wizard/index.js +4 -0
  699. package/dist/src/components/wizard/useWizard.js +9 -0
  700. package/dist/src/constants/apiLimits.js +81 -0
  701. package/dist/src/constants/betas.js +45 -0
  702. package/dist/src/constants/common.js +29 -0
  703. package/dist/src/constants/cyberRiskInstruction.js +24 -0
  704. package/dist/src/constants/errorIds.js +14 -0
  705. package/dist/src/constants/figures.js +38 -0
  706. package/dist/src/constants/files.js +150 -0
  707. package/dist/src/constants/github-app.js +139 -0
  708. package/dist/src/constants/keys.js +10 -0
  709. package/dist/src/constants/messages.js +1 -0
  710. package/dist/src/constants/oauth.js +221 -0
  711. package/dist/src/constants/outputStyles.js +162 -0
  712. package/dist/src/constants/product.js +56 -0
  713. package/dist/src/constants/prompts.js +752 -0
  714. package/dist/src/constants/spinnerVerbs.js +202 -0
  715. package/dist/src/constants/system.js +77 -0
  716. package/dist/src/constants/systemPromptSections.js +39 -0
  717. package/dist/src/constants/toolLimits.js +50 -0
  718. package/dist/src/constants/tools.js +103 -0
  719. package/dist/src/constants/turnCompletionVerbs.js +12 -0
  720. package/dist/src/constants/xml.js +73 -0
  721. package/dist/src/context/QueuedMessageContext.js +51 -0
  722. package/dist/src/context/fpsMetrics.js +22 -0
  723. package/dist/src/context/mailbox.js +35 -0
  724. package/dist/src/context/modalContext.js +34 -0
  725. package/dist/src/context/notifications.js +199 -0
  726. package/dist/src/context/overlayContext.js +149 -0
  727. package/dist/src/context/promptOverlayContext.js +118 -0
  728. package/dist/src/context/stats.js +207 -0
  729. package/dist/src/context/voice.js +74 -0
  730. package/dist/src/context.js +146 -0
  731. package/dist/src/coordinator/coordinatorMode.js +349 -0
  732. package/dist/src/cost-tracker.js +208 -0
  733. package/dist/src/costHook.js +17 -0
  734. package/dist/src/daemon/main.js +16 -0
  735. package/dist/src/daemon/workerRegistry.js +16 -0
  736. package/dist/src/dialogLaunchers.js +68 -0
  737. package/dist/src/entrypoints/agentSdkTypes.js +202 -0
  738. package/dist/src/entrypoints/cli.js +252 -0
  739. package/dist/src/entrypoints/init.js +265 -0
  740. package/dist/src/entrypoints/mcp.js +142 -0
  741. package/dist/src/entrypoints/sandboxTypes.js +112 -0
  742. package/dist/src/entrypoints/sdk/controlSchemas.js +452 -0
  743. package/dist/src/entrypoints/sdk/controlTypes.js +1 -0
  744. package/dist/src/entrypoints/sdk/coreSchemas.js +1331 -0
  745. package/dist/src/entrypoints/sdk/coreTypes.generated.js +1 -0
  746. package/dist/src/entrypoints/sdk/coreTypes.js +49 -0
  747. package/dist/src/entrypoints/sdk/runtimeTypes.js +1 -0
  748. package/dist/src/entrypoints/sdk/toolTypes.js +1 -0
  749. package/dist/src/environment-runner/main.js +16 -0
  750. package/dist/src/history.js +386 -0
  751. package/dist/src/hooks/fileSuggestions.js +635 -0
  752. package/dist/src/hooks/notifs/useAutoModeUnavailableNotification.js +47 -0
  753. package/dist/src/hooks/notifs/useCanSwitchToExistingSubscription.js +57 -0
  754. package/dist/src/hooks/notifs/useDeprecationWarningNotification.js +43 -0
  755. package/dist/src/hooks/notifs/useFastModeNotification.js +164 -0
  756. package/dist/src/hooks/notifs/useIDEStatusIndicator.js +174 -0
  757. package/dist/src/hooks/notifs/useInstallMessages.js +27 -0
  758. package/dist/src/hooks/notifs/useLspInitializationNotification.js +144 -0
  759. package/dist/src/hooks/notifs/useMcpConnectivityStatus.js +80 -0
  760. package/dist/src/hooks/notifs/useModelMigrationNotifications.js +53 -0
  761. package/dist/src/hooks/notifs/useNpmDeprecationNotification.js +24 -0
  762. package/dist/src/hooks/notifs/usePluginAutoupdateNotification.js +82 -0
  763. package/dist/src/hooks/notifs/usePluginInstallationStatus.js +127 -0
  764. package/dist/src/hooks/notifs/useRateLimitWarningNotification.js +118 -0
  765. package/dist/src/hooks/notifs/useSettingsErrors.js +64 -0
  766. package/dist/src/hooks/notifs/useStartupNotification.js +33 -0
  767. package/dist/src/hooks/notifs/useTeammateShutdownNotification.js +64 -0
  768. package/dist/src/hooks/renderPlaceholder.js +26 -0
  769. package/dist/src/hooks/toolPermission/PermissionContext.js +211 -0
  770. package/dist/src/hooks/toolPermission/handlers/coordinatorHandler.js +44 -0
  771. package/dist/src/hooks/toolPermission/handlers/interactiveHandler.js +397 -0
  772. package/dist/src/hooks/toolPermission/handlers/swarmWorkerHandler.js +108 -0
  773. package/dist/src/hooks/toolPermission/permissionLogging.js +145 -0
  774. package/dist/src/hooks/unifiedSuggestions.js +130 -0
  775. package/dist/src/hooks/useAfterFirstRender.js +12 -0
  776. package/dist/src/hooks/useApiKeyVerification.js +63 -0
  777. package/dist/src/hooks/useArrowKeyHistory.js +203 -0
  778. package/dist/src/hooks/useAssistantHistory.js +194 -0
  779. package/dist/src/hooks/useAwaySummary.js +105 -0
  780. package/dist/src/hooks/useBackgroundTaskNavigation.js +204 -0
  781. package/dist/src/hooks/useBlink.js +28 -0
  782. package/dist/src/hooks/useCanUseTool.js +192 -0
  783. package/dist/src/hooks/useCancelRequest.js +195 -0
  784. package/dist/src/hooks/useChromeExtensionNotification.js +49 -0
  785. package/dist/src/hooks/useClaudeCodeHintRecommendation.js +117 -0
  786. package/dist/src/hooks/useClipboardImageHint.js +59 -0
  787. package/dist/src/hooks/useCommandKeybindings.js +87 -0
  788. package/dist/src/hooks/useCommandQueue.js +10 -0
  789. package/dist/src/hooks/useCopyOnSelect.js +88 -0
  790. package/dist/src/hooks/useDeferredHookMessages.js +43 -0
  791. package/dist/src/hooks/useDiffData.js +69 -0
  792. package/dist/src/hooks/useDiffInIDE.js +252 -0
  793. package/dist/src/hooks/useDirectConnect.js +150 -0
  794. package/dist/src/hooks/useDoublePress.js +44 -0
  795. package/dist/src/hooks/useDynamicConfig.js +17 -0
  796. package/dist/src/hooks/useElapsedTime.js +25 -0
  797. package/dist/src/hooks/useExitOnCtrlCD.js +57 -0
  798. package/dist/src/hooks/useExitOnCtrlCDWithKeybindings.js +17 -0
  799. package/dist/src/hooks/useFileHistorySnapshotInit.js +14 -0
  800. package/dist/src/hooks/useGlobalKeybindings.js +215 -0
  801. package/dist/src/hooks/useHistorySearch.js +241 -0
  802. package/dist/src/hooks/useIDEIntegration.js +56 -0
  803. package/dist/src/hooks/useIdeAtMentioned.js +51 -0
  804. package/dist/src/hooks/useIdeConnectionStatus.js +21 -0
  805. package/dist/src/hooks/useIdeLogging.js +29 -0
  806. package/dist/src/hooks/useIdeSelection.js +106 -0
  807. package/dist/src/hooks/useInboxPoller.js +709 -0
  808. package/dist/src/hooks/useInputBuffer.js +73 -0
  809. package/dist/src/hooks/useIssueFlagBanner.js +115 -0
  810. package/dist/src/hooks/useLogMessages.js +98 -0
  811. package/dist/src/hooks/useLspPluginRecommendation.js +176 -0
  812. package/dist/src/hooks/useMailboxBridge.js +15 -0
  813. package/dist/src/hooks/useMainLoopModel.js +25 -0
  814. package/dist/src/hooks/useManagePlugins.js +261 -0
  815. package/dist/src/hooks/useMemoryUsage.js +28 -0
  816. package/dist/src/hooks/useMergedClients.js +11 -0
  817. package/dist/src/hooks/useMergedCommands.js +10 -0
  818. package/dist/src/hooks/useMergedTools.js +32 -0
  819. package/dist/src/hooks/useMinDisplayTime.js +26 -0
  820. package/dist/src/hooks/useNotifyAfterTimeout.js +51 -0
  821. package/dist/src/hooks/useOfficialMarketplaceNotification.js +46 -0
  822. package/dist/src/hooks/usePasteHandler.js +188 -0
  823. package/dist/src/hooks/usePluginRecommendationBase.js +101 -0
  824. package/dist/src/hooks/usePrStatus.js +91 -0
  825. package/dist/src/hooks/usePromptSuggestion.js +128 -0
  826. package/dist/src/hooks/usePromptsFromClaudeInChrome.js +66 -0
  827. package/dist/src/hooks/useQueueProcessor.js +46 -0
  828. package/dist/src/hooks/useRemoteSession.js +431 -0
  829. package/dist/src/hooks/useReplBridge.js +717 -0
  830. package/dist/src/hooks/useSSHSession.js +167 -0
  831. package/dist/src/hooks/useScheduledTasks.js +104 -0
  832. package/dist/src/hooks/useSearchInput.js +302 -0
  833. package/dist/src/hooks/useSessionBackgrounding.js +132 -0
  834. package/dist/src/hooks/useSettings.js +10 -0
  835. package/dist/src/hooks/useSettingsChange.js +13 -0
  836. package/dist/src/hooks/useSkillImprovementSurvey.js +69 -0
  837. package/dist/src/hooks/useSkillsChange.js +51 -0
  838. package/dist/src/hooks/useSwarmInitialization.js +67 -0
  839. package/dist/src/hooks/useSwarmPermissionPoller.js +215 -0
  840. package/dist/src/hooks/useTaskListWatcher.js +157 -0
  841. package/dist/src/hooks/useTasksV2.js +220 -0
  842. package/dist/src/hooks/useTeammateViewAutoExit.js +55 -0
  843. package/dist/src/hooks/useTelegramMirror.js +47 -0
  844. package/dist/src/hooks/useTeleportResume.js +81 -0
  845. package/dist/src/hooks/useTerminalSize.js +9 -0
  846. package/dist/src/hooks/useTextInput.js +397 -0
  847. package/dist/src/hooks/useTimeout.js +10 -0
  848. package/dist/src/hooks/useTurnDiffs.js +160 -0
  849. package/dist/src/hooks/useTypeahead.js +1617 -0
  850. package/dist/src/hooks/useUpdateNotification.js +22 -0
  851. package/dist/src/hooks/useVimInput.js +232 -0
  852. package/dist/src/hooks/useVirtualScroll.js +627 -0
  853. package/dist/src/hooks/useVoice.js +954 -0
  854. package/dist/src/hooks/useVoiceEnabled.js +21 -0
  855. package/dist/src/hooks/useVoiceIntegration.js +631 -0
  856. package/dist/src/hooks/useWhatsAppMirror.js +46 -0
  857. package/dist/src/index.js +18 -0
  858. package/dist/src/ink/Ansi.js +269 -0
  859. package/dist/src/ink/bidi.js +117 -0
  860. package/dist/src/ink/clearTerminal.js +58 -0
  861. package/dist/src/ink/colorize.js +198 -0
  862. package/dist/src/ink/components/AlternateScreen.js +74 -0
  863. package/dist/src/ink/components/App.js +558 -0
  864. package/dist/src/ink/components/AppContext.js +11 -0
  865. package/dist/src/ink/components/Box.js +153 -0
  866. package/dist/src/ink/components/Button.js +166 -0
  867. package/dist/src/ink/components/ClockContext.js +108 -0
  868. package/dist/src/ink/components/CursorDeclarationContext.js +3 -0
  869. package/dist/src/ink/components/ErrorOverview.js +49 -0
  870. package/dist/src/ink/components/Link.js +33 -0
  871. package/dist/src/ink/components/Newline.js +29 -0
  872. package/dist/src/ink/components/NoSelect.js +56 -0
  873. package/dist/src/ink/components/RawAnsi.js +45 -0
  874. package/dist/src/ink/components/ScrollBox.js +170 -0
  875. package/dist/src/ink/components/Spacer.js +19 -0
  876. package/dist/src/ink/components/StdinContext.js +16 -0
  877. package/dist/src/ink/components/TerminalFocusContext.js +45 -0
  878. package/dist/src/ink/components/TerminalSizeContext.js +3 -0
  879. package/dist/src/ink/components/Text.js +194 -0
  880. package/dist/src/ink/constants.js +2 -0
  881. package/dist/src/ink/devtools.js +16 -0
  882. package/dist/src/ink/dom.js +298 -0
  883. package/dist/src/ink/events/click-event.js +36 -0
  884. package/dist/src/ink/events/dispatcher.js +172 -0
  885. package/dist/src/ink/events/emitter.js +31 -0
  886. package/dist/src/ink/events/event-handlers.js +30 -0
  887. package/dist/src/ink/events/event.js +9 -0
  888. package/dist/src/ink/events/focus-event.js +16 -0
  889. package/dist/src/ink/events/input-event.js +161 -0
  890. package/dist/src/ink/events/keyboard-event.js +45 -0
  891. package/dist/src/ink/events/terminal-event.js +78 -0
  892. package/dist/src/ink/events/terminal-focus-event.js +15 -0
  893. package/dist/src/ink/focus.js +158 -0
  894. package/dist/src/ink/frame.js +30 -0
  895. package/dist/src/ink/get-max-width.js +23 -0
  896. package/dist/src/ink/hit-test.js +113 -0
  897. package/dist/src/ink/hooks/use-animation-frame.js +48 -0
  898. package/dist/src/ink/hooks/use-app.js +7 -0
  899. package/dist/src/ink/hooks/use-declared-cursor.js +60 -0
  900. package/dist/src/ink/hooks/use-input.js +70 -0
  901. package/dist/src/ink/hooks/use-interval.js +54 -0
  902. package/dist/src/ink/hooks/use-search-highlight.js +32 -0
  903. package/dist/src/ink/hooks/use-selection.js +60 -0
  904. package/dist/src/ink/hooks/use-stdin.js +7 -0
  905. package/dist/src/ink/hooks/use-tab-status.js +57 -0
  906. package/dist/src/ink/hooks/use-terminal-focus.js +15 -0
  907. package/dist/src/ink/hooks/use-terminal-title.js +29 -0
  908. package/dist/src/ink/hooks/use-terminal-viewport.js +77 -0
  909. package/dist/src/ink/ink.js +1644 -0
  910. package/dist/src/ink/instances.js +7 -0
  911. package/dist/src/ink/layout/engine.js +4 -0
  912. package/dist/src/ink/layout/geometry.js +61 -0
  913. package/dist/src/ink/layout/node.js +62 -0
  914. package/dist/src/ink/layout/yoga.js +237 -0
  915. package/dist/src/ink/line-width-cache.js +19 -0
  916. package/dist/src/ink/log-update.js +583 -0
  917. package/dist/src/ink/measure-element.js +8 -0
  918. package/dist/src/ink/measure-text.js +35 -0
  919. package/dist/src/ink/node-cache.js +30 -0
  920. package/dist/src/ink/optimizer.js +81 -0
  921. package/dist/src/ink/output.js +556 -0
  922. package/dist/src/ink/parse-keypress.js +695 -0
  923. package/dist/src/ink/reconciler.js +384 -0
  924. package/dist/src/ink/render-border.js +134 -0
  925. package/dist/src/ink/render-node-to-output.js +1216 -0
  926. package/dist/src/ink/render-to-screen.js +171 -0
  927. package/dist/src/ink/renderer.js +129 -0
  928. package/dist/src/ink/root.js +80 -0
  929. package/dist/src/ink/screen.js +1132 -0
  930. package/dist/src/ink/searchHighlight.js +78 -0
  931. package/dist/src/ink/selection.js +792 -0
  932. package/dist/src/ink/squash-text-nodes.js +56 -0
  933. package/dist/src/ink/stringWidth.js +200 -0
  934. package/dist/src/ink/styles.js +299 -0
  935. package/dist/src/ink/supports-hyperlinks.js +40 -0
  936. package/dist/src/ink/tabstops.js +39 -0
  937. package/dist/src/ink/terminal-focus-state.js +35 -0
  938. package/dist/src/ink/terminal-querier.js +173 -0
  939. package/dist/src/ink/terminal.js +208 -0
  940. package/dist/src/ink/termio/ansi.js +70 -0
  941. package/dist/src/ink/termio/csi.js +260 -0
  942. package/dist/src/ink/termio/dec.js +53 -0
  943. package/dist/src/ink/termio/esc.js +55 -0
  944. package/dist/src/ink/termio/osc.js +432 -0
  945. package/dist/src/ink/termio/parser.js +356 -0
  946. package/dist/src/ink/termio/sgr.js +292 -0
  947. package/dist/src/ink/termio/tokenize.js +264 -0
  948. package/dist/src/ink/termio/types.js +55 -0
  949. package/dist/src/ink/termio.js +24 -0
  950. package/dist/src/ink/useTerminalNotification.js +57 -0
  951. package/dist/src/ink/warn.js +10 -0
  952. package/dist/src/ink/widest-line.js +14 -0
  953. package/dist/src/ink/wrap-text.js +54 -0
  954. package/dist/src/ink/wrapAnsi.js +6 -0
  955. package/dist/src/ink.js +50 -0
  956. package/dist/src/interactiveHelpers.js +317 -0
  957. package/dist/src/keybindings/KeybindingContext.js +184 -0
  958. package/dist/src/keybindings/KeybindingProviderSetup.js +259 -0
  959. package/dist/src/keybindings/defaultBindings.js +333 -0
  960. package/dist/src/keybindings/loadUserBindings.js +393 -0
  961. package/dist/src/keybindings/match.js +111 -0
  962. package/dist/src/keybindings/parser.js +184 -0
  963. package/dist/src/keybindings/reservedShortcuts.js +109 -0
  964. package/dist/src/keybindings/resolver.js +182 -0
  965. package/dist/src/keybindings/schema.js +205 -0
  966. package/dist/src/keybindings/shortcutFormat.js +48 -0
  967. package/dist/src/keybindings/template.js +40 -0
  968. package/dist/src/keybindings/useKeybinding.js +161 -0
  969. package/dist/src/keybindings/useShortcutDisplay.js +43 -0
  970. package/dist/src/keybindings/validate.js +395 -0
  971. package/dist/src/main.js +4080 -0
  972. package/dist/src/memdir/findRelevantMemories.js +101 -0
  973. package/dist/src/memdir/memdir.js +408 -0
  974. package/dist/src/memdir/memoryAge.js +52 -0
  975. package/dist/src/memdir/memoryScan.js +65 -0
  976. package/dist/src/memdir/memoryTypes.js +260 -0
  977. package/dist/src/memdir/paths.js +236 -0
  978. package/dist/src/memdir/teamMemPaths.js +261 -0
  979. package/dist/src/memdir/teamMemPrompts.js +82 -0
  980. package/dist/src/migrations/migrateAutoUpdatesToSettings.js +47 -0
  981. package/dist/src/migrations/migrateBypassPermissionsAcceptedToSettings.js +32 -0
  982. package/dist/src/migrations/migrateEnableAllProjectMcpServersToSettings.js +83 -0
  983. package/dist/src/migrations/migrateFennecToOpus.js +39 -0
  984. package/dist/src/migrations/migrateLegacyOpusToCurrent.js +44 -0
  985. package/dist/src/migrations/migrateOpusToOpus1m.js +31 -0
  986. package/dist/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.js +23 -0
  987. package/dist/src/migrations/migrateSonnet1mToSonnet45.js +38 -0
  988. package/dist/src/migrations/migrateSonnet45ToSonnet46.js +48 -0
  989. package/dist/src/migrations/resetAutoModeOptInForDefaultOffer.js +47 -0
  990. package/dist/src/migrations/resetProToOpusDefault.js +46 -0
  991. package/dist/src/mirrors/shared.js +186 -0
  992. package/dist/src/moreright/useMoreRight.js +13 -0
  993. package/dist/src/native-ts/color-diff/index.js +821 -0
  994. package/dist/src/native-ts/file-index/index.js +328 -0
  995. package/dist/src/native-ts/yoga-layout/enums.js +101 -0
  996. package/dist/src/native-ts/yoga-layout/index.js +2113 -0
  997. package/dist/src/outputStyles/loadOutputStylesDir.js +73 -0
  998. package/dist/src/plugins/builtinPlugins.js +132 -0
  999. package/dist/src/plugins/bundled/index.js +22 -0
  1000. package/dist/src/projectOnboardingState.js +61 -0
  1001. package/dist/src/query/config.js +17 -0
  1002. package/dist/src/query/deps.js +12 -0
  1003. package/dist/src/query/stopHooks.js +334 -0
  1004. package/dist/src/query/tokenBudget.js +49 -0
  1005. package/dist/src/query.js +1330 -0
  1006. package/dist/src/recovery/bunBundleShim.js +11 -0
  1007. package/dist/src/remote/RemoteSessionManager.js +195 -0
  1008. package/dist/src/remote/SessionsWebSocket.js +305 -0
  1009. package/dist/src/remote/remotePermissionBridge.js +70 -0
  1010. package/dist/src/remote/sdkMessageAdapter.js +227 -0
  1011. package/dist/src/replLauncher.js +6 -0
  1012. package/dist/src/schemas/hooks.js +174 -0
  1013. package/dist/src/screens/Doctor.js +581 -0
  1014. package/dist/src/screens/REPL.js +4434 -0
  1015. package/dist/src/screens/ResumeConversation.js +341 -0
  1016. package/dist/src/self-hosted-runner/main.js +16 -0
  1017. package/dist/src/server/backends/dangerousBackend.js +16 -0
  1018. package/dist/src/server/connectHeadless.js +16 -0
  1019. package/dist/src/server/createDirectConnectSession.js +62 -0
  1020. package/dist/src/server/directConnectManager.js +153 -0
  1021. package/dist/src/server/lockfile.js +16 -0
  1022. package/dist/src/server/parseConnectUrl.js +16 -0
  1023. package/dist/src/server/server.js +16 -0
  1024. package/dist/src/server/serverBanner.js +16 -0
  1025. package/dist/src/server/serverLog.js +16 -0
  1026. package/dist/src/server/sessionManager.js +16 -0
  1027. package/dist/src/server/types.js +7 -0
  1028. package/dist/src/services/AgentSummary/agentSummary.js +147 -0
  1029. package/dist/src/services/MagicDocs/magicDocs.js +193 -0
  1030. package/dist/src/services/MagicDocs/prompts.js +110 -0
  1031. package/dist/src/services/PromptSuggestion/promptSuggestion.js +402 -0
  1032. package/dist/src/services/PromptSuggestion/speculation.js +643 -0
  1033. package/dist/src/services/SessionMemory/prompts.js +254 -0
  1034. package/dist/src/services/SessionMemory/sessionMemory.js +358 -0
  1035. package/dist/src/services/SessionMemory/sessionMemoryUtils.js +157 -0
  1036. package/dist/src/services/analytics/config.js +33 -0
  1037. package/dist/src/services/analytics/datadog.js +259 -0
  1038. package/dist/src/services/analytics/firstPartyEventLogger.js +342 -0
  1039. package/dist/src/services/analytics/firstPartyEventLoggingExporter.js +594 -0
  1040. package/dist/src/services/analytics/growthbook.js +952 -0
  1041. package/dist/src/services/analytics/index.js +114 -0
  1042. package/dist/src/services/analytics/metadata.js +698 -0
  1043. package/dist/src/services/analytics/sink.js +95 -0
  1044. package/dist/src/services/analytics/sinkKillswitch.js +19 -0
  1045. package/dist/src/services/api/adminRequests.js +57 -0
  1046. package/dist/src/services/api/bootstrap.js +149 -0
  1047. package/dist/src/services/api/claude.js +2461 -0
  1048. package/dist/src/services/api/client.js +325 -0
  1049. package/dist/src/services/api/dumpPrompts.js +174 -0
  1050. package/dist/src/services/api/emptyUsage.js +20 -0
  1051. package/dist/src/services/api/errorUtils.js +203 -0
  1052. package/dist/src/services/api/errors.js +934 -0
  1053. package/dist/src/services/api/filesApi.js +523 -0
  1054. package/dist/src/services/api/firstTokenDate.js +49 -0
  1055. package/dist/src/services/api/grove.js +272 -0
  1056. package/dist/src/services/api/index.js +23 -0
  1057. package/dist/src/services/api/logging.js +484 -0
  1058. package/dist/src/services/api/metricsOptOut.js +129 -0
  1059. package/dist/src/services/api/openai.js +1187 -0
  1060. package/dist/src/services/api/openrouter.js +30 -0
  1061. package/dist/src/services/api/overageCreditGrant.js +123 -0
  1062. package/dist/src/services/api/promptCacheBreakDetection.js +510 -0
  1063. package/dist/src/services/api/referral.js +219 -0
  1064. package/dist/src/services/api/sessionIngress.js +358 -0
  1065. package/dist/src/services/api/ultrareviewQuota.js +29 -0
  1066. package/dist/src/services/api/usage.js +31 -0
  1067. package/dist/src/services/api/withRetry.js +599 -0
  1068. package/dist/src/services/autoDream/autoDream.js +244 -0
  1069. package/dist/src/services/autoDream/config.js +17 -0
  1070. package/dist/src/services/autoDream/consolidationLock.js +122 -0
  1071. package/dist/src/services/autoDream/consolidationPrompt.js +56 -0
  1072. package/dist/src/services/awaySummary.js +61 -0
  1073. package/dist/src/services/claudeAiLimits.js +331 -0
  1074. package/dist/src/services/claudeAiLimitsHook.js +15 -0
  1075. package/dist/src/services/compact/apiMicrocompact.js +97 -0
  1076. package/dist/src/services/compact/autoCompact.js +236 -0
  1077. package/dist/src/services/compact/cachedMicrocompact.js +16 -0
  1078. package/dist/src/services/compact/compact.js +1258 -0
  1079. package/dist/src/services/compact/compactWarningHook.js +12 -0
  1080. package/dist/src/services/compact/compactWarningState.js +15 -0
  1081. package/dist/src/services/compact/grouping.js +58 -0
  1082. package/dist/src/services/compact/microCompact.js +414 -0
  1083. package/dist/src/services/compact/postCompactCleanup.js +72 -0
  1084. package/dist/src/services/compact/prompt.js +327 -0
  1085. package/dist/src/services/compact/sessionMemoryCompact.js +467 -0
  1086. package/dist/src/services/compact/timeBasedMCConfig.js +11 -0
  1087. package/dist/src/services/diagnosticTracking.js +282 -0
  1088. package/dist/src/services/extractMemories/extractMemories.js +444 -0
  1089. package/dist/src/services/extractMemories/prompts.js +129 -0
  1090. package/dist/src/services/internalLogging.js +68 -0
  1091. package/dist/src/services/limits/adapters/claude.js +219 -0
  1092. package/dist/src/services/limits/adapters/minimax.js +177 -0
  1093. package/dist/src/services/limits/adapters/ollama.js +189 -0
  1094. package/dist/src/services/limits/adapters/openai.js +167 -0
  1095. package/dist/src/services/limits/adapters/openrouter.js +166 -0
  1096. package/dist/src/services/limits/adapters/zai.js +154 -0
  1097. package/dist/src/services/limits/index.js +2 -0
  1098. package/dist/src/services/limits/registry.js +179 -0
  1099. package/dist/src/services/limits/sessionCounter.js +168 -0
  1100. package/dist/src/services/limits/types.js +1 -0
  1101. package/dist/src/services/lsp/LSPClient.js +306 -0
  1102. package/dist/src/services/lsp/LSPDiagnosticRegistry.js +277 -0
  1103. package/dist/src/services/lsp/LSPServerInstance.js +390 -0
  1104. package/dist/src/services/lsp/LSPServerManager.js +305 -0
  1105. package/dist/src/services/lsp/config.js +57 -0
  1106. package/dist/src/services/lsp/manager.js +246 -0
  1107. package/dist/src/services/lsp/passiveFeedback.js +226 -0
  1108. package/dist/src/services/mcp/InProcessTransport.js +54 -0
  1109. package/dist/src/services/mcp/MCPConnectionManager.js +50 -0
  1110. package/dist/src/services/mcp/SdkControlTransport.js +115 -0
  1111. package/dist/src/services/mcp/auth.js +1882 -0
  1112. package/dist/src/services/mcp/channelAllowlist.js +57 -0
  1113. package/dist/src/services/mcp/channelNotification.js +236 -0
  1114. package/dist/src/services/mcp/channelPermissions.js +192 -0
  1115. package/dist/src/services/mcp/claudeai.js +123 -0
  1116. package/dist/src/services/mcp/client.js +2480 -0
  1117. package/dist/src/services/mcp/config.js +1277 -0
  1118. package/dist/src/services/mcp/elicitationHandler.js +192 -0
  1119. package/dist/src/services/mcp/envExpansion.js +30 -0
  1120. package/dist/src/services/mcp/headersHelper.js +94 -0
  1121. package/dist/src/services/mcp/mcpStringUtils.js +85 -0
  1122. package/dist/src/services/mcp/normalization.js +21 -0
  1123. package/dist/src/services/mcp/oauthPort.js +69 -0
  1124. package/dist/src/services/mcp/officialRegistry.js +58 -0
  1125. package/dist/src/services/mcp/types.js +94 -0
  1126. package/dist/src/services/mcp/useManageMCPConnections.js +820 -0
  1127. package/dist/src/services/mcp/utils.js +433 -0
  1128. package/dist/src/services/mcp/vscodeSdkMcp.js +69 -0
  1129. package/dist/src/services/mcp/xaa.js +342 -0
  1130. package/dist/src/services/mcp/xaaIdpLogin.js +377 -0
  1131. package/dist/src/services/mcpServerApproval.js +29 -0
  1132. package/dist/src/services/mockRateLimits.js +666 -0
  1133. package/dist/src/services/notifier.js +114 -0
  1134. package/dist/src/services/oauth/auth-code-listener.js +236 -0
  1135. package/dist/src/services/oauth/client.js +545 -0
  1136. package/dist/src/services/oauth/crypto.js +19 -0
  1137. package/dist/src/services/oauth/getOauthProfile.js +48 -0
  1138. package/dist/src/services/oauth/index.js +152 -0
  1139. package/dist/src/services/oauth/types.js +1 -0
  1140. package/dist/src/services/orchestration/execution/AgentTaskExecutor.js +315 -0
  1141. package/dist/src/services/orchestration/execution/OrchestrationExecutionRuntime.js +1147 -0
  1142. package/dist/src/services/orchestration/execution/index.js +2 -0
  1143. package/dist/src/services/orchestration/execution/types.js +1 -0
  1144. package/dist/src/services/orchestration/global/GlobalOrchestratorRuntime.js +140 -0
  1145. package/dist/src/services/orchestration/global/index.js +3 -0
  1146. package/dist/src/services/orchestration/global/reporting.js +541 -0
  1147. package/dist/src/services/orchestration/global/types.js +1 -0
  1148. package/dist/src/services/orchestration/index.js +4 -0
  1149. package/dist/src/services/orchestration/policy/index.js +2 -0
  1150. package/dist/src/services/orchestration/policy/scoring.js +291 -0
  1151. package/dist/src/services/orchestration/policy/types.js +1 -0
  1152. package/dist/src/services/orchestration/squad/SquadOrchestratorRuntime.js +198 -0
  1153. package/dist/src/services/orchestration/squad/index.js +3 -0
  1154. package/dist/src/services/orchestration/squad/reporting.js +525 -0
  1155. package/dist/src/services/orchestration/squad/types.js +1 -0
  1156. package/dist/src/services/plugins/PluginInstallationManager.js +139 -0
  1157. package/dist/src/services/plugins/pluginCliCommands.js +230 -0
  1158. package/dist/src/services/plugins/pluginOperations.js +826 -0
  1159. package/dist/src/services/policyLimits/index.js +547 -0
  1160. package/dist/src/services/policyLimits/types.js +9 -0
  1161. package/dist/src/services/preventSleep.js +143 -0
  1162. package/dist/src/services/rateLimitMessages.js +271 -0
  1163. package/dist/src/services/rateLimitMocking.js +91 -0
  1164. package/dist/src/services/remoteManagedSettings/index.js +534 -0
  1165. package/dist/src/services/remoteManagedSettings/securityCheck.js +59 -0
  1166. package/dist/src/services/remoteManagedSettings/syncCache.js +90 -0
  1167. package/dist/src/services/remoteManagedSettings/syncCacheState.js +89 -0
  1168. package/dist/src/services/remoteManagedSettings/types.js +12 -0
  1169. package/dist/src/services/settingsSync/index.js +478 -0
  1170. package/dist/src/services/settingsSync/types.js +35 -0
  1171. package/dist/src/services/teamMemorySync/index.js +976 -0
  1172. package/dist/src/services/teamMemorySync/secretScanner.js +275 -0
  1173. package/dist/src/services/teamMemorySync/teamMemSecretGuard.js +35 -0
  1174. package/dist/src/services/teamMemorySync/types.js +47 -0
  1175. package/dist/src/services/teamMemorySync/watcher.js +326 -0
  1176. package/dist/src/services/tips/tipHistory.js +17 -0
  1177. package/dist/src/services/tips/tipRegistry.js +589 -0
  1178. package/dist/src/services/tips/tipScheduler.js +40 -0
  1179. package/dist/src/services/tokenEstimation.js +365 -0
  1180. package/dist/src/services/toolUseSummary/toolUseSummaryGenerator.js +87 -0
  1181. package/dist/src/services/tools/StreamingToolExecutor.js +413 -0
  1182. package/dist/src/services/tools/toolExecution.js +1218 -0
  1183. package/dist/src/services/tools/toolHooks.js +454 -0
  1184. package/dist/src/services/tools/toolOrchestration.js +110 -0
  1185. package/dist/src/services/vcr.js +291 -0
  1186. package/dist/src/services/voice.js +394 -0
  1187. package/dist/src/services/voiceKeyterms.js +94 -0
  1188. package/dist/src/services/voiceStreamSTT.js +406 -0
  1189. package/dist/src/setup.js +349 -0
  1190. package/dist/src/skills/bundled/batch.js +114 -0
  1191. package/dist/src/skills/bundled/claudeApi.js +145 -0
  1192. package/dist/src/skills/bundled/claudeApiContent.js +14 -0
  1193. package/dist/src/skills/bundled/claudeInChrome.js +27 -0
  1194. package/dist/src/skills/bundled/debug.js +99 -0
  1195. package/dist/src/skills/bundled/index.js +5 -0
  1196. package/dist/src/skills/bundled/keybindings.js +292 -0
  1197. package/dist/src/skills/bundled/loop.js +81 -0
  1198. package/dist/src/skills/bundled/loremIpsum.js +266 -0
  1199. package/dist/src/skills/bundled/remember.js +75 -0
  1200. package/dist/src/skills/bundled/scheduleRemoteAgents.js +373 -0
  1201. package/dist/src/skills/bundled/simplify.js +66 -0
  1202. package/dist/src/skills/bundled/skillify.js +184 -0
  1203. package/dist/src/skills/bundled/stuck.js +75 -0
  1204. package/dist/src/skills/bundled/updateConfig.js +463 -0
  1205. package/dist/src/skills/bundled/verify.js +25 -0
  1206. package/dist/src/skills/bundled/verifyContent.js +7 -0
  1207. package/dist/src/skills/bundledSkills.js +159 -0
  1208. package/dist/src/skills/loadSkillsDir.js +751 -0
  1209. package/dist/src/skills/mcpSkillBuilders.js +10 -0
  1210. package/dist/src/ssh/createSSHSession.js +16 -0
  1211. package/dist/src/state/AppState.js +184 -0
  1212. package/dist/src/state/AppStateStore.js +120 -0
  1213. package/dist/src/state/onChangeAppState.js +132 -0
  1214. package/dist/src/state/selectors.js +51 -0
  1215. package/dist/src/state/store.js +21 -0
  1216. package/dist/src/state/teammateViewHelpers.js +124 -0
  1217. package/dist/src/tasks/DreamTask/DreamTask.js +99 -0
  1218. package/dist/src/tasks/InProcessTeammateTask/InProcessTeammateTask.js +116 -0
  1219. package/dist/src/tasks/InProcessTeammateTask/types.js +35 -0
  1220. package/dist/src/tasks/LocalAgentTask/LocalAgentTask.js +507 -0
  1221. package/dist/src/tasks/LocalMainSessionTask.js +338 -0
  1222. package/dist/src/tasks/LocalShellTask/LocalShellTask.js +475 -0
  1223. package/dist/src/tasks/LocalShellTask/guards.js +9 -0
  1224. package/dist/src/tasks/LocalShellTask/killShellTasks.js +59 -0
  1225. package/dist/src/tasks/RemoteAgentTask/RemoteAgentTask.js +742 -0
  1226. package/dist/src/tasks/pillLabel.js +69 -0
  1227. package/dist/src/tasks/stopTask.js +67 -0
  1228. package/dist/src/tasks/types.js +18 -0
  1229. package/dist/src/tasks.js +39 -0
  1230. package/dist/src/telegram/bridge.js +329 -0
  1231. package/dist/src/telegram/config.js +89 -0
  1232. package/dist/src/telegram/mirror.js +91 -0
  1233. package/dist/src/tools/AgentTool/AgentTool.js +1222 -0
  1234. package/dist/src/tools/AgentTool/UI.js +592 -0
  1235. package/dist/src/tools/AgentTool/agentColorManager.js +43 -0
  1236. package/dist/src/tools/AgentTool/agentDisplay.js +72 -0
  1237. package/dist/src/tools/AgentTool/agentMemory.js +139 -0
  1238. package/dist/src/tools/AgentTool/agentMemorySnapshot.js +136 -0
  1239. package/dist/src/tools/AgentTool/agentToolUtils.js +456 -0
  1240. package/dist/src/tools/AgentTool/built-in/claudeCodeGuideAgent.js +175 -0
  1241. package/dist/src/tools/AgentTool/built-in/exploreAgent.js +76 -0
  1242. package/dist/src/tools/AgentTool/built-in/generalPurposeAgent.js +28 -0
  1243. package/dist/src/tools/AgentTool/built-in/planAgent.js +87 -0
  1244. package/dist/src/tools/AgentTool/built-in/statuslineSetup.js +140 -0
  1245. package/dist/src/tools/AgentTool/built-in/verificationAgent.js +146 -0
  1246. package/dist/src/tools/AgentTool/builtInAgents.js +59 -0
  1247. package/dist/src/tools/AgentTool/constants.js +11 -0
  1248. package/dist/src/tools/AgentTool/forkSubagent.js +177 -0
  1249. package/dist/src/tools/AgentTool/loadAgentsDir.js +497 -0
  1250. package/dist/src/tools/AgentTool/prompt.js +262 -0
  1251. package/dist/src/tools/AgentTool/resumeAgent.js +182 -0
  1252. package/dist/src/tools/AgentTool/runAgent.js +629 -0
  1253. package/dist/src/tools/AskUserQuestionTool/AskUserQuestionTool.js +237 -0
  1254. package/dist/src/tools/AskUserQuestionTool/prompt.js +38 -0
  1255. package/dist/src/tools/BashTool/BashTool.js +1008 -0
  1256. package/dist/src/tools/BashTool/BashToolResultMessage.js +168 -0
  1257. package/dist/src/tools/BashTool/UI.js +133 -0
  1258. package/dist/src/tools/BashTool/bashCommandHelpers.js +184 -0
  1259. package/dist/src/tools/BashTool/bashPermissions.js +2023 -0
  1260. package/dist/src/tools/BashTool/bashSecurity.js +2267 -0
  1261. package/dist/src/tools/BashTool/commandSemantics.js +105 -0
  1262. package/dist/src/tools/BashTool/commentLabel.js +14 -0
  1263. package/dist/src/tools/BashTool/destructiveCommandWarning.js +88 -0
  1264. package/dist/src/tools/BashTool/modeValidation.js +86 -0
  1265. package/dist/src/tools/BashTool/pathValidation.js +1080 -0
  1266. package/dist/src/tools/BashTool/prompt.js +334 -0
  1267. package/dist/src/tools/BashTool/readOnlyValidation.js +1794 -0
  1268. package/dist/src/tools/BashTool/sedEditParser.js +282 -0
  1269. package/dist/src/tools/BashTool/sedValidation.js +580 -0
  1270. package/dist/src/tools/BashTool/shouldUseSandbox.js +125 -0
  1271. package/dist/src/tools/BashTool/toolName.js +2 -0
  1272. package/dist/src/tools/BashTool/utils.js +180 -0
  1273. package/dist/src/tools/BriefTool/BriefTool.js +172 -0
  1274. package/dist/src/tools/BriefTool/UI.js +66 -0
  1275. package/dist/src/tools/BriefTool/attachments.js +86 -0
  1276. package/dist/src/tools/BriefTool/prompt.js +19 -0
  1277. package/dist/src/tools/BriefTool/upload.js +136 -0
  1278. package/dist/src/tools/ConfigTool/ConfigTool.js +398 -0
  1279. package/dist/src/tools/ConfigTool/UI.js +24 -0
  1280. package/dist/src/tools/ConfigTool/constants.js +1 -0
  1281. package/dist/src/tools/ConfigTool/prompt.js +82 -0
  1282. package/dist/src/tools/ConfigTool/supportedSettings.js +180 -0
  1283. package/dist/src/tools/EnterPlanModeTool/EnterPlanModeTool.js +98 -0
  1284. package/dist/src/tools/EnterPlanModeTool/UI.js +13 -0
  1285. package/dist/src/tools/EnterPlanModeTool/constants.js +1 -0
  1286. package/dist/src/tools/EnterPlanModeTool/prompt.js +164 -0
  1287. package/dist/src/tools/EnterWorktreeTool/EnterWorktreeTool.js +104 -0
  1288. package/dist/src/tools/EnterWorktreeTool/UI.js +8 -0
  1289. package/dist/src/tools/EnterWorktreeTool/constants.js +1 -0
  1290. package/dist/src/tools/EnterWorktreeTool/prompt.js +30 -0
  1291. package/dist/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.js +385 -0
  1292. package/dist/src/tools/ExitPlanModeTool/UI.js +31 -0
  1293. package/dist/src/tools/ExitPlanModeTool/constants.js +2 -0
  1294. package/dist/src/tools/ExitPlanModeTool/prompt.js +27 -0
  1295. package/dist/src/tools/ExitWorktreeTool/ExitWorktreeTool.js +257 -0
  1296. package/dist/src/tools/ExitWorktreeTool/UI.js +9 -0
  1297. package/dist/src/tools/ExitWorktreeTool/constants.js +1 -0
  1298. package/dist/src/tools/ExitWorktreeTool/prompt.js +32 -0
  1299. package/dist/src/tools/FileEditTool/FileEditTool.js +480 -0
  1300. package/dist/src/tools/FileEditTool/UI.js +201 -0
  1301. package/dist/src/tools/FileEditTool/constants.js +7 -0
  1302. package/dist/src/tools/FileEditTool/prompt.js +24 -0
  1303. package/dist/src/tools/FileEditTool/types.js +50 -0
  1304. package/dist/src/tools/FileEditTool/utils.js +579 -0
  1305. package/dist/src/tools/FileReadTool/FileReadTool.js +889 -0
  1306. package/dist/src/tools/FileReadTool/UI.js +125 -0
  1307. package/dist/src/tools/FileReadTool/imageProcessor.js +46 -0
  1308. package/dist/src/tools/FileReadTool/limits.js +70 -0
  1309. package/dist/src/tools/FileReadTool/prompt.js +31 -0
  1310. package/dist/src/tools/FileWriteTool/FileWriteTool.js +341 -0
  1311. package/dist/src/tools/FileWriteTool/UI.js +338 -0
  1312. package/dist/src/tools/FileWriteTool/prompt.js +15 -0
  1313. package/dist/src/tools/GlobTool/GlobTool.js +161 -0
  1314. package/dist/src/tools/GlobTool/UI.js +39 -0
  1315. package/dist/src/tools/GlobTool/prompt.js +6 -0
  1316. package/dist/src/tools/GrepTool/GrepTool.js +439 -0
  1317. package/dist/src/tools/GrepTool/UI.js +154 -0
  1318. package/dist/src/tools/GrepTool/prompt.js +16 -0
  1319. package/dist/src/tools/LSPTool/LSPTool.js +660 -0
  1320. package/dist/src/tools/LSPTool/UI.js +204 -0
  1321. package/dist/src/tools/LSPTool/formatters.js +445 -0
  1322. package/dist/src/tools/LSPTool/prompt.js +20 -0
  1323. package/dist/src/tools/LSPTool/schemas.js +197 -0
  1324. package/dist/src/tools/LSPTool/symbolContext.js +75 -0
  1325. package/dist/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.js +100 -0
  1326. package/dist/src/tools/ListMcpResourcesTool/UI.js +16 -0
  1327. package/dist/src/tools/ListMcpResourcesTool/prompt.js +18 -0
  1328. package/dist/src/tools/MCPTool/MCPTool.js +60 -0
  1329. package/dist/src/tools/MCPTool/UI.js +342 -0
  1330. package/dist/src/tools/MCPTool/classifyForCollapse.js +597 -0
  1331. package/dist/src/tools/MCPTool/prompt.js +3 -0
  1332. package/dist/src/tools/McpAuthTool/McpAuthTool.js +162 -0
  1333. package/dist/src/tools/NotebookEditTool/NotebookEditTool.js +421 -0
  1334. package/dist/src/tools/NotebookEditTool/UI.js +40 -0
  1335. package/dist/src/tools/NotebookEditTool/constants.js +2 -0
  1336. package/dist/src/tools/NotebookEditTool/prompt.js +2 -0
  1337. package/dist/src/tools/PowerShellTool/PowerShellTool.js +899 -0
  1338. package/dist/src/tools/PowerShellTool/UI.js +57 -0
  1339. package/dist/src/tools/PowerShellTool/clmTypes.js +207 -0
  1340. package/dist/src/tools/PowerShellTool/commandSemantics.js +115 -0
  1341. package/dist/src/tools/PowerShellTool/commonParameters.js +27 -0
  1342. package/dist/src/tools/PowerShellTool/destructiveCommandWarning.js +92 -0
  1343. package/dist/src/tools/PowerShellTool/gitSafety.js +185 -0
  1344. package/dist/src/tools/PowerShellTool/modeValidation.js +357 -0
  1345. package/dist/src/tools/PowerShellTool/pathValidation.js +1712 -0
  1346. package/dist/src/tools/PowerShellTool/powershellPermissions.js +1351 -0
  1347. package/dist/src/tools/PowerShellTool/powershellSecurity.js +942 -0
  1348. package/dist/src/tools/PowerShellTool/prompt.js +134 -0
  1349. package/dist/src/tools/PowerShellTool/readOnlyValidation.js +1633 -0
  1350. package/dist/src/tools/PowerShellTool/toolName.js +2 -0
  1351. package/dist/src/tools/REPLTool/constants.js +43 -0
  1352. package/dist/src/tools/REPLTool/primitiveTools.js +36 -0
  1353. package/dist/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.js +112 -0
  1354. package/dist/src/tools/ReadMcpResourceTool/UI.js +23 -0
  1355. package/dist/src/tools/ReadMcpResourceTool/prompt.js +15 -0
  1356. package/dist/src/tools/RemoteTriggerTool/RemoteTriggerTool.js +142 -0
  1357. package/dist/src/tools/RemoteTriggerTool/UI.js +11 -0
  1358. package/dist/src/tools/RemoteTriggerTool/prompt.js +12 -0
  1359. package/dist/src/tools/ScheduleCronTool/CronCreateTool.js +120 -0
  1360. package/dist/src/tools/ScheduleCronTool/CronDeleteTool.js +74 -0
  1361. package/dist/src/tools/ScheduleCronTool/CronListTool.js +77 -0
  1362. package/dist/src/tools/ScheduleCronTool/UI.js +28 -0
  1363. package/dist/src/tools/ScheduleCronTool/prompt.js +115 -0
  1364. package/dist/src/tools/SendMessageTool/SendMessageTool.js +675 -0
  1365. package/dist/src/tools/SendMessageTool/UI.js +23 -0
  1366. package/dist/src/tools/SendMessageTool/constants.js +1 -0
  1367. package/dist/src/tools/SendMessageTool/prompt.js +47 -0
  1368. package/dist/src/tools/SkillTool/SkillTool.js +827 -0
  1369. package/dist/src/tools/SkillTool/UI.js +60 -0
  1370. package/dist/src/tools/SkillTool/constants.js +1 -0
  1371. package/dist/src/tools/SkillTool/prompt.js +184 -0
  1372. package/dist/src/tools/SleepTool/prompt.js +14 -0
  1373. package/dist/src/tools/SyntheticOutputTool/SyntheticOutputTool.js +138 -0
  1374. package/dist/src/tools/TaskCreateTool/TaskCreateTool.js +104 -0
  1375. package/dist/src/tools/TaskCreateTool/constants.js +1 -0
  1376. package/dist/src/tools/TaskCreateTool/prompt.js +52 -0
  1377. package/dist/src/tools/TaskGetTool/TaskGetTool.js +106 -0
  1378. package/dist/src/tools/TaskGetTool/constants.js +1 -0
  1379. package/dist/src/tools/TaskGetTool/prompt.js +23 -0
  1380. package/dist/src/tools/TaskListTool/TaskListTool.js +89 -0
  1381. package/dist/src/tools/TaskListTool/constants.js +1 -0
  1382. package/dist/src/tools/TaskListTool/prompt.js +44 -0
  1383. package/dist/src/tools/TaskOutputTool/TaskOutputTool.js +535 -0
  1384. package/dist/src/tools/TaskOutputTool/constants.js +1 -0
  1385. package/dist/src/tools/TaskStopTool/TaskStopTool.js +110 -0
  1386. package/dist/src/tools/TaskStopTool/UI.js +30 -0
  1387. package/dist/src/tools/TaskStopTool/prompt.js +7 -0
  1388. package/dist/src/tools/TaskUpdateTool/TaskUpdateTool.js +301 -0
  1389. package/dist/src/tools/TaskUpdateTool/constants.js +1 -0
  1390. package/dist/src/tools/TaskUpdateTool/prompt.js +76 -0
  1391. package/dist/src/tools/TeamCreateTool/TeamCreateTool.js +177 -0
  1392. package/dist/src/tools/TeamCreateTool/UI.js +4 -0
  1393. package/dist/src/tools/TeamCreateTool/constants.js +1 -0
  1394. package/dist/src/tools/TeamCreateTool/prompt.js +113 -0
  1395. package/dist/src/tools/TeamDeleteTool/TeamDeleteTool.js +102 -0
  1396. package/dist/src/tools/TeamDeleteTool/UI.js +13 -0
  1397. package/dist/src/tools/TeamDeleteTool/constants.js +1 -0
  1398. package/dist/src/tools/TeamDeleteTool/prompt.js +16 -0
  1399. package/dist/src/tools/TodoWriteTool/TodoWriteTool.js +99 -0
  1400. package/dist/src/tools/TodoWriteTool/constants.js +1 -0
  1401. package/dist/src/tools/TodoWriteTool/prompt.js +181 -0
  1402. package/dist/src/tools/ToolSearchTool/ToolSearchTool.js +357 -0
  1403. package/dist/src/tools/ToolSearchTool/constants.js +1 -0
  1404. package/dist/src/tools/ToolSearchTool/prompt.js +99 -0
  1405. package/dist/src/tools/TungstenTool/TungstenLiveMonitor.js +7 -0
  1406. package/dist/src/tools/TungstenTool/TungstenTool.js +3 -0
  1407. package/dist/src/tools/WebFetchTool/UI.js +30 -0
  1408. package/dist/src/tools/WebFetchTool/WebFetchTool.js +246 -0
  1409. package/dist/src/tools/WebFetchTool/preapproved.js +155 -0
  1410. package/dist/src/tools/WebFetchTool/prompt.js +39 -0
  1411. package/dist/src/tools/WebFetchTool/utils.js +381 -0
  1412. package/dist/src/tools/WebSearchTool/UI.js +66 -0
  1413. package/dist/src/tools/WebSearchTool/WebSearchTool.js +352 -0
  1414. package/dist/src/tools/WebSearchTool/prompt.js +32 -0
  1415. package/dist/src/tools/WorkflowTool/constants.js +2 -0
  1416. package/dist/src/tools/shared/gitOperationTracking.js +220 -0
  1417. package/dist/src/tools/shared/spawnMultiAgent.js +805 -0
  1418. package/dist/src/tools/testing/TestingPermissionTool.js +72 -0
  1419. package/dist/src/tools/utils.js +24 -0
  1420. package/dist/src/tools.js +332 -0
  1421. package/dist/src/types/command.js +10 -0
  1422. package/dist/src/types/connectorText.js +2 -0
  1423. package/dist/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.js +673 -0
  1424. package/dist/src/types/generated/events_mono/common/v1/auth.js +49 -0
  1425. package/dist/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.js +147 -0
  1426. package/dist/src/types/generated/google/protobuf/timestamp.js +38 -0
  1427. package/dist/src/types/hooks.js +153 -0
  1428. package/dist/src/types/ids.js +27 -0
  1429. package/dist/src/types/logs.js +11 -0
  1430. package/dist/src/types/message.js +1 -0
  1431. package/dist/src/types/permissions.js +25 -0
  1432. package/dist/src/types/plugin.js +72 -0
  1433. package/dist/src/types/textInputTypes.js +20 -0
  1434. package/dist/src/types/utils.js +5 -0
  1435. package/dist/src/upstreamproxy/relay.js +346 -0
  1436. package/dist/src/upstreamproxy/upstreamproxy.js +236 -0
  1437. package/dist/src/utils/CircularBuffer.js +75 -0
  1438. package/dist/src/utils/Cursor.js +1229 -0
  1439. package/dist/src/utils/QueryGuard.js +115 -0
  1440. package/dist/src/utils/Shell.js +374 -0
  1441. package/dist/src/utils/ShellCommand.js +338 -0
  1442. package/dist/src/utils/abortController.js +74 -0
  1443. package/dist/src/utils/activityManager.js +127 -0
  1444. package/dist/src/utils/advisor.js +77 -0
  1445. package/dist/src/utils/agentContext.js +91 -0
  1446. package/dist/src/utils/agentId.js +83 -0
  1447. package/dist/src/utils/agentSwarmsEnabled.js +37 -0
  1448. package/dist/src/utils/agenticSessionSearch.js +255 -0
  1449. package/dist/src/utils/analyzeContext.js +848 -0
  1450. package/dist/src/utils/ansiToPng.js +259 -0
  1451. package/dist/src/utils/ansiToSvg.js +207 -0
  1452. package/dist/src/utils/api.js +555 -0
  1453. package/dist/src/utils/apiPreconnect.js +62 -0
  1454. package/dist/src/utils/appleTerminalBackup.js +95 -0
  1455. package/dist/src/utils/argumentSubstitution.js +114 -0
  1456. package/dist/src/utils/array.js +12 -0
  1457. package/dist/src/utils/asciicast.js +200 -0
  1458. package/dist/src/utils/attachments.js +2514 -0
  1459. package/dist/src/utils/attribution.js +308 -0
  1460. package/dist/src/utils/attributionHooks.js +16 -0
  1461. package/dist/src/utils/attributionTrailer.js +16 -0
  1462. package/dist/src/utils/auth.js +2022 -0
  1463. package/dist/src/utils/authFileDescriptor.js +152 -0
  1464. package/dist/src/utils/authPortable.js +14 -0
  1465. package/dist/src/utils/autoModeDenials.js +15 -0
  1466. package/dist/src/utils/autoRunIssue.js +112 -0
  1467. package/dist/src/utils/autoUpdater.js +461 -0
  1468. package/dist/src/utils/aws.js +44 -0
  1469. package/dist/src/utils/awsAuthStatusManager.js +66 -0
  1470. package/dist/src/utils/background/remote/preconditions.js +175 -0
  1471. package/dist/src/utils/background/remote/remoteSession.js +53 -0
  1472. package/dist/src/utils/backgroundHousekeeping.js +66 -0
  1473. package/dist/src/utils/bash/ParsedCommand.js +241 -0
  1474. package/dist/src/utils/bash/ShellSnapshot.js +489 -0
  1475. package/dist/src/utils/bash/ast.js +2590 -0
  1476. package/dist/src/utils/bash/bashParser.js +4355 -0
  1477. package/dist/src/utils/bash/bashPipeCommand.js +249 -0
  1478. package/dist/src/utils/bash/commands.js +1131 -0
  1479. package/dist/src/utils/bash/heredoc.js +647 -0
  1480. package/dist/src/utils/bash/parser.js +195 -0
  1481. package/dist/src/utils/bash/prefix.js +154 -0
  1482. package/dist/src/utils/bash/registry.js +23 -0
  1483. package/dist/src/utils/bash/shellCompletion.js +196 -0
  1484. package/dist/src/utils/bash/shellPrefix.js +25 -0
  1485. package/dist/src/utils/bash/shellQuote.js +253 -0
  1486. package/dist/src/utils/bash/shellQuoting.js +106 -0
  1487. package/dist/src/utils/bash/specs/alias.js +11 -0
  1488. package/dist/src/utils/bash/specs/index.js +16 -0
  1489. package/dist/src/utils/bash/specs/nohup.js +10 -0
  1490. package/dist/src/utils/bash/specs/pyright.js +88 -0
  1491. package/dist/src/utils/bash/specs/sleep.js +10 -0
  1492. package/dist/src/utils/bash/specs/srun.js +28 -0
  1493. package/dist/src/utils/bash/specs/time.js +10 -0
  1494. package/dist/src/utils/bash/specs/timeout.js +17 -0
  1495. package/dist/src/utils/bash/treeSitterAnalysis.js +407 -0
  1496. package/dist/src/utils/betas.js +332 -0
  1497. package/dist/src/utils/billing.js +54 -0
  1498. package/dist/src/utils/binaryCheck.js +40 -0
  1499. package/dist/src/utils/browser.js +58 -0
  1500. package/dist/src/utils/bufferedWriter.js +77 -0
  1501. package/dist/src/utils/bundledMode.js +19 -0
  1502. package/dist/src/utils/caCerts.js +93 -0
  1503. package/dist/src/utils/caCertsConfig.js +77 -0
  1504. package/dist/src/utils/cachePaths.js +28 -0
  1505. package/dist/src/utils/ccshareResume.js +16 -0
  1506. package/dist/src/utils/classifierApprovals.js +66 -0
  1507. package/dist/src/utils/classifierApprovalsHook.js +10 -0
  1508. package/dist/src/utils/claudeCodeHints.js +142 -0
  1509. package/dist/src/utils/claudeDesktop.js +108 -0
  1510. package/dist/src/utils/claudeInChrome/chromeNativeHost.js +416 -0
  1511. package/dist/src/utils/claudeInChrome/common.js +466 -0
  1512. package/dist/src/utils/claudeInChrome/mcpServer.js +237 -0
  1513. package/dist/src/utils/claudeInChrome/prompt.js +79 -0
  1514. package/dist/src/utils/claudeInChrome/setup.js +320 -0
  1515. package/dist/src/utils/claudeInChrome/setupPortable.js +172 -0
  1516. package/dist/src/utils/claudeInChrome/toolRendering.js +234 -0
  1517. package/dist/src/utils/claudemd.js +1054 -0
  1518. package/dist/src/utils/cleanup.js +514 -0
  1519. package/dist/src/utils/cleanupRegistry.js +22 -0
  1520. package/dist/src/utils/cliArgs.js +53 -0
  1521. package/dist/src/utils/cliHighlight.js +45 -0
  1522. package/dist/src/utils/codeIndexing.js +149 -0
  1523. package/dist/src/utils/collapseBackgroundBashNotifications.js +70 -0
  1524. package/dist/src/utils/collapseHookSummaries.js +48 -0
  1525. package/dist/src/utils/collapseReadSearch.js +871 -0
  1526. package/dist/src/utils/collapseTeammateShutdowns.js +44 -0
  1527. package/dist/src/utils/combinedAbortSignal.js +40 -0
  1528. package/dist/src/utils/commandLifecycle.js +7 -0
  1529. package/dist/src/utils/commitAttribution.js +720 -0
  1530. package/dist/src/utils/completionCache.js +138 -0
  1531. package/dist/src/utils/computerUse/appNames.js +170 -0
  1532. package/dist/src/utils/computerUse/cleanup.js +66 -0
  1533. package/dist/src/utils/computerUse/common.js +56 -0
  1534. package/dist/src/utils/computerUse/computerUseLock.js +183 -0
  1535. package/dist/src/utils/computerUse/drainRunLoop.js +71 -0
  1536. package/dist/src/utils/computerUse/escHotkey.js +53 -0
  1537. package/dist/src/utils/computerUse/executor.js +480 -0
  1538. package/dist/src/utils/computerUse/gates.js +55 -0
  1539. package/dist/src/utils/computerUse/hostAdapter.js +62 -0
  1540. package/dist/src/utils/computerUse/inputLoader.js +27 -0
  1541. package/dist/src/utils/computerUse/mcpServer.js +84 -0
  1542. package/dist/src/utils/computerUse/setup.js +42 -0
  1543. package/dist/src/utils/computerUse/swiftLoader.js +20 -0
  1544. package/dist/src/utils/computerUse/toolRendering.js +100 -0
  1545. package/dist/src/utils/computerUse/wrapper.js +318 -0
  1546. package/dist/src/utils/concurrentSessions.js +179 -0
  1547. package/dist/src/utils/config.js +1084 -0
  1548. package/dist/src/utils/configConstants.js +18 -0
  1549. package/dist/src/utils/contentArray.js +45 -0
  1550. package/dist/src/utils/context.js +185 -0
  1551. package/dist/src/utils/contextAnalysis.js +171 -0
  1552. package/dist/src/utils/contextSuggestions.js +158 -0
  1553. package/dist/src/utils/controlMessageCompat.js +31 -0
  1554. package/dist/src/utils/conversationRecovery.js +436 -0
  1555. package/dist/src/utils/cron.js +260 -0
  1556. package/dist/src/utils/cronJitterConfig.js +62 -0
  1557. package/dist/src/utils/cronScheduler.js +388 -0
  1558. package/dist/src/utils/cronTasks.js +332 -0
  1559. package/dist/src/utils/cronTasksLock.js +164 -0
  1560. package/dist/src/utils/crossProjectResume.js +46 -0
  1561. package/dist/src/utils/crypto.js +13 -0
  1562. package/dist/src/utils/cwd.js +29 -0
  1563. package/dist/src/utils/databaseMcp/common.js +48 -0
  1564. package/dist/src/utils/databaseMcp/mcpServer.js +2 -0
  1565. package/dist/src/utils/databaseMcp/server/connection.js +243 -0
  1566. package/dist/src/utils/databaseMcp/server/index.js +1442 -0
  1567. package/dist/src/utils/databaseMcp/server/queries.js +683 -0
  1568. package/dist/src/utils/databaseMcp/server/types.js +7 -0
  1569. package/dist/src/utils/databaseMcp/setup.js +28 -0
  1570. package/dist/src/utils/debug.js +220 -0
  1571. package/dist/src/utils/debugFilter.js +125 -0
  1572. package/dist/src/utils/deepLink/banner.js +103 -0
  1573. package/dist/src/utils/deepLink/parseDeepLink.js +138 -0
  1574. package/dist/src/utils/deepLink/protocolHandler.js +119 -0
  1575. package/dist/src/utils/deepLink/registerProtocol.js +291 -0
  1576. package/dist/src/utils/deepLink/terminalLauncher.js +455 -0
  1577. package/dist/src/utils/deepLink/terminalPreference.js +51 -0
  1578. package/dist/src/utils/desktopDeepLink.js +208 -0
  1579. package/dist/src/utils/detectRepository.js +157 -0
  1580. package/dist/src/utils/diagLogs.js +74 -0
  1581. package/dist/src/utils/diff.js +108 -0
  1582. package/dist/src/utils/directMemberMessage.js +34 -0
  1583. package/dist/src/utils/displayTags.js +46 -0
  1584. package/dist/src/utils/doctorContextWarnings.js +179 -0
  1585. package/dist/src/utils/doctorDiagnostic.js +495 -0
  1586. package/dist/src/utils/dxt/helpers.js +64 -0
  1587. package/dist/src/utils/dxt/zip.js +167 -0
  1588. package/dist/src/utils/earlyInput.js +166 -0
  1589. package/dist/src/utils/editor.js +163 -0
  1590. package/dist/src/utils/effort.js +278 -0
  1591. package/dist/src/utils/embeddedTools.js +26 -0
  1592. package/dist/src/utils/env.js +358 -0
  1593. package/dist/src/utils/envDynamic.js +130 -0
  1594. package/dist/src/utils/envUtils.js +192 -0
  1595. package/dist/src/utils/envValidation.js +26 -0
  1596. package/dist/src/utils/errorLogSink.js +197 -0
  1597. package/dist/src/utils/errors.js +207 -0
  1598. package/dist/src/utils/eventLoopStallDetector.js +16 -0
  1599. package/dist/src/utils/exampleCommands.js +165 -0
  1600. package/dist/src/utils/execFileNoThrow.js +93 -0
  1601. package/dist/src/utils/execFileNoThrowPortable.js +111 -0
  1602. package/dist/src/utils/execSyncWrapper.js +68 -0
  1603. package/dist/src/utils/exportRenderer.js +71 -0
  1604. package/dist/src/utils/extraUsage.js +19 -0
  1605. package/dist/src/utils/fastMode.js +393 -0
  1606. package/dist/src/utils/file.js +467 -0
  1607. package/dist/src/utils/fileHistory.js +851 -0
  1608. package/dist/src/utils/fileOperationAnalytics.js +45 -0
  1609. package/dist/src/utils/filePersistence/filePersistence.js +212 -0
  1610. package/dist/src/utils/filePersistence/outputsScanner.js +104 -0
  1611. package/dist/src/utils/filePersistence/types.js +5 -0
  1612. package/dist/src/utils/fileRead.js +81 -0
  1613. package/dist/src/utils/fileReadCache.js +78 -0
  1614. package/dist/src/utils/fileStateCache.js +99 -0
  1615. package/dist/src/utils/findExecutable.js +13 -0
  1616. package/dist/src/utils/fingerprint.js +59 -0
  1617. package/dist/src/utils/forkedAgent.js +410 -0
  1618. package/dist/src/utils/format.js +238 -0
  1619. package/dist/src/utils/formatBriefTimestamp.js +72 -0
  1620. package/dist/src/utils/fpsTracker.js +34 -0
  1621. package/dist/src/utils/frontmatterParser.js +260 -0
  1622. package/dist/src/utils/fsOperations.js +834 -0
  1623. package/dist/src/utils/fullscreen.js +194 -0
  1624. package/dist/src/utils/generatedFiles.js +122 -0
  1625. package/dist/src/utils/generators.js +67 -0
  1626. package/dist/src/utils/genericProcessUtils.js +155 -0
  1627. package/dist/src/utils/getWorktreePaths.js +56 -0
  1628. package/dist/src/utils/getWorktreePathsPortable.js +23 -0
  1629. package/dist/src/utils/ghPrStatus.js +71 -0
  1630. package/dist/src/utils/git/gitConfigParser.js +226 -0
  1631. package/dist/src/utils/git/gitFilesystem.js +606 -0
  1632. package/dist/src/utils/git/gitignore.js +84 -0
  1633. package/dist/src/utils/git.js +725 -0
  1634. package/dist/src/utils/gitDiff.js +395 -0
  1635. package/dist/src/utils/gitSettings.js +18 -0
  1636. package/dist/src/utils/github/ghAuthStatus.js +23 -0
  1637. package/dist/src/utils/githubRepoPathMapping.js +135 -0
  1638. package/dist/src/utils/glob.js +90 -0
  1639. package/dist/src/utils/gracefulShutdown.js +447 -0
  1640. package/dist/src/utils/groupToolUses.js +126 -0
  1641. package/dist/src/utils/handlePromptSubmit.js +398 -0
  1642. package/dist/src/utils/hash.js +46 -0
  1643. package/dist/src/utils/headlessProfiler.js +147 -0
  1644. package/dist/src/utils/heapDumpService.js +202 -0
  1645. package/dist/src/utils/heatmap.js +151 -0
  1646. package/dist/src/utils/highlightMatch.js +28 -0
  1647. package/dist/src/utils/hooks/AsyncHookRegistry.js +187 -0
  1648. package/dist/src/utils/hooks/apiQueryHookHelper.js +77 -0
  1649. package/dist/src/utils/hooks/execAgentHook.js +257 -0
  1650. package/dist/src/utils/hooks/execHttpHook.js +184 -0
  1651. package/dist/src/utils/hooks/execPromptHook.js +171 -0
  1652. package/dist/src/utils/hooks/fileChangedWatcher.js +161 -0
  1653. package/dist/src/utils/hooks/hookEvents.js +111 -0
  1654. package/dist/src/utils/hooks/hookHelpers.js +60 -0
  1655. package/dist/src/utils/hooks/hooksConfigManager.js +323 -0
  1656. package/dist/src/utils/hooks/hooksConfigSnapshot.js +114 -0
  1657. package/dist/src/utils/hooks/hooksSettings.js +204 -0
  1658. package/dist/src/utils/hooks/postSamplingHooks.js +39 -0
  1659. package/dist/src/utils/hooks/registerFrontmatterHooks.js +47 -0
  1660. package/dist/src/utils/hooks/registerSkillHooks.js +40 -0
  1661. package/dist/src/utils/hooks/sessionHooks.js +252 -0
  1662. package/dist/src/utils/hooks/skillImprovement.js +211 -0
  1663. package/dist/src/utils/hooks/ssrfGuard.js +258 -0
  1664. package/dist/src/utils/hooks.js +3668 -0
  1665. package/dist/src/utils/horizontalScroll.js +108 -0
  1666. package/dist/src/utils/http.js +121 -0
  1667. package/dist/src/utils/hyperlink.js +28 -0
  1668. package/dist/src/utils/iTermBackup.js +48 -0
  1669. package/dist/src/utils/ide.js +1235 -0
  1670. package/dist/src/utils/idePathConversion.js +66 -0
  1671. package/dist/src/utils/idleTimeout.js +44 -0
  1672. package/dist/src/utils/imagePaste.js +329 -0
  1673. package/dist/src/utils/imageResizer.js +664 -0
  1674. package/dist/src/utils/imageStore.js +150 -0
  1675. package/dist/src/utils/imageValidation.js +92 -0
  1676. package/dist/src/utils/immediateCommand.js +12 -0
  1677. package/dist/src/utils/inProcessTeammateHelpers.js +71 -0
  1678. package/dist/src/utils/ink.js +20 -0
  1679. package/dist/src/utils/intl.js +83 -0
  1680. package/dist/src/utils/jetbrains.js +152 -0
  1681. package/dist/src/utils/json.js +295 -0
  1682. package/dist/src/utils/jsonRead.js +14 -0
  1683. package/dist/src/utils/keyboardShortcuts.js +11 -0
  1684. package/dist/src/utils/lazySchema.js +8 -0
  1685. package/dist/src/utils/listSessionsImpl.js +332 -0
  1686. package/dist/src/utils/localInstaller.js +131 -0
  1687. package/dist/src/utils/lockfile.js +22 -0
  1688. package/dist/src/utils/log.js +280 -0
  1689. package/dist/src/utils/logoV2Utils.js +290 -0
  1690. package/dist/src/utils/mailbox.js +50 -0
  1691. package/dist/src/utils/managedEnv.js +160 -0
  1692. package/dist/src/utils/managedEnvConstants.js +200 -0
  1693. package/dist/src/utils/markdown.js +300 -0
  1694. package/dist/src/utils/markdownConfigLoader.js +494 -0
  1695. package/dist/src/utils/mcp/dateTimeParser.js +102 -0
  1696. package/dist/src/utils/mcp/elicitationValidation.js +259 -0
  1697. package/dist/src/utils/mcpInstructionsDelta.js +97 -0
  1698. package/dist/src/utils/mcpOutputStorage.js +159 -0
  1699. package/dist/src/utils/mcpValidation.js +165 -0
  1700. package/dist/src/utils/mcpWebSocketTransport.js +180 -0
  1701. package/dist/src/utils/memoize.js +205 -0
  1702. package/dist/src/utils/memory/types.js +9 -0
  1703. package/dist/src/utils/memory/versions.js +7 -0
  1704. package/dist/src/utils/memoryFileDetection.js +247 -0
  1705. package/dist/src/utils/messagePredicates.js +6 -0
  1706. package/dist/src/utils/messageQueueManager.js +430 -0
  1707. package/dist/src/utils/messages/mappers.js +240 -0
  1708. package/dist/src/utils/messages/systemInit.js +74 -0
  1709. package/dist/src/utils/messages.js +4273 -0
  1710. package/dist/src/utils/model/agent.js +128 -0
  1711. package/dist/src/utils/model/aliases.js +21 -0
  1712. package/dist/src/utils/model/antModels.js +25 -0
  1713. package/dist/src/utils/model/bedrock.js +220 -0
  1714. package/dist/src/utils/model/check1mAccess.js +64 -0
  1715. package/dist/src/utils/model/configs.js +93 -0
  1716. package/dist/src/utils/model/contextWindowUpgradeCheck.js +41 -0
  1717. package/dist/src/utils/model/deprecation.js +72 -0
  1718. package/dist/src/utils/model/model.js +641 -0
  1719. package/dist/src/utils/model/modelAllowlist.js +148 -0
  1720. package/dist/src/utils/model/modelCapabilities.js +107 -0
  1721. package/dist/src/utils/model/modelOptions.js +645 -0
  1722. package/dist/src/utils/model/modelStrings.js +144 -0
  1723. package/dist/src/utils/model/modelSupportOverrides.js +40 -0
  1724. package/dist/src/utils/model/openrouter.js +51 -0
  1725. package/dist/src/utils/model/providerBaseUrls.js +77 -0
  1726. package/dist/src/utils/model/providerCatalog.js +81 -0
  1727. package/dist/src/utils/model/providerModels.js +334 -0
  1728. package/dist/src/utils/model/providerProfiles.js +392 -0
  1729. package/dist/src/utils/model/providerProfilesDb.js +886 -0
  1730. package/dist/src/utils/model/providerSwitch.js +50 -0
  1731. package/dist/src/utils/model/providerWorkspaces.js +36 -0
  1732. package/dist/src/utils/model/providers.js +199 -0
  1733. package/dist/src/utils/model/validateModel.js +257 -0
  1734. package/dist/src/utils/modelCost.js +160 -0
  1735. package/dist/src/utils/modifiers.js +35 -0
  1736. package/dist/src/utils/mtls.js +134 -0
  1737. package/dist/src/utils/nativeInstaller/download.js +370 -0
  1738. package/dist/src/utils/nativeInstaller/index.js +8 -0
  1739. package/dist/src/utils/nativeInstaller/installer.js +1396 -0
  1740. package/dist/src/utils/nativeInstaller/packageManagers.js +258 -0
  1741. package/dist/src/utils/nativeInstaller/pidLock.js +347 -0
  1742. package/dist/src/utils/notebook.js +176 -0
  1743. package/dist/src/utils/objectGroupBy.js +15 -0
  1744. package/dist/src/utils/orchestration/store/index.js +6 -0
  1745. package/dist/src/utils/orchestration/store/orchestrationDb.js +42 -0
  1746. package/dist/src/utils/orchestration/store/providerAgentStore.js +244 -0
  1747. package/dist/src/utils/orchestration/store/providerWorkspaceStore.js +125 -0
  1748. package/dist/src/utils/orchestration/store/runStore.js +486 -0
  1749. package/dist/src/utils/orchestration/store/teamStore.js +285 -0
  1750. package/dist/src/utils/orchestration/store/types.js +1 -0
  1751. package/dist/src/utils/pasteStore.js +93 -0
  1752. package/dist/src/utils/path.js +140 -0
  1753. package/dist/src/utils/pdf.js +236 -0
  1754. package/dist/src/utils/pdfUtils.js +61 -0
  1755. package/dist/src/utils/peerAddress.js +20 -0
  1756. package/dist/src/utils/permissions/PermissionMode.js +95 -0
  1757. package/dist/src/utils/permissions/PermissionPromptToolResultSchema.js +85 -0
  1758. package/dist/src/utils/permissions/PermissionResult.js +11 -0
  1759. package/dist/src/utils/permissions/PermissionRule.js +19 -0
  1760. package/dist/src/utils/permissions/PermissionUpdate.js +330 -0
  1761. package/dist/src/utils/permissions/PermissionUpdateSchema.js +61 -0
  1762. package/dist/src/utils/permissions/autoModeState.js +34 -0
  1763. package/dist/src/utils/permissions/bashClassifier.js +30 -0
  1764. package/dist/src/utils/permissions/bypassPermissionsKillswitch.js +115 -0
  1765. package/dist/src/utils/permissions/classifierDecision.js +88 -0
  1766. package/dist/src/utils/permissions/classifierShared.js +28 -0
  1767. package/dist/src/utils/permissions/dangerousPatterns.js +78 -0
  1768. package/dist/src/utils/permissions/denialTracking.js +34 -0
  1769. package/dist/src/utils/permissions/filesystem.js +1426 -0
  1770. package/dist/src/utils/permissions/getNextPermissionMode.js +74 -0
  1771. package/dist/src/utils/permissions/pathValidation.js +351 -0
  1772. package/dist/src/utils/permissions/permissionExplainer.js +188 -0
  1773. package/dist/src/utils/permissions/permissionRuleParser.js +177 -0
  1774. package/dist/src/utils/permissions/permissionSetup.js +1164 -0
  1775. package/dist/src/utils/permissions/permissions.js +1106 -0
  1776. package/dist/src/utils/permissions/permissionsDb.js +322 -0
  1777. package/dist/src/utils/permissions/permissionsLoader.js +217 -0
  1778. package/dist/src/utils/permissions/shadowedRuleDetection.js +149 -0
  1779. package/dist/src/utils/permissions/shellRuleMatching.js +174 -0
  1780. package/dist/src/utils/permissions/yoloClassifier.js +1195 -0
  1781. package/dist/src/utils/planModeV2.js +75 -0
  1782. package/dist/src/utils/plans.js +334 -0
  1783. package/dist/src/utils/platform.js +122 -0
  1784. package/dist/src/utils/plugins/addDirPluginSettings.js +53 -0
  1785. package/dist/src/utils/plugins/cacheUtils.js +174 -0
  1786. package/dist/src/utils/plugins/dependencyResolver.js +244 -0
  1787. package/dist/src/utils/plugins/fetchTelemetry.js +108 -0
  1788. package/dist/src/utils/plugins/gitAvailability.js +65 -0
  1789. package/dist/src/utils/plugins/headlessPluginInstall.js +136 -0
  1790. package/dist/src/utils/plugins/hintRecommendation.js +136 -0
  1791. package/dist/src/utils/plugins/installCounts.js +218 -0
  1792. package/dist/src/utils/plugins/installedPluginsManager.js +1003 -0
  1793. package/dist/src/utils/plugins/loadPluginAgents.js +219 -0
  1794. package/dist/src/utils/plugins/loadPluginCommands.js +595 -0
  1795. package/dist/src/utils/plugins/loadPluginHooks.js +239 -0
  1796. package/dist/src/utils/plugins/loadPluginOutputStyles.js +112 -0
  1797. package/dist/src/utils/plugins/lspPluginIntegration.js +293 -0
  1798. package/dist/src/utils/plugins/lspRecommendation.js +278 -0
  1799. package/dist/src/utils/plugins/managedPlugins.js +26 -0
  1800. package/dist/src/utils/plugins/marketplaceHelpers.js +470 -0
  1801. package/dist/src/utils/plugins/marketplaceManager.js +1939 -0
  1802. package/dist/src/utils/plugins/mcpPluginIntegration.js +465 -0
  1803. package/dist/src/utils/plugins/mcpbHandler.js +708 -0
  1804. package/dist/src/utils/plugins/officialMarketplace.js +21 -0
  1805. package/dist/src/utils/plugins/officialMarketplaceGcs.js +195 -0
  1806. package/dist/src/utils/plugins/officialMarketplaceStartupCheck.js +338 -0
  1807. package/dist/src/utils/plugins/orphanedPluginFilter.js +96 -0
  1808. package/dist/src/utils/plugins/parseMarketplaceInput.js +143 -0
  1809. package/dist/src/utils/plugins/performStartupChecks.js +66 -0
  1810. package/dist/src/utils/plugins/pluginAutoupdate.js +210 -0
  1811. package/dist/src/utils/plugins/pluginBlocklist.js +93 -0
  1812. package/dist/src/utils/plugins/pluginDirectories.js +172 -0
  1813. package/dist/src/utils/plugins/pluginFlagging.js +173 -0
  1814. package/dist/src/utils/plugins/pluginIdentifier.js +78 -0
  1815. package/dist/src/utils/plugins/pluginInstallationHelpers.js +400 -0
  1816. package/dist/src/utils/plugins/pluginLoader.js +2426 -0
  1817. package/dist/src/utils/plugins/pluginOptionsStorage.js +311 -0
  1818. package/dist/src/utils/plugins/pluginPolicy.js +18 -0
  1819. package/dist/src/utils/plugins/pluginStartupCheck.js +261 -0
  1820. package/dist/src/utils/plugins/pluginVersioning.js +128 -0
  1821. package/dist/src/utils/plugins/reconciler.js +181 -0
  1822. package/dist/src/utils/plugins/refresh.js +162 -0
  1823. package/dist/src/utils/plugins/schemas.js +1283 -0
  1824. package/dist/src/utils/plugins/validatePlugin.js +765 -0
  1825. package/dist/src/utils/plugins/walkPluginMarkdown.js +49 -0
  1826. package/dist/src/utils/plugins/zipCache.js +346 -0
  1827. package/dist/src/utils/plugins/zipCacheAdapters.js +133 -0
  1828. package/dist/src/utils/postCommitAttribution.js +16 -0
  1829. package/dist/src/utils/powershell/dangerousCmdlets.js +174 -0
  1830. package/dist/src/utils/powershell/parser.js +1357 -0
  1831. package/dist/src/utils/powershell/staticPrefix.js +277 -0
  1832. package/dist/src/utils/preflightChecks.js +147 -0
  1833. package/dist/src/utils/privacyLevel.js +49 -0
  1834. package/dist/src/utils/process.js +56 -0
  1835. package/dist/src/utils/processUserInput/processBashCommand.js +119 -0
  1836. package/dist/src/utils/processUserInput/processSlashCommand.js +859 -0
  1837. package/dist/src/utils/processUserInput/processTextPrompt.js +68 -0
  1838. package/dist/src/utils/processUserInput/processUserInput.js +326 -0
  1839. package/dist/src/utils/profilerBase.js +29 -0
  1840. package/dist/src/utils/promptCategory.js +39 -0
  1841. package/dist/src/utils/promptEditor.js +151 -0
  1842. package/dist/src/utils/promptShellExecution.js +119 -0
  1843. package/dist/src/utils/proxy.js +347 -0
  1844. package/dist/src/utils/queryContext.js +110 -0
  1845. package/dist/src/utils/queryHelpers.js +436 -0
  1846. package/dist/src/utils/queryProfiler.js +242 -0
  1847. package/dist/src/utils/queueProcessor.js +70 -0
  1848. package/dist/src/utils/readEditContext.js +176 -0
  1849. package/dist/src/utils/readFileInRange.js +278 -0
  1850. package/dist/src/utils/releaseNotes.js +304 -0
  1851. package/dist/src/utils/renderOptions.js +67 -0
  1852. package/dist/src/utils/ripgrep.js +540 -0
  1853. package/dist/src/utils/sandbox/sandbox-adapter.js +751 -0
  1854. package/dist/src/utils/sandbox/sandbox-ui-utils.js +11 -0
  1855. package/dist/src/utils/sanitization.js +72 -0
  1856. package/dist/src/utils/screenshotClipboard.js +89 -0
  1857. package/dist/src/utils/sdkEventQueue.js +49 -0
  1858. package/dist/src/utils/sdkHeapDumpMonitor.js +16 -0
  1859. package/dist/src/utils/secureStorage/fallbackStorage.js +59 -0
  1860. package/dist/src/utils/secureStorage/index.js +14 -0
  1861. package/dist/src/utils/secureStorage/keychainPrefetch.js +91 -0
  1862. package/dist/src/utils/secureStorage/macOsKeychainHelpers.js +91 -0
  1863. package/dist/src/utils/secureStorage/macOsKeychainStorage.js +192 -0
  1864. package/dist/src/utils/secureStorage/plainTextStorage.js +81 -0
  1865. package/dist/src/utils/secureStorage/secureStoreDefs.js +1 -0
  1866. package/dist/src/utils/secureStorage/sqliteStorage.js +224 -0
  1867. package/dist/src/utils/secureStorage/types.js +1 -0
  1868. package/dist/src/utils/semanticBoolean.js +23 -0
  1869. package/dist/src/utils/semanticNumber.js +34 -0
  1870. package/dist/src/utils/semver.js +53 -0
  1871. package/dist/src/utils/sequential.js +43 -0
  1872. package/dist/src/utils/sessionActivity.js +120 -0
  1873. package/dist/src/utils/sessionDataUploader.js +16 -0
  1874. package/dist/src/utils/sessionEnvVars.js +18 -0
  1875. package/dist/src/utils/sessionEnvironment.js +131 -0
  1876. package/dist/src/utils/sessionFileAccessHooks.js +207 -0
  1877. package/dist/src/utils/sessionIngressAuth.js +113 -0
  1878. package/dist/src/utils/sessionRestore.js +359 -0
  1879. package/dist/src/utils/sessionStart.js +165 -0
  1880. package/dist/src/utils/sessionState.js +76 -0
  1881. package/dist/src/utils/sessionStorage.js +4162 -0
  1882. package/dist/src/utils/sessionStoragePortable.js +665 -0
  1883. package/dist/src/utils/sessionTitle.js +120 -0
  1884. package/dist/src/utils/sessionUrl.js +50 -0
  1885. package/dist/src/utils/set.js +50 -0
  1886. package/dist/src/utils/settings/allErrors.js +29 -0
  1887. package/dist/src/utils/settings/applySettingsChange.js +65 -0
  1888. package/dist/src/utils/settings/changeDetector.js +409 -0
  1889. package/dist/src/utils/settings/constants.js +166 -0
  1890. package/dist/src/utils/settings/internalWrites.js +33 -0
  1891. package/dist/src/utils/settings/managedPath.js +29 -0
  1892. package/dist/src/utils/settings/mdm/constants.js +62 -0
  1893. package/dist/src/utils/settings/mdm/rawRead.js +97 -0
  1894. package/dist/src/utils/settings/mdm/settings.js +254 -0
  1895. package/dist/src/utils/settings/permissionValidation.js +224 -0
  1896. package/dist/src/utils/settings/pluginOnlyPolicy.js +53 -0
  1897. package/dist/src/utils/settings/schemaOutput.js +7 -0
  1898. package/dist/src/utils/settings/settings.js +844 -0
  1899. package/dist/src/utils/settings/settingsCache.js +47 -0
  1900. package/dist/src/utils/settings/toolValidationConfig.js +76 -0
  1901. package/dist/src/utils/settings/types.js +846 -0
  1902. package/dist/src/utils/settings/validateEditTool.js +34 -0
  1903. package/dist/src/utils/settings/validation.js +192 -0
  1904. package/dist/src/utils/settings/validationTips.js +111 -0
  1905. package/dist/src/utils/shell/bashProvider.js +202 -0
  1906. package/dist/src/utils/shell/outputLimits.js +7 -0
  1907. package/dist/src/utils/shell/powershellDetection.js +96 -0
  1908. package/dist/src/utils/shell/powershellProvider.js +104 -0
  1909. package/dist/src/utils/shell/prefix.js +246 -0
  1910. package/dist/src/utils/shell/readOnlyCommandValidation.js +1776 -0
  1911. package/dist/src/utils/shell/resolveDefaultShell.js +13 -0
  1912. package/dist/src/utils/shell/shellProvider.js +2 -0
  1913. package/dist/src/utils/shell/shellToolUtils.js +21 -0
  1914. package/dist/src/utils/shell/specPrefix.js +198 -0
  1915. package/dist/src/utils/shellConfig.js +136 -0
  1916. package/dist/src/utils/sideQuery.js +195 -0
  1917. package/dist/src/utils/sideQuestion.js +121 -0
  1918. package/dist/src/utils/signal.js +34 -0
  1919. package/dist/src/utils/sinks.js +15 -0
  1920. package/dist/src/utils/skills/skillChangeDetector.js +266 -0
  1921. package/dist/src/utils/slashCommandParsing.js +46 -0
  1922. package/dist/src/utils/sleep.js +72 -0
  1923. package/dist/src/utils/sliceAnsi.js +74 -0
  1924. package/dist/src/utils/slowOperations.js +323 -0
  1925. package/dist/src/utils/standaloneAgent.js +20 -0
  1926. package/dist/src/utils/startupProfiler.js +158 -0
  1927. package/dist/src/utils/staticRender.js +103 -0
  1928. package/dist/src/utils/stats.js +802 -0
  1929. package/dist/src/utils/statsCache.js +330 -0
  1930. package/dist/src/utils/status.js +552 -0
  1931. package/dist/src/utils/statusNoticeDefinitions.js +112 -0
  1932. package/dist/src/utils/statusNoticeHelpers.js +15 -0
  1933. package/dist/src/utils/stream.js +73 -0
  1934. package/dist/src/utils/streamJsonStdoutGuard.js +107 -0
  1935. package/dist/src/utils/streamlinedTransform.js +162 -0
  1936. package/dist/src/utils/stringUtils.js +202 -0
  1937. package/dist/src/utils/subprocessEnv.js +87 -0
  1938. package/dist/src/utils/suggestions/commandSuggestions.js +458 -0
  1939. package/dist/src/utils/suggestions/directoryCompletion.js +191 -0
  1940. package/dist/src/utils/suggestions/shellHistoryCompletion.js +95 -0
  1941. package/dist/src/utils/suggestions/skillUsageTracking.js +50 -0
  1942. package/dist/src/utils/suggestions/slackChannelSuggestions.js +169 -0
  1943. package/dist/src/utils/swarm/It2SetupPrompt.js +386 -0
  1944. package/dist/src/utils/swarm/backends/ITermBackend.js +276 -0
  1945. package/dist/src/utils/swarm/backends/InProcessBackend.js +237 -0
  1946. package/dist/src/utils/swarm/backends/PaneBackendExecutor.js +250 -0
  1947. package/dist/src/utils/swarm/backends/TmuxBackend.js +574 -0
  1948. package/dist/src/utils/swarm/backends/detection.js +112 -0
  1949. package/dist/src/utils/swarm/backends/it2Setup.js +185 -0
  1950. package/dist/src/utils/swarm/backends/registry.js +369 -0
  1951. package/dist/src/utils/swarm/backends/teammateModeSnapshot.js +68 -0
  1952. package/dist/src/utils/swarm/backends/types.js +9 -0
  1953. package/dist/src/utils/swarm/constants.js +29 -0
  1954. package/dist/src/utils/swarm/inProcessRunner.js +1021 -0
  1955. package/dist/src/utils/swarm/leaderPermissionBridge.js +31 -0
  1956. package/dist/src/utils/swarm/permissionSync.js +667 -0
  1957. package/dist/src/utils/swarm/reconnection.js +82 -0
  1958. package/dist/src/utils/swarm/spawnInProcess.js +218 -0
  1959. package/dist/src/utils/swarm/spawnUtils.js +123 -0
  1960. package/dist/src/utils/swarm/teamHelpers.js +484 -0
  1961. package/dist/src/utils/swarm/teammateInit.js +87 -0
  1962. package/dist/src/utils/swarm/teammateLayoutManager.js +82 -0
  1963. package/dist/src/utils/swarm/teammateModel.js +9 -0
  1964. package/dist/src/utils/swarm/teammatePromptAddendum.js +17 -0
  1965. package/dist/src/utils/systemDirectories.js +51 -0
  1966. package/dist/src/utils/systemPrompt.js +91 -0
  1967. package/dist/src/utils/systemPromptType.js +9 -0
  1968. package/dist/src/utils/systemTheme.js +108 -0
  1969. package/dist/src/utils/systemThemeWatcher.js +16 -0
  1970. package/dist/src/utils/taggedId.js +49 -0
  1971. package/dist/src/utils/task/TaskOutput.js +320 -0
  1972. package/dist/src/utils/task/diskOutput.js +387 -0
  1973. package/dist/src/utils/task/framework.js +236 -0
  1974. package/dist/src/utils/task/outputFormatting.js +24 -0
  1975. package/dist/src/utils/task/sdkProgress.js +24 -0
  1976. package/dist/src/utils/tasks.js +672 -0
  1977. package/dist/src/utils/teamDiscovery.js +48 -0
  1978. package/dist/src/utils/teamMemoryOps.js +67 -0
  1979. package/dist/src/utils/teammate.js +237 -0
  1980. package/dist/src/utils/teammateContext.js +56 -0
  1981. package/dist/src/utils/teammateMailbox.js +793 -0
  1982. package/dist/src/utils/telemetry/betaSessionTracing.js +371 -0
  1983. package/dist/src/utils/telemetry/bigqueryExporter.js +181 -0
  1984. package/dist/src/utils/telemetry/events.js +57 -0
  1985. package/dist/src/utils/telemetry/instrumentation.js +617 -0
  1986. package/dist/src/utils/telemetry/logger.js +25 -0
  1987. package/dist/src/utils/telemetry/perfettoTracing.js +882 -0
  1988. package/dist/src/utils/telemetry/pluginTelemetry.js +157 -0
  1989. package/dist/src/utils/telemetry/sessionTracing.js +693 -0
  1990. package/dist/src/utils/telemetry/skillLoadedEvent.js +26 -0
  1991. package/dist/src/utils/telemetryAttributes.js +57 -0
  1992. package/dist/src/utils/teleport/api.js +299 -0
  1993. package/dist/src/utils/teleport/environmentSelection.js +55 -0
  1994. package/dist/src/utils/teleport/environments.js +84 -0
  1995. package/dist/src/utils/teleport/gitBundle.js +192 -0
  1996. package/dist/src/utils/teleport.js +1041 -0
  1997. package/dist/src/utils/tempfile.js +26 -0
  1998. package/dist/src/utils/terminal.js +105 -0
  1999. package/dist/src/utils/terminalPanel.js +155 -0
  2000. package/dist/src/utils/textHighlighting.js +113 -0
  2001. package/dist/src/utils/theme.js +525 -0
  2002. package/dist/src/utils/thinking.js +130 -0
  2003. package/dist/src/utils/timeouts.js +35 -0
  2004. package/dist/src/utils/tmuxSocket.js +373 -0
  2005. package/dist/src/utils/todo/types.js +9 -0
  2006. package/dist/src/utils/tokenBudget.js +62 -0
  2007. package/dist/src/utils/tokens.js +223 -0
  2008. package/dist/src/utils/toolErrors.js +101 -0
  2009. package/dist/src/utils/toolPool.js +63 -0
  2010. package/dist/src/utils/toolResultStorage.js +769 -0
  2011. package/dist/src/utils/toolSchemaCache.js +7 -0
  2012. package/dist/src/utils/toolSearch.js +551 -0
  2013. package/dist/src/utils/transcriptSearch.js +200 -0
  2014. package/dist/src/utils/treeify.js +111 -0
  2015. package/dist/src/utils/truncate.js +164 -0
  2016. package/dist/src/utils/udsClient.js +16 -0
  2017. package/dist/src/utils/udsMessaging.js +16 -0
  2018. package/dist/src/utils/ultraplan/ccrSession.js +264 -0
  2019. package/dist/src/utils/ultraplan/keyword.js +122 -0
  2020. package/dist/src/utils/ultraplan/prompt.txt +1 -0
  2021. package/dist/src/utils/unaryLogging.js +16 -0
  2022. package/dist/src/utils/undercover.js +89 -0
  2023. package/dist/src/utils/user.js +138 -0
  2024. package/dist/src/utils/userAgent.js +13 -0
  2025. package/dist/src/utils/userPromptKeywords.js +21 -0
  2026. package/dist/src/utils/uuid.js +22 -0
  2027. package/dist/src/utils/warningHandler.js +97 -0
  2028. package/dist/src/utils/which.js +75 -0
  2029. package/dist/src/utils/windowsPaths.js +150 -0
  2030. package/dist/src/utils/withResolvers.js +13 -0
  2031. package/dist/src/utils/words.js +793 -0
  2032. package/dist/src/utils/workloadContext.js +42 -0
  2033. package/dist/src/utils/worktree.js +1145 -0
  2034. package/dist/src/utils/worktreeModeEnabled.js +11 -0
  2035. package/dist/src/utils/xdg.js +52 -0
  2036. package/dist/src/utils/xml.js +15 -0
  2037. package/dist/src/utils/yaml.js +16 -0
  2038. package/dist/src/utils/zodToJsonSchema.js +19 -0
  2039. package/dist/src/vim/motions.js +73 -0
  2040. package/dist/src/vim/operators.js +401 -0
  2041. package/dist/src/vim/textObjects.js +153 -0
  2042. package/dist/src/vim/transitions.js +340 -0
  2043. package/dist/src/vim/types.js +93 -0
  2044. package/dist/src/voice/voiceModeEnabled.js +48 -0
  2045. package/dist/src/whatsapp/bridge.js +267 -0
  2046. package/dist/src/whatsapp/config.js +153 -0
  2047. package/dist/src/whatsapp/markdown.js +37 -0
  2048. package/dist/src/whatsapp/mirror.js +74 -0
  2049. package/dist/src/whatsapp/session.js +142 -0
  2050. package/package.json +2 -1
@@ -0,0 +1,2480 @@
1
+ import { MACRO, feature } from '../../recovery/bunBundleShim.js';
2
+ import { createRequire } from 'module';
3
+ const require = createRequire(import.meta.url);
4
+ import { Client } from '@modelcontextprotocol/sdk/client/index.js';
5
+ import { SSEClientTransport, } from '@modelcontextprotocol/sdk/client/sse.js';
6
+ import { StdioClientTransport } from '@modelcontextprotocol/sdk/client/stdio.js';
7
+ import { StreamableHTTPClientTransport, } from '@modelcontextprotocol/sdk/client/streamableHttp.js';
8
+ import { createFetchWithInit, } from '@modelcontextprotocol/sdk/shared/transport.js';
9
+ import { CallToolResultSchema, ElicitRequestSchema, ErrorCode, ListPromptsResultSchema, ListResourcesResultSchema, ListRootsRequestSchema, ListToolsResultSchema, McpError, } from '@modelcontextprotocol/sdk/types.js';
10
+ import mapValues from 'lodash-es/mapValues.js';
11
+ import memoize from 'lodash-es/memoize.js';
12
+ import zipObject from 'lodash-es/zipObject.js';
13
+ import pMap from 'p-map';
14
+ import { getOriginalCwd, getSessionId } from '../../bootstrap/state.js';
15
+ import { getOauthConfig } from '../../constants/oauth.js';
16
+ import { PRODUCT_URL } from '../../constants/product.js';
17
+ import { toolMatchesName, } from '../../Tool.js';
18
+ import { ListMcpResourcesTool } from '../../tools/ListMcpResourcesTool/ListMcpResourcesTool.js';
19
+ import { MCPTool } from '../../tools/MCPTool/MCPTool.js';
20
+ import { createMcpAuthTool } from '../../tools/McpAuthTool/McpAuthTool.js';
21
+ import { ReadMcpResourceTool } from '../../tools/ReadMcpResourceTool/ReadMcpResourceTool.js';
22
+ import { createAbortController } from '../../utils/abortController.js';
23
+ import { count } from '../../utils/array.js';
24
+ import { checkAndRefreshOAuthTokenIfNeeded, getClaudeAIOAuthTokens, handleOAuth401Error, } from '../../utils/auth.js';
25
+ import { registerCleanup } from '../../utils/cleanupRegistry.js';
26
+ import { detectCodeIndexingFromMcpServerName } from '../../utils/codeIndexing.js';
27
+ import { logForDebugging } from '../../utils/debug.js';
28
+ import { isEnvDefinedFalsy, isEnvTruthy } from '../../utils/envUtils.js';
29
+ import { errorMessage, TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS, } from '../../utils/errors.js';
30
+ import { getMCPUserAgent } from '../../utils/http.js';
31
+ import { maybeNotifyIDEConnected } from '../../utils/ide.js';
32
+ import { maybeResizeAndDownsampleImageBuffer } from '../../utils/imageResizer.js';
33
+ import { logMCPDebug, logMCPError } from '../../utils/log.js';
34
+ import { getBinaryBlobSavedMessage, getFormatDescription, getLargeOutputInstructions, persistBinaryContent, } from '../../utils/mcpOutputStorage.js';
35
+ import { getContentSizeEstimate, mcpContentNeedsTruncation, truncateMcpContentIfNeeded, } from '../../utils/mcpValidation.js';
36
+ import { WebSocketTransport } from '../../utils/mcpWebSocketTransport.js';
37
+ import { memoizeWithLRU } from '../../utils/memoize.js';
38
+ import { getWebSocketTLSOptions } from '../../utils/mtls.js';
39
+ import { getProxyFetchOptions, getWebSocketProxyAgent, getWebSocketProxyUrl, } from '../../utils/proxy.js';
40
+ import { recursivelySanitizeUnicode } from '../../utils/sanitization.js';
41
+ import { getSessionIngressAuthToken } from '../../utils/sessionIngressAuth.js';
42
+ import { subprocessEnv } from '../../utils/subprocessEnv.js';
43
+ import { isPersistError, persistToolResult, } from '../../utils/toolResultStorage.js';
44
+ import { logEvent, } from '../analytics/index.js';
45
+ import { runElicitationHooks, runElicitationResultHooks, } from './elicitationHandler.js';
46
+ import { buildMcpToolName } from './mcpStringUtils.js';
47
+ import { normalizeNameForMCP } from './normalization.js';
48
+ import { getLoggingSafeMcpBaseUrl } from './utils.js';
49
+ /* eslint-disable @typescript-eslint/no-require-imports */
50
+ const fetchMcpSkillsForClient = feature('MCP_SKILLS')
51
+ ? require('../../skills/mcpSkills.js').fetchMcpSkillsForClient
52
+ : null;
53
+ import { UnauthorizedError } from '@modelcontextprotocol/sdk/client/auth.js';
54
+ /* eslint-enable @typescript-eslint/no-require-imports */
55
+ import { classifyMcpToolForCollapse } from '../../tools/MCPTool/classifyForCollapse.js';
56
+ import { clearKeychainCache } from '../../utils/secureStorage/macOsKeychainHelpers.js';
57
+ import { sleep } from '../../utils/sleep.js';
58
+ import { ClaudeAuthProvider, hasMcpDiscoveryButNoToken, wrapFetchWithStepUpDetection, } from './auth.js';
59
+ import { markClaudeAiMcpConnected } from './claudeai.js';
60
+ import { getAllMcpConfigs, isMcpServerDisabled } from './config.js';
61
+ import { getMcpServerHeaders } from './headersHelper.js';
62
+ import { SdkControlClientTransport } from './SdkControlTransport.js';
63
+ /**
64
+ * Custom error class to indicate that an MCP tool call failed due to
65
+ * authentication issues (e.g., expired OAuth token returning 401).
66
+ * This error should be caught at the tool execution layer to update
67
+ * the client's status to 'needs-auth'.
68
+ */
69
+ export class McpAuthError extends Error {
70
+ serverName;
71
+ constructor(serverName, message) {
72
+ super(message);
73
+ this.name = 'McpAuthError';
74
+ this.serverName = serverName;
75
+ }
76
+ }
77
+ /**
78
+ * Thrown when an MCP session has expired and the connection cache has been cleared.
79
+ * The caller should get a fresh client via ensureConnectedClient and retry.
80
+ */
81
+ class McpSessionExpiredError extends Error {
82
+ constructor(serverName) {
83
+ super(`MCP server "${serverName}" session expired`);
84
+ this.name = 'McpSessionExpiredError';
85
+ }
86
+ }
87
+ /**
88
+ * Thrown when an MCP tool returns `isError: true`. Carries the result's `_meta`
89
+ * so SDK consumers can still receive it — per the MCP spec, `_meta` is on the
90
+ * base Result type and is valid on error results.
91
+ */
92
+ export class McpToolCallError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS extends TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS {
93
+ mcpMeta;
94
+ constructor(message, telemetryMessage, mcpMeta) {
95
+ super(message, telemetryMessage);
96
+ this.mcpMeta = mcpMeta;
97
+ this.name = 'McpToolCallError';
98
+ }
99
+ }
100
+ /**
101
+ * Detects whether an error is an MCP "Session not found" error (HTTP 404 + JSON-RPC code -32001).
102
+ * Per the MCP spec, servers return 404 when a session ID is no longer valid.
103
+ * We check both signals to avoid false positives from generic 404s (wrong URL, server gone, etc.).
104
+ */
105
+ export function isMcpSessionExpiredError(error) {
106
+ const httpStatus = 'code' in error ? error.code : undefined;
107
+ if (httpStatus !== 404) {
108
+ return false;
109
+ }
110
+ // The SDK embeds the response body text in the error message.
111
+ // MCP servers return: {"error":{"code":-32001,"message":"Session not found"},...}
112
+ // Check for the JSON-RPC error code to distinguish from generic web server 404s.
113
+ return (error.message.includes('"code":-32001') ||
114
+ error.message.includes('"code": -32001'));
115
+ }
116
+ /**
117
+ * Default timeout for MCP tool calls (effectively infinite - ~27.8 hours).
118
+ */
119
+ const DEFAULT_MCP_TOOL_TIMEOUT_MS = 100_000_000;
120
+ /**
121
+ * Cap on MCP tool descriptions and server instructions sent to the model.
122
+ * OpenAPI-generated MCP servers have been observed dumping 15-60KB of endpoint
123
+ * docs into tool.description; this caps the p95 tail without losing the intent.
124
+ */
125
+ const MAX_MCP_DESCRIPTION_LENGTH = 2048;
126
+ /**
127
+ * Gets the timeout for MCP tool calls in milliseconds.
128
+ * Uses MCP_TOOL_TIMEOUT environment variable if set, otherwise defaults to ~27.8 hours.
129
+ */
130
+ function getMcpToolTimeoutMs() {
131
+ return (parseInt(process.env.MCP_TOOL_TIMEOUT || '', 10) ||
132
+ DEFAULT_MCP_TOOL_TIMEOUT_MS);
133
+ }
134
+ import { isClaudeInChromeMCPServer } from '../../utils/claudeInChrome/common.js';
135
+ // Lazy: toolRendering.tsx pulls React/ink; only needed when Claude-in-Chrome MCP server is connected
136
+ /* eslint-disable @typescript-eslint/no-require-imports */
137
+ const claudeInChromeToolRendering = () => require('../../utils/claudeInChrome/toolRendering.js');
138
+ // Lazy: wrapper.tsx → hostAdapter.ts → executor.ts pulls both native modules
139
+ // (@ant/computer-use-input + @ant/computer-use-swift). Runtime-gated by
140
+ // GrowthBook tengu_malort_pedway (see gates.ts).
141
+ const computerUseWrapper = feature('CHICAGO_MCP')
142
+ ? () => require('../../utils/computerUse/wrapper.js')
143
+ : undefined;
144
+ const isComputerUseMCPServer = feature('CHICAGO_MCP')
145
+ ? require('../../utils/computerUse/common.js').isComputerUseMCPServer
146
+ : undefined;
147
+ import { mkdir, readFile, unlink, writeFile } from 'fs/promises';
148
+ import { dirname, join } from 'path';
149
+ import { getClaudeConfigHomeDir } from '../../utils/envUtils.js';
150
+ /* eslint-enable @typescript-eslint/no-require-imports */
151
+ import { jsonParse, jsonStringify } from '../../utils/slowOperations.js';
152
+ const MCP_AUTH_CACHE_TTL_MS = 15 * 60 * 1000; // 15 min
153
+ function getMcpAuthCachePath() {
154
+ return join(getClaudeConfigHomeDir(), 'mcp-needs-auth-cache.json');
155
+ }
156
+ // Memoized so N concurrent isMcpAuthCached() calls during batched connection
157
+ // share a single file read instead of N reads of the same file. Invalidated
158
+ // on write (setMcpAuthCacheEntry) and clear (clearMcpAuthCache). Not using
159
+ // lodash memoize because we need to null out the cache, not delete by key.
160
+ let authCachePromise = null;
161
+ function getMcpAuthCache() {
162
+ if (!authCachePromise) {
163
+ authCachePromise = readFile(getMcpAuthCachePath(), 'utf-8')
164
+ .then(data => jsonParse(data))
165
+ .catch(() => ({}));
166
+ }
167
+ return authCachePromise;
168
+ }
169
+ async function isMcpAuthCached(serverId) {
170
+ const cache = await getMcpAuthCache();
171
+ const entry = cache[serverId];
172
+ if (!entry) {
173
+ return false;
174
+ }
175
+ return Date.now() - entry.timestamp < MCP_AUTH_CACHE_TTL_MS;
176
+ }
177
+ // Serialize cache writes through a promise chain to prevent concurrent
178
+ // read-modify-write races when multiple servers return 401 in the same batch
179
+ let writeChain = Promise.resolve();
180
+ function setMcpAuthCacheEntry(serverId) {
181
+ writeChain = writeChain
182
+ .then(async () => {
183
+ const cache = await getMcpAuthCache();
184
+ cache[serverId] = { timestamp: Date.now() };
185
+ const cachePath = getMcpAuthCachePath();
186
+ await mkdir(dirname(cachePath), { recursive: true });
187
+ await writeFile(cachePath, jsonStringify(cache));
188
+ // Invalidate the read cache so subsequent reads see the new entry.
189
+ // Safe because writeChain serializes writes: the next write's
190
+ // getMcpAuthCache() call will re-read the file with this entry present.
191
+ authCachePromise = null;
192
+ })
193
+ .catch(() => {
194
+ // Best-effort cache write
195
+ });
196
+ }
197
+ export function clearMcpAuthCache() {
198
+ authCachePromise = null;
199
+ void unlink(getMcpAuthCachePath()).catch(() => {
200
+ // Cache file may not exist
201
+ });
202
+ }
203
+ /**
204
+ * Spread-ready analytics field for the server's base URL. Calls
205
+ * getLoggingSafeMcpBaseUrl once (not twice like the inline ternary it replaces).
206
+ * Typed as AnalyticsMetadata since the URL is query-stripped and safe to log.
207
+ */
208
+ function mcpBaseUrlAnalytics(serverRef) {
209
+ const url = getLoggingSafeMcpBaseUrl(serverRef);
210
+ return url
211
+ ? {
212
+ mcpServerBaseUrl: url,
213
+ }
214
+ : {};
215
+ }
216
+ /**
217
+ * Shared handler for sse/http/claudeai-proxy auth failures during connect:
218
+ * emits tengu_mcp_server_needs_auth, caches the needs-auth entry, and returns
219
+ * the needs-auth connection result.
220
+ */
221
+ function handleRemoteAuthFailure(name, serverRef, transportType) {
222
+ logEvent('tengu_mcp_server_needs_auth', {
223
+ transportType: transportType,
224
+ ...mcpBaseUrlAnalytics(serverRef),
225
+ });
226
+ const label = {
227
+ sse: 'SSE',
228
+ http: 'HTTP',
229
+ 'claudeai-proxy': 'claude.ai proxy',
230
+ };
231
+ logMCPDebug(name, `Authentication required for ${label[transportType]} server`);
232
+ setMcpAuthCacheEntry(name);
233
+ return { name, type: 'needs-auth', config: serverRef };
234
+ }
235
+ /**
236
+ * Fetch wrapper for claude.ai proxy connections. Attaches the OAuth bearer
237
+ * token and retries once on 401 via handleOAuth401Error (force-refresh).
238
+ *
239
+ * The Anthropic API path has this retry (withRetry.ts, grove.ts) to handle
240
+ * memoize-cache staleness and clock drift. Without the same here, a single
241
+ * stale token mass-401s every claude.ai connector and sticks them all in the
242
+ * 15-min needs-auth cache.
243
+ */
244
+ export function createClaudeAiProxyFetch(innerFetch) {
245
+ return async (url, init) => {
246
+ const doRequest = async () => {
247
+ await checkAndRefreshOAuthTokenIfNeeded();
248
+ const currentTokens = getClaudeAIOAuthTokens();
249
+ if (!currentTokens) {
250
+ throw new Error('No claude.ai OAuth token available');
251
+ }
252
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
253
+ const headers = new Headers(init?.headers);
254
+ headers.set('Authorization', `Bearer ${currentTokens.accessToken}`);
255
+ const response = await innerFetch(url, { ...init, headers });
256
+ // Return the exact token that was sent. Reading getClaudeAIOAuthTokens()
257
+ // again after the request is wrong under concurrent 401s: another
258
+ // connector's handleOAuth401Error clears the memoize cache, so we'd read
259
+ // the NEW token from keychain, pass it to handleOAuth401Error, which
260
+ // finds same-as-keychain → returns false → skips retry. Same pattern as
261
+ // bridgeApi.ts withOAuthRetry (token passed as fn param).
262
+ return { response, sentToken: currentTokens.accessToken };
263
+ };
264
+ const { response, sentToken } = await doRequest();
265
+ if (response.status !== 401) {
266
+ return response;
267
+ }
268
+ // handleOAuth401Error returns true only if the token actually changed
269
+ // (keychain had a newer one, or force-refresh succeeded). Gate retry on
270
+ // that — otherwise we double round-trip time for every connector whose
271
+ // downstream service genuinely needs auth (the common case: 30+ servers
272
+ // with "MCP server requires authentication but no OAuth token configured").
273
+ const tokenChanged = await handleOAuth401Error(sentToken).catch(() => false);
274
+ logEvent('tengu_mcp_claudeai_proxy_401', {
275
+ tokenChanged: tokenChanged,
276
+ });
277
+ if (!tokenChanged) {
278
+ // ELOCKED contention: another connector may have won the lockfile and refreshed — check if token changed underneath us
279
+ const now = getClaudeAIOAuthTokens()?.accessToken;
280
+ if (!now || now === sentToken) {
281
+ return response;
282
+ }
283
+ }
284
+ try {
285
+ return (await doRequest()).response;
286
+ }
287
+ catch {
288
+ // Retry itself failed (network error). Return the original 401 so the
289
+ // outer handler can classify it.
290
+ return response;
291
+ }
292
+ };
293
+ }
294
+ /**
295
+ * Create a ws.WebSocket client with the MCP protocol.
296
+ * Bun's ws shim types lack the 3-arg constructor (url, protocols, options)
297
+ * that the real ws package supports, so we cast the constructor here.
298
+ */
299
+ async function createNodeWsClient(url, options) {
300
+ const wsModule = await import('ws');
301
+ const WS = wsModule.default;
302
+ return new WS(url, ['mcp'], options);
303
+ }
304
+ const IMAGE_MIME_TYPES = new Set([
305
+ 'image/jpeg',
306
+ 'image/png',
307
+ 'image/gif',
308
+ 'image/webp',
309
+ ]);
310
+ function getConnectionTimeoutMs() {
311
+ return parseInt(process.env.MCP_TIMEOUT || '', 10) || 30000;
312
+ }
313
+ /**
314
+ * Default timeout for individual MCP requests (auth, tool calls, etc.)
315
+ */
316
+ const MCP_REQUEST_TIMEOUT_MS = 60000;
317
+ /**
318
+ * MCP Streamable HTTP spec requires clients to advertise acceptance of both
319
+ * JSON and SSE on every POST. Servers that enforce this strictly reject
320
+ * requests without it (HTTP 406).
321
+ * https://modelcontextprotocol.io/specification/2025-03-26/basic/transports#sending-messages-to-the-server
322
+ */
323
+ const MCP_STREAMABLE_HTTP_ACCEPT = 'application/json, text/event-stream';
324
+ /**
325
+ * Wraps a fetch function to apply a fresh timeout signal to each request.
326
+ * This avoids the bug where a single AbortSignal.timeout() created at connection
327
+ * time becomes stale after 60 seconds, causing all subsequent requests to fail
328
+ * immediately with "The operation timed out." Uses a 60-second timeout.
329
+ *
330
+ * Also ensures the Accept header required by the MCP Streamable HTTP spec is
331
+ * present on POSTs. The MCP SDK sets this inside StreamableHTTPClientTransport.send(),
332
+ * but it is attached to a Headers instance that passes through an object spread here,
333
+ * and some runtimes/agents have been observed dropping it before it reaches the wire.
334
+ * See https://github.com/anthropics/claude-agent-sdk-typescript/issues/202.
335
+ * Normalizing here (the last wrapper before fetch()) guarantees it is sent.
336
+ *
337
+ * GET requests are excluded from the timeout since, for MCP transports, they are
338
+ * long-lived SSE streams meant to stay open indefinitely. (Auth-related GETs use
339
+ * a separate fetch wrapper with its own timeout in auth.ts.)
340
+ *
341
+ * @param baseFetch - The fetch function to wrap
342
+ */
343
+ export function wrapFetchWithTimeout(baseFetch) {
344
+ return async (url, init) => {
345
+ const method = (init?.method ?? 'GET').toUpperCase();
346
+ // Skip timeout for GET requests - in MCP transports, these are long-lived SSE streams.
347
+ // (OAuth discovery GETs in auth.ts use a separate createAuthFetch() with its own timeout.)
348
+ if (method === 'GET') {
349
+ return baseFetch(url, init);
350
+ }
351
+ // Normalize headers and guarantee the Streamable-HTTP Accept value. new Headers()
352
+ // accepts HeadersInit | undefined and copies from plain objects, tuple arrays,
353
+ // and existing Headers instances — so whatever shape the SDK handed us, the
354
+ // Accept value survives the spread below as an own property of a concrete object.
355
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
356
+ const headers = new Headers(init?.headers);
357
+ if (!headers.has('accept')) {
358
+ headers.set('accept', MCP_STREAMABLE_HTTP_ACCEPT);
359
+ }
360
+ // Use setTimeout instead of AbortSignal.timeout() so we can clearTimeout on
361
+ // completion. AbortSignal.timeout's internal timer is only released when the
362
+ // signal is GC'd, which in Bun is lazy — ~2.4KB of native memory per request
363
+ // lingers for the full 60s even when the request completes in milliseconds.
364
+ const controller = new AbortController();
365
+ const timer = setTimeout(c => c.abort(new DOMException('The operation timed out.', 'TimeoutError')), MCP_REQUEST_TIMEOUT_MS, controller);
366
+ timer.unref?.();
367
+ const parentSignal = init?.signal;
368
+ const abort = () => controller.abort(parentSignal?.reason);
369
+ parentSignal?.addEventListener('abort', abort);
370
+ if (parentSignal?.aborted) {
371
+ controller.abort(parentSignal.reason);
372
+ }
373
+ const cleanup = () => {
374
+ clearTimeout(timer);
375
+ parentSignal?.removeEventListener('abort', abort);
376
+ };
377
+ try {
378
+ const response = await baseFetch(url, {
379
+ ...init,
380
+ headers,
381
+ signal: controller.signal,
382
+ });
383
+ cleanup();
384
+ return response;
385
+ }
386
+ catch (error) {
387
+ cleanup();
388
+ throw error;
389
+ }
390
+ };
391
+ }
392
+ export function getMcpServerConnectionBatchSize() {
393
+ return parseInt(process.env.MCP_SERVER_CONNECTION_BATCH_SIZE || '', 10) || 3;
394
+ }
395
+ function getRemoteMcpServerConnectionBatchSize() {
396
+ return (parseInt(process.env.MCP_REMOTE_SERVER_CONNECTION_BATCH_SIZE || '', 10) ||
397
+ 20);
398
+ }
399
+ function isLocalMcpServer(config) {
400
+ return !config.type || config.type === 'stdio' || config.type === 'sdk';
401
+ }
402
+ // For the IDE MCP servers, we only include specific tools
403
+ const ALLOWED_IDE_TOOLS = ['mcp__ide__executeCode', 'mcp__ide__getDiagnostics'];
404
+ function isIncludedMcpTool(tool) {
405
+ return (!tool.name.startsWith('mcp__ide__') || ALLOWED_IDE_TOOLS.includes(tool.name));
406
+ }
407
+ /**
408
+ * Generates the cache key for a server connection
409
+ * @param name Server name
410
+ * @param serverRef Server configuration
411
+ * @returns Cache key string
412
+ */
413
+ export function getServerCacheKey(name, serverRef) {
414
+ return `${name}-${jsonStringify(serverRef)}`;
415
+ }
416
+ /**
417
+ * TODO (ollie): The memoization here increases complexity by a lot, and im not sure it really improves performance
418
+ * Attempts to connect to a single MCP server
419
+ * @param name Server name
420
+ * @param serverRef Scoped server configuration
421
+ * @returns A wrapped client (either connected or failed)
422
+ */
423
+ export const connectToServer = memoize(async (name, serverRef, serverStats) => {
424
+ const connectStartTime = Date.now();
425
+ let inProcessServer;
426
+ try {
427
+ let transport;
428
+ // If we have the session ingress JWT, we will connect via the session ingress rather than
429
+ // to remote MCP's directly.
430
+ const sessionIngressToken = getSessionIngressAuthToken();
431
+ if (serverRef.type === 'sse') {
432
+ // Create an auth provider for this server
433
+ const authProvider = new ClaudeAuthProvider(name, serverRef);
434
+ // Get combined headers (static + dynamic)
435
+ const combinedHeaders = await getMcpServerHeaders(name, serverRef);
436
+ // Use the auth provider with SSEClientTransport
437
+ const transportOptions = {
438
+ authProvider,
439
+ // Use fresh timeout per request to avoid stale AbortSignal bug.
440
+ // Step-up detection wraps innermost so the 403 is seen before the
441
+ // SDK's handler calls auth() → tokens().
442
+ fetch: wrapFetchWithTimeout(wrapFetchWithStepUpDetection(createFetchWithInit(), authProvider)),
443
+ requestInit: {
444
+ headers: {
445
+ 'User-Agent': getMCPUserAgent(),
446
+ ...combinedHeaders,
447
+ },
448
+ },
449
+ };
450
+ // IMPORTANT: Always set eventSourceInit with a fetch that does NOT use the
451
+ // timeout wrapper. The EventSource connection is long-lived (stays open indefinitely
452
+ // to receive server-sent events), so applying a 60-second timeout would kill it.
453
+ // The timeout is only meant for individual API requests (POST, auth refresh), not
454
+ // the persistent SSE stream.
455
+ transportOptions.eventSourceInit = {
456
+ fetch: async (url, init) => {
457
+ // Get auth headers from the auth provider
458
+ const authHeaders = {};
459
+ const tokens = await authProvider.tokens();
460
+ if (tokens) {
461
+ authHeaders.Authorization = `Bearer ${tokens.access_token}`;
462
+ }
463
+ const proxyOptions = getProxyFetchOptions();
464
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
465
+ return fetch(url, {
466
+ ...init,
467
+ ...proxyOptions,
468
+ headers: {
469
+ 'User-Agent': getMCPUserAgent(),
470
+ ...authHeaders,
471
+ ...init?.headers,
472
+ ...combinedHeaders,
473
+ Accept: 'text/event-stream',
474
+ },
475
+ });
476
+ },
477
+ };
478
+ transport = new SSEClientTransport(new URL(serverRef.url), transportOptions);
479
+ logMCPDebug(name, `SSE transport initialized, awaiting connection`);
480
+ }
481
+ else if (serverRef.type === 'sse-ide') {
482
+ logMCPDebug(name, `Setting up SSE-IDE transport to ${serverRef.url}`);
483
+ // IDE servers don't need authentication
484
+ // TODO: Use the auth token provided in the lockfile
485
+ const proxyOptions = getProxyFetchOptions();
486
+ const transportOptions = proxyOptions.dispatcher
487
+ ? {
488
+ eventSourceInit: {
489
+ fetch: async (url, init) => {
490
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
491
+ return fetch(url, {
492
+ ...init,
493
+ ...proxyOptions,
494
+ headers: {
495
+ 'User-Agent': getMCPUserAgent(),
496
+ ...init?.headers,
497
+ },
498
+ });
499
+ },
500
+ },
501
+ }
502
+ : {};
503
+ transport = new SSEClientTransport(new URL(serverRef.url), Object.keys(transportOptions).length > 0
504
+ ? transportOptions
505
+ : undefined);
506
+ }
507
+ else if (serverRef.type === 'ws-ide') {
508
+ const tlsOptions = getWebSocketTLSOptions();
509
+ const wsHeaders = {
510
+ 'User-Agent': getMCPUserAgent(),
511
+ ...(serverRef.authToken && {
512
+ 'X-Claude-Code-Ide-Authorization': serverRef.authToken,
513
+ }),
514
+ };
515
+ let wsClient;
516
+ if (typeof Bun !== 'undefined') {
517
+ // Bun's WebSocket supports headers/proxy/tls options but the DOM typings don't
518
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
519
+ wsClient = new globalThis.WebSocket(serverRef.url, {
520
+ protocols: ['mcp'],
521
+ headers: wsHeaders,
522
+ proxy: getWebSocketProxyUrl(serverRef.url),
523
+ tls: tlsOptions || undefined,
524
+ });
525
+ }
526
+ else {
527
+ wsClient = await createNodeWsClient(serverRef.url, {
528
+ headers: wsHeaders,
529
+ agent: getWebSocketProxyAgent(serverRef.url),
530
+ ...(tlsOptions || {}),
531
+ });
532
+ }
533
+ transport = new WebSocketTransport(wsClient);
534
+ }
535
+ else if (serverRef.type === 'ws') {
536
+ logMCPDebug(name, `Initializing WebSocket transport to ${serverRef.url}`);
537
+ const combinedHeaders = await getMcpServerHeaders(name, serverRef);
538
+ const tlsOptions = getWebSocketTLSOptions();
539
+ const wsHeaders = {
540
+ 'User-Agent': getMCPUserAgent(),
541
+ ...(sessionIngressToken && {
542
+ Authorization: `Bearer ${sessionIngressToken}`,
543
+ }),
544
+ ...combinedHeaders,
545
+ };
546
+ // Redact sensitive headers before logging
547
+ const wsHeadersForLogging = mapValues(wsHeaders, (value, key) => key.toLowerCase() === 'authorization' ? '[REDACTED]' : value);
548
+ logMCPDebug(name, `WebSocket transport options: ${jsonStringify({
549
+ url: serverRef.url,
550
+ headers: wsHeadersForLogging,
551
+ hasSessionAuth: !!sessionIngressToken,
552
+ })}`);
553
+ let wsClient;
554
+ if (typeof Bun !== 'undefined') {
555
+ // Bun's WebSocket supports headers/proxy/tls options but the DOM typings don't
556
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
557
+ wsClient = new globalThis.WebSocket(serverRef.url, {
558
+ protocols: ['mcp'],
559
+ headers: wsHeaders,
560
+ proxy: getWebSocketProxyUrl(serverRef.url),
561
+ tls: tlsOptions || undefined,
562
+ });
563
+ }
564
+ else {
565
+ wsClient = await createNodeWsClient(serverRef.url, {
566
+ headers: wsHeaders,
567
+ agent: getWebSocketProxyAgent(serverRef.url),
568
+ ...(tlsOptions || {}),
569
+ });
570
+ }
571
+ transport = new WebSocketTransport(wsClient);
572
+ }
573
+ else if (serverRef.type === 'http') {
574
+ logMCPDebug(name, `Initializing HTTP transport to ${serverRef.url}`);
575
+ logMCPDebug(name, `Node version: ${process.version}, Platform: ${process.platform}`);
576
+ logMCPDebug(name, `Environment: ${jsonStringify({
577
+ NODE_OPTIONS: process.env.NODE_OPTIONS || 'not set',
578
+ UV_THREADPOOL_SIZE: process.env.UV_THREADPOOL_SIZE || 'default',
579
+ HTTP_PROXY: process.env.HTTP_PROXY || 'not set',
580
+ HTTPS_PROXY: process.env.HTTPS_PROXY || 'not set',
581
+ NO_PROXY: process.env.NO_PROXY || 'not set',
582
+ })}`);
583
+ // Create an auth provider for this server
584
+ const authProvider = new ClaudeAuthProvider(name, serverRef);
585
+ // Get combined headers (static + dynamic)
586
+ const combinedHeaders = await getMcpServerHeaders(name, serverRef);
587
+ // Check if this server has stored OAuth tokens. If so, the SDK's
588
+ // authProvider will set Authorization — don't override with the
589
+ // session ingress token (SDK merges requestInit AFTER authProvider).
590
+ // CCR proxy URLs (ccr_shttp_mcp) have no stored OAuth, so they still
591
+ // get the ingress token. See PR #24454 discussion.
592
+ const hasOAuthTokens = !!(await authProvider.tokens());
593
+ // Use the auth provider with StreamableHTTPClientTransport
594
+ const proxyOptions = getProxyFetchOptions();
595
+ logMCPDebug(name, `Proxy options: ${proxyOptions.dispatcher ? 'custom dispatcher' : 'default'}`);
596
+ const transportOptions = {
597
+ authProvider,
598
+ // Use fresh timeout per request to avoid stale AbortSignal bug.
599
+ // Step-up detection wraps innermost so the 403 is seen before the
600
+ // SDK's handler calls auth() → tokens().
601
+ fetch: wrapFetchWithTimeout(wrapFetchWithStepUpDetection(createFetchWithInit(), authProvider)),
602
+ requestInit: {
603
+ ...proxyOptions,
604
+ headers: {
605
+ 'User-Agent': getMCPUserAgent(),
606
+ ...(sessionIngressToken &&
607
+ !hasOAuthTokens && {
608
+ Authorization: `Bearer ${sessionIngressToken}`,
609
+ }),
610
+ ...combinedHeaders,
611
+ },
612
+ },
613
+ };
614
+ // Redact sensitive headers before logging
615
+ const headersForLogging = transportOptions.requestInit?.headers
616
+ ? mapValues(transportOptions.requestInit.headers, (value, key) => key.toLowerCase() === 'authorization' ? '[REDACTED]' : value)
617
+ : undefined;
618
+ logMCPDebug(name, `HTTP transport options: ${jsonStringify({
619
+ url: serverRef.url,
620
+ headers: headersForLogging,
621
+ hasAuthProvider: !!authProvider,
622
+ timeoutMs: MCP_REQUEST_TIMEOUT_MS,
623
+ })}`);
624
+ transport = new StreamableHTTPClientTransport(new URL(serverRef.url), transportOptions);
625
+ logMCPDebug(name, `HTTP transport created successfully`);
626
+ }
627
+ else if (serverRef.type === 'sdk') {
628
+ throw new Error('SDK servers should be handled in print.ts');
629
+ }
630
+ else if (serverRef.type === 'claudeai-proxy') {
631
+ logMCPDebug(name, `Initializing claude.ai proxy transport for server ${serverRef.id}`);
632
+ const tokens = getClaudeAIOAuthTokens();
633
+ if (!tokens) {
634
+ throw new Error('No claude.ai OAuth token found');
635
+ }
636
+ const oauthConfig = getOauthConfig();
637
+ const proxyUrl = `${oauthConfig.MCP_PROXY_URL}${oauthConfig.MCP_PROXY_PATH.replace('{server_id}', serverRef.id)}`;
638
+ logMCPDebug(name, `Using claude.ai proxy at ${proxyUrl}`);
639
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
640
+ const fetchWithAuth = createClaudeAiProxyFetch(globalThis.fetch);
641
+ const proxyOptions = getProxyFetchOptions();
642
+ const transportOptions = {
643
+ // Wrap fetchWithAuth with fresh timeout per request
644
+ fetch: wrapFetchWithTimeout(fetchWithAuth),
645
+ requestInit: {
646
+ ...proxyOptions,
647
+ headers: {
648
+ 'User-Agent': getMCPUserAgent(),
649
+ 'X-Mcp-Client-Session-Id': getSessionId(),
650
+ },
651
+ },
652
+ };
653
+ transport = new StreamableHTTPClientTransport(new URL(proxyUrl), transportOptions);
654
+ logMCPDebug(name, `claude.ai proxy transport created successfully`);
655
+ }
656
+ else if ((serverRef.type === 'stdio' || !serverRef.type) &&
657
+ isClaudeInChromeMCPServer(name)) {
658
+ // Run the Chrome MCP server in-process to avoid spawning a ~325 MB subprocess
659
+ const { createChromeContext } = await import('../../utils/claudeInChrome/mcpServer.js');
660
+ const { createClaudeForChromeMcpServer } = await import('@ant/claude-for-chrome-mcp');
661
+ const { createLinkedTransportPair } = await import('./InProcessTransport.js');
662
+ const context = createChromeContext(serverRef.env);
663
+ inProcessServer = createClaudeForChromeMcpServer(context);
664
+ const [clientTransport, serverTransport] = createLinkedTransportPair();
665
+ await inProcessServer.connect(serverTransport);
666
+ transport = clientTransport;
667
+ logMCPDebug(name, `In-process Chrome MCP server started`);
668
+ }
669
+ else if (feature('CHICAGO_MCP') &&
670
+ (serverRef.type === 'stdio' || !serverRef.type) &&
671
+ isComputerUseMCPServer(name)) {
672
+ // Run the Computer Use MCP server in-process — same rationale as
673
+ // Chrome above. The package's CallTool handler is a stub; real
674
+ // dispatch goes through wrapper.tsx's .call() override.
675
+ const { createComputerUseMcpServerForCli } = await import('../../utils/computerUse/mcpServer.js');
676
+ const { createLinkedTransportPair } = await import('./InProcessTransport.js');
677
+ inProcessServer = await createComputerUseMcpServerForCli();
678
+ const [clientTransport, serverTransport] = createLinkedTransportPair();
679
+ await inProcessServer.connect(serverTransport);
680
+ transport = clientTransport;
681
+ logMCPDebug(name, `In-process Computer Use MCP server started`);
682
+ }
683
+ else if (serverRef.type === 'stdio' || !serverRef.type) {
684
+ const finalCommand = process.env.CLAUDE_CODE_SHELL_PREFIX || serverRef.command;
685
+ const finalArgs = process.env.CLAUDE_CODE_SHELL_PREFIX
686
+ ? [[serverRef.command, ...serverRef.args].join(' ')]
687
+ : serverRef.args;
688
+ transport = new StdioClientTransport({
689
+ command: finalCommand,
690
+ args: finalArgs,
691
+ env: {
692
+ ...subprocessEnv(),
693
+ ...serverRef.env,
694
+ },
695
+ stderr: 'pipe', // prevents error output from the MCP server from printing to the UI
696
+ });
697
+ }
698
+ else {
699
+ throw new Error(`Unsupported server type: ${serverRef.type}`);
700
+ }
701
+ // Set up stderr logging for stdio transport before connecting in case there are any stderr
702
+ // outputs emitted during the connection start (this can be useful for debugging failed connections).
703
+ // Store handler reference for cleanup to prevent memory leaks
704
+ let stderrHandler;
705
+ let stderrOutput = '';
706
+ if (serverRef.type === 'stdio' || !serverRef.type) {
707
+ const stdioTransport = transport;
708
+ if (stdioTransport.stderr) {
709
+ stderrHandler = (data) => {
710
+ // Cap stderr accumulation to prevent unbounded memory growth
711
+ if (stderrOutput.length < 64 * 1024 * 1024) {
712
+ try {
713
+ stderrOutput += data.toString();
714
+ }
715
+ catch {
716
+ // Ignore errors from exceeding max string length
717
+ }
718
+ }
719
+ };
720
+ stdioTransport.stderr.on('data', stderrHandler);
721
+ }
722
+ }
723
+ const client = new Client({
724
+ name: 'claude-code',
725
+ title: 'Context Code',
726
+ version: MACRO.VERSION ?? 'unknown',
727
+ description: "Anthropic's agentic coding tool",
728
+ websiteUrl: PRODUCT_URL,
729
+ }, {
730
+ capabilities: {
731
+ roots: {},
732
+ // Empty object declares the capability. Sending {form:{},url:{}}
733
+ // breaks Java MCP SDK servers (Spring AI) whose Elicitation class
734
+ // has zero fields and fails on unknown properties.
735
+ elicitation: {},
736
+ },
737
+ });
738
+ // Add debug logging for client events if available
739
+ if (serverRef.type === 'http') {
740
+ logMCPDebug(name, `Client created, setting up request handler`);
741
+ }
742
+ client.setRequestHandler(ListRootsRequestSchema, async () => {
743
+ logMCPDebug(name, `Received ListRoots request from server`);
744
+ return {
745
+ roots: [
746
+ {
747
+ uri: `file://${getOriginalCwd()}`,
748
+ },
749
+ ],
750
+ };
751
+ });
752
+ // Add a timeout to connection attempts to prevent tests from hanging indefinitely
753
+ logMCPDebug(name, `Starting connection with timeout of ${getConnectionTimeoutMs()}ms`);
754
+ // For HTTP transport, try a basic connectivity test first
755
+ if (serverRef.type === 'http') {
756
+ logMCPDebug(name, `Testing basic HTTP connectivity to ${serverRef.url}`);
757
+ try {
758
+ const testUrl = new URL(serverRef.url);
759
+ logMCPDebug(name, `Parsed URL: host=${testUrl.hostname}, port=${testUrl.port || 'default'}, protocol=${testUrl.protocol}`);
760
+ // Log DNS resolution attempt
761
+ if (testUrl.hostname === '127.0.0.1' ||
762
+ testUrl.hostname === 'localhost') {
763
+ logMCPDebug(name, `Using loopback address: ${testUrl.hostname}`);
764
+ }
765
+ }
766
+ catch (urlError) {
767
+ logMCPDebug(name, `Failed to parse URL: ${urlError}`);
768
+ }
769
+ }
770
+ const connectPromise = client.connect(transport);
771
+ const timeoutPromise = new Promise((_, reject) => {
772
+ const timeoutId = setTimeout(() => {
773
+ const elapsed = Date.now() - connectStartTime;
774
+ logMCPDebug(name, `Connection timeout triggered after ${elapsed}ms (limit: ${getConnectionTimeoutMs()}ms)`);
775
+ if (inProcessServer) {
776
+ inProcessServer.close().catch(() => { });
777
+ }
778
+ transport.close().catch(() => { });
779
+ reject(new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(`MCP server "${name}" connection timed out after ${getConnectionTimeoutMs()}ms`, 'MCP connection timeout'));
780
+ }, getConnectionTimeoutMs());
781
+ // Clean up timeout if connect resolves or rejects
782
+ connectPromise.then(() => {
783
+ clearTimeout(timeoutId);
784
+ }, _error => {
785
+ clearTimeout(timeoutId);
786
+ });
787
+ });
788
+ try {
789
+ await Promise.race([connectPromise, timeoutPromise]);
790
+ if (stderrOutput) {
791
+ logMCPError(name, `Server stderr: ${stderrOutput}`);
792
+ stderrOutput = ''; // Release accumulated string to prevent memory growth
793
+ }
794
+ const elapsed = Date.now() - connectStartTime;
795
+ logMCPDebug(name, `Successfully connected (transport: ${serverRef.type || 'stdio'}) in ${elapsed}ms`);
796
+ }
797
+ catch (error) {
798
+ const elapsed = Date.now() - connectStartTime;
799
+ // SSE-specific error logging
800
+ if (serverRef.type === 'sse' && error instanceof Error) {
801
+ logMCPDebug(name, `SSE Connection failed after ${elapsed}ms: ${jsonStringify({
802
+ url: serverRef.url,
803
+ error: error.message,
804
+ errorType: error.constructor.name,
805
+ stack: error.stack,
806
+ })}`);
807
+ logMCPError(name, error);
808
+ if (error instanceof UnauthorizedError) {
809
+ return handleRemoteAuthFailure(name, serverRef, 'sse');
810
+ }
811
+ }
812
+ else if (serverRef.type === 'http' && error instanceof Error) {
813
+ const errorObj = error;
814
+ logMCPDebug(name, `HTTP Connection failed after ${elapsed}ms: ${error.message} (code: ${errorObj.code || 'none'}, errno: ${errorObj.errno || 'none'})`);
815
+ logMCPError(name, error);
816
+ if (error instanceof UnauthorizedError) {
817
+ return handleRemoteAuthFailure(name, serverRef, 'http');
818
+ }
819
+ }
820
+ else if (serverRef.type === 'claudeai-proxy' &&
821
+ error instanceof Error) {
822
+ logMCPDebug(name, `claude.ai proxy connection failed after ${elapsed}ms: ${error.message}`);
823
+ logMCPError(name, error);
824
+ // StreamableHTTPError has a `code` property with the HTTP status
825
+ const errorCode = error.code;
826
+ if (errorCode === 401) {
827
+ return handleRemoteAuthFailure(name, serverRef, 'claudeai-proxy');
828
+ }
829
+ }
830
+ else if (serverRef.type === 'sse-ide' ||
831
+ serverRef.type === 'ws-ide') {
832
+ logEvent('tengu_mcp_ide_server_connection_failed', {
833
+ connectionDurationMs: elapsed,
834
+ });
835
+ }
836
+ if (inProcessServer) {
837
+ inProcessServer.close().catch(() => { });
838
+ }
839
+ transport.close().catch(() => { });
840
+ if (stderrOutput) {
841
+ logMCPError(name, `Server stderr: ${stderrOutput}`);
842
+ }
843
+ throw error;
844
+ }
845
+ const capabilities = client.getServerCapabilities();
846
+ const serverVersion = client.getServerVersion();
847
+ const rawInstructions = client.getInstructions();
848
+ let instructions = rawInstructions;
849
+ if (rawInstructions &&
850
+ rawInstructions.length > MAX_MCP_DESCRIPTION_LENGTH) {
851
+ instructions =
852
+ rawInstructions.slice(0, MAX_MCP_DESCRIPTION_LENGTH) + '… [truncated]';
853
+ logMCPDebug(name, `Server instructions truncated from ${rawInstructions.length} to ${MAX_MCP_DESCRIPTION_LENGTH} chars`);
854
+ }
855
+ // Log successful connection details
856
+ logMCPDebug(name, `Connection established with capabilities: ${jsonStringify({
857
+ hasTools: !!capabilities?.tools,
858
+ hasPrompts: !!capabilities?.prompts,
859
+ hasResources: !!capabilities?.resources,
860
+ hasResourceSubscribe: !!capabilities?.resources?.subscribe,
861
+ serverVersion: serverVersion || 'unknown',
862
+ })}`);
863
+ logForDebugging(`[MCP] Server "${name}" connected with subscribe=${!!capabilities?.resources?.subscribe}`);
864
+ // Register default elicitation handler that returns cancel during the
865
+ // window before registerElicitationHandler overwrites it in
866
+ // onConnectionAttempt (useManageMCPConnections).
867
+ client.setRequestHandler(ElicitRequestSchema, async (request) => {
868
+ logMCPDebug(name, `Elicitation request received during initialization: ${jsonStringify(request)}`);
869
+ return { action: 'cancel' };
870
+ });
871
+ if (serverRef.type === 'sse-ide' || serverRef.type === 'ws-ide') {
872
+ const ideConnectionDurationMs = Date.now() - connectStartTime;
873
+ logEvent('tengu_mcp_ide_server_connection_succeeded', {
874
+ connectionDurationMs: ideConnectionDurationMs,
875
+ serverVersion: serverVersion,
876
+ });
877
+ try {
878
+ void maybeNotifyIDEConnected(client);
879
+ }
880
+ catch (error) {
881
+ logMCPError(name, `Failed to send ide_connected notification: ${error}`);
882
+ }
883
+ }
884
+ // Enhanced connection drop detection and logging for all transport types
885
+ const connectionStartTime = Date.now();
886
+ let hasErrorOccurred = false;
887
+ // Store original handlers
888
+ const originalOnerror = client.onerror;
889
+ const originalOnclose = client.onclose;
890
+ // The SDK's transport calls onerror on connection failures but doesn't call onclose,
891
+ // which CC uses to trigger reconnection. We bridge this gap by tracking consecutive
892
+ // terminal errors and manually closing after MAX_ERRORS_BEFORE_RECONNECT failures.
893
+ let consecutiveConnectionErrors = 0;
894
+ const MAX_ERRORS_BEFORE_RECONNECT = 3;
895
+ // Guard against re-entry: close() aborts in-flight streams which may fire
896
+ // onerror again before the close chain completes.
897
+ let hasTriggeredClose = false;
898
+ // client.close() → transport.close() → transport.onclose → SDK's _onclose():
899
+ // rejects all pending request handlers (so hung callTool() promises fail with
900
+ // McpError -32000 "Connection closed") and then invokes our client.onclose
901
+ // handler below (which clears the memo cache so the next call reconnects).
902
+ // Calling client.onclose?.() directly would only clear the cache — pending
903
+ // tool calls would stay hung.
904
+ const closeTransportAndRejectPending = (reason) => {
905
+ if (hasTriggeredClose)
906
+ return;
907
+ hasTriggeredClose = true;
908
+ logMCPDebug(name, `Closing transport (${reason})`);
909
+ void client.close().catch(e => {
910
+ logMCPDebug(name, `Error during close: ${errorMessage(e)}`);
911
+ });
912
+ };
913
+ const isTerminalConnectionError = (msg) => {
914
+ return (msg.includes('ECONNRESET') ||
915
+ msg.includes('ETIMEDOUT') ||
916
+ msg.includes('EPIPE') ||
917
+ msg.includes('EHOSTUNREACH') ||
918
+ msg.includes('ECONNREFUSED') ||
919
+ msg.includes('Body Timeout Error') ||
920
+ msg.includes('terminated') ||
921
+ // SDK SSE reconnection intermediate errors — may be wrapped around the
922
+ // actual network error, so the substrings above won't match
923
+ msg.includes('SSE stream disconnected') ||
924
+ msg.includes('Failed to reconnect SSE stream'));
925
+ };
926
+ // Enhanced error handler with detailed logging
927
+ client.onerror = (error) => {
928
+ const uptime = Date.now() - connectionStartTime;
929
+ hasErrorOccurred = true;
930
+ const transportType = serverRef.type || 'stdio';
931
+ // Log the connection drop with context
932
+ logMCPDebug(name, `${transportType.toUpperCase()} connection dropped after ${Math.floor(uptime / 1000)}s uptime`);
933
+ // Log specific error details for debugging
934
+ if (error.message) {
935
+ if (error.message.includes('ECONNRESET')) {
936
+ logMCPDebug(name, `Connection reset - server may have crashed or restarted`);
937
+ }
938
+ else if (error.message.includes('ETIMEDOUT')) {
939
+ logMCPDebug(name, `Connection timeout - network issue or server unresponsive`);
940
+ }
941
+ else if (error.message.includes('ECONNREFUSED')) {
942
+ logMCPDebug(name, `Connection refused - server may be down`);
943
+ }
944
+ else if (error.message.includes('EPIPE')) {
945
+ logMCPDebug(name, `Broken pipe - server closed connection unexpectedly`);
946
+ }
947
+ else if (error.message.includes('EHOSTUNREACH')) {
948
+ logMCPDebug(name, `Host unreachable - network connectivity issue`);
949
+ }
950
+ else if (error.message.includes('ESRCH')) {
951
+ logMCPDebug(name, `Process not found - stdio server process terminated`);
952
+ }
953
+ else if (error.message.includes('spawn')) {
954
+ logMCPDebug(name, `Failed to spawn process - check command and permissions`);
955
+ }
956
+ else {
957
+ logMCPDebug(name, `Connection error: ${error.message}`);
958
+ }
959
+ }
960
+ // For HTTP transports, detect session expiry (404 + JSON-RPC -32001)
961
+ // and close the transport so pending tool calls reject and the next
962
+ // call reconnects with a fresh session ID.
963
+ if ((transportType === 'http' || transportType === 'claudeai-proxy') &&
964
+ isMcpSessionExpiredError(error)) {
965
+ logMCPDebug(name, `MCP session expired (server returned 404 with session-not-found), triggering reconnection`);
966
+ closeTransportAndRejectPending('session expired');
967
+ if (originalOnerror) {
968
+ originalOnerror(error);
969
+ }
970
+ return;
971
+ }
972
+ // For remote transports (SSE/HTTP), track terminal connection errors
973
+ // and trigger reconnection via close if we see repeated failures.
974
+ if (transportType === 'sse' ||
975
+ transportType === 'http' ||
976
+ transportType === 'claudeai-proxy') {
977
+ // The SDK's StreamableHTTP transport fires this after exhausting its
978
+ // own SSE reconnect attempts (default maxRetries: 2) — but it never
979
+ // calls onclose, so pending callTool() promises hang indefinitely.
980
+ // This is the definitive "transport gave up" signal.
981
+ if (error.message.includes('Maximum reconnection attempts')) {
982
+ closeTransportAndRejectPending('SSE reconnection exhausted');
983
+ if (originalOnerror) {
984
+ originalOnerror(error);
985
+ }
986
+ return;
987
+ }
988
+ if (isTerminalConnectionError(error.message)) {
989
+ consecutiveConnectionErrors++;
990
+ logMCPDebug(name, `Terminal connection error ${consecutiveConnectionErrors}/${MAX_ERRORS_BEFORE_RECONNECT}`);
991
+ if (consecutiveConnectionErrors >= MAX_ERRORS_BEFORE_RECONNECT) {
992
+ consecutiveConnectionErrors = 0;
993
+ closeTransportAndRejectPending('max consecutive terminal errors');
994
+ }
995
+ }
996
+ else {
997
+ // Non-terminal error (e.g., transient issue), reset counter
998
+ consecutiveConnectionErrors = 0;
999
+ }
1000
+ }
1001
+ // Call original handler
1002
+ if (originalOnerror) {
1003
+ originalOnerror(error);
1004
+ }
1005
+ };
1006
+ // Enhanced close handler with connection drop context
1007
+ client.onclose = () => {
1008
+ const uptime = Date.now() - connectionStartTime;
1009
+ const transportType = serverRef.type ?? 'unknown';
1010
+ logMCPDebug(name, `${transportType.toUpperCase()} connection closed after ${Math.floor(uptime / 1000)}s (${hasErrorOccurred ? 'with errors' : 'cleanly'})`);
1011
+ // Clear the memoization cache so next operation reconnects
1012
+ const key = getServerCacheKey(name, serverRef);
1013
+ // Also clear fetch caches (keyed by server name). Reconnection
1014
+ // creates a new connection object; without clearing, the next
1015
+ // fetch would return stale tools/resources from the old connection.
1016
+ fetchToolsForClient.cache.delete(name);
1017
+ fetchResourcesForClient.cache.delete(name);
1018
+ fetchCommandsForClient.cache.delete(name);
1019
+ if (feature('MCP_SKILLS')) {
1020
+ fetchMcpSkillsForClient.cache.delete(name);
1021
+ }
1022
+ connectToServer.cache.delete(key);
1023
+ logMCPDebug(name, `Cleared connection cache for reconnection`);
1024
+ if (originalOnclose) {
1025
+ originalOnclose();
1026
+ }
1027
+ };
1028
+ const cleanup = async () => {
1029
+ // In-process servers (e.g. Chrome MCP) don't have child processes or stderr
1030
+ if (inProcessServer) {
1031
+ try {
1032
+ await inProcessServer.close();
1033
+ }
1034
+ catch (error) {
1035
+ logMCPDebug(name, `Error closing in-process server: ${error}`);
1036
+ }
1037
+ try {
1038
+ await client.close();
1039
+ }
1040
+ catch (error) {
1041
+ logMCPDebug(name, `Error closing client: ${error}`);
1042
+ }
1043
+ return;
1044
+ }
1045
+ // Remove stderr event listener to prevent memory leaks
1046
+ if (stderrHandler && (serverRef.type === 'stdio' || !serverRef.type)) {
1047
+ const stdioTransport = transport;
1048
+ stdioTransport.stderr?.off('data', stderrHandler);
1049
+ }
1050
+ // For stdio transports, explicitly terminate the child process with proper signals
1051
+ // NOTE: StdioClientTransport.close() only sends an abort signal, but many MCP servers
1052
+ // (especially Docker containers) need explicit SIGINT/SIGTERM signals to trigger graceful shutdown
1053
+ if (serverRef.type === 'stdio') {
1054
+ try {
1055
+ const stdioTransport = transport;
1056
+ const childPid = stdioTransport.pid;
1057
+ if (childPid) {
1058
+ logMCPDebug(name, 'Sending SIGINT to MCP server process');
1059
+ // First try SIGINT (like Ctrl+C)
1060
+ try {
1061
+ process.kill(childPid, 'SIGINT');
1062
+ }
1063
+ catch (error) {
1064
+ logMCPDebug(name, `Error sending SIGINT: ${error}`);
1065
+ return;
1066
+ }
1067
+ // Wait for graceful shutdown with rapid escalation (total 500ms to keep CLI responsive)
1068
+ await new Promise(async (resolve) => {
1069
+ let resolved = false;
1070
+ // Set up a timer to check if process still exists
1071
+ const checkInterval = setInterval(() => {
1072
+ try {
1073
+ // process.kill(pid, 0) checks if process exists without killing it
1074
+ process.kill(childPid, 0);
1075
+ }
1076
+ catch {
1077
+ // Process no longer exists
1078
+ if (!resolved) {
1079
+ resolved = true;
1080
+ clearInterval(checkInterval);
1081
+ clearTimeout(failsafeTimeout);
1082
+ logMCPDebug(name, 'MCP server process exited cleanly');
1083
+ resolve();
1084
+ }
1085
+ }
1086
+ }, 50);
1087
+ // Absolute failsafe: clear interval after 600ms no matter what
1088
+ const failsafeTimeout = setTimeout(() => {
1089
+ if (!resolved) {
1090
+ resolved = true;
1091
+ clearInterval(checkInterval);
1092
+ logMCPDebug(name, 'Cleanup timeout reached, stopping process monitoring');
1093
+ resolve();
1094
+ }
1095
+ }, 600);
1096
+ try {
1097
+ // Wait 100ms for SIGINT to work (usually much faster)
1098
+ await sleep(100);
1099
+ if (!resolved) {
1100
+ // Check if process still exists
1101
+ try {
1102
+ process.kill(childPid, 0);
1103
+ // Process still exists, SIGINT failed, try SIGTERM
1104
+ logMCPDebug(name, 'SIGINT failed, sending SIGTERM to MCP server process');
1105
+ try {
1106
+ process.kill(childPid, 'SIGTERM');
1107
+ }
1108
+ catch (termError) {
1109
+ logMCPDebug(name, `Error sending SIGTERM: ${termError}`);
1110
+ resolved = true;
1111
+ clearInterval(checkInterval);
1112
+ clearTimeout(failsafeTimeout);
1113
+ resolve();
1114
+ return;
1115
+ }
1116
+ }
1117
+ catch {
1118
+ // Process already exited
1119
+ resolved = true;
1120
+ clearInterval(checkInterval);
1121
+ clearTimeout(failsafeTimeout);
1122
+ resolve();
1123
+ return;
1124
+ }
1125
+ // Wait 400ms for SIGTERM to work (slower than SIGINT, often used for cleanup)
1126
+ await sleep(400);
1127
+ if (!resolved) {
1128
+ // Check if process still exists
1129
+ try {
1130
+ process.kill(childPid, 0);
1131
+ // Process still exists, SIGTERM failed, force kill with SIGKILL
1132
+ logMCPDebug(name, 'SIGTERM failed, sending SIGKILL to MCP server process');
1133
+ try {
1134
+ process.kill(childPid, 'SIGKILL');
1135
+ }
1136
+ catch (killError) {
1137
+ logMCPDebug(name, `Error sending SIGKILL: ${killError}`);
1138
+ }
1139
+ }
1140
+ catch {
1141
+ // Process already exited
1142
+ resolved = true;
1143
+ clearInterval(checkInterval);
1144
+ clearTimeout(failsafeTimeout);
1145
+ resolve();
1146
+ }
1147
+ }
1148
+ }
1149
+ // Final timeout - always resolve after 500ms max (total cleanup time)
1150
+ if (!resolved) {
1151
+ resolved = true;
1152
+ clearInterval(checkInterval);
1153
+ clearTimeout(failsafeTimeout);
1154
+ resolve();
1155
+ }
1156
+ }
1157
+ catch {
1158
+ // Handle any errors in the escalation sequence
1159
+ if (!resolved) {
1160
+ resolved = true;
1161
+ clearInterval(checkInterval);
1162
+ clearTimeout(failsafeTimeout);
1163
+ resolve();
1164
+ }
1165
+ }
1166
+ });
1167
+ }
1168
+ }
1169
+ catch (processError) {
1170
+ logMCPDebug(name, `Error terminating process: ${processError}`);
1171
+ }
1172
+ }
1173
+ // Close the client connection (which also closes the transport)
1174
+ try {
1175
+ await client.close();
1176
+ }
1177
+ catch (error) {
1178
+ logMCPDebug(name, `Error closing client: ${error}`);
1179
+ }
1180
+ };
1181
+ // Register cleanup for all transport types - even network transports might need cleanup
1182
+ // This ensures all MCP servers get properly terminated, not just stdio ones
1183
+ const cleanupUnregister = registerCleanup(cleanup);
1184
+ // Create the wrapped cleanup that includes unregistering
1185
+ const wrappedCleanup = async () => {
1186
+ cleanupUnregister?.();
1187
+ await cleanup();
1188
+ };
1189
+ const connectionDurationMs = Date.now() - connectStartTime;
1190
+ logEvent('tengu_mcp_server_connection_succeeded', {
1191
+ connectionDurationMs,
1192
+ transportType: (serverRef.type ??
1193
+ 'stdio'),
1194
+ totalServers: serverStats?.totalServers,
1195
+ stdioCount: serverStats?.stdioCount,
1196
+ sseCount: serverStats?.sseCount,
1197
+ httpCount: serverStats?.httpCount,
1198
+ sseIdeCount: serverStats?.sseIdeCount,
1199
+ wsIdeCount: serverStats?.wsIdeCount,
1200
+ ...mcpBaseUrlAnalytics(serverRef),
1201
+ });
1202
+ return {
1203
+ name,
1204
+ client,
1205
+ type: 'connected',
1206
+ capabilities: capabilities ?? {},
1207
+ serverInfo: serverVersion,
1208
+ instructions,
1209
+ config: serverRef,
1210
+ cleanup: wrappedCleanup,
1211
+ };
1212
+ }
1213
+ catch (error) {
1214
+ const connectionDurationMs = Date.now() - connectStartTime;
1215
+ logEvent('tengu_mcp_server_connection_failed', {
1216
+ connectionDurationMs,
1217
+ totalServers: serverStats?.totalServers || 1,
1218
+ stdioCount: serverStats?.stdioCount || (serverRef.type === 'stdio' ? 1 : 0),
1219
+ sseCount: serverStats?.sseCount || (serverRef.type === 'sse' ? 1 : 0),
1220
+ httpCount: serverStats?.httpCount || (serverRef.type === 'http' ? 1 : 0),
1221
+ sseIdeCount: serverStats?.sseIdeCount || (serverRef.type === 'sse-ide' ? 1 : 0),
1222
+ wsIdeCount: serverStats?.wsIdeCount || (serverRef.type === 'ws-ide' ? 1 : 0),
1223
+ transportType: (serverRef.type ??
1224
+ 'stdio'),
1225
+ ...mcpBaseUrlAnalytics(serverRef),
1226
+ });
1227
+ logMCPDebug(name, `Connection failed after ${connectionDurationMs}ms: ${errorMessage(error)}`);
1228
+ logMCPError(name, `Connection failed: ${errorMessage(error)}`);
1229
+ if (inProcessServer) {
1230
+ inProcessServer.close().catch(() => { });
1231
+ }
1232
+ return {
1233
+ name,
1234
+ type: 'failed',
1235
+ config: serverRef,
1236
+ error: errorMessage(error),
1237
+ };
1238
+ }
1239
+ }, getServerCacheKey);
1240
+ /**
1241
+ * Clears the memoize cache for a specific server
1242
+ * @param name Server name
1243
+ * @param serverRef Server configuration
1244
+ */
1245
+ export async function clearServerCache(name, serverRef) {
1246
+ const key = getServerCacheKey(name, serverRef);
1247
+ try {
1248
+ const wrappedClient = await connectToServer(name, serverRef);
1249
+ if (wrappedClient.type === 'connected') {
1250
+ await wrappedClient.cleanup();
1251
+ }
1252
+ }
1253
+ catch {
1254
+ // Ignore errors - server might have failed to connect
1255
+ }
1256
+ // Clear from cache (both connection and fetch caches so reconnect
1257
+ // fetches fresh tools/resources/commands instead of stale ones)
1258
+ connectToServer.cache.delete(key);
1259
+ fetchToolsForClient.cache.delete(name);
1260
+ fetchResourcesForClient.cache.delete(name);
1261
+ fetchCommandsForClient.cache.delete(name);
1262
+ if (feature('MCP_SKILLS')) {
1263
+ fetchMcpSkillsForClient.cache.delete(name);
1264
+ }
1265
+ }
1266
+ /**
1267
+ * Ensures a valid connected client for an MCP server.
1268
+ * For most server types, uses the memoization cache if available, or reconnects
1269
+ * if the cache was cleared (e.g., after onclose). This ensures tool/resource
1270
+ * calls always use a valid connection.
1271
+ *
1272
+ * SDK MCP servers run in-process and are handled separately via setupSdkMcpClients,
1273
+ * so they are returned as-is without going through connectToServer.
1274
+ *
1275
+ * @param client The connected MCP server client
1276
+ * @returns Connected MCP server client (same or reconnected)
1277
+ * @throws Error if server cannot be connected
1278
+ */
1279
+ export async function ensureConnectedClient(client) {
1280
+ // SDK MCP servers run in-process and are handled separately via setupSdkMcpClients
1281
+ if (client.config.type === 'sdk') {
1282
+ return client;
1283
+ }
1284
+ const connectedClient = await connectToServer(client.name, client.config);
1285
+ if (connectedClient.type !== 'connected') {
1286
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(`MCP server "${client.name}" is not connected`, 'MCP server not connected');
1287
+ }
1288
+ return connectedClient;
1289
+ }
1290
+ /**
1291
+ * Compares two MCP server configurations to determine if they are equivalent.
1292
+ * Used to detect when a server needs to be reconnected due to config changes.
1293
+ */
1294
+ export function areMcpConfigsEqual(a, b) {
1295
+ // Quick type check first
1296
+ if (a.type !== b.type)
1297
+ return false;
1298
+ // Compare by serializing - this handles all config variations
1299
+ // We exclude 'scope' from comparison since it's metadata, not connection config
1300
+ const { scope: _scopeA, ...configA } = a;
1301
+ const { scope: _scopeB, ...configB } = b;
1302
+ return jsonStringify(configA) === jsonStringify(configB);
1303
+ }
1304
+ // Max cache size for fetch* caches. Keyed by server name (stable across
1305
+ // reconnects), bounded to prevent unbounded growth with many MCP servers.
1306
+ const MCP_FETCH_CACHE_SIZE = 20;
1307
+ /**
1308
+ * Encode MCP tool input for the auto-mode security classifier.
1309
+ * Exported so the auto-mode eval scripts can mirror production encoding
1310
+ * for `mcp__*` tool stubs without duplicating this logic.
1311
+ */
1312
+ export function mcpToolInputToAutoClassifierInput(input, toolName) {
1313
+ const keys = Object.keys(input);
1314
+ return keys.length > 0
1315
+ ? keys.map(k => `${k}=${String(input[k])}`).join(' ')
1316
+ : toolName;
1317
+ }
1318
+ export const fetchToolsForClient = memoizeWithLRU(async (client) => {
1319
+ if (client.type !== 'connected')
1320
+ return [];
1321
+ try {
1322
+ if (!client.capabilities?.tools) {
1323
+ return [];
1324
+ }
1325
+ const result = (await client.client.request({ method: 'tools/list' }, ListToolsResultSchema));
1326
+ // Sanitize tool data from MCP server
1327
+ const toolsToProcess = recursivelySanitizeUnicode(result.tools);
1328
+ // Check if we should skip the mcp__ prefix for SDK MCP servers
1329
+ const skipPrefix = client.config.type === 'sdk' &&
1330
+ isEnvTruthy(process.env.CLAUDE_AGENT_SDK_MCP_NO_PREFIX);
1331
+ // Convert MCP tools to our Tool format
1332
+ return toolsToProcess
1333
+ .map((tool) => {
1334
+ const fullyQualifiedName = buildMcpToolName(client.name, tool.name);
1335
+ return {
1336
+ ...MCPTool,
1337
+ // In skip-prefix mode, use the original name for model invocation so MCP tools
1338
+ // can override builtins by name. mcpInfo is used for permission checking.
1339
+ name: skipPrefix ? tool.name : fullyQualifiedName,
1340
+ mcpInfo: { serverName: client.name, toolName: tool.name },
1341
+ isMcp: true,
1342
+ // Collapse whitespace: _meta is open to external MCP servers, and
1343
+ // a newline here would inject orphan lines into the deferred-tool
1344
+ // list (formatDeferredToolLine joins on '\n').
1345
+ searchHint: typeof tool._meta?.['anthropic/searchHint'] === 'string'
1346
+ ? tool._meta['anthropic/searchHint']
1347
+ .replace(/\s+/g, ' ')
1348
+ .trim() || undefined
1349
+ : undefined,
1350
+ alwaysLoad: tool._meta?.['anthropic/alwaysLoad'] === true,
1351
+ async description() {
1352
+ return tool.description ?? '';
1353
+ },
1354
+ async prompt() {
1355
+ const desc = tool.description ?? '';
1356
+ return desc.length > MAX_MCP_DESCRIPTION_LENGTH
1357
+ ? desc.slice(0, MAX_MCP_DESCRIPTION_LENGTH) + '… [truncated]'
1358
+ : desc;
1359
+ },
1360
+ isConcurrencySafe() {
1361
+ return tool.annotations?.readOnlyHint ?? false;
1362
+ },
1363
+ isReadOnly() {
1364
+ return tool.annotations?.readOnlyHint ?? false;
1365
+ },
1366
+ toAutoClassifierInput(input) {
1367
+ return mcpToolInputToAutoClassifierInput(input, tool.name);
1368
+ },
1369
+ isDestructive() {
1370
+ return tool.annotations?.destructiveHint ?? false;
1371
+ },
1372
+ isOpenWorld() {
1373
+ return tool.annotations?.openWorldHint ?? false;
1374
+ },
1375
+ isSearchOrReadCommand() {
1376
+ return classifyMcpToolForCollapse(client.name, tool.name);
1377
+ },
1378
+ inputJSONSchema: tool.inputSchema,
1379
+ async checkPermissions() {
1380
+ return {
1381
+ behavior: 'passthrough',
1382
+ message: 'MCPTool requires permission.',
1383
+ suggestions: [
1384
+ {
1385
+ type: 'addRules',
1386
+ rules: [
1387
+ {
1388
+ toolName: fullyQualifiedName,
1389
+ ruleContent: undefined,
1390
+ },
1391
+ ],
1392
+ behavior: 'allow',
1393
+ destination: 'localSettings',
1394
+ },
1395
+ ],
1396
+ };
1397
+ },
1398
+ async call(args, context, _canUseTool, parentMessage, onProgress) {
1399
+ const toolUseId = extractToolUseId(parentMessage);
1400
+ const meta = toolUseId
1401
+ ? { 'claudecode/toolUseId': toolUseId }
1402
+ : {};
1403
+ // Emit progress when tool starts
1404
+ if (onProgress && toolUseId) {
1405
+ onProgress({
1406
+ toolUseID: toolUseId,
1407
+ data: {
1408
+ type: 'mcp_progress',
1409
+ status: 'started',
1410
+ serverName: client.name,
1411
+ toolName: tool.name,
1412
+ },
1413
+ });
1414
+ }
1415
+ const startTime = Date.now();
1416
+ const MAX_SESSION_RETRIES = 1;
1417
+ for (let attempt = 0;; attempt++) {
1418
+ try {
1419
+ const connectedClient = await ensureConnectedClient(client);
1420
+ const mcpResult = await callMCPToolWithUrlElicitationRetry({
1421
+ client: connectedClient,
1422
+ clientConnection: client,
1423
+ tool: tool.name,
1424
+ args,
1425
+ meta,
1426
+ signal: context.abortController.signal,
1427
+ setAppState: context.setAppState,
1428
+ onProgress: onProgress && toolUseId
1429
+ ? progressData => {
1430
+ onProgress({
1431
+ toolUseID: toolUseId,
1432
+ data: progressData,
1433
+ });
1434
+ }
1435
+ : undefined,
1436
+ handleElicitation: context.handleElicitation,
1437
+ });
1438
+ // Emit progress when tool completes successfully
1439
+ if (onProgress && toolUseId) {
1440
+ onProgress({
1441
+ toolUseID: toolUseId,
1442
+ data: {
1443
+ type: 'mcp_progress',
1444
+ status: 'completed',
1445
+ serverName: client.name,
1446
+ toolName: tool.name,
1447
+ elapsedTimeMs: Date.now() - startTime,
1448
+ },
1449
+ });
1450
+ }
1451
+ return {
1452
+ data: mcpResult.content,
1453
+ ...((mcpResult._meta || mcpResult.structuredContent) && {
1454
+ mcpMeta: {
1455
+ ...(mcpResult._meta && {
1456
+ _meta: mcpResult._meta,
1457
+ }),
1458
+ ...(mcpResult.structuredContent && {
1459
+ structuredContent: mcpResult.structuredContent,
1460
+ }),
1461
+ },
1462
+ }),
1463
+ };
1464
+ }
1465
+ catch (error) {
1466
+ // Session expired — the connection cache has been
1467
+ // cleared, so retry with a fresh client.
1468
+ if (error instanceof McpSessionExpiredError &&
1469
+ attempt < MAX_SESSION_RETRIES) {
1470
+ logMCPDebug(client.name, `Retrying tool '${tool.name}' after session recovery`);
1471
+ continue;
1472
+ }
1473
+ // Emit progress when tool fails
1474
+ if (onProgress && toolUseId) {
1475
+ onProgress({
1476
+ toolUseID: toolUseId,
1477
+ data: {
1478
+ type: 'mcp_progress',
1479
+ status: 'failed',
1480
+ serverName: client.name,
1481
+ toolName: tool.name,
1482
+ elapsedTimeMs: Date.now() - startTime,
1483
+ },
1484
+ });
1485
+ }
1486
+ // Wrap MCP SDK errors so telemetry gets useful context
1487
+ // instead of just "Error" or "McpError" (the constructor
1488
+ // name). MCP SDK errors are protocol-level messages and
1489
+ // don't contain user file paths or code.
1490
+ if (error instanceof Error &&
1491
+ !(error instanceof
1492
+ TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)) {
1493
+ const name = error.constructor.name;
1494
+ if (name === 'Error') {
1495
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(error.message, error.message.slice(0, 200));
1496
+ }
1497
+ // McpError has a numeric `code` with the JSON-RPC error
1498
+ // code (e.g. -32000 ConnectionClosed, -32001 RequestTimeout)
1499
+ if (name === 'McpError' &&
1500
+ 'code' in error &&
1501
+ typeof error.code === 'number') {
1502
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(error.message, `McpError ${error.code}`);
1503
+ }
1504
+ }
1505
+ throw error;
1506
+ }
1507
+ }
1508
+ },
1509
+ userFacingName() {
1510
+ // Prefer title annotation if available, otherwise use tool name
1511
+ const displayName = tool.annotations?.title || tool.name;
1512
+ return `${client.name} - ${displayName} (MCP)`;
1513
+ },
1514
+ ...(isClaudeInChromeMCPServer(client.name) &&
1515
+ (client.config.type === 'stdio' || !client.config.type)
1516
+ ? claudeInChromeToolRendering().getClaudeInChromeMCPToolOverrides(tool.name)
1517
+ : {}),
1518
+ ...(feature('CHICAGO_MCP') &&
1519
+ (client.config.type === 'stdio' || !client.config.type) &&
1520
+ isComputerUseMCPServer(client.name)
1521
+ ? computerUseWrapper().getComputerUseMCPToolOverrides(tool.name)
1522
+ : {}),
1523
+ };
1524
+ })
1525
+ .filter(isIncludedMcpTool);
1526
+ }
1527
+ catch (error) {
1528
+ logMCPError(client.name, `Failed to fetch tools: ${errorMessage(error)}`);
1529
+ return [];
1530
+ }
1531
+ }, (client) => client.name, MCP_FETCH_CACHE_SIZE);
1532
+ export const fetchResourcesForClient = memoizeWithLRU(async (client) => {
1533
+ if (client.type !== 'connected')
1534
+ return [];
1535
+ try {
1536
+ if (!client.capabilities?.resources) {
1537
+ return [];
1538
+ }
1539
+ const result = await client.client.request({ method: 'resources/list' }, ListResourcesResultSchema);
1540
+ if (!result.resources)
1541
+ return [];
1542
+ // Add server name to each resource
1543
+ return result.resources.map(resource => ({
1544
+ ...resource,
1545
+ server: client.name,
1546
+ }));
1547
+ }
1548
+ catch (error) {
1549
+ logMCPError(client.name, `Failed to fetch resources: ${errorMessage(error)}`);
1550
+ return [];
1551
+ }
1552
+ }, (client) => client.name, MCP_FETCH_CACHE_SIZE);
1553
+ export const fetchCommandsForClient = memoizeWithLRU(async (client) => {
1554
+ if (client.type !== 'connected')
1555
+ return [];
1556
+ try {
1557
+ if (!client.capabilities?.prompts) {
1558
+ return [];
1559
+ }
1560
+ // Request prompts list from client
1561
+ const result = (await client.client.request({ method: 'prompts/list' }, ListPromptsResultSchema));
1562
+ if (!result.prompts)
1563
+ return [];
1564
+ // Sanitize prompt data from MCP server
1565
+ const promptsToProcess = recursivelySanitizeUnicode(result.prompts);
1566
+ // Convert MCP prompts to our Command format
1567
+ return promptsToProcess.map(prompt => {
1568
+ const argNames = Object.values(prompt.arguments ?? {}).map(k => k.name);
1569
+ return {
1570
+ type: 'prompt',
1571
+ name: 'mcp__' + normalizeNameForMCP(client.name) + '__' + prompt.name,
1572
+ description: prompt.description ?? '',
1573
+ hasUserSpecifiedDescription: !!prompt.description,
1574
+ contentLength: 0, // Dynamic MCP content
1575
+ isEnabled: () => true,
1576
+ isHidden: false,
1577
+ isMcp: true,
1578
+ progressMessage: 'running',
1579
+ userFacingName() {
1580
+ // Use prompt.name (programmatic identifier) not prompt.title (display name)
1581
+ // to avoid spaces breaking slash command parsing
1582
+ return `${client.name}:${prompt.name} (MCP)`;
1583
+ },
1584
+ argNames,
1585
+ source: 'mcp',
1586
+ async getPromptForCommand(args) {
1587
+ const argsArray = args.split(' ');
1588
+ try {
1589
+ const connectedClient = await ensureConnectedClient(client);
1590
+ const result = await connectedClient.client.getPrompt({
1591
+ name: prompt.name,
1592
+ arguments: zipObject(argNames, argsArray),
1593
+ });
1594
+ const transformed = await Promise.all(result.messages.map(message => transformResultContent(message.content, connectedClient.name)));
1595
+ return transformed.flat();
1596
+ }
1597
+ catch (error) {
1598
+ logMCPError(client.name, `Error running command '${prompt.name}': ${errorMessage(error)}`);
1599
+ throw error;
1600
+ }
1601
+ },
1602
+ };
1603
+ });
1604
+ }
1605
+ catch (error) {
1606
+ logMCPError(client.name, `Failed to fetch commands: ${errorMessage(error)}`);
1607
+ return [];
1608
+ }
1609
+ }, (client) => client.name, MCP_FETCH_CACHE_SIZE);
1610
+ /**
1611
+ * Call an IDE tool directly as an RPC
1612
+ * @param toolName The name of the tool to call
1613
+ * @param args The arguments to pass to the tool
1614
+ * @param client The IDE client to use for the RPC call
1615
+ * @returns The result of the tool call
1616
+ */
1617
+ export async function callIdeRpc(toolName, args, client) {
1618
+ const result = await callMCPTool({
1619
+ client,
1620
+ tool: toolName,
1621
+ args,
1622
+ signal: createAbortController().signal,
1623
+ });
1624
+ return result.content;
1625
+ }
1626
+ /**
1627
+ * Note: This should not be called by UI components directly, they should use the reconnectMcpServer
1628
+ * function from useManageMcpConnections.
1629
+ * @param name Server name
1630
+ * @param config Server configuration
1631
+ * @returns Object containing the client connection and its resources
1632
+ */
1633
+ export async function reconnectMcpServerImpl(name, config) {
1634
+ try {
1635
+ // Invalidate the keychain cache so we read fresh credentials from disk.
1636
+ // This is necessary when another process (e.g. the VS Code extension host)
1637
+ // has modified stored tokens (cleared auth, saved new OAuth tokens) and then
1638
+ // asks the CLI subprocess to reconnect. Without this, the subprocess would
1639
+ // use stale cached data and never notice the tokens were removed.
1640
+ clearKeychainCache();
1641
+ await clearServerCache(name, config);
1642
+ const client = await connectToServer(name, config);
1643
+ if (client.type !== 'connected') {
1644
+ return {
1645
+ client,
1646
+ tools: [],
1647
+ commands: [],
1648
+ };
1649
+ }
1650
+ if (config.type === 'claudeai-proxy') {
1651
+ markClaudeAiMcpConnected(name);
1652
+ }
1653
+ const supportsResources = !!client.capabilities?.resources;
1654
+ const [tools, mcpCommands, mcpSkills, resources] = await Promise.all([
1655
+ fetchToolsForClient(client),
1656
+ fetchCommandsForClient(client),
1657
+ feature('MCP_SKILLS') && supportsResources
1658
+ ? fetchMcpSkillsForClient(client)
1659
+ : Promise.resolve([]),
1660
+ supportsResources ? fetchResourcesForClient(client) : Promise.resolve([]),
1661
+ ]);
1662
+ const commands = [...mcpCommands, ...mcpSkills];
1663
+ // Check if we need to add resource tools
1664
+ const resourceTools = [];
1665
+ if (supportsResources) {
1666
+ // Only add resource tools if no other server has them
1667
+ const hasResourceTools = [ListMcpResourcesTool, ReadMcpResourceTool].some(tool => tools.some(t => toolMatchesName(t, tool.name)));
1668
+ if (!hasResourceTools) {
1669
+ resourceTools.push(ListMcpResourcesTool, ReadMcpResourceTool);
1670
+ }
1671
+ }
1672
+ return {
1673
+ client,
1674
+ tools: [...tools, ...resourceTools],
1675
+ commands,
1676
+ resources: resources.length > 0 ? resources : undefined,
1677
+ };
1678
+ }
1679
+ catch (error) {
1680
+ // Handle errors gracefully - connection might have closed during fetch
1681
+ logMCPError(name, `Error during reconnection: ${errorMessage(error)}`);
1682
+ // Return with failed status
1683
+ return {
1684
+ client: { name, type: 'failed', config },
1685
+ tools: [],
1686
+ commands: [],
1687
+ };
1688
+ }
1689
+ }
1690
+ // Replaced 2026-03: previous implementation ran fixed-size sequential batches
1691
+ // (await batch 1 fully, then start batch 2). That meant one slow server in
1692
+ // batch N held up ALL servers in batch N+1, even if the other 19 slots were
1693
+ // idle. pMap frees each slot as soon as its server completes, so a single
1694
+ // slow server only occupies one slot instead of blocking an entire batch
1695
+ // boundary. Same concurrency ceiling, same results, better scheduling.
1696
+ async function processBatched(items, concurrency, processor) {
1697
+ await pMap(items, processor, { concurrency });
1698
+ }
1699
+ export async function getMcpToolsCommandsAndResources(onConnectionAttempt, mcpConfigs) {
1700
+ let resourceToolsAdded = false;
1701
+ const allConfigEntries = Object.entries(mcpConfigs ?? (await getAllMcpConfigs()).servers);
1702
+ // Partition into disabled and active entries — disabled servers should
1703
+ // never generate HTTP connections or flow through batch processing
1704
+ const configEntries = [];
1705
+ for (const entry of allConfigEntries) {
1706
+ if (isMcpServerDisabled(entry[0])) {
1707
+ onConnectionAttempt({
1708
+ client: { name: entry[0], type: 'disabled', config: entry[1] },
1709
+ tools: [],
1710
+ commands: [],
1711
+ });
1712
+ }
1713
+ else {
1714
+ configEntries.push(entry);
1715
+ }
1716
+ }
1717
+ // Calculate transport counts for logging
1718
+ const totalServers = configEntries.length;
1719
+ const stdioCount = count(configEntries, ([_, c]) => c.type === 'stdio');
1720
+ const sseCount = count(configEntries, ([_, c]) => c.type === 'sse');
1721
+ const httpCount = count(configEntries, ([_, c]) => c.type === 'http');
1722
+ const sseIdeCount = count(configEntries, ([_, c]) => c.type === 'sse-ide');
1723
+ const wsIdeCount = count(configEntries, ([_, c]) => c.type === 'ws-ide');
1724
+ // Split servers by type: local (stdio/sdk) need lower concurrency due to
1725
+ // process spawning, remote servers can connect with higher concurrency
1726
+ const localServers = configEntries.filter(([_, config]) => isLocalMcpServer(config));
1727
+ const remoteServers = configEntries.filter(([_, config]) => !isLocalMcpServer(config));
1728
+ const serverStats = {
1729
+ totalServers,
1730
+ stdioCount,
1731
+ sseCount,
1732
+ httpCount,
1733
+ sseIdeCount,
1734
+ wsIdeCount,
1735
+ };
1736
+ const processServer = async ([name, config]) => {
1737
+ try {
1738
+ // Check if server is disabled - if so, just add it to state without connecting
1739
+ if (isMcpServerDisabled(name)) {
1740
+ onConnectionAttempt({
1741
+ client: {
1742
+ name,
1743
+ type: 'disabled',
1744
+ config,
1745
+ },
1746
+ tools: [],
1747
+ commands: [],
1748
+ });
1749
+ return;
1750
+ }
1751
+ // Skip connection for servers that recently returned 401 (15min TTL),
1752
+ // or that we have probed before but hold no token for. The second
1753
+ // check closes the gap the TTL leaves open: without it, every 15min
1754
+ // we re-probe servers that cannot succeed until the user runs /mcp.
1755
+ // Each probe is a network round-trip for connect-401 plus OAuth
1756
+ // discovery, and print mode awaits the whole batch (main.tsx:3503).
1757
+ if ((config.type === 'claudeai-proxy' ||
1758
+ config.type === 'http' ||
1759
+ config.type === 'sse') &&
1760
+ ((await isMcpAuthCached(name)) ||
1761
+ ((config.type === 'http' || config.type === 'sse') &&
1762
+ hasMcpDiscoveryButNoToken(name, config)))) {
1763
+ logMCPDebug(name, `Skipping connection (cached needs-auth)`);
1764
+ onConnectionAttempt({
1765
+ client: { name, type: 'needs-auth', config },
1766
+ tools: [createMcpAuthTool(name, config)],
1767
+ commands: [],
1768
+ });
1769
+ return;
1770
+ }
1771
+ const client = await connectToServer(name, config, serverStats);
1772
+ if (client.type !== 'connected') {
1773
+ onConnectionAttempt({
1774
+ client,
1775
+ tools: client.type === 'needs-auth'
1776
+ ? [createMcpAuthTool(name, config)]
1777
+ : [],
1778
+ commands: [],
1779
+ });
1780
+ return;
1781
+ }
1782
+ if (config.type === 'claudeai-proxy') {
1783
+ markClaudeAiMcpConnected(name);
1784
+ }
1785
+ const supportsResources = !!client.capabilities?.resources;
1786
+ const [tools, mcpCommands, mcpSkills, resources] = await Promise.all([
1787
+ fetchToolsForClient(client),
1788
+ fetchCommandsForClient(client),
1789
+ // Discover skills from skill:// resources
1790
+ feature('MCP_SKILLS') && supportsResources
1791
+ ? fetchMcpSkillsForClient(client)
1792
+ : Promise.resolve([]),
1793
+ // Fetch resources if supported
1794
+ supportsResources
1795
+ ? fetchResourcesForClient(client)
1796
+ : Promise.resolve([]),
1797
+ ]);
1798
+ const commands = [...mcpCommands, ...mcpSkills];
1799
+ // If this server resources and we haven't added resource tools yet,
1800
+ // include our resource tools with this client's tools
1801
+ const resourceTools = [];
1802
+ if (supportsResources && !resourceToolsAdded) {
1803
+ resourceToolsAdded = true;
1804
+ resourceTools.push(ListMcpResourcesTool, ReadMcpResourceTool);
1805
+ }
1806
+ onConnectionAttempt({
1807
+ client,
1808
+ tools: [...tools, ...resourceTools],
1809
+ commands,
1810
+ resources: resources.length > 0 ? resources : undefined,
1811
+ });
1812
+ }
1813
+ catch (error) {
1814
+ // Handle errors gracefully - connection might have closed during fetch
1815
+ logMCPError(name, `Error fetching tools/commands/resources: ${errorMessage(error)}`);
1816
+ // Still update with the client but no tools/commands
1817
+ onConnectionAttempt({
1818
+ client: { name, type: 'failed', config },
1819
+ tools: [],
1820
+ commands: [],
1821
+ });
1822
+ }
1823
+ };
1824
+ // Process both groups concurrently, each with their own concurrency limits:
1825
+ // - Local servers (stdio/sdk): lower concurrency to avoid process spawning resource contention
1826
+ // - Remote servers: higher concurrency since they're just network connections
1827
+ await Promise.all([
1828
+ processBatched(localServers, getMcpServerConnectionBatchSize(), processServer),
1829
+ processBatched(remoteServers, getRemoteMcpServerConnectionBatchSize(), processServer),
1830
+ ]);
1831
+ }
1832
+ // Not memoized: called only 2-3 times at startup/reconfig. The inner work
1833
+ // (connectToServer, fetch*ForClient) is already cached. Memoizing here by
1834
+ // mcpConfigs object ref leaked — main.tsx creates fresh config objects each call.
1835
+ export function prefetchAllMcpResources(mcpConfigs) {
1836
+ return new Promise(resolve => {
1837
+ let pendingCount = 0;
1838
+ let completedCount = 0;
1839
+ pendingCount = Object.keys(mcpConfigs).length;
1840
+ if (pendingCount === 0) {
1841
+ void resolve({
1842
+ clients: [],
1843
+ tools: [],
1844
+ commands: [],
1845
+ });
1846
+ return;
1847
+ }
1848
+ const clients = [];
1849
+ const tools = [];
1850
+ const commands = [];
1851
+ getMcpToolsCommandsAndResources(result => {
1852
+ clients.push(result.client);
1853
+ tools.push(...result.tools);
1854
+ commands.push(...result.commands);
1855
+ completedCount++;
1856
+ if (completedCount >= pendingCount) {
1857
+ const commandsMetadataLength = commands.reduce((sum, command) => {
1858
+ const commandMetadataLength = command.name.length +
1859
+ (command.description ?? '').length +
1860
+ (command.argumentHint ?? '').length;
1861
+ return sum + commandMetadataLength;
1862
+ }, 0);
1863
+ logEvent('tengu_mcp_tools_commands_loaded', {
1864
+ tools_count: tools.length,
1865
+ commands_count: commands.length,
1866
+ commands_metadata_length: commandsMetadataLength,
1867
+ });
1868
+ void resolve({
1869
+ clients,
1870
+ tools,
1871
+ commands,
1872
+ });
1873
+ }
1874
+ }, mcpConfigs).catch(error => {
1875
+ logMCPError('prefetchAllMcpResources', `Failed to get MCP resources: ${errorMessage(error)}`);
1876
+ // Still resolve with empty results
1877
+ void resolve({
1878
+ clients: [],
1879
+ tools: [],
1880
+ commands: [],
1881
+ });
1882
+ });
1883
+ });
1884
+ }
1885
+ /**
1886
+ * Transform result content from an MCP tool or MCP prompt into message blocks
1887
+ */
1888
+ export async function transformResultContent(resultContent, serverName) {
1889
+ switch (resultContent.type) {
1890
+ case 'text':
1891
+ return [
1892
+ {
1893
+ type: 'text',
1894
+ text: resultContent.text,
1895
+ },
1896
+ ];
1897
+ case 'audio': {
1898
+ const audioData = resultContent;
1899
+ return await persistBlobToTextBlock(Buffer.from(audioData.data, 'base64'), audioData.mimeType, serverName, `[Audio from ${serverName}] `);
1900
+ }
1901
+ case 'image': {
1902
+ // Resize and compress image data, enforcing API dimension limits
1903
+ const imageBuffer = Buffer.from(String(resultContent.data), 'base64');
1904
+ const ext = resultContent.mimeType?.split('/')[1] || 'png';
1905
+ const resized = await maybeResizeAndDownsampleImageBuffer(imageBuffer, imageBuffer.length, ext);
1906
+ return [
1907
+ {
1908
+ type: 'image',
1909
+ source: {
1910
+ data: resized.buffer.toString('base64'),
1911
+ media_type: `image/${resized.mediaType}`,
1912
+ type: 'base64',
1913
+ },
1914
+ },
1915
+ ];
1916
+ }
1917
+ case 'resource': {
1918
+ const resource = resultContent.resource;
1919
+ const prefix = `[Resource from ${serverName} at ${resource.uri}] `;
1920
+ if ('text' in resource) {
1921
+ return [
1922
+ {
1923
+ type: 'text',
1924
+ text: `${prefix}${resource.text}`,
1925
+ },
1926
+ ];
1927
+ }
1928
+ else if ('blob' in resource) {
1929
+ const isImage = IMAGE_MIME_TYPES.has(resource.mimeType ?? '');
1930
+ if (isImage) {
1931
+ // Resize and compress image blob, enforcing API dimension limits
1932
+ const imageBuffer = Buffer.from(resource.blob, 'base64');
1933
+ const ext = resource.mimeType?.split('/')[1] || 'png';
1934
+ const resized = await maybeResizeAndDownsampleImageBuffer(imageBuffer, imageBuffer.length, ext);
1935
+ const content = [];
1936
+ if (prefix) {
1937
+ content.push({
1938
+ type: 'text',
1939
+ text: prefix,
1940
+ });
1941
+ }
1942
+ content.push({
1943
+ type: 'image',
1944
+ source: {
1945
+ data: resized.buffer.toString('base64'),
1946
+ media_type: `image/${resized.mediaType}`,
1947
+ type: 'base64',
1948
+ },
1949
+ });
1950
+ return content;
1951
+ }
1952
+ else {
1953
+ return await persistBlobToTextBlock(Buffer.from(resource.blob, 'base64'), resource.mimeType, serverName, prefix);
1954
+ }
1955
+ }
1956
+ return [];
1957
+ }
1958
+ case 'resource_link': {
1959
+ const resourceLink = resultContent;
1960
+ let text = `[Resource link: ${resourceLink.name}] ${resourceLink.uri}`;
1961
+ if (resourceLink.description) {
1962
+ text += ` (${resourceLink.description})`;
1963
+ }
1964
+ return [
1965
+ {
1966
+ type: 'text',
1967
+ text,
1968
+ },
1969
+ ];
1970
+ }
1971
+ default:
1972
+ return [];
1973
+ }
1974
+ }
1975
+ /**
1976
+ * Decode base64 binary content, write it to disk with the proper extension,
1977
+ * and return a small text block with the file path. Replaces the old behavior
1978
+ * of dumping raw base64 into the context.
1979
+ */
1980
+ async function persistBlobToTextBlock(bytes, mimeType, serverName, sourceDescription) {
1981
+ const persistId = `mcp-${normalizeNameForMCP(serverName)}-blob-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`;
1982
+ const result = await persistBinaryContent(bytes, mimeType, persistId);
1983
+ if ('error' in result) {
1984
+ return [
1985
+ {
1986
+ type: 'text',
1987
+ text: `${sourceDescription}Binary content (${mimeType || 'unknown type'}, ${bytes.length} bytes) could not be saved to disk: ${result.error}`,
1988
+ },
1989
+ ];
1990
+ }
1991
+ return [
1992
+ {
1993
+ type: 'text',
1994
+ text: getBinaryBlobSavedMessage(result.filepath, mimeType, result.size, sourceDescription),
1995
+ },
1996
+ ];
1997
+ }
1998
+ /**
1999
+ * Generates a compact, jq-friendly type signature for a value.
2000
+ * e.g. "{title: string, items: [{id: number, name: string}]}"
2001
+ */
2002
+ export function inferCompactSchema(value, depth = 2) {
2003
+ if (value === null)
2004
+ return 'null';
2005
+ if (Array.isArray(value)) {
2006
+ if (value.length === 0)
2007
+ return '[]';
2008
+ return `[${inferCompactSchema(value[0], depth - 1)}]`;
2009
+ }
2010
+ if (typeof value === 'object') {
2011
+ if (depth <= 0)
2012
+ return '{...}';
2013
+ const entries = Object.entries(value).slice(0, 10);
2014
+ const props = entries.map(([k, v]) => `${k}: ${inferCompactSchema(v, depth - 1)}`);
2015
+ const suffix = Object.keys(value).length > 10 ? ', ...' : '';
2016
+ return `{${props.join(', ')}${suffix}}`;
2017
+ }
2018
+ return typeof value;
2019
+ }
2020
+ export async function transformMCPResult(result, tool, // Tool name for validation (e.g., "search")
2021
+ name) {
2022
+ if (result && typeof result === 'object') {
2023
+ if ('toolResult' in result) {
2024
+ return {
2025
+ content: String(result.toolResult),
2026
+ type: 'toolResult',
2027
+ };
2028
+ }
2029
+ if ('structuredContent' in result &&
2030
+ result.structuredContent !== undefined) {
2031
+ return {
2032
+ content: jsonStringify(result.structuredContent),
2033
+ type: 'structuredContent',
2034
+ schema: inferCompactSchema(result.structuredContent),
2035
+ };
2036
+ }
2037
+ if ('content' in result && Array.isArray(result.content)) {
2038
+ const transformedContent = (await Promise.all(result.content.map(item => transformResultContent(item, name)))).flat();
2039
+ return {
2040
+ content: transformedContent,
2041
+ type: 'contentArray',
2042
+ schema: inferCompactSchema(transformedContent),
2043
+ };
2044
+ }
2045
+ }
2046
+ const errorMessage = `MCP server "${name}" tool "${tool}": unexpected response format`;
2047
+ logMCPError(name, errorMessage);
2048
+ throw new TelemetrySafeError_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS(errorMessage, 'MCP tool unexpected response format');
2049
+ }
2050
+ /**
2051
+ * Check if MCP content contains any image blocks.
2052
+ * Used to decide whether to persist to file (images should use truncation instead
2053
+ * to preserve image compression and viewability).
2054
+ */
2055
+ function contentContainsImages(content) {
2056
+ if (!content || typeof content === 'string') {
2057
+ return false;
2058
+ }
2059
+ return content.some(block => block.type === 'image');
2060
+ }
2061
+ export async function processMCPResult(result, tool, // Tool name for validation (e.g., "search")
2062
+ name) {
2063
+ const { content, type, schema } = await transformMCPResult(result, tool, name);
2064
+ // IDE tools are not going to the model directly, so we don't need to
2065
+ // handle large output.
2066
+ if (name === 'ide') {
2067
+ return content;
2068
+ }
2069
+ // Check if content needs truncation (i.e., is too large)
2070
+ if (!(await mcpContentNeedsTruncation(content))) {
2071
+ return content;
2072
+ }
2073
+ const sizeEstimateTokens = getContentSizeEstimate(content);
2074
+ // If large output files feature is disabled, fall back to old truncation behavior
2075
+ if (isEnvDefinedFalsy(process.env.ENABLE_MCP_LARGE_OUTPUT_FILES)) {
2076
+ logEvent('tengu_mcp_large_result_handled', {
2077
+ outcome: 'truncated',
2078
+ reason: 'env_disabled',
2079
+ sizeEstimateTokens,
2080
+ });
2081
+ return await truncateMcpContentIfNeeded(content);
2082
+ }
2083
+ // Save large output to file and return instructions for reading it
2084
+ // Content is guaranteed to exist at this point (we checked mcpContentNeedsTruncation)
2085
+ if (!content) {
2086
+ return content;
2087
+ }
2088
+ // If content contains images, fall back to truncation - persisting images as JSON
2089
+ // defeats the image compression logic and makes them non-viewable
2090
+ if (contentContainsImages(content)) {
2091
+ logEvent('tengu_mcp_large_result_handled', {
2092
+ outcome: 'truncated',
2093
+ reason: 'contains_images',
2094
+ sizeEstimateTokens,
2095
+ });
2096
+ return await truncateMcpContentIfNeeded(content);
2097
+ }
2098
+ // Generate a unique ID for the persisted file (server__tool-timestamp)
2099
+ const timestamp = Date.now();
2100
+ const persistId = `mcp-${normalizeNameForMCP(name)}-${normalizeNameForMCP(tool)}-${timestamp}`;
2101
+ // Convert to string for persistence (persistToolResult expects string or specific block types)
2102
+ const contentStr = typeof content === 'string' ? content : jsonStringify(content, null, 2);
2103
+ const persistResult = await persistToolResult(contentStr, persistId);
2104
+ if (isPersistError(persistResult)) {
2105
+ // If file save failed, fall back to returning truncated content info
2106
+ const contentLength = contentStr.length;
2107
+ logEvent('tengu_mcp_large_result_handled', {
2108
+ outcome: 'truncated',
2109
+ reason: 'persist_failed',
2110
+ sizeEstimateTokens,
2111
+ });
2112
+ 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.`;
2113
+ }
2114
+ logEvent('tengu_mcp_large_result_handled', {
2115
+ outcome: 'persisted',
2116
+ reason: 'file_saved',
2117
+ sizeEstimateTokens,
2118
+ persistedSizeChars: persistResult.originalSize,
2119
+ });
2120
+ const formatDescription = getFormatDescription(type, schema);
2121
+ return getLargeOutputInstructions(persistResult.filepath, persistResult.originalSize, formatDescription);
2122
+ }
2123
+ /** @internal Exported for testing. */
2124
+ export async function callMCPToolWithUrlElicitationRetry({ client: connectedClient, clientConnection, tool, args, meta, signal, setAppState, onProgress, callToolFn = callMCPTool, handleElicitation, }) {
2125
+ const MAX_URL_ELICITATION_RETRIES = 3;
2126
+ for (let attempt = 0;; attempt++) {
2127
+ try {
2128
+ return await callToolFn({
2129
+ client: connectedClient,
2130
+ tool,
2131
+ args,
2132
+ meta,
2133
+ signal,
2134
+ onProgress,
2135
+ });
2136
+ }
2137
+ catch (error) {
2138
+ // The MCP SDK's Protocol creates plain McpError (not UrlElicitationRequiredError)
2139
+ // for error responses, so we check the error code instead of instanceof.
2140
+ if (!(error instanceof McpError) ||
2141
+ error.code !== ErrorCode.UrlElicitationRequired) {
2142
+ throw error;
2143
+ }
2144
+ // Limit the number of URL elicitation retries
2145
+ if (attempt >= MAX_URL_ELICITATION_RETRIES) {
2146
+ throw error;
2147
+ }
2148
+ const errorData = error.data;
2149
+ const rawElicitations = errorData != null &&
2150
+ typeof errorData === 'object' &&
2151
+ 'elicitations' in errorData &&
2152
+ Array.isArray(errorData.elicitations)
2153
+ ? errorData.elicitations
2154
+ : [];
2155
+ // Validate each element has the required fields for ElicitRequestURLParams
2156
+ const elicitations = rawElicitations.filter((e) => {
2157
+ if (e == null || typeof e !== 'object')
2158
+ return false;
2159
+ const obj = e;
2160
+ return (obj.mode === 'url' &&
2161
+ typeof obj.url === 'string' &&
2162
+ typeof obj.elicitationId === 'string' &&
2163
+ typeof obj.message === 'string');
2164
+ });
2165
+ const serverName = clientConnection.type === 'connected'
2166
+ ? clientConnection.name
2167
+ : 'unknown';
2168
+ if (elicitations.length === 0) {
2169
+ logMCPDebug(serverName, `Tool '${tool}' returned -32042 but no valid elicitations in error data`);
2170
+ throw error;
2171
+ }
2172
+ logMCPDebug(serverName, `Tool '${tool}' requires URL elicitation (error -32042, attempt ${attempt + 1}), processing ${elicitations.length} elicitation(s)`);
2173
+ // Process each URL elicitation from the error.
2174
+ // The completion notification handler (in registerElicitationHandler) sets
2175
+ // `completed: true` on the matching queue event; the dialog reacts to this flag.
2176
+ for (const elicitation of elicitations) {
2177
+ const { elicitationId } = elicitation;
2178
+ // Run elicitation hooks — they can resolve URL elicitations programmatically
2179
+ const hookResponse = await runElicitationHooks(serverName, elicitation, signal);
2180
+ if (hookResponse) {
2181
+ logMCPDebug(serverName, `URL elicitation ${elicitationId} resolved by hook: ${jsonStringify(hookResponse)}`);
2182
+ if (hookResponse.action !== 'accept') {
2183
+ return {
2184
+ 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.`,
2185
+ };
2186
+ }
2187
+ // Hook accepted — skip the UI and proceed to retry
2188
+ continue;
2189
+ }
2190
+ // Resolve the URL elicitation via callback (print/SDK mode) or queue (REPL mode).
2191
+ let userResult;
2192
+ if (handleElicitation) {
2193
+ // Print/SDK mode: delegate to structuredIO which sends a control request
2194
+ userResult = await handleElicitation(serverName, elicitation, signal);
2195
+ }
2196
+ else {
2197
+ // REPL mode: queue for ElicitationDialog with two-phase consent/waiting flow
2198
+ const waitingState = {
2199
+ actionLabel: 'Retry now',
2200
+ showCancel: true,
2201
+ };
2202
+ userResult = await new Promise(resolve => {
2203
+ const onAbort = () => {
2204
+ void resolve({ action: 'cancel' });
2205
+ };
2206
+ if (signal.aborted) {
2207
+ onAbort();
2208
+ return;
2209
+ }
2210
+ signal.addEventListener('abort', onAbort, { once: true });
2211
+ setAppState(prev => ({
2212
+ ...prev,
2213
+ elicitation: {
2214
+ queue: [
2215
+ ...prev.elicitation.queue,
2216
+ {
2217
+ serverName,
2218
+ requestId: `error-elicit-${elicitationId}`,
2219
+ params: elicitation,
2220
+ signal,
2221
+ waitingState,
2222
+ respond: result => {
2223
+ // Phase 1 consent: accept is a no-op (doesn't resolve retry Promise)
2224
+ if (result.action === 'accept') {
2225
+ return;
2226
+ }
2227
+ // Decline or cancel: resolve the retry Promise
2228
+ signal.removeEventListener('abort', onAbort);
2229
+ void resolve(result);
2230
+ },
2231
+ onWaitingDismiss: action => {
2232
+ signal.removeEventListener('abort', onAbort);
2233
+ if (action === 'retry') {
2234
+ void resolve({ action: 'accept' });
2235
+ }
2236
+ else {
2237
+ void resolve({ action: 'cancel' });
2238
+ }
2239
+ },
2240
+ },
2241
+ ],
2242
+ },
2243
+ }));
2244
+ });
2245
+ }
2246
+ // Run ElicitationResult hooks — they can modify or block the response
2247
+ const finalResult = await runElicitationResultHooks(serverName, userResult, signal, 'url', elicitationId);
2248
+ if (finalResult.action !== 'accept') {
2249
+ logMCPDebug(serverName, `User ${finalResult.action === 'decline' ? 'declined' : finalResult.action + 'ed'} URL elicitation ${elicitationId}`);
2250
+ return {
2251
+ 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.`,
2252
+ };
2253
+ }
2254
+ logMCPDebug(serverName, `Elicitation ${elicitationId} completed, retrying tool call`);
2255
+ }
2256
+ // Loop back to retry the tool call
2257
+ }
2258
+ }
2259
+ }
2260
+ async function callMCPTool({ client: { client, name, config }, tool, args, meta, signal, onProgress, }) {
2261
+ const toolStartTime = Date.now();
2262
+ let progressInterval;
2263
+ try {
2264
+ logMCPDebug(name, `Calling MCP tool: ${tool}`);
2265
+ // Set up progress logging for long-running tools (every 30 seconds)
2266
+ progressInterval = setInterval((startTime, name, tool) => {
2267
+ const elapsed = Date.now() - startTime;
2268
+ const elapsedSeconds = Math.floor(elapsed / 1000);
2269
+ const duration = `${elapsedSeconds}s`;
2270
+ logMCPDebug(name, `Tool '${tool}' still running (${duration} elapsed)`);
2271
+ }, 30000, // Log every 30 seconds
2272
+ toolStartTime, name, tool);
2273
+ // Use Promise.race with our own timeout to handle cases where SDK's
2274
+ // internal timeout doesn't work (e.g., SSE stream breaks mid-request)
2275
+ const timeoutMs = getMcpToolTimeoutMs();
2276
+ let timeoutId;
2277
+ const timeoutPromise = new Promise((_, reject) => {
2278
+ timeoutId = setTimeout((reject, name, tool, timeoutMs) => {
2279
+ 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'));
2280
+ }, timeoutMs, reject, name, tool, timeoutMs);
2281
+ });
2282
+ const result = await Promise.race([
2283
+ client.callTool({
2284
+ name: tool,
2285
+ arguments: args,
2286
+ _meta: meta,
2287
+ }, CallToolResultSchema, {
2288
+ signal,
2289
+ timeout: timeoutMs,
2290
+ onprogress: onProgress
2291
+ ? sdkProgress => {
2292
+ onProgress({
2293
+ type: 'mcp_progress',
2294
+ status: 'progress',
2295
+ serverName: name,
2296
+ toolName: tool,
2297
+ progress: sdkProgress.progress,
2298
+ total: sdkProgress.total,
2299
+ progressMessage: sdkProgress.message,
2300
+ });
2301
+ }
2302
+ : undefined,
2303
+ }),
2304
+ timeoutPromise,
2305
+ ]).finally(() => {
2306
+ if (timeoutId) {
2307
+ clearTimeout(timeoutId);
2308
+ }
2309
+ });
2310
+ if ('isError' in result && result.isError) {
2311
+ let errorDetails = 'Unknown error';
2312
+ if ('content' in result &&
2313
+ Array.isArray(result.content) &&
2314
+ result.content.length > 0) {
2315
+ const firstContent = result.content[0];
2316
+ if (firstContent &&
2317
+ typeof firstContent === 'object' &&
2318
+ 'text' in firstContent) {
2319
+ errorDetails = firstContent.text;
2320
+ }
2321
+ }
2322
+ else if ('error' in result) {
2323
+ // Fallback for legacy error format
2324
+ errorDetails = String(result.error);
2325
+ }
2326
+ logMCPError(name, errorDetails);
2327
+ 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);
2328
+ }
2329
+ const elapsed = Date.now() - toolStartTime;
2330
+ const duration = elapsed < 1000
2331
+ ? `${elapsed}ms`
2332
+ : elapsed < 60000
2333
+ ? `${Math.floor(elapsed / 1000)}s`
2334
+ : `${Math.floor(elapsed / 60000)}m ${Math.floor((elapsed % 60000) / 1000)}s`;
2335
+ logMCPDebug(name, `Tool '${tool}' completed successfully in ${duration}`);
2336
+ // Log code indexing tool usage
2337
+ const codeIndexingTool = detectCodeIndexingFromMcpServerName(name);
2338
+ if (codeIndexingTool) {
2339
+ logEvent('tengu_code_indexing_tool_used', {
2340
+ tool: codeIndexingTool,
2341
+ source: 'mcp',
2342
+ success: true,
2343
+ });
2344
+ }
2345
+ const content = await processMCPResult(result, tool, name);
2346
+ return {
2347
+ content,
2348
+ _meta: result._meta,
2349
+ structuredContent: result.structuredContent,
2350
+ };
2351
+ }
2352
+ catch (e) {
2353
+ // Clear intervals on error
2354
+ if (progressInterval !== undefined) {
2355
+ clearInterval(progressInterval);
2356
+ }
2357
+ const elapsed = Date.now() - toolStartTime;
2358
+ if (e instanceof Error && e.name !== 'AbortError') {
2359
+ logMCPDebug(name, `Tool '${tool}' failed after ${Math.floor(elapsed / 1000)}s: ${e.message}`);
2360
+ }
2361
+ // Check for 401 errors indicating expired/invalid OAuth tokens
2362
+ // The MCP SDK's StreamableHTTPError has a `code` property with the HTTP status
2363
+ if (e instanceof Error) {
2364
+ const errorCode = 'code' in e ? e.code : undefined;
2365
+ if (errorCode === 401 || e instanceof UnauthorizedError) {
2366
+ logMCPDebug(name, `Tool call returned 401 Unauthorized - token may have expired`);
2367
+ logEvent('tengu_mcp_tool_call_auth_error', {});
2368
+ throw new McpAuthError(name, `MCP server "${name}" requires re-authorization (token expired)`);
2369
+ }
2370
+ // Check for session expiry — two error shapes can surface here:
2371
+ // 1. Direct 404 + JSON-RPC -32001 from the server (StreamableHTTPError)
2372
+ // 2. -32000 "Connection closed" (McpError) — the SDK closes the transport
2373
+ // after the onerror handler fires, so the pending callTool() rejects
2374
+ // with this derived error instead of the original 404.
2375
+ // In both cases, clear the connection cache so the next tool call
2376
+ // creates a fresh session.
2377
+ const isSessionExpired = isMcpSessionExpiredError(e);
2378
+ const isConnectionClosedOnHttp = 'code' in e &&
2379
+ e.code === -32000 &&
2380
+ e.message.includes('Connection closed') &&
2381
+ (config.type === 'http' || config.type === 'claudeai-proxy');
2382
+ if (isSessionExpired || isConnectionClosedOnHttp) {
2383
+ logMCPDebug(name, `MCP session expired during tool call (${isSessionExpired ? '404/-32001' : 'connection closed'}), clearing connection cache for re-initialization`);
2384
+ logEvent('tengu_mcp_session_expired', {});
2385
+ await clearServerCache(name, config);
2386
+ throw new McpSessionExpiredError(name);
2387
+ }
2388
+ }
2389
+ // When the users hits esc, avoid logspew
2390
+ if (!(e instanceof Error) || e.name !== 'AbortError') {
2391
+ throw e;
2392
+ }
2393
+ return { content: undefined };
2394
+ }
2395
+ finally {
2396
+ // Always clear intervals
2397
+ if (progressInterval !== undefined) {
2398
+ clearInterval(progressInterval);
2399
+ }
2400
+ }
2401
+ }
2402
+ function extractToolUseId(message) {
2403
+ if (message.message.content[0]?.type !== 'tool_use') {
2404
+ return undefined;
2405
+ }
2406
+ return message.message.content[0].id;
2407
+ }
2408
+ /**
2409
+ * Sets up SDK MCP clients by creating transports and connecting them.
2410
+ * This is used for SDK MCP servers that run in the same process as the SDK.
2411
+ *
2412
+ * @param sdkMcpConfigs - The SDK MCP server configurations
2413
+ * @param sendMcpMessage - Callback to send MCP messages through the control channel
2414
+ * @returns Connected clients, their tools, and transport map for message routing
2415
+ */
2416
+ export async function setupSdkMcpClients(sdkMcpConfigs, sendMcpMessage) {
2417
+ const clients = [];
2418
+ const tools = [];
2419
+ // Connect to all servers in parallel
2420
+ const results = await Promise.allSettled(Object.entries(sdkMcpConfigs).map(async ([name, config]) => {
2421
+ const transport = new SdkControlClientTransport(name, sendMcpMessage);
2422
+ const client = new Client({
2423
+ name: 'claude-code',
2424
+ title: 'Context Code',
2425
+ version: MACRO.VERSION ?? 'unknown',
2426
+ description: "Anthropic's agentic coding tool",
2427
+ websiteUrl: PRODUCT_URL,
2428
+ }, {
2429
+ capabilities: {},
2430
+ });
2431
+ try {
2432
+ // Connect the client
2433
+ await client.connect(transport);
2434
+ // Get capabilities from the server
2435
+ const capabilities = client.getServerCapabilities();
2436
+ // Create the connected client object
2437
+ const connectedClient = {
2438
+ type: 'connected',
2439
+ name,
2440
+ capabilities: capabilities || {},
2441
+ client,
2442
+ config: { ...config, scope: 'dynamic' },
2443
+ cleanup: async () => {
2444
+ await client.close();
2445
+ },
2446
+ };
2447
+ // Fetch tools if the server has them
2448
+ const serverTools = [];
2449
+ if (capabilities?.tools) {
2450
+ const sdkTools = await fetchToolsForClient(connectedClient);
2451
+ serverTools.push(...sdkTools);
2452
+ }
2453
+ return {
2454
+ client: connectedClient,
2455
+ tools: serverTools,
2456
+ };
2457
+ }
2458
+ catch (error) {
2459
+ // If connection fails, return failed server
2460
+ logMCPError(name, `Failed to connect SDK MCP server: ${error}`);
2461
+ return {
2462
+ client: {
2463
+ type: 'failed',
2464
+ name,
2465
+ config: { ...config, scope: 'user' },
2466
+ },
2467
+ tools: [],
2468
+ };
2469
+ }
2470
+ }));
2471
+ // Process results and collect clients and tools
2472
+ for (const result of results) {
2473
+ if (result.status === 'fulfilled') {
2474
+ clients.push(result.value.client);
2475
+ tools.push(...result.value.tools);
2476
+ }
2477
+ // If rejected (unexpected), the error was already logged inside the promise
2478
+ }
2479
+ return { clients, tools };
2480
+ }