thaddeus 1.0.18 → 1.0.27

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 (2084) hide show
  1. package/package.json +14 -5
  2. package/src/QueryEngine.js +926 -0
  3. package/src/Task.js +49 -0
  4. package/src/Tool.js +61 -0
  5. package/src/assistant/gate.js +5 -0
  6. package/src/assistant/index.js +106 -0
  7. package/src/assistant/sessionHistory.js +145 -0
  8. package/src/bootstrap/state.js +1163 -0
  9. package/src/bridge/bridgeApi.js +304 -0
  10. package/src/bridge/bridgeConfig.js +39 -0
  11. package/src/bridge/bridgeDebug.js +73 -0
  12. package/src/bridge/bridgeEnabled.js +185 -0
  13. package/src/bridge/bridgeMain.js +2289 -0
  14. package/src/bridge/bridgeMessaging.js +353 -0
  15. package/src/bridge/bridgePermissionCallbacks.js +10 -0
  16. package/src/bridge/bridgePointer.js +175 -0
  17. package/src/bridge/bridgeStatusUtil.js +105 -0
  18. package/src/bridge/bridgeUI.js +411 -0
  19. package/src/bridge/capacityWake.js +35 -0
  20. package/src/bridge/codeSessionApi.js +111 -0
  21. package/src/bridge/createSession.js +273 -0
  22. package/src/bridge/debugUtils.js +115 -0
  23. package/src/bridge/envLessBridgeConfig.js +120 -0
  24. package/src/bridge/flushGate.js +65 -0
  25. package/src/bridge/inboundAttachments.js +152 -0
  26. package/src/bridge/inboundMessages.js +63 -0
  27. package/src/bridge/initReplBridge.js +431 -0
  28. package/src/bridge/jwtUtils.js +185 -0
  29. package/src/bridge/peerSessions.js +5 -0
  30. package/src/bridge/pollConfig.js +85 -0
  31. package/src/bridge/pollConfigDefaults.js +62 -0
  32. package/src/bridge/remoteBridgeCore.js +712 -0
  33. package/src/bridge/replBridge.js +1719 -0
  34. package/src/bridge/replBridgeHandle.js +30 -0
  35. package/src/bridge/replBridgeTransport.js +236 -0
  36. package/src/bridge/sessionIdCompat.js +56 -0
  37. package/src/bridge/sessionRunner.js +421 -0
  38. package/src/bridge/trustedDevice.js +170 -0
  39. package/src/bridge/types.js +9 -0
  40. package/src/bridge/webhookSanitizer.js +6 -0
  41. package/src/bridge/workSecret.js +99 -0
  42. package/src/buddy/CompanionSprite.js +348 -0
  43. package/src/buddy/companion.js +107 -0
  44. package/src/buddy/prompt.js +33 -0
  45. package/src/buddy/sprites.js +488 -0
  46. package/src/buddy/types.js +90 -0
  47. package/src/buddy/useBuddyNotification.js +85 -0
  48. package/src/cli/bg.js +17 -0
  49. package/src/cli/exit.js +30 -0
  50. package/src/cli/handlers/agents.js +55 -0
  51. package/src/cli/handlers/auth.js +249 -0
  52. package/src/cli/handlers/autoMode.js +128 -0
  53. package/src/cli/handlers/mcp.js +335 -0
  54. package/src/cli/handlers/plugins.js +634 -0
  55. package/src/cli/handlers/templateJobs.js +19 -0
  56. package/src/cli/handlers/util.js +76 -0
  57. package/src/cli/ndjsonSafeStringify.js +27 -0
  58. package/src/cli/print.js +4294 -0
  59. package/src/cli/remoteIO.js +208 -0
  60. package/src/cli/structuredIO.js +644 -0
  61. package/src/cli/transports/HybridTransport.js +233 -0
  62. package/src/cli/transports/SSETransport.js +538 -0
  63. package/src/cli/transports/SerialBatchEventUploader.js +224 -0
  64. package/src/cli/transports/WebSocketTransport.js +613 -0
  65. package/src/cli/transports/WorkerStateUploader.js +88 -0
  66. package/src/cli/transports/ccrClient.js +711 -0
  67. package/src/cli/transports/transportUtils.js +39 -0
  68. package/src/cli/update.js +314 -0
  69. package/src/commandCenter/launch.js +39 -0
  70. package/src/commandCenter/phoneApi.js +168 -0
  71. package/src/commandCenter/phoneStore.js +159 -0
  72. package/src/commandCenter/reactorBus.js +130 -0
  73. package/src/commandCenter/server.js +288 -0
  74. package/src/commandCenter/server.ts +42 -7
  75. package/src/commandCenter/tunnel.js +199 -0
  76. package/src/commands/add-dir/add-dir.js +121 -0
  77. package/src/commands/add-dir/index.js +8 -0
  78. package/src/commands/add-dir/validation.js +76 -0
  79. package/src/commands/advisor.js +88 -0
  80. package/src/commands/agents/agents.js +10 -0
  81. package/src/commands/agents/index.js +7 -0
  82. package/src/commands/agents-platform/index.js +2 -0
  83. package/src/commands/assistant/index.js +86 -0
  84. package/src/commands/backup/index.js +31 -0
  85. package/src/commands/branch/branch.js +205 -0
  86. package/src/commands/branch/index.js +11 -0
  87. package/src/commands/bridge/bridge.js +513 -0
  88. package/src/commands/bridge/index.js +22 -0
  89. package/src/commands/bridge-kick.js +179 -0
  90. package/src/commands/brief.js +89 -0
  91. package/src/commands/btw/btw.js +235 -0
  92. package/src/commands/btw/index.js +9 -0
  93. package/src/commands/buddy/buddy.js +100 -0
  94. package/src/commands/buddy/index.js +11 -0
  95. package/src/commands/chrome/chrome.js +291 -0
  96. package/src/commands/chrome/index.js +10 -0
  97. package/src/commands/clear/caches.js +116 -0
  98. package/src/commands/clear/clear.js +5 -0
  99. package/src/commands/clear/conversation.js +189 -0
  100. package/src/commands/clear/index.js +9 -0
  101. package/src/commands/color/color.js +58 -0
  102. package/src/commands/color/index.js +9 -0
  103. package/src/commands/commit-push-pr.js +137 -0
  104. package/src/commands/commit.js +80 -0
  105. package/src/commands/compact/compact.js +194 -0
  106. package/src/commands/compact/index.js +11 -0
  107. package/src/commands/config/config.js +6 -0
  108. package/src/commands/config/index.js +8 -0
  109. package/src/commands/context/context-noninteractive.js +219 -0
  110. package/src/commands/context/context.js +45 -0
  111. package/src/commands/context/index.js +21 -0
  112. package/src/commands/coordinator.js +34 -0
  113. package/src/commands/copy/copy.js +366 -0
  114. package/src/commands/copy/index.js +7 -0
  115. package/src/commands/cost/cost.js +21 -0
  116. package/src/commands/cost/index.js +16 -0
  117. package/src/commands/createMovedToPluginCommand.js +33 -0
  118. package/src/commands/desktop/desktop.js +6 -0
  119. package/src/commands/desktop/index.js +22 -0
  120. package/src/commands/diff/diff.js +6 -0
  121. package/src/commands/diff/index.js +6 -0
  122. package/src/commands/doctor/doctor.js +6 -0
  123. package/src/commands/doctor/index.js +9 -0
  124. package/src/commands/effort/effort.js +166 -0
  125. package/src/commands/effort/index.js +11 -0
  126. package/src/commands/exit/exit.js +32 -0
  127. package/src/commands/exit/index.js +9 -0
  128. package/src/commands/export/export.js +87 -0
  129. package/src/commands/export/index.js +8 -0
  130. package/src/commands/extra-usage/extra-usage-core.js +99 -0
  131. package/src/commands/extra-usage/extra-usage-noninteractive.js +13 -0
  132. package/src/commands/extra-usage/extra-usage.js +15 -0
  133. package/src/commands/extra-usage/index.js +29 -0
  134. package/src/commands/fast/fast.js +276 -0
  135. package/src/commands/fast/index.js +19 -0
  136. package/src/commands/feedback/feedback.js +11 -0
  137. package/src/commands/feedback/index.js +20 -0
  138. package/src/commands/files/files.js +11 -0
  139. package/src/commands/files/index.js +9 -0
  140. package/src/commands/force-snip.js +19 -0
  141. package/src/commands/fork/index.js +67 -0
  142. package/src/commands/heapdump/heapdump.js +14 -0
  143. package/src/commands/heapdump/index.js +9 -0
  144. package/src/commands/help/help.js +6 -0
  145. package/src/commands/help/index.js +7 -0
  146. package/src/commands/hooks/hooks.js +12 -0
  147. package/src/commands/hooks/index.js +8 -0
  148. package/src/commands/ide/ide.js +615 -0
  149. package/src/commands/ide/index.js +8 -0
  150. package/src/commands/init-verifiers.js +258 -0
  151. package/src/commands/init.js +248 -0
  152. package/src/commands/insights.js +2554 -0
  153. package/src/commands/install-github-app/ApiKeyStep.js +230 -0
  154. package/src/commands/install-github-app/CheckExistingSecretStep.js +194 -0
  155. package/src/commands/install-github-app/CheckGitHubStep.js +16 -0
  156. package/src/commands/install-github-app/ChooseRepoStep.js +211 -0
  157. package/src/commands/install-github-app/CreatingStep.js +53 -0
  158. package/src/commands/install-github-app/ErrorStep.js +84 -0
  159. package/src/commands/install-github-app/ExistingWorkflowStep.js +105 -0
  160. package/src/commands/install-github-app/InstallAppStep.js +97 -0
  161. package/src/commands/install-github-app/OAuthFlowStep.js +190 -0
  162. package/src/commands/install-github-app/SuccessStep.js +94 -0
  163. package/src/commands/install-github-app/WarningsStep.js +71 -0
  164. package/src/commands/install-github-app/index.js +10 -0
  165. package/src/commands/install-github-app/install-github-app.js +593 -0
  166. package/src/commands/install-github-app/setupGitHubActions.js +227 -0
  167. package/src/commands/install-slack-app/index.js +9 -0
  168. package/src/commands/install-slack-app/install-slack-app.js +25 -0
  169. package/src/commands/install.js +198 -0
  170. package/src/commands/keybindings/index.js +10 -0
  171. package/src/commands/keybindings/keybindings.js +47 -0
  172. package/src/commands/login/index.js +21 -0
  173. package/src/commands/login/login.js +135 -0
  174. package/src/commands/logout/index.js +11 -0
  175. package/src/commands/logout/logout.js +75 -0
  176. package/src/commands/mcp/addCommand.js +183 -0
  177. package/src/commands/mcp/index.js +9 -0
  178. package/src/commands/mcp/mcp.js +78 -0
  179. package/src/commands/mcp/xaaIdpCommand.js +193 -0
  180. package/src/commands/memories/index.js +9 -0
  181. package/src/commands/memories/index.ts +12 -0
  182. package/src/commands/memories/memories.tsx +950 -0
  183. package/src/commands/memory/index.js +7 -0
  184. package/src/commands/memory/memory.js +71 -0
  185. package/src/commands/mobile/index.js +9 -0
  186. package/src/commands/mobile/mobile.js +279 -0
  187. package/src/commands/model/index.js +14 -0
  188. package/src/commands/model/model.js +284 -0
  189. package/src/commands/output-style/index.js +8 -0
  190. package/src/commands/output-style/output-style.js +6 -0
  191. package/src/commands/passes/index.js +17 -0
  192. package/src/commands/passes/passes.js +23 -0
  193. package/src/commands/peers/index.js +68 -0
  194. package/src/commands/permissions/index.js +8 -0
  195. package/src/commands/permissions/permissions.js +9 -0
  196. package/src/commands/plan/index.js +8 -0
  197. package/src/commands/plan/plan.js +116 -0
  198. package/src/commands/plugin/AddMarketplace.js +96 -0
  199. package/src/commands/plugin/BrowseMarketplace.js +582 -0
  200. package/src/commands/plugin/DiscoverPlugins.js +613 -0
  201. package/src/commands/plugin/ManageMarketplaces.js +583 -0
  202. package/src/commands/plugin/ManagePlugins.js +1783 -0
  203. package/src/commands/plugin/PluginErrors.js +124 -0
  204. package/src/commands/plugin/PluginOptionsDialog.js +367 -0
  205. package/src/commands/plugin/PluginOptionsFlow.js +97 -0
  206. package/src/commands/plugin/PluginSettings.js +1041 -0
  207. package/src/commands/plugin/PluginTrustWarning.js +35 -0
  208. package/src/commands/plugin/UnifiedInstalledCell.js +616 -0
  209. package/src/commands/plugin/ValidatePlugin.js +96 -0
  210. package/src/commands/plugin/index.js +10 -0
  211. package/src/commands/plugin/parseArgs.js +71 -0
  212. package/src/commands/plugin/plugin.js +6 -0
  213. package/src/commands/plugin/pluginDetailsHelpers.js +95 -0
  214. package/src/commands/plugin/usePagination.js +89 -0
  215. package/src/commands/pr_comments/index.js +49 -0
  216. package/src/commands/privacy-settings/index.js +11 -0
  217. package/src/commands/privacy-settings/privacy-settings.js +55 -0
  218. package/src/commands/proactive.js +29 -0
  219. package/src/commands/rate-limit-options/index.js +15 -0
  220. package/src/commands/rate-limit-options/rate-limit-options.js +213 -0
  221. package/src/commands/release-notes/index.js +8 -0
  222. package/src/commands/release-notes/release-notes.js +38 -0
  223. package/src/commands/reload-plugins/index.js +11 -0
  224. package/src/commands/reload-plugins/reload-plugins.js +52 -0
  225. package/src/commands/remote-env/index.js +12 -0
  226. package/src/commands/remote-env/remote-env.js +6 -0
  227. package/src/commands/remote-setup/api.js +155 -0
  228. package/src/commands/remote-setup/index.js +15 -0
  229. package/src/commands/remote-setup/remote-setup.js +150 -0
  230. package/src/commands/remoteControlServer/index.js +58 -0
  231. package/src/commands/rename/generateSessionName.js +58 -0
  232. package/src/commands/rename/index.js +9 -0
  233. package/src/commands/rename/rename.js +52 -0
  234. package/src/commands/resume/index.js +9 -0
  235. package/src/commands/resume/resume.js +239 -0
  236. package/src/commands/review/UltrareviewOverageDialog.js +97 -0
  237. package/src/commands/review/reviewRemote.js +259 -0
  238. package/src/commands/review/ultrareviewCommand.js +58 -0
  239. package/src/commands/review/ultrareviewEnabled.js +10 -0
  240. package/src/commands/review.js +53 -0
  241. package/src/commands/rewind/index.js +10 -0
  242. package/src/commands/rewind/rewind.js +7 -0
  243. package/src/commands/sandbox-toggle/index.js +41 -0
  244. package/src/commands/sandbox-toggle/sandbox-toggle.js +73 -0
  245. package/src/commands/security-review.js +231 -0
  246. package/src/commands/session/index.js +13 -0
  247. package/src/commands/session/session.js +143 -0
  248. package/src/commands/skills/index.js +7 -0
  249. package/src/commands/skills/skills.js +6 -0
  250. package/src/commands/speak.js +21 -0
  251. package/src/commands/start-business.js +1575 -0
  252. package/src/commands/start-business.ts +1581 -0
  253. package/src/commands/stats/index.js +7 -0
  254. package/src/commands/stats/stats.js +6 -0
  255. package/src/commands/status/index.js +8 -0
  256. package/src/commands/status/status.js +6 -0
  257. package/src/commands/statusline.js +22 -0
  258. package/src/commands/stickers/index.js +8 -0
  259. package/src/commands/stickers/stickers.js +14 -0
  260. package/src/commands/subscribe-pr.js +131 -0
  261. package/src/commands/tag/index.js +9 -0
  262. package/src/commands/tag/tag.js +215 -0
  263. package/src/commands/tasks/index.js +8 -0
  264. package/src/commands/tasks/tasks.js +6 -0
  265. package/src/commands/terminalSetup/index.js +18 -0
  266. package/src/commands/terminalSetup/terminalSetup.js +491 -0
  267. package/src/commands/thaddeus-usage/index.js +17 -0
  268. package/src/commands/theme/index.js +7 -0
  269. package/src/commands/theme/theme.js +51 -0
  270. package/src/commands/thinkback/index.js +9 -0
  271. package/src/commands/thinkback/thinkback.js +528 -0
  272. package/src/commands/thinkback-play/index.js +13 -0
  273. package/src/commands/thinkback-play/thinkback-play.js +34 -0
  274. package/src/commands/torch.js +122 -0
  275. package/src/commands/ultraplan.js +416 -0
  276. package/src/commands/upgrade/index.js +12 -0
  277. package/src/commands/upgrade/upgrade.js +38 -0
  278. package/src/commands/usage/index.js +7 -0
  279. package/src/commands/usage/usage.js +6 -0
  280. package/src/commands/version.js +17 -0
  281. package/src/commands/vim/index.js +8 -0
  282. package/src/commands/vim/vim.js +25 -0
  283. package/src/commands/voice/index.js +13 -0
  284. package/src/commands/voice/voice.js +44 -0
  285. package/src/commands/workflows/index.js +123 -0
  286. package/src/commands.js +614 -0
  287. package/src/commands.ts +4 -0
  288. package/src/components/AgentProgressLine.js +112 -0
  289. package/src/components/AntModelSwitchCallout.js +8 -0
  290. package/src/components/App.js +46 -0
  291. package/src/components/ApproveApiKey.js +125 -0
  292. package/src/components/AutoModeOptInDialog.js +140 -0
  293. package/src/components/AutoUpdater.js +156 -0
  294. package/src/components/AutoUpdaterWrapper.js +78 -0
  295. package/src/components/AwsAuthStatusBox.js +88 -0
  296. package/src/components/BaseTextInput.js +105 -0
  297. package/src/components/BashModeProgress.js +49 -0
  298. package/src/components/BridgeDialog.js +415 -0
  299. package/src/components/BypassPermissionsModeDialog.js +87 -0
  300. package/src/components/ChannelDowngradeDialog.js +101 -0
  301. package/src/components/ClaudeInChromeOnboarding.js +126 -0
  302. package/src/components/ClaudeMdExternalIncludesDialog.js +137 -0
  303. package/src/components/ClickableImageRef.js +65 -0
  304. package/src/components/CompactSummary.js +120 -0
  305. package/src/components/ConfigurableShortcutHint.js +35 -0
  306. package/src/components/ConsoleOAuthFlow.js +554 -0
  307. package/src/components/ContextSuggestions.js +44 -0
  308. package/src/components/ContextVisualization.js +482 -0
  309. package/src/components/CoordinatorAgentStatus.js +261 -0
  310. package/src/components/CostThresholdDialog.js +49 -0
  311. package/src/components/CtrlOToExpand.js +50 -0
  312. package/src/components/CustomSelect/SelectMulti.js +150 -0
  313. package/src/components/CustomSelect/index.js +2 -0
  314. package/src/components/CustomSelect/option-map.js +32 -0
  315. package/src/components/CustomSelect/select-input-option.js +426 -0
  316. package/src/components/CustomSelect/select-option.js +24 -0
  317. package/src/components/CustomSelect/select.js +518 -0
  318. package/src/components/CustomSelect/use-multi-select-state.js +214 -0
  319. package/src/components/CustomSelect/use-select-input.js +170 -0
  320. package/src/components/CustomSelect/use-select-navigation.js +366 -0
  321. package/src/components/CustomSelect/use-select-state.js +22 -0
  322. package/src/components/DesktopHandoff.js +195 -0
  323. package/src/components/DesktopUpsell/DesktopUpsellStartup.js +174 -0
  324. package/src/components/DevBar.js +51 -0
  325. package/src/components/DevChannelsDialog.js +104 -0
  326. package/src/components/DiagnosticsDisplay.js +91 -0
  327. package/src/components/EffortCallout.js +264 -0
  328. package/src/components/EffortIndicator.js +28 -0
  329. package/src/components/ExitFlow.js +41 -0
  330. package/src/components/ExportDialog.js +101 -0
  331. package/src/components/FallbackToolUseErrorMessage.js +116 -0
  332. package/src/components/FallbackToolUseRejectedMessage.js +17 -0
  333. package/src/components/FastIcon.js +43 -0
  334. package/src/components/Feedback.js +369 -0
  335. package/src/components/FeedbackSurvey/FeedbackSurvey.js +151 -0
  336. package/src/components/FeedbackSurvey/FeedbackSurveyView.js +104 -0
  337. package/src/components/FeedbackSurvey/TranscriptSharePrompt.js +84 -0
  338. package/src/components/FeedbackSurvey/submitTranscriptShare.js +10 -0
  339. package/src/components/FeedbackSurvey/useDebouncedDigitInput.js +51 -0
  340. package/src/components/FeedbackSurvey/useFeedbackSurvey.js +258 -0
  341. package/src/components/FeedbackSurvey/useFrustrationDetection.js +8 -0
  342. package/src/components/FeedbackSurvey/useMemorySurvey.js +191 -0
  343. package/src/components/FeedbackSurvey/usePostCompactSurvey.js +202 -0
  344. package/src/components/FeedbackSurvey/useSurveyState.js +80 -0
  345. package/src/components/FileEditToolDiff.js +167 -0
  346. package/src/components/FileEditToolUpdatedMessage.js +112 -0
  347. package/src/components/FileEditToolUseRejectedMessage.js +158 -0
  348. package/src/components/FilePathLink.js +35 -0
  349. package/src/components/FullscreenLayout.js +578 -0
  350. package/src/components/GlobalSearchDialog.js +340 -0
  351. package/src/components/HelpV2/Commands.js +66 -0
  352. package/src/components/HelpV2/General.js +25 -0
  353. package/src/components/HelpV2/HelpV2.js +186 -0
  354. package/src/components/HighlightedCode/Fallback.js +193 -0
  355. package/src/components/HighlightedCode.js +185 -0
  356. package/src/components/HistorySearchDialog.js +93 -0
  357. package/src/components/IdeAutoConnectDialog.js +154 -0
  358. package/src/components/IdeOnboardingDialog.js +175 -0
  359. package/src/components/IdeStatusIndicator.js +50 -0
  360. package/src/components/IdleReturnDialog.js +117 -0
  361. package/src/components/InterruptedByUser.js +16 -0
  362. package/src/components/InvalidConfigDialog.js +135 -0
  363. package/src/components/InvalidSettingsDialog.js +85 -0
  364. package/src/components/KeybindingWarnings.js +55 -0
  365. package/src/components/LanguagePicker.js +84 -0
  366. package/src/components/LogSelector.js +1579 -0
  367. package/src/components/LogoV2/AnimatedAsterisk.js +43 -0
  368. package/src/components/LogoV2/AnimatedClawd.js +64 -0
  369. package/src/components/LogoV2/ChannelsNotice.js +262 -0
  370. package/src/components/LogoV2/Clawd.js +33 -0
  371. package/src/components/LogoV2/CondensedLogo.js +160 -0
  372. package/src/components/LogoV2/EmergencyTip.js +48 -0
  373. package/src/components/LogoV2/Feed.js +85 -0
  374. package/src/components/LogoV2/FeedColumn.js +55 -0
  375. package/src/components/LogoV2/GuestPassesUpsell.js +71 -0
  376. package/src/components/LogoV2/LogoV2.js +565 -0
  377. package/src/components/LogoV2/Opus1mMergeNotice.js +57 -0
  378. package/src/components/LogoV2/OverageCreditUpsell.js +161 -0
  379. package/src/components/LogoV2/VoiceModeNotice.js +71 -0
  380. package/src/components/LogoV2/WelcomeV2.js +14 -0
  381. package/src/components/LogoV2/feedConfigs.js +79 -0
  382. package/src/components/LspRecommendation/LspRecommendationMenu.js +46 -0
  383. package/src/components/MCPServerApprovalDialog.js +114 -0
  384. package/src/components/MCPServerDesktopImportDialog.js +206 -0
  385. package/src/components/MCPServerDialogCopy.js +16 -0
  386. package/src/components/MCPServerMultiselectDialog.js +134 -0
  387. package/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.js +150 -0
  388. package/src/components/ManagedSettingsSecurityDialog/utils.js +105 -0
  389. package/src/components/Markdown.js +233 -0
  390. package/src/components/MarkdownTable.js +280 -0
  391. package/src/components/MemoryUsageIndicator.js +28 -0
  392. package/src/components/Message.js +564 -0
  393. package/src/components/MessageModel.js +37 -0
  394. package/src/components/MessageResponse.js +73 -0
  395. package/src/components/MessageRow.js +346 -0
  396. package/src/components/MessageSelector.js +744 -0
  397. package/src/components/MessageTimestamp.js +58 -0
  398. package/src/components/Messages.js +645 -0
  399. package/src/components/ModelPicker.js +452 -0
  400. package/src/components/NativeAutoUpdater.js +152 -0
  401. package/src/components/NotebookEditToolUseRejectedMessage.js +84 -0
  402. package/src/components/OffscreenFreeze.js +35 -0
  403. package/src/components/Onboarding.js +174 -0
  404. package/src/components/OutputStylePicker.js +103 -0
  405. package/src/components/PackageManagerAutoUpdater.js +99 -0
  406. package/src/components/Passes/Passes.js +114 -0
  407. package/src/components/PrBadge.js +91 -0
  408. package/src/components/PressEnterToContinue.js +16 -0
  409. package/src/components/PromptInput/HistorySearchInput.js +45 -0
  410. package/src/components/PromptInput/IssueFlagBanner.js +8 -0
  411. package/src/components/PromptInput/Notifications.js +220 -0
  412. package/src/components/PromptInput/PromptInput.js +2014 -0
  413. package/src/components/PromptInput/PromptInputFooter.js +85 -0
  414. package/src/components/PromptInput/PromptInputFooterLeftSide.js +408 -0
  415. package/src/components/PromptInput/PromptInputFooterSuggestions.js +281 -0
  416. package/src/components/PromptInput/PromptInputHelpMenu.js +380 -0
  417. package/src/components/PromptInput/PromptInputModeIndicator.js +73 -0
  418. package/src/components/PromptInput/PromptInputQueuedCommands.js +105 -0
  419. package/src/components/PromptInput/PromptInputStashNotice.js +21 -0
  420. package/src/components/PromptInput/SandboxPromptFooterHint.js +66 -0
  421. package/src/components/PromptInput/ShimmeredInput.js +133 -0
  422. package/src/components/PromptInput/VoiceIndicator.js +137 -0
  423. package/src/components/PromptInput/inputModes.js +24 -0
  424. package/src/components/PromptInput/inputPaste.js +62 -0
  425. package/src/components/PromptInput/useMaybeTruncateInput.js +33 -0
  426. package/src/components/PromptInput/usePromptInputPlaceholder.js +53 -0
  427. package/src/components/PromptInput/useShowFastIconHint.js +23 -0
  428. package/src/components/PromptInput/useSwarmBanner.js +112 -0
  429. package/src/components/PromptInput/utils.js +50 -0
  430. package/src/components/QuickOpenDialog.js +244 -0
  431. package/src/components/RemoteCallout.js +53 -0
  432. package/src/components/RemoteEnvironmentDialog.js +346 -0
  433. package/src/components/ResumeTask.js +173 -0
  434. package/src/components/SandboxViolationExpandedView.js +106 -0
  435. package/src/components/SandboxViolationExpandedView.tsx +3 -0
  436. package/src/components/ScrollKeybindingHandler.js +982 -0
  437. package/src/components/SearchBox.js +56 -0
  438. package/src/components/SentryErrorBoundary.js +16 -0
  439. package/src/components/SessionBackgroundHint.js +105 -0
  440. package/src/components/SessionPreview.js +200 -0
  441. package/src/components/Settings/Config.js +1626 -0
  442. package/src/components/Settings/Settings.js +131 -0
  443. package/src/components/Settings/Status.js +230 -0
  444. package/src/components/Settings/Usage.js +341 -0
  445. package/src/components/ShowInIDEPrompt.js +152 -0
  446. package/src/components/SkillImprovementSurvey.js +130 -0
  447. package/src/components/Spinner/FlashingChar.js +52 -0
  448. package/src/components/Spinner/GlimmerMessage.js +329 -0
  449. package/src/components/Spinner/ShimmerChar.js +23 -0
  450. package/src/components/Spinner/SpinnerAnimationRow.js +170 -0
  451. package/src/components/Spinner/SpinnerGlyph.js +70 -0
  452. package/src/components/Spinner/TeammateSpinnerLine.js +171 -0
  453. package/src/components/Spinner/TeammateSpinnerTree.js +269 -0
  454. package/src/components/Spinner/index.js +9 -0
  455. package/src/components/Spinner/teammateSelectHint.js +1 -0
  456. package/src/components/Spinner/useShimmerAnimation.js +22 -0
  457. package/src/components/Spinner/useStalledAnimation.js +63 -0
  458. package/src/components/Spinner/utils.js +78 -0
  459. package/src/components/Spinner.js +474 -0
  460. package/src/components/Stats.js +1000 -0
  461. package/src/components/StatusLine.js +286 -0
  462. package/src/components/StatusNotices.js +50 -0
  463. package/src/components/StructuredDiff/Fallback.js +336 -0
  464. package/src/components/StructuredDiff/colorDiff.js +37 -0
  465. package/src/components/StructuredDiff.js +153 -0
  466. package/src/components/StructuredDiffList.js +9 -0
  467. package/src/components/TagTabs.js +101 -0
  468. package/src/components/TaskListV2.js +333 -0
  469. package/src/components/TeammateViewHeader.js +88 -0
  470. package/src/components/TeleportError.js +191 -0
  471. package/src/components/TeleportProgress.js +131 -0
  472. package/src/components/TeleportRepoMismatchDialog.js +98 -0
  473. package/src/components/TeleportResumeWrapper.js +158 -0
  474. package/src/components/TeleportStash.js +82 -0
  475. package/src/components/TextInput.js +108 -0
  476. package/src/components/ThaddeusHint/PluginHintMenu.js +37 -0
  477. package/src/components/ThemePicker.js +331 -0
  478. package/src/components/ThinkingToggle.js +154 -0
  479. package/src/components/TokenWarning.js +171 -0
  480. package/src/components/ToolUseLoader.js +35 -0
  481. package/src/components/TrustDialog/TrustDialog.js +301 -0
  482. package/src/components/TrustDialog/utils.js +199 -0
  483. package/src/components/UndercoverAutoCallout.js +5 -0
  484. package/src/components/ValidationErrorsList.js +147 -0
  485. package/src/components/VimTextInput.js +136 -0
  486. package/src/components/VirtualMessageList.js +893 -0
  487. package/src/components/WorkflowMultiselectDialog.js +118 -0
  488. package/src/components/WorktreeExitDialog.js +220 -0
  489. package/src/components/agents/AgentDetail.js +227 -0
  490. package/src/components/agents/AgentEditor.js +147 -0
  491. package/src/components/agents/AgentNavigationFooter.js +22 -0
  492. package/src/components/agents/AgentsList.js +436 -0
  493. package/src/components/agents/AgentsMenu.js +849 -0
  494. package/src/components/agents/ColorPicker.js +110 -0
  495. package/src/components/agents/ModelSelector.js +63 -0
  496. package/src/components/agents/SnapshotUpdateDialog.js +14 -0
  497. package/src/components/agents/ToolSelector.js +557 -0
  498. package/src/components/agents/agentFileUtils.js +179 -0
  499. package/src/components/agents/generateAgent.js +161 -0
  500. package/src/components/agents/new-agent-creation/CreateAgentWizard.js +89 -0
  501. package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.js +81 -0
  502. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.js +387 -0
  503. package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.js +63 -0
  504. package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.js +126 -0
  505. package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.js +118 -0
  506. package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.js +80 -0
  507. package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.js +108 -0
  508. package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.js +80 -0
  509. package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.js +49 -0
  510. package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.js +131 -0
  511. package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.js +52 -0
  512. package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.js +100 -0
  513. package/src/components/agents/types.js +4 -0
  514. package/src/components/agents/utils.js +14 -0
  515. package/src/components/agents/validateAgent.js +79 -0
  516. package/src/components/design-system/Byline.js +72 -0
  517. package/src/components/design-system/Dialog.js +117 -0
  518. package/src/components/design-system/Divider.js +110 -0
  519. package/src/components/design-system/FuzzyPicker.js +191 -0
  520. package/src/components/design-system/KeyboardShortcutHint.js +68 -0
  521. package/src/components/design-system/ListItem.js +184 -0
  522. package/src/components/design-system/LoadingState.js +69 -0
  523. package/src/components/design-system/Pane.js +69 -0
  524. package/src/components/design-system/ProgressBar.js +63 -0
  525. package/src/components/design-system/Ratchet.js +71 -0
  526. package/src/components/design-system/StatusIcon.js +70 -0
  527. package/src/components/design-system/Tabs.js +269 -0
  528. package/src/components/design-system/ThemeProvider.js +137 -0
  529. package/src/components/design-system/ThemedBox.js +126 -0
  530. package/src/components/design-system/ThemedText.js +60 -0
  531. package/src/components/design-system/color.js +22 -0
  532. package/src/components/diff/DiffDetailView.js +285 -0
  533. package/src/components/diff/DiffDialog.js +387 -0
  534. package/src/components/diff/DiffFileList.js +292 -0
  535. package/src/components/grove/Grove.js +483 -0
  536. package/src/components/hooks/HooksConfigMenu.js +583 -0
  537. package/src/components/hooks/PromptDialog.js +82 -0
  538. package/src/components/hooks/SelectEventMode.js +118 -0
  539. package/src/components/hooks/SelectHookMode.js +101 -0
  540. package/src/components/hooks/SelectMatcherMode.js +131 -0
  541. package/src/components/hooks/ViewHookMode.js +204 -0
  542. package/src/components/mcp/CapabilitiesSection.js +56 -0
  543. package/src/components/mcp/ElicitationDialog.js +945 -0
  544. package/src/components/mcp/MCPAgentServerMenu.js +95 -0
  545. package/src/components/mcp/MCPListPanel.js +505 -0
  546. package/src/components/mcp/MCPReconnect.js +168 -0
  547. package/src/components/mcp/MCPRemoteServerMenu.js +460 -0
  548. package/src/components/mcp/MCPSettings.js +414 -0
  549. package/src/components/mcp/MCPStdioServerMenu.js +95 -0
  550. package/src/components/mcp/MCPToolDetailView.js +219 -0
  551. package/src/components/mcp/MCPToolListView.js +137 -0
  552. package/src/components/mcp/McpParsingWarnings.js +212 -0
  553. package/src/components/mcp/index.js +8 -0
  554. package/src/components/mcp/utils/reconnectHelpers.js +35 -0
  555. package/src/components/memory/MemoryFileSelector.js +454 -0
  556. package/src/components/memory/MemoryUpdateNotification.js +43 -0
  557. package/src/components/messageActions.js +418 -0
  558. package/src/components/messages/AdvisorMessage.js +152 -0
  559. package/src/components/messages/AssistantRedactedThinkingMessage.js +28 -0
  560. package/src/components/messages/AssistantTextMessage.js +287 -0
  561. package/src/components/messages/AssistantThinkingMessage.js +70 -0
  562. package/src/components/messages/AssistantToolUseMessage.js +324 -0
  563. package/src/components/messages/AttachmentMessage.js +418 -0
  564. package/src/components/messages/CollapsedReadSearchContent.js +363 -0
  565. package/src/components/messages/CompactBoundaryMessage.js +19 -0
  566. package/src/components/messages/GroupedToolUseContent.js +37 -0
  567. package/src/components/messages/HighlightedThinkingText.js +165 -0
  568. package/src/components/messages/HookProgressMessage.js +111 -0
  569. package/src/components/messages/PlanApprovalMessage.js +213 -0
  570. package/src/components/messages/RateLimitMessage.js +149 -0
  571. package/src/components/messages/ShutdownMessage.js +124 -0
  572. package/src/components/messages/SnipBoundaryMessage.js +7 -0
  573. package/src/components/messages/SystemAPIErrorMessage.js +136 -0
  574. package/src/components/messages/SystemTextMessage.js +842 -0
  575. package/src/components/messages/TaskAssignmentMessage.js +72 -0
  576. package/src/components/messages/UserAgentNotificationMessage.js +78 -0
  577. package/src/components/messages/UserBashInputMessage.js +52 -0
  578. package/src/components/messages/UserBashOutputMessage.js +55 -0
  579. package/src/components/messages/UserChannelMessage.js +130 -0
  580. package/src/components/messages/UserCommandMessage.js +107 -0
  581. package/src/components/messages/UserCrossSessionMessage.js +11 -0
  582. package/src/components/messages/UserForkBoilerplateMessage.js +11 -0
  583. package/src/components/messages/UserGitHubWebhookMessage.js +12 -0
  584. package/src/components/messages/UserImageMessage.js +54 -0
  585. package/src/components/messages/UserLocalCommandOutputMessage.js +170 -0
  586. package/src/components/messages/UserMemoryInputMessage.js +73 -0
  587. package/src/components/messages/UserPlanMessage.js +38 -0
  588. package/src/components/messages/UserPromptMessage.js +63 -0
  589. package/src/components/messages/UserResourceUpdateMessage.js +102 -0
  590. package/src/components/messages/UserTeammateMessage.js +156 -0
  591. package/src/components/messages/UserTextMessage.js +270 -0
  592. package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.js +28 -0
  593. package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.js +17 -0
  594. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +17 -0
  595. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.js +92 -0
  596. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.js +74 -0
  597. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.js +84 -0
  598. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +58 -0
  599. package/src/components/messages/UserToolResultMessage/utils.js +43 -0
  600. package/src/components/messages/nullRenderingAttachments.js +58 -0
  601. package/src/components/messages/teamMemCollapsed.js +142 -0
  602. package/src/components/messages/teamMemSaved.js +16 -0
  603. package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.js +659 -0
  604. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.js +219 -0
  605. package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.js +227 -0
  606. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.js +175 -0
  607. package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.js +444 -0
  608. package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.js +137 -0
  609. package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.js +100 -0
  610. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.js +404 -0
  611. package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.js +110 -0
  612. package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.js +449 -0
  613. package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.js +126 -0
  614. package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.js +653 -0
  615. package/src/components/permissions/FallbackPermissionRequest.js +349 -0
  616. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +185 -0
  617. package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.js +108 -0
  618. package/src/components/permissions/FilePermissionDialog/ideDiffConfig.js +13 -0
  619. package/src/components/permissions/FilePermissionDialog/permissionOptions.js +137 -0
  620. package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.js +131 -0
  621. package/src/components/permissions/FilePermissionDialog/usePermissionHandler.js +86 -0
  622. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +164 -0
  623. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +79 -0
  624. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +113 -0
  625. package/src/components/permissions/MonitorPermissionRequest/MonitorPermissionRequest.js +7 -0
  626. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.js +164 -0
  627. package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.js +218 -0
  628. package/src/components/permissions/PermissionDecisionDebugInfo.js +467 -0
  629. package/src/components/permissions/PermissionDialog.js +55 -0
  630. package/src/components/permissions/PermissionExplanation.js +269 -0
  631. package/src/components/permissions/PermissionPrompt.js +316 -0
  632. package/src/components/permissions/PermissionRequest.js +159 -0
  633. package/src/components/permissions/PermissionRequestTitle.js +58 -0
  634. package/src/components/permissions/PermissionRuleExplanation.js +110 -0
  635. package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.js +178 -0
  636. package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.js +73 -0
  637. package/src/components/permissions/ReviewArtifactPermissionRequest/ReviewArtifactPermissionRequest.js +7 -0
  638. package/src/components/permissions/SandboxPermissionRequest.js +162 -0
  639. package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.js +228 -0
  640. package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.js +385 -0
  641. package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.js +259 -0
  642. package/src/components/permissions/WorkerBadge.js +44 -0
  643. package/src/components/permissions/WorkerPendingPermission.js +107 -0
  644. package/src/components/permissions/hooks.js +163 -0
  645. package/src/components/permissions/rules/AddPermissionRules.js +171 -0
  646. package/src/components/permissions/rules/AddWorkspaceDirectory.js +335 -0
  647. package/src/components/permissions/rules/PermissionRuleDescription.js +78 -0
  648. package/src/components/permissions/rules/PermissionRuleInput.js +136 -0
  649. package/src/components/permissions/rules/PermissionRuleList.js +1190 -0
  650. package/src/components/permissions/rules/RecentDenialsTab.js +205 -0
  651. package/src/components/permissions/rules/RemoveWorkspaceDirectory.js +103 -0
  652. package/src/components/permissions/rules/WorkspaceTab.js +133 -0
  653. package/src/components/permissions/shellPermissionHelpers.js +112 -0
  654. package/src/components/permissions/useShellPermissionFeedback.js +108 -0
  655. package/src/components/permissions/utils.js +14 -0
  656. package/src/components/sandbox/SandboxConfigTab.js +48 -0
  657. package/src/components/sandbox/SandboxDependenciesTab.js +123 -0
  658. package/src/components/sandbox/SandboxDoctorSection.js +47 -0
  659. package/src/components/sandbox/SandboxOverridesTab.js +193 -0
  660. package/src/components/sandbox/SandboxSettings.js +297 -0
  661. package/src/components/shell/ExpandShellOutputContext.js +33 -0
  662. package/src/components/shell/OutputLine.js +110 -0
  663. package/src/components/shell/ShellProgressMessage.js +144 -0
  664. package/src/components/shell/ShellTimeDisplay.js +72 -0
  665. package/src/components/skills/SkillsMenu.js +239 -0
  666. package/src/components/tasks/AsyncAgentDetailDialog.js +235 -0
  667. package/src/components/tasks/BackgroundTask.js +364 -0
  668. package/src/components/tasks/BackgroundTaskStatus.js +419 -0
  669. package/src/components/tasks/BackgroundTasksDialog.js +494 -0
  670. package/src/components/tasks/DreamDetailDialog.js +251 -0
  671. package/src/components/tasks/InProcessTeammateDetailDialog.js +275 -0
  672. package/src/components/tasks/MonitorMcpDetailDialog.js +7 -0
  673. package/src/components/tasks/RemoteSessionDetailDialog.js +868 -0
  674. package/src/components/tasks/RemoteSessionProgress.js +249 -0
  675. package/src/components/tasks/ShellDetailDialog.js +403 -0
  676. package/src/components/tasks/ShellProgress.js +77 -0
  677. package/src/components/tasks/WorkflowDetailDialog.js +7 -0
  678. package/src/components/tasks/renderToolActivity.js +29 -0
  679. package/src/components/tasks/taskStatusUtils.js +94 -0
  680. package/src/components/teams/TeamStatus.js +77 -0
  681. package/src/components/teams/TeamsDialog.js +673 -0
  682. package/src/components/ui/OrderedList.js +66 -0
  683. package/src/components/ui/OrderedListItem.js +41 -0
  684. package/src/components/ui/TreeSelect.js +300 -0
  685. package/src/components/wizard/WizardDialogLayout.js +48 -0
  686. package/src/components/wizard/WizardNavigationFooter.js +11 -0
  687. package/src/components/wizard/WizardProvider.js +217 -0
  688. package/src/components/wizard/index.js +4 -0
  689. package/src/components/wizard/useWizard.js +9 -0
  690. package/src/constants/apiLimits.js +81 -0
  691. package/src/constants/betas.js +45 -0
  692. package/src/constants/common.js +29 -0
  693. package/src/constants/cyberRiskInstruction.js +23 -0
  694. package/src/constants/errorIds.js +14 -0
  695. package/src/constants/figures.js +38 -0
  696. package/src/constants/files.js +150 -0
  697. package/src/constants/github-app.js +139 -0
  698. package/src/constants/identity.js +112 -0
  699. package/src/constants/keys.js +10 -0
  700. package/src/constants/messages.js +1 -0
  701. package/src/constants/oauth.js +175 -0
  702. package/src/constants/outputStyles.js +162 -0
  703. package/src/constants/product.js +54 -0
  704. package/src/constants/prompts.js +994 -0
  705. package/src/constants/spinnerVerbs.js +98 -0
  706. package/src/constants/system.js +77 -0
  707. package/src/constants/systemPromptSections.js +39 -0
  708. package/src/constants/toolLimits.js +50 -0
  709. package/src/constants/tools.js +103 -0
  710. package/src/constants/turnCompletionVerbs.js +12 -0
  711. package/src/constants/xml.js +73 -0
  712. package/src/context/QueuedMessageContext.js +51 -0
  713. package/src/context/fpsMetrics.js +22 -0
  714. package/src/context/mailbox.js +35 -0
  715. package/src/context/modalContext.js +34 -0
  716. package/src/context/notifications.js +199 -0
  717. package/src/context/overlayContext.js +149 -0
  718. package/src/context/promptOverlayContext.js +118 -0
  719. package/src/context/stats.js +207 -0
  720. package/src/context/voice.js +74 -0
  721. package/src/context.js +146 -0
  722. package/src/coordinator/coordinatorMode.js +345 -0
  723. package/src/coordinator/workerAgent.js +24 -0
  724. package/src/cost-tracker.js +208 -0
  725. package/src/costHook.js +17 -0
  726. package/src/daemon/main.js +19 -0
  727. package/src/dialogLaunchers.js +77 -0
  728. package/src/entrypoints/agentSdkTypes.js +202 -0
  729. package/src/entrypoints/cli.js +226 -0
  730. package/src/entrypoints/init.js +265 -0
  731. package/src/entrypoints/mcp.js +141 -0
  732. package/src/entrypoints/sandboxTypes.js +112 -0
  733. package/src/entrypoints/sdk/controlSchemas.js +452 -0
  734. package/src/entrypoints/sdk/controlTypes.js +1 -0
  735. package/src/entrypoints/sdk/coreSchemas.js +1331 -0
  736. package/src/entrypoints/sdk/coreTypes.generated.js +3 -0
  737. package/src/entrypoints/sdk/coreTypes.js +49 -0
  738. package/src/entrypoints/sdk/runtimeTypes.js +1 -0
  739. package/src/entrypoints/sdk/sdkUtilityTypes.js +1 -0
  740. package/src/entrypoints/sdk/settingsTypes.generated.js +1 -0
  741. package/src/entrypoints/sdk/toolTypes.js +1 -0
  742. package/src/environment-runner/main.js +8 -0
  743. package/src/history.js +386 -0
  744. package/src/hooks/fileSuggestions.js +635 -0
  745. package/src/hooks/notifs/useAntOrgWarningNotification.js +5 -0
  746. package/src/hooks/notifs/useAutoModeUnavailableNotification.js +47 -0
  747. package/src/hooks/notifs/useCanSwitchToExistingSubscription.js +58 -0
  748. package/src/hooks/notifs/useDeprecationWarningNotification.js +43 -0
  749. package/src/hooks/notifs/useFastModeNotification.js +164 -0
  750. package/src/hooks/notifs/useIDEStatusIndicator.js +174 -0
  751. package/src/hooks/notifs/useInstallMessages.js +27 -0
  752. package/src/hooks/notifs/useLspInitializationNotification.js +144 -0
  753. package/src/hooks/notifs/useMcpConnectivityStatus.js +81 -0
  754. package/src/hooks/notifs/useModelMigrationNotifications.js +53 -0
  755. package/src/hooks/notifs/useNpmDeprecationNotification.js +25 -0
  756. package/src/hooks/notifs/usePluginAutoupdateNotification.js +83 -0
  757. package/src/hooks/notifs/usePluginInstallationStatus.js +128 -0
  758. package/src/hooks/notifs/useRateLimitWarningNotification.js +119 -0
  759. package/src/hooks/notifs/useSettingsErrors.js +64 -0
  760. package/src/hooks/notifs/useStartupNotification.js +33 -0
  761. package/src/hooks/notifs/useTeammateShutdownNotification.js +64 -0
  762. package/src/hooks/renderPlaceholder.js +26 -0
  763. package/src/hooks/toolPermission/PermissionContext.js +211 -0
  764. package/src/hooks/toolPermission/handlers/coordinatorHandler.js +44 -0
  765. package/src/hooks/toolPermission/handlers/interactiveHandler.js +397 -0
  766. package/src/hooks/toolPermission/handlers/swarmWorkerHandler.js +108 -0
  767. package/src/hooks/toolPermission/permissionLogging.js +145 -0
  768. package/src/hooks/unifiedSuggestions.js +130 -0
  769. package/src/hooks/useAfterFirstRender.js +12 -0
  770. package/src/hooks/useApiKeyVerification.js +63 -0
  771. package/src/hooks/useArrowKeyHistory.js +203 -0
  772. package/src/hooks/useAssistantHistory.js +193 -0
  773. package/src/hooks/useAwaySummary.js +105 -0
  774. package/src/hooks/useBackgroundTaskNavigation.js +204 -0
  775. package/src/hooks/useBlink.js +28 -0
  776. package/src/hooks/useCanUseTool.js +193 -0
  777. package/src/hooks/useCancelRequest.js +195 -0
  778. package/src/hooks/useChromeExtensionNotification.js +50 -0
  779. package/src/hooks/useClipboardImageHint.js +59 -0
  780. package/src/hooks/useCommandKeybindings.js +87 -0
  781. package/src/hooks/useCommandQueue.js +10 -0
  782. package/src/hooks/useCopyOnSelect.js +88 -0
  783. package/src/hooks/useDeferredHookMessages.js +43 -0
  784. package/src/hooks/useDiffData.js +69 -0
  785. package/src/hooks/useDiffInIDE.js +252 -0
  786. package/src/hooks/useDirectConnect.js +150 -0
  787. package/src/hooks/useDoublePress.js +44 -0
  788. package/src/hooks/useDynamicConfig.js +17 -0
  789. package/src/hooks/useElapsedTime.js +25 -0
  790. package/src/hooks/useExitOnCtrlCD.js +57 -0
  791. package/src/hooks/useExitOnCtrlCDWithKeybindings.js +17 -0
  792. package/src/hooks/useFileHistorySnapshotInit.js +14 -0
  793. package/src/hooks/useGlobalKeybindings.js +213 -0
  794. package/src/hooks/useHistorySearch.js +241 -0
  795. package/src/hooks/useIDEIntegration.js +56 -0
  796. package/src/hooks/useIdeAtMentioned.js +51 -0
  797. package/src/hooks/useIdeConnectionStatus.js +21 -0
  798. package/src/hooks/useIdeLogging.js +29 -0
  799. package/src/hooks/useIdeSelection.js +106 -0
  800. package/src/hooks/useInboxPoller.js +709 -0
  801. package/src/hooks/useInputBuffer.js +73 -0
  802. package/src/hooks/useIssueFlagBanner.js +115 -0
  803. package/src/hooks/useLogMessages.js +98 -0
  804. package/src/hooks/useLspPluginRecommendation.js +176 -0
  805. package/src/hooks/useMailboxBridge.js +15 -0
  806. package/src/hooks/useMainLoopModel.js +25 -0
  807. package/src/hooks/useManagePlugins.js +261 -0
  808. package/src/hooks/useMemoryUsage.js +28 -0
  809. package/src/hooks/useMergedClients.js +11 -0
  810. package/src/hooks/useMergedCommands.js +10 -0
  811. package/src/hooks/useMergedTools.js +32 -0
  812. package/src/hooks/useMinDisplayTime.js +26 -0
  813. package/src/hooks/useNotifyAfterTimeout.js +51 -0
  814. package/src/hooks/useOfficialMarketplaceNotification.js +47 -0
  815. package/src/hooks/usePasteHandler.js +195 -0
  816. package/src/hooks/usePluginRecommendationBase.js +101 -0
  817. package/src/hooks/usePrStatus.js +91 -0
  818. package/src/hooks/usePromptSuggestion.js +128 -0
  819. package/src/hooks/usePromptsFromClaudeInChrome.js +66 -0
  820. package/src/hooks/useQueueProcessor.js +46 -0
  821. package/src/hooks/useRemoteSession.js +431 -0
  822. package/src/hooks/useReplBridge.js +715 -0
  823. package/src/hooks/useSSHSession.js +167 -0
  824. package/src/hooks/useScheduledTasks.js +104 -0
  825. package/src/hooks/useSearchInput.js +302 -0
  826. package/src/hooks/useSessionBackgrounding.js +132 -0
  827. package/src/hooks/useSettings.js +10 -0
  828. package/src/hooks/useSettingsChange.js +13 -0
  829. package/src/hooks/useSkillImprovementSurvey.js +69 -0
  830. package/src/hooks/useSkillsChange.js +51 -0
  831. package/src/hooks/useSwarmInitialization.js +67 -0
  832. package/src/hooks/useSwarmPermissionPoller.js +215 -0
  833. package/src/hooks/useTaskListWatcher.js +157 -0
  834. package/src/hooks/useTasksV2.js +220 -0
  835. package/src/hooks/useTeammateViewAutoExit.js +55 -0
  836. package/src/hooks/useTeleportResume.js +81 -0
  837. package/src/hooks/useTerminalSize.js +9 -0
  838. package/src/hooks/useTextInput.js +397 -0
  839. package/src/hooks/useThaddeusHintRecommendation.js +117 -0
  840. package/src/hooks/useTimeout.js +10 -0
  841. package/src/hooks/useTurnDiffs.js +160 -0
  842. package/src/hooks/useTypeahead.js +1250 -0
  843. package/src/hooks/useUpdateNotification.js +21 -0
  844. package/src/hooks/useVimInput.js +232 -0
  845. package/src/hooks/useVirtualScroll.js +627 -0
  846. package/src/hooks/useVoice.js +952 -0
  847. package/src/hooks/useVoiceEnabled.js +21 -0
  848. package/src/hooks/useVoiceIntegration.js +629 -0
  849. package/src/infrastructure/audit.js +210 -0
  850. package/src/infrastructure/guardrails.js +513 -0
  851. package/src/infrastructure/index.js +11 -0
  852. package/src/ink/Ansi.js +269 -0
  853. package/src/ink/bidi.js +117 -0
  854. package/src/ink/clearTerminal.js +58 -0
  855. package/src/ink/colorize.js +198 -0
  856. package/src/ink/components/AlternateScreen.js +74 -0
  857. package/src/ink/components/App.js +562 -0
  858. package/src/ink/components/AppContext.js +11 -0
  859. package/src/ink/components/Box.js +155 -0
  860. package/src/ink/components/Button.js +166 -0
  861. package/src/ink/components/ClockContext.js +108 -0
  862. package/src/ink/components/CursorDeclarationContext.js +3 -0
  863. package/src/ink/components/ErrorOverview.js +50 -0
  864. package/src/ink/components/Link.js +34 -0
  865. package/src/ink/components/Newline.js +30 -0
  866. package/src/ink/components/NoSelect.js +57 -0
  867. package/src/ink/components/RawAnsi.js +46 -0
  868. package/src/ink/components/ScrollBox.js +171 -0
  869. package/src/ink/components/Spacer.js +20 -0
  870. package/src/ink/components/StdinContext.js +16 -0
  871. package/src/ink/components/TerminalFocusContext.js +45 -0
  872. package/src/ink/components/TerminalSizeContext.js +3 -0
  873. package/src/ink/components/Text.js +195 -0
  874. package/src/ink/constants.js +2 -0
  875. package/src/ink/dom.js +298 -0
  876. package/src/ink/events/click-event.js +36 -0
  877. package/src/ink/events/dispatcher.js +172 -0
  878. package/src/ink/events/emitter.js +31 -0
  879. package/src/ink/events/event-handlers.js +30 -0
  880. package/src/ink/events/event.js +9 -0
  881. package/src/ink/events/focus-event.js +16 -0
  882. package/src/ink/events/input-event.js +161 -0
  883. package/src/ink/events/keyboard-event.js +46 -0
  884. package/src/ink/events/terminal-event.js +78 -0
  885. package/src/ink/events/terminal-focus-event.js +15 -0
  886. package/src/ink/focus.js +158 -0
  887. package/src/ink/frame.js +30 -0
  888. package/src/ink/get-max-width.js +23 -0
  889. package/src/ink/hit-test.js +113 -0
  890. package/src/ink/hooks/use-animation-frame.js +48 -0
  891. package/src/ink/hooks/use-app.js +7 -0
  892. package/src/ink/hooks/use-declared-cursor.js +60 -0
  893. package/src/ink/hooks/use-input.js +70 -0
  894. package/src/ink/hooks/use-interval.js +54 -0
  895. package/src/ink/hooks/use-search-highlight.js +32 -0
  896. package/src/ink/hooks/use-selection.js +60 -0
  897. package/src/ink/hooks/use-stdin.js +7 -0
  898. package/src/ink/hooks/use-tab-status.js +57 -0
  899. package/src/ink/hooks/use-terminal-focus.js +15 -0
  900. package/src/ink/hooks/use-terminal-title.js +29 -0
  901. package/src/ink/hooks/use-terminal-viewport.js +77 -0
  902. package/src/ink/ink.js +1645 -0
  903. package/src/ink/instances.js +7 -0
  904. package/src/ink/layout/engine.js +4 -0
  905. package/src/ink/layout/geometry.js +61 -0
  906. package/src/ink/layout/node.js +62 -0
  907. package/src/ink/layout/yoga.js +237 -0
  908. package/src/ink/line-width-cache.js +19 -0
  909. package/src/ink/log-update.js +583 -0
  910. package/src/ink/measure-element.js +8 -0
  911. package/src/ink/measure-text.js +35 -0
  912. package/src/ink/node-cache.js +30 -0
  913. package/src/ink/optimizer.js +81 -0
  914. package/src/ink/output.js +556 -0
  915. package/src/ink/parse-keypress.js +695 -0
  916. package/src/ink/reconciler.js +384 -0
  917. package/src/ink/render-border.js +134 -0
  918. package/src/ink/render-node-to-output.js +1216 -0
  919. package/src/ink/render-to-screen.js +171 -0
  920. package/src/ink/renderer.js +129 -0
  921. package/src/ink/root.js +80 -0
  922. package/src/ink/screen.js +1132 -0
  923. package/src/ink/searchHighlight.js +78 -0
  924. package/src/ink/selection.js +792 -0
  925. package/src/ink/squash-text-nodes.js +56 -0
  926. package/src/ink/stringWidth.js +200 -0
  927. package/src/ink/styles.js +299 -0
  928. package/src/ink/supports-hyperlinks.js +40 -0
  929. package/src/ink/tabstops.js +39 -0
  930. package/src/ink/terminal-focus-state.js +35 -0
  931. package/src/ink/terminal-querier.js +173 -0
  932. package/src/ink/terminal.js +208 -0
  933. package/src/ink/termio/ansi.js +70 -0
  934. package/src/ink/termio/csi.js +260 -0
  935. package/src/ink/termio/dec.js +53 -0
  936. package/src/ink/termio/esc.js +55 -0
  937. package/src/ink/termio/osc.js +432 -0
  938. package/src/ink/termio/parser.js +356 -0
  939. package/src/ink/termio/sgr.js +292 -0
  940. package/src/ink/termio/tokenize.js +264 -0
  941. package/src/ink/termio/types.js +55 -0
  942. package/src/ink/termio.js +24 -0
  943. package/src/ink/useTerminalNotification.js +57 -0
  944. package/src/ink/warn.js +10 -0
  945. package/src/ink/widest-line.js +14 -0
  946. package/src/ink/wrap-text.js +54 -0
  947. package/src/ink/wrapAnsi.js +6 -0
  948. package/src/ink.js +50 -0
  949. package/src/integrations/credentialStore.js +176 -0
  950. package/src/integrations/index.js +5 -0
  951. package/src/integrations/integrationManager.js +180 -0
  952. package/src/integrations/providers/BaseProvider.js +180 -0
  953. package/src/integrations/providers/GitHubProvider.js +217 -0
  954. package/src/integrations/providers/GmailProvider.js +204 -0
  955. package/src/integrations/providers/GoogleCalendarProvider.js +113 -0
  956. package/src/integrations/providers/HubSpotProvider.js +159 -0
  957. package/src/integrations/providers/JiraProvider.js +216 -0
  958. package/src/integrations/providers/NotionProvider.js +221 -0
  959. package/src/integrations/providers/QuickBooksProvider.js +176 -0
  960. package/src/integrations/providers/SlackProvider.js +174 -0
  961. package/src/integrations/providers/StripeProvider.js +206 -0
  962. package/src/integrations/providers/TwilioProvider.js +239 -0
  963. package/src/integrations/providers/_template.js +112 -0
  964. package/src/integrations/types.js +7 -0
  965. package/src/interactiveHelpers.js +308 -0
  966. package/src/jobs/classifier.js +6 -0
  967. package/src/keybindings/KeybindingContext.js +184 -0
  968. package/src/keybindings/KeybindingProviderSetup.js +259 -0
  969. package/src/keybindings/defaultBindings.js +333 -0
  970. package/src/keybindings/loadUserBindings.js +393 -0
  971. package/src/keybindings/match.js +111 -0
  972. package/src/keybindings/parser.js +184 -0
  973. package/src/keybindings/reservedShortcuts.js +109 -0
  974. package/src/keybindings/resolver.js +182 -0
  975. package/src/keybindings/schema.js +205 -0
  976. package/src/keybindings/shortcutFormat.js +48 -0
  977. package/src/keybindings/template.js +40 -0
  978. package/src/keybindings/useKeybinding.js +161 -0
  979. package/src/keybindings/useShortcutDisplay.js +43 -0
  980. package/src/keybindings/validate.js +395 -0
  981. package/src/main.js +4128 -0
  982. package/src/memdir/findRelevantMemories.js +99 -0
  983. package/src/memdir/memdir.js +406 -0
  984. package/src/memdir/memoryAge.js +52 -0
  985. package/src/memdir/memoryScan.js +65 -0
  986. package/src/memdir/memoryShapeTelemetry.js +8 -0
  987. package/src/memdir/memoryTypes.js +260 -0
  988. package/src/memdir/paths.js +235 -0
  989. package/src/memdir/teamMemPaths.js +261 -0
  990. package/src/memdir/teamMemPrompts.js +82 -0
  991. package/src/migrations/migrateAutoUpdatesToSettings.js +47 -0
  992. package/src/migrations/migrateBypassPermissionsAcceptedToSettings.js +32 -0
  993. package/src/migrations/migrateEnableAllProjectMcpServersToSettings.js +83 -0
  994. package/src/migrations/migrateFennecToOpus.js +39 -0
  995. package/src/migrations/migrateLegacyOpusToCurrent.js +44 -0
  996. package/src/migrations/migrateOpusToOpus1m.js +31 -0
  997. package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.js +23 -0
  998. package/src/migrations/migrateSonnet1mToSonnet45.js +38 -0
  999. package/src/migrations/migrateSonnet45ToSonnet46.js +48 -0
  1000. package/src/migrations/resetAutoModeOptInForDefaultOffer.js +47 -0
  1001. package/src/migrations/resetProToOpusDefault.js +46 -0
  1002. package/src/moreright/useMoreRight.js +13 -0
  1003. package/src/native-ts/color-diff/index.js +819 -0
  1004. package/src/native-ts/file-index/index.js +328 -0
  1005. package/src/native-ts/yoga-layout/enums.js +101 -0
  1006. package/src/native-ts/yoga-layout/index.js +2113 -0
  1007. package/src/outputStyles/loadOutputStylesDir.js +71 -0
  1008. package/src/plugins/builtinPlugins.js +132 -0
  1009. package/src/plugins/bundled/index.js +22 -0
  1010. package/src/proactive/index.js +138 -0
  1011. package/src/proactive/useProactive.js +82 -0
  1012. package/src/projectOnboardingState.js +61 -0
  1013. package/src/query/config.js +17 -0
  1014. package/src/query/deps.js +12 -0
  1015. package/src/query/stopHooks.js +332 -0
  1016. package/src/query/tokenBudget.js +49 -0
  1017. package/src/query.js +1264 -0
  1018. package/src/remote/RemoteSessionManager.js +172 -0
  1019. package/src/remote/SessionsWebSocket.js +308 -0
  1020. package/src/remote/remotePermissionBridge.js +70 -0
  1021. package/src/remote/sdkMessageAdapter.js +227 -0
  1022. package/src/replLauncher.js +7 -0
  1023. package/src/schemas/hooks.js +174 -0
  1024. package/src/screens/Doctor.js +580 -0
  1025. package/src/screens/REPL.js +4500 -0
  1026. package/src/screens/ResumeConversation.js +339 -0
  1027. package/src/self-hosted-runner/main.js +8 -0
  1028. package/src/server/backends/dangerousBackend.js +8 -0
  1029. package/src/server/connectHeadless.js +6 -0
  1030. package/src/server/createDirectConnectSession.js +62 -0
  1031. package/src/server/directConnectManager.js +153 -0
  1032. package/src/server/lockfile.js +11 -0
  1033. package/src/server/parseConnectUrl.js +20 -0
  1034. package/src/server/server.js +12 -0
  1035. package/src/server/serverBanner.js +9 -0
  1036. package/src/server/serverLog.js +11 -0
  1037. package/src/server/sessionManager.js +19 -0
  1038. package/src/server/types.js +7 -0
  1039. package/src/services/AgentSummary/agentSummary.js +147 -0
  1040. package/src/services/MagicDocs/magicDocs.js +193 -0
  1041. package/src/services/MagicDocs/prompts.js +110 -0
  1042. package/src/services/PromptSuggestion/promptSuggestion.js +402 -0
  1043. package/src/services/PromptSuggestion/speculation.js +643 -0
  1044. package/src/services/SessionMemory/prompts.js +254 -0
  1045. package/src/services/SessionMemory/sessionMemory.js +358 -0
  1046. package/src/services/SessionMemory/sessionMemoryUtils.js +157 -0
  1047. package/src/services/analytics/config.js +27 -0
  1048. package/src/services/analytics/datadog.js +26 -0
  1049. package/src/services/analytics/firstPartyEventLogger.js +65 -0
  1050. package/src/services/analytics/firstPartyEventLoggingExporter.js +595 -0
  1051. package/src/services/analytics/growthbook.js +103 -0
  1052. package/src/services/analytics/index.js +91 -0
  1053. package/src/services/analytics/metadata.js +696 -0
  1054. package/src/services/analytics/sink.js +19 -0
  1055. package/src/services/analytics/sinkKillswitch.js +19 -0
  1056. package/src/services/api/adminRequests.js +57 -0
  1057. package/src/services/api/bootstrap.js +118 -0
  1058. package/src/services/api/claude.js +2466 -0
  1059. package/src/services/api/client.js +335 -0
  1060. package/src/services/api/dumpPrompts.js +174 -0
  1061. package/src/services/api/emptyUsage.js +20 -0
  1062. package/src/services/api/errorUtils.js +203 -0
  1063. package/src/services/api/errors.js +926 -0
  1064. package/src/services/api/filesApi.js +523 -0
  1065. package/src/services/api/firstTokenDate.js +49 -0
  1066. package/src/services/api/grove.js +44 -0
  1067. package/src/services/api/logging.js +484 -0
  1068. package/src/services/api/metricsOptOut.js +15 -0
  1069. package/src/services/api/overageCreditGrant.js +123 -0
  1070. package/src/services/api/promptCacheBreakDetection.js +510 -0
  1071. package/src/services/api/referral.js +219 -0
  1072. package/src/services/api/sessionIngress.js +358 -0
  1073. package/src/services/api/ultrareviewQuota.js +29 -0
  1074. package/src/services/api/usage.js +31 -0
  1075. package/src/services/api/withRetry.js +587 -0
  1076. package/src/services/api/xai/anthropic-shim.js +885 -0
  1077. package/src/services/api/xai/brightDataSearch.js +161 -0
  1078. package/src/services/api/xai/thaddeus-engine.js +605 -0
  1079. package/src/services/api/xai/xai-client.js +276 -0
  1080. package/src/services/autoDream/autoDream.js +244 -0
  1081. package/src/services/autoDream/config.js +17 -0
  1082. package/src/services/autoDream/consolidationLock.js +122 -0
  1083. package/src/services/autoDream/consolidationPrompt.js +55 -0
  1084. package/src/services/awaySummary.js +61 -0
  1085. package/src/services/claudeAiLimits.js +331 -0
  1086. package/src/services/claudeAiLimitsHook.js +15 -0
  1087. package/src/services/compact/apiMicrocompact.js +97 -0
  1088. package/src/services/compact/autoCompact.js +234 -0
  1089. package/src/services/compact/cachedMCConfig.js +5 -0
  1090. package/src/services/compact/compact.js +1256 -0
  1091. package/src/services/compact/compactWarningHook.js +12 -0
  1092. package/src/services/compact/compactWarningState.js +15 -0
  1093. package/src/services/compact/grouping.js +58 -0
  1094. package/src/services/compact/microCompact.js +414 -0
  1095. package/src/services/compact/postCompactCleanup.js +70 -0
  1096. package/src/services/compact/prompt.js +325 -0
  1097. package/src/services/compact/reactiveCompact.js +20 -0
  1098. package/src/services/compact/sessionMemoryCompact.js +467 -0
  1099. package/src/services/compact/snipCompact.js +23 -0
  1100. package/src/services/compact/snipProjection.js +11 -0
  1101. package/src/services/compact/timeBasedMCConfig.js +11 -0
  1102. package/src/services/contextCollapse/index.js +33 -0
  1103. package/src/services/contextCollapse/operations.js +5 -0
  1104. package/src/services/contextCollapse/persist.js +5 -0
  1105. package/src/services/diagnosticTracking.js +282 -0
  1106. package/src/services/elevenlabsTTS.js +245 -0
  1107. package/src/services/extractMemories/extractMemories.js +442 -0
  1108. package/src/services/extractMemories/prompts.js +129 -0
  1109. package/src/services/internalLogging.js +68 -0
  1110. package/src/services/lsp/LSPClient.js +306 -0
  1111. package/src/services/lsp/LSPDiagnosticRegistry.js +277 -0
  1112. package/src/services/lsp/LSPServerInstance.js +388 -0
  1113. package/src/services/lsp/LSPServerManager.js +305 -0
  1114. package/src/services/lsp/config.js +57 -0
  1115. package/src/services/lsp/manager.js +246 -0
  1116. package/src/services/lsp/passiveFeedback.js +226 -0
  1117. package/src/services/mcp/InProcessTransport.js +54 -0
  1118. package/src/services/mcp/MCPConnectionManager.js +50 -0
  1119. package/src/services/mcp/SdkControlTransport.js +115 -0
  1120. package/src/services/mcp/auth.js +1882 -0
  1121. package/src/services/mcp/channelAllowlist.js +57 -0
  1122. package/src/services/mcp/channelNotification.js +235 -0
  1123. package/src/services/mcp/channelPermissions.js +192 -0
  1124. package/src/services/mcp/claudeai.js +123 -0
  1125. package/src/services/mcp/client.js +2478 -0
  1126. package/src/services/mcp/config.js +1271 -0
  1127. package/src/services/mcp/elicitationHandler.js +192 -0
  1128. package/src/services/mcp/envExpansion.js +30 -0
  1129. package/src/services/mcp/headersHelper.js +93 -0
  1130. package/src/services/mcp/mcpStringUtils.js +85 -0
  1131. package/src/services/mcp/normalization.js +21 -0
  1132. package/src/services/mcp/oauthPort.js +69 -0
  1133. package/src/services/mcp/officialRegistry.js +20 -0
  1134. package/src/services/mcp/types.js +94 -0
  1135. package/src/services/mcp/useManageMCPConnections.js +818 -0
  1136. package/src/services/mcp/utils.js +433 -0
  1137. package/src/services/mcp/vscodeSdkMcp.js +69 -0
  1138. package/src/services/mcp/xaa.js +342 -0
  1139. package/src/services/mcp/xaaIdpLogin.js +377 -0
  1140. package/src/services/mcpServerApproval.js +30 -0
  1141. package/src/services/mockRateLimits.js +666 -0
  1142. package/src/services/notifier.js +114 -0
  1143. package/src/services/oauth/auth-code-listener.js +165 -0
  1144. package/src/services/oauth/client.js +397 -0
  1145. package/src/services/oauth/crypto.js +19 -0
  1146. package/src/services/oauth/getOauthProfile.js +48 -0
  1147. package/src/services/oauth/index.js +133 -0
  1148. package/src/services/plugins/PluginInstallationManager.js +139 -0
  1149. package/src/services/plugins/pluginCliCommands.js +230 -0
  1150. package/src/services/plugins/pluginOperations.js +826 -0
  1151. package/src/services/policyLimits/index.js +547 -0
  1152. package/src/services/policyLimits/types.js +9 -0
  1153. package/src/services/preventSleep.js +143 -0
  1154. package/src/services/rateLimitMessages.js +271 -0
  1155. package/src/services/rateLimitMocking.js +91 -0
  1156. package/src/services/remoteManagedSettings/index.js +534 -0
  1157. package/src/services/remoteManagedSettings/securityCheck.js +60 -0
  1158. package/src/services/remoteManagedSettings/syncCache.js +90 -0
  1159. package/src/services/remoteManagedSettings/syncCacheState.js +89 -0
  1160. package/src/services/remoteManagedSettings/types.js +12 -0
  1161. package/src/services/sessionTranscript/sessionTranscript.js +5 -0
  1162. package/src/services/settingsSync/index.js +478 -0
  1163. package/src/services/settingsSync/types.js +35 -0
  1164. package/src/services/skillSearch/featureCheck.js +8 -0
  1165. package/src/services/skillSearch/localSearch.js +5 -0
  1166. package/src/services/skillSearch/prefetch.js +8 -0
  1167. package/src/services/skillSearch/remoteSkillLoader.js +8 -0
  1168. package/src/services/skillSearch/remoteSkillState.js +11 -0
  1169. package/src/services/skillSearch/signals.js +3 -0
  1170. package/src/services/skillSearch/telemetry.js +8 -0
  1171. package/src/services/teamMemorySync/index.js +976 -0
  1172. package/src/services/teamMemorySync/secretScanner.js +275 -0
  1173. package/src/services/teamMemorySync/teamMemSecretGuard.js +33 -0
  1174. package/src/services/teamMemorySync/types.js +47 -0
  1175. package/src/services/teamMemorySync/watcher.js +326 -0
  1176. package/src/services/thaddeusAuth.js +485 -0
  1177. package/src/services/thaddeusAuthTypes.js +9 -0
  1178. package/src/services/thaddeusLoginFlow.js +236 -0
  1179. package/src/services/tips/tipHistory.js +17 -0
  1180. package/src/services/tips/tipRegistry.js +593 -0
  1181. package/src/services/tips/tipScheduler.js +40 -0
  1182. package/src/services/tokenEstimation.js +365 -0
  1183. package/src/services/toolUseSummary/toolUseSummaryGenerator.js +87 -0
  1184. package/src/services/tools/StreamingToolExecutor.js +413 -0
  1185. package/src/services/tools/toolExecution.js +1309 -0
  1186. package/src/services/tools/toolHooks.js +454 -0
  1187. package/src/services/tools/toolOrchestration.js +110 -0
  1188. package/src/services/vcr.js +291 -0
  1189. package/src/services/voice.js +392 -0
  1190. package/src/services/voiceKeyterms.js +94 -0
  1191. package/src/services/voiceStreamSTT.js +405 -0
  1192. package/src/setup.js +310 -0
  1193. package/src/skills/bundled/batch.js +114 -0
  1194. package/src/skills/bundled/claudeApi.js +145 -0
  1195. package/src/skills/bundled/claudeApiContent.js +71 -0
  1196. package/src/skills/bundled/claudeInChrome.js +27 -0
  1197. package/src/skills/bundled/debug.js +99 -0
  1198. package/src/skills/bundled/dream.js +49 -0
  1199. package/src/skills/bundled/emailSetup.js +196 -0
  1200. package/src/skills/bundled/hunter.js +28 -0
  1201. package/src/skills/bundled/index.js +80 -0
  1202. package/src/skills/bundled/keybindings.js +292 -0
  1203. package/src/skills/bundled/loop.js +81 -0
  1204. package/src/skills/bundled/loremIpsum.js +264 -0
  1205. package/src/skills/bundled/reactor.js +31 -0
  1206. package/src/skills/bundled/remember.js +73 -0
  1207. package/src/skills/bundled/runSkillGenerator.js +12 -0
  1208. package/src/skills/bundled/scheduleRemoteAgents.js +373 -0
  1209. package/src/skills/bundled/simplify.js +66 -0
  1210. package/src/skills/bundled/skillify.js +182 -0
  1211. package/src/skills/bundled/stuck.js +69 -0
  1212. package/src/skills/bundled/updateConfig.js +463 -0
  1213. package/src/skills/bundled/verify.js +23 -0
  1214. package/src/skills/bundled/verifyContent.js +10 -0
  1215. package/src/skills/bundledSkills.js +159 -0
  1216. package/src/skills/loadSkillsDir.js +736 -0
  1217. package/src/skills/mcpSkillBuilders.js +10 -0
  1218. package/src/skills/mcpSkills.js +5 -0
  1219. package/src/state/AppState.js +182 -0
  1220. package/src/state/AppStateStore.js +117 -0
  1221. package/src/state/onChangeAppState.js +132 -0
  1222. package/src/state/selectors.js +51 -0
  1223. package/src/state/store.js +21 -0
  1224. package/src/state/teammateViewHelpers.js +124 -0
  1225. package/src/stubs/ant-chrome-mcp/index.js +4 -0
  1226. package/src/stubs/ant-computer-use-input/index.js +2 -0
  1227. package/src/stubs/ant-computer-use-mcp/index.js +7 -0
  1228. package/src/stubs/ant-computer-use-mcp/sentinelApps.js +2 -0
  1229. package/src/stubs/ant-computer-use-mcp/types.js +3 -0
  1230. package/src/stubs/ant-computer-use-swift/index.js +1 -0
  1231. package/src/stubs/anthropic-sandbox/index.js +34 -0
  1232. package/src/tasks/DreamTask/DreamTask.js +99 -0
  1233. package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.js +116 -0
  1234. package/src/tasks/InProcessTeammateTask/types.js +35 -0
  1235. package/src/tasks/LocalAgentTask/LocalAgentTask.js +507 -0
  1236. package/src/tasks/LocalMainSessionTask.js +338 -0
  1237. package/src/tasks/LocalShellTask/LocalShellTask.js +475 -0
  1238. package/src/tasks/LocalShellTask/guards.js +9 -0
  1239. package/src/tasks/LocalShellTask/killShellTasks.js +59 -0
  1240. package/src/tasks/LocalWorkflowTask/LocalWorkflowTask.js +7 -0
  1241. package/src/tasks/MonitorMcpTask/MonitorMcpTask.js +20 -0
  1242. package/src/tasks/RemoteAgentTask/RemoteAgentTask.js +742 -0
  1243. package/src/tasks/pillLabel.js +69 -0
  1244. package/src/tasks/stopTask.js +67 -0
  1245. package/src/tasks/types.js +18 -0
  1246. package/src/tasks.js +37 -0
  1247. package/src/tools/AIEmployeesTool/AIEmployeesTool.js +674 -0
  1248. package/src/tools/AIEmployeesTool/constants.js +1 -0
  1249. package/src/tools/AIEmployeesTool/prompt.js +56 -0
  1250. package/src/tools/AgentTool/AgentTool.js +1221 -0
  1251. package/src/tools/AgentTool/UI.js +593 -0
  1252. package/src/tools/AgentTool/agentColorManager.js +43 -0
  1253. package/src/tools/AgentTool/agentDisplay.js +72 -0
  1254. package/src/tools/AgentTool/agentMemory.js +125 -0
  1255. package/src/tools/AgentTool/agentMemorySnapshot.js +136 -0
  1256. package/src/tools/AgentTool/agentToolUtils.js +456 -0
  1257. package/src/tools/AgentTool/built-in/exploreAgent.js +76 -0
  1258. package/src/tools/AgentTool/built-in/generalPurposeAgent.js +28 -0
  1259. package/src/tools/AgentTool/built-in/planAgent.js +87 -0
  1260. package/src/tools/AgentTool/built-in/statuslineSetup.js +140 -0
  1261. package/src/tools/AgentTool/built-in/thaddeusGuideAgent.js +174 -0
  1262. package/src/tools/AgentTool/built-in/verificationAgent.js +146 -0
  1263. package/src/tools/AgentTool/builtInAgents.js +56 -0
  1264. package/src/tools/AgentTool/constants.js +11 -0
  1265. package/src/tools/AgentTool/forkSubagent.js +177 -0
  1266. package/src/tools/AgentTool/loadAgentsDir.js +497 -0
  1267. package/src/tools/AgentTool/prompt.js +260 -0
  1268. package/src/tools/AgentTool/resumeAgent.js +182 -0
  1269. package/src/tools/AgentTool/runAgent.js +627 -0
  1270. package/src/tools/AppointmentsTool/AppointmentsTool.js +628 -0
  1271. package/src/tools/AppointmentsTool/constants.js +1 -0
  1272. package/src/tools/AppointmentsTool/prompt.js +15 -0
  1273. package/src/tools/AskUserQuestionTool/AskUserQuestionTool.js +238 -0
  1274. package/src/tools/AskUserQuestionTool/prompt.js +38 -0
  1275. package/src/tools/BashTool/BashTool.js +1009 -0
  1276. package/src/tools/BashTool/BashToolResultMessage.js +169 -0
  1277. package/src/tools/BashTool/UI.js +134 -0
  1278. package/src/tools/BashTool/bashCommandHelpers.js +184 -0
  1279. package/src/tools/BashTool/bashPermissions.js +2023 -0
  1280. package/src/tools/BashTool/bashSecurity.js +2267 -0
  1281. package/src/tools/BashTool/commandSemantics.js +105 -0
  1282. package/src/tools/BashTool/commentLabel.js +14 -0
  1283. package/src/tools/BashTool/destructiveCommandWarning.js +88 -0
  1284. package/src/tools/BashTool/modeValidation.js +86 -0
  1285. package/src/tools/BashTool/pathValidation.js +1079 -0
  1286. package/src/tools/BashTool/prompt.js +333 -0
  1287. package/src/tools/BashTool/readOnlyValidation.js +1794 -0
  1288. package/src/tools/BashTool/sedEditParser.js +282 -0
  1289. package/src/tools/BashTool/sedValidation.js +580 -0
  1290. package/src/tools/BashTool/shouldUseSandbox.js +125 -0
  1291. package/src/tools/BashTool/toolName.js +2 -0
  1292. package/src/tools/BashTool/utils.js +180 -0
  1293. package/src/tools/BriefTool/BriefTool.js +173 -0
  1294. package/src/tools/BriefTool/UI.js +67 -0
  1295. package/src/tools/BriefTool/attachments.js +86 -0
  1296. package/src/tools/BriefTool/prompt.js +19 -0
  1297. package/src/tools/BriefTool/upload.js +136 -0
  1298. package/src/tools/CalendarTool/CalendarTool.js +498 -0
  1299. package/src/tools/CalendarTool/constants.js +1 -0
  1300. package/src/tools/CalendarTool/prompt.js +11 -0
  1301. package/src/tools/ConfigTool/ConfigTool.js +398 -0
  1302. package/src/tools/ConfigTool/UI.js +25 -0
  1303. package/src/tools/ConfigTool/constants.js +1 -0
  1304. package/src/tools/ConfigTool/prompt.js +82 -0
  1305. package/src/tools/ConfigTool/supportedSettings.js +180 -0
  1306. package/src/tools/ContactsTool/ContactsTool.js +648 -0
  1307. package/src/tools/ContactsTool/constants.js +1 -0
  1308. package/src/tools/ContactsTool/prompt.js +15 -0
  1309. package/src/tools/CtxInspectTool/CtxInspectTool.js +44 -0
  1310. package/src/tools/DiscoverSkillsTool/prompt.js +4 -0
  1311. package/src/tools/EmailReadTool/index.js +410 -0
  1312. package/src/tools/EmailSendTool/index.js +178 -0
  1313. package/src/tools/EnterPlanModeTool/EnterPlanModeTool.js +98 -0
  1314. package/src/tools/EnterPlanModeTool/UI.js +14 -0
  1315. package/src/tools/EnterPlanModeTool/constants.js +1 -0
  1316. package/src/tools/EnterPlanModeTool/prompt.js +164 -0
  1317. package/src/tools/EnterWorktreeTool/EnterWorktreeTool.js +104 -0
  1318. package/src/tools/EnterWorktreeTool/UI.js +9 -0
  1319. package/src/tools/EnterWorktreeTool/constants.js +1 -0
  1320. package/src/tools/EnterWorktreeTool/prompt.js +30 -0
  1321. package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.js +383 -0
  1322. package/src/tools/ExitPlanModeTool/UI.js +32 -0
  1323. package/src/tools/ExitPlanModeTool/constants.js +2 -0
  1324. package/src/tools/ExitPlanModeTool/prompt.js +27 -0
  1325. package/src/tools/ExitWorktreeTool/ExitWorktreeTool.js +257 -0
  1326. package/src/tools/ExitWorktreeTool/UI.js +10 -0
  1327. package/src/tools/ExitWorktreeTool/constants.js +1 -0
  1328. package/src/tools/ExitWorktreeTool/prompt.js +32 -0
  1329. package/src/tools/FileEditTool/FileEditTool.js +480 -0
  1330. package/src/tools/FileEditTool/UI.js +202 -0
  1331. package/src/tools/FileEditTool/constants.js +7 -0
  1332. package/src/tools/FileEditTool/prompt.js +24 -0
  1333. package/src/tools/FileEditTool/types.js +50 -0
  1334. package/src/tools/FileEditTool/utils.js +579 -0
  1335. package/src/tools/FileReadTool/FileReadTool.js +889 -0
  1336. package/src/tools/FileReadTool/UI.js +126 -0
  1337. package/src/tools/FileReadTool/imageProcessor.js +46 -0
  1338. package/src/tools/FileReadTool/limits.js +70 -0
  1339. package/src/tools/FileReadTool/prompt.js +31 -0
  1340. package/src/tools/FileWriteTool/FileWriteTool.js +341 -0
  1341. package/src/tools/FileWriteTool/UI.js +339 -0
  1342. package/src/tools/FileWriteTool/prompt.js +15 -0
  1343. package/src/tools/GlobTool/GlobTool.js +161 -0
  1344. package/src/tools/GlobTool/UI.js +40 -0
  1345. package/src/tools/GlobTool/prompt.js +6 -0
  1346. package/src/tools/GrepTool/GrepTool.js +439 -0
  1347. package/src/tools/GrepTool/UI.js +155 -0
  1348. package/src/tools/GrepTool/prompt.js +16 -0
  1349. package/src/tools/IntegrationsTool/IntegrationsTool.js +217 -0
  1350. package/src/tools/IntegrationsTool/constants.js +1 -0
  1351. package/src/tools/IntegrationsTool/prompt.js +41 -0
  1352. package/src/tools/InteractionsTool/InteractionsTool.js +525 -0
  1353. package/src/tools/InteractionsTool/constants.js +1 -0
  1354. package/src/tools/InteractionsTool/prompt.js +14 -0
  1355. package/src/tools/InvoicesTool/InvoicesTool.js +581 -0
  1356. package/src/tools/InvoicesTool/constants.js +1 -0
  1357. package/src/tools/InvoicesTool/prompt.js +15 -0
  1358. package/src/tools/LSPTool/LSPTool.js +660 -0
  1359. package/src/tools/LSPTool/UI.js +205 -0
  1360. package/src/tools/LSPTool/formatters.js +445 -0
  1361. package/src/tools/LSPTool/prompt.js +20 -0
  1362. package/src/tools/LSPTool/schemas.js +197 -0
  1363. package/src/tools/LSPTool/symbolContext.js +75 -0
  1364. package/src/tools/LeadScorerTool/LeadScorerTool.js +509 -0
  1365. package/src/tools/LeadScorerTool/constants.js +1 -0
  1366. package/src/tools/LeadScorerTool/prompt.js +11 -0
  1367. package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.js +100 -0
  1368. package/src/tools/ListMcpResourcesTool/UI.js +17 -0
  1369. package/src/tools/ListMcpResourcesTool/prompt.js +18 -0
  1370. package/src/tools/ListPeersTool/ListPeersTool.js +45 -0
  1371. package/src/tools/MCPTool/MCPTool.js +60 -0
  1372. package/src/tools/MCPTool/UI.js +343 -0
  1373. package/src/tools/MCPTool/classifyForCollapse.js +597 -0
  1374. package/src/tools/MCPTool/prompt.js +3 -0
  1375. package/src/tools/McpAuthTool/McpAuthTool.js +162 -0
  1376. package/src/tools/MonitorTool/MonitorTool.js +55 -0
  1377. package/src/tools/NotebookEditTool/NotebookEditTool.js +421 -0
  1378. package/src/tools/NotebookEditTool/UI.js +41 -0
  1379. package/src/tools/NotebookEditTool/constants.js +2 -0
  1380. package/src/tools/NotebookEditTool/prompt.js +2 -0
  1381. package/src/tools/OverflowTestTool/OverflowTestTool.js +51 -0
  1382. package/src/tools/PhoneBridgeTool/PhoneBridgeTool.js +301 -0
  1383. package/src/tools/PhoneBridgeTool/constants.js +1 -0
  1384. package/src/tools/PhoneBridgeTool/prompt.js +26 -0
  1385. package/src/tools/PowerShellTool/PowerShellTool.js +900 -0
  1386. package/src/tools/PowerShellTool/UI.js +58 -0
  1387. package/src/tools/PowerShellTool/clmTypes.js +207 -0
  1388. package/src/tools/PowerShellTool/commandSemantics.js +115 -0
  1389. package/src/tools/PowerShellTool/commonParameters.js +27 -0
  1390. package/src/tools/PowerShellTool/destructiveCommandWarning.js +92 -0
  1391. package/src/tools/PowerShellTool/gitSafety.js +185 -0
  1392. package/src/tools/PowerShellTool/modeValidation.js +357 -0
  1393. package/src/tools/PowerShellTool/pathValidation.js +1712 -0
  1394. package/src/tools/PowerShellTool/powershellPermissions.js +1351 -0
  1395. package/src/tools/PowerShellTool/powershellSecurity.js +942 -0
  1396. package/src/tools/PowerShellTool/prompt.js +132 -0
  1397. package/src/tools/PowerShellTool/readOnlyValidation.js +1633 -0
  1398. package/src/tools/PowerShellTool/toolName.js +2 -0
  1399. package/src/tools/PushNotificationTool/PushNotificationTool.js +35 -0
  1400. package/src/tools/REPLTool/REPLTool.js +44 -0
  1401. package/src/tools/REPLTool/constants.js +43 -0
  1402. package/src/tools/REPLTool/primitiveTools.js +36 -0
  1403. package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.js +112 -0
  1404. package/src/tools/ReadMcpResourceTool/UI.js +24 -0
  1405. package/src/tools/ReadMcpResourceTool/prompt.js +15 -0
  1406. package/src/tools/RemoteTriggerTool/RemoteTriggerTool.js +142 -0
  1407. package/src/tools/RemoteTriggerTool/UI.js +12 -0
  1408. package/src/tools/RemoteTriggerTool/prompt.js +12 -0
  1409. package/src/tools/ReviewArtifactTool/ReviewArtifactTool.js +51 -0
  1410. package/src/tools/ScheduleCronTool/CronCreateTool.js +120 -0
  1411. package/src/tools/ScheduleCronTool/CronDeleteTool.js +74 -0
  1412. package/src/tools/ScheduleCronTool/CronListTool.js +77 -0
  1413. package/src/tools/ScheduleCronTool/UI.js +29 -0
  1414. package/src/tools/ScheduleCronTool/prompt.js +115 -0
  1415. package/src/tools/SendMessageTool/SendMessageTool.js +673 -0
  1416. package/src/tools/SendMessageTool/UI.js +24 -0
  1417. package/src/tools/SendMessageTool/constants.js +1 -0
  1418. package/src/tools/SendMessageTool/prompt.js +47 -0
  1419. package/src/tools/SendUserFileTool/SendUserFileTool.js +35 -0
  1420. package/src/tools/SendUserFileTool/prompt.js +5 -0
  1421. package/src/tools/SkillTool/SkillTool.js +825 -0
  1422. package/src/tools/SkillTool/UI.js +61 -0
  1423. package/src/tools/SkillTool/constants.js +1 -0
  1424. package/src/tools/SkillTool/prompt.js +184 -0
  1425. package/src/tools/SleepTool/SleepTool.js +42 -0
  1426. package/src/tools/SleepTool/prompt.js +14 -0
  1427. package/src/tools/SnipTool/SnipTool.js +47 -0
  1428. package/src/tools/SnipTool/prompt.js +5 -0
  1429. package/src/tools/SubscribePRTool/SubscribePRTool.js +49 -0
  1430. package/src/tools/SuggestBackgroundPRTool/SuggestBackgroundPRTool.js +44 -0
  1431. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.js +138 -0
  1432. package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +1 -1
  1433. package/src/tools/TaskCreateTool/TaskCreateTool.js +104 -0
  1434. package/src/tools/TaskCreateTool/constants.js +1 -0
  1435. package/src/tools/TaskCreateTool/prompt.js +52 -0
  1436. package/src/tools/TaskGetTool/TaskGetTool.js +106 -0
  1437. package/src/tools/TaskGetTool/constants.js +1 -0
  1438. package/src/tools/TaskGetTool/prompt.js +23 -0
  1439. package/src/tools/TaskListTool/TaskListTool.js +89 -0
  1440. package/src/tools/TaskListTool/constants.js +1 -0
  1441. package/src/tools/TaskListTool/prompt.js +44 -0
  1442. package/src/tools/TaskOutputTool/TaskOutputTool.js +536 -0
  1443. package/src/tools/TaskOutputTool/constants.js +1 -0
  1444. package/src/tools/TaskStopTool/TaskStopTool.js +110 -0
  1445. package/src/tools/TaskStopTool/UI.js +31 -0
  1446. package/src/tools/TaskStopTool/prompt.js +7 -0
  1447. package/src/tools/TaskUpdateTool/TaskUpdateTool.js +301 -0
  1448. package/src/tools/TaskUpdateTool/constants.js +1 -0
  1449. package/src/tools/TaskUpdateTool/prompt.js +76 -0
  1450. package/src/tools/TeamCreateTool/TeamCreateTool.js +177 -0
  1451. package/src/tools/TeamCreateTool/UI.js +4 -0
  1452. package/src/tools/TeamCreateTool/constants.js +1 -0
  1453. package/src/tools/TeamCreateTool/prompt.js +113 -0
  1454. package/src/tools/TeamDeleteTool/TeamDeleteTool.js +102 -0
  1455. package/src/tools/TeamDeleteTool/UI.js +13 -0
  1456. package/src/tools/TeamDeleteTool/constants.js +1 -0
  1457. package/src/tools/TeamDeleteTool/prompt.js +16 -0
  1458. package/src/tools/TerminalCaptureTool/TerminalCaptureTool.js +47 -0
  1459. package/src/tools/TerminalCaptureTool/prompt.js +11 -0
  1460. package/src/tools/TodoWriteTool/TodoWriteTool.js +99 -0
  1461. package/src/tools/TodoWriteTool/constants.js +1 -0
  1462. package/src/tools/TodoWriteTool/prompt.js +181 -0
  1463. package/src/tools/ToolSearchTool/ToolSearchTool.js +357 -0
  1464. package/src/tools/ToolSearchTool/constants.js +1 -0
  1465. package/src/tools/ToolSearchTool/prompt.js +97 -0
  1466. package/src/tools/TungstenTool/TungstenLiveMonitor.js +7 -0
  1467. package/src/tools/TungstenTool/TungstenTool.js +3 -0
  1468. package/src/tools/VerifyPlanExecutionTool/VerifyPlanExecutionTool.js +45 -0
  1469. package/src/tools/VerifyPlanExecutionTool/constants.js +2 -0
  1470. package/src/tools/WebBrowserTool/WebBrowserPanel.js +5 -0
  1471. package/src/tools/WebBrowserTool/WebBrowserTool.js +58 -0
  1472. package/src/tools/WebFetchTool/UI.js +31 -0
  1473. package/src/tools/WebFetchTool/WebFetchTool.js +246 -0
  1474. package/src/tools/WebFetchTool/preapproved.js +154 -0
  1475. package/src/tools/WebFetchTool/prompt.js +39 -0
  1476. package/src/tools/WebFetchTool/utils.js +368 -0
  1477. package/src/tools/WebSearchTool/UI.js +67 -0
  1478. package/src/tools/WebSearchTool/WebSearchTool.js +396 -0
  1479. package/src/tools/WebSearchTool/prompt.js +32 -0
  1480. package/src/tools/WorkflowTool/WorkflowPermissionRequest.js +7 -0
  1481. package/src/tools/WorkflowTool/WorkflowTool.js +51 -0
  1482. package/src/tools/WorkflowTool/bundled/index.js +5 -0
  1483. package/src/tools/WorkflowTool/constants.js +1 -0
  1484. package/src/tools/WorkflowTool/createWorkflowCommand.js +5 -0
  1485. package/src/tools/shared/gitOperationTracking.js +220 -0
  1486. package/src/tools/shared/spawnMultiAgent.js +805 -0
  1487. package/src/tools/testing/TestingPermissionTool.js +72 -0
  1488. package/src/tools/utils.js +24 -0
  1489. package/src/tools.js +365 -0
  1490. package/src/types/command.js +8 -0
  1491. package/src/types/connectorText.js +3 -0
  1492. package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.js +673 -0
  1493. package/src/types/generated/events_mono/common/v1/auth.js +49 -0
  1494. package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.js +147 -0
  1495. package/src/types/generated/google/protobuf/timestamp.js +38 -0
  1496. package/src/types/hooks.js +153 -0
  1497. package/src/types/ids.js +27 -0
  1498. package/src/types/logs.js +11 -0
  1499. package/src/types/permissions.js +25 -0
  1500. package/src/types/plugin.js +72 -0
  1501. package/src/types/textInputTypes.js +20 -0
  1502. package/src/upstreamproxy/relay.js +346 -0
  1503. package/src/upstreamproxy/upstreamproxy.js +234 -0
  1504. package/src/utils/CircularBuffer.js +75 -0
  1505. package/src/utils/Cursor.js +1229 -0
  1506. package/src/utils/QueryGuard.js +115 -0
  1507. package/src/utils/Shell.js +374 -0
  1508. package/src/utils/ShellCommand.js +336 -0
  1509. package/src/utils/abortController.js +74 -0
  1510. package/src/utils/activityManager.js +127 -0
  1511. package/src/utils/advisor.js +77 -0
  1512. package/src/utils/agentContext.js +91 -0
  1513. package/src/utils/agentId.js +83 -0
  1514. package/src/utils/agentSwarmsEnabled.js +37 -0
  1515. package/src/utils/agenticSessionSearch.js +255 -0
  1516. package/src/utils/analyzeContext.js +846 -0
  1517. package/src/utils/ansiToPng.js +259 -0
  1518. package/src/utils/ansiToSvg.js +207 -0
  1519. package/src/utils/api.js +555 -0
  1520. package/src/utils/apiPreconnect.js +62 -0
  1521. package/src/utils/appleTerminalBackup.js +95 -0
  1522. package/src/utils/argumentSubstitution.js +114 -0
  1523. package/src/utils/array.js +12 -0
  1524. package/src/utils/asciicast.js +200 -0
  1525. package/src/utils/attachments.js +2518 -0
  1526. package/src/utils/attribution.js +308 -0
  1527. package/src/utils/auth.js +1598 -0
  1528. package/src/utils/authFileDescriptor.js +152 -0
  1529. package/src/utils/authPortable.js +14 -0
  1530. package/src/utils/autoModeDenials.js +15 -0
  1531. package/src/utils/autoRunIssue.js +113 -0
  1532. package/src/utils/autoUpdater.js +457 -0
  1533. package/src/utils/aws.js +44 -0
  1534. package/src/utils/awsAuthStatusManager.js +66 -0
  1535. package/src/utils/background/remote/preconditions.js +175 -0
  1536. package/src/utils/background/remote/remoteSession.js +53 -0
  1537. package/src/utils/backgroundHousekeeping.js +64 -0
  1538. package/src/utils/bash/ParsedCommand.js +241 -0
  1539. package/src/utils/bash/ShellSnapshot.js +489 -0
  1540. package/src/utils/bash/ast.js +2590 -0
  1541. package/src/utils/bash/bashParser.js +4355 -0
  1542. package/src/utils/bash/bashPipeCommand.js +249 -0
  1543. package/src/utils/bash/commands.js +1131 -0
  1544. package/src/utils/bash/heredoc.js +647 -0
  1545. package/src/utils/bash/parser.js +195 -0
  1546. package/src/utils/bash/prefix.js +154 -0
  1547. package/src/utils/bash/registry.js +23 -0
  1548. package/src/utils/bash/shellCompletion.js +196 -0
  1549. package/src/utils/bash/shellPrefix.js +25 -0
  1550. package/src/utils/bash/shellQuote.js +253 -0
  1551. package/src/utils/bash/shellQuoting.js +106 -0
  1552. package/src/utils/bash/specs/alias.js +11 -0
  1553. package/src/utils/bash/specs/index.js +16 -0
  1554. package/src/utils/bash/specs/nohup.js +10 -0
  1555. package/src/utils/bash/specs/pyright.js +88 -0
  1556. package/src/utils/bash/specs/sleep.js +10 -0
  1557. package/src/utils/bash/specs/srun.js +28 -0
  1558. package/src/utils/bash/specs/time.js +10 -0
  1559. package/src/utils/bash/specs/timeout.js +17 -0
  1560. package/src/utils/bash/treeSitterAnalysis.js +407 -0
  1561. package/src/utils/betas.js +331 -0
  1562. package/src/utils/billing.js +54 -0
  1563. package/src/utils/binaryCheck.js +40 -0
  1564. package/src/utils/browser.js +58 -0
  1565. package/src/utils/bufferedWriter.js +77 -0
  1566. package/src/utils/bundledMode.js +19 -0
  1567. package/src/utils/businessDb.js +390 -0
  1568. package/src/utils/caCerts.js +91 -0
  1569. package/src/utils/caCertsConfig.js +77 -0
  1570. package/src/utils/cachePaths.js +28 -0
  1571. package/src/utils/classifierApprovals.js +66 -0
  1572. package/src/utils/classifierApprovalsHook.js +10 -0
  1573. package/src/utils/claudeDesktop.js +108 -0
  1574. package/src/utils/claudeInChrome/chromeNativeHost.js +416 -0
  1575. package/src/utils/claudeInChrome/common.js +466 -0
  1576. package/src/utils/claudeInChrome/mcpServer.js +237 -0
  1577. package/src/utils/claudeInChrome/prompt.js +79 -0
  1578. package/src/utils/claudeInChrome/setup.js +304 -0
  1579. package/src/utils/claudeInChrome/setupPortable.js +172 -0
  1580. package/src/utils/claudeInChrome/toolRendering.js +235 -0
  1581. package/src/utils/claudemd.js +1052 -0
  1582. package/src/utils/cleanup.js +514 -0
  1583. package/src/utils/cleanupRegistry.js +22 -0
  1584. package/src/utils/cliArgs.js +53 -0
  1585. package/src/utils/cliHighlight.js +45 -0
  1586. package/src/utils/codeIndexing.js +149 -0
  1587. package/src/utils/collapseBackgroundBashNotifications.js +70 -0
  1588. package/src/utils/collapseHookSummaries.js +48 -0
  1589. package/src/utils/collapseReadSearch.js +869 -0
  1590. package/src/utils/collapseTeammateShutdowns.js +44 -0
  1591. package/src/utils/combinedAbortSignal.js +40 -0
  1592. package/src/utils/commandLifecycle.js +7 -0
  1593. package/src/utils/commitAttribution.js +718 -0
  1594. package/src/utils/completionCache.js +138 -0
  1595. package/src/utils/computerUse/appNames.js +170 -0
  1596. package/src/utils/computerUse/cleanup.js +65 -0
  1597. package/src/utils/computerUse/common.js +56 -0
  1598. package/src/utils/computerUse/computerUseLock.js +183 -0
  1599. package/src/utils/computerUse/drainRunLoop.js +71 -0
  1600. package/src/utils/computerUse/escHotkey.js +53 -0
  1601. package/src/utils/computerUse/executor.js +480 -0
  1602. package/src/utils/computerUse/gates.js +55 -0
  1603. package/src/utils/computerUse/hostAdapter.js +62 -0
  1604. package/src/utils/computerUse/inputLoader.js +25 -0
  1605. package/src/utils/computerUse/mcpServer.js +84 -0
  1606. package/src/utils/computerUse/setup.js +42 -0
  1607. package/src/utils/computerUse/swiftLoader.js +18 -0
  1608. package/src/utils/computerUse/toolRendering.js +101 -0
  1609. package/src/utils/computerUse/wrapper.js +317 -0
  1610. package/src/utils/concurrentSessions.js +179 -0
  1611. package/src/utils/config.js +1078 -0
  1612. package/src/utils/configConstants.js +18 -0
  1613. package/src/utils/contentArray.js +45 -0
  1614. package/src/utils/context.js +185 -0
  1615. package/src/utils/contextAnalysis.js +171 -0
  1616. package/src/utils/contextSuggestions.js +158 -0
  1617. package/src/utils/controlMessageCompat.js +31 -0
  1618. package/src/utils/conversationRecovery.js +434 -0
  1619. package/src/utils/cron.js +260 -0
  1620. package/src/utils/cronJitterConfig.js +62 -0
  1621. package/src/utils/cronScheduler.js +388 -0
  1622. package/src/utils/cronTasks.js +328 -0
  1623. package/src/utils/cronTasksLock.js +159 -0
  1624. package/src/utils/crossProjectResume.js +46 -0
  1625. package/src/utils/crypto.js +13 -0
  1626. package/src/utils/cwd.js +29 -0
  1627. package/src/utils/debug.js +220 -0
  1628. package/src/utils/debugFilter.js +125 -0
  1629. package/src/utils/deepLink/banner.js +103 -0
  1630. package/src/utils/deepLink/parseDeepLink.js +138 -0
  1631. package/src/utils/deepLink/protocolHandler.js +119 -0
  1632. package/src/utils/deepLink/registerProtocol.js +291 -0
  1633. package/src/utils/deepLink/terminalLauncher.js +455 -0
  1634. package/src/utils/deepLink/terminalPreference.js +51 -0
  1635. package/src/utils/desktopDeepLink.js +208 -0
  1636. package/src/utils/detectRepository.js +157 -0
  1637. package/src/utils/diagLogs.js +74 -0
  1638. package/src/utils/diff.js +108 -0
  1639. package/src/utils/directMemberMessage.js +34 -0
  1640. package/src/utils/displayTags.js +46 -0
  1641. package/src/utils/doctorContextWarnings.js +179 -0
  1642. package/src/utils/doctorDiagnostic.js +494 -0
  1643. package/src/utils/dxt/helpers.js +64 -0
  1644. package/src/utils/dxt/zip.js +167 -0
  1645. package/src/utils/earlyInput.js +166 -0
  1646. package/src/utils/editor.js +163 -0
  1647. package/src/utils/effort.js +271 -0
  1648. package/src/utils/embeddedTools.js +26 -0
  1649. package/src/utils/employeeChat.js +271 -0
  1650. package/src/utils/employeeDb.js +326 -0
  1651. package/src/utils/env.js +358 -0
  1652. package/src/utils/envDynamic.js +130 -0
  1653. package/src/utils/envUtils.js +161 -0
  1654. package/src/utils/envValidation.js +26 -0
  1655. package/src/utils/errorLogSink.js +196 -0
  1656. package/src/utils/errors.js +207 -0
  1657. package/src/utils/exampleCommands.js +165 -0
  1658. package/src/utils/execFileNoThrow.js +93 -0
  1659. package/src/utils/execFileNoThrowPortable.js +49 -0
  1660. package/src/utils/execSyncWrapper.js +6 -0
  1661. package/src/utils/exportRenderer.js +71 -0
  1662. package/src/utils/extraUsage.js +19 -0
  1663. package/src/utils/fastMode.js +393 -0
  1664. package/src/utils/file.js +467 -0
  1665. package/src/utils/fileHistory.js +851 -0
  1666. package/src/utils/fileOperationAnalytics.js +45 -0
  1667. package/src/utils/filePersistence/filePersistence.js +212 -0
  1668. package/src/utils/filePersistence/outputsScanner.js +104 -0
  1669. package/src/utils/filePersistence/types.js +4 -0
  1670. package/src/utils/fileRead.js +81 -0
  1671. package/src/utils/fileReadCache.js +78 -0
  1672. package/src/utils/fileStateCache.js +99 -0
  1673. package/src/utils/findExecutable.js +13 -0
  1674. package/src/utils/fingerprint.js +58 -0
  1675. package/src/utils/forkedAgent.js +410 -0
  1676. package/src/utils/format.js +238 -0
  1677. package/src/utils/formatBriefTimestamp.js +72 -0
  1678. package/src/utils/fpsTracker.js +34 -0
  1679. package/src/utils/frontmatterParser.js +260 -0
  1680. package/src/utils/fsOperations.js +555 -0
  1681. package/src/utils/fullscreen.js +194 -0
  1682. package/src/utils/generatedFiles.js +122 -0
  1683. package/src/utils/generators.js +67 -0
  1684. package/src/utils/genericProcessUtils.js +155 -0
  1685. package/src/utils/getWorktreePaths.js +56 -0
  1686. package/src/utils/getWorktreePathsPortable.js +23 -0
  1687. package/src/utils/ghPrStatus.js +71 -0
  1688. package/src/utils/git/gitConfigParser.js +226 -0
  1689. package/src/utils/git/gitFilesystem.js +606 -0
  1690. package/src/utils/git/gitignore.js +84 -0
  1691. package/src/utils/git.js +725 -0
  1692. package/src/utils/gitDiff.js +395 -0
  1693. package/src/utils/gitSettings.js +18 -0
  1694. package/src/utils/github/ghAuthStatus.js +23 -0
  1695. package/src/utils/githubRepoPathMapping.js +135 -0
  1696. package/src/utils/glob.js +90 -0
  1697. package/src/utils/gracefulShutdown.js +447 -0
  1698. package/src/utils/groupToolUses.js +126 -0
  1699. package/src/utils/handlePromptSubmit.js +398 -0
  1700. package/src/utils/hash.js +44 -0
  1701. package/src/utils/headlessProfiler.js +147 -0
  1702. package/src/utils/heapDumpService.js +201 -0
  1703. package/src/utils/heatmap.js +151 -0
  1704. package/src/utils/highlightMatch.js +29 -0
  1705. package/src/utils/hooks/AsyncHookRegistry.js +187 -0
  1706. package/src/utils/hooks/apiQueryHookHelper.js +77 -0
  1707. package/src/utils/hooks/execAgentHook.js +257 -0
  1708. package/src/utils/hooks/execHttpHook.js +184 -0
  1709. package/src/utils/hooks/execPromptHook.js +171 -0
  1710. package/src/utils/hooks/fileChangedWatcher.js +161 -0
  1711. package/src/utils/hooks/hookEvents.js +111 -0
  1712. package/src/utils/hooks/hookHelpers.js +60 -0
  1713. package/src/utils/hooks/hooksConfigManager.js +323 -0
  1714. package/src/utils/hooks/hooksConfigSnapshot.js +114 -0
  1715. package/src/utils/hooks/hooksSettings.js +204 -0
  1716. package/src/utils/hooks/postSamplingHooks.js +39 -0
  1717. package/src/utils/hooks/registerFrontmatterHooks.js +47 -0
  1718. package/src/utils/hooks/registerSkillHooks.js +40 -0
  1719. package/src/utils/hooks/sessionHooks.js +252 -0
  1720. package/src/utils/hooks/skillImprovement.js +211 -0
  1721. package/src/utils/hooks/ssrfGuard.js +258 -0
  1722. package/src/utils/hooks.js +3668 -0
  1723. package/src/utils/horizontalScroll.js +108 -0
  1724. package/src/utils/http.js +120 -0
  1725. package/src/utils/hyperlink.js +28 -0
  1726. package/src/utils/iTermBackup.js +48 -0
  1727. package/src/utils/ide.js +1195 -0
  1728. package/src/utils/idePathConversion.js +66 -0
  1729. package/src/utils/idleTimeout.js +44 -0
  1730. package/src/utils/imagePaste.js +343 -0
  1731. package/src/utils/imageResizer.js +664 -0
  1732. package/src/utils/imageStore.js +150 -0
  1733. package/src/utils/imageValidation.js +92 -0
  1734. package/src/utils/immediateCommand.js +12 -0
  1735. package/src/utils/inProcessTeammateHelpers.js +71 -0
  1736. package/src/utils/ink.js +20 -0
  1737. package/src/utils/intl.js +83 -0
  1738. package/src/utils/jetbrains.js +152 -0
  1739. package/src/utils/json.js +231 -0
  1740. package/src/utils/jsonRead.js +14 -0
  1741. package/src/utils/keyboardShortcuts.js +11 -0
  1742. package/src/utils/lazySchema.js +8 -0
  1743. package/src/utils/listSessionsImpl.js +332 -0
  1744. package/src/utils/localInstaller.js +130 -0
  1745. package/src/utils/lockfile.js +30 -0
  1746. package/src/utils/log.js +280 -0
  1747. package/src/utils/logoV2Utils.js +256 -0
  1748. package/src/utils/mailbox.js +50 -0
  1749. package/src/utils/managedEnv.js +160 -0
  1750. package/src/utils/managedEnvConstants.js +185 -0
  1751. package/src/utils/markdown.js +315 -0
  1752. package/src/utils/markdownConfigLoader.js +480 -0
  1753. package/src/utils/mcp/dateTimeParser.js +102 -0
  1754. package/src/utils/mcp/elicitationValidation.js +259 -0
  1755. package/src/utils/mcpInstructionsDelta.js +97 -0
  1756. package/src/utils/mcpOutputStorage.js +159 -0
  1757. package/src/utils/mcpValidation.js +165 -0
  1758. package/src/utils/mcpWebSocketTransport.js +180 -0
  1759. package/src/utils/memoize.js +205 -0
  1760. package/src/utils/memory/types.js +9 -0
  1761. package/src/utils/memory/versions.js +7 -0
  1762. package/src/utils/memoryFileDetection.js +245 -0
  1763. package/src/utils/messagePredicates.js +6 -0
  1764. package/src/utils/messageQueueManager.js +430 -0
  1765. package/src/utils/messages/mappers.js +240 -0
  1766. package/src/utils/messages/systemInit.js +72 -0
  1767. package/src/utils/messages.js +4286 -0
  1768. package/src/utils/model/agent.js +128 -0
  1769. package/src/utils/model/aliases.js +21 -0
  1770. package/src/utils/model/antModels.js +25 -0
  1771. package/src/utils/model/bedrock.js +220 -0
  1772. package/src/utils/model/check1mAccess.js +64 -0
  1773. package/src/utils/model/configs.js +86 -0
  1774. package/src/utils/model/contextWindowUpgradeCheck.js +41 -0
  1775. package/src/utils/model/deprecation.js +72 -0
  1776. package/src/utils/model/model.js +533 -0
  1777. package/src/utils/model/modelAllowlist.js +148 -0
  1778. package/src/utils/model/modelCapabilities.js +105 -0
  1779. package/src/utils/model/modelOptions.js +450 -0
  1780. package/src/utils/model/modelStrings.js +144 -0
  1781. package/src/utils/model/modelSupportOverrides.js +40 -0
  1782. package/src/utils/model/providers.js +35 -0
  1783. package/src/utils/model/validateModel.js +131 -0
  1784. package/src/utils/modelCost.js +160 -0
  1785. package/src/utils/modifiers.js +39 -0
  1786. package/src/utils/mtls.js +132 -0
  1787. package/src/utils/nativeInstaller/download.js +370 -0
  1788. package/src/utils/nativeInstaller/index.js +8 -0
  1789. package/src/utils/nativeInstaller/installer.js +1395 -0
  1790. package/src/utils/nativeInstaller/packageManagers.js +258 -0
  1791. package/src/utils/nativeInstaller/pidLock.js +347 -0
  1792. package/src/utils/notebook.js +176 -0
  1793. package/src/utils/objectGroupBy.js +15 -0
  1794. package/src/utils/pasteStore.js +93 -0
  1795. package/src/utils/path.js +140 -0
  1796. package/src/utils/pdf.js +236 -0
  1797. package/src/utils/pdfUtils.js +61 -0
  1798. package/src/utils/peerAddress.js +20 -0
  1799. package/src/utils/permissions/PermissionMode.js +95 -0
  1800. package/src/utils/permissions/PermissionPromptToolResultSchema.js +85 -0
  1801. package/src/utils/permissions/PermissionResult.js +11 -0
  1802. package/src/utils/permissions/PermissionRule.js +19 -0
  1803. package/src/utils/permissions/PermissionUpdate.js +268 -0
  1804. package/src/utils/permissions/PermissionUpdateSchema.js +61 -0
  1805. package/src/utils/permissions/autoModeState.js +31 -0
  1806. package/src/utils/permissions/bashClassifier.js +30 -0
  1807. package/src/utils/permissions/bypassPermissionsKillswitch.js +115 -0
  1808. package/src/utils/permissions/classifierDecision.js +86 -0
  1809. package/src/utils/permissions/classifierShared.js +28 -0
  1810. package/src/utils/permissions/dangerousPatterns.js +78 -0
  1811. package/src/utils/permissions/denialTracking.js +34 -0
  1812. package/src/utils/permissions/filesystem.js +1411 -0
  1813. package/src/utils/permissions/getNextPermissionMode.js +74 -0
  1814. package/src/utils/permissions/pathValidation.js +351 -0
  1815. package/src/utils/permissions/permissionExplainer.js +188 -0
  1816. package/src/utils/permissions/permissionRuleParser.js +175 -0
  1817. package/src/utils/permissions/permissionSetup.js +1162 -0
  1818. package/src/utils/permissions/permissions.js +1063 -0
  1819. package/src/utils/permissions/permissionsLoader.js +217 -0
  1820. package/src/utils/permissions/shadowedRuleDetection.js +149 -0
  1821. package/src/utils/permissions/shellRuleMatching.js +174 -0
  1822. package/src/utils/permissions/yoloClassifier.js +1193 -0
  1823. package/src/utils/planModeV2.js +75 -0
  1824. package/src/utils/plans.js +334 -0
  1825. package/src/utils/platform.js +122 -0
  1826. package/src/utils/plugins/addDirPluginSettings.js +53 -0
  1827. package/src/utils/plugins/cacheUtils.js +174 -0
  1828. package/src/utils/plugins/dependencyResolver.js +244 -0
  1829. package/src/utils/plugins/fetchTelemetry.js +108 -0
  1830. package/src/utils/plugins/gitAvailability.js +65 -0
  1831. package/src/utils/plugins/headlessPluginInstall.js +136 -0
  1832. package/src/utils/plugins/hintRecommendation.js +136 -0
  1833. package/src/utils/plugins/installCounts.js +221 -0
  1834. package/src/utils/plugins/installedPluginsManager.js +1003 -0
  1835. package/src/utils/plugins/loadPluginAgents.js +219 -0
  1836. package/src/utils/plugins/loadPluginCommands.js +595 -0
  1837. package/src/utils/plugins/loadPluginHooks.js +239 -0
  1838. package/src/utils/plugins/loadPluginOutputStyles.js +112 -0
  1839. package/src/utils/plugins/lspPluginIntegration.js +293 -0
  1840. package/src/utils/plugins/lspRecommendation.js +278 -0
  1841. package/src/utils/plugins/managedPlugins.js +26 -0
  1842. package/src/utils/plugins/marketplaceHelpers.js +470 -0
  1843. package/src/utils/plugins/marketplaceManager.js +1939 -0
  1844. package/src/utils/plugins/mcpPluginIntegration.js +465 -0
  1845. package/src/utils/plugins/mcpbHandler.js +708 -0
  1846. package/src/utils/plugins/officialMarketplace.js +19 -0
  1847. package/src/utils/plugins/officialMarketplaceGcs.js +202 -0
  1848. package/src/utils/plugins/officialMarketplaceStartupCheck.js +344 -0
  1849. package/src/utils/plugins/orphanedPluginFilter.js +96 -0
  1850. package/src/utils/plugins/parseMarketplaceInput.js +143 -0
  1851. package/src/utils/plugins/performStartupChecks.js +66 -0
  1852. package/src/utils/plugins/pluginAutoupdate.js +210 -0
  1853. package/src/utils/plugins/pluginBlocklist.js +93 -0
  1854. package/src/utils/plugins/pluginDirectories.js +170 -0
  1855. package/src/utils/plugins/pluginFlagging.js +173 -0
  1856. package/src/utils/plugins/pluginIdentifier.js +78 -0
  1857. package/src/utils/plugins/pluginInstallationHelpers.js +400 -0
  1858. package/src/utils/plugins/pluginLoader.js +2426 -0
  1859. package/src/utils/plugins/pluginOptionsStorage.js +311 -0
  1860. package/src/utils/plugins/pluginPolicy.js +18 -0
  1861. package/src/utils/plugins/pluginStartupCheck.js +261 -0
  1862. package/src/utils/plugins/pluginVersioning.js +128 -0
  1863. package/src/utils/plugins/reconciler.js +181 -0
  1864. package/src/utils/plugins/refresh.js +162 -0
  1865. package/src/utils/plugins/schemas.js +1283 -0
  1866. package/src/utils/plugins/validatePlugin.js +765 -0
  1867. package/src/utils/plugins/walkPluginMarkdown.js +49 -0
  1868. package/src/utils/plugins/zipCache.js +346 -0
  1869. package/src/utils/plugins/zipCacheAdapters.js +133 -0
  1870. package/src/utils/powershell/dangerousCmdlets.js +174 -0
  1871. package/src/utils/powershell/parser.js +1357 -0
  1872. package/src/utils/powershell/staticPrefix.js +277 -0
  1873. package/src/utils/preflightChecks.js +147 -0
  1874. package/src/utils/privacyLevel.js +49 -0
  1875. package/src/utils/process.js +56 -0
  1876. package/src/utils/processUserInput/processBashCommand.js +118 -0
  1877. package/src/utils/processUserInput/processSlashCommand.js +845 -0
  1878. package/src/utils/processUserInput/processTextPrompt.js +68 -0
  1879. package/src/utils/processUserInput/processUserInput.js +344 -0
  1880. package/src/utils/profilerBase.js +32 -0
  1881. package/src/utils/promptCategory.js +39 -0
  1882. package/src/utils/promptEditor.js +151 -0
  1883. package/src/utils/promptShellExecution.js +117 -0
  1884. package/src/utils/protectedNamespace.js +4 -0
  1885. package/src/utils/proxy.js +345 -0
  1886. package/src/utils/queryContext.js +110 -0
  1887. package/src/utils/queryHelpers.js +436 -0
  1888. package/src/utils/queryProfiler.js +242 -0
  1889. package/src/utils/queueProcessor.js +70 -0
  1890. package/src/utils/readEditContext.js +176 -0
  1891. package/src/utils/readFileInRange.js +278 -0
  1892. package/src/utils/releaseNotes.js +307 -0
  1893. package/src/utils/renderOptions.js +67 -0
  1894. package/src/utils/ripgrep.js +521 -0
  1895. package/src/utils/sandbox/sandbox-adapter.js +750 -0
  1896. package/src/utils/sandbox/sandbox-ui-utils.js +11 -0
  1897. package/src/utils/sanitization.js +72 -0
  1898. package/src/utils/screenshotClipboard.js +89 -0
  1899. package/src/utils/sdkEventQueue.js +49 -0
  1900. package/src/utils/secureStorage/fallbackStorage.js +59 -0
  1901. package/src/utils/secureStorage/index.js +13 -0
  1902. package/src/utils/secureStorage/keychainPrefetch.js +91 -0
  1903. package/src/utils/secureStorage/macOsKeychainHelpers.js +91 -0
  1904. package/src/utils/secureStorage/macOsKeychainStorage.js +192 -0
  1905. package/src/utils/secureStorage/plainTextStorage.js +81 -0
  1906. package/src/utils/semanticBoolean.js +23 -0
  1907. package/src/utils/semanticNumber.js +34 -0
  1908. package/src/utils/semver.js +51 -0
  1909. package/src/utils/sequential.js +43 -0
  1910. package/src/utils/sessionActivity.js +120 -0
  1911. package/src/utils/sessionEnvVars.js +18 -0
  1912. package/src/utils/sessionEnvironment.js +131 -0
  1913. package/src/utils/sessionFileAccessHooks.js +205 -0
  1914. package/src/utils/sessionIngressAuth.js +113 -0
  1915. package/src/utils/sessionRestore.js +357 -0
  1916. package/src/utils/sessionStart.js +165 -0
  1917. package/src/utils/sessionState.js +76 -0
  1918. package/src/utils/sessionStorage.js +4162 -0
  1919. package/src/utils/sessionStoragePortable.js +665 -0
  1920. package/src/utils/sessionTitle.js +120 -0
  1921. package/src/utils/sessionUrl.js +50 -0
  1922. package/src/utils/set.js +50 -0
  1923. package/src/utils/settings/allErrors.js +29 -0
  1924. package/src/utils/settings/applySettingsChange.js +65 -0
  1925. package/src/utils/settings/changeDetector.js +409 -0
  1926. package/src/utils/settings/constants.js +166 -0
  1927. package/src/utils/settings/internalWrites.js +33 -0
  1928. package/src/utils/settings/managedPath.js +29 -0
  1929. package/src/utils/settings/mdm/constants.js +62 -0
  1930. package/src/utils/settings/mdm/rawRead.js +97 -0
  1931. package/src/utils/settings/mdm/settings.js +254 -0
  1932. package/src/utils/settings/permissionValidation.js +224 -0
  1933. package/src/utils/settings/pluginOnlyPolicy.js +53 -0
  1934. package/src/utils/settings/schemaOutput.js +7 -0
  1935. package/src/utils/settings/settings.js +791 -0
  1936. package/src/utils/settings/settingsCache.js +47 -0
  1937. package/src/utils/settings/toolValidationConfig.js +76 -0
  1938. package/src/utils/settings/types.js +846 -0
  1939. package/src/utils/settings/validateEditTool.js +34 -0
  1940. package/src/utils/settings/validation.js +192 -0
  1941. package/src/utils/settings/validationTips.js +111 -0
  1942. package/src/utils/shell/bashProvider.js +202 -0
  1943. package/src/utils/shell/outputLimits.js +7 -0
  1944. package/src/utils/shell/powershellDetection.js +96 -0
  1945. package/src/utils/shell/powershellProvider.js +104 -0
  1946. package/src/utils/shell/prefix.js +246 -0
  1947. package/src/utils/shell/readOnlyCommandValidation.js +1776 -0
  1948. package/src/utils/shell/resolveDefaultShell.js +13 -0
  1949. package/src/utils/shell/shellProvider.js +2 -0
  1950. package/src/utils/shell/shellToolUtils.js +21 -0
  1951. package/src/utils/shell/specPrefix.js +198 -0
  1952. package/src/utils/shellConfig.js +136 -0
  1953. package/src/utils/sideQuery.js +134 -0
  1954. package/src/utils/sideQuestion.js +121 -0
  1955. package/src/utils/signal.js +34 -0
  1956. package/src/utils/sinks.js +15 -0
  1957. package/src/utils/skills/skillChangeDetector.js +264 -0
  1958. package/src/utils/slashCommandParsing.js +46 -0
  1959. package/src/utils/sleep.js +72 -0
  1960. package/src/utils/sliceAnsi.js +74 -0
  1961. package/src/utils/slowOperations.js +216 -0
  1962. package/src/utils/standaloneAgent.js +20 -0
  1963. package/src/utils/startupProfiler.js +149 -0
  1964. package/src/utils/staticRender.js +104 -0
  1965. package/src/utils/stats.js +802 -0
  1966. package/src/utils/statsCache.js +330 -0
  1967. package/src/utils/status.js +359 -0
  1968. package/src/utils/statusNoticeDefinitions.js +123 -0
  1969. package/src/utils/statusNoticeHelpers.js +15 -0
  1970. package/src/utils/stream.js +73 -0
  1971. package/src/utils/streamJsonStdoutGuard.js +107 -0
  1972. package/src/utils/streamlinedTransform.js +162 -0
  1973. package/src/utils/stringUtils.js +202 -0
  1974. package/src/utils/subprocessEnv.js +87 -0
  1975. package/src/utils/suggestions/commandSuggestions.js +458 -0
  1976. package/src/utils/suggestions/directoryCompletion.js +191 -0
  1977. package/src/utils/suggestions/shellHistoryCompletion.js +95 -0
  1978. package/src/utils/suggestions/skillUsageTracking.js +50 -0
  1979. package/src/utils/suggestions/slackChannelSuggestions.js +169 -0
  1980. package/src/utils/swarm/It2SetupPrompt.js +386 -0
  1981. package/src/utils/swarm/backends/ITermBackend.js +276 -0
  1982. package/src/utils/swarm/backends/InProcessBackend.js +237 -0
  1983. package/src/utils/swarm/backends/PaneBackendExecutor.js +250 -0
  1984. package/src/utils/swarm/backends/TmuxBackend.js +574 -0
  1985. package/src/utils/swarm/backends/detection.js +112 -0
  1986. package/src/utils/swarm/backends/it2Setup.js +185 -0
  1987. package/src/utils/swarm/backends/registry.js +369 -0
  1988. package/src/utils/swarm/backends/teammateModeSnapshot.js +68 -0
  1989. package/src/utils/swarm/backends/types.js +9 -0
  1990. package/src/utils/swarm/constants.js +29 -0
  1991. package/src/utils/swarm/inProcessRunner.js +1021 -0
  1992. package/src/utils/swarm/leaderPermissionBridge.js +31 -0
  1993. package/src/utils/swarm/permissionSync.js +667 -0
  1994. package/src/utils/swarm/reconnection.js +82 -0
  1995. package/src/utils/swarm/spawnInProcess.js +218 -0
  1996. package/src/utils/swarm/spawnUtils.js +123 -0
  1997. package/src/utils/swarm/teamHelpers.js +484 -0
  1998. package/src/utils/swarm/teammateInit.js +87 -0
  1999. package/src/utils/swarm/teammateLayoutManager.js +82 -0
  2000. package/src/utils/swarm/teammateModel.js +9 -0
  2001. package/src/utils/swarm/teammatePromptAddendum.js +17 -0
  2002. package/src/utils/systemDirectories.js +51 -0
  2003. package/src/utils/systemPrompt.js +88 -0
  2004. package/src/utils/systemPromptType.js +9 -0
  2005. package/src/utils/systemTheme.js +108 -0
  2006. package/src/utils/taggedId.js +49 -0
  2007. package/src/utils/task/TaskOutput.js +320 -0
  2008. package/src/utils/task/diskOutput.js +387 -0
  2009. package/src/utils/task/framework.js +236 -0
  2010. package/src/utils/task/outputFormatting.js +24 -0
  2011. package/src/utils/task/sdkProgress.js +24 -0
  2012. package/src/utils/taskSummary.js +3 -0
  2013. package/src/utils/tasks.js +672 -0
  2014. package/src/utils/teamDiscovery.js +48 -0
  2015. package/src/utils/teamMemoryOps.js +67 -0
  2016. package/src/utils/teammate.js +237 -0
  2017. package/src/utils/teammateContext.js +56 -0
  2018. package/src/utils/teammateMailbox.js +793 -0
  2019. package/src/utils/telemetry/betaSessionTracing.js +25 -0
  2020. package/src/utils/telemetry/bigqueryExporter.js +17 -0
  2021. package/src/utils/telemetry/events.js +7 -0
  2022. package/src/utils/telemetry/instrumentation.js +16 -0
  2023. package/src/utils/telemetry/logger.js +25 -0
  2024. package/src/utils/telemetry/perfettoTracing.js +882 -0
  2025. package/src/utils/telemetry/pluginTelemetry.js +76 -0
  2026. package/src/utils/telemetry/sessionTracing.js +62 -0
  2027. package/src/utils/telemetry/skillLoadedEvent.js +4 -0
  2028. package/src/utils/telemetryAttributes.js +56 -0
  2029. package/src/utils/teleport/api.js +299 -0
  2030. package/src/utils/teleport/environmentSelection.js +55 -0
  2031. package/src/utils/teleport/environments.js +84 -0
  2032. package/src/utils/teleport/gitBundle.js +192 -0
  2033. package/src/utils/teleport.js +1047 -0
  2034. package/src/utils/tempfile.js +26 -0
  2035. package/src/utils/terminal.js +105 -0
  2036. package/src/utils/terminalPanel.js +155 -0
  2037. package/src/utils/textHighlighting.js +113 -0
  2038. package/src/utils/thaddeusHints.js +142 -0
  2039. package/src/utils/theme.js +525 -0
  2040. package/src/utils/thinking.js +130 -0
  2041. package/src/utils/timeouts.js +35 -0
  2042. package/src/utils/tmuxSocket.js +373 -0
  2043. package/src/utils/todo/types.js +9 -0
  2044. package/src/utils/tokenBudget.js +62 -0
  2045. package/src/utils/tokens.js +223 -0
  2046. package/src/utils/toolErrors.js +101 -0
  2047. package/src/utils/toolPool.js +61 -0
  2048. package/src/utils/toolResultStorage.js +768 -0
  2049. package/src/utils/toolSchemaCache.js +7 -0
  2050. package/src/utils/toolSearch.js +551 -0
  2051. package/src/utils/transcriptSearch.js +200 -0
  2052. package/src/utils/treeify.js +111 -0
  2053. package/src/utils/truncate.js +164 -0
  2054. package/src/utils/udsClient.js +5 -0
  2055. package/src/utils/udsMessaging.js +23 -0
  2056. package/src/utils/ultraplan/ccrSession.js +264 -0
  2057. package/src/utils/ultraplan/keyword.js +122 -0
  2058. package/src/utils/unaryLogging.js +16 -0
  2059. package/src/utils/undercover.js +89 -0
  2060. package/src/utils/user.js +137 -0
  2061. package/src/utils/userAgent.js +9 -0
  2062. package/src/utils/userPromptKeywords.js +21 -0
  2063. package/src/utils/uuid.js +22 -0
  2064. package/src/utils/warningHandler.js +97 -0
  2065. package/src/utils/which.js +75 -0
  2066. package/src/utils/windowsPaths.js +146 -0
  2067. package/src/utils/withResolvers.js +13 -0
  2068. package/src/utils/words.js +793 -0
  2069. package/src/utils/workforceIntent.js +192 -0
  2070. package/src/utils/workloadContext.js +42 -0
  2071. package/src/utils/worktree.js +1142 -0
  2072. package/src/utils/worktreeModeEnabled.js +11 -0
  2073. package/src/utils/xdg.js +52 -0
  2074. package/src/utils/xml.js +15 -0
  2075. package/src/utils/yaml.js +14 -0
  2076. package/src/utils/zodToJsonSchema.js +19 -0
  2077. package/src/vim/motions.js +73 -0
  2078. package/src/vim/operators.js +401 -0
  2079. package/src/vim/textObjects.js +153 -0
  2080. package/src/vim/transitions.js +340 -0
  2081. package/src/vim/types.js +93 -0
  2082. package/src/voice/voiceModeEnabled.js +20 -0
  2083. package/thaddeus-terminal.ts +401 -3
  2084. package/thaddeus.command +1 -1
@@ -0,0 +1,1598 @@
1
+ import chalk from 'chalk';
2
+ import { exec } from 'child_process';
3
+ import { execa } from 'execa';
4
+ import { mkdir, stat } from 'fs/promises';
5
+ import memoize from 'lodash-es/memoize.js';
6
+ import { join } from 'path';
7
+ import { isAuthenticated as isThaddeusAuthenticated } from 'src/services/thaddeusAuth.js';
8
+ import { THADDEUS_PROFILE_SCOPE } from 'src/constants/oauth.js';
9
+ import { logEvent, } from 'src/services/analytics/index.js';
10
+ import { getModelStrings } from 'src/utils/model/modelStrings.js';
11
+ import { getAPIProvider } from 'src/utils/model/providers.js';
12
+ import { getIsNonInteractiveSession, preferThirdPartyAuthentication, } from '../bootstrap/state.js';
13
+ import { getMockSubscriptionType, shouldUseMockSubscription, } from '../services/mockRateLimits.js';
14
+ import { isOAuthTokenExpired, refreshOAuthToken, shouldUseClaudeAIAuth, } from '../services/oauth/client.js';
15
+ import { getOauthProfileFromOauthToken } from '../services/oauth/getOauthProfile.js';
16
+ import { getApiKeyFromFileDescriptor, getOAuthTokenFromFileDescriptor, } from './authFileDescriptor.js';
17
+ import { maybeRemoveApiKeyFromMacOSKeychainThrows, normalizeApiKeyForConfig, } from './authPortable.js';
18
+ import { checkStsCallerIdentity, clearAwsIniCache, isValidAwsStsOutput, } from './aws.js';
19
+ import { AwsAuthStatusManager } from './awsAuthStatusManager.js';
20
+ import { clearBetasCaches } from './betas.js';
21
+ import { checkHasTrustDialogAccepted, getGlobalConfig, saveGlobalConfig, } from './config.js';
22
+ import { logAntError, logForDebugging } from './debug.js';
23
+ import { getClaudeConfigHomeDir, isBareMode, isEnvTruthy, isRunningOnHomespace, } from './envUtils.js';
24
+ import { errorMessage } from './errors.js';
25
+ import { execSyncWithDefaults_DEPRECATED } from './execFileNoThrow.js';
26
+ import * as lockfile from './lockfile.js';
27
+ import { logError } from './log.js';
28
+ import { memoizeWithTTLAsync } from './memoize.js';
29
+ import { getSecureStorage } from './secureStorage/index.js';
30
+ import { clearLegacyApiKeyPrefetch, getLegacyApiKeyPrefetchResult, } from './secureStorage/keychainPrefetch.js';
31
+ import { clearKeychainCache, getMacOsKeychainStorageServiceName, getUsername, } from './secureStorage/macOsKeychainHelpers.js';
32
+ import { getSettings_DEPRECATED, getSettingsForSource, } from './settings/settings.js';
33
+ import { sleep } from './sleep.js';
34
+ import { jsonParse } from './slowOperations.js';
35
+ import { clearToolSchemaCache } from './toolSchemaCache.js';
36
+ /** Default TTL for API key helper cache in milliseconds (5 minutes) */
37
+ const DEFAULT_API_KEY_HELPER_TTL = 5 * 60 * 1000;
38
+ /**
39
+ * CCR and Thaddeus Desktop spawn the CLI with OAuth and should never fall back
40
+ * to the user's ~/.claude/settings.json API-key config (apiKeyHelper,
41
+ * env.ANTHROPIC_API_KEY, env.ANTHROPIC_AUTH_TOKEN). Those settings exist for
42
+ * the user's terminal CLI, not managed sessions. Without this guard, a user
43
+ * who runs `claude` in their terminal with an API key sees every CCD session
44
+ * also use that key — and fail if it's stale/wrong-org.
45
+ */
46
+ function isManagedOAuthContext() {
47
+ return (isEnvTruthy(process.env.THADDEUS_REMOTE) ||
48
+ process.env.THADDEUS_ENTRYPOINT === 'claude-desktop');
49
+ }
50
+ /** Whether we are supporting direct 1P auth. */
51
+ // this code is closely related to getAuthTokenSource
52
+ export function isAnthropicAuthEnabled() {
53
+ // --bare: API-key-only, never OAuth.
54
+ if (isBareMode())
55
+ return false;
56
+ // `claude ssh` remote: ANTHROPIC_UNIX_SOCKET tunnels API calls through a
57
+ // local auth-injecting proxy. The launcher sets THADDEUS_OAUTH_TOKEN as a
58
+ // placeholder iff the local side is a subscriber (so the remote includes the
59
+ // oauth-2025 beta header to match what the proxy will inject). The remote's
60
+ // ~/.claude settings (apiKeyHelper, settings.env.ANTHROPIC_API_KEY) MUST NOT
61
+ // flip this — they'd cause a header mismatch with the proxy and a bogus
62
+ // "invalid x-api-key" from the API. See src/ssh/sshAuthProxy.ts.
63
+ if (process.env.ANTHROPIC_UNIX_SOCKET) {
64
+ return !!process.env.THADDEUS_OAUTH_TOKEN;
65
+ }
66
+ const is3P = isEnvTruthy(process.env.THADDEUS_USE_BEDROCK) ||
67
+ isEnvTruthy(process.env.THADDEUS_USE_VERTEX) ||
68
+ isEnvTruthy(process.env.THADDEUS_USE_FOUNDRY) ||
69
+ isEnvTruthy(process.env.THADDEUS_USE_XAI);
70
+ // Check if user has configured an external API key source
71
+ // This allows externally-provided API keys to work (without requiring proxy configuration)
72
+ const settings = getSettings_DEPRECATED() || {};
73
+ const apiKeyHelper = settings.apiKeyHelper;
74
+ const hasExternalAuthToken = process.env.ANTHROPIC_AUTH_TOKEN ||
75
+ apiKeyHelper ||
76
+ process.env.THADDEUS_API_KEY_FILE_DESCRIPTOR;
77
+ // Check if API key is from an external source (not managed by /login)
78
+ const { source: apiKeySource } = getAnthropicApiKeyWithSource({
79
+ skipRetrievingKeyFromApiKeyHelper: true,
80
+ });
81
+ const hasExternalApiKey = apiKeySource === 'ANTHROPIC_API_KEY' || apiKeySource === 'apiKeyHelper';
82
+ // Disable Delphi Labs auth if:
83
+ // 1. Using 3rd party services (Bedrock/Vertex/Foundry)
84
+ // 2. User has an external API key (regardless of proxy configuration)
85
+ // 3. User has an external auth token (regardless of proxy configuration)
86
+ // this may cause issues if users have complex proxy / gateway "client-side creds" auth scenarios,
87
+ // e.g. if they want to set X-Api-Key to a gateway key but use Delphi Labs OAuth for the Authorization
88
+ // if we get reports of that, we should probably add an env var to force OAuth enablement
89
+ const shouldDisableAuth = is3P ||
90
+ (hasExternalAuthToken && !isManagedOAuthContext()) ||
91
+ (hasExternalApiKey && !isManagedOAuthContext());
92
+ return !shouldDisableAuth;
93
+ }
94
+ /** Where the auth token is being sourced from, if any. */
95
+ // this code is closely related to isAnthropicAuthEnabled
96
+ export function getAuthTokenSource() {
97
+ // xAI/Grok: no Delphi Labs tokens needed — shim handles everything
98
+ if (isEnvTruthy(process.env.THADDEUS_USE_XAI)) {
99
+ return { source: 'none', hasToken: false };
100
+ }
101
+ // --bare: API-key-only. apiKeyHelper (from --settings) is the only
102
+ // bearer-token-shaped source allowed. OAuth env vars, FD tokens, and
103
+ // keychain are ignored.
104
+ if (isBareMode()) {
105
+ if (getConfiguredApiKeyHelper()) {
106
+ return { source: 'apiKeyHelper', hasToken: true };
107
+ }
108
+ return { source: 'none', hasToken: false };
109
+ }
110
+ if (process.env.ANTHROPIC_AUTH_TOKEN && !isManagedOAuthContext()) {
111
+ return { source: 'ANTHROPIC_AUTH_TOKEN', hasToken: true };
112
+ }
113
+ if (process.env.THADDEUS_OAUTH_TOKEN) {
114
+ return { source: 'THADDEUS_OAUTH_TOKEN', hasToken: true };
115
+ }
116
+ // Check for OAuth token from file descriptor (or its CCR disk fallback)
117
+ const oauthTokenFromFd = getOAuthTokenFromFileDescriptor();
118
+ if (oauthTokenFromFd) {
119
+ // getOAuthTokenFromFileDescriptor has a disk fallback for CCR subprocesses
120
+ // that can't inherit the pipe FD. Distinguish by env var presence so the
121
+ // org-mismatch message doesn't tell the user to unset a variable that
122
+ // doesn't exist. Call sites fall through correctly — the new source is
123
+ // !== 'none' (cli/handlers/auth.ts → oauth_token) and not in the
124
+ // isEnvVarToken set (auth.ts:1844 → generic re-login message).
125
+ if (process.env.THADDEUS_OAUTH_TOKEN_FILE_DESCRIPTOR) {
126
+ return {
127
+ source: 'THADDEUS_OAUTH_TOKEN_FILE_DESCRIPTOR',
128
+ hasToken: true,
129
+ };
130
+ }
131
+ return {
132
+ source: 'CCR_OAUTH_TOKEN_FILE',
133
+ hasToken: true,
134
+ };
135
+ }
136
+ // Check if apiKeyHelper is configured without executing it
137
+ // This prevents security issues where arbitrary code could execute before trust is established
138
+ const apiKeyHelper = getConfiguredApiKeyHelper();
139
+ if (apiKeyHelper && !isManagedOAuthContext()) {
140
+ return { source: 'apiKeyHelper', hasToken: true };
141
+ }
142
+ const oauthTokens = getClaudeAIOAuthTokens();
143
+ if (shouldUseClaudeAIAuth(oauthTokens?.scopes) && oauthTokens?.accessToken) {
144
+ return { source: 'claude.ai', hasToken: true };
145
+ }
146
+ return { source: 'none', hasToken: false };
147
+ }
148
+ export function getAnthropicApiKey() {
149
+ const { key } = getAnthropicApiKeyWithSource();
150
+ return key;
151
+ }
152
+ export function hasAnthropicApiKeyAuth() {
153
+ // Thaddeus proxy auth — user has a subscription token, no API key needed
154
+ if (isThaddeusAuthenticated()) {
155
+ return true;
156
+ }
157
+ const { key, source } = getAnthropicApiKeyWithSource({
158
+ skipRetrievingKeyFromApiKeyHelper: true,
159
+ });
160
+ return key !== null && source !== 'none';
161
+ }
162
+ export function getAnthropicApiKeyWithSource(opts = {}) {
163
+ // xAI/Grok: no Delphi Labs key needed — shim handles everything
164
+ if (isEnvTruthy(process.env.THADDEUS_USE_XAI)) {
165
+ return { key: null, source: 'none' };
166
+ }
167
+ // --bare: hermetic auth. Only ANTHROPIC_API_KEY env or apiKeyHelper from
168
+ // the --settings flag. Never touches keychain, config file, or approval
169
+ // lists. 3P (Bedrock/Vertex/Foundry) uses provider creds, not this path.
170
+ if (isBareMode()) {
171
+ if (process.env.ANTHROPIC_API_KEY) {
172
+ return { key: process.env.ANTHROPIC_API_KEY, source: 'ANTHROPIC_API_KEY' };
173
+ }
174
+ if (getConfiguredApiKeyHelper()) {
175
+ return {
176
+ key: opts.skipRetrievingKeyFromApiKeyHelper
177
+ ? null
178
+ : getApiKeyFromApiKeyHelperCached(),
179
+ source: 'apiKeyHelper',
180
+ };
181
+ }
182
+ return { key: null, source: 'none' };
183
+ }
184
+ // On homespace, don't use ANTHROPIC_API_KEY (use Console key instead)
185
+ // https://anthropic.slack.com/archives/C08428WSLKV/p1747331773214779
186
+ const apiKeyEnv = isRunningOnHomespace()
187
+ ? undefined
188
+ : process.env.ANTHROPIC_API_KEY;
189
+ // Always check for direct environment variable when the user ran claude --print.
190
+ // This is useful for CI, etc.
191
+ if (preferThirdPartyAuthentication() && apiKeyEnv) {
192
+ return {
193
+ key: apiKeyEnv,
194
+ source: 'ANTHROPIC_API_KEY',
195
+ };
196
+ }
197
+ if (isEnvTruthy(process.env.CI) || process.env.NODE_ENV === 'test') {
198
+ // Check for API key from file descriptor first
199
+ const apiKeyFromFd = getApiKeyFromFileDescriptor();
200
+ if (apiKeyFromFd) {
201
+ return {
202
+ key: apiKeyFromFd,
203
+ source: 'ANTHROPIC_API_KEY',
204
+ };
205
+ }
206
+ if (!apiKeyEnv &&
207
+ !process.env.THADDEUS_OAUTH_TOKEN &&
208
+ !process.env.THADDEUS_OAUTH_TOKEN_FILE_DESCRIPTOR) {
209
+ throw new Error('ANTHROPIC_API_KEY or THADDEUS_OAUTH_TOKEN env var is required');
210
+ }
211
+ if (apiKeyEnv) {
212
+ return {
213
+ key: apiKeyEnv,
214
+ source: 'ANTHROPIC_API_KEY',
215
+ };
216
+ }
217
+ // OAuth token is present but this function returns API keys only
218
+ return {
219
+ key: null,
220
+ source: 'none',
221
+ };
222
+ }
223
+ // Check for ANTHROPIC_API_KEY before checking the apiKeyHelper or /login-managed key
224
+ if (apiKeyEnv &&
225
+ getGlobalConfig().customApiKeyResponses?.approved?.includes(normalizeApiKeyForConfig(apiKeyEnv))) {
226
+ return {
227
+ key: apiKeyEnv,
228
+ source: 'ANTHROPIC_API_KEY',
229
+ };
230
+ }
231
+ // Check for API key from file descriptor
232
+ const apiKeyFromFd = getApiKeyFromFileDescriptor();
233
+ if (apiKeyFromFd) {
234
+ return {
235
+ key: apiKeyFromFd,
236
+ source: 'ANTHROPIC_API_KEY',
237
+ };
238
+ }
239
+ // Check for apiKeyHelper — use sync cache, never block
240
+ const apiKeyHelperCommand = getConfiguredApiKeyHelper();
241
+ if (apiKeyHelperCommand) {
242
+ if (opts.skipRetrievingKeyFromApiKeyHelper) {
243
+ return {
244
+ key: null,
245
+ source: 'apiKeyHelper',
246
+ };
247
+ }
248
+ // Cache may be cold (helper hasn't finished yet). Return null with
249
+ // source='apiKeyHelper' rather than falling through to keychain —
250
+ // apiKeyHelper must win. Callers needing a real key must await
251
+ // getApiKeyFromApiKeyHelper() first (client.ts, useApiKeyVerification do).
252
+ return {
253
+ key: getApiKeyFromApiKeyHelperCached(),
254
+ source: 'apiKeyHelper',
255
+ };
256
+ }
257
+ const apiKeyFromConfigOrMacOSKeychain = getApiKeyFromConfigOrMacOSKeychain();
258
+ if (apiKeyFromConfigOrMacOSKeychain) {
259
+ return apiKeyFromConfigOrMacOSKeychain;
260
+ }
261
+ return {
262
+ key: null,
263
+ source: 'none',
264
+ };
265
+ }
266
+ /**
267
+ * Get the configured apiKeyHelper from settings.
268
+ * In bare mode, only the --settings flag source is consulted — apiKeyHelper
269
+ * from ~/.claude/settings.json or project settings is ignored.
270
+ */
271
+ export function getConfiguredApiKeyHelper() {
272
+ if (isBareMode()) {
273
+ return getSettingsForSource('flagSettings')?.apiKeyHelper;
274
+ }
275
+ const mergedSettings = getSettings_DEPRECATED() || {};
276
+ return mergedSettings.apiKeyHelper;
277
+ }
278
+ /**
279
+ * Check if the configured apiKeyHelper comes from project settings (projectSettings or localSettings)
280
+ */
281
+ function isApiKeyHelperFromProjectOrLocalSettings() {
282
+ const apiKeyHelper = getConfiguredApiKeyHelper();
283
+ if (!apiKeyHelper) {
284
+ return false;
285
+ }
286
+ const projectSettings = getSettingsForSource('projectSettings');
287
+ const localSettings = getSettingsForSource('localSettings');
288
+ return (projectSettings?.apiKeyHelper === apiKeyHelper ||
289
+ localSettings?.apiKeyHelper === apiKeyHelper);
290
+ }
291
+ /**
292
+ * Get the configured awsAuthRefresh from settings
293
+ */
294
+ function getConfiguredAwsAuthRefresh() {
295
+ const mergedSettings = getSettings_DEPRECATED() || {};
296
+ return mergedSettings.awsAuthRefresh;
297
+ }
298
+ /**
299
+ * Check if the configured awsAuthRefresh comes from project settings
300
+ */
301
+ export function isAwsAuthRefreshFromProjectSettings() {
302
+ const awsAuthRefresh = getConfiguredAwsAuthRefresh();
303
+ if (!awsAuthRefresh) {
304
+ return false;
305
+ }
306
+ const projectSettings = getSettingsForSource('projectSettings');
307
+ const localSettings = getSettingsForSource('localSettings');
308
+ return (projectSettings?.awsAuthRefresh === awsAuthRefresh ||
309
+ localSettings?.awsAuthRefresh === awsAuthRefresh);
310
+ }
311
+ /**
312
+ * Get the configured awsCredentialExport from settings
313
+ */
314
+ function getConfiguredAwsCredentialExport() {
315
+ const mergedSettings = getSettings_DEPRECATED() || {};
316
+ return mergedSettings.awsCredentialExport;
317
+ }
318
+ /**
319
+ * Check if the configured awsCredentialExport comes from project settings
320
+ */
321
+ export function isAwsCredentialExportFromProjectSettings() {
322
+ const awsCredentialExport = getConfiguredAwsCredentialExport();
323
+ if (!awsCredentialExport) {
324
+ return false;
325
+ }
326
+ const projectSettings = getSettingsForSource('projectSettings');
327
+ const localSettings = getSettingsForSource('localSettings');
328
+ return (projectSettings?.awsCredentialExport === awsCredentialExport ||
329
+ localSettings?.awsCredentialExport === awsCredentialExport);
330
+ }
331
+ /**
332
+ * Calculate TTL in milliseconds for the API key helper cache
333
+ * Uses THADDEUS_API_KEY_HELPER_TTL_MS env var if set and valid,
334
+ * otherwise defaults to 5 minutes
335
+ */
336
+ export function calculateApiKeyHelperTTL() {
337
+ const envTtl = process.env.THADDEUS_API_KEY_HELPER_TTL_MS;
338
+ if (envTtl) {
339
+ const parsed = parseInt(envTtl, 10);
340
+ if (!Number.isNaN(parsed) && parsed >= 0) {
341
+ return parsed;
342
+ }
343
+ logForDebugging(`Found THADDEUS_API_KEY_HELPER_TTL_MS env var, but it was not a valid number. Got ${envTtl}`, { level: 'error' });
344
+ }
345
+ return DEFAULT_API_KEY_HELPER_TTL;
346
+ }
347
+ // Async API key helper with sync cache for non-blocking reads.
348
+ // Epoch bumps on clearApiKeyHelperCache() — orphaned executions check their
349
+ // captured epoch before touching module state so a settings-change or 401-retry
350
+ // mid-flight can't clobber the newer cache/inflight.
351
+ let _apiKeyHelperCache = null;
352
+ let _apiKeyHelperInflight = null;
353
+ let _apiKeyHelperEpoch = 0;
354
+ export function getApiKeyHelperElapsedMs() {
355
+ const startedAt = _apiKeyHelperInflight?.startedAt;
356
+ return startedAt ? Date.now() - startedAt : 0;
357
+ }
358
+ export async function getApiKeyFromApiKeyHelper(isNonInteractiveSession) {
359
+ if (!getConfiguredApiKeyHelper())
360
+ return null;
361
+ const ttl = calculateApiKeyHelperTTL();
362
+ if (_apiKeyHelperCache) {
363
+ if (Date.now() - _apiKeyHelperCache.timestamp < ttl) {
364
+ return _apiKeyHelperCache.value;
365
+ }
366
+ // Stale — return stale value now, refresh in the background.
367
+ // `??=` banned here by eslint no-nullish-assign-object-call (bun bug).
368
+ if (!_apiKeyHelperInflight) {
369
+ _apiKeyHelperInflight = {
370
+ promise: _runAndCache(isNonInteractiveSession, false, _apiKeyHelperEpoch),
371
+ startedAt: null,
372
+ };
373
+ }
374
+ return _apiKeyHelperCache.value;
375
+ }
376
+ // Cold cache — deduplicate concurrent calls
377
+ if (_apiKeyHelperInflight)
378
+ return _apiKeyHelperInflight.promise;
379
+ _apiKeyHelperInflight = {
380
+ promise: _runAndCache(isNonInteractiveSession, true, _apiKeyHelperEpoch),
381
+ startedAt: Date.now(),
382
+ };
383
+ return _apiKeyHelperInflight.promise;
384
+ }
385
+ async function _runAndCache(isNonInteractiveSession, isCold, epoch) {
386
+ try {
387
+ const value = await _executeApiKeyHelper(isNonInteractiveSession);
388
+ if (epoch !== _apiKeyHelperEpoch)
389
+ return value;
390
+ if (value !== null) {
391
+ _apiKeyHelperCache = { value, timestamp: Date.now() };
392
+ }
393
+ return value;
394
+ }
395
+ catch (e) {
396
+ if (epoch !== _apiKeyHelperEpoch)
397
+ return ' ';
398
+ const detail = e instanceof Error ? e.message : String(e);
399
+ // biome-ignore lint/suspicious/noConsole: user-configured script failed; must be visible without --debug
400
+ console.error(chalk.red(`apiKeyHelper failed: ${detail}`));
401
+ logForDebugging(`Error getting API key from apiKeyHelper: ${detail}`, {
402
+ level: 'error',
403
+ });
404
+ // SWR path: a transient failure shouldn't replace a working key with
405
+ // the ' ' sentinel — keep serving the stale value and bump timestamp
406
+ // so we don't hammer-retry every call.
407
+ if (!isCold && _apiKeyHelperCache && _apiKeyHelperCache.value !== ' ') {
408
+ _apiKeyHelperCache = { ..._apiKeyHelperCache, timestamp: Date.now() };
409
+ return _apiKeyHelperCache.value;
410
+ }
411
+ // Cold cache or prior error — cache ' ' so callers don't fall back to OAuth
412
+ _apiKeyHelperCache = { value: ' ', timestamp: Date.now() };
413
+ return ' ';
414
+ }
415
+ finally {
416
+ if (epoch === _apiKeyHelperEpoch) {
417
+ _apiKeyHelperInflight = null;
418
+ }
419
+ }
420
+ }
421
+ async function _executeApiKeyHelper(isNonInteractiveSession) {
422
+ const apiKeyHelper = getConfiguredApiKeyHelper();
423
+ if (!apiKeyHelper) {
424
+ return null;
425
+ }
426
+ if (isApiKeyHelperFromProjectOrLocalSettings()) {
427
+ const hasTrust = checkHasTrustDialogAccepted();
428
+ if (!hasTrust && !isNonInteractiveSession) {
429
+ const error = new Error(`Security: apiKeyHelper executed before workspace trust is confirmed. If you see this message, post in ${MACRO.FEEDBACK_CHANNEL}.`);
430
+ logAntError('apiKeyHelper invoked before trust check', error);
431
+ logEvent('thaddeus_apiKeyHelper_missing_trust11', {});
432
+ return null;
433
+ }
434
+ }
435
+ const result = await execa(apiKeyHelper, {
436
+ shell: true,
437
+ timeout: 10 * 60 * 1000,
438
+ reject: false,
439
+ });
440
+ if (result.failed) {
441
+ // reject:false — execa resolves on exit≠0/timeout, stderr is on result
442
+ const why = result.timedOut ? 'timed out' : `exited ${result.exitCode}`;
443
+ const stderr = result.stderr?.trim();
444
+ throw new Error(stderr ? `${why}: ${stderr}` : why);
445
+ }
446
+ const stdout = result.stdout?.trim();
447
+ if (!stdout) {
448
+ throw new Error('did not return a value');
449
+ }
450
+ return stdout;
451
+ }
452
+ /**
453
+ * Sync cache reader — returns the last fetched apiKeyHelper value without executing.
454
+ * Returns stale values to match SWR semantics of the async reader.
455
+ * Returns null only if the async fetch hasn't completed yet.
456
+ */
457
+ export function getApiKeyFromApiKeyHelperCached() {
458
+ return _apiKeyHelperCache?.value ?? null;
459
+ }
460
+ export function clearApiKeyHelperCache() {
461
+ _apiKeyHelperEpoch++;
462
+ _apiKeyHelperCache = null;
463
+ _apiKeyHelperInflight = null;
464
+ }
465
+ export function prefetchApiKeyFromApiKeyHelperIfSafe(isNonInteractiveSession) {
466
+ // Skip if trust not yet accepted — the inner _executeApiKeyHelper check
467
+ // would catch this too, but would fire a false-positive analytics event.
468
+ if (isApiKeyHelperFromProjectOrLocalSettings() &&
469
+ !checkHasTrustDialogAccepted()) {
470
+ return;
471
+ }
472
+ void getApiKeyFromApiKeyHelper(isNonInteractiveSession);
473
+ }
474
+ /** Default STS credentials are one hour. We manually manage invalidation, so not too worried about this being accurate. */
475
+ const DEFAULT_AWS_STS_TTL = 60 * 60 * 1000;
476
+ /**
477
+ * Run awsAuthRefresh to perform interactive authentication (e.g., aws sso login)
478
+ * Streams output in real-time for user visibility
479
+ */
480
+ async function runAwsAuthRefresh() {
481
+ const awsAuthRefresh = getConfiguredAwsAuthRefresh();
482
+ if (!awsAuthRefresh) {
483
+ return false; // Not configured, treat as success
484
+ }
485
+ // SECURITY: Check if awsAuthRefresh is from project settings
486
+ if (isAwsAuthRefreshFromProjectSettings()) {
487
+ // Check if trust has been established for this project
488
+ const hasTrust = checkHasTrustDialogAccepted();
489
+ if (!hasTrust && !getIsNonInteractiveSession()) {
490
+ const error = new Error(`Security: awsAuthRefresh executed before workspace trust is confirmed. If you see this message, post in ${MACRO.FEEDBACK_CHANNEL}.`);
491
+ logAntError('awsAuthRefresh invoked before trust check', error);
492
+ logEvent('thaddeus_awsAuthRefresh_missing_trust', {});
493
+ return false;
494
+ }
495
+ }
496
+ try {
497
+ logForDebugging('Fetching AWS caller identity for AWS auth refresh command');
498
+ await checkStsCallerIdentity();
499
+ logForDebugging('Fetched AWS caller identity, skipping AWS auth refresh command');
500
+ return false;
501
+ }
502
+ catch {
503
+ // only actually do the refresh if caller-identity calls
504
+ return refreshAwsAuth(awsAuthRefresh);
505
+ }
506
+ }
507
+ // Timeout for AWS auth refresh command (3 minutes).
508
+ // Long enough for browser-based SSO flows, short enough to prevent indefinite hangs.
509
+ const AWS_AUTH_REFRESH_TIMEOUT_MS = 3 * 60 * 1000;
510
+ export function refreshAwsAuth(awsAuthRefresh) {
511
+ logForDebugging('Running AWS auth refresh command');
512
+ // Start tracking authentication status
513
+ const authStatusManager = AwsAuthStatusManager.getInstance();
514
+ authStatusManager.startAuthentication();
515
+ return new Promise(resolve => {
516
+ const refreshProc = exec(awsAuthRefresh, {
517
+ timeout: AWS_AUTH_REFRESH_TIMEOUT_MS,
518
+ });
519
+ refreshProc.stdout.on('data', data => {
520
+ const output = data.toString().trim();
521
+ if (output) {
522
+ // Add output to status manager for UI display
523
+ authStatusManager.addOutput(output);
524
+ // Also log for debugging
525
+ logForDebugging(output, { level: 'debug' });
526
+ }
527
+ });
528
+ refreshProc.stderr.on('data', data => {
529
+ const error = data.toString().trim();
530
+ if (error) {
531
+ authStatusManager.setError(error);
532
+ logForDebugging(error, { level: 'error' });
533
+ }
534
+ });
535
+ refreshProc.on('close', (code, signal) => {
536
+ if (code === 0) {
537
+ logForDebugging('AWS auth refresh completed successfully');
538
+ authStatusManager.endAuthentication(true);
539
+ void resolve(true);
540
+ }
541
+ else {
542
+ const timedOut = signal === 'SIGTERM';
543
+ const message = timedOut
544
+ ? chalk.red('AWS auth refresh timed out after 3 minutes. Run your auth command manually in a separate terminal.')
545
+ : chalk.red('Error running awsAuthRefresh (in settings or ~/.claude.json):');
546
+ // biome-ignore lint/suspicious/noConsole:: intentional console output
547
+ console.error(message);
548
+ authStatusManager.endAuthentication(false);
549
+ void resolve(false);
550
+ }
551
+ });
552
+ });
553
+ }
554
+ /**
555
+ * Run awsCredentialExport to get credentials and set environment variables
556
+ * Expects JSON output containing AWS credentials
557
+ */
558
+ async function getAwsCredsFromCredentialExport() {
559
+ const awsCredentialExport = getConfiguredAwsCredentialExport();
560
+ if (!awsCredentialExport) {
561
+ return null;
562
+ }
563
+ // SECURITY: Check if awsCredentialExport is from project settings
564
+ if (isAwsCredentialExportFromProjectSettings()) {
565
+ // Check if trust has been established for this project
566
+ const hasTrust = checkHasTrustDialogAccepted();
567
+ if (!hasTrust && !getIsNonInteractiveSession()) {
568
+ const error = new Error(`Security: awsCredentialExport executed before workspace trust is confirmed. If you see this message, post in ${MACRO.FEEDBACK_CHANNEL}.`);
569
+ logAntError('awsCredentialExport invoked before trust check', error);
570
+ logEvent('thaddeus_awsCredentialExport_missing_trust', {});
571
+ return null;
572
+ }
573
+ }
574
+ try {
575
+ logForDebugging('Fetching AWS caller identity for credential export command');
576
+ await checkStsCallerIdentity();
577
+ logForDebugging('Fetched AWS caller identity, skipping AWS credential export command');
578
+ return null;
579
+ }
580
+ catch {
581
+ // only actually do the export if caller-identity calls
582
+ try {
583
+ logForDebugging('Running AWS credential export command');
584
+ const result = await execa(awsCredentialExport, {
585
+ shell: true,
586
+ reject: false,
587
+ });
588
+ if (result.exitCode !== 0 || !result.stdout) {
589
+ throw new Error('awsCredentialExport did not return a valid value');
590
+ }
591
+ // Parse the JSON output from aws sts commands
592
+ const awsOutput = jsonParse(result.stdout.trim());
593
+ if (!isValidAwsStsOutput(awsOutput)) {
594
+ throw new Error('awsCredentialExport did not return valid AWS STS output structure');
595
+ }
596
+ logForDebugging('AWS credentials retrieved from awsCredentialExport');
597
+ return {
598
+ accessKeyId: awsOutput.Credentials.AccessKeyId,
599
+ secretAccessKey: awsOutput.Credentials.SecretAccessKey,
600
+ sessionToken: awsOutput.Credentials.SessionToken,
601
+ };
602
+ }
603
+ catch (e) {
604
+ const message = chalk.red('Error getting AWS credentials from awsCredentialExport (in settings or ~/.claude.json):');
605
+ if (e instanceof Error) {
606
+ // biome-ignore lint/suspicious/noConsole:: intentional console output
607
+ console.error(message, e.message);
608
+ }
609
+ else {
610
+ // biome-ignore lint/suspicious/noConsole:: intentional console output
611
+ console.error(message, e);
612
+ }
613
+ return null;
614
+ }
615
+ }
616
+ }
617
+ /**
618
+ * Refresh AWS authentication and get credentials with cache clearing
619
+ * This combines runAwsAuthRefresh, getAwsCredsFromCredentialExport, and clearAwsIniCache
620
+ * to ensure fresh credentials are always used
621
+ */
622
+ export const refreshAndGetAwsCredentials = memoizeWithTTLAsync(async () => {
623
+ // First run auth refresh if needed
624
+ const refreshed = await runAwsAuthRefresh();
625
+ // Get credentials from export
626
+ const credentials = await getAwsCredsFromCredentialExport();
627
+ // Clear AWS INI cache to ensure fresh credentials are used
628
+ if (refreshed || credentials) {
629
+ await clearAwsIniCache();
630
+ }
631
+ return credentials;
632
+ }, DEFAULT_AWS_STS_TTL);
633
+ export function clearAwsCredentialsCache() {
634
+ refreshAndGetAwsCredentials.cache.clear();
635
+ }
636
+ /**
637
+ * Get the configured gcpAuthRefresh from settings
638
+ */
639
+ function getConfiguredGcpAuthRefresh() {
640
+ const mergedSettings = getSettings_DEPRECATED() || {};
641
+ return mergedSettings.gcpAuthRefresh;
642
+ }
643
+ /**
644
+ * Check if the configured gcpAuthRefresh comes from project settings
645
+ */
646
+ export function isGcpAuthRefreshFromProjectSettings() {
647
+ const gcpAuthRefresh = getConfiguredGcpAuthRefresh();
648
+ if (!gcpAuthRefresh) {
649
+ return false;
650
+ }
651
+ const projectSettings = getSettingsForSource('projectSettings');
652
+ const localSettings = getSettingsForSource('localSettings');
653
+ return (projectSettings?.gcpAuthRefresh === gcpAuthRefresh ||
654
+ localSettings?.gcpAuthRefresh === gcpAuthRefresh);
655
+ }
656
+ /** Short timeout for the GCP credentials probe. Without this, when no local
657
+ * credential source exists (no ADC file, no env var), google-auth-library falls
658
+ * through to the GCE metadata server which hangs ~12s outside GCP. */
659
+ const GCP_CREDENTIALS_CHECK_TIMEOUT_MS = 5_000;
660
+ /**
661
+ * Check if GCP credentials are currently valid by attempting to get an access token.
662
+ * This uses the same authentication chain that the Vertex SDK uses.
663
+ */
664
+ export async function checkGcpCredentialsValid() {
665
+ try {
666
+ // Dynamically import to avoid loading google-auth-library unnecessarily
667
+ const { GoogleAuth } = await import('google-auth-library');
668
+ const auth = new GoogleAuth({
669
+ scopes: ['https://www.googleapis.com/auth/cloud-platform'],
670
+ });
671
+ const probe = (async () => {
672
+ const client = await auth.getClient();
673
+ await client.getAccessToken();
674
+ })();
675
+ const timeout = sleep(GCP_CREDENTIALS_CHECK_TIMEOUT_MS).then(() => {
676
+ throw new GcpCredentialsTimeoutError('GCP credentials check timed out');
677
+ });
678
+ await Promise.race([probe, timeout]);
679
+ return true;
680
+ }
681
+ catch {
682
+ return false;
683
+ }
684
+ }
685
+ /** Default GCP credential TTL - 1 hour to match typical ADC token lifetime */
686
+ const DEFAULT_GCP_CREDENTIAL_TTL = 60 * 60 * 1000;
687
+ /**
688
+ * Run gcpAuthRefresh to perform interactive authentication (e.g., gcloud auth application-default login)
689
+ * Streams output in real-time for user visibility
690
+ */
691
+ async function runGcpAuthRefresh() {
692
+ const gcpAuthRefresh = getConfiguredGcpAuthRefresh();
693
+ if (!gcpAuthRefresh) {
694
+ return false; // Not configured, treat as success
695
+ }
696
+ // SECURITY: Check if gcpAuthRefresh is from project settings
697
+ if (isGcpAuthRefreshFromProjectSettings()) {
698
+ // Check if trust has been established for this project
699
+ // Pass true to indicate this is a dangerous feature that requires trust
700
+ const hasTrust = checkHasTrustDialogAccepted();
701
+ if (!hasTrust && !getIsNonInteractiveSession()) {
702
+ const error = new Error(`Security: gcpAuthRefresh executed before workspace trust is confirmed. If you see this message, post in ${MACRO.FEEDBACK_CHANNEL}.`);
703
+ logAntError('gcpAuthRefresh invoked before trust check', error);
704
+ logEvent('thaddeus_gcpAuthRefresh_missing_trust', {});
705
+ return false;
706
+ }
707
+ }
708
+ try {
709
+ logForDebugging('Checking GCP credentials validity for auth refresh');
710
+ const isValid = await checkGcpCredentialsValid();
711
+ if (isValid) {
712
+ logForDebugging('GCP credentials are valid, skipping auth refresh command');
713
+ return false;
714
+ }
715
+ }
716
+ catch {
717
+ // Credentials check failed, proceed with refresh
718
+ }
719
+ return refreshGcpAuth(gcpAuthRefresh);
720
+ }
721
+ // Timeout for GCP auth refresh command (3 minutes).
722
+ // Long enough for browser-based auth flows, short enough to prevent indefinite hangs.
723
+ const GCP_AUTH_REFRESH_TIMEOUT_MS = 3 * 60 * 1000;
724
+ export function refreshGcpAuth(gcpAuthRefresh) {
725
+ logForDebugging('Running GCP auth refresh command');
726
+ // Start tracking authentication status. AwsAuthStatusManager is cloud-provider-agnostic
727
+ // despite the name — print.ts emits its updates as generic SDK 'auth_status' messages.
728
+ const authStatusManager = AwsAuthStatusManager.getInstance();
729
+ authStatusManager.startAuthentication();
730
+ return new Promise(resolve => {
731
+ const refreshProc = exec(gcpAuthRefresh, {
732
+ timeout: GCP_AUTH_REFRESH_TIMEOUT_MS,
733
+ });
734
+ refreshProc.stdout.on('data', data => {
735
+ const output = data.toString().trim();
736
+ if (output) {
737
+ // Add output to status manager for UI display
738
+ authStatusManager.addOutput(output);
739
+ // Also log for debugging
740
+ logForDebugging(output, { level: 'debug' });
741
+ }
742
+ });
743
+ refreshProc.stderr.on('data', data => {
744
+ const error = data.toString().trim();
745
+ if (error) {
746
+ authStatusManager.setError(error);
747
+ logForDebugging(error, { level: 'error' });
748
+ }
749
+ });
750
+ refreshProc.on('close', (code, signal) => {
751
+ if (code === 0) {
752
+ logForDebugging('GCP auth refresh completed successfully');
753
+ authStatusManager.endAuthentication(true);
754
+ void resolve(true);
755
+ }
756
+ else {
757
+ const timedOut = signal === 'SIGTERM';
758
+ const message = timedOut
759
+ ? chalk.red('GCP auth refresh timed out after 3 minutes. Run your auth command manually in a separate terminal.')
760
+ : chalk.red('Error running gcpAuthRefresh (in settings or ~/.claude.json):');
761
+ // biome-ignore lint/suspicious/noConsole:: intentional console output
762
+ console.error(message);
763
+ authStatusManager.endAuthentication(false);
764
+ void resolve(false);
765
+ }
766
+ });
767
+ });
768
+ }
769
+ /**
770
+ * Refresh GCP authentication if needed.
771
+ * This function checks if credentials are valid and runs the refresh command if not.
772
+ * Memoized with TTL to avoid excessive refresh attempts.
773
+ */
774
+ export const refreshGcpCredentialsIfNeeded = memoizeWithTTLAsync(async () => {
775
+ // Run auth refresh if needed
776
+ const refreshed = await runGcpAuthRefresh();
777
+ return refreshed;
778
+ }, DEFAULT_GCP_CREDENTIAL_TTL);
779
+ export function clearGcpCredentialsCache() {
780
+ refreshGcpCredentialsIfNeeded.cache.clear();
781
+ }
782
+ /**
783
+ * Prefetches GCP credentials only if workspace trust has already been established.
784
+ * This allows us to start the potentially slow GCP commands early for trusted workspaces
785
+ * while maintaining security for untrusted ones.
786
+ *
787
+ * Returns void to prevent misuse - use refreshGcpCredentialsIfNeeded() to actually refresh.
788
+ */
789
+ export function prefetchGcpCredentialsIfSafe() {
790
+ // Check if gcpAuthRefresh is configured
791
+ const gcpAuthRefresh = getConfiguredGcpAuthRefresh();
792
+ if (!gcpAuthRefresh) {
793
+ return;
794
+ }
795
+ // Check if gcpAuthRefresh is from project settings
796
+ if (isGcpAuthRefreshFromProjectSettings()) {
797
+ // Only prefetch if trust has already been established
798
+ const hasTrust = checkHasTrustDialogAccepted();
799
+ if (!hasTrust && !getIsNonInteractiveSession()) {
800
+ // Don't prefetch - wait for trust to be established first
801
+ return;
802
+ }
803
+ }
804
+ // Safe to prefetch - either not from project settings or trust already established
805
+ void refreshGcpCredentialsIfNeeded();
806
+ }
807
+ /**
808
+ * Prefetches AWS credentials only if workspace trust has already been established.
809
+ * This allows us to start the potentially slow AWS commands early for trusted workspaces
810
+ * while maintaining security for untrusted ones.
811
+ *
812
+ * Returns void to prevent misuse - use refreshAndGetAwsCredentials() to actually retrieve credentials.
813
+ */
814
+ export function prefetchAwsCredentialsAndBedRockInfoIfSafe() {
815
+ // Check if either AWS command is configured
816
+ const awsAuthRefresh = getConfiguredAwsAuthRefresh();
817
+ const awsCredentialExport = getConfiguredAwsCredentialExport();
818
+ if (!awsAuthRefresh && !awsCredentialExport) {
819
+ return;
820
+ }
821
+ // Check if either command is from project settings
822
+ if (isAwsAuthRefreshFromProjectSettings() ||
823
+ isAwsCredentialExportFromProjectSettings()) {
824
+ // Only prefetch if trust has already been established
825
+ const hasTrust = checkHasTrustDialogAccepted();
826
+ if (!hasTrust && !getIsNonInteractiveSession()) {
827
+ // Don't prefetch - wait for trust to be established first
828
+ return;
829
+ }
830
+ }
831
+ // Safe to prefetch - either not from project settings or trust already established
832
+ void refreshAndGetAwsCredentials();
833
+ getModelStrings();
834
+ }
835
+ /** @private Use {@link getAnthropicApiKey} or {@link getAnthropicApiKeyWithSource} */
836
+ export const getApiKeyFromConfigOrMacOSKeychain = memoize(() => {
837
+ if (isBareMode())
838
+ return null;
839
+ // TODO: migrate to SecureStorage
840
+ if (process.platform === 'darwin') {
841
+ // keychainPrefetch.ts fires this read at main.tsx top-level in parallel
842
+ // with module imports. If it completed, use that instead of spawning a
843
+ // sync `security` subprocess here (~33ms).
844
+ const prefetch = getLegacyApiKeyPrefetchResult();
845
+ if (prefetch) {
846
+ if (prefetch.stdout) {
847
+ return { key: prefetch.stdout, source: '/login managed key' };
848
+ }
849
+ // Prefetch completed with no key — fall through to config, not keychain.
850
+ }
851
+ else {
852
+ const storageServiceName = getMacOsKeychainStorageServiceName();
853
+ try {
854
+ const result = execSyncWithDefaults_DEPRECATED(`security find-generic-password -a $USER -w -s "${storageServiceName}"`);
855
+ if (result) {
856
+ return { key: result, source: '/login managed key' };
857
+ }
858
+ }
859
+ catch (e) {
860
+ logError(e);
861
+ }
862
+ }
863
+ }
864
+ const config = getGlobalConfig();
865
+ if (!config.primaryApiKey) {
866
+ return null;
867
+ }
868
+ return { key: config.primaryApiKey, source: '/login managed key' };
869
+ });
870
+ function isValidApiKey(apiKey) {
871
+ // Only allow alphanumeric characters, dashes, and underscores
872
+ return /^[a-zA-Z0-9-_]+$/.test(apiKey);
873
+ }
874
+ export async function saveApiKey(apiKey) {
875
+ if (!isValidApiKey(apiKey)) {
876
+ throw new Error('Invalid API key format. API key must contain only alphanumeric characters, dashes, and underscores.');
877
+ }
878
+ // Store as primary API key
879
+ await maybeRemoveApiKeyFromMacOSKeychain();
880
+ let savedToKeychain = false;
881
+ if (process.platform === 'darwin') {
882
+ try {
883
+ // TODO: migrate to SecureStorage
884
+ const storageServiceName = getMacOsKeychainStorageServiceName();
885
+ const username = getUsername();
886
+ // Convert to hexadecimal to avoid any escaping issues
887
+ const hexValue = Buffer.from(apiKey, 'utf-8').toString('hex');
888
+ // Use security's interactive mode (-i) with -X (hexadecimal) option
889
+ // This ensures credentials never appear in process command-line arguments
890
+ // Process monitors only see "security -i", not the password
891
+ const command = `add-generic-password -U -a "${username}" -s "${storageServiceName}" -X "${hexValue}"\n`;
892
+ await execa('security', ['-i'], {
893
+ input: command,
894
+ reject: false,
895
+ });
896
+ logEvent('thaddeus_api_key_saved_to_keychain', {});
897
+ savedToKeychain = true;
898
+ }
899
+ catch (e) {
900
+ logError(e);
901
+ logEvent('thaddeus_api_key_keychain_error', {
902
+ error: errorMessage(e),
903
+ });
904
+ logEvent('thaddeus_api_key_saved_to_config', {});
905
+ }
906
+ }
907
+ else {
908
+ logEvent('thaddeus_api_key_saved_to_config', {});
909
+ }
910
+ const normalizedKey = normalizeApiKeyForConfig(apiKey);
911
+ // Save config with all updates
912
+ saveGlobalConfig(current => {
913
+ const approved = current.customApiKeyResponses?.approved ?? [];
914
+ return {
915
+ ...current,
916
+ // Only save to config if keychain save failed or not on darwin
917
+ primaryApiKey: savedToKeychain ? current.primaryApiKey : apiKey,
918
+ customApiKeyResponses: {
919
+ ...current.customApiKeyResponses,
920
+ approved: approved.includes(normalizedKey)
921
+ ? approved
922
+ : [...approved, normalizedKey],
923
+ rejected: current.customApiKeyResponses?.rejected ?? [],
924
+ },
925
+ };
926
+ });
927
+ // Clear memo cache
928
+ getApiKeyFromConfigOrMacOSKeychain.cache.clear?.();
929
+ clearLegacyApiKeyPrefetch();
930
+ }
931
+ export function isCustomApiKeyApproved(apiKey) {
932
+ const config = getGlobalConfig();
933
+ const normalizedKey = normalizeApiKeyForConfig(apiKey);
934
+ return (config.customApiKeyResponses?.approved?.includes(normalizedKey) ?? false);
935
+ }
936
+ export async function removeApiKey() {
937
+ await maybeRemoveApiKeyFromMacOSKeychain();
938
+ // Also remove from config instead of returning early, for older clients
939
+ // that set keys before we supported keychain.
940
+ saveGlobalConfig(current => ({
941
+ ...current,
942
+ primaryApiKey: undefined,
943
+ }));
944
+ // Clear memo cache
945
+ getApiKeyFromConfigOrMacOSKeychain.cache.clear?.();
946
+ clearLegacyApiKeyPrefetch();
947
+ }
948
+ async function maybeRemoveApiKeyFromMacOSKeychain() {
949
+ try {
950
+ await maybeRemoveApiKeyFromMacOSKeychainThrows();
951
+ }
952
+ catch (e) {
953
+ logError(e);
954
+ }
955
+ }
956
+ // Function to store OAuth tokens in secure storage
957
+ export function saveOAuthTokensIfNeeded(tokens) {
958
+ if (!shouldUseClaudeAIAuth(tokens.scopes)) {
959
+ logEvent('thaddeus_oauth_tokens_not_claude_ai', {});
960
+ return { success: true };
961
+ }
962
+ // Skip saving inference-only tokens (they come from env vars)
963
+ if (!tokens.refreshToken || !tokens.expiresAt) {
964
+ logEvent('thaddeus_oauth_tokens_inference_only', {});
965
+ return { success: true };
966
+ }
967
+ const secureStorage = getSecureStorage();
968
+ const storageBackend = secureStorage.name;
969
+ try {
970
+ const storageData = secureStorage.read() || {};
971
+ const existingOauth = storageData.claudeAiOauth;
972
+ storageData.claudeAiOauth = {
973
+ accessToken: tokens.accessToken,
974
+ refreshToken: tokens.refreshToken,
975
+ expiresAt: tokens.expiresAt,
976
+ scopes: tokens.scopes,
977
+ // Profile fetch in refreshOAuthToken swallows errors and returns null on
978
+ // transient failures (network, 5xx, rate limit). Don't clobber a valid
979
+ // stored subscription with null — fall back to the existing value.
980
+ subscriptionType: tokens.subscriptionType ?? existingOauth?.subscriptionType ?? null,
981
+ rateLimitTier: tokens.rateLimitTier ?? existingOauth?.rateLimitTier ?? null,
982
+ };
983
+ const updateStatus = secureStorage.update(storageData);
984
+ if (updateStatus.success) {
985
+ logEvent('thaddeus_oauth_tokens_saved', { storageBackend });
986
+ }
987
+ else {
988
+ logEvent('thaddeus_oauth_tokens_save_failed', { storageBackend });
989
+ }
990
+ getClaudeAIOAuthTokens.cache?.clear?.();
991
+ clearBetasCaches();
992
+ clearToolSchemaCache();
993
+ return updateStatus;
994
+ }
995
+ catch (error) {
996
+ logError(error);
997
+ logEvent('thaddeus_oauth_tokens_save_exception', {
998
+ storageBackend,
999
+ error: errorMessage(error),
1000
+ });
1001
+ return { success: false, warning: 'Failed to save OAuth tokens' };
1002
+ }
1003
+ }
1004
+ export const getClaudeAIOAuthTokens = memoize(() => {
1005
+ // --bare: API-key-only. No OAuth env tokens, no keychain, no credentials file.
1006
+ if (isBareMode())
1007
+ return null;
1008
+ // Check for force-set OAuth token from environment variable
1009
+ if (process.env.THADDEUS_OAUTH_TOKEN) {
1010
+ // Return an inference-only token (unknown refresh and expiry)
1011
+ return {
1012
+ accessToken: process.env.THADDEUS_OAUTH_TOKEN,
1013
+ refreshToken: null,
1014
+ expiresAt: null,
1015
+ scopes: ['user:inference'],
1016
+ subscriptionType: null,
1017
+ rateLimitTier: null,
1018
+ };
1019
+ }
1020
+ // Check for OAuth token from file descriptor
1021
+ const oauthTokenFromFd = getOAuthTokenFromFileDescriptor();
1022
+ if (oauthTokenFromFd) {
1023
+ // Return an inference-only token (unknown refresh and expiry)
1024
+ return {
1025
+ accessToken: oauthTokenFromFd,
1026
+ refreshToken: null,
1027
+ expiresAt: null,
1028
+ scopes: ['user:inference'],
1029
+ subscriptionType: null,
1030
+ rateLimitTier: null,
1031
+ };
1032
+ }
1033
+ try {
1034
+ const secureStorage = getSecureStorage();
1035
+ const storageData = secureStorage.read();
1036
+ const oauthData = storageData?.claudeAiOauth;
1037
+ if (!oauthData?.accessToken) {
1038
+ return null;
1039
+ }
1040
+ return oauthData;
1041
+ }
1042
+ catch (error) {
1043
+ logError(error);
1044
+ return null;
1045
+ }
1046
+ });
1047
+ /**
1048
+ * Clears all OAuth token caches. Call this on 401 errors to ensure
1049
+ * the next token read comes from secure storage, not stale in-memory caches.
1050
+ * This handles the case where the local expiration check disagrees with the
1051
+ * server (e.g., due to clock corrections after token was issued).
1052
+ */
1053
+ export function clearOAuthTokenCache() {
1054
+ getClaudeAIOAuthTokens.cache?.clear?.();
1055
+ clearKeychainCache();
1056
+ }
1057
+ let lastCredentialsMtimeMs = 0;
1058
+ // Cross-process staleness: another CC instance may write fresh tokens to
1059
+ // disk (refresh or /login), but this process's memoize caches forever.
1060
+ // Without this, terminal 1's /login fixes terminal 1; terminal 2's /login
1061
+ // then revokes terminal 1 server-side, and terminal 1's memoize never
1062
+ // re-reads — infinite /login regress (CC-1096, GH#24317).
1063
+ async function invalidateOAuthCacheIfDiskChanged() {
1064
+ try {
1065
+ const { mtimeMs } = await stat(join(getClaudeConfigHomeDir(), '.credentials.json'));
1066
+ if (mtimeMs !== lastCredentialsMtimeMs) {
1067
+ lastCredentialsMtimeMs = mtimeMs;
1068
+ clearOAuthTokenCache();
1069
+ }
1070
+ }
1071
+ catch {
1072
+ // ENOENT — macOS keychain path (file deleted on migration). Clear only
1073
+ // the memoize so it delegates to the keychain cache's 30s TTL instead
1074
+ // of caching forever on top. `security find-generic-password` is
1075
+ // ~15ms; bounded to once per 30s by the keychain cache.
1076
+ getClaudeAIOAuthTokens.cache?.clear?.();
1077
+ }
1078
+ }
1079
+ // In-flight dedup: when N claude.ai proxy connectors hit 401 with the same
1080
+ // token simultaneously (common at startup — #20930), only one should clear
1081
+ // caches and re-read the keychain. Without this, each call's clearOAuthTokenCache()
1082
+ // nukes readInFlight in macOsKeychainStorage and triggers a fresh spawn —
1083
+ // sync spawns stacked to 800ms+ of blocked render frames.
1084
+ const pending401Handlers = new Map();
1085
+ /**
1086
+ * Handle a 401 "OAuth token has expired" error from the API.
1087
+ *
1088
+ * This function forces a token refresh when the server says the token is expired,
1089
+ * even if our local expiration check disagrees (which can happen due to clock
1090
+ * issues when the token was issued).
1091
+ *
1092
+ * Safety: We compare the failed token with what's in keychain. If another tab
1093
+ * already refreshed (different token in keychain), we use that instead of
1094
+ * refreshing again. Concurrent calls with the same failedAccessToken are
1095
+ * deduplicated to a single keychain read.
1096
+ *
1097
+ * @param failedAccessToken - The access token that was rejected with 401
1098
+ * @returns true if we now have a valid token, false otherwise
1099
+ */
1100
+ export function handleOAuth401Error(failedAccessToken) {
1101
+ const pending = pending401Handlers.get(failedAccessToken);
1102
+ if (pending)
1103
+ return pending;
1104
+ const promise = handleOAuth401ErrorImpl(failedAccessToken).finally(() => {
1105
+ pending401Handlers.delete(failedAccessToken);
1106
+ });
1107
+ pending401Handlers.set(failedAccessToken, promise);
1108
+ return promise;
1109
+ }
1110
+ async function handleOAuth401ErrorImpl(failedAccessToken) {
1111
+ // Clear caches and re-read from keychain (async — sync read blocks ~100ms/call)
1112
+ clearOAuthTokenCache();
1113
+ const currentTokens = await getClaudeAIOAuthTokensAsync();
1114
+ if (!currentTokens?.refreshToken) {
1115
+ return false;
1116
+ }
1117
+ // If keychain has a different token, another tab already refreshed - use it
1118
+ if (currentTokens.accessToken !== failedAccessToken) {
1119
+ logEvent('thaddeus_oauth_401_recovered_from_keychain', {});
1120
+ return true;
1121
+ }
1122
+ // Same token that failed - force refresh, bypassing local expiration check
1123
+ return checkAndRefreshOAuthTokenIfNeeded(0, true);
1124
+ }
1125
+ /**
1126
+ * Reads OAuth tokens asynchronously, avoiding blocking keychain reads.
1127
+ * Delegates to the sync memoized version for env var / file descriptor tokens
1128
+ * (which don't hit the keychain), and only uses async for storage reads.
1129
+ */
1130
+ export async function getClaudeAIOAuthTokensAsync() {
1131
+ if (isBareMode())
1132
+ return null;
1133
+ // Env var and FD tokens are sync and don't hit the keychain
1134
+ if (process.env.THADDEUS_OAUTH_TOKEN ||
1135
+ getOAuthTokenFromFileDescriptor()) {
1136
+ return getClaudeAIOAuthTokens();
1137
+ }
1138
+ try {
1139
+ const secureStorage = getSecureStorage();
1140
+ const storageData = await secureStorage.readAsync();
1141
+ const oauthData = storageData?.claudeAiOauth;
1142
+ if (!oauthData?.accessToken) {
1143
+ return null;
1144
+ }
1145
+ return oauthData;
1146
+ }
1147
+ catch (error) {
1148
+ logError(error);
1149
+ return null;
1150
+ }
1151
+ }
1152
+ // In-flight promise for deduplicating concurrent calls
1153
+ let pendingRefreshCheck = null;
1154
+ export function checkAndRefreshOAuthTokenIfNeeded(retryCount = 0, force = false) {
1155
+ // Deduplicate concurrent non-retry, non-force calls
1156
+ if (retryCount === 0 && !force) {
1157
+ if (pendingRefreshCheck) {
1158
+ return pendingRefreshCheck;
1159
+ }
1160
+ const promise = checkAndRefreshOAuthTokenIfNeededImpl(retryCount, force);
1161
+ pendingRefreshCheck = promise.finally(() => {
1162
+ pendingRefreshCheck = null;
1163
+ });
1164
+ return pendingRefreshCheck;
1165
+ }
1166
+ return checkAndRefreshOAuthTokenIfNeededImpl(retryCount, force);
1167
+ }
1168
+ async function checkAndRefreshOAuthTokenIfNeededImpl(retryCount, force) {
1169
+ const MAX_RETRIES = 5;
1170
+ await invalidateOAuthCacheIfDiskChanged();
1171
+ // First check if token is expired with cached value
1172
+ // Skip this check if force=true (server already told us token is bad)
1173
+ const tokens = getClaudeAIOAuthTokens();
1174
+ if (!force) {
1175
+ if (!tokens?.refreshToken || !isOAuthTokenExpired(tokens.expiresAt)) {
1176
+ return false;
1177
+ }
1178
+ }
1179
+ if (!tokens?.refreshToken) {
1180
+ return false;
1181
+ }
1182
+ if (!shouldUseClaudeAIAuth(tokens.scopes)) {
1183
+ return false;
1184
+ }
1185
+ // Re-read tokens async to check if they're still expired
1186
+ // Another process might have refreshed them
1187
+ getClaudeAIOAuthTokens.cache?.clear?.();
1188
+ clearKeychainCache();
1189
+ const freshTokens = await getClaudeAIOAuthTokensAsync();
1190
+ if (!freshTokens?.refreshToken ||
1191
+ !isOAuthTokenExpired(freshTokens.expiresAt)) {
1192
+ return false;
1193
+ }
1194
+ // Tokens are still expired, try to acquire lock and refresh
1195
+ const claudeDir = getClaudeConfigHomeDir();
1196
+ await mkdir(claudeDir, { recursive: true });
1197
+ let release;
1198
+ try {
1199
+ logEvent('thaddeus_oauth_token_refresh_lock_acquiring', {});
1200
+ release = await lockfile.lock(claudeDir);
1201
+ logEvent('thaddeus_oauth_token_refresh_lock_acquired', {});
1202
+ }
1203
+ catch (err) {
1204
+ if (err.code === 'ELOCKED') {
1205
+ // Another process has the lock, let's retry if we haven't exceeded max retries
1206
+ if (retryCount < MAX_RETRIES) {
1207
+ logEvent('thaddeus_oauth_token_refresh_lock_retry', {
1208
+ retryCount: retryCount + 1,
1209
+ });
1210
+ // Wait a bit before retrying
1211
+ await sleep(1000 + Math.random() * 1000);
1212
+ return checkAndRefreshOAuthTokenIfNeededImpl(retryCount + 1, force);
1213
+ }
1214
+ logEvent('thaddeus_oauth_token_refresh_lock_retry_limit_reached', {
1215
+ maxRetries: MAX_RETRIES,
1216
+ });
1217
+ return false;
1218
+ }
1219
+ logError(err);
1220
+ logEvent('thaddeus_oauth_token_refresh_lock_error', {
1221
+ error: errorMessage(err),
1222
+ });
1223
+ return false;
1224
+ }
1225
+ try {
1226
+ // Check one more time after acquiring lock
1227
+ getClaudeAIOAuthTokens.cache?.clear?.();
1228
+ clearKeychainCache();
1229
+ const lockedTokens = await getClaudeAIOAuthTokensAsync();
1230
+ if (!lockedTokens?.refreshToken ||
1231
+ !isOAuthTokenExpired(lockedTokens.expiresAt)) {
1232
+ logEvent('thaddeus_oauth_token_refresh_race_resolved', {});
1233
+ return false;
1234
+ }
1235
+ logEvent('thaddeus_oauth_token_refresh_starting', {});
1236
+ const refreshedTokens = await refreshOAuthToken(lockedTokens.refreshToken, {
1237
+ // For Thaddeus subscribers, omit scopes so the default
1238
+ // THADDEUS_OAUTH_SCOPES applies — this allows scope expansion
1239
+ // (e.g. adding user:file_upload) on refresh without re-login.
1240
+ scopes: shouldUseClaudeAIAuth(lockedTokens.scopes)
1241
+ ? undefined
1242
+ : lockedTokens.scopes,
1243
+ });
1244
+ saveOAuthTokensIfNeeded(refreshedTokens);
1245
+ // Clear the cache after refreshing token
1246
+ getClaudeAIOAuthTokens.cache?.clear?.();
1247
+ clearKeychainCache();
1248
+ return true;
1249
+ }
1250
+ catch (error) {
1251
+ logError(error);
1252
+ getClaudeAIOAuthTokens.cache?.clear?.();
1253
+ clearKeychainCache();
1254
+ const currentTokens = await getClaudeAIOAuthTokensAsync();
1255
+ if (currentTokens && !isOAuthTokenExpired(currentTokens.expiresAt)) {
1256
+ logEvent('thaddeus_oauth_token_refresh_race_recovered', {});
1257
+ return true;
1258
+ }
1259
+ return false;
1260
+ }
1261
+ finally {
1262
+ logEvent('thaddeus_oauth_token_refresh_lock_releasing', {});
1263
+ await release();
1264
+ logEvent('thaddeus_oauth_token_refresh_lock_released', {});
1265
+ }
1266
+ }
1267
+ export function isClaudeAISubscriber() {
1268
+ if (!isAnthropicAuthEnabled()) {
1269
+ return false;
1270
+ }
1271
+ return shouldUseClaudeAIAuth(getClaudeAIOAuthTokens()?.scopes);
1272
+ }
1273
+ /**
1274
+ * Check if the current OAuth token has the user:profile scope.
1275
+ *
1276
+ * Real /login tokens always include this scope. Env-var and file-descriptor
1277
+ * tokens (service keys) hardcode scopes to ['user:inference'] only. Use this
1278
+ * to gate calls to profile-scoped endpoints so service key sessions don't
1279
+ * generate 403 storms against /api/oauth/profile, bootstrap, etc.
1280
+ */
1281
+ export function hasProfileScope() {
1282
+ return (getClaudeAIOAuthTokens()?.scopes?.includes(THADDEUS_PROFILE_SCOPE) ?? false);
1283
+ }
1284
+ export function is1PApiCustomer() {
1285
+ // 1P API customers are users who are NOT:
1286
+ // 1. Thaddeus subscribers (Max, Pro, Enterprise, Team)
1287
+ // 2. Vertex AI users
1288
+ // 3. AWS Bedrock users
1289
+ // 4. Foundry users
1290
+ // Exclude Vertex, Bedrock, and Foundry customers
1291
+ if (isEnvTruthy(process.env.THADDEUS_USE_BEDROCK) ||
1292
+ isEnvTruthy(process.env.THADDEUS_USE_VERTEX) ||
1293
+ isEnvTruthy(process.env.THADDEUS_USE_FOUNDRY)) {
1294
+ return false;
1295
+ }
1296
+ // Exclude Thaddeus subscribers
1297
+ if (isClaudeAISubscriber()) {
1298
+ return false;
1299
+ }
1300
+ // Everyone else is an API customer (OAuth API customers, direct API key users, etc.)
1301
+ return true;
1302
+ }
1303
+ /**
1304
+ * Gets OAuth account information when Delphi Labs auth is enabled.
1305
+ * Returns undefined when using external API keys or third-party services.
1306
+ */
1307
+ export function getOauthAccountInfo() {
1308
+ return isAnthropicAuthEnabled() ? getGlobalConfig().oauthAccount : undefined;
1309
+ }
1310
+ /**
1311
+ * Checks if overage/extra usage provisioning is allowed for this organization.
1312
+ * This mirrors the logic in apps/claude-ai `useIsOverageProvisioningAllowed` hook as closely as possible.
1313
+ */
1314
+ export function isOverageProvisioningAllowed() {
1315
+ const accountInfo = getOauthAccountInfo();
1316
+ const billingType = accountInfo?.billingType;
1317
+ // Must be a Thaddeus subscriber with a supported subscription type
1318
+ if (!isClaudeAISubscriber() || !billingType) {
1319
+ return false;
1320
+ }
1321
+ // only allow Stripe and mobile billing types to purchase extra usage
1322
+ if (billingType !== 'stripe_subscription' &&
1323
+ billingType !== 'stripe_subscription_contracted' &&
1324
+ billingType !== 'apple_subscription' &&
1325
+ billingType !== 'google_play_subscription') {
1326
+ return false;
1327
+ }
1328
+ return true;
1329
+ }
1330
+ // Returns whether the user has Opus access at all, regardless of whether they
1331
+ // are a subscriber or PayG.
1332
+ export function hasOpusAccess() {
1333
+ const subscriptionType = getSubscriptionType();
1334
+ return (subscriptionType === 'max' ||
1335
+ subscriptionType === 'enterprise' ||
1336
+ subscriptionType === 'team' ||
1337
+ subscriptionType === 'pro' ||
1338
+ // subscriptionType === null covers both API users and the case where
1339
+ // subscribers do not have subscription type populated. For those
1340
+ // subscribers, when in doubt, we should not limit their access to Opus.
1341
+ subscriptionType === null);
1342
+ }
1343
+ export function getSubscriptionType() {
1344
+ // Check for mock subscription type first (ANT-only testing)
1345
+ if (shouldUseMockSubscription()) {
1346
+ return getMockSubscriptionType();
1347
+ }
1348
+ if (!isAnthropicAuthEnabled()) {
1349
+ return null;
1350
+ }
1351
+ const oauthTokens = getClaudeAIOAuthTokens();
1352
+ if (!oauthTokens) {
1353
+ return null;
1354
+ }
1355
+ return oauthTokens.subscriptionType ?? null;
1356
+ }
1357
+ export function isMaxSubscriber() {
1358
+ return getSubscriptionType() === 'max';
1359
+ }
1360
+ export function isTeamSubscriber() {
1361
+ return getSubscriptionType() === 'team';
1362
+ }
1363
+ export function isTeamPremiumSubscriber() {
1364
+ return (getSubscriptionType() === 'team' &&
1365
+ getRateLimitTier() === 'default_claude_max_5x');
1366
+ }
1367
+ export function isEnterpriseSubscriber() {
1368
+ return getSubscriptionType() === 'enterprise';
1369
+ }
1370
+ export function isProSubscriber() {
1371
+ return getSubscriptionType() === 'pro';
1372
+ }
1373
+ export function getRateLimitTier() {
1374
+ if (!isAnthropicAuthEnabled()) {
1375
+ return null;
1376
+ }
1377
+ const oauthTokens = getClaudeAIOAuthTokens();
1378
+ if (!oauthTokens) {
1379
+ return null;
1380
+ }
1381
+ return oauthTokens.rateLimitTier ?? null;
1382
+ }
1383
+ export function getSubscriptionName() {
1384
+ const subscriptionType = getSubscriptionType();
1385
+ switch (subscriptionType) {
1386
+ case 'enterprise':
1387
+ return 'Thaddeus Enterprise';
1388
+ case 'team':
1389
+ return 'Thaddeus Team';
1390
+ case 'max':
1391
+ return 'Thaddeus Max';
1392
+ case 'pro':
1393
+ return 'Thaddeus Pro';
1394
+ default:
1395
+ return 'Thaddeus API';
1396
+ }
1397
+ }
1398
+ /** Check if using third-party services (Bedrock or Vertex or Foundry) */
1399
+ export function isUsing3PServices() {
1400
+ return !!(isEnvTruthy(process.env.THADDEUS_USE_BEDROCK) ||
1401
+ isEnvTruthy(process.env.THADDEUS_USE_VERTEX) ||
1402
+ isEnvTruthy(process.env.THADDEUS_USE_FOUNDRY));
1403
+ }
1404
+ /**
1405
+ * Get the configured otelHeadersHelper from settings
1406
+ */
1407
+ function getConfiguredOtelHeadersHelper() {
1408
+ const mergedSettings = getSettings_DEPRECATED() || {};
1409
+ return mergedSettings.otelHeadersHelper;
1410
+ }
1411
+ /**
1412
+ * Check if the configured otelHeadersHelper comes from project settings (projectSettings or localSettings)
1413
+ */
1414
+ export function isOtelHeadersHelperFromProjectOrLocalSettings() {
1415
+ const otelHeadersHelper = getConfiguredOtelHeadersHelper();
1416
+ if (!otelHeadersHelper) {
1417
+ return false;
1418
+ }
1419
+ const projectSettings = getSettingsForSource('projectSettings');
1420
+ const localSettings = getSettingsForSource('localSettings');
1421
+ return (projectSettings?.otelHeadersHelper === otelHeadersHelper ||
1422
+ localSettings?.otelHeadersHelper === otelHeadersHelper);
1423
+ }
1424
+ // Cache for debouncing otelHeadersHelper calls
1425
+ let cachedOtelHeaders = null;
1426
+ let cachedOtelHeadersTimestamp = 0;
1427
+ const DEFAULT_OTEL_HEADERS_DEBOUNCE_MS = 29 * 60 * 1000; // 29 minutes
1428
+ export function getOtelHeadersFromHelper() {
1429
+ const otelHeadersHelper = getConfiguredOtelHeadersHelper();
1430
+ if (!otelHeadersHelper) {
1431
+ return {};
1432
+ }
1433
+ // Return cached headers if still valid (debounce)
1434
+ const debounceMs = parseInt(process.env.THADDEUS_OTEL_HEADERS_HELPER_DEBOUNCE_MS ||
1435
+ DEFAULT_OTEL_HEADERS_DEBOUNCE_MS.toString());
1436
+ if (cachedOtelHeaders &&
1437
+ Date.now() - cachedOtelHeadersTimestamp < debounceMs) {
1438
+ return cachedOtelHeaders;
1439
+ }
1440
+ if (isOtelHeadersHelperFromProjectOrLocalSettings()) {
1441
+ // Check if trust has been established for this project
1442
+ const hasTrust = checkHasTrustDialogAccepted();
1443
+ if (!hasTrust) {
1444
+ return {};
1445
+ }
1446
+ }
1447
+ try {
1448
+ const result = execSyncWithDefaults_DEPRECATED(otelHeadersHelper, {
1449
+ timeout: 30000, // 30 seconds - allows for auth service latency
1450
+ })
1451
+ ?.toString()
1452
+ .trim();
1453
+ if (!result) {
1454
+ throw new Error('otelHeadersHelper did not return a valid value');
1455
+ }
1456
+ const headers = jsonParse(result);
1457
+ if (typeof headers !== 'object' ||
1458
+ headers === null ||
1459
+ Array.isArray(headers)) {
1460
+ throw new Error('otelHeadersHelper must return a JSON object with string key-value pairs');
1461
+ }
1462
+ // Validate all values are strings
1463
+ for (const [key, value] of Object.entries(headers)) {
1464
+ if (typeof value !== 'string') {
1465
+ throw new Error(`otelHeadersHelper returned non-string value for key "${key}": ${typeof value}`);
1466
+ }
1467
+ }
1468
+ // Cache the result
1469
+ cachedOtelHeaders = headers;
1470
+ cachedOtelHeadersTimestamp = Date.now();
1471
+ return cachedOtelHeaders;
1472
+ }
1473
+ catch (error) {
1474
+ logError(new Error(`Error getting OpenTelemetry headers from otelHeadersHelper (in settings): ${errorMessage(error)}`));
1475
+ throw error;
1476
+ }
1477
+ }
1478
+ function isConsumerPlan(plan) {
1479
+ return plan === 'max' || plan === 'pro';
1480
+ }
1481
+ export function isConsumerSubscriber() {
1482
+ const subscriptionType = getSubscriptionType();
1483
+ return (isClaudeAISubscriber() &&
1484
+ subscriptionType !== null &&
1485
+ isConsumerPlan(subscriptionType));
1486
+ }
1487
+ export function getAccountInformation() {
1488
+ const apiProvider = getAPIProvider();
1489
+ // Only provide account info for first-party Delphi Labs API
1490
+ if (apiProvider !== 'firstParty') {
1491
+ return undefined;
1492
+ }
1493
+ const { source: authTokenSource } = getAuthTokenSource();
1494
+ const accountInfo = {};
1495
+ if (authTokenSource === 'THADDEUS_OAUTH_TOKEN' ||
1496
+ authTokenSource === 'THADDEUS_OAUTH_TOKEN_FILE_DESCRIPTOR') {
1497
+ accountInfo.tokenSource = authTokenSource;
1498
+ }
1499
+ else if (isClaudeAISubscriber()) {
1500
+ accountInfo.subscription = getSubscriptionName();
1501
+ }
1502
+ else {
1503
+ accountInfo.tokenSource = authTokenSource;
1504
+ }
1505
+ const { key: apiKey, source: apiKeySource } = getAnthropicApiKeyWithSource();
1506
+ if (apiKey) {
1507
+ accountInfo.apiKeySource = apiKeySource;
1508
+ }
1509
+ // We don't know the organization if we're relying on an external API key or auth token
1510
+ if (authTokenSource === 'claude.ai' ||
1511
+ apiKeySource === '/login managed key') {
1512
+ // Get organization name from OAuth account info
1513
+ const orgName = getOauthAccountInfo()?.organizationName;
1514
+ if (orgName) {
1515
+ accountInfo.organization = orgName;
1516
+ }
1517
+ }
1518
+ const email = getOauthAccountInfo()?.emailAddress;
1519
+ if ((authTokenSource === 'claude.ai' ||
1520
+ apiKeySource === '/login managed key') &&
1521
+ email) {
1522
+ accountInfo.email = email;
1523
+ }
1524
+ return accountInfo;
1525
+ }
1526
+ /**
1527
+ * Validate that the active OAuth token belongs to the organization required
1528
+ * by `forceLoginOrgUUID` in managed settings. Returns a result object
1529
+ * rather than throwing so callers can choose how to surface the error.
1530
+ *
1531
+ * Fails closed: if `forceLoginOrgUUID` is set and we cannot determine the
1532
+ * token's org (network error, missing profile data), validation fails.
1533
+ */
1534
+ export async function validateForceLoginOrg() {
1535
+ // `claude ssh` remote: real auth lives on the local machine and is injected
1536
+ // by the proxy. The placeholder token can't be validated against the profile
1537
+ // endpoint. The local side already ran this check before establishing the session.
1538
+ if (process.env.ANTHROPIC_UNIX_SOCKET) {
1539
+ return { valid: true };
1540
+ }
1541
+ if (!isAnthropicAuthEnabled()) {
1542
+ return { valid: true };
1543
+ }
1544
+ const requiredOrgUuid = getSettingsForSource('policySettings')?.forceLoginOrgUUID;
1545
+ if (!requiredOrgUuid) {
1546
+ return { valid: true };
1547
+ }
1548
+ // Ensure the access token is fresh before hitting the profile endpoint.
1549
+ // No-op for env-var tokens (refreshToken is null).
1550
+ await checkAndRefreshOAuthTokenIfNeeded();
1551
+ const tokens = getClaudeAIOAuthTokens();
1552
+ if (!tokens) {
1553
+ return { valid: true };
1554
+ }
1555
+ // Always fetch the authoritative org UUID from the profile endpoint.
1556
+ // Even keychain-sourced tokens verify server-side: the cached org UUID
1557
+ // in ~/.claude.json is user-writable and cannot be trusted.
1558
+ const { source } = getAuthTokenSource();
1559
+ const isEnvVarToken = source === 'THADDEUS_OAUTH_TOKEN' ||
1560
+ source === 'THADDEUS_OAUTH_TOKEN_FILE_DESCRIPTOR';
1561
+ const profile = await getOauthProfileFromOauthToken(tokens.accessToken);
1562
+ if (!profile) {
1563
+ // Fail closed — we can't verify the org
1564
+ return {
1565
+ valid: false,
1566
+ message: `Unable to verify organization for the current authentication token.\n` +
1567
+ `This machine requires organization ${requiredOrgUuid} but the profile could not be fetched.\n` +
1568
+ `This may be a network error, or the token may lack the user:profile scope required for\n` +
1569
+ `verification (tokens from 'claude setup-token' do not include this scope).\n` +
1570
+ `Try again, or obtain a full-scope token via 'claude auth login'.`,
1571
+ };
1572
+ }
1573
+ const tokenOrgUuid = profile.organization.uuid;
1574
+ if (tokenOrgUuid === requiredOrgUuid) {
1575
+ return { valid: true };
1576
+ }
1577
+ if (isEnvVarToken) {
1578
+ const envVarName = source === 'THADDEUS_OAUTH_TOKEN'
1579
+ ? 'THADDEUS_OAUTH_TOKEN'
1580
+ : 'THADDEUS_OAUTH_TOKEN_FILE_DESCRIPTOR';
1581
+ return {
1582
+ valid: false,
1583
+ message: `The ${envVarName} environment variable provides a token for a\n` +
1584
+ `different organization than required by this machine's managed settings.\n\n` +
1585
+ `Required organization: ${requiredOrgUuid}\n` +
1586
+ `Token organization: ${tokenOrgUuid}\n\n` +
1587
+ `Remove the environment variable or obtain a token for the correct organization.`,
1588
+ };
1589
+ }
1590
+ return {
1591
+ valid: false,
1592
+ message: `Your authentication token belongs to organization ${tokenOrgUuid},\n` +
1593
+ `but this machine requires organization ${requiredOrgUuid}.\n\n` +
1594
+ `Please log in with the correct organization: claude auth login`,
1595
+ };
1596
+ }
1597
+ class GcpCredentialsTimeoutError extends Error {
1598
+ }