@xortex/xcode 3.0.0
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.
- package/LICENSE +21 -0
- package/README.md +171 -0
- package/bin/xcode +127 -0
- package/bin/xcode-test +84 -0
- package/bin/xcode.cmd +31 -0
- package/constants/apiLimits.ts +94 -0
- package/constants/betas.ts +52 -0
- package/constants/common.ts +33 -0
- package/constants/cyberRiskInstruction.ts +24 -0
- package/constants/errorIds.ts +15 -0
- package/constants/figures.ts +45 -0
- package/constants/files.ts +156 -0
- package/constants/github-app.ts +144 -0
- package/constants/keys.ts +11 -0
- package/constants/messages.ts +1 -0
- package/constants/oauth.ts +234 -0
- package/constants/outputStyles.ts +216 -0
- package/constants/product.ts +76 -0
- package/constants/prompts.ts +939 -0
- package/constants/spinnerVerbs.ts +204 -0
- package/constants/system.ts +95 -0
- package/constants/systemPromptSections.ts +68 -0
- package/constants/toolLimits.ts +56 -0
- package/constants/tools.ts +112 -0
- package/constants/turnCompletionVerbs.ts +12 -0
- package/constants/xml.ts +86 -0
- package/entrypoints/agentSdkTypes.ts +443 -0
- package/entrypoints/cli.tsx +307 -0
- package/entrypoints/init.ts +340 -0
- package/entrypoints/mcp.ts +196 -0
- package/entrypoints/sandboxTypes.ts +156 -0
- package/entrypoints/sdk/controlSchemas.ts +663 -0
- package/entrypoints/sdk/coreSchemas.ts +1889 -0
- package/entrypoints/sdk/coreTypes.generated.ts +2 -0
- package/entrypoints/sdk/coreTypes.ts +62 -0
- package/entrypoints/sdk/runtimeTypes.ts +140 -0
- package/entrypoints/sdk/sdkUtilityTypes.ts +3 -0
- package/entrypoints/sdk/toolTypes.ts +90 -0
- package/main.tsx +4686 -0
- package/package.json +120 -0
- package/services/AgentSummary/agentSummary.ts +179 -0
- package/services/MagicDocs/magicDocs.ts +254 -0
- package/services/MagicDocs/prompts.ts +127 -0
- package/services/PromptSuggestion/promptSuggestion.ts +523 -0
- package/services/PromptSuggestion/speculation.ts +991 -0
- package/services/SessionMemory/prompts.ts +324 -0
- package/services/SessionMemory/sessionMemory.ts +495 -0
- package/services/SessionMemory/sessionMemoryUtils.ts +207 -0
- package/services/analytics/config.ts +38 -0
- package/services/analytics/datadog.ts +307 -0
- package/services/analytics/firstPartyEventLogger.ts +449 -0
- package/services/analytics/firstPartyEventLoggingExporter.ts +806 -0
- package/services/analytics/growthbook.ts +1155 -0
- package/services/analytics/index.ts +173 -0
- package/services/analytics/metadata.ts +973 -0
- package/services/analytics/sink.ts +114 -0
- package/services/analytics/sinkKillswitch.ts +25 -0
- package/services/api/adminRequests.ts +119 -0
- package/services/api/bootstrap.ts +141 -0
- package/services/api/claude.ts +3422 -0
- package/services/api/client.ts +406 -0
- package/services/api/dumpPrompts.ts +226 -0
- package/services/api/emptyUsage.ts +22 -0
- package/services/api/errorUtils.ts +260 -0
- package/services/api/errors.ts +1207 -0
- package/services/api/filesApi.ts +748 -0
- package/services/api/firstTokenDate.ts +60 -0
- package/services/api/gemini.ts +359 -0
- package/services/api/geminiAdapter.ts +123 -0
- package/services/api/geminiClient.ts +291 -0
- package/services/api/grove.ts +357 -0
- package/services/api/logging.ts +788 -0
- package/services/api/metricsOptOut.ts +159 -0
- package/services/api/openRouterClient.ts +453 -0
- package/services/api/overageCreditGrant.ts +137 -0
- package/services/api/promptCacheBreakDetection.ts +727 -0
- package/services/api/referral.ts +281 -0
- package/services/api/sessionIngress.ts +514 -0
- package/services/api/ultrareviewQuota.ts +38 -0
- package/services/api/usage.ts +63 -0
- package/services/api/withRetry.ts +822 -0
- package/services/autoDream/autoDream.ts +324 -0
- package/services/autoDream/config.ts +21 -0
- package/services/autoDream/consolidationLock.ts +140 -0
- package/services/autoDream/consolidationPrompt.ts +65 -0
- package/services/awaySummary.ts +74 -0
- package/services/claudeAiLimits.ts +515 -0
- package/services/claudeAiLimitsHook.ts +23 -0
- package/services/compact/apiMicrocompact.ts +153 -0
- package/services/compact/autoCompact.ts +351 -0
- package/services/compact/compact.ts +1705 -0
- package/services/compact/compactWarningHook.ts +16 -0
- package/services/compact/compactWarningState.ts +18 -0
- package/services/compact/grouping.ts +63 -0
- package/services/compact/microCompact.ts +530 -0
- package/services/compact/postCompactCleanup.ts +77 -0
- package/services/compact/prompt.ts +374 -0
- package/services/compact/sessionMemoryCompact.ts +630 -0
- package/services/compact/timeBasedMCConfig.ts +43 -0
- package/services/diagnosticTracking.ts +397 -0
- package/services/extractMemories/extractMemories.ts +517 -0
- package/services/extractMemories/prompts.ts +154 -0
- package/services/internalLogging.ts +90 -0
- package/services/lsp/LSPClient.ts +447 -0
- package/services/lsp/LSPDiagnosticRegistry.ts +386 -0
- package/services/lsp/LSPServerInstance.ts +511 -0
- package/services/lsp/LSPServerManager.ts +420 -0
- package/services/lsp/config.ts +79 -0
- package/services/lsp/manager.ts +289 -0
- package/services/lsp/passiveFeedback.ts +328 -0
- package/services/mcp/InProcessTransport.ts +63 -0
- package/services/mcp/MCPConnectionManager.tsx +73 -0
- package/services/mcp/SdkControlTransport.ts +136 -0
- package/services/mcp/auth.ts +2465 -0
- package/services/mcp/channelAllowlist.ts +76 -0
- package/services/mcp/channelNotification.ts +316 -0
- package/services/mcp/channelPermissions.ts +240 -0
- package/services/mcp/claudeai.ts +164 -0
- package/services/mcp/client.ts +3348 -0
- package/services/mcp/config.ts +1578 -0
- package/services/mcp/elicitationHandler.ts +313 -0
- package/services/mcp/envExpansion.ts +38 -0
- package/services/mcp/headersHelper.ts +138 -0
- package/services/mcp/mcpStringUtils.ts +106 -0
- package/services/mcp/normalization.ts +23 -0
- package/services/mcp/oauthPort.ts +78 -0
- package/services/mcp/officialRegistry.ts +72 -0
- package/services/mcp/types.ts +258 -0
- package/services/mcp/useManageMCPConnections.ts +1141 -0
- package/services/mcp/utils.ts +575 -0
- package/services/mcp/vscodeSdkMcp.ts +112 -0
- package/services/mcp/xaa.ts +511 -0
- package/services/mcp/xaaIdpLogin.ts +487 -0
- package/services/mcpServerApproval.tsx +41 -0
- package/services/mockRateLimits.ts +882 -0
- package/services/notifier.ts +156 -0
- package/services/oauth/auth-code-listener.ts +211 -0
- package/services/oauth/client.ts +566 -0
- package/services/oauth/crypto.ts +23 -0
- package/services/oauth/getOauthProfile.ts +53 -0
- package/services/oauth/index.ts +198 -0
- package/services/plugins/PluginInstallationManager.ts +184 -0
- package/services/plugins/pluginCliCommands.ts +344 -0
- package/services/plugins/pluginOperations.ts +1088 -0
- package/services/policyLimits/index.ts +663 -0
- package/services/policyLimits/types.ts +27 -0
- package/services/preventSleep.ts +165 -0
- package/services/rateLimitMessages.ts +344 -0
- package/services/rateLimitMocking.ts +144 -0
- package/services/remoteManagedSettings/index.ts +638 -0
- package/services/remoteManagedSettings/securityCheck.tsx +74 -0
- package/services/remoteManagedSettings/syncCache.ts +112 -0
- package/services/remoteManagedSettings/syncCacheState.ts +96 -0
- package/services/remoteManagedSettings/types.ts +31 -0
- package/services/settingsSync/index.ts +581 -0
- package/services/settingsSync/types.ts +67 -0
- package/services/teamMemorySync/index.ts +1256 -0
- package/services/teamMemorySync/secretScanner.ts +324 -0
- package/services/teamMemorySync/teamMemSecretGuard.ts +44 -0
- package/services/teamMemorySync/types.ts +156 -0
- package/services/teamMemorySync/watcher.ts +387 -0
- package/services/tips/tipHistory.ts +17 -0
- package/services/tips/tipRegistry.ts +686 -0
- package/services/tips/tipScheduler.ts +58 -0
- package/services/tokenEstimation.ts +495 -0
- package/services/toolUseSummary/toolUseSummaryGenerator.ts +112 -0
- package/services/tools/StreamingToolExecutor.ts +530 -0
- package/services/tools/toolExecution.ts +1745 -0
- package/services/tools/toolHooks.ts +650 -0
- package/services/tools/toolOrchestration.ts +188 -0
- package/services/vcr.ts +406 -0
- package/services/voice.ts +525 -0
- package/services/voiceKeyterms.ts +106 -0
- package/services/voiceStreamSTT.ts +544 -0
- package/tools/AgentTool/AgentTool.tsx +1398 -0
- package/tools/AgentTool/UI.tsx +872 -0
- package/tools/AgentTool/agentColorManager.ts +66 -0
- package/tools/AgentTool/agentDisplay.ts +104 -0
- package/tools/AgentTool/agentMemory.ts +177 -0
- package/tools/AgentTool/agentMemorySnapshot.ts +197 -0
- package/tools/AgentTool/agentToolUtils.ts +686 -0
- package/tools/AgentTool/built-in/claudeCodeGuideAgent.ts +205 -0
- package/tools/AgentTool/built-in/exploreAgent.ts +83 -0
- package/tools/AgentTool/built-in/generalPurposeAgent.ts +34 -0
- package/tools/AgentTool/built-in/planAgent.ts +92 -0
- package/tools/AgentTool/built-in/statuslineSetup.ts +144 -0
- package/tools/AgentTool/built-in/verificationAgent.ts +152 -0
- package/tools/AgentTool/builtInAgents.ts +72 -0
- package/tools/AgentTool/constants.ts +12 -0
- package/tools/AgentTool/forkSubagent.ts +210 -0
- package/tools/AgentTool/loadAgentsDir.ts +755 -0
- package/tools/AgentTool/prompt.ts +287 -0
- package/tools/AgentTool/resumeAgent.ts +265 -0
- package/tools/AgentTool/runAgent.ts +973 -0
- package/tools/AskUserQuestionTool/AskUserQuestionTool.tsx +266 -0
- package/tools/AskUserQuestionTool/prompt.ts +44 -0
- package/tools/BashTool/BashTool.tsx +1144 -0
- package/tools/BashTool/BashToolResultMessage.tsx +191 -0
- package/tools/BashTool/UI.tsx +185 -0
- package/tools/BashTool/bashCommandHelpers.ts +265 -0
- package/tools/BashTool/bashPermissions.ts +2621 -0
- package/tools/BashTool/bashSecurity.ts +2592 -0
- package/tools/BashTool/commandSemantics.ts +140 -0
- package/tools/BashTool/commentLabel.ts +13 -0
- package/tools/BashTool/destructiveCommandWarning.ts +102 -0
- package/tools/BashTool/modeValidation.ts +115 -0
- package/tools/BashTool/pathValidation.ts +1303 -0
- package/tools/BashTool/prompt.ts +369 -0
- package/tools/BashTool/readOnlyValidation.ts +1990 -0
- package/tools/BashTool/sedEditParser.ts +322 -0
- package/tools/BashTool/sedValidation.ts +684 -0
- package/tools/BashTool/shouldUseSandbox.ts +153 -0
- package/tools/BashTool/toolName.ts +2 -0
- package/tools/BashTool/utils.ts +223 -0
- package/tools/BriefTool/BriefTool.ts +204 -0
- package/tools/BriefTool/UI.tsx +101 -0
- package/tools/BriefTool/attachments.ts +110 -0
- package/tools/BriefTool/prompt.ts +22 -0
- package/tools/BriefTool/upload.ts +174 -0
- package/tools/ConfigTool/ConfigTool.ts +467 -0
- package/tools/ConfigTool/UI.tsx +38 -0
- package/tools/ConfigTool/constants.ts +1 -0
- package/tools/ConfigTool/prompt.ts +93 -0
- package/tools/ConfigTool/supportedSettings.ts +211 -0
- package/tools/EnterPlanModeTool/EnterPlanModeTool.ts +126 -0
- package/tools/EnterPlanModeTool/UI.tsx +33 -0
- package/tools/EnterPlanModeTool/constants.ts +1 -0
- package/tools/EnterPlanModeTool/prompt.ts +170 -0
- package/tools/EnterWorktreeTool/EnterWorktreeTool.ts +127 -0
- package/tools/EnterWorktreeTool/UI.tsx +20 -0
- package/tools/EnterWorktreeTool/constants.ts +1 -0
- package/tools/EnterWorktreeTool/prompt.ts +30 -0
- package/tools/ExitPlanModeTool/ExitPlanModeV2Tool.ts +493 -0
- package/tools/ExitPlanModeTool/UI.tsx +82 -0
- package/tools/ExitPlanModeTool/constants.ts +2 -0
- package/tools/ExitPlanModeTool/prompt.ts +29 -0
- package/tools/ExitWorktreeTool/ExitWorktreeTool.ts +329 -0
- package/tools/ExitWorktreeTool/UI.tsx +25 -0
- package/tools/ExitWorktreeTool/constants.ts +1 -0
- package/tools/ExitWorktreeTool/prompt.ts +32 -0
- package/tools/FileEditTool/FileEditTool.ts +625 -0
- package/tools/FileEditTool/UI.tsx +289 -0
- package/tools/FileEditTool/constants.ts +11 -0
- package/tools/FileEditTool/prompt.ts +28 -0
- package/tools/FileEditTool/types.ts +85 -0
- package/tools/FileEditTool/utils.ts +775 -0
- package/tools/FileReadTool/FileReadTool.ts +1183 -0
- package/tools/FileReadTool/UI.tsx +185 -0
- package/tools/FileReadTool/imageProcessor.ts +94 -0
- package/tools/FileReadTool/limits.ts +92 -0
- package/tools/FileReadTool/prompt.ts +49 -0
- package/tools/FileWriteTool/FileWriteTool.ts +434 -0
- package/tools/FileWriteTool/UI.tsx +405 -0
- package/tools/FileWriteTool/prompt.ts +18 -0
- package/tools/GlobTool/GlobTool.ts +198 -0
- package/tools/GlobTool/UI.tsx +63 -0
- package/tools/GlobTool/prompt.ts +7 -0
- package/tools/GrepTool/GrepTool.ts +577 -0
- package/tools/GrepTool/UI.tsx +201 -0
- package/tools/GrepTool/prompt.ts +18 -0
- package/tools/LSPTool/LSPTool.ts +860 -0
- package/tools/LSPTool/UI.tsx +228 -0
- package/tools/LSPTool/formatters.ts +592 -0
- package/tools/LSPTool/prompt.ts +21 -0
- package/tools/LSPTool/schemas.ts +215 -0
- package/tools/LSPTool/symbolContext.ts +90 -0
- package/tools/ListMcpResourcesTool/ListMcpResourcesTool.ts +123 -0
- package/tools/ListMcpResourcesTool/UI.tsx +29 -0
- package/tools/ListMcpResourcesTool/prompt.ts +20 -0
- package/tools/MCPTool/MCPTool.ts +77 -0
- package/tools/MCPTool/UI.tsx +403 -0
- package/tools/MCPTool/classifyForCollapse.ts +604 -0
- package/tools/MCPTool/prompt.ts +3 -0
- package/tools/McpAuthTool/McpAuthTool.ts +215 -0
- package/tools/NotebookEditTool/NotebookEditTool.ts +490 -0
- package/tools/NotebookEditTool/UI.tsx +93 -0
- package/tools/NotebookEditTool/constants.ts +2 -0
- package/tools/NotebookEditTool/prompt.ts +3 -0
- package/tools/PowerShellTool/PowerShellTool.tsx +1001 -0
- package/tools/PowerShellTool/UI.tsx +131 -0
- package/tools/PowerShellTool/clmTypes.ts +211 -0
- package/tools/PowerShellTool/commandSemantics.ts +142 -0
- package/tools/PowerShellTool/commonParameters.ts +30 -0
- package/tools/PowerShellTool/destructiveCommandWarning.ts +109 -0
- package/tools/PowerShellTool/gitSafety.ts +176 -0
- package/tools/PowerShellTool/modeValidation.ts +404 -0
- package/tools/PowerShellTool/pathValidation.ts +2049 -0
- package/tools/PowerShellTool/powershellPermissions.ts +1648 -0
- package/tools/PowerShellTool/powershellSecurity.ts +1090 -0
- package/tools/PowerShellTool/prompt.ts +145 -0
- package/tools/PowerShellTool/readOnlyValidation.ts +1823 -0
- package/tools/PowerShellTool/toolName.ts +2 -0
- package/tools/REPLTool/constants.ts +46 -0
- package/tools/REPLTool/primitiveTools.ts +39 -0
- package/tools/ReadMcpResourceTool/ReadMcpResourceTool.ts +158 -0
- package/tools/ReadMcpResourceTool/UI.tsx +37 -0
- package/tools/ReadMcpResourceTool/prompt.ts +16 -0
- package/tools/RemoteTriggerTool/RemoteTriggerTool.ts +161 -0
- package/tools/RemoteTriggerTool/UI.tsx +17 -0
- package/tools/RemoteTriggerTool/prompt.ts +15 -0
- package/tools/ScheduleCronTool/CronCreateTool.ts +157 -0
- package/tools/ScheduleCronTool/CronDeleteTool.ts +95 -0
- package/tools/ScheduleCronTool/CronListTool.ts +97 -0
- package/tools/ScheduleCronTool/UI.tsx +60 -0
- package/tools/ScheduleCronTool/prompt.ts +135 -0
- package/tools/SendMessageTool/SendMessageTool.ts +917 -0
- package/tools/SendMessageTool/UI.tsx +31 -0
- package/tools/SendMessageTool/constants.ts +1 -0
- package/tools/SendMessageTool/prompt.ts +49 -0
- package/tools/SkillTool/SkillTool.ts +1108 -0
- package/tools/SkillTool/UI.tsx +128 -0
- package/tools/SkillTool/constants.ts +1 -0
- package/tools/SkillTool/prompt.ts +241 -0
- package/tools/SleepTool/prompt.ts +17 -0
- package/tools/SyntheticOutputTool/SyntheticOutputTool.ts +163 -0
- package/tools/TaskCreateTool/TaskCreateTool.ts +138 -0
- package/tools/TaskCreateTool/constants.ts +1 -0
- package/tools/TaskCreateTool/prompt.ts +56 -0
- package/tools/TaskGetTool/TaskGetTool.ts +128 -0
- package/tools/TaskGetTool/constants.ts +1 -0
- package/tools/TaskGetTool/prompt.ts +24 -0
- package/tools/TaskListTool/TaskListTool.ts +116 -0
- package/tools/TaskListTool/constants.ts +1 -0
- package/tools/TaskListTool/prompt.ts +49 -0
- package/tools/TaskOutputTool/TaskOutputTool.tsx +584 -0
- package/tools/TaskOutputTool/constants.ts +1 -0
- package/tools/TaskStopTool/TaskStopTool.ts +131 -0
- package/tools/TaskStopTool/UI.tsx +41 -0
- package/tools/TaskStopTool/prompt.ts +8 -0
- package/tools/TaskUpdateTool/TaskUpdateTool.ts +406 -0
- package/tools/TaskUpdateTool/constants.ts +1 -0
- package/tools/TaskUpdateTool/prompt.ts +77 -0
- package/tools/TeamCreateTool/TeamCreateTool.ts +240 -0
- package/tools/TeamCreateTool/UI.tsx +6 -0
- package/tools/TeamCreateTool/constants.ts +1 -0
- package/tools/TeamCreateTool/prompt.ts +113 -0
- package/tools/TeamDeleteTool/TeamDeleteTool.ts +139 -0
- package/tools/TeamDeleteTool/UI.tsx +20 -0
- package/tools/TeamDeleteTool/constants.ts +1 -0
- package/tools/TeamDeleteTool/prompt.ts +16 -0
- package/tools/TodoWriteTool/TodoWriteTool.ts +115 -0
- package/tools/TodoWriteTool/constants.ts +1 -0
- package/tools/TodoWriteTool/prompt.ts +184 -0
- package/tools/ToolSearchTool/ToolSearchTool.ts +471 -0
- package/tools/ToolSearchTool/constants.ts +1 -0
- package/tools/ToolSearchTool/prompt.ts +121 -0
- package/tools/TungstenTool/TungstenTool.ts +4 -0
- package/tools/WebFetchTool/UI.tsx +72 -0
- package/tools/WebFetchTool/WebFetchTool.ts +318 -0
- package/tools/WebFetchTool/preapproved.ts +166 -0
- package/tools/WebFetchTool/prompt.ts +46 -0
- package/tools/WebFetchTool/utils.ts +530 -0
- package/tools/WebSearchTool/UI.tsx +101 -0
- package/tools/WebSearchTool/WebSearchTool.ts +435 -0
- package/tools/WebSearchTool/prompt.ts +34 -0
- package/tools/WorkflowTool/constants.ts +2 -0
- package/tools/XMemIngestTool/XMemIngestTool.ts +140 -0
- package/tools/XMemIngestTool/prompt.ts +13 -0
- package/tools/XMemRetrieveTool/XMemRetrieveTool.ts +177 -0
- package/tools/XMemRetrieveTool/prompt.ts +16 -0
- package/tools/XMemSearchTool/XMemSearchTool.ts +172 -0
- package/tools/XMemSearchTool/prompt.ts +11 -0
- package/tools/shared/gitOperationTracking.ts +277 -0
- package/tools/shared/spawnMultiAgent.ts +1093 -0
- package/tools/testing/TestingPermissionTool.tsx +74 -0
- package/tools/utils.ts +40 -0
- package/utils/CircularBuffer.ts +84 -0
- package/utils/Cursor.ts +1530 -0
- package/utils/QueryGuard.ts +121 -0
- package/utils/Shell.ts +474 -0
- package/utils/ShellCommand.ts +465 -0
- package/utils/abortController.ts +99 -0
- package/utils/activityManager.ts +164 -0
- package/utils/advisor.ts +145 -0
- package/utils/agentContext.ts +178 -0
- package/utils/agentId.ts +99 -0
- package/utils/agentSwarmsEnabled.ts +44 -0
- package/utils/agenticSessionSearch.ts +307 -0
- package/utils/analyzeContext.ts +1382 -0
- package/utils/ansiToPng.ts +334 -0
- package/utils/ansiToSvg.ts +272 -0
- package/utils/api.ts +718 -0
- package/utils/apiPreconnect.ts +71 -0
- package/utils/appleTerminalBackup.ts +124 -0
- package/utils/argumentSubstitution.ts +145 -0
- package/utils/array.ts +13 -0
- package/utils/asciicast.ts +239 -0
- package/utils/attachments.ts +4091 -0
- package/utils/attribution.ts +393 -0
- package/utils/auth.ts +2002 -0
- package/utils/authFileDescriptor.ts +196 -0
- package/utils/authPortable.ts +19 -0
- package/utils/autoModeDenials.ts +26 -0
- package/utils/autoRunIssue.tsx +122 -0
- package/utils/autoUpdater.ts +561 -0
- package/utils/aws.ts +74 -0
- package/utils/awsAuthStatusManager.ts +81 -0
- package/utils/axios.ts +8 -0
- package/utils/background/remote/preconditions.ts +235 -0
- package/utils/background/remote/remoteSession.ts +98 -0
- package/utils/backgroundHousekeeping.ts +94 -0
- package/utils/bash/ParsedCommand.ts +318 -0
- package/utils/bash/ShellSnapshot.ts +582 -0
- package/utils/bash/ast.ts +2679 -0
- package/utils/bash/bashParser.ts +4436 -0
- package/utils/bash/bashPipeCommand.ts +294 -0
- package/utils/bash/commands.ts +1339 -0
- package/utils/bash/heredoc.ts +733 -0
- package/utils/bash/parser.ts +230 -0
- package/utils/bash/prefix.ts +204 -0
- package/utils/bash/registry.ts +53 -0
- package/utils/bash/shellCompletion.ts +259 -0
- package/utils/bash/shellPrefix.ts +28 -0
- package/utils/bash/shellQuote.ts +304 -0
- package/utils/bash/shellQuoting.ts +128 -0
- package/utils/bash/specs/alias.ts +14 -0
- package/utils/bash/specs/index.ts +18 -0
- package/utils/bash/specs/nohup.ts +13 -0
- package/utils/bash/specs/pyright.ts +91 -0
- package/utils/bash/specs/sleep.ts +13 -0
- package/utils/bash/specs/srun.ts +31 -0
- package/utils/bash/specs/time.ts +13 -0
- package/utils/bash/specs/timeout.ts +20 -0
- package/utils/bash/treeSitterAnalysis.ts +506 -0
- package/utils/betas.ts +434 -0
- package/utils/billing.ts +78 -0
- package/utils/binaryCheck.ts +53 -0
- package/utils/browser.ts +68 -0
- package/utils/bufferedWriter.ts +100 -0
- package/utils/bundledMode.ts +22 -0
- package/utils/caCerts.ts +115 -0
- package/utils/caCertsConfig.ts +88 -0
- package/utils/cachePaths.ts +38 -0
- package/utils/classifierApprovals.ts +88 -0
- package/utils/classifierApprovalsHook.ts +17 -0
- package/utils/claudeCodeHints.ts +193 -0
- package/utils/claudeDesktop.ts +152 -0
- package/utils/claudeInChrome/chromeNativeHost.ts +527 -0
- package/utils/claudeInChrome/common.ts +540 -0
- package/utils/claudeInChrome/mcpServer.ts +292 -0
- package/utils/claudeInChrome/prompt.ts +83 -0
- package/utils/claudeInChrome/setup.ts +400 -0
- package/utils/claudeInChrome/setupPortable.ts +233 -0
- package/utils/claudeInChrome/toolRendering.tsx +262 -0
- package/utils/claudemd.ts +1479 -0
- package/utils/cleanup.ts +602 -0
- package/utils/cleanupRegistry.ts +25 -0
- package/utils/cliArgs.ts +60 -0
- package/utils/cliHighlight.ts +54 -0
- package/utils/codeIndexing.ts +206 -0
- package/utils/collapseBackgroundBashNotifications.ts +84 -0
- package/utils/collapseHookSummaries.ts +59 -0
- package/utils/collapseReadSearch.ts +1109 -0
- package/utils/collapseTeammateShutdowns.ts +55 -0
- package/utils/color-diff-mock.ts +27 -0
- package/utils/combinedAbortSignal.ts +47 -0
- package/utils/commandLifecycle.ts +21 -0
- package/utils/commitAttribution.ts +961 -0
- package/utils/completionCache.ts +166 -0
- package/utils/computerUse/appNames.ts +196 -0
- package/utils/computerUse/cleanup.ts +86 -0
- package/utils/computerUse/common.ts +61 -0
- package/utils/computerUse/computerUseLock.ts +215 -0
- package/utils/computerUse/drainRunLoop.ts +79 -0
- package/utils/computerUse/escHotkey.ts +54 -0
- package/utils/computerUse/executor.ts +658 -0
- package/utils/computerUse/gates.ts +72 -0
- package/utils/computerUse/hostAdapter.ts +69 -0
- package/utils/computerUse/inputLoader.ts +30 -0
- package/utils/computerUse/mcpServer.ts +106 -0
- package/utils/computerUse/setup.ts +53 -0
- package/utils/computerUse/swiftLoader.ts +23 -0
- package/utils/computerUse/toolRendering.tsx +125 -0
- package/utils/computerUse/wrapper.tsx +336 -0
- package/utils/concurrentSessions.ts +204 -0
- package/utils/config.ts +1817 -0
- package/utils/configConstants.ts +21 -0
- package/utils/contentArray.ts +51 -0
- package/utils/context.ts +221 -0
- package/utils/contextAnalysis.ts +272 -0
- package/utils/contextSuggestions.ts +235 -0
- package/utils/controlMessageCompat.ts +32 -0
- package/utils/conversationRecovery.ts +597 -0
- package/utils/cron.ts +308 -0
- package/utils/cronJitterConfig.ts +75 -0
- package/utils/cronScheduler.ts +565 -0
- package/utils/cronTasks.ts +458 -0
- package/utils/cronTasksLock.ts +195 -0
- package/utils/crossProjectResume.ts +75 -0
- package/utils/crypto.ts +13 -0
- package/utils/cwd.ts +32 -0
- package/utils/debug.ts +268 -0
- package/utils/debugFilter.ts +157 -0
- package/utils/deepLink/banner.ts +123 -0
- package/utils/deepLink/parseDeepLink.ts +170 -0
- package/utils/deepLink/protocolHandler.ts +136 -0
- package/utils/deepLink/registerProtocol.ts +348 -0
- package/utils/deepLink/terminalLauncher.ts +557 -0
- package/utils/deepLink/terminalPreference.ts +54 -0
- package/utils/desktopDeepLink.ts +236 -0
- package/utils/detectRepository.ts +178 -0
- package/utils/diagLogs.ts +94 -0
- package/utils/diff.ts +177 -0
- package/utils/directMemberMessage.ts +69 -0
- package/utils/displayTags.ts +51 -0
- package/utils/doctorContextWarnings.ts +265 -0
- package/utils/doctorDiagnostic.ts +625 -0
- package/utils/dxt/helpers.ts +88 -0
- package/utils/dxt/zip.ts +226 -0
- package/utils/earlyInput.ts +191 -0
- package/utils/editor.ts +183 -0
- package/utils/effort.ts +329 -0
- package/utils/embeddedTools.ts +29 -0
- package/utils/env.ts +347 -0
- package/utils/envDynamic.ts +151 -0
- package/utils/envUtils.ts +183 -0
- package/utils/envValidation.ts +38 -0
- package/utils/errorLogSink.ts +235 -0
- package/utils/errors.ts +238 -0
- package/utils/exampleCommands.ts +184 -0
- package/utils/execFileNoThrow.ts +150 -0
- package/utils/execFileNoThrowPortable.ts +89 -0
- package/utils/execSyncWrapper.ts +38 -0
- package/utils/exportRenderer.tsx +98 -0
- package/utils/extraUsage.ts +23 -0
- package/utils/fastMode.ts +532 -0
- package/utils/file.ts +584 -0
- package/utils/fileHistory.ts +1115 -0
- package/utils/fileOperationAnalytics.ts +71 -0
- package/utils/filePersistence/filePersistence.ts +287 -0
- package/utils/filePersistence/outputsScanner.ts +126 -0
- package/utils/fileRead.ts +102 -0
- package/utils/fileReadCache.ts +96 -0
- package/utils/fileStateCache.ts +142 -0
- package/utils/findExecutable.ts +17 -0
- package/utils/fingerprint.ts +76 -0
- package/utils/forkedAgent.ts +689 -0
- package/utils/format.ts +308 -0
- package/utils/formatBriefTimestamp.ts +81 -0
- package/utils/fpsTracker.ts +47 -0
- package/utils/frontmatterParser.ts +370 -0
- package/utils/fsOperations.ts +770 -0
- package/utils/fullscreen.ts +202 -0
- package/utils/generatedFiles.ts +136 -0
- package/utils/generators.ts +88 -0
- package/utils/genericProcessUtils.ts +184 -0
- package/utils/getWorktreePaths.ts +70 -0
- package/utils/getWorktreePathsPortable.ts +27 -0
- package/utils/ghPrStatus.ts +106 -0
- package/utils/git/gitConfigParser.ts +277 -0
- package/utils/git/gitFilesystem.ts +699 -0
- package/utils/git/gitignore.ts +99 -0
- package/utils/git.ts +926 -0
- package/utils/gitDiff.ts +532 -0
- package/utils/gitSettings.ts +18 -0
- package/utils/github/ghAuthStatus.ts +29 -0
- package/utils/githubRepoPathMapping.ts +162 -0
- package/utils/glob.ts +130 -0
- package/utils/gracefulShutdown.ts +529 -0
- package/utils/groupToolUses.ts +182 -0
- package/utils/handlePromptSubmit.ts +610 -0
- package/utils/hash.ts +46 -0
- package/utils/headlessProfiler.ts +178 -0
- package/utils/heapDumpService.ts +303 -0
- package/utils/heatmap.ts +198 -0
- package/utils/highlightMatch.tsx +28 -0
- package/utils/hooks/AsyncHookRegistry.ts +309 -0
- package/utils/hooks/apiQueryHookHelper.ts +141 -0
- package/utils/hooks/execAgentHook.ts +339 -0
- package/utils/hooks/execHttpHook.ts +242 -0
- package/utils/hooks/execPromptHook.ts +211 -0
- package/utils/hooks/fileChangedWatcher.ts +191 -0
- package/utils/hooks/hookEvents.ts +192 -0
- package/utils/hooks/hookHelpers.ts +83 -0
- package/utils/hooks/hooksConfigManager.ts +400 -0
- package/utils/hooks/hooksConfigSnapshot.ts +133 -0
- package/utils/hooks/hooksSettings.ts +271 -0
- package/utils/hooks/postSamplingHooks.ts +70 -0
- package/utils/hooks/registerFrontmatterHooks.ts +67 -0
- package/utils/hooks/registerSkillHooks.ts +64 -0
- package/utils/hooks/sessionHooks.ts +447 -0
- package/utils/hooks/skillImprovement.ts +267 -0
- package/utils/hooks/ssrfGuard.ts +294 -0
- package/utils/hooks.ts +5022 -0
- package/utils/horizontalScroll.ts +137 -0
- package/utils/http.ts +136 -0
- package/utils/hyperlink.ts +39 -0
- package/utils/iTermBackup.ts +73 -0
- package/utils/ide.ts +1494 -0
- package/utils/idePathConversion.ts +90 -0
- package/utils/idleTimeout.ts +53 -0
- package/utils/imagePaste.ts +416 -0
- package/utils/imageResizer.ts +880 -0
- package/utils/imageStore.ts +167 -0
- package/utils/imageValidation.ts +104 -0
- package/utils/immediateCommand.ts +15 -0
- package/utils/inProcessTeammateHelpers.ts +102 -0
- package/utils/ink.ts +26 -0
- package/utils/intl.ts +94 -0
- package/utils/jetbrains.ts +191 -0
- package/utils/json.ts +277 -0
- package/utils/jsonRead.ts +16 -0
- package/utils/keyboardShortcuts.ts +14 -0
- package/utils/lazySchema.ts +8 -0
- package/utils/listSessionsImpl.ts +454 -0
- package/utils/localInstaller.ts +162 -0
- package/utils/lockfile.ts +43 -0
- package/utils/log.ts +362 -0
- package/utils/logoV2Utils.ts +347 -0
- package/utils/mailbox.ts +73 -0
- package/utils/managedEnv.ts +199 -0
- package/utils/managedEnvConstants.ts +191 -0
- package/utils/markdown.ts +381 -0
- package/utils/markdownConfigLoader.ts +600 -0
- package/utils/mcp/dateTimeParser.ts +121 -0
- package/utils/mcp/elicitationValidation.ts +336 -0
- package/utils/mcpInstructionsDelta.ts +130 -0
- package/utils/mcpOutputStorage.ts +189 -0
- package/utils/mcpValidation.ts +208 -0
- package/utils/mcpWebSocketTransport.ts +200 -0
- package/utils/memoize.ts +269 -0
- package/utils/memory/types.ts +12 -0
- package/utils/memory/versions.ts +8 -0
- package/utils/memoryFileDetection.ts +289 -0
- package/utils/messagePredicates.ts +8 -0
- package/utils/messageQueueManager.ts +547 -0
- package/utils/messages/mappers.ts +290 -0
- package/utils/messages/systemInit.ts +96 -0
- package/utils/messages.ts +5520 -0
- package/utils/model/agent.ts +157 -0
- package/utils/model/aliases.ts +35 -0
- package/utils/model/antModels.ts +64 -0
- package/utils/model/bedrock.ts +265 -0
- package/utils/model/check1mAccess.ts +72 -0
- package/utils/model/configs.ts +158 -0
- package/utils/model/contextWindowUpgradeCheck.ts +47 -0
- package/utils/model/deprecation.ts +101 -0
- package/utils/model/model.ts +654 -0
- package/utils/model/modelAllowlist.ts +170 -0
- package/utils/model/modelCapabilities.ts +118 -0
- package/utils/model/modelOptions.ts +589 -0
- package/utils/model/modelStrings.ts +170 -0
- package/utils/model/modelSupportOverrides.ts +50 -0
- package/utils/model/providers.ts +42 -0
- package/utils/model/validateModel.ts +159 -0
- package/utils/modelCost.ts +231 -0
- package/utils/modifiers.ts +36 -0
- package/utils/mtls.ts +179 -0
- package/utils/nativeInstaller/download.ts +523 -0
- package/utils/nativeInstaller/index.ts +18 -0
- package/utils/nativeInstaller/installer.ts +1708 -0
- package/utils/nativeInstaller/packageManagers.ts +336 -0
- package/utils/nativeInstaller/pidLock.ts +433 -0
- package/utils/notebook.ts +224 -0
- package/utils/objectGroupBy.ts +18 -0
- package/utils/pasteStore.ts +104 -0
- package/utils/path.ts +155 -0
- package/utils/pdf.ts +300 -0
- package/utils/pdfUtils.ts +70 -0
- package/utils/peerAddress.ts +21 -0
- package/utils/permissions/PermissionMode.ts +141 -0
- package/utils/permissions/PermissionPromptToolResultSchema.ts +127 -0
- package/utils/permissions/PermissionResult.ts +35 -0
- package/utils/permissions/PermissionRule.ts +40 -0
- package/utils/permissions/PermissionUpdate.ts +389 -0
- package/utils/permissions/PermissionUpdateSchema.ts +78 -0
- package/utils/permissions/autoModeState.ts +39 -0
- package/utils/permissions/bashClassifier.ts +61 -0
- package/utils/permissions/bypassPermissionsKillswitch.ts +155 -0
- package/utils/permissions/classifierDecision.ts +98 -0
- package/utils/permissions/classifierShared.ts +39 -0
- package/utils/permissions/dangerousPatterns.ts +80 -0
- package/utils/permissions/denialTracking.ts +45 -0
- package/utils/permissions/filesystem.ts +1777 -0
- package/utils/permissions/getNextPermissionMode.ts +101 -0
- package/utils/permissions/pathValidation.ts +485 -0
- package/utils/permissions/permissionExplainer.ts +250 -0
- package/utils/permissions/permissionRuleParser.ts +198 -0
- package/utils/permissions/permissionSetup.ts +1532 -0
- package/utils/permissions/permissions.ts +1486 -0
- package/utils/permissions/permissionsLoader.ts +296 -0
- package/utils/permissions/shadowedRuleDetection.ts +234 -0
- package/utils/permissions/shellRuleMatching.ts +228 -0
- package/utils/permissions/yoloClassifier.ts +1495 -0
- package/utils/planModeV2.ts +95 -0
- package/utils/plans.ts +397 -0
- package/utils/platform.ts +150 -0
- package/utils/plugins/addDirPluginSettings.ts +71 -0
- package/utils/plugins/cacheUtils.ts +196 -0
- package/utils/plugins/dependencyResolver.ts +305 -0
- package/utils/plugins/fetchTelemetry.ts +135 -0
- package/utils/plugins/gitAvailability.ts +69 -0
- package/utils/plugins/headlessPluginInstall.ts +174 -0
- package/utils/plugins/hintRecommendation.ts +164 -0
- package/utils/plugins/installCounts.ts +292 -0
- package/utils/plugins/installedPluginsManager.ts +1268 -0
- package/utils/plugins/loadPluginAgents.ts +348 -0
- package/utils/plugins/loadPluginCommands.ts +946 -0
- package/utils/plugins/loadPluginHooks.ts +287 -0
- package/utils/plugins/loadPluginOutputStyles.ts +178 -0
- package/utils/plugins/lspPluginIntegration.ts +387 -0
- package/utils/plugins/lspRecommendation.ts +374 -0
- package/utils/plugins/managedPlugins.ts +27 -0
- package/utils/plugins/marketplaceHelpers.ts +592 -0
- package/utils/plugins/marketplaceManager.ts +2643 -0
- package/utils/plugins/mcpPluginIntegration.ts +634 -0
- package/utils/plugins/mcpbHandler.ts +968 -0
- package/utils/plugins/officialMarketplace.ts +25 -0
- package/utils/plugins/officialMarketplaceGcs.ts +216 -0
- package/utils/plugins/officialMarketplaceStartupCheck.ts +439 -0
- package/utils/plugins/orphanedPluginFilter.ts +114 -0
- package/utils/plugins/parseMarketplaceInput.ts +162 -0
- package/utils/plugins/performStartupChecks.tsx +70 -0
- package/utils/plugins/pluginAutoupdate.ts +284 -0
- package/utils/plugins/pluginBlocklist.ts +127 -0
- package/utils/plugins/pluginDirectories.ts +178 -0
- package/utils/plugins/pluginFlagging.ts +208 -0
- package/utils/plugins/pluginIdentifier.ts +123 -0
- package/utils/plugins/pluginInstallationHelpers.ts +595 -0
- package/utils/plugins/pluginLoader.ts +3302 -0
- package/utils/plugins/pluginOptionsStorage.ts +400 -0
- package/utils/plugins/pluginPolicy.ts +20 -0
- package/utils/plugins/pluginStartupCheck.ts +341 -0
- package/utils/plugins/pluginVersioning.ts +157 -0
- package/utils/plugins/reconciler.ts +265 -0
- package/utils/plugins/refresh.ts +215 -0
- package/utils/plugins/schemas.ts +1681 -0
- package/utils/plugins/validatePlugin.ts +903 -0
- package/utils/plugins/walkPluginMarkdown.ts +69 -0
- package/utils/plugins/zipCache.ts +406 -0
- package/utils/plugins/zipCacheAdapters.ts +164 -0
- package/utils/powershell/dangerousCmdlets.ts +185 -0
- package/utils/powershell/parser.ts +1804 -0
- package/utils/powershell/staticPrefix.ts +316 -0
- package/utils/preflightChecks.tsx +151 -0
- package/utils/privacyLevel.ts +55 -0
- package/utils/process.ts +68 -0
- package/utils/processUserInput/processBashCommand.tsx +140 -0
- package/utils/processUserInput/processSlashCommand.tsx +922 -0
- package/utils/processUserInput/processTextPrompt.ts +100 -0
- package/utils/processUserInput/processUserInput.ts +605 -0
- package/utils/profilerBase.ts +46 -0
- package/utils/promptCategory.ts +49 -0
- package/utils/promptEditor.ts +188 -0
- package/utils/promptShellExecution.ts +183 -0
- package/utils/proxy.ts +426 -0
- package/utils/queryContext.ts +179 -0
- package/utils/queryHelpers.ts +552 -0
- package/utils/queryProfiler.ts +301 -0
- package/utils/queueProcessor.ts +95 -0
- package/utils/readEditContext.ts +227 -0
- package/utils/readFileInRange.ts +383 -0
- package/utils/releaseNotes.ts +360 -0
- package/utils/renderOptions.ts +113 -0
- package/utils/ripgrep.ts +679 -0
- package/utils/sandbox/sandbox-adapter.ts +985 -0
- package/utils/sandbox/sandbox-ui-utils.ts +12 -0
- package/utils/sanitization.ts +91 -0
- package/utils/screenshotClipboard.ts +121 -0
- package/utils/sdkEventQueue.ts +134 -0
- package/utils/secureStorage/fallbackStorage.ts +70 -0
- package/utils/secureStorage/index.ts +17 -0
- package/utils/secureStorage/keychainPrefetch.ts +116 -0
- package/utils/secureStorage/macOsKeychainHelpers.ts +111 -0
- package/utils/secureStorage/macOsKeychainStorage.ts +231 -0
- package/utils/secureStorage/plainTextStorage.ts +84 -0
- package/utils/semanticBoolean.ts +29 -0
- package/utils/semanticNumber.ts +36 -0
- package/utils/semver.ts +59 -0
- package/utils/sequential.ts +56 -0
- package/utils/sessionActivity.ts +133 -0
- package/utils/sessionEnvVars.ts +22 -0
- package/utils/sessionEnvironment.ts +166 -0
- package/utils/sessionFileAccessHooks.ts +250 -0
- package/utils/sessionIngressAuth.ts +140 -0
- package/utils/sessionRestore.ts +551 -0
- package/utils/sessionStart.ts +232 -0
- package/utils/sessionState.ts +150 -0
- package/utils/sessionStorage.ts +5105 -0
- package/utils/sessionStoragePortable.ts +793 -0
- package/utils/sessionTitle.ts +129 -0
- package/utils/sessionUrl.ts +64 -0
- package/utils/set.ts +53 -0
- package/utils/settings/allErrors.ts +32 -0
- package/utils/settings/applySettingsChange.ts +92 -0
- package/utils/settings/changeDetector.ts +488 -0
- package/utils/settings/constants.ts +202 -0
- package/utils/settings/internalWrites.ts +37 -0
- package/utils/settings/managedPath.ts +34 -0
- package/utils/settings/mdm/constants.ts +81 -0
- package/utils/settings/mdm/rawRead.ts +130 -0
- package/utils/settings/mdm/settings.ts +316 -0
- package/utils/settings/permissionValidation.ts +262 -0
- package/utils/settings/pluginOnlyPolicy.ts +60 -0
- package/utils/settings/schemaOutput.ts +8 -0
- package/utils/settings/settings.ts +1015 -0
- package/utils/settings/settingsCache.ts +80 -0
- package/utils/settings/toolValidationConfig.ts +103 -0
- package/utils/settings/types.ts +1149 -0
- package/utils/settings/validateEditTool.ts +45 -0
- package/utils/settings/validation.ts +265 -0
- package/utils/settings/validationTips.ts +164 -0
- package/utils/shell/bashProvider.ts +255 -0
- package/utils/shell/outputLimits.ts +14 -0
- package/utils/shell/powershellDetection.ts +107 -0
- package/utils/shell/powershellProvider.ts +123 -0
- package/utils/shell/prefix.ts +367 -0
- package/utils/shell/readOnlyCommandValidation.ts +1893 -0
- package/utils/shell/resolveDefaultShell.ts +14 -0
- package/utils/shell/shellProvider.ts +33 -0
- package/utils/shell/shellToolUtils.ts +22 -0
- package/utils/shell/specPrefix.ts +241 -0
- package/utils/shellConfig.ts +167 -0
- package/utils/sideQuery.ts +222 -0
- package/utils/sideQuestion.ts +155 -0
- package/utils/signal.ts +43 -0
- package/utils/sinks.ts +16 -0
- package/utils/skills/skillChangeDetector.ts +311 -0
- package/utils/slashCommandParsing.ts +60 -0
- package/utils/sleep.ts +84 -0
- package/utils/sliceAnsi.ts +91 -0
- package/utils/slowOperations.ts +286 -0
- package/utils/standaloneAgent.ts +23 -0
- package/utils/startupProfiler.ts +194 -0
- package/utils/staticRender.tsx +116 -0
- package/utils/stats.ts +1061 -0
- package/utils/statsCache.ts +434 -0
- package/utils/status.tsx +362 -0
- package/utils/statusNoticeDefinitions.tsx +198 -0
- package/utils/statusNoticeHelpers.ts +20 -0
- package/utils/stream.ts +76 -0
- package/utils/streamJsonStdoutGuard.ts +123 -0
- package/utils/streamlinedTransform.ts +201 -0
- package/utils/stringUtils.ts +235 -0
- package/utils/subprocessEnv.ts +99 -0
- package/utils/suggestions/commandSuggestions.ts +567 -0
- package/utils/suggestions/directoryCompletion.ts +263 -0
- package/utils/suggestions/shellHistoryCompletion.ts +119 -0
- package/utils/suggestions/skillUsageTracking.ts +55 -0
- package/utils/suggestions/slackChannelSuggestions.ts +209 -0
- package/utils/swarm/It2SetupPrompt.tsx +380 -0
- package/utils/swarm/backends/ITermBackend.ts +370 -0
- package/utils/swarm/backends/InProcessBackend.ts +339 -0
- package/utils/swarm/backends/PaneBackendExecutor.ts +354 -0
- package/utils/swarm/backends/TmuxBackend.ts +764 -0
- package/utils/swarm/backends/detection.ts +128 -0
- package/utils/swarm/backends/it2Setup.ts +245 -0
- package/utils/swarm/backends/registry.ts +464 -0
- package/utils/swarm/backends/teammateModeSnapshot.ts +87 -0
- package/utils/swarm/backends/types.ts +311 -0
- package/utils/swarm/constants.ts +33 -0
- package/utils/swarm/inProcessRunner.ts +1552 -0
- package/utils/swarm/leaderPermissionBridge.ts +54 -0
- package/utils/swarm/permissionSync.ts +928 -0
- package/utils/swarm/reconnection.ts +119 -0
- package/utils/swarm/spawnInProcess.ts +328 -0
- package/utils/swarm/spawnUtils.ts +146 -0
- package/utils/swarm/teamHelpers.ts +683 -0
- package/utils/swarm/teammateInit.ts +129 -0
- package/utils/swarm/teammateLayoutManager.ts +107 -0
- package/utils/swarm/teammateModel.ts +10 -0
- package/utils/swarm/teammatePromptAddendum.ts +18 -0
- package/utils/systemDirectories.ts +74 -0
- package/utils/systemPrompt.ts +123 -0
- package/utils/systemPromptType.ts +14 -0
- package/utils/systemTheme.ts +119 -0
- package/utils/taggedId.ts +54 -0
- package/utils/task/TaskOutput.ts +390 -0
- package/utils/task/diskOutput.ts +451 -0
- package/utils/task/framework.ts +308 -0
- package/utils/task/outputFormatting.ts +38 -0
- package/utils/task/sdkProgress.ts +36 -0
- package/utils/tasks.ts +862 -0
- package/utils/teamDiscovery.ts +81 -0
- package/utils/teamMemoryOps.ts +88 -0
- package/utils/teammate.ts +292 -0
- package/utils/teammateContext.ts +96 -0
- package/utils/teammateMailbox.ts +1183 -0
- package/utils/telemetry/betaSessionTracing.ts +491 -0
- package/utils/telemetry/bigqueryExporter.ts +252 -0
- package/utils/telemetry/events.ts +75 -0
- package/utils/telemetry/instrumentation.ts +825 -0
- package/utils/telemetry/logger.ts +26 -0
- package/utils/telemetry/perfettoTracing.ts +1120 -0
- package/utils/telemetry/pluginTelemetry.ts +289 -0
- package/utils/telemetry/sessionTracing.ts +927 -0
- package/utils/telemetry/skillLoadedEvent.ts +39 -0
- package/utils/telemetryAttributes.ts +71 -0
- package/utils/teleport/api.ts +466 -0
- package/utils/teleport/environmentSelection.ts +77 -0
- package/utils/teleport/environments.ts +120 -0
- package/utils/teleport/gitBundle.ts +292 -0
- package/utils/teleport.tsx +1226 -0
- package/utils/tempfile.ts +31 -0
- package/utils/terminal.ts +131 -0
- package/utils/terminalPanel.ts +191 -0
- package/utils/textHighlighting.ts +166 -0
- package/utils/theme.ts +639 -0
- package/utils/thinking.ts +162 -0
- package/utils/timeouts.ts +39 -0
- package/utils/tmuxSocket.ts +427 -0
- package/utils/todo/types.ts +18 -0
- package/utils/tokenBudget.ts +73 -0
- package/utils/tokens.ts +261 -0
- package/utils/toolErrors.ts +132 -0
- package/utils/toolPool.ts +79 -0
- package/utils/toolResultStorage.ts +1040 -0
- package/utils/toolSchemaCache.ts +26 -0
- package/utils/toolSearch.ts +756 -0
- package/utils/transcriptSearch.ts +202 -0
- package/utils/treeify.ts +170 -0
- package/utils/truncate.ts +179 -0
- package/utils/ultraplan/ccrSession.ts +349 -0
- package/utils/ultraplan/keyword.ts +127 -0
- package/utils/ultraplan/prompt.txt +1 -0
- package/utils/unaryLogging.ts +39 -0
- package/utils/undercover.ts +89 -0
- package/utils/user.ts +194 -0
- package/utils/userAgent.ts +10 -0
- package/utils/userPromptKeywords.ts +27 -0
- package/utils/uuid.ts +27 -0
- package/utils/warningHandler.ts +121 -0
- package/utils/which.ts +82 -0
- package/utils/windowsPaths.ts +173 -0
- package/utils/withResolvers.ts +13 -0
- package/utils/words.ts +800 -0
- package/utils/workloadContext.ts +57 -0
- package/utils/worktree.ts +1519 -0
- package/utils/worktreeModeEnabled.ts +11 -0
- package/utils/xdg.ts +65 -0
- package/utils/xmem.ts +6 -0
- package/utils/xml.ts +16 -0
- package/utils/yaml.ts +15 -0
- package/utils/zodToJsonSchema.ts +23 -0
|
@@ -0,0 +1,511 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cross-App Access (XAA) / Enterprise Managed Authorization (SEP-990)
|
|
3
|
+
*
|
|
4
|
+
* Obtains an MCP access token WITHOUT a browser consent screen by chaining:
|
|
5
|
+
* 1. RFC 8693 Token Exchange at the IdP: id_token → ID-JAG
|
|
6
|
+
* 2. RFC 7523 JWT Bearer Grant at the AS: ID-JAG → access_token
|
|
7
|
+
*
|
|
8
|
+
* Spec refs:
|
|
9
|
+
* - ID-JAG (IETF draft): https://datatracker.ietf.org/doc/draft-ietf-oauth-identity-assertion-authz-grant/
|
|
10
|
+
* - MCP ext-auth (SEP-990): https://github.com/modelcontextprotocol/ext-auth
|
|
11
|
+
* - RFC 8693 (Token Exchange), RFC 7523 (JWT Bearer), RFC 9728 (PRM)
|
|
12
|
+
*
|
|
13
|
+
* Reference impl: ~/code/mcp/conformance/examples/clients/typescript/everything-client.ts:375-522
|
|
14
|
+
*
|
|
15
|
+
* Structure: four Layer-2 ops (aligned with TS SDK PR #1593's Layer-2 shapes so
|
|
16
|
+
* a future SDK swap is mechanical) + one Layer-3 orchestrator that composes them.
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
import {
|
|
20
|
+
discoverAuthorizationServerMetadata,
|
|
21
|
+
discoverOAuthProtectedResourceMetadata,
|
|
22
|
+
} from '@modelcontextprotocol/sdk/client/auth.js'
|
|
23
|
+
import type { FetchLike } from '@modelcontextprotocol/sdk/shared/transport.js'
|
|
24
|
+
import { z } from 'zod/v4'
|
|
25
|
+
import { lazySchema } from '../../utils/lazySchema.js'
|
|
26
|
+
import { logMCPDebug } from '../../utils/log.js'
|
|
27
|
+
import { jsonStringify } from '../../utils/slowOperations.js'
|
|
28
|
+
|
|
29
|
+
const XAA_REQUEST_TIMEOUT_MS = 30000
|
|
30
|
+
|
|
31
|
+
const TOKEN_EXCHANGE_GRANT = 'urn:ietf:params:oauth:grant-type:token-exchange'
|
|
32
|
+
const JWT_BEARER_GRANT = 'urn:ietf:params:oauth:grant-type:jwt-bearer'
|
|
33
|
+
const ID_JAG_TOKEN_TYPE = 'urn:ietf:params:oauth:token-type:id-jag'
|
|
34
|
+
const ID_TOKEN_TYPE = 'urn:ietf:params:oauth:token-type:id_token'
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Creates a fetch wrapper that enforces the XAA request timeout and optionally
|
|
38
|
+
* composes a caller-provided abort signal. Using AbortSignal.any ensures the
|
|
39
|
+
* user's cancel (e.g. Esc in the auth menu) actually aborts in-flight requests
|
|
40
|
+
* rather than being clobbered by the timeout signal.
|
|
41
|
+
*/
|
|
42
|
+
function makeXaaFetch(abortSignal?: AbortSignal): FetchLike {
|
|
43
|
+
return (url, init) => {
|
|
44
|
+
const timeout = AbortSignal.timeout(XAA_REQUEST_TIMEOUT_MS)
|
|
45
|
+
const signal = abortSignal
|
|
46
|
+
? // eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
|
|
47
|
+
AbortSignal.any([timeout, abortSignal])
|
|
48
|
+
: timeout
|
|
49
|
+
// eslint-disable-next-line eslint-plugin-n/no-unsupported-features/node-builtins
|
|
50
|
+
return fetch(url, { ...init, signal })
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const defaultFetch = makeXaaFetch()
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* RFC 8414 §3.3 / RFC 9728 §3.3 identifier comparison. Roundtrip through URL
|
|
58
|
+
* to apply RFC 3986 §6.2.2 syntax-based normalization (lowercases scheme+host,
|
|
59
|
+
* drops default port), then strip trailing slash.
|
|
60
|
+
*/
|
|
61
|
+
function normalizeUrl(url: string): string {
|
|
62
|
+
try {
|
|
63
|
+
return new URL(url).href.replace(/\/$/, '')
|
|
64
|
+
} catch {
|
|
65
|
+
return url.replace(/\/$/, '')
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Thrown by requestJwtAuthorizationGrant when the IdP token-exchange leg
|
|
71
|
+
* fails. Carries `shouldClearIdToken` so callers can decide whether to drop
|
|
72
|
+
* the cached id_token based on OAuth error semantics (not substring matching):
|
|
73
|
+
* - 4xx / invalid_grant / invalid_token → id_token is bad, clear it
|
|
74
|
+
* - 5xx → IdP is down, id_token may still be valid, keep it
|
|
75
|
+
* - 200 with structurally-invalid body → protocol violation, clear it
|
|
76
|
+
*/
|
|
77
|
+
export class XaaTokenExchangeError extends Error {
|
|
78
|
+
readonly shouldClearIdToken: boolean
|
|
79
|
+
constructor(message: string, shouldClearIdToken: boolean) {
|
|
80
|
+
super(message)
|
|
81
|
+
this.name = 'XaaTokenExchangeError'
|
|
82
|
+
this.shouldClearIdToken = shouldClearIdToken
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// Matches quoted values for known token-bearing keys regardless of nesting
|
|
87
|
+
// depth. Works on both parsed-then-stringified bodies AND raw text() error
|
|
88
|
+
// bodies from !res.ok paths — a misbehaving AS that echoes the request's
|
|
89
|
+
// subject_token/assertion/client_secret in a 4xx error envelope must not leak
|
|
90
|
+
// into debug logs.
|
|
91
|
+
const SENSITIVE_TOKEN_RE =
|
|
92
|
+
/"(access_token|refresh_token|id_token|assertion|subject_token|client_secret)"\s*:\s*"[^"]*"/g
|
|
93
|
+
|
|
94
|
+
function redactTokens(raw: unknown): string {
|
|
95
|
+
const s = typeof raw === 'string' ? raw : jsonStringify(raw)
|
|
96
|
+
return s.replace(SENSITIVE_TOKEN_RE, (_, k) => `"${k}":"[REDACTED]"`)
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
// ─── Zod Schemas ────────────────────────────────────────────────────────────
|
|
100
|
+
|
|
101
|
+
const TokenExchangeResponseSchema = lazySchema(() =>
|
|
102
|
+
z.object({
|
|
103
|
+
access_token: z.string().optional(),
|
|
104
|
+
issued_token_type: z.string().optional(),
|
|
105
|
+
// z.coerce tolerates IdPs that send expires_in as a string (common in
|
|
106
|
+
// PHP-backed IdPs) — technically non-conformant JSON but widespread.
|
|
107
|
+
expires_in: z.coerce.number().optional(),
|
|
108
|
+
scope: z.string().optional(),
|
|
109
|
+
}),
|
|
110
|
+
)
|
|
111
|
+
|
|
112
|
+
const JwtBearerResponseSchema = lazySchema(() =>
|
|
113
|
+
z.object({
|
|
114
|
+
access_token: z.string().min(1),
|
|
115
|
+
// Many ASes omit token_type since Bearer is the only value anyone uses
|
|
116
|
+
// (RFC 6750). Don't reject a valid access_token over a missing label.
|
|
117
|
+
token_type: z.string().default('Bearer'),
|
|
118
|
+
expires_in: z.coerce.number().optional(),
|
|
119
|
+
scope: z.string().optional(),
|
|
120
|
+
refresh_token: z.string().optional(),
|
|
121
|
+
}),
|
|
122
|
+
)
|
|
123
|
+
|
|
124
|
+
// ─── Layer 2: Discovery ─────────────────────────────────────────────────────
|
|
125
|
+
|
|
126
|
+
export type ProtectedResourceMetadata = {
|
|
127
|
+
resource: string
|
|
128
|
+
authorization_servers: string[]
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
/**
|
|
132
|
+
* RFC 9728 PRM discovery via SDK, plus RFC 9728 §3.3 resource-mismatch
|
|
133
|
+
* validation (mix-up protection — TODO: upstream to SDK).
|
|
134
|
+
*/
|
|
135
|
+
export async function discoverProtectedResource(
|
|
136
|
+
serverUrl: string,
|
|
137
|
+
opts?: { fetchFn?: FetchLike },
|
|
138
|
+
): Promise<ProtectedResourceMetadata> {
|
|
139
|
+
let prm
|
|
140
|
+
try {
|
|
141
|
+
prm = await discoverOAuthProtectedResourceMetadata(
|
|
142
|
+
serverUrl,
|
|
143
|
+
undefined,
|
|
144
|
+
opts?.fetchFn ?? defaultFetch,
|
|
145
|
+
)
|
|
146
|
+
} catch (e) {
|
|
147
|
+
throw new Error(
|
|
148
|
+
`XAA: PRM discovery failed: ${e instanceof Error ? e.message : String(e)}`,
|
|
149
|
+
)
|
|
150
|
+
}
|
|
151
|
+
if (!prm.resource || !prm.authorization_servers?.[0]) {
|
|
152
|
+
throw new Error(
|
|
153
|
+
'XAA: PRM discovery failed: PRM missing resource or authorization_servers',
|
|
154
|
+
)
|
|
155
|
+
}
|
|
156
|
+
if (normalizeUrl(prm.resource) !== normalizeUrl(serverUrl)) {
|
|
157
|
+
throw new Error(
|
|
158
|
+
`XAA: PRM discovery failed: PRM resource mismatch: expected ${serverUrl}, got ${prm.resource}`,
|
|
159
|
+
)
|
|
160
|
+
}
|
|
161
|
+
return {
|
|
162
|
+
resource: prm.resource,
|
|
163
|
+
authorization_servers: prm.authorization_servers,
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
export type AuthorizationServerMetadata = {
|
|
168
|
+
issuer: string
|
|
169
|
+
token_endpoint: string
|
|
170
|
+
grant_types_supported?: string[]
|
|
171
|
+
token_endpoint_auth_methods_supported?: string[]
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
/**
|
|
175
|
+
* AS metadata discovery via SDK (RFC 8414 + OIDC fallback), plus RFC 8414
|
|
176
|
+
* §3.3 issuer-mismatch validation (mix-up protection — TODO: upstream to SDK).
|
|
177
|
+
*/
|
|
178
|
+
export async function discoverAuthorizationServer(
|
|
179
|
+
asUrl: string,
|
|
180
|
+
opts?: { fetchFn?: FetchLike },
|
|
181
|
+
): Promise<AuthorizationServerMetadata> {
|
|
182
|
+
const meta = await discoverAuthorizationServerMetadata(asUrl, {
|
|
183
|
+
fetchFn: opts?.fetchFn ?? defaultFetch,
|
|
184
|
+
})
|
|
185
|
+
if (!meta?.issuer || !meta.token_endpoint) {
|
|
186
|
+
throw new Error(
|
|
187
|
+
`XAA: AS metadata discovery failed: no valid metadata at ${asUrl}`,
|
|
188
|
+
)
|
|
189
|
+
}
|
|
190
|
+
if (normalizeUrl(meta.issuer) !== normalizeUrl(asUrl)) {
|
|
191
|
+
throw new Error(
|
|
192
|
+
`XAA: AS metadata discovery failed: issuer mismatch: expected ${asUrl}, got ${meta.issuer}`,
|
|
193
|
+
)
|
|
194
|
+
}
|
|
195
|
+
// RFC 8414 §3.3 / RFC 9728 §3 require HTTPS. A PRM-advertised http:// AS
|
|
196
|
+
// that self-consistently reports an http:// issuer would pass the mismatch
|
|
197
|
+
// check above, then we'd POST id_token + client_secret over plaintext.
|
|
198
|
+
if (new URL(meta.token_endpoint).protocol !== 'https:') {
|
|
199
|
+
throw new Error(
|
|
200
|
+
`XAA: refusing non-HTTPS token endpoint: ${meta.token_endpoint}`,
|
|
201
|
+
)
|
|
202
|
+
}
|
|
203
|
+
return {
|
|
204
|
+
issuer: meta.issuer,
|
|
205
|
+
token_endpoint: meta.token_endpoint,
|
|
206
|
+
grant_types_supported: meta.grant_types_supported,
|
|
207
|
+
token_endpoint_auth_methods_supported:
|
|
208
|
+
meta.token_endpoint_auth_methods_supported,
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
// ─── Layer 2: Exchange ──────────────────────────────────────────────────────
|
|
213
|
+
|
|
214
|
+
export type JwtAuthGrantResult = {
|
|
215
|
+
/** The ID-JAG (Identity Assertion Authorization Grant) */
|
|
216
|
+
jwtAuthGrant: string
|
|
217
|
+
expiresIn?: number
|
|
218
|
+
scope?: string
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
/**
|
|
222
|
+
* RFC 8693 Token Exchange at the IdP: id_token → ID-JAG.
|
|
223
|
+
* Validates `issued_token_type` is `urn:ietf:params:oauth:token-type:id-jag`.
|
|
224
|
+
*
|
|
225
|
+
* `clientSecret` is optional — sent via `client_secret_post` if present.
|
|
226
|
+
* Some IdPs register the client as confidential even when they advertise
|
|
227
|
+
* `token_endpoint_auth_method: "none"`.
|
|
228
|
+
*
|
|
229
|
+
* TODO(xaa-ga): consult `token_endpoint_auth_methods_supported` from IdP
|
|
230
|
+
* OIDC metadata and support `client_secret_basic`, mirroring the AS-side
|
|
231
|
+
* selection in `performCrossAppAccess`. All major IdPs accept POST today.
|
|
232
|
+
*/
|
|
233
|
+
export async function requestJwtAuthorizationGrant(opts: {
|
|
234
|
+
tokenEndpoint: string
|
|
235
|
+
audience: string
|
|
236
|
+
resource: string
|
|
237
|
+
idToken: string
|
|
238
|
+
clientId: string
|
|
239
|
+
clientSecret?: string
|
|
240
|
+
scope?: string
|
|
241
|
+
fetchFn?: FetchLike
|
|
242
|
+
}): Promise<JwtAuthGrantResult> {
|
|
243
|
+
const fetchFn = opts.fetchFn ?? defaultFetch
|
|
244
|
+
const params = new URLSearchParams({
|
|
245
|
+
grant_type: TOKEN_EXCHANGE_GRANT,
|
|
246
|
+
requested_token_type: ID_JAG_TOKEN_TYPE,
|
|
247
|
+
audience: opts.audience,
|
|
248
|
+
resource: opts.resource,
|
|
249
|
+
subject_token: opts.idToken,
|
|
250
|
+
subject_token_type: ID_TOKEN_TYPE,
|
|
251
|
+
client_id: opts.clientId,
|
|
252
|
+
})
|
|
253
|
+
if (opts.clientSecret) {
|
|
254
|
+
params.set('client_secret', opts.clientSecret)
|
|
255
|
+
}
|
|
256
|
+
if (opts.scope) {
|
|
257
|
+
params.set('scope', opts.scope)
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
const res = await fetchFn(opts.tokenEndpoint, {
|
|
261
|
+
method: 'POST',
|
|
262
|
+
headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
|
|
263
|
+
body: params,
|
|
264
|
+
})
|
|
265
|
+
if (!res.ok) {
|
|
266
|
+
const body = redactTokens(await res.text()).slice(0, 200)
|
|
267
|
+
// 4xx → id_token rejected (invalid_grant etc.), clear cache.
|
|
268
|
+
// 5xx → IdP outage, id_token may still be valid, preserve it.
|
|
269
|
+
const shouldClear = res.status < 500
|
|
270
|
+
throw new XaaTokenExchangeError(
|
|
271
|
+
`XAA: token exchange failed: HTTP ${res.status}: ${body}`,
|
|
272
|
+
shouldClear,
|
|
273
|
+
)
|
|
274
|
+
}
|
|
275
|
+
let rawExchange: unknown
|
|
276
|
+
try {
|
|
277
|
+
rawExchange = await res.json()
|
|
278
|
+
} catch {
|
|
279
|
+
// Transient network condition (captive portal, proxy) — don't clear id_token.
|
|
280
|
+
throw new XaaTokenExchangeError(
|
|
281
|
+
`XAA: token exchange returned non-JSON (captive portal?) at ${opts.tokenEndpoint}`,
|
|
282
|
+
false,
|
|
283
|
+
)
|
|
284
|
+
}
|
|
285
|
+
const exchangeParsed = TokenExchangeResponseSchema().safeParse(rawExchange)
|
|
286
|
+
if (!exchangeParsed.success) {
|
|
287
|
+
throw new XaaTokenExchangeError(
|
|
288
|
+
`XAA: token exchange response did not match expected shape: ${redactTokens(rawExchange)}`,
|
|
289
|
+
true,
|
|
290
|
+
)
|
|
291
|
+
}
|
|
292
|
+
const result = exchangeParsed.data
|
|
293
|
+
if (!result.access_token) {
|
|
294
|
+
throw new XaaTokenExchangeError(
|
|
295
|
+
`XAA: token exchange response missing access_token: ${redactTokens(result)}`,
|
|
296
|
+
true,
|
|
297
|
+
)
|
|
298
|
+
}
|
|
299
|
+
if (result.issued_token_type !== ID_JAG_TOKEN_TYPE) {
|
|
300
|
+
throw new XaaTokenExchangeError(
|
|
301
|
+
`XAA: token exchange returned unexpected issued_token_type: ${result.issued_token_type}`,
|
|
302
|
+
true,
|
|
303
|
+
)
|
|
304
|
+
}
|
|
305
|
+
return {
|
|
306
|
+
jwtAuthGrant: result.access_token,
|
|
307
|
+
expiresIn: result.expires_in,
|
|
308
|
+
scope: result.scope,
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
export type XaaTokenResult = {
|
|
313
|
+
access_token: string
|
|
314
|
+
token_type: string
|
|
315
|
+
expires_in?: number
|
|
316
|
+
scope?: string
|
|
317
|
+
refresh_token?: string
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
export type XaaResult = XaaTokenResult & {
|
|
321
|
+
/**
|
|
322
|
+
* The AS issuer URL discovered via PRM. Callers must persist this as
|
|
323
|
+
* `discoveryState.authorizationServerUrl` so that refresh (auth.ts _doRefresh)
|
|
324
|
+
* and revocation (revokeServerTokens) can locate the token/revocation
|
|
325
|
+
* endpoints — the MCP URL is not the AS URL in typical XAA setups.
|
|
326
|
+
*/
|
|
327
|
+
authorizationServerUrl: string
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
/**
|
|
331
|
+
* RFC 7523 JWT Bearer Grant at the AS: ID-JAG → access_token.
|
|
332
|
+
*
|
|
333
|
+
* `authMethod` defaults to `client_secret_basic` (Base64 header, not body
|
|
334
|
+
* params) — the SEP-990 conformance test requires this. Only set
|
|
335
|
+
* `client_secret_post` if the AS explicitly requires it.
|
|
336
|
+
*/
|
|
337
|
+
export async function exchangeJwtAuthGrant(opts: {
|
|
338
|
+
tokenEndpoint: string
|
|
339
|
+
assertion: string
|
|
340
|
+
clientId: string
|
|
341
|
+
clientSecret: string
|
|
342
|
+
authMethod?: 'client_secret_basic' | 'client_secret_post'
|
|
343
|
+
scope?: string
|
|
344
|
+
fetchFn?: FetchLike
|
|
345
|
+
}): Promise<XaaTokenResult> {
|
|
346
|
+
const fetchFn = opts.fetchFn ?? defaultFetch
|
|
347
|
+
const authMethod = opts.authMethod ?? 'client_secret_basic'
|
|
348
|
+
|
|
349
|
+
const params = new URLSearchParams({
|
|
350
|
+
grant_type: JWT_BEARER_GRANT,
|
|
351
|
+
assertion: opts.assertion,
|
|
352
|
+
})
|
|
353
|
+
if (opts.scope) {
|
|
354
|
+
params.set('scope', opts.scope)
|
|
355
|
+
}
|
|
356
|
+
|
|
357
|
+
const headers: Record<string, string> = {
|
|
358
|
+
'Content-Type': 'application/x-www-form-urlencoded',
|
|
359
|
+
}
|
|
360
|
+
if (authMethod === 'client_secret_basic') {
|
|
361
|
+
const basicAuth = Buffer.from(
|
|
362
|
+
`${encodeURIComponent(opts.clientId)}:${encodeURIComponent(opts.clientSecret)}`,
|
|
363
|
+
).toString('base64')
|
|
364
|
+
headers.Authorization = `Basic ${basicAuth}`
|
|
365
|
+
} else {
|
|
366
|
+
params.set('client_id', opts.clientId)
|
|
367
|
+
params.set('client_secret', opts.clientSecret)
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
const res = await fetchFn(opts.tokenEndpoint, {
|
|
371
|
+
method: 'POST',
|
|
372
|
+
headers,
|
|
373
|
+
body: params,
|
|
374
|
+
})
|
|
375
|
+
if (!res.ok) {
|
|
376
|
+
const body = redactTokens(await res.text()).slice(0, 200)
|
|
377
|
+
throw new Error(`XAA: jwt-bearer grant failed: HTTP ${res.status}: ${body}`)
|
|
378
|
+
}
|
|
379
|
+
let rawTokens: unknown
|
|
380
|
+
try {
|
|
381
|
+
rawTokens = await res.json()
|
|
382
|
+
} catch {
|
|
383
|
+
throw new Error(
|
|
384
|
+
`XAA: jwt-bearer grant returned non-JSON (captive portal?) at ${opts.tokenEndpoint}`,
|
|
385
|
+
)
|
|
386
|
+
}
|
|
387
|
+
const tokensParsed = JwtBearerResponseSchema().safeParse(rawTokens)
|
|
388
|
+
if (!tokensParsed.success) {
|
|
389
|
+
throw new Error(
|
|
390
|
+
`XAA: jwt-bearer response did not match expected shape: ${redactTokens(rawTokens)}`,
|
|
391
|
+
)
|
|
392
|
+
}
|
|
393
|
+
return tokensParsed.data
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
// ─── Layer 3: Orchestrator ──────────────────────────────────────────────────
|
|
397
|
+
|
|
398
|
+
/**
|
|
399
|
+
* Config needed to run the full XAA orchestrator.
|
|
400
|
+
* Mirrors the conformance test context shape (see ClientConformanceContextSchema).
|
|
401
|
+
*/
|
|
402
|
+
export type XaaConfig = {
|
|
403
|
+
/** Client ID registered at the MCP server's authorization server */
|
|
404
|
+
clientId: string
|
|
405
|
+
/** Client secret for the MCP server's authorization server */
|
|
406
|
+
clientSecret: string
|
|
407
|
+
/** Client ID registered at the IdP (for the token-exchange request) */
|
|
408
|
+
idpClientId: string
|
|
409
|
+
/** Optional IdP client secret (client_secret_post) — some IdPs require it */
|
|
410
|
+
idpClientSecret?: string
|
|
411
|
+
/** The user's OIDC id_token from the IdP login */
|
|
412
|
+
idpIdToken: string
|
|
413
|
+
/** IdP token endpoint (where to send the RFC 8693 token-exchange) */
|
|
414
|
+
idpTokenEndpoint: string
|
|
415
|
+
}
|
|
416
|
+
|
|
417
|
+
/**
|
|
418
|
+
* Full XAA flow: PRM → AS metadata → token-exchange → jwt-bearer → access_token.
|
|
419
|
+
* Thin composition of the four Layer-2 ops. Used by performMCPXaaAuth,
|
|
420
|
+
* ClaudeAuthProvider.xaaRefresh, and the try-xaa*.ts debug scripts.
|
|
421
|
+
*
|
|
422
|
+
* @param serverUrl The MCP server URL (e.g. `https://mcp.example.com/mcp`)
|
|
423
|
+
* @param config IdP + AS credentials
|
|
424
|
+
* @param serverName Server name for debug logging
|
|
425
|
+
*/
|
|
426
|
+
export async function performCrossAppAccess(
|
|
427
|
+
serverUrl: string,
|
|
428
|
+
config: XaaConfig,
|
|
429
|
+
serverName = 'xaa',
|
|
430
|
+
abortSignal?: AbortSignal,
|
|
431
|
+
): Promise<XaaResult> {
|
|
432
|
+
const fetchFn = makeXaaFetch(abortSignal)
|
|
433
|
+
|
|
434
|
+
logMCPDebug(serverName, `XAA: discovering PRM for ${serverUrl}`)
|
|
435
|
+
const prm = await discoverProtectedResource(serverUrl, { fetchFn })
|
|
436
|
+
logMCPDebug(
|
|
437
|
+
serverName,
|
|
438
|
+
`XAA: discovered resource=${prm.resource} ASes=[${prm.authorization_servers.join(', ')}]`,
|
|
439
|
+
)
|
|
440
|
+
|
|
441
|
+
// Try each advertised AS in order. grant_types_supported is OPTIONAL per
|
|
442
|
+
// RFC 8414 §2 — only skip if the AS explicitly advertises a list that omits
|
|
443
|
+
// jwt-bearer. If absent, let the token endpoint decide.
|
|
444
|
+
let asMeta: AuthorizationServerMetadata | undefined
|
|
445
|
+
const asErrors: string[] = []
|
|
446
|
+
for (const asUrl of prm.authorization_servers) {
|
|
447
|
+
let candidate: AuthorizationServerMetadata
|
|
448
|
+
try {
|
|
449
|
+
candidate = await discoverAuthorizationServer(asUrl, { fetchFn })
|
|
450
|
+
} catch (e) {
|
|
451
|
+
if (abortSignal?.aborted) throw e
|
|
452
|
+
asErrors.push(`${asUrl}: ${e instanceof Error ? e.message : String(e)}`)
|
|
453
|
+
continue
|
|
454
|
+
}
|
|
455
|
+
if (
|
|
456
|
+
candidate.grant_types_supported &&
|
|
457
|
+
!candidate.grant_types_supported.includes(JWT_BEARER_GRANT)
|
|
458
|
+
) {
|
|
459
|
+
asErrors.push(
|
|
460
|
+
`${asUrl}: does not advertise jwt-bearer grant (supported: ${candidate.grant_types_supported.join(', ')})`,
|
|
461
|
+
)
|
|
462
|
+
continue
|
|
463
|
+
}
|
|
464
|
+
asMeta = candidate
|
|
465
|
+
break
|
|
466
|
+
}
|
|
467
|
+
if (!asMeta) {
|
|
468
|
+
throw new Error(
|
|
469
|
+
`XAA: no authorization server supports jwt-bearer. Tried: ${asErrors.join('; ')}`,
|
|
470
|
+
)
|
|
471
|
+
}
|
|
472
|
+
// Pick auth method from what the AS advertises. We handle
|
|
473
|
+
// client_secret_basic and client_secret_post; if the AS only supports post,
|
|
474
|
+
// honor that, else default to basic (SEP-990 conformance expectation).
|
|
475
|
+
const authMethods = asMeta.token_endpoint_auth_methods_supported
|
|
476
|
+
const authMethod: 'client_secret_basic' | 'client_secret_post' =
|
|
477
|
+
authMethods &&
|
|
478
|
+
!authMethods.includes('client_secret_basic') &&
|
|
479
|
+
authMethods.includes('client_secret_post')
|
|
480
|
+
? 'client_secret_post'
|
|
481
|
+
: 'client_secret_basic'
|
|
482
|
+
logMCPDebug(
|
|
483
|
+
serverName,
|
|
484
|
+
`XAA: AS issuer=${asMeta.issuer} token_endpoint=${asMeta.token_endpoint} auth_method=${authMethod}`,
|
|
485
|
+
)
|
|
486
|
+
|
|
487
|
+
logMCPDebug(serverName, `XAA: exchanging id_token for ID-JAG at IdP`)
|
|
488
|
+
const jag = await requestJwtAuthorizationGrant({
|
|
489
|
+
tokenEndpoint: config.idpTokenEndpoint,
|
|
490
|
+
audience: asMeta.issuer,
|
|
491
|
+
resource: prm.resource,
|
|
492
|
+
idToken: config.idpIdToken,
|
|
493
|
+
clientId: config.idpClientId,
|
|
494
|
+
clientSecret: config.idpClientSecret,
|
|
495
|
+
fetchFn,
|
|
496
|
+
})
|
|
497
|
+
logMCPDebug(serverName, `XAA: ID-JAG obtained`)
|
|
498
|
+
|
|
499
|
+
logMCPDebug(serverName, `XAA: exchanging ID-JAG for access_token at AS`)
|
|
500
|
+
const tokens = await exchangeJwtAuthGrant({
|
|
501
|
+
tokenEndpoint: asMeta.token_endpoint,
|
|
502
|
+
assertion: jag.jwtAuthGrant,
|
|
503
|
+
clientId: config.clientId,
|
|
504
|
+
clientSecret: config.clientSecret,
|
|
505
|
+
authMethod,
|
|
506
|
+
fetchFn,
|
|
507
|
+
})
|
|
508
|
+
logMCPDebug(serverName, `XAA: access_token obtained`)
|
|
509
|
+
|
|
510
|
+
return { ...tokens, authorizationServerUrl: asMeta.issuer }
|
|
511
|
+
}
|