@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,1882 @@
1
+ import { discoverAuthorizationServerMetadata, discoverOAuthServerInfo, auth as sdkAuth, refreshAuthorization as sdkRefreshAuthorization, } from '@modelcontextprotocol/sdk/client/auth.js';
2
+ import { InvalidGrantError, OAuthError, ServerError, TemporarilyUnavailableError, TooManyRequestsError, } from '@modelcontextprotocol/sdk/server/auth/errors.js';
3
+ import { OAuthErrorResponseSchema, OAuthMetadataSchema, OAuthTokensSchema, } from '@modelcontextprotocol/sdk/shared/auth.js';
4
+ import axios from 'axios';
5
+ import { createHash, randomBytes, randomUUID } from 'crypto';
6
+ import { mkdir } from 'fs/promises';
7
+ import { createServer } from 'http';
8
+ import { join } from 'path';
9
+ import { parse } from 'url';
10
+ import xss from 'xss';
11
+ import { MCP_CLIENT_METADATA_URL } from '../../constants/oauth.js';
12
+ import { openBrowser } from '../../utils/browser.js';
13
+ import { getClaudeConfigHomeDir } from '../../utils/envUtils.js';
14
+ import { errorMessage, getErrnoCode } from '../../utils/errors.js';
15
+ import * as lockfile from '../../utils/lockfile.js';
16
+ import { logMCPDebug } from '../../utils/log.js';
17
+ import { getPlatform } from '../../utils/platform.js';
18
+ import { getSecureStorage } from '../../utils/secureStorage/index.js';
19
+ import { clearKeychainCache } from '../../utils/secureStorage/macOsKeychainHelpers.js';
20
+ import { sleep } from '../../utils/sleep.js';
21
+ import { jsonParse, jsonStringify } from '../../utils/slowOperations.js';
22
+ import { logEvent } from '../analytics/index.js';
23
+ import { buildRedirectUri, findAvailablePort } from './oauthPort.js';
24
+ import { getLoggingSafeMcpBaseUrl } from './utils.js';
25
+ import { performCrossAppAccess, XaaTokenExchangeError } from './xaa.js';
26
+ import { acquireIdpIdToken, clearIdpIdToken, discoverOidc, getCachedIdpIdToken, getIdpClientSecret, getXaaIdpSettings, isXaaEnabled, } from './xaaIdpLogin.js';
27
+ /**
28
+ * Timeout for individual OAuth requests (metadata discovery, token refresh, etc.)
29
+ */
30
+ const AUTH_REQUEST_TIMEOUT_MS = 30000;
31
+ const MAX_LOCK_RETRIES = 5;
32
+ /**
33
+ * OAuth query parameters that should be redacted from logs.
34
+ * These contain sensitive values that could enable CSRF or session fixation attacks.
35
+ */
36
+ const SENSITIVE_OAUTH_PARAMS = [
37
+ 'state',
38
+ 'nonce',
39
+ 'code_challenge',
40
+ 'code_verifier',
41
+ 'code',
42
+ ];
43
+ /**
44
+ * Redacts sensitive OAuth query parameters from a URL for safe logging.
45
+ * Prevents exposure of state, nonce, code_challenge, code_verifier, and authorization codes.
46
+ */
47
+ function redactSensitiveUrlParams(url) {
48
+ try {
49
+ const parsedUrl = new URL(url);
50
+ for (const param of SENSITIVE_OAUTH_PARAMS) {
51
+ if (parsedUrl.searchParams.has(param)) {
52
+ parsedUrl.searchParams.set(param, '[REDACTED]');
53
+ }
54
+ }
55
+ return parsedUrl.toString();
56
+ }
57
+ catch {
58
+ // Return as-is if not a valid URL
59
+ return url;
60
+ }
61
+ }
62
+ /**
63
+ * Some OAuth servers (notably Slack) return HTTP 200 for all responses,
64
+ * signaling errors via the JSON body instead. The SDK's executeTokenRequest
65
+ * only calls parseErrorResponse when !response.ok, so a 200 with
66
+ * {"error":"invalid_grant"} gets fed to OAuthTokensSchema.parse() and
67
+ * surfaces as a ZodError — which the refresh retry/invalidation logic
68
+ * treats as opaque request_failed instead of invalid_grant.
69
+ *
70
+ * This wrapper peeks at 2xx POST response bodies and rewrites ones that
71
+ * match OAuthErrorResponseSchema (but not OAuthTokensSchema) to a 400
72
+ * Response, so the SDK's normal error-class mapping applies. The same
73
+ * fetchFn is also used for DCR POSTs, but DCR success responses have no
74
+ * {error: string} field so they don't match the rewrite condition.
75
+ *
76
+ * Slack uses non-standard error codes (invalid_refresh_token observed live
77
+ * at oauth.v2.user.access; expired_refresh_token/token_expired per Slack's
78
+ * token rotation docs) where RFC 6749 specifies invalid_grant. We normalize
79
+ * those so OAUTH_ERRORS['invalid_grant'] → InvalidGrantError matches and
80
+ * token invalidation fires correctly.
81
+ */
82
+ const NONSTANDARD_INVALID_GRANT_ALIASES = new Set([
83
+ 'invalid_refresh_token',
84
+ 'expired_refresh_token',
85
+ 'token_expired',
86
+ ]);
87
+ /* eslint-disable eslint-plugin-n/no-unsupported-features/node-builtins --
88
+ * Response has been stable in Node since 18; the rule flags it as
89
+ * experimental-until-21 which is incorrect. Pattern matches existing
90
+ * createAuthFetch suppressions in this file. */
91
+ export async function normalizeOAuthErrorBody(response) {
92
+ if (!response.ok) {
93
+ return response;
94
+ }
95
+ const text = await response.text();
96
+ let parsed;
97
+ try {
98
+ parsed = jsonParse(text);
99
+ }
100
+ catch {
101
+ return new Response(text, response);
102
+ }
103
+ if (OAuthTokensSchema.safeParse(parsed).success) {
104
+ return new Response(text, response);
105
+ }
106
+ const result = OAuthErrorResponseSchema.safeParse(parsed);
107
+ if (!result.success) {
108
+ return new Response(text, response);
109
+ }
110
+ const normalized = NONSTANDARD_INVALID_GRANT_ALIASES.has(result.data.error)
111
+ ? {
112
+ error: 'invalid_grant',
113
+ error_description: result.data.error_description ??
114
+ `Server returned non-standard error code: ${result.data.error}`,
115
+ }
116
+ : result.data;
117
+ return new Response(jsonStringify(normalized), {
118
+ status: 400,
119
+ statusText: 'Bad Request',
120
+ headers: response.headers,
121
+ });
122
+ }
123
+ /* eslint-enable eslint-plugin-n/no-unsupported-features/node-builtins */
124
+ /**
125
+ * Creates a fetch function with a fresh 30-second timeout for each OAuth request.
126
+ * Used by ClaudeAuthProvider for metadata discovery and token refresh.
127
+ * Prevents stale timeout signals from affecting auth operations.
128
+ */
129
+ function createAuthFetch() {
130
+ return async (url, init) => {
131
+ const timeoutSignal = AbortSignal.timeout(AUTH_REQUEST_TIMEOUT_MS);
132
+ const isPost = init?.method?.toUpperCase() === 'POST';
133
+ // No existing signal - just use timeout
134
+ if (!init?.signal) {
135
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
136
+ const response = await fetch(url, { ...init, signal: timeoutSignal });
137
+ return isPost ? normalizeOAuthErrorBody(response) : response;
138
+ }
139
+ // Combine signals: abort when either fires
140
+ const controller = new AbortController();
141
+ const abort = () => controller.abort();
142
+ init.signal.addEventListener('abort', abort);
143
+ timeoutSignal.addEventListener('abort', abort);
144
+ // Cleanup to prevent event listener leaks after fetch completes
145
+ const cleanup = () => {
146
+ init.signal?.removeEventListener('abort', abort);
147
+ timeoutSignal.removeEventListener('abort', abort);
148
+ };
149
+ if (init.signal.aborted) {
150
+ controller.abort();
151
+ }
152
+ try {
153
+ // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
154
+ const response = await fetch(url, { ...init, signal: controller.signal });
155
+ cleanup();
156
+ return isPost ? normalizeOAuthErrorBody(response) : response;
157
+ }
158
+ catch (error) {
159
+ cleanup();
160
+ throw error;
161
+ }
162
+ };
163
+ }
164
+ /**
165
+ * Fetches authorization server metadata, using a configured metadata URL if available,
166
+ * otherwise performing RFC 9728 → RFC 8414 discovery via the SDK.
167
+ *
168
+ * Discovery order when no configured URL:
169
+ * 1. RFC 9728: probe /.well-known/oauth-protected-resource on the MCP server,
170
+ * read authorization_servers[0], then RFC 8414 against that URL.
171
+ * 2. Fallback: RFC 8414 directly against the MCP server URL (path-aware). Covers
172
+ * legacy servers that co-host auth metadata at /.well-known/oauth-authorization-server/{path}
173
+ * without implementing RFC 9728. The SDK's own fallback strips the path, so this
174
+ * preserves the pre-existing path-aware probe for backward compatibility.
175
+ *
176
+ * Note: configuredMetadataUrl is user-controlled via .mcp.json. Project-scoped MCP
177
+ * servers require user approval before connecting (same trust level as the MCP server
178
+ * URL itself). The HTTPS requirement here is defense-in-depth beyond schema validation
179
+ * — RFC 8414 mandates OAuth metadata retrieval over TLS.
180
+ */
181
+ async function fetchAuthServerMetadata(serverName, serverUrl, configuredMetadataUrl, fetchFn, resourceMetadataUrl) {
182
+ if (configuredMetadataUrl) {
183
+ if (!configuredMetadataUrl.startsWith('https://')) {
184
+ throw new Error(`authServerMetadataUrl must use https:// (got: ${configuredMetadataUrl})`);
185
+ }
186
+ const authFetch = fetchFn ?? createAuthFetch();
187
+ const response = await authFetch(configuredMetadataUrl, {
188
+ headers: { Accept: 'application/json' },
189
+ });
190
+ if (response.ok) {
191
+ return OAuthMetadataSchema.parse(await response.json());
192
+ }
193
+ throw new Error(`HTTP ${response.status} fetching configured auth server metadata from ${configuredMetadataUrl}`);
194
+ }
195
+ try {
196
+ const { authorizationServerMetadata } = await discoverOAuthServerInfo(serverUrl, {
197
+ ...(fetchFn && { fetchFn }),
198
+ ...(resourceMetadataUrl && { resourceMetadataUrl }),
199
+ });
200
+ if (authorizationServerMetadata) {
201
+ return authorizationServerMetadata;
202
+ }
203
+ }
204
+ catch (err) {
205
+ // Any error from the RFC 9728 → RFC 8414 chain (5xx from the root or
206
+ // resolved-AS probe, schema parse failure, network error) — fall through
207
+ // to the legacy path-aware retry.
208
+ logMCPDebug(serverName, `RFC 9728 discovery failed, falling back: ${errorMessage(err)}`);
209
+ }
210
+ // Fallback only when the URL has a path component; for root URLs the SDK's
211
+ // own fallback already probed the same endpoints.
212
+ const url = new URL(serverUrl);
213
+ if (url.pathname === '/') {
214
+ return undefined;
215
+ }
216
+ return discoverAuthorizationServerMetadata(url, {
217
+ ...(fetchFn && { fetchFn }),
218
+ });
219
+ }
220
+ export class AuthenticationCancelledError extends Error {
221
+ constructor() {
222
+ super('Authentication was cancelled');
223
+ this.name = 'AuthenticationCancelledError';
224
+ }
225
+ }
226
+ /**
227
+ * Generates a unique key for server credentials based on both name and config hash
228
+ * This prevents credentials from being reused across different servers
229
+ * with the same name or different configurations
230
+ */
231
+ export function getServerKey(serverName, serverConfig) {
232
+ const configJson = jsonStringify({
233
+ type: serverConfig.type,
234
+ url: serverConfig.url,
235
+ headers: serverConfig.headers || {},
236
+ });
237
+ const hash = createHash('sha256')
238
+ .update(configJson)
239
+ .digest('hex')
240
+ .substring(0, 16);
241
+ return `${serverName}|${hash}`;
242
+ }
243
+ /**
244
+ * True when we have probed this server before (OAuth discovery state is
245
+ * stored) but hold no credentials to try. A connection attempt in this
246
+ * state is guaranteed to 401 — the only way out is the user running
247
+ * /mcp to authenticate.
248
+ */
249
+ export function hasMcpDiscoveryButNoToken(serverName, serverConfig) {
250
+ // XAA servers can silently re-auth via cached id_token even without an
251
+ // access/refresh token — tokens() fires the xaaRefresh path. Skipping the
252
+ // connection here would make that auto-auth branch unreachable after
253
+ // invalidateCredentials('tokens') clears the stored tokens.
254
+ if (isXaaEnabled() && serverConfig.oauth?.xaa) {
255
+ return false;
256
+ }
257
+ const serverKey = getServerKey(serverName, serverConfig);
258
+ const entry = getSecureStorage().read()?.mcpOAuth?.[serverKey];
259
+ return entry !== undefined && !entry.accessToken && !entry.refreshToken;
260
+ }
261
+ /**
262
+ * Revokes a single token on the OAuth server.
263
+ *
264
+ * Per RFC 7009, public clients (like Context Code) should authenticate by including
265
+ * client_id in the request body, NOT via an Authorization header. The Bearer token
266
+ * in an Authorization header is meant for resource owner authentication, not client
267
+ * authentication.
268
+ *
269
+ * However, the MCP spec doesn't explicitly define token revocation behavior, so some
270
+ * servers may not be RFC 7009 compliant. As defensive programming, we:
271
+ * 1. First try the RFC 7009 compliant approach (client_id in body, no Authorization header)
272
+ * 2. If we get a 401, retry with Bearer auth as a fallback for non-compliant servers
273
+ *
274
+ * This fallback should rarely be needed - most servers either accept the compliant
275
+ * approach or ignore unexpected headers.
276
+ */
277
+ async function revokeToken({ serverName, endpoint, token, tokenTypeHint, clientId, clientSecret, accessToken, authMethod = 'client_secret_basic', }) {
278
+ const params = new URLSearchParams();
279
+ params.set('token', token);
280
+ params.set('token_type_hint', tokenTypeHint);
281
+ const headers = {
282
+ 'Content-Type': 'application/x-www-form-urlencoded',
283
+ };
284
+ // RFC 7009 §2.1 requires client auth per RFC 6749 §2.3. XAA always uses a
285
+ // confidential client at the AS — strict ASes (Okta/Stytch) reject public-
286
+ // client revocation of confidential-client tokens.
287
+ if (clientId && clientSecret) {
288
+ if (authMethod === 'client_secret_post') {
289
+ params.set('client_id', clientId);
290
+ params.set('client_secret', clientSecret);
291
+ }
292
+ else {
293
+ const basic = Buffer.from(`${encodeURIComponent(clientId)}:${encodeURIComponent(clientSecret)}`).toString('base64');
294
+ headers.Authorization = `Basic ${basic}`;
295
+ }
296
+ }
297
+ else if (clientId) {
298
+ params.set('client_id', clientId);
299
+ }
300
+ else {
301
+ logMCPDebug(serverName, `No client_id available for ${tokenTypeHint} revocation - server may reject`);
302
+ }
303
+ try {
304
+ await axios.post(endpoint, params, { headers });
305
+ logMCPDebug(serverName, `Successfully revoked ${tokenTypeHint}`);
306
+ }
307
+ catch (error) {
308
+ // Fallback for non-RFC-7009-compliant servers that require Bearer auth
309
+ if (axios.isAxiosError(error) &&
310
+ error.response?.status === 401 &&
311
+ accessToken) {
312
+ logMCPDebug(serverName, `Got 401, retrying ${tokenTypeHint} revocation with Bearer auth`);
313
+ // RFC 6749 §2.3.1: must not send more than one auth method. The retry
314
+ // switches to Bearer — clear any client creds from the body.
315
+ params.delete('client_id');
316
+ params.delete('client_secret');
317
+ await axios.post(endpoint, params, {
318
+ headers: { ...headers, Authorization: `Bearer ${accessToken}` },
319
+ });
320
+ logMCPDebug(serverName, `Successfully revoked ${tokenTypeHint} with Bearer auth`);
321
+ }
322
+ else {
323
+ throw error;
324
+ }
325
+ }
326
+ }
327
+ /**
328
+ * Revokes tokens on the OAuth server if a revocation endpoint is available.
329
+ * Per RFC 7009, we revoke the refresh token first (the long-lived credential),
330
+ * then the access token. Revoking the refresh token prevents generation of new
331
+ * access tokens and many servers implicitly invalidate associated access tokens.
332
+ */
333
+ export async function revokeServerTokens(serverName, serverConfig, { preserveStepUpState = false } = {}) {
334
+ const storage = getSecureStorage();
335
+ const existingData = storage.read();
336
+ if (!existingData?.mcpOAuth)
337
+ return;
338
+ const serverKey = getServerKey(serverName, serverConfig);
339
+ const tokenData = existingData.mcpOAuth[serverKey];
340
+ // Attempt server-side revocation if there are tokens to revoke (best-effort)
341
+ if (tokenData?.accessToken || tokenData?.refreshToken) {
342
+ try {
343
+ // For XAA (and any PRM-discovered auth), the AS is at a different host
344
+ // than the MCP URL — use the persisted discoveryState if we have it.
345
+ const asUrl = tokenData.discoveryState?.authorizationServerUrl ?? serverConfig.url;
346
+ const metadata = await fetchAuthServerMetadata(serverName, asUrl, serverConfig.oauth?.authServerMetadataUrl);
347
+ if (!metadata) {
348
+ logMCPDebug(serverName, 'No OAuth metadata found');
349
+ }
350
+ else {
351
+ const revocationEndpoint = 'revocation_endpoint' in metadata
352
+ ? metadata.revocation_endpoint
353
+ : null;
354
+ if (!revocationEndpoint) {
355
+ logMCPDebug(serverName, 'Server does not support token revocation');
356
+ }
357
+ else {
358
+ const revocationEndpointStr = String(revocationEndpoint);
359
+ // RFC 7009 defines revocation_endpoint_auth_methods_supported
360
+ // separately from the token endpoint's list; prefer it if present.
361
+ const authMethods = ('revocation_endpoint_auth_methods_supported' in metadata
362
+ ? metadata.revocation_endpoint_auth_methods_supported
363
+ : undefined) ??
364
+ ('token_endpoint_auth_methods_supported' in metadata
365
+ ? metadata.token_endpoint_auth_methods_supported
366
+ : undefined);
367
+ const authMethod = authMethods &&
368
+ !authMethods.includes('client_secret_basic') &&
369
+ authMethods.includes('client_secret_post')
370
+ ? 'client_secret_post'
371
+ : 'client_secret_basic';
372
+ logMCPDebug(serverName, `Revoking tokens via ${revocationEndpointStr} (${authMethod})`);
373
+ // Revoke refresh token first (more important - prevents future access token generation)
374
+ if (tokenData.refreshToken) {
375
+ try {
376
+ await revokeToken({
377
+ serverName,
378
+ endpoint: revocationEndpointStr,
379
+ token: tokenData.refreshToken,
380
+ tokenTypeHint: 'refresh_token',
381
+ clientId: tokenData.clientId,
382
+ clientSecret: tokenData.clientSecret,
383
+ accessToken: tokenData.accessToken,
384
+ authMethod,
385
+ });
386
+ }
387
+ catch (error) {
388
+ // Log but continue
389
+ logMCPDebug(serverName, `Failed to revoke refresh token: ${errorMessage(error)}`);
390
+ }
391
+ }
392
+ // Then revoke access token (may already be invalidated by refresh token revocation)
393
+ if (tokenData.accessToken) {
394
+ try {
395
+ await revokeToken({
396
+ serverName,
397
+ endpoint: revocationEndpointStr,
398
+ token: tokenData.accessToken,
399
+ tokenTypeHint: 'access_token',
400
+ clientId: tokenData.clientId,
401
+ clientSecret: tokenData.clientSecret,
402
+ accessToken: tokenData.accessToken,
403
+ authMethod,
404
+ });
405
+ }
406
+ catch (error) {
407
+ logMCPDebug(serverName, `Failed to revoke access token: ${errorMessage(error)}`);
408
+ }
409
+ }
410
+ }
411
+ }
412
+ }
413
+ catch (error) {
414
+ // Log error but don't throw - revocation is best-effort
415
+ logMCPDebug(serverName, `Failed to revoke tokens: ${errorMessage(error)}`);
416
+ }
417
+ }
418
+ else {
419
+ logMCPDebug(serverName, 'No tokens to revoke');
420
+ }
421
+ // Always clear local tokens, regardless of server-side revocation result.
422
+ clearServerTokensFromLocalStorage(serverName, serverConfig);
423
+ // When re-authenticating, preserve step-up auth state (scope + discovery)
424
+ // so the next performMCPOAuthFlow can use cached scope instead of
425
+ // re-probing. For "Clear Auth" (default), wipe everything.
426
+ if (preserveStepUpState &&
427
+ tokenData &&
428
+ (tokenData.stepUpScope || tokenData.discoveryState)) {
429
+ const freshData = storage.read() || {};
430
+ const updatedData = {
431
+ ...freshData,
432
+ mcpOAuth: {
433
+ ...freshData.mcpOAuth,
434
+ [serverKey]: {
435
+ ...freshData.mcpOAuth?.[serverKey],
436
+ serverName,
437
+ serverUrl: serverConfig.url,
438
+ accessToken: freshData.mcpOAuth?.[serverKey]?.accessToken ?? '',
439
+ expiresAt: freshData.mcpOAuth?.[serverKey]?.expiresAt ?? 0,
440
+ ...(tokenData.stepUpScope
441
+ ? { stepUpScope: tokenData.stepUpScope }
442
+ : {}),
443
+ ...(tokenData.discoveryState
444
+ ? {
445
+ // Strip legacy bulky metadata fields here too so users with
446
+ // existing overflowed blobs recover on next re-auth (#30337).
447
+ discoveryState: {
448
+ authorizationServerUrl: tokenData.discoveryState.authorizationServerUrl,
449
+ resourceMetadataUrl: tokenData.discoveryState.resourceMetadataUrl,
450
+ },
451
+ }
452
+ : {}),
453
+ },
454
+ },
455
+ };
456
+ storage.update(updatedData);
457
+ logMCPDebug(serverName, 'Preserved step-up auth state across revocation');
458
+ }
459
+ }
460
+ export function clearServerTokensFromLocalStorage(serverName, serverConfig) {
461
+ const storage = getSecureStorage();
462
+ const existingData = storage.read();
463
+ if (!existingData?.mcpOAuth)
464
+ return;
465
+ const serverKey = getServerKey(serverName, serverConfig);
466
+ if (existingData.mcpOAuth[serverKey]) {
467
+ delete existingData.mcpOAuth[serverKey];
468
+ storage.update(existingData);
469
+ logMCPDebug(serverName, 'Cleared stored tokens');
470
+ }
471
+ }
472
+ /**
473
+ * XAA (Cross-App Access) auth.
474
+ *
475
+ * One IdP browser login is reused across all XAA-configured MCP servers:
476
+ * 1. Acquire an id_token from the IdP (cached in keychain by issuer; if
477
+ * missing/expired, runs a standard OIDC authorization_code+PKCE flow
478
+ * — this is the one browser pop)
479
+ * 2. Run the RFC 8693 + RFC 7523 exchange (no browser)
480
+ * 3. Save tokens to the same keychain slot as normal OAuth
481
+ *
482
+ * IdP connection details come from settings.xaaIdp (configured once via
483
+ * `claude mcp xaa setup`). Per-server config is just `oauth.xaa: true`
484
+ * plus the AS clientId/clientSecret.
485
+ *
486
+ * No silent fallback: if `oauth.xaa` is set, XAA is the only path.
487
+ * All errors are actionable — they tell the user what to run.
488
+ */
489
+ async function performMCPXaaAuth(serverName, serverConfig, onAuthorizationUrl, abortSignal, skipBrowserOpen) {
490
+ if (!serverConfig.oauth?.xaa) {
491
+ throw new Error('XAA: oauth.xaa must be set'); // guarded by caller
492
+ }
493
+ // IdP config comes from user-level settings, not per-server.
494
+ const idp = getXaaIdpSettings();
495
+ if (!idp) {
496
+ throw new Error("XAA: no IdP connection configured. Run 'claude mcp xaa setup --issuer <url> --client-id <id> --client-secret' to configure.");
497
+ }
498
+ const clientId = serverConfig.oauth?.clientId;
499
+ if (!clientId) {
500
+ throw new Error(`XAA: server '${serverName}' needs an AS client_id. Re-add with --client-id.`);
501
+ }
502
+ const clientConfig = getMcpClientConfig(serverName, serverConfig);
503
+ const clientSecret = clientConfig?.clientSecret;
504
+ if (!clientSecret) {
505
+ // Diagnostic context for serverKey mismatch debugging. Only computed
506
+ // on the error path so there's no perf cost on success.
507
+ const wantedKey = getServerKey(serverName, serverConfig);
508
+ const haveKeys = Object.keys(getSecureStorage().read()?.mcpOAuthClientConfig ?? {});
509
+ const headersForLogging = Object.fromEntries(Object.entries(serverConfig.headers ?? {}).map(([k, v]) => k.toLowerCase() === 'authorization' ? [k, '[REDACTED]'] : [k, v]));
510
+ logMCPDebug(serverName, `XAA: secret lookup miss. wanted=${wantedKey} have=[${haveKeys.join(', ')}] configHeaders=${jsonStringify(headersForLogging)}`);
511
+ throw new Error(`XAA: AS client secret not found for '${serverName}'. Re-add with --client-secret.`);
512
+ }
513
+ logMCPDebug(serverName, 'XAA: starting cross-app access flow');
514
+ // IdP client secret lives in a separate keychain slot (keyed by IdP issuer),
515
+ // NOT the AS secret — different trust domain. Optional: if absent, PKCE-only.
516
+ const idpClientSecret = getIdpClientSecret(idp.issuer);
517
+ // Acquire id_token (cached or via one OIDC browser pop at the IdP).
518
+ // Peek the cache first so we can report idTokenCacheHit in analytics before
519
+ // acquireIdpIdToken potentially writes a fresh one.
520
+ const idTokenCacheHit = getCachedIdpIdToken(idp.issuer) !== undefined;
521
+ let failureStage = 'idp_login';
522
+ try {
523
+ let idToken;
524
+ try {
525
+ idToken = await acquireIdpIdToken({
526
+ idpIssuer: idp.issuer,
527
+ idpClientId: idp.clientId,
528
+ idpClientSecret,
529
+ callbackPort: idp.callbackPort,
530
+ onAuthorizationUrl,
531
+ skipBrowserOpen,
532
+ abortSignal,
533
+ });
534
+ }
535
+ catch (e) {
536
+ if (abortSignal?.aborted)
537
+ throw new AuthenticationCancelledError();
538
+ throw e;
539
+ }
540
+ // Discover the IdP's token endpoint for the RFC 8693 exchange.
541
+ failureStage = 'discovery';
542
+ const oidc = await discoverOidc(idp.issuer);
543
+ // Run the exchange. performCrossAppAccess throws XaaTokenExchangeError
544
+ // for the IdP leg and "jwt-bearer grant failed" for the AS leg.
545
+ failureStage = 'token_exchange';
546
+ let tokens;
547
+ try {
548
+ tokens = await performCrossAppAccess(serverConfig.url, {
549
+ clientId,
550
+ clientSecret,
551
+ idpClientId: idp.clientId,
552
+ idpClientSecret,
553
+ idpIdToken: idToken,
554
+ idpTokenEndpoint: oidc.token_endpoint,
555
+ }, serverName, abortSignal);
556
+ }
557
+ catch (e) {
558
+ if (abortSignal?.aborted)
559
+ throw new AuthenticationCancelledError();
560
+ const msg = errorMessage(e);
561
+ // If the IdP says the id_token is bad, drop it from the cache so the
562
+ // next attempt does a fresh IdP login. XaaTokenExchangeError carries
563
+ // shouldClearIdToken so we key off OAuth semantics (4xx / invalid body
564
+ // → clear; 5xx IdP outage → preserve) rather than substring matching.
565
+ if (e instanceof XaaTokenExchangeError) {
566
+ if (e.shouldClearIdToken) {
567
+ clearIdpIdToken(idp.issuer);
568
+ logMCPDebug(serverName, 'XAA: cleared cached id_token after token-exchange failure');
569
+ }
570
+ }
571
+ else if (msg.includes('PRM discovery failed') ||
572
+ msg.includes('AS metadata discovery failed') ||
573
+ msg.includes('no authorization server supports jwt-bearer')) {
574
+ // performCrossAppAccess runs PRM + AS discovery before the actual
575
+ // exchange — don't attribute their failures to 'token_exchange'.
576
+ failureStage = 'discovery';
577
+ }
578
+ else if (msg.includes('jwt-bearer')) {
579
+ failureStage = 'jwt_bearer';
580
+ }
581
+ throw e;
582
+ }
583
+ // Save tokens via the same storage path as normal OAuth. We write directly
584
+ // (instead of ClaudeAuthProvider.saveTokens) to avoid instantiating the
585
+ // whole provider just to write the same keys.
586
+ const storage = getSecureStorage();
587
+ const existingData = storage.read() || {};
588
+ const serverKey = getServerKey(serverName, serverConfig);
589
+ const prev = existingData.mcpOAuth?.[serverKey];
590
+ storage.update({
591
+ ...existingData,
592
+ mcpOAuth: {
593
+ ...existingData.mcpOAuth,
594
+ [serverKey]: {
595
+ ...prev,
596
+ serverName,
597
+ serverUrl: serverConfig.url,
598
+ accessToken: tokens.access_token,
599
+ // AS may omit refresh_token on jwt-bearer — preserve any existing one
600
+ refreshToken: tokens.refresh_token ?? prev?.refreshToken,
601
+ expiresAt: Date.now() + (tokens.expires_in || 3600) * 1000,
602
+ scope: tokens.scope,
603
+ clientId,
604
+ clientSecret,
605
+ // Persist the AS URL so _doRefresh and revokeServerTokens can locate
606
+ // the token/revocation endpoints when MCP URL ≠ AS URL (the common
607
+ // XAA topology).
608
+ discoveryState: {
609
+ authorizationServerUrl: tokens.authorizationServerUrl,
610
+ },
611
+ },
612
+ },
613
+ });
614
+ logMCPDebug(serverName, 'XAA: tokens saved');
615
+ logEvent('tengu_mcp_oauth_flow_success', {
616
+ authMethod: 'xaa',
617
+ idTokenCacheHit,
618
+ });
619
+ }
620
+ catch (e) {
621
+ // User-initiated cancel (Esc during IdP browser pop) isn't a failure.
622
+ if (e instanceof AuthenticationCancelledError) {
623
+ throw e;
624
+ }
625
+ logEvent('tengu_mcp_oauth_flow_failure', {
626
+ authMethod: 'xaa',
627
+ xaaFailureStage: failureStage,
628
+ idTokenCacheHit,
629
+ });
630
+ throw e;
631
+ }
632
+ }
633
+ export async function performMCPOAuthFlow(serverName, serverConfig, onAuthorizationUrl, abortSignal, options) {
634
+ // XAA (SEP-990): if configured, bypass the per-server consent dance.
635
+ // If the IdP id_token isn't cached, this pops the browser once at the IdP
636
+ // (shared across all XAA servers for that issuer). Subsequent servers hit
637
+ // the cache and are silent. Tokens land in the same keychain slot, so the
638
+ // rest of CC's transport wiring (ClaudeAuthProvider.tokens() in client.ts)
639
+ // works unchanged.
640
+ //
641
+ // No silent fallback: if `oauth.xaa` is set, XAA is the only path. We
642
+ // never fall through to the consent flow — that would be surprising (the
643
+ // user explicitly asked for XAA) and security-relevant (consent flow may
644
+ // have a different trust/scope posture than the org's IdP policy).
645
+ //
646
+ // Servers with `oauth.xaa` but CLAUDE_CODE_ENABLE_XAA unset hard-fail with
647
+ // actionable copy rather than silently degrade to consent.
648
+ if (serverConfig.oauth?.xaa) {
649
+ if (!isXaaEnabled()) {
650
+ throw new Error(`XAA is not enabled (set CLAUDE_CODE_ENABLE_XAA=1). Remove 'oauth.xaa' from server '${serverName}' to use the standard consent flow.`);
651
+ }
652
+ logEvent('tengu_mcp_oauth_flow_start', {
653
+ isOAuthFlow: true,
654
+ authMethod: 'xaa',
655
+ transportType: serverConfig.type,
656
+ ...(getLoggingSafeMcpBaseUrl(serverConfig)
657
+ ? {
658
+ mcpServerBaseUrl: getLoggingSafeMcpBaseUrl(serverConfig),
659
+ }
660
+ : {}),
661
+ });
662
+ // performMCPXaaAuth logs its own success/failure events (with
663
+ // idTokenCacheHit + xaaFailureStage).
664
+ await performMCPXaaAuth(serverName, serverConfig, onAuthorizationUrl, abortSignal, options?.skipBrowserOpen);
665
+ return;
666
+ }
667
+ // Check for cached step-up scope and resource metadata URL before clearing
668
+ // tokens. The transport-attached auth provider persists scope when it receives
669
+ // a step-up 401, so we can use it here instead of making an extra probe request.
670
+ const storage = getSecureStorage();
671
+ const serverKey = getServerKey(serverName, serverConfig);
672
+ const cachedEntry = storage.read()?.mcpOAuth?.[serverKey];
673
+ const cachedStepUpScope = cachedEntry?.stepUpScope;
674
+ const cachedResourceMetadataUrl = cachedEntry?.discoveryState?.resourceMetadataUrl;
675
+ // Clear any existing stored credentials to ensure fresh client registration.
676
+ // Note: this deletes the entire entry (including discoveryState/stepUpScope),
677
+ // but we already read the cached values above.
678
+ clearServerTokensFromLocalStorage(serverName, serverConfig);
679
+ // Use cached step-up scope and resource metadata URL if available.
680
+ // The transport-attached auth provider caches these when it receives a
681
+ // step-up 401, so we don't need to probe the server again.
682
+ let resourceMetadataUrl;
683
+ if (cachedResourceMetadataUrl) {
684
+ try {
685
+ resourceMetadataUrl = new URL(cachedResourceMetadataUrl);
686
+ }
687
+ catch {
688
+ logMCPDebug(serverName, `Invalid cached resourceMetadataUrl: ${cachedResourceMetadataUrl}`);
689
+ }
690
+ }
691
+ const wwwAuthParams = {
692
+ scope: cachedStepUpScope,
693
+ resourceMetadataUrl,
694
+ };
695
+ const flowAttemptId = randomUUID();
696
+ logEvent('tengu_mcp_oauth_flow_start', {
697
+ flowAttemptId: flowAttemptId,
698
+ isOAuthFlow: true,
699
+ transportType: serverConfig.type,
700
+ ...(getLoggingSafeMcpBaseUrl(serverConfig)
701
+ ? {
702
+ mcpServerBaseUrl: getLoggingSafeMcpBaseUrl(serverConfig),
703
+ }
704
+ : {}),
705
+ });
706
+ // Track whether we reached the token-exchange phase so the catch block can
707
+ // attribute the failure reason correctly.
708
+ let authorizationCodeObtained = false;
709
+ try {
710
+ // Use configured callback port for pre-configured OAuth, otherwise find an available port
711
+ const configuredCallbackPort = serverConfig.oauth?.callbackPort;
712
+ const port = configuredCallbackPort ?? (await findAvailablePort());
713
+ const redirectUri = buildRedirectUri(port);
714
+ logMCPDebug(serverName, `Using redirect port: ${port}${configuredCallbackPort ? ' (from config)' : ''}`);
715
+ const provider = new ClaudeAuthProvider(serverName, serverConfig, redirectUri, true, onAuthorizationUrl, options?.skipBrowserOpen);
716
+ // Fetch and store OAuth metadata for scope information
717
+ try {
718
+ const metadata = await fetchAuthServerMetadata(serverName, serverConfig.url, serverConfig.oauth?.authServerMetadataUrl, undefined, wwwAuthParams.resourceMetadataUrl);
719
+ if (metadata) {
720
+ // Store metadata in provider for scope information
721
+ provider.setMetadata(metadata);
722
+ logMCPDebug(serverName, `Fetched OAuth metadata with scope: ${getScopeFromMetadata(metadata) || 'NONE'}`);
723
+ }
724
+ }
725
+ catch (error) {
726
+ logMCPDebug(serverName, `Failed to fetch OAuth metadata: ${errorMessage(error)}`);
727
+ }
728
+ // Get the OAuth state from the provider for validation
729
+ const oauthState = await provider.state();
730
+ // Store the server, timeout, and abort listener references for cleanup
731
+ let server = null;
732
+ let timeoutId = null;
733
+ let abortHandler = null;
734
+ const cleanup = () => {
735
+ if (server) {
736
+ server.removeAllListeners();
737
+ // Defensive: removeAllListeners() strips the error handler, so swallow any late error during close
738
+ server.on('error', () => { });
739
+ server.close();
740
+ server = null;
741
+ }
742
+ if (timeoutId) {
743
+ clearTimeout(timeoutId);
744
+ timeoutId = null;
745
+ }
746
+ if (abortSignal && abortHandler) {
747
+ abortSignal.removeEventListener('abort', abortHandler);
748
+ abortHandler = null;
749
+ }
750
+ logMCPDebug(serverName, `MCP OAuth server cleaned up`);
751
+ };
752
+ // Setup a server to receive the callback
753
+ const authorizationCode = await new Promise((resolve, reject) => {
754
+ let resolved = false;
755
+ const resolveOnce = (code) => {
756
+ if (resolved)
757
+ return;
758
+ resolved = true;
759
+ resolve(code);
760
+ };
761
+ const rejectOnce = (error) => {
762
+ if (resolved)
763
+ return;
764
+ resolved = true;
765
+ reject(error);
766
+ };
767
+ if (abortSignal) {
768
+ abortHandler = () => {
769
+ cleanup();
770
+ rejectOnce(new AuthenticationCancelledError());
771
+ };
772
+ if (abortSignal.aborted) {
773
+ abortHandler();
774
+ return;
775
+ }
776
+ abortSignal.addEventListener('abort', abortHandler);
777
+ }
778
+ // Allow manual callback URL paste for remote/browser-based environments
779
+ // where localhost is not reachable from the user's browser.
780
+ if (options?.onWaitingForCallback) {
781
+ options.onWaitingForCallback((callbackUrl) => {
782
+ try {
783
+ const parsed = new URL(callbackUrl);
784
+ const code = parsed.searchParams.get('code');
785
+ const state = parsed.searchParams.get('state');
786
+ const error = parsed.searchParams.get('error');
787
+ if (error) {
788
+ const errorDescription = parsed.searchParams.get('error_description') || '';
789
+ cleanup();
790
+ rejectOnce(new Error(`OAuth error: ${error} - ${errorDescription}`));
791
+ return;
792
+ }
793
+ if (!code) {
794
+ // Not a valid callback URL, ignore so the user can try again
795
+ return;
796
+ }
797
+ if (state !== oauthState) {
798
+ cleanup();
799
+ rejectOnce(new Error('OAuth state mismatch - possible CSRF attack'));
800
+ return;
801
+ }
802
+ logMCPDebug(serverName, `Received auth code via manual callback URL`);
803
+ cleanup();
804
+ resolveOnce(code);
805
+ }
806
+ catch {
807
+ // Invalid URL, ignore so the user can try again
808
+ }
809
+ });
810
+ }
811
+ server = createServer((req, res) => {
812
+ const parsedUrl = parse(req.url || '', true);
813
+ if (parsedUrl.pathname === '/callback') {
814
+ const code = parsedUrl.query.code;
815
+ const state = parsedUrl.query.state;
816
+ const error = parsedUrl.query.error;
817
+ const errorDescription = parsedUrl.query.error_description;
818
+ const errorUri = parsedUrl.query.error_uri;
819
+ // Validate OAuth state to prevent CSRF attacks
820
+ if (!error && state !== oauthState) {
821
+ res.writeHead(400, { 'Content-Type': 'text/html' });
822
+ res.end(`<h1>Authentication Error</h1><p>Invalid state parameter. Please try again.</p><p>You can close this window.</p>`);
823
+ cleanup();
824
+ rejectOnce(new Error('OAuth state mismatch - possible CSRF attack'));
825
+ return;
826
+ }
827
+ if (error) {
828
+ res.writeHead(200, { 'Content-Type': 'text/html' });
829
+ // Sanitize error messages to prevent XSS
830
+ const sanitizedError = xss(String(error));
831
+ const sanitizedErrorDescription = errorDescription
832
+ ? xss(String(errorDescription))
833
+ : '';
834
+ res.end(`<h1>Authentication Error</h1><p>${sanitizedError}: ${sanitizedErrorDescription}</p><p>You can close this window.</p>`);
835
+ cleanup();
836
+ let errorMessage = `OAuth error: ${error}`;
837
+ if (errorDescription) {
838
+ errorMessage += ` - ${errorDescription}`;
839
+ }
840
+ if (errorUri) {
841
+ errorMessage += ` (See: ${errorUri})`;
842
+ }
843
+ rejectOnce(new Error(errorMessage));
844
+ return;
845
+ }
846
+ if (code) {
847
+ res.writeHead(200, { 'Content-Type': 'text/html' });
848
+ res.end(`<h1>Authentication Successful</h1><p>You can close this window. Return to Context Code.</p>`);
849
+ cleanup();
850
+ resolveOnce(code);
851
+ }
852
+ }
853
+ });
854
+ server.on('error', (err) => {
855
+ cleanup();
856
+ if (err.code === 'EADDRINUSE') {
857
+ const findCmd = getPlatform() === 'windows'
858
+ ? `netstat -ano | findstr :${port}`
859
+ : `lsof -ti:${port} -sTCP:LISTEN`;
860
+ rejectOnce(new Error(`OAuth callback port ${port} is already in use — another process may be holding it. ` +
861
+ `Run \`${findCmd}\` to find it.`));
862
+ }
863
+ else {
864
+ rejectOnce(new Error(`OAuth callback server failed: ${err.message}`));
865
+ }
866
+ });
867
+ server.listen(port, '127.0.0.1', async () => {
868
+ try {
869
+ logMCPDebug(serverName, `Starting SDK auth`);
870
+ logMCPDebug(serverName, `Server URL: ${serverConfig.url}`);
871
+ // First call to start the auth flow - should redirect
872
+ // Pass the scope and resource_metadata from WWW-Authenticate header if available
873
+ const result = await sdkAuth(provider, {
874
+ serverUrl: serverConfig.url,
875
+ scope: wwwAuthParams.scope,
876
+ resourceMetadataUrl: wwwAuthParams.resourceMetadataUrl,
877
+ });
878
+ logMCPDebug(serverName, `Initial auth result: ${result}`);
879
+ if (result !== 'REDIRECT') {
880
+ logMCPDebug(serverName, `Unexpected auth result, expected REDIRECT: ${result}`);
881
+ }
882
+ }
883
+ catch (error) {
884
+ logMCPDebug(serverName, `SDK auth error: ${error}`);
885
+ cleanup();
886
+ rejectOnce(new Error(`SDK auth failed: ${errorMessage(error)}`));
887
+ }
888
+ });
889
+ // Don't let the callback server or timeout pin the event loop — if the UI
890
+ // component unmounts without aborting (e.g. parent intercepts Esc), we'd
891
+ // rather let the process exit than stay alive for 5 minutes holding the
892
+ // port. The abortSignal is the intended lifecycle management.
893
+ server.unref();
894
+ timeoutId = setTimeout((cleanup, rejectOnce) => {
895
+ cleanup();
896
+ rejectOnce(new Error('Authentication timeout'));
897
+ }, 5 * 60 * 1000, // 5 minutes
898
+ cleanup, rejectOnce);
899
+ timeoutId.unref();
900
+ });
901
+ authorizationCodeObtained = true;
902
+ // Now complete the auth flow with the received code
903
+ logMCPDebug(serverName, `Completing auth flow with authorization code`);
904
+ const result = await sdkAuth(provider, {
905
+ serverUrl: serverConfig.url,
906
+ authorizationCode,
907
+ resourceMetadataUrl: wwwAuthParams.resourceMetadataUrl,
908
+ });
909
+ logMCPDebug(serverName, `Auth result: ${result}`);
910
+ if (result === 'AUTHORIZED') {
911
+ // Debug: Check if tokens were properly saved
912
+ const savedTokens = await provider.tokens();
913
+ logMCPDebug(serverName, `Tokens after auth: ${savedTokens ? 'Present' : 'Missing'}`);
914
+ if (savedTokens) {
915
+ logMCPDebug(serverName, `Token access_token length: ${savedTokens.access_token?.length}`);
916
+ logMCPDebug(serverName, `Token expires_in: ${savedTokens.expires_in}`);
917
+ }
918
+ logEvent('tengu_mcp_oauth_flow_success', {
919
+ flowAttemptId: flowAttemptId,
920
+ transportType: serverConfig.type,
921
+ ...(getLoggingSafeMcpBaseUrl(serverConfig)
922
+ ? {
923
+ mcpServerBaseUrl: getLoggingSafeMcpBaseUrl(serverConfig),
924
+ }
925
+ : {}),
926
+ });
927
+ }
928
+ else {
929
+ throw new Error('Unexpected auth result: ' + result);
930
+ }
931
+ }
932
+ catch (error) {
933
+ logMCPDebug(serverName, `Error during auth completion: ${error}`);
934
+ // Determine failure reason for attribution telemetry. The try block covers
935
+ // port acquisition, the callback server, the redirect flow, and token
936
+ // exchange. Map known failure paths to stable reason codes.
937
+ let reason = 'unknown';
938
+ let oauthErrorCode;
939
+ let httpStatus;
940
+ if (error instanceof AuthenticationCancelledError) {
941
+ reason = 'cancelled';
942
+ }
943
+ else if (authorizationCodeObtained) {
944
+ reason = 'token_exchange_failed';
945
+ }
946
+ else {
947
+ const msg = errorMessage(error);
948
+ if (msg.includes('Authentication timeout')) {
949
+ reason = 'timeout';
950
+ }
951
+ else if (msg.includes('OAuth state mismatch')) {
952
+ reason = 'state_mismatch';
953
+ }
954
+ else if (msg.includes('OAuth error:')) {
955
+ reason = 'provider_denied';
956
+ }
957
+ else if (msg.includes('already in use') ||
958
+ msg.includes('EADDRINUSE') ||
959
+ msg.includes('callback server failed') ||
960
+ msg.includes('No available port')) {
961
+ reason = 'port_unavailable';
962
+ }
963
+ else if (msg.includes('SDK auth failed')) {
964
+ reason = 'sdk_auth_failed';
965
+ }
966
+ }
967
+ // sdkAuth uses native fetch and throws OAuthError subclasses (InvalidGrantError,
968
+ // ServerError, InvalidClientError, etc.) via parseErrorResponse. Extract the
969
+ // OAuth error code directly from the SDK error instance.
970
+ if (error instanceof OAuthError) {
971
+ oauthErrorCode = error.errorCode;
972
+ // SDK does not attach HTTP status as a property, but the fallback ServerError
973
+ // embeds it in the message as "HTTP {status}:" when the response body was
974
+ // unparseable. Best-effort extraction.
975
+ const statusMatch = error.message.match(/^HTTP (\d{3}):/);
976
+ if (statusMatch) {
977
+ httpStatus = Number(statusMatch[1]);
978
+ }
979
+ // If client not found, clear the stored client ID and suggest retry
980
+ if (error.errorCode === 'invalid_client' &&
981
+ error.message.includes('Client not found')) {
982
+ const storage = getSecureStorage();
983
+ const existingData = storage.read() || {};
984
+ const serverKey = getServerKey(serverName, serverConfig);
985
+ if (existingData.mcpOAuth?.[serverKey]) {
986
+ delete existingData.mcpOAuth[serverKey].clientId;
987
+ delete existingData.mcpOAuth[serverKey].clientSecret;
988
+ storage.update(existingData);
989
+ }
990
+ }
991
+ }
992
+ logEvent('tengu_mcp_oauth_flow_error', {
993
+ flowAttemptId: flowAttemptId,
994
+ reason: reason,
995
+ error_code: oauthErrorCode,
996
+ http_status: httpStatus?.toString(),
997
+ transportType: serverConfig.type,
998
+ ...(getLoggingSafeMcpBaseUrl(serverConfig)
999
+ ? {
1000
+ mcpServerBaseUrl: getLoggingSafeMcpBaseUrl(serverConfig),
1001
+ }
1002
+ : {}),
1003
+ });
1004
+ throw error;
1005
+ }
1006
+ }
1007
+ /**
1008
+ * Wraps fetch to detect 403 insufficient_scope responses and mark step-up
1009
+ * pending on the provider BEFORE the SDK's 403 handler calls auth(). Without
1010
+ * this, the SDK's authInternal sees refresh_token → refreshes (uselessly, since
1011
+ * RFC 6749 §6 forbids scope elevation via refresh) → returns 'AUTHORIZED' →
1012
+ * retry → 403 again → aborts with "Server returned 403 after trying upscoping",
1013
+ * never reaching redirectToAuthorization where step-up scope is persisted.
1014
+ * With this flag set, tokens() omits refresh_token so the SDK falls through
1015
+ * to the PKCE flow. See github.com/anthropics/claude-code/issues/28258.
1016
+ */
1017
+ export function wrapFetchWithStepUpDetection(baseFetch, provider) {
1018
+ return async (url, init) => {
1019
+ const response = await baseFetch(url, init);
1020
+ if (response.status === 403) {
1021
+ const wwwAuth = response.headers.get('WWW-Authenticate');
1022
+ if (wwwAuth?.includes('insufficient_scope')) {
1023
+ // Match both quoted and unquoted values (RFC 6750 §3 allows either).
1024
+ // Same pattern as the SDK's extractFieldFromWwwAuth.
1025
+ const match = wwwAuth.match(/scope=(?:"([^"]+)"|([^\s,]+))/);
1026
+ const scope = match?.[1] ?? match?.[2];
1027
+ if (scope) {
1028
+ provider.markStepUpPending(scope);
1029
+ }
1030
+ }
1031
+ }
1032
+ return response;
1033
+ };
1034
+ }
1035
+ export class ClaudeAuthProvider {
1036
+ serverName;
1037
+ serverConfig;
1038
+ redirectUri;
1039
+ handleRedirection;
1040
+ _codeVerifier;
1041
+ _authorizationUrl;
1042
+ _state;
1043
+ _scopes;
1044
+ _metadata;
1045
+ _refreshInProgress;
1046
+ _pendingStepUpScope;
1047
+ onAuthorizationUrlCallback;
1048
+ skipBrowserOpen;
1049
+ constructor(serverName, serverConfig, redirectUri = buildRedirectUri(), handleRedirection = false, onAuthorizationUrl, skipBrowserOpen) {
1050
+ this.serverName = serverName;
1051
+ this.serverConfig = serverConfig;
1052
+ this.redirectUri = redirectUri;
1053
+ this.handleRedirection = handleRedirection;
1054
+ this.onAuthorizationUrlCallback = onAuthorizationUrl;
1055
+ this.skipBrowserOpen = skipBrowserOpen ?? false;
1056
+ }
1057
+ get redirectUrl() {
1058
+ return this.redirectUri;
1059
+ }
1060
+ get authorizationUrl() {
1061
+ return this._authorizationUrl;
1062
+ }
1063
+ get clientMetadata() {
1064
+ const metadata = {
1065
+ client_name: `Context Code (${this.serverName})`,
1066
+ redirect_uris: [this.redirectUri],
1067
+ grant_types: ['authorization_code', 'refresh_token'],
1068
+ response_types: ['code'],
1069
+ token_endpoint_auth_method: 'none', // Public client
1070
+ };
1071
+ // Include scope from metadata if available
1072
+ const metadataScope = getScopeFromMetadata(this._metadata);
1073
+ if (metadataScope) {
1074
+ metadata.scope = metadataScope;
1075
+ logMCPDebug(this.serverName, `Using scope from metadata: ${metadata.scope}`);
1076
+ }
1077
+ return metadata;
1078
+ }
1079
+ /**
1080
+ * CIMD (SEP-991): URL-based client_id. When the auth server advertises
1081
+ * client_id_metadata_document_supported: true, the SDK uses this URL as the
1082
+ * client_id instead of performing Dynamic Client Registration.
1083
+ * Override via MCP_OAUTH_CLIENT_METADATA_URL env var (e.g. for testing, FedStart).
1084
+ */
1085
+ get clientMetadataUrl() {
1086
+ const override = process.env.MCP_OAUTH_CLIENT_METADATA_URL;
1087
+ if (override) {
1088
+ logMCPDebug(this.serverName, `Using CIMD URL from env: ${override}`);
1089
+ return override;
1090
+ }
1091
+ return MCP_CLIENT_METADATA_URL;
1092
+ }
1093
+ setMetadata(metadata) {
1094
+ this._metadata = metadata;
1095
+ }
1096
+ /**
1097
+ * Called by the fetch wrapper when a 403 insufficient_scope response is
1098
+ * detected. Setting this causes tokens() to omit refresh_token, forcing
1099
+ * the SDK's authInternal to skip its (useless) refresh path and fall through
1100
+ * to startAuthorization → redirectToAuthorization → step-up persistence.
1101
+ * RFC 6749 §6 forbids scope elevation via refresh, so refreshing would just
1102
+ * return the same-scoped token and the retry would 403 again.
1103
+ */
1104
+ markStepUpPending(scope) {
1105
+ this._pendingStepUpScope = scope;
1106
+ logMCPDebug(this.serverName, `Marked step-up pending: ${scope}`);
1107
+ }
1108
+ async state() {
1109
+ // Generate state if not already generated for this instance
1110
+ if (!this._state) {
1111
+ this._state = randomBytes(32).toString('base64url');
1112
+ logMCPDebug(this.serverName, 'Generated new OAuth state');
1113
+ }
1114
+ return this._state;
1115
+ }
1116
+ async clientInformation() {
1117
+ const storage = getSecureStorage();
1118
+ const data = storage.read();
1119
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1120
+ // Check session credentials first (from DCR or previous auth)
1121
+ const storedInfo = data?.mcpOAuth?.[serverKey];
1122
+ if (storedInfo?.clientId) {
1123
+ logMCPDebug(this.serverName, `Found client info`);
1124
+ return {
1125
+ client_id: storedInfo.clientId,
1126
+ client_secret: storedInfo.clientSecret,
1127
+ };
1128
+ }
1129
+ // Fallback: pre-configured client ID from server config
1130
+ const configClientId = this.serverConfig.oauth?.clientId;
1131
+ if (configClientId) {
1132
+ const clientConfig = data?.mcpOAuthClientConfig?.[serverKey];
1133
+ logMCPDebug(this.serverName, `Using pre-configured client ID`);
1134
+ return {
1135
+ client_id: configClientId,
1136
+ client_secret: clientConfig?.clientSecret,
1137
+ };
1138
+ }
1139
+ // If we don't have stored client info, return undefined to trigger registration
1140
+ logMCPDebug(this.serverName, `No client info found`);
1141
+ return undefined;
1142
+ }
1143
+ async saveClientInformation(clientInformation) {
1144
+ const storage = getSecureStorage();
1145
+ const existingData = storage.read() || {};
1146
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1147
+ const updatedData = {
1148
+ ...existingData,
1149
+ mcpOAuth: {
1150
+ ...existingData.mcpOAuth,
1151
+ [serverKey]: {
1152
+ ...existingData.mcpOAuth?.[serverKey],
1153
+ serverName: this.serverName,
1154
+ serverUrl: this.serverConfig.url,
1155
+ clientId: clientInformation.client_id,
1156
+ clientSecret: clientInformation.client_secret,
1157
+ // Provide default values for required fields if not present
1158
+ accessToken: existingData.mcpOAuth?.[serverKey]?.accessToken || '',
1159
+ expiresAt: existingData.mcpOAuth?.[serverKey]?.expiresAt || 0,
1160
+ },
1161
+ },
1162
+ };
1163
+ storage.update(updatedData);
1164
+ }
1165
+ async tokens() {
1166
+ // Cross-process token changes (another CC instance refreshed or invalidated)
1167
+ // are picked up via the keychain cache TTL (see macOsKeychainStorage.ts).
1168
+ // In-process writes already invalidate the cache via storage.update().
1169
+ // We do NOT clearKeychainCache() here — tokens() is called by the MCP SDK's
1170
+ // _commonHeaders on every request, and forcing a cache miss would trigger
1171
+ // a blocking spawnSync(`security find-generic-password`) 30-40x/sec.
1172
+ // See CPU profile: spawnSync was 7.2% of total CPU after PR #19436.
1173
+ const storage = getSecureStorage();
1174
+ const data = await storage.readAsync();
1175
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1176
+ const tokenData = data?.mcpOAuth?.[serverKey];
1177
+ // XAA: a cached id_token plays the same UX role as a refresh_token — run
1178
+ // the silent exchange to get a fresh access_token without a browser. The
1179
+ // id_token does expire (we re-acquire via `xaa login` when it does); the
1180
+ // point is that while it's valid, re-auth is zero-interaction.
1181
+ //
1182
+ // Only fire when we don't have a refresh_token. If the AS returned one,
1183
+ // the normal refresh path (below) is cheaper — 1 request vs the 4-request
1184
+ // XAA chain. If that refresh is revoked, refreshAuthorization() clears it
1185
+ // (invalidateCredentials('tokens')), and the next tokens() falls through
1186
+ // to here.
1187
+ //
1188
+ // Fires on:
1189
+ // - never authed (!tokenData) → first connect, auto-auth
1190
+ // - SDK partial write {accessToken:''} → stale from past session
1191
+ // - expired/expiring, no refresh_token → proactive XAA re-auth
1192
+ //
1193
+ // No special-casing of {accessToken:'', expiresAt:0}. Yes, SDK auth()
1194
+ // writes that mid-flow (saveClientInformation defaults). But with this
1195
+ // auto-auth branch, the *first* tokens() call — before auth() writes
1196
+ // anything — fires xaaRefresh. If id_token is cached, SDK short-circuits
1197
+ // there and never reaches the write. If id_token isn't cached, xaaRefresh
1198
+ // returns undefined in ~1 keychain read, auth() proceeds, writes the
1199
+ // marker, calls tokens() again, xaaRefresh fails again identically.
1200
+ // Harmless redundancy, not a wasted exchange. And guarding on `!==''`
1201
+ // permanently bricks auto-auth when a *prior* session left that marker
1202
+ // in keychain — real bug seen with xaa.dev.
1203
+ //
1204
+ // xaaRefresh() internally short-circuits to undefined when the id_token
1205
+ // isn't cached (or settings.xaaIdp is gone) → we fall through to the
1206
+ // existing needs-auth path → user runs `xaa login`.
1207
+ //
1208
+ if (isXaaEnabled() &&
1209
+ this.serverConfig.oauth?.xaa &&
1210
+ !tokenData?.refreshToken &&
1211
+ (!tokenData?.accessToken ||
1212
+ (tokenData.expiresAt - Date.now()) / 1000 <= 300)) {
1213
+ if (!this._refreshInProgress) {
1214
+ logMCPDebug(this.serverName, tokenData
1215
+ ? `XAA: access_token expiring, attempting silent exchange`
1216
+ : `XAA: no access_token yet, attempting silent exchange`);
1217
+ this._refreshInProgress = this.xaaRefresh().finally(() => {
1218
+ this._refreshInProgress = undefined;
1219
+ });
1220
+ }
1221
+ try {
1222
+ const refreshed = await this._refreshInProgress;
1223
+ if (refreshed)
1224
+ return refreshed;
1225
+ }
1226
+ catch (e) {
1227
+ logMCPDebug(this.serverName, `XAA silent exchange failed: ${errorMessage(e)}`);
1228
+ }
1229
+ // Fall through. Either id_token isn't cached (xaaRefresh returned
1230
+ // undefined) or the exchange errored. Normal path below handles both:
1231
+ // !tokenData → undefined → 401 → needs-auth; expired → undefined → same.
1232
+ }
1233
+ if (!tokenData) {
1234
+ logMCPDebug(this.serverName, `No token data found`);
1235
+ return undefined;
1236
+ }
1237
+ // Check if token is expired
1238
+ const expiresIn = (tokenData.expiresAt - Date.now()) / 1000;
1239
+ // Step-up check: if a 403 insufficient_scope was detected and the current
1240
+ // token doesn't have the requested scope, omit refresh_token below so the
1241
+ // SDK skips refresh and falls through to the PKCE flow.
1242
+ const currentScopes = tokenData.scope?.split(' ') ?? [];
1243
+ const needsStepUp = this._pendingStepUpScope !== undefined &&
1244
+ this._pendingStepUpScope.split(' ').some(s => !currentScopes.includes(s));
1245
+ if (needsStepUp) {
1246
+ logMCPDebug(this.serverName, `Step-up pending (${this._pendingStepUpScope}), omitting refresh_token`);
1247
+ }
1248
+ // If token is expired and we don't have a refresh token, return undefined
1249
+ if (expiresIn <= 0 && !tokenData.refreshToken) {
1250
+ logMCPDebug(this.serverName, `Token expired without refresh token`);
1251
+ return undefined;
1252
+ }
1253
+ // If token is expired or about to expire (within 5 minutes) and we have a refresh token, refresh it proactively.
1254
+ // This proactive refresh is a UX improvement - it avoids the latency of a failed request followed by token refresh.
1255
+ // While MCP servers should return 401 for expired tokens (which triggers SDK-level refresh), proactively refreshing
1256
+ // before expiry provides a smoother user experience.
1257
+ // Skip when step-up is pending — refreshing can't elevate scope (RFC 6749 §6).
1258
+ if (expiresIn <= 300 && tokenData.refreshToken && !needsStepUp) {
1259
+ // Reuse existing refresh promise if one is in progress to prevent concurrent refreshes
1260
+ if (!this._refreshInProgress) {
1261
+ logMCPDebug(this.serverName, `Token expires in ${Math.floor(expiresIn)}s, attempting proactive refresh`);
1262
+ this._refreshInProgress = this.refreshAuthorization(tokenData.refreshToken).finally(() => {
1263
+ this._refreshInProgress = undefined;
1264
+ });
1265
+ }
1266
+ else {
1267
+ logMCPDebug(this.serverName, `Token refresh already in progress, reusing existing promise`);
1268
+ }
1269
+ try {
1270
+ const refreshed = await this._refreshInProgress;
1271
+ if (refreshed) {
1272
+ logMCPDebug(this.serverName, `Token refreshed successfully`);
1273
+ return refreshed;
1274
+ }
1275
+ logMCPDebug(this.serverName, `Token refresh failed, returning current tokens`);
1276
+ }
1277
+ catch (error) {
1278
+ logMCPDebug(this.serverName, `Token refresh error: ${errorMessage(error)}`);
1279
+ }
1280
+ }
1281
+ // Return current tokens (may be expired if refresh failed or not needed yet)
1282
+ const tokens = {
1283
+ access_token: tokenData.accessToken,
1284
+ refresh_token: needsStepUp ? undefined : tokenData.refreshToken,
1285
+ expires_in: expiresIn,
1286
+ scope: tokenData.scope,
1287
+ token_type: 'Bearer',
1288
+ };
1289
+ logMCPDebug(this.serverName, `Returning tokens`);
1290
+ logMCPDebug(this.serverName, `Token length: ${tokens.access_token?.length}`);
1291
+ logMCPDebug(this.serverName, `Has refresh token: ${!!tokens.refresh_token}`);
1292
+ logMCPDebug(this.serverName, `Expires in: ${Math.floor(expiresIn)}s`);
1293
+ return tokens;
1294
+ }
1295
+ async saveTokens(tokens) {
1296
+ this._pendingStepUpScope = undefined;
1297
+ const storage = getSecureStorage();
1298
+ const existingData = storage.read() || {};
1299
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1300
+ logMCPDebug(this.serverName, `Saving tokens`);
1301
+ logMCPDebug(this.serverName, `Token expires in: ${tokens.expires_in}`);
1302
+ logMCPDebug(this.serverName, `Has refresh token: ${!!tokens.refresh_token}`);
1303
+ const updatedData = {
1304
+ ...existingData,
1305
+ mcpOAuth: {
1306
+ ...existingData.mcpOAuth,
1307
+ [serverKey]: {
1308
+ ...existingData.mcpOAuth?.[serverKey],
1309
+ serverName: this.serverName,
1310
+ serverUrl: this.serverConfig.url,
1311
+ accessToken: tokens.access_token,
1312
+ refreshToken: tokens.refresh_token,
1313
+ expiresAt: Date.now() + (tokens.expires_in || 3600) * 1000,
1314
+ scope: tokens.scope,
1315
+ },
1316
+ },
1317
+ };
1318
+ storage.update(updatedData);
1319
+ }
1320
+ /**
1321
+ * XAA silent refresh: cached id_token → Layer-2 exchange → new access_token.
1322
+ * No browser.
1323
+ *
1324
+ * Returns undefined if the id_token is gone from cache — caller treats this
1325
+ * as needs-interactive-reauth (transport will 401, CC surfaces it).
1326
+ *
1327
+ * On exchange failure, clears the id_token cache so the next interactive
1328
+ * auth does a fresh IdP login (the cached id_token is likely stale/revoked).
1329
+ *
1330
+ * TODO(xaa-ga): add cross-process lockfile before GA. `_refreshInProgress`
1331
+ * only dedupes within one process — two CC instances with expiring tokens
1332
+ * both fire the full 4-request XAA chain and race on storage.update().
1333
+ * Unlike inc-4829 the id_token is not single-use so both access_tokens
1334
+ * stay valid (wasted round-trips + keychain write race, not brickage),
1335
+ * but this is the shape CLAUDE.md flags under "Token/auth caching across
1336
+ * process boundaries". Mirror refreshAuthorization()'s lockfile pattern.
1337
+ */
1338
+ async xaaRefresh() {
1339
+ const idp = getXaaIdpSettings();
1340
+ if (!idp)
1341
+ return undefined; // config was removed mid-session
1342
+ const idToken = getCachedIdpIdToken(idp.issuer);
1343
+ if (!idToken) {
1344
+ logMCPDebug(this.serverName, 'XAA: id_token not cached, needs interactive re-auth');
1345
+ return undefined;
1346
+ }
1347
+ const clientId = this.serverConfig.oauth?.clientId;
1348
+ const clientConfig = getMcpClientConfig(this.serverName, this.serverConfig);
1349
+ if (!clientId || !clientConfig?.clientSecret) {
1350
+ logMCPDebug(this.serverName, 'XAA: missing clientId or clientSecret in config — skipping silent refresh');
1351
+ return undefined; // shouldn't happen if `mcp add` was correct
1352
+ }
1353
+ const idpClientSecret = getIdpClientSecret(idp.issuer);
1354
+ // Discover IdP token endpoint. Could cache (fetchCache.ts already
1355
+ // caches /.well-known/ requests), but OIDC metadata is cheap + idempotent.
1356
+ // xaaRefresh is the silent tokens() path — soft-fail to undefined so the
1357
+ // caller falls through to needs-authentication instead of throwing mid-connect.
1358
+ let oidc;
1359
+ try {
1360
+ oidc = await discoverOidc(idp.issuer);
1361
+ }
1362
+ catch (e) {
1363
+ logMCPDebug(this.serverName, `XAA: OIDC discovery failed in silent refresh: ${errorMessage(e)}`);
1364
+ return undefined;
1365
+ }
1366
+ try {
1367
+ const tokens = await performCrossAppAccess(this.serverConfig.url, {
1368
+ clientId,
1369
+ clientSecret: clientConfig.clientSecret,
1370
+ idpClientId: idp.clientId,
1371
+ idpClientSecret,
1372
+ idpIdToken: idToken,
1373
+ idpTokenEndpoint: oidc.token_endpoint,
1374
+ }, this.serverName);
1375
+ // Write directly (not via saveTokens) so clientId + clientSecret land in
1376
+ // storage even when this is the first write for serverKey. saveTokens
1377
+ // only spreads existing data; if no prior performMCPXaaAuth ran,
1378
+ // revokeServerTokens would later read tokenData.clientId as undefined
1379
+ // and send a client_id-less RFC 7009 request that strict ASes reject.
1380
+ const storage = getSecureStorage();
1381
+ const existingData = storage.read() || {};
1382
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1383
+ const prev = existingData.mcpOAuth?.[serverKey];
1384
+ storage.update({
1385
+ ...existingData,
1386
+ mcpOAuth: {
1387
+ ...existingData.mcpOAuth,
1388
+ [serverKey]: {
1389
+ ...prev,
1390
+ serverName: this.serverName,
1391
+ serverUrl: this.serverConfig.url,
1392
+ accessToken: tokens.access_token,
1393
+ refreshToken: tokens.refresh_token ?? prev?.refreshToken,
1394
+ expiresAt: Date.now() + (tokens.expires_in || 3600) * 1000,
1395
+ scope: tokens.scope,
1396
+ clientId,
1397
+ clientSecret: clientConfig.clientSecret,
1398
+ discoveryState: {
1399
+ authorizationServerUrl: tokens.authorizationServerUrl,
1400
+ },
1401
+ },
1402
+ },
1403
+ });
1404
+ return {
1405
+ access_token: tokens.access_token,
1406
+ token_type: 'Bearer',
1407
+ expires_in: tokens.expires_in,
1408
+ scope: tokens.scope,
1409
+ refresh_token: tokens.refresh_token,
1410
+ };
1411
+ }
1412
+ catch (e) {
1413
+ if (e instanceof XaaTokenExchangeError && e.shouldClearIdToken) {
1414
+ clearIdpIdToken(idp.issuer);
1415
+ logMCPDebug(this.serverName, 'XAA: cleared id_token after exchange failure');
1416
+ }
1417
+ throw e;
1418
+ }
1419
+ }
1420
+ async redirectToAuthorization(authorizationUrl) {
1421
+ // Store the authorization URL
1422
+ this._authorizationUrl = authorizationUrl.toString();
1423
+ // Extract and store scopes from the authorization URL for later use in token exchange
1424
+ const scopes = authorizationUrl.searchParams.get('scope');
1425
+ logMCPDebug(this.serverName, `Authorization URL: ${redactSensitiveUrlParams(authorizationUrl.toString())}`);
1426
+ logMCPDebug(this.serverName, `Scopes in URL: ${scopes || 'NOT FOUND'}`);
1427
+ if (scopes) {
1428
+ this._scopes = scopes;
1429
+ logMCPDebug(this.serverName, `Captured scopes from authorization URL: ${scopes}`);
1430
+ }
1431
+ else {
1432
+ // If no scope in URL, try to get it from metadata
1433
+ const metadataScope = getScopeFromMetadata(this._metadata);
1434
+ if (metadataScope) {
1435
+ this._scopes = metadataScope;
1436
+ logMCPDebug(this.serverName, `Using scopes from metadata: ${metadataScope}`);
1437
+ }
1438
+ else {
1439
+ logMCPDebug(this.serverName, `No scopes available from URL or metadata`);
1440
+ }
1441
+ }
1442
+ // Persist scope for step-up auth: only when the transport-attached provider
1443
+ // (handleRedirection=false) receives a step-up 401. The SDK calls auth()
1444
+ // which calls redirectToAuthorization with the new scope. We persist it
1445
+ // so the next performMCPOAuthFlow can use it without an extra probe request.
1446
+ // Guard with !handleRedirection to avoid persisting during normal auth flows
1447
+ // (where the scope may come from metadata scopes_supported rather than a 401).
1448
+ if (this._scopes && !this.handleRedirection) {
1449
+ const storage = getSecureStorage();
1450
+ const existingData = storage.read() || {};
1451
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1452
+ const existing = existingData.mcpOAuth?.[serverKey];
1453
+ if (existing) {
1454
+ existing.stepUpScope = this._scopes;
1455
+ storage.update(existingData);
1456
+ logMCPDebug(this.serverName, `Persisted step-up scope: ${this._scopes}`);
1457
+ }
1458
+ }
1459
+ if (!this.handleRedirection) {
1460
+ logMCPDebug(this.serverName, `Redirection handling is disabled, skipping redirect`);
1461
+ return;
1462
+ }
1463
+ // Validate URL scheme for security
1464
+ const urlString = authorizationUrl.toString();
1465
+ if (!urlString.startsWith('http://') && !urlString.startsWith('https://')) {
1466
+ throw new Error('Invalid authorization URL: must use http:// or https:// scheme');
1467
+ }
1468
+ logMCPDebug(this.serverName, `Redirecting to authorization URL`);
1469
+ const redactedUrl = redactSensitiveUrlParams(urlString);
1470
+ logMCPDebug(this.serverName, `Authorization URL: ${redactedUrl}`);
1471
+ // Notify the UI about the authorization URL BEFORE opening the browser,
1472
+ // so users can see the URL as a fallback if the browser fails to open
1473
+ if (this.onAuthorizationUrlCallback) {
1474
+ this.onAuthorizationUrlCallback(urlString);
1475
+ }
1476
+ if (!this.skipBrowserOpen) {
1477
+ logMCPDebug(this.serverName, `Opening authorization URL: ${redactedUrl}`);
1478
+ const success = await openBrowser(urlString);
1479
+ if (!success) {
1480
+ logMCPDebug(this.serverName, `Browser didn't open automatically. URL is shown in UI.`);
1481
+ }
1482
+ }
1483
+ else {
1484
+ logMCPDebug(this.serverName, `Skipping browser open (skipBrowserOpen=true). URL: ${redactedUrl}`);
1485
+ }
1486
+ }
1487
+ async saveCodeVerifier(codeVerifier) {
1488
+ logMCPDebug(this.serverName, `Saving code verifier`);
1489
+ this._codeVerifier = codeVerifier;
1490
+ }
1491
+ async codeVerifier() {
1492
+ if (!this._codeVerifier) {
1493
+ logMCPDebug(this.serverName, `No code verifier saved`);
1494
+ throw new Error('No code verifier saved');
1495
+ }
1496
+ logMCPDebug(this.serverName, `Returning code verifier`);
1497
+ return this._codeVerifier;
1498
+ }
1499
+ async invalidateCredentials(scope) {
1500
+ const storage = getSecureStorage();
1501
+ const existingData = storage.read();
1502
+ if (!existingData?.mcpOAuth)
1503
+ return;
1504
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1505
+ const tokenData = existingData.mcpOAuth[serverKey];
1506
+ if (!tokenData)
1507
+ return;
1508
+ switch (scope) {
1509
+ case 'all':
1510
+ delete existingData.mcpOAuth[serverKey];
1511
+ break;
1512
+ case 'client':
1513
+ tokenData.clientId = undefined;
1514
+ tokenData.clientSecret = undefined;
1515
+ break;
1516
+ case 'tokens':
1517
+ tokenData.accessToken = '';
1518
+ tokenData.refreshToken = undefined;
1519
+ tokenData.expiresAt = 0;
1520
+ break;
1521
+ case 'verifier':
1522
+ this._codeVerifier = undefined;
1523
+ return;
1524
+ case 'discovery':
1525
+ tokenData.discoveryState = undefined;
1526
+ tokenData.stepUpScope = undefined;
1527
+ break;
1528
+ }
1529
+ storage.update(existingData);
1530
+ logMCPDebug(this.serverName, `Invalidated credentials (scope: ${scope})`);
1531
+ }
1532
+ async saveDiscoveryState(state) {
1533
+ const storage = getSecureStorage();
1534
+ const existingData = storage.read() || {};
1535
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1536
+ logMCPDebug(this.serverName, `Saving discovery state (authServer: ${state.authorizationServerUrl})`);
1537
+ // Persist only the URLs, NOT the full metadata blobs.
1538
+ // authorizationServerMetadata alone is ~1.5-2KB per MCP server (every
1539
+ // grant type, PKCE method, endpoint the IdP supports). On macOS the
1540
+ // keychain write goes through `security -i` which has a 4096-byte stdin
1541
+ // line limit — with hex encoding that's ~2013 bytes of JSON total. Two
1542
+ // OAuth MCP servers persisting full metadata overflows it, corrupting
1543
+ // the credential store (#30337). The SDK re-fetches missing metadata
1544
+ // with one HTTP GET on the next auth — see node_modules/.../auth.js
1545
+ // `cachedState.authorizationServerMetadata ?? await discover...`.
1546
+ const updatedData = {
1547
+ ...existingData,
1548
+ mcpOAuth: {
1549
+ ...existingData.mcpOAuth,
1550
+ [serverKey]: {
1551
+ ...existingData.mcpOAuth?.[serverKey],
1552
+ serverName: this.serverName,
1553
+ serverUrl: this.serverConfig.url,
1554
+ accessToken: existingData.mcpOAuth?.[serverKey]?.accessToken || '',
1555
+ expiresAt: existingData.mcpOAuth?.[serverKey]?.expiresAt || 0,
1556
+ discoveryState: {
1557
+ authorizationServerUrl: state.authorizationServerUrl,
1558
+ resourceMetadataUrl: state.resourceMetadataUrl,
1559
+ },
1560
+ },
1561
+ },
1562
+ };
1563
+ storage.update(updatedData);
1564
+ }
1565
+ async discoveryState() {
1566
+ const storage = getSecureStorage();
1567
+ const data = storage.read();
1568
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1569
+ const cached = data?.mcpOAuth?.[serverKey]?.discoveryState;
1570
+ if (cached?.authorizationServerUrl) {
1571
+ logMCPDebug(this.serverName, `Returning cached discovery state (authServer: ${cached.authorizationServerUrl})`);
1572
+ return {
1573
+ authorizationServerUrl: cached.authorizationServerUrl,
1574
+ resourceMetadataUrl: cached.resourceMetadataUrl,
1575
+ resourceMetadata: cached.resourceMetadata,
1576
+ authorizationServerMetadata: cached.authorizationServerMetadata,
1577
+ };
1578
+ }
1579
+ // Check config hint for direct metadata URL
1580
+ const metadataUrl = this.serverConfig.oauth?.authServerMetadataUrl;
1581
+ if (metadataUrl) {
1582
+ logMCPDebug(this.serverName, `Fetching metadata from configured URL: ${metadataUrl}`);
1583
+ try {
1584
+ const metadata = await fetchAuthServerMetadata(this.serverName, this.serverConfig.url, metadataUrl);
1585
+ if (metadata) {
1586
+ return {
1587
+ authorizationServerUrl: metadata.issuer,
1588
+ authorizationServerMetadata: metadata,
1589
+ };
1590
+ }
1591
+ }
1592
+ catch (error) {
1593
+ logMCPDebug(this.serverName, `Failed to fetch from configured metadata URL: ${errorMessage(error)}`);
1594
+ }
1595
+ }
1596
+ return undefined;
1597
+ }
1598
+ async refreshAuthorization(refreshToken) {
1599
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1600
+ const claudeDir = getClaudeConfigHomeDir();
1601
+ await mkdir(claudeDir, { recursive: true });
1602
+ const sanitizedKey = serverKey.replace(/[^a-zA-Z0-9]/g, '_');
1603
+ const lockfilePath = join(claudeDir, `mcp-refresh-${sanitizedKey}.lock`);
1604
+ let release;
1605
+ for (let retry = 0; retry < MAX_LOCK_RETRIES; retry++) {
1606
+ try {
1607
+ logMCPDebug(this.serverName, `Acquiring refresh lock (attempt ${retry + 1})`);
1608
+ release = await lockfile.lock(lockfilePath, {
1609
+ realpath: false,
1610
+ onCompromised: () => {
1611
+ logMCPDebug(this.serverName, `Refresh lock was compromised`);
1612
+ },
1613
+ });
1614
+ logMCPDebug(this.serverName, `Acquired refresh lock`);
1615
+ break;
1616
+ }
1617
+ catch (e) {
1618
+ const code = getErrnoCode(e);
1619
+ if (code === 'ELOCKED') {
1620
+ logMCPDebug(this.serverName, `Refresh lock held by another process, waiting (attempt ${retry + 1}/${MAX_LOCK_RETRIES})`);
1621
+ await sleep(1000 + Math.random() * 1000);
1622
+ continue;
1623
+ }
1624
+ logMCPDebug(this.serverName, `Failed to acquire refresh lock: ${code}, proceeding without lock`);
1625
+ break;
1626
+ }
1627
+ }
1628
+ if (!release) {
1629
+ logMCPDebug(this.serverName, `Could not acquire refresh lock after ${MAX_LOCK_RETRIES} retries, proceeding without lock`);
1630
+ }
1631
+ try {
1632
+ // Re-read tokens after acquiring lock — another process may have refreshed
1633
+ clearKeychainCache();
1634
+ const storage = getSecureStorage();
1635
+ const data = storage.read();
1636
+ const tokenData = data?.mcpOAuth?.[serverKey];
1637
+ if (tokenData) {
1638
+ const expiresIn = (tokenData.expiresAt - Date.now()) / 1000;
1639
+ if (expiresIn > 300) {
1640
+ logMCPDebug(this.serverName, `Another process already refreshed tokens (expires in ${Math.floor(expiresIn)}s)`);
1641
+ return {
1642
+ access_token: tokenData.accessToken,
1643
+ refresh_token: tokenData.refreshToken,
1644
+ expires_in: expiresIn,
1645
+ scope: tokenData.scope,
1646
+ token_type: 'Bearer',
1647
+ };
1648
+ }
1649
+ // Use the freshest refresh token from storage
1650
+ if (tokenData.refreshToken) {
1651
+ refreshToken = tokenData.refreshToken;
1652
+ }
1653
+ }
1654
+ return await this._doRefresh(refreshToken);
1655
+ }
1656
+ finally {
1657
+ if (release) {
1658
+ try {
1659
+ await release();
1660
+ logMCPDebug(this.serverName, `Released refresh lock`);
1661
+ }
1662
+ catch {
1663
+ logMCPDebug(this.serverName, `Failed to release refresh lock`);
1664
+ }
1665
+ }
1666
+ }
1667
+ }
1668
+ async _doRefresh(refreshToken) {
1669
+ const MAX_ATTEMPTS = 3;
1670
+ const mcpServerBaseUrl = getLoggingSafeMcpBaseUrl(this.serverConfig);
1671
+ const emitRefreshEvent = (outcome, reason) => {
1672
+ logEvent(outcome === 'success'
1673
+ ? 'tengu_mcp_oauth_refresh_success'
1674
+ : 'tengu_mcp_oauth_refresh_failure', {
1675
+ transportType: this.serverConfig
1676
+ .type,
1677
+ ...(mcpServerBaseUrl
1678
+ ? {
1679
+ mcpServerBaseUrl: mcpServerBaseUrl,
1680
+ }
1681
+ : {}),
1682
+ ...(reason
1683
+ ? {
1684
+ reason: reason,
1685
+ }
1686
+ : {}),
1687
+ });
1688
+ };
1689
+ for (let attempt = 1; attempt <= MAX_ATTEMPTS; attempt++) {
1690
+ try {
1691
+ logMCPDebug(this.serverName, `Starting token refresh`);
1692
+ const authFetch = createAuthFetch();
1693
+ // Reuse cached metadata from the initial OAuth flow if available,
1694
+ // since metadata (token endpoint URL, etc.) is static per auth server.
1695
+ // Priority:
1696
+ // 1. In-memory cache (same-session refreshes)
1697
+ // 2. Persisted discovery state from initial auth (cross-session) —
1698
+ // avoids re-running RFC 9728 discovery on every refresh.
1699
+ // 3. Full RFC 9728 → RFC 8414 re-discovery via fetchAuthServerMetadata.
1700
+ let metadata = this._metadata;
1701
+ if (!metadata) {
1702
+ const cached = await this.discoveryState();
1703
+ if (cached?.authorizationServerMetadata) {
1704
+ logMCPDebug(this.serverName, `Using persisted auth server metadata for refresh`);
1705
+ metadata = cached.authorizationServerMetadata;
1706
+ }
1707
+ else if (cached?.authorizationServerUrl) {
1708
+ logMCPDebug(this.serverName, `Re-discovering metadata from persisted auth server URL: ${cached.authorizationServerUrl}`);
1709
+ metadata = await discoverAuthorizationServerMetadata(cached.authorizationServerUrl, { fetchFn: authFetch });
1710
+ }
1711
+ }
1712
+ if (!metadata) {
1713
+ metadata = await fetchAuthServerMetadata(this.serverName, this.serverConfig.url, this.serverConfig.oauth?.authServerMetadataUrl, authFetch);
1714
+ }
1715
+ if (!metadata) {
1716
+ logMCPDebug(this.serverName, `Failed to discover OAuth metadata`);
1717
+ emitRefreshEvent('failure', 'metadata_discovery_failed');
1718
+ return undefined;
1719
+ }
1720
+ // Cache for future refreshes
1721
+ this._metadata = metadata;
1722
+ const clientInfo = await this.clientInformation();
1723
+ if (!clientInfo) {
1724
+ logMCPDebug(this.serverName, `No client information available`);
1725
+ emitRefreshEvent('failure', 'no_client_info');
1726
+ return undefined;
1727
+ }
1728
+ const newTokens = await sdkRefreshAuthorization(new URL(this.serverConfig.url), {
1729
+ metadata,
1730
+ clientInformation: clientInfo,
1731
+ refreshToken,
1732
+ resource: new URL(this.serverConfig.url),
1733
+ fetchFn: authFetch,
1734
+ });
1735
+ if (newTokens) {
1736
+ logMCPDebug(this.serverName, `Token refresh successful`);
1737
+ await this.saveTokens(newTokens);
1738
+ emitRefreshEvent('success');
1739
+ return newTokens;
1740
+ }
1741
+ logMCPDebug(this.serverName, `Token refresh returned no tokens`);
1742
+ emitRefreshEvent('failure', 'no_tokens_returned');
1743
+ return undefined;
1744
+ }
1745
+ catch (error) {
1746
+ // Invalid grant means the refresh token itself is invalid/revoked/expired.
1747
+ // But another process may have already refreshed successfully — check first.
1748
+ if (error instanceof InvalidGrantError) {
1749
+ logMCPDebug(this.serverName, `Token refresh failed with invalid_grant: ${error.message}`);
1750
+ clearKeychainCache();
1751
+ const storage = getSecureStorage();
1752
+ const data = storage.read();
1753
+ const serverKey = getServerKey(this.serverName, this.serverConfig);
1754
+ const tokenData = data?.mcpOAuth?.[serverKey];
1755
+ if (tokenData) {
1756
+ const expiresIn = (tokenData.expiresAt - Date.now()) / 1000;
1757
+ if (expiresIn > 300) {
1758
+ logMCPDebug(this.serverName, `Another process refreshed tokens, using those`);
1759
+ // Not emitted as success: this process did not perform a
1760
+ // refresh, and the winning process already emitted its own
1761
+ // success event. Emitting here would double-count.
1762
+ return {
1763
+ access_token: tokenData.accessToken,
1764
+ refresh_token: tokenData.refreshToken,
1765
+ expires_in: expiresIn,
1766
+ scope: tokenData.scope,
1767
+ token_type: 'Bearer',
1768
+ };
1769
+ }
1770
+ }
1771
+ logMCPDebug(this.serverName, `No valid tokens in storage, clearing stored tokens`);
1772
+ await this.invalidateCredentials('tokens');
1773
+ emitRefreshEvent('failure', 'invalid_grant');
1774
+ return undefined;
1775
+ }
1776
+ // Retry on timeouts or transient server errors
1777
+ const isTimeoutError = error instanceof Error &&
1778
+ /timeout|timed out|etimedout|econnreset/i.test(error.message);
1779
+ const isTransientServerError = error instanceof ServerError ||
1780
+ error instanceof TemporarilyUnavailableError ||
1781
+ error instanceof TooManyRequestsError;
1782
+ const isRetryable = isTimeoutError || isTransientServerError;
1783
+ if (!isRetryable || attempt >= MAX_ATTEMPTS) {
1784
+ logMCPDebug(this.serverName, `Token refresh failed: ${errorMessage(error)}`);
1785
+ emitRefreshEvent('failure', isRetryable ? 'transient_retries_exhausted' : 'request_failed');
1786
+ return undefined;
1787
+ }
1788
+ const delayMs = 1000 * Math.pow(2, attempt - 1); // 1s, 2s, 4s
1789
+ logMCPDebug(this.serverName, `Token refresh failed, retrying in ${delayMs}ms (attempt ${attempt}/${MAX_ATTEMPTS})`);
1790
+ await sleep(delayMs);
1791
+ }
1792
+ }
1793
+ return undefined;
1794
+ }
1795
+ }
1796
+ export async function readClientSecret() {
1797
+ const envSecret = process.env.MCP_CLIENT_SECRET;
1798
+ if (envSecret) {
1799
+ return envSecret;
1800
+ }
1801
+ if (!process.stdin.isTTY) {
1802
+ throw new Error('No TTY available to prompt for client secret. Set MCP_CLIENT_SECRET env var instead.');
1803
+ }
1804
+ return new Promise((resolve, reject) => {
1805
+ process.stderr.write('Enter OAuth client secret: ');
1806
+ process.stdin.setRawMode?.(true);
1807
+ let secret = '';
1808
+ const onData = (ch) => {
1809
+ const c = ch.toString();
1810
+ if (c === '\n' || c === '\r') {
1811
+ process.stdin.setRawMode?.(false);
1812
+ process.stdin.removeListener('data', onData);
1813
+ process.stderr.write('\n');
1814
+ resolve(secret);
1815
+ }
1816
+ else if (c === '\u0003') {
1817
+ process.stdin.setRawMode?.(false);
1818
+ process.stdin.removeListener('data', onData);
1819
+ reject(new Error('Cancelled'));
1820
+ }
1821
+ else if (c === '\u007F' || c === '\b') {
1822
+ secret = secret.slice(0, -1);
1823
+ }
1824
+ else {
1825
+ secret += c;
1826
+ }
1827
+ };
1828
+ process.stdin.on('data', onData);
1829
+ });
1830
+ }
1831
+ export function saveMcpClientSecret(serverName, serverConfig, clientSecret) {
1832
+ const storage = getSecureStorage();
1833
+ const existingData = storage.read() || {};
1834
+ const serverKey = getServerKey(serverName, serverConfig);
1835
+ storage.update({
1836
+ ...existingData,
1837
+ mcpOAuthClientConfig: {
1838
+ ...existingData.mcpOAuthClientConfig,
1839
+ [serverKey]: { clientSecret },
1840
+ },
1841
+ });
1842
+ }
1843
+ export function clearMcpClientConfig(serverName, serverConfig) {
1844
+ const storage = getSecureStorage();
1845
+ const existingData = storage.read();
1846
+ if (!existingData?.mcpOAuthClientConfig)
1847
+ return;
1848
+ const serverKey = getServerKey(serverName, serverConfig);
1849
+ if (existingData.mcpOAuthClientConfig[serverKey]) {
1850
+ delete existingData.mcpOAuthClientConfig[serverKey];
1851
+ storage.update(existingData);
1852
+ }
1853
+ }
1854
+ export function getMcpClientConfig(serverName, serverConfig) {
1855
+ const storage = getSecureStorage();
1856
+ const data = storage.read();
1857
+ const serverKey = getServerKey(serverName, serverConfig);
1858
+ return data?.mcpOAuthClientConfig?.[serverKey];
1859
+ }
1860
+ /**
1861
+ * Safely extracts scope information from AuthorizationServerMetadata.
1862
+ * The metadata can be either OAuthMetadata or OpenIdProviderDiscoveryMetadata,
1863
+ * and different providers use different fields for scope information.
1864
+ */
1865
+ function getScopeFromMetadata(metadata) {
1866
+ if (!metadata)
1867
+ return undefined;
1868
+ // Try 'scope' first (non-standard but used by some providers)
1869
+ if ('scope' in metadata && typeof metadata.scope === 'string') {
1870
+ return metadata.scope;
1871
+ }
1872
+ // Try 'default_scope' (non-standard but used by some providers)
1873
+ if ('default_scope' in metadata &&
1874
+ typeof metadata.default_scope === 'string') {
1875
+ return metadata.default_scope;
1876
+ }
1877
+ // Fall back to scopes_supported (standard OAuth 2.0 field)
1878
+ if (metadata.scopes_supported && Array.isArray(metadata.scopes_supported)) {
1879
+ return metadata.scopes_supported.join(' ');
1880
+ }
1881
+ return undefined;
1882
+ }