@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,101 @@
|
|
|
1
|
+
import { feature } from 'bun:bundle'
|
|
2
|
+
import type { ToolPermissionContext } from '../../Tool.js'
|
|
3
|
+
import { logForDebugging } from '../debug.js'
|
|
4
|
+
import type { PermissionMode } from './PermissionMode.js'
|
|
5
|
+
import {
|
|
6
|
+
getAutoModeUnavailableReason,
|
|
7
|
+
isAutoModeGateEnabled,
|
|
8
|
+
transitionPermissionMode,
|
|
9
|
+
} from './permissionSetup.js'
|
|
10
|
+
|
|
11
|
+
// Checks both the cached isAutoModeAvailable (set at startup by
|
|
12
|
+
// verifyAutoModeGateAccess) and the live isAutoModeGateEnabled() — these can
|
|
13
|
+
// diverge if the circuit breaker or settings change mid-session. The
|
|
14
|
+
// live check prevents transitionPermissionMode from throwing
|
|
15
|
+
// (permissionSetup.ts:~559), which would silently crash the shift+tab handler
|
|
16
|
+
// and leave the user stuck at the current mode.
|
|
17
|
+
function canCycleToAuto(ctx: ToolPermissionContext): boolean {
|
|
18
|
+
if (feature('TRANSCRIPT_CLASSIFIER')) {
|
|
19
|
+
const gateEnabled = isAutoModeGateEnabled()
|
|
20
|
+
const can = !!ctx.isAutoModeAvailable && gateEnabled
|
|
21
|
+
if (!can) {
|
|
22
|
+
logForDebugging(
|
|
23
|
+
`[auto-mode] canCycleToAuto=false: ctx.isAutoModeAvailable=${ctx.isAutoModeAvailable} isAutoModeGateEnabled=${gateEnabled} reason=${getAutoModeUnavailableReason()}`,
|
|
24
|
+
)
|
|
25
|
+
}
|
|
26
|
+
return can
|
|
27
|
+
}
|
|
28
|
+
return false
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Determines the next permission mode when cycling through modes with Shift+Tab.
|
|
33
|
+
*/
|
|
34
|
+
export function getNextPermissionMode(
|
|
35
|
+
toolPermissionContext: ToolPermissionContext,
|
|
36
|
+
_teamContext?: { leadAgentId: string },
|
|
37
|
+
): PermissionMode {
|
|
38
|
+
switch (toolPermissionContext.mode) {
|
|
39
|
+
case 'default':
|
|
40
|
+
// Ants skip acceptEdits and plan — auto mode replaces them
|
|
41
|
+
if (process.env.USER_TYPE === 'ant') {
|
|
42
|
+
if (toolPermissionContext.isBypassPermissionsModeAvailable) {
|
|
43
|
+
return 'bypassPermissions'
|
|
44
|
+
}
|
|
45
|
+
if (canCycleToAuto(toolPermissionContext)) {
|
|
46
|
+
return 'auto'
|
|
47
|
+
}
|
|
48
|
+
return 'default'
|
|
49
|
+
}
|
|
50
|
+
return 'acceptEdits'
|
|
51
|
+
|
|
52
|
+
case 'acceptEdits':
|
|
53
|
+
return 'plan'
|
|
54
|
+
|
|
55
|
+
case 'plan':
|
|
56
|
+
if (toolPermissionContext.isBypassPermissionsModeAvailable) {
|
|
57
|
+
return 'bypassPermissions'
|
|
58
|
+
}
|
|
59
|
+
if (canCycleToAuto(toolPermissionContext)) {
|
|
60
|
+
return 'auto'
|
|
61
|
+
}
|
|
62
|
+
return 'default'
|
|
63
|
+
|
|
64
|
+
case 'bypassPermissions':
|
|
65
|
+
if (canCycleToAuto(toolPermissionContext)) {
|
|
66
|
+
return 'auto'
|
|
67
|
+
}
|
|
68
|
+
return 'default'
|
|
69
|
+
|
|
70
|
+
case 'dontAsk':
|
|
71
|
+
// Not exposed in UI cycle yet, but return default if somehow reached
|
|
72
|
+
return 'default'
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
default:
|
|
76
|
+
// Covers auto (when TRANSCRIPT_CLASSIFIER is enabled) and any future modes — always fall back to default
|
|
77
|
+
return 'default'
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Computes the next permission mode and prepares the context for it.
|
|
83
|
+
* Handles any context cleanup needed for the target mode (e.g., stripping
|
|
84
|
+
* dangerous permissions when entering auto mode).
|
|
85
|
+
*
|
|
86
|
+
* @returns The next mode and the context to use (with dangerous permissions stripped if needed)
|
|
87
|
+
*/
|
|
88
|
+
export function cyclePermissionMode(
|
|
89
|
+
toolPermissionContext: ToolPermissionContext,
|
|
90
|
+
teamContext?: { leadAgentId: string },
|
|
91
|
+
): { nextMode: PermissionMode; context: ToolPermissionContext } {
|
|
92
|
+
const nextMode = getNextPermissionMode(toolPermissionContext, teamContext)
|
|
93
|
+
return {
|
|
94
|
+
nextMode,
|
|
95
|
+
context: transitionPermissionMode(
|
|
96
|
+
toolPermissionContext.mode,
|
|
97
|
+
nextMode,
|
|
98
|
+
toolPermissionContext,
|
|
99
|
+
),
|
|
100
|
+
}
|
|
101
|
+
}
|
|
@@ -0,0 +1,485 @@
|
|
|
1
|
+
import memoize from 'lodash-es/memoize.js'
|
|
2
|
+
import { homedir } from 'os'
|
|
3
|
+
import { dirname, isAbsolute, resolve } from 'path'
|
|
4
|
+
import type { ToolPermissionContext } from '../../Tool.js'
|
|
5
|
+
import { getPlatform } from '../../utils/platform.js'
|
|
6
|
+
import {
|
|
7
|
+
getFsImplementation,
|
|
8
|
+
getPathsForPermissionCheck,
|
|
9
|
+
safeResolvePath,
|
|
10
|
+
} from '../fsOperations.js'
|
|
11
|
+
import { containsPathTraversal } from '../path.js'
|
|
12
|
+
import { SandboxManager } from '../sandbox/sandbox-adapter.js'
|
|
13
|
+
import { containsVulnerableUncPath } from '../shell/readOnlyCommandValidation.js'
|
|
14
|
+
import {
|
|
15
|
+
checkEditableInternalPath,
|
|
16
|
+
checkPathSafetyForAutoEdit,
|
|
17
|
+
checkReadableInternalPath,
|
|
18
|
+
matchingRuleForInput,
|
|
19
|
+
pathInAllowedWorkingPath,
|
|
20
|
+
pathInWorkingPath,
|
|
21
|
+
} from './filesystem.js'
|
|
22
|
+
import type { PermissionDecisionReason } from './PermissionResult.js'
|
|
23
|
+
|
|
24
|
+
const MAX_DIRS_TO_LIST = 5
|
|
25
|
+
const GLOB_PATTERN_REGEX = /[*?[\]{}]/
|
|
26
|
+
|
|
27
|
+
export type FileOperationType = 'read' | 'write' | 'create'
|
|
28
|
+
|
|
29
|
+
export type PathCheckResult = {
|
|
30
|
+
allowed: boolean
|
|
31
|
+
decisionReason?: PermissionDecisionReason
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export type ResolvedPathCheckResult = PathCheckResult & {
|
|
35
|
+
resolvedPath: string
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export function formatDirectoryList(directories: string[]): string {
|
|
39
|
+
const dirCount = directories.length
|
|
40
|
+
|
|
41
|
+
if (dirCount <= MAX_DIRS_TO_LIST) {
|
|
42
|
+
return directories.map(dir => `'${dir}'`).join(', ')
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
const firstDirs = directories
|
|
46
|
+
.slice(0, MAX_DIRS_TO_LIST)
|
|
47
|
+
.map(dir => `'${dir}'`)
|
|
48
|
+
.join(', ')
|
|
49
|
+
|
|
50
|
+
return `${firstDirs}, and ${dirCount - MAX_DIRS_TO_LIST} more`
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* Extracts the base directory from a glob pattern for validation.
|
|
55
|
+
* For example: "/path/to/*.txt" returns "/path/to"
|
|
56
|
+
*/
|
|
57
|
+
export function getGlobBaseDirectory(path: string): string {
|
|
58
|
+
const globMatch = path.match(GLOB_PATTERN_REGEX)
|
|
59
|
+
if (!globMatch || globMatch.index === undefined) {
|
|
60
|
+
return path
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// Get everything before the first glob character
|
|
64
|
+
const beforeGlob = path.substring(0, globMatch.index)
|
|
65
|
+
|
|
66
|
+
// Find the last directory separator
|
|
67
|
+
const lastSepIndex =
|
|
68
|
+
getPlatform() === 'windows'
|
|
69
|
+
? Math.max(beforeGlob.lastIndexOf('/'), beforeGlob.lastIndexOf('\\'))
|
|
70
|
+
: beforeGlob.lastIndexOf('/')
|
|
71
|
+
if (lastSepIndex === -1) return '.'
|
|
72
|
+
|
|
73
|
+
return beforeGlob.substring(0, lastSepIndex) || '/'
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* Expands tilde (~) at the start of a path to the user's home directory.
|
|
78
|
+
* Note: ~username expansion is not supported for security reasons.
|
|
79
|
+
*/
|
|
80
|
+
export function expandTilde(path: string): string {
|
|
81
|
+
if (
|
|
82
|
+
path === '~' ||
|
|
83
|
+
path.startsWith('~/') ||
|
|
84
|
+
(process.platform === 'win32' && path.startsWith('~\\'))
|
|
85
|
+
) {
|
|
86
|
+
return homedir() + path.slice(1)
|
|
87
|
+
}
|
|
88
|
+
return path
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Checks if a resolved path is writable according to the sandbox write allowlist.
|
|
93
|
+
* When the sandbox is enabled, the user has explicitly configured which directories
|
|
94
|
+
* are writable. We treat these as additional allowed write directories for path
|
|
95
|
+
* validation purposes, so commands like `echo foo > /tmp/claude/x.txt` don't
|
|
96
|
+
* prompt for permission when /tmp/claude/ is already in the sandbox allowlist.
|
|
97
|
+
*
|
|
98
|
+
* Respects the deny-within-allow list: paths in denyWithinAllow (like
|
|
99
|
+
* .claude/settings.json) are still blocked even if their parent is in allowOnly.
|
|
100
|
+
*/
|
|
101
|
+
export function isPathInSandboxWriteAllowlist(resolvedPath: string): boolean {
|
|
102
|
+
if (!SandboxManager.isSandboxingEnabled()) {
|
|
103
|
+
return false
|
|
104
|
+
}
|
|
105
|
+
const { allowOnly, denyWithinAllow } = SandboxManager.getFsWriteConfig()
|
|
106
|
+
// Resolve symlinks on both sides so comparisons are symmetric (matching
|
|
107
|
+
// pathInAllowedWorkingPath). Without this, an allowlist entry that is a
|
|
108
|
+
// symlink (e.g. /home/user/proj -> /data/proj) would not match a write to
|
|
109
|
+
// its resolved target, causing an unnecessary prompt. Over-conservative,
|
|
110
|
+
// not a security issue. All resolved input representations must be allowed
|
|
111
|
+
// and none may be denied. Config paths are session-stable, so memoize
|
|
112
|
+
// their resolution to avoid N × config.length redundant syscalls per
|
|
113
|
+
// command with N write targets (matching getResolvedWorkingDirPaths).
|
|
114
|
+
const pathsToCheck = getPathsForPermissionCheck(resolvedPath)
|
|
115
|
+
const resolvedAllow = allowOnly.flatMap(getResolvedSandboxConfigPath)
|
|
116
|
+
const resolvedDeny = denyWithinAllow.flatMap(getResolvedSandboxConfigPath)
|
|
117
|
+
return pathsToCheck.every(p => {
|
|
118
|
+
for (const denyPath of resolvedDeny) {
|
|
119
|
+
if (pathInWorkingPath(p, denyPath)) return false
|
|
120
|
+
}
|
|
121
|
+
return resolvedAllow.some(allowPath => pathInWorkingPath(p, allowPath))
|
|
122
|
+
})
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// Sandbox config paths are session-stable; memoize their resolved forms to
|
|
126
|
+
// avoid repeated lstat/realpath syscalls on every write-target check.
|
|
127
|
+
// Matches the getResolvedWorkingDirPaths pattern in filesystem.ts.
|
|
128
|
+
const getResolvedSandboxConfigPath = memoize(getPathsForPermissionCheck)
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Checks if a resolved path is allowed for the given operation type.
|
|
132
|
+
*
|
|
133
|
+
* @param precomputedPathsToCheck - Optional cached result of
|
|
134
|
+
* `getPathsForPermissionCheck(resolvedPath)`. When `resolvedPath` is the
|
|
135
|
+
* output of `realpathSync` (canonical path, all symlinks resolved), this
|
|
136
|
+
* is trivially `[resolvedPath]` and passing it here skips 5 redundant
|
|
137
|
+
* syscalls per inner check. Do NOT pass this for non-canonical paths
|
|
138
|
+
* (nonexistent files, UNC paths, etc.) — parent-directory symlink
|
|
139
|
+
* resolution is still required for those.
|
|
140
|
+
*/
|
|
141
|
+
export function isPathAllowed(
|
|
142
|
+
resolvedPath: string,
|
|
143
|
+
context: ToolPermissionContext,
|
|
144
|
+
operationType: FileOperationType,
|
|
145
|
+
precomputedPathsToCheck?: readonly string[],
|
|
146
|
+
): PathCheckResult {
|
|
147
|
+
// Determine which permission type to check based on operation
|
|
148
|
+
const permissionType = operationType === 'read' ? 'read' : 'edit'
|
|
149
|
+
|
|
150
|
+
// 1. Check deny rules first (they take precedence)
|
|
151
|
+
const denyRule = matchingRuleForInput(
|
|
152
|
+
resolvedPath,
|
|
153
|
+
context,
|
|
154
|
+
permissionType,
|
|
155
|
+
'deny',
|
|
156
|
+
)
|
|
157
|
+
if (denyRule !== null) {
|
|
158
|
+
return {
|
|
159
|
+
allowed: false,
|
|
160
|
+
decisionReason: { type: 'rule', rule: denyRule },
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
// 2. For write/create operations, check internal editable paths (plan files, scratchpad, agent memory, job dirs)
|
|
165
|
+
// This MUST come before checkPathSafetyForAutoEdit since .claude is a dangerous directory
|
|
166
|
+
// and internal editable paths live under ~/.claude/ — matching the ordering in
|
|
167
|
+
// checkWritePermissionForTool (filesystem.ts step 1.5)
|
|
168
|
+
if (operationType !== 'read') {
|
|
169
|
+
const internalEditResult = checkEditableInternalPath(resolvedPath, {})
|
|
170
|
+
if (internalEditResult.behavior === 'allow') {
|
|
171
|
+
return {
|
|
172
|
+
allowed: true,
|
|
173
|
+
decisionReason: internalEditResult.decisionReason,
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
// 2.5. For write/create operations, check comprehensive safety validations
|
|
179
|
+
// This MUST come before checking working directory to prevent bypass via acceptEdits mode
|
|
180
|
+
// Checks: Windows patterns, Claude config files, dangerous files (on original + symlink paths)
|
|
181
|
+
if (operationType !== 'read') {
|
|
182
|
+
const safetyCheck = checkPathSafetyForAutoEdit(
|
|
183
|
+
resolvedPath,
|
|
184
|
+
precomputedPathsToCheck,
|
|
185
|
+
)
|
|
186
|
+
if (!safetyCheck.safe) {
|
|
187
|
+
return {
|
|
188
|
+
allowed: false,
|
|
189
|
+
decisionReason: {
|
|
190
|
+
type: 'safetyCheck',
|
|
191
|
+
reason: safetyCheck.message,
|
|
192
|
+
classifierApprovable: safetyCheck.classifierApprovable,
|
|
193
|
+
},
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
// 3. Check if path is in allowed working directory
|
|
199
|
+
// For write/create operations, require acceptEdits mode to auto-allow
|
|
200
|
+
// This is consistent with checkWritePermissionForTool in filesystem.ts
|
|
201
|
+
const isInWorkingDir = pathInAllowedWorkingPath(
|
|
202
|
+
resolvedPath,
|
|
203
|
+
context,
|
|
204
|
+
precomputedPathsToCheck,
|
|
205
|
+
)
|
|
206
|
+
if (isInWorkingDir) {
|
|
207
|
+
if (operationType === 'read' || context.mode === 'acceptEdits') {
|
|
208
|
+
return { allowed: true }
|
|
209
|
+
}
|
|
210
|
+
// Write/create without acceptEdits mode falls through to check allow rules
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
// 3.5. For read operations, check internal readable paths (project temp dir, session memory, etc.)
|
|
214
|
+
// This allows reading agent output files without explicit permission
|
|
215
|
+
if (operationType === 'read') {
|
|
216
|
+
const internalReadResult = checkReadableInternalPath(resolvedPath, {})
|
|
217
|
+
if (internalReadResult.behavior === 'allow') {
|
|
218
|
+
return {
|
|
219
|
+
allowed: true,
|
|
220
|
+
decisionReason: internalReadResult.decisionReason,
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
// 3.7. For write/create operations to paths OUTSIDE the working directory,
|
|
226
|
+
// check the sandbox write allowlist. When the sandbox is enabled, users
|
|
227
|
+
// have explicitly configured writable directories (e.g. /tmp/claude/) —
|
|
228
|
+
// treat these as additional allowed write directories so redirects/touch/
|
|
229
|
+
// mkdir don't prompt unnecessarily. Safety checks (step 2) already ran.
|
|
230
|
+
// Paths IN the working directory are intentionally excluded: the sandbox
|
|
231
|
+
// allowlist always seeds '.' (cwd, see sandbox-adapter.ts), which would
|
|
232
|
+
// bypass the acceptEdits gate at step 3. Step 3 handles those.
|
|
233
|
+
if (
|
|
234
|
+
operationType !== 'read' &&
|
|
235
|
+
!isInWorkingDir &&
|
|
236
|
+
isPathInSandboxWriteAllowlist(resolvedPath)
|
|
237
|
+
) {
|
|
238
|
+
return {
|
|
239
|
+
allowed: true,
|
|
240
|
+
decisionReason: {
|
|
241
|
+
type: 'other',
|
|
242
|
+
reason: 'Path is in sandbox write allowlist',
|
|
243
|
+
},
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
// 4. Check allow rules for the operation type
|
|
248
|
+
const allowRule = matchingRuleForInput(
|
|
249
|
+
resolvedPath,
|
|
250
|
+
context,
|
|
251
|
+
permissionType,
|
|
252
|
+
'allow',
|
|
253
|
+
)
|
|
254
|
+
if (allowRule !== null) {
|
|
255
|
+
return {
|
|
256
|
+
allowed: true,
|
|
257
|
+
decisionReason: { type: 'rule', rule: allowRule },
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
// 5. Path is not allowed
|
|
262
|
+
return { allowed: false }
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
/**
|
|
266
|
+
* Validates a glob pattern by checking its base directory.
|
|
267
|
+
* Returns the validation result for the base path where the glob would expand.
|
|
268
|
+
*/
|
|
269
|
+
export function validateGlobPattern(
|
|
270
|
+
cleanPath: string,
|
|
271
|
+
cwd: string,
|
|
272
|
+
toolPermissionContext: ToolPermissionContext,
|
|
273
|
+
operationType: FileOperationType,
|
|
274
|
+
): ResolvedPathCheckResult {
|
|
275
|
+
if (containsPathTraversal(cleanPath)) {
|
|
276
|
+
// For patterns with path traversal, resolve the full path
|
|
277
|
+
const absolutePath = isAbsolute(cleanPath)
|
|
278
|
+
? cleanPath
|
|
279
|
+
: resolve(cwd, cleanPath)
|
|
280
|
+
const { resolvedPath, isCanonical } = safeResolvePath(
|
|
281
|
+
getFsImplementation(),
|
|
282
|
+
absolutePath,
|
|
283
|
+
)
|
|
284
|
+
const result = isPathAllowed(
|
|
285
|
+
resolvedPath,
|
|
286
|
+
toolPermissionContext,
|
|
287
|
+
operationType,
|
|
288
|
+
isCanonical ? [resolvedPath] : undefined,
|
|
289
|
+
)
|
|
290
|
+
return {
|
|
291
|
+
allowed: result.allowed,
|
|
292
|
+
resolvedPath,
|
|
293
|
+
decisionReason: result.decisionReason,
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
const basePath = getGlobBaseDirectory(cleanPath)
|
|
298
|
+
const absoluteBasePath = isAbsolute(basePath)
|
|
299
|
+
? basePath
|
|
300
|
+
: resolve(cwd, basePath)
|
|
301
|
+
const { resolvedPath, isCanonical } = safeResolvePath(
|
|
302
|
+
getFsImplementation(),
|
|
303
|
+
absoluteBasePath,
|
|
304
|
+
)
|
|
305
|
+
const result = isPathAllowed(
|
|
306
|
+
resolvedPath,
|
|
307
|
+
toolPermissionContext,
|
|
308
|
+
operationType,
|
|
309
|
+
isCanonical ? [resolvedPath] : undefined,
|
|
310
|
+
)
|
|
311
|
+
return {
|
|
312
|
+
allowed: result.allowed,
|
|
313
|
+
resolvedPath,
|
|
314
|
+
decisionReason: result.decisionReason,
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
|
|
318
|
+
const WINDOWS_DRIVE_ROOT_REGEX = /^[A-Za-z]:\/?$/
|
|
319
|
+
const WINDOWS_DRIVE_CHILD_REGEX = /^[A-Za-z]:\/[^/]+$/
|
|
320
|
+
|
|
321
|
+
/**
|
|
322
|
+
* Checks if a resolved path is dangerous for removal operations (rm/rmdir).
|
|
323
|
+
* Dangerous paths are:
|
|
324
|
+
* - Wildcard '*' (removes all files in directory)
|
|
325
|
+
* - Any path ending with '/*' or '\*' (e.g., /path/to/dir/*, C:\foo\*)
|
|
326
|
+
* - Root directory (/)
|
|
327
|
+
* - Home directory (~)
|
|
328
|
+
* - Direct children of root (/usr, /tmp, /etc, etc.)
|
|
329
|
+
* - Windows drive root (C:\, D:\) and direct children (C:\Windows, C:\Users)
|
|
330
|
+
*/
|
|
331
|
+
export function isDangerousRemovalPath(resolvedPath: string): boolean {
|
|
332
|
+
// Callers pass both slash forms; collapse runs so C:\\Windows (valid in
|
|
333
|
+
// PowerShell) doesn't bypass the drive-child check.
|
|
334
|
+
const forwardSlashed = resolvedPath.replace(/[\\/]+/g, '/')
|
|
335
|
+
|
|
336
|
+
if (forwardSlashed === '*' || forwardSlashed.endsWith('/*')) {
|
|
337
|
+
return true
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
const normalizedPath =
|
|
341
|
+
forwardSlashed === '/' ? forwardSlashed : forwardSlashed.replace(/\/$/, '')
|
|
342
|
+
|
|
343
|
+
if (normalizedPath === '/') {
|
|
344
|
+
return true
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
if (WINDOWS_DRIVE_ROOT_REGEX.test(normalizedPath)) {
|
|
348
|
+
return true
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
const normalizedHome = homedir().replace(/[\\/]+/g, '/')
|
|
352
|
+
if (normalizedPath === normalizedHome) {
|
|
353
|
+
return true
|
|
354
|
+
}
|
|
355
|
+
|
|
356
|
+
// Direct children of root: /usr, /tmp, /etc (but not /usr/local)
|
|
357
|
+
const parentDir = dirname(normalizedPath)
|
|
358
|
+
if (parentDir === '/') {
|
|
359
|
+
return true
|
|
360
|
+
}
|
|
361
|
+
|
|
362
|
+
if (WINDOWS_DRIVE_CHILD_REGEX.test(normalizedPath)) {
|
|
363
|
+
return true
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
return false
|
|
367
|
+
}
|
|
368
|
+
|
|
369
|
+
/**
|
|
370
|
+
* Validates a file system path, handling tilde expansion and glob patterns.
|
|
371
|
+
* Returns whether the path is allowed and the resolved path for error messages.
|
|
372
|
+
*/
|
|
373
|
+
export function validatePath(
|
|
374
|
+
path: string,
|
|
375
|
+
cwd: string,
|
|
376
|
+
toolPermissionContext: ToolPermissionContext,
|
|
377
|
+
operationType: FileOperationType,
|
|
378
|
+
): ResolvedPathCheckResult {
|
|
379
|
+
// Remove surrounding quotes if present
|
|
380
|
+
const cleanPath = expandTilde(path.replace(/^['"]|['"]$/g, ''))
|
|
381
|
+
|
|
382
|
+
// SECURITY: Block UNC paths that could leak credentials
|
|
383
|
+
if (containsVulnerableUncPath(cleanPath)) {
|
|
384
|
+
return {
|
|
385
|
+
allowed: false,
|
|
386
|
+
resolvedPath: cleanPath,
|
|
387
|
+
decisionReason: {
|
|
388
|
+
type: 'other',
|
|
389
|
+
reason: 'UNC network paths require manual approval',
|
|
390
|
+
},
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
// SECURITY: Reject tilde variants (~user, ~+, ~-, ~N) that expandTilde doesn't handle.
|
|
395
|
+
// expandTilde resolves ~ and ~/ to $HOME, but ~root, ~+, ~- etc. are left as literal
|
|
396
|
+
// text and resolved as relative paths (e.g., /cwd/~root/.ssh/id_rsa).
|
|
397
|
+
// The shell expands these differently (~root → /var/root, ~+ → $PWD, ~- → $OLDPWD),
|
|
398
|
+
// creating a TOCTOU gap: we validate /cwd/~root/... but bash reads /var/root/...
|
|
399
|
+
// This check is safe from false positives because expandTilde already converted
|
|
400
|
+
// ~ and ~/ to absolute paths starting with /, so only unexpanded variants remain.
|
|
401
|
+
if (cleanPath.startsWith('~')) {
|
|
402
|
+
return {
|
|
403
|
+
allowed: false,
|
|
404
|
+
resolvedPath: cleanPath,
|
|
405
|
+
decisionReason: {
|
|
406
|
+
type: 'other',
|
|
407
|
+
reason:
|
|
408
|
+
'Tilde expansion variants (~user, ~+, ~-) in paths require manual approval',
|
|
409
|
+
},
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
|
|
413
|
+
// SECURITY: Reject paths containing ANY shell expansion syntax ($ or % characters,
|
|
414
|
+
// or paths starting with = which triggers Zsh equals expansion)
|
|
415
|
+
// - $VAR (Unix/Linux environment variables like $HOME, $PWD)
|
|
416
|
+
// - ${VAR} (brace expansion)
|
|
417
|
+
// - $(cmd) (command substitution)
|
|
418
|
+
// - %VAR% (Windows environment variables like %TEMP%, %USERPROFILE%)
|
|
419
|
+
// - Nested combinations like $(echo $HOME)
|
|
420
|
+
// - =cmd (Zsh equals expansion, e.g. =rg expands to /usr/bin/rg)
|
|
421
|
+
// All of these are preserved as literal strings during validation but expanded
|
|
422
|
+
// by the shell during execution, creating a TOCTOU vulnerability
|
|
423
|
+
if (
|
|
424
|
+
cleanPath.includes('$') ||
|
|
425
|
+
cleanPath.includes('%') ||
|
|
426
|
+
cleanPath.startsWith('=')
|
|
427
|
+
) {
|
|
428
|
+
return {
|
|
429
|
+
allowed: false,
|
|
430
|
+
resolvedPath: cleanPath,
|
|
431
|
+
decisionReason: {
|
|
432
|
+
type: 'other',
|
|
433
|
+
reason: 'Shell expansion syntax in paths requires manual approval',
|
|
434
|
+
},
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
// SECURITY: Block glob patterns in write/create operations
|
|
439
|
+
// Write tools don't expand globs - they use paths literally.
|
|
440
|
+
// Allowing globs in write operations could bypass security checks.
|
|
441
|
+
// Example: /allowed/dir/*.txt would only validate /allowed/dir,
|
|
442
|
+
// but the actual write would use the literal path with the *
|
|
443
|
+
if (GLOB_PATTERN_REGEX.test(cleanPath)) {
|
|
444
|
+
if (operationType === 'write' || operationType === 'create') {
|
|
445
|
+
return {
|
|
446
|
+
allowed: false,
|
|
447
|
+
resolvedPath: cleanPath,
|
|
448
|
+
decisionReason: {
|
|
449
|
+
type: 'other',
|
|
450
|
+
reason:
|
|
451
|
+
'Glob patterns are not allowed in write operations. Please specify an exact file path.',
|
|
452
|
+
},
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
|
|
456
|
+
// For read operations, validate the base directory where the glob would expand
|
|
457
|
+
return validateGlobPattern(
|
|
458
|
+
cleanPath,
|
|
459
|
+
cwd,
|
|
460
|
+
toolPermissionContext,
|
|
461
|
+
operationType,
|
|
462
|
+
)
|
|
463
|
+
}
|
|
464
|
+
|
|
465
|
+
// Resolve path
|
|
466
|
+
const absolutePath = isAbsolute(cleanPath)
|
|
467
|
+
? cleanPath
|
|
468
|
+
: resolve(cwd, cleanPath)
|
|
469
|
+
const { resolvedPath, isCanonical } = safeResolvePath(
|
|
470
|
+
getFsImplementation(),
|
|
471
|
+
absolutePath,
|
|
472
|
+
)
|
|
473
|
+
|
|
474
|
+
const result = isPathAllowed(
|
|
475
|
+
resolvedPath,
|
|
476
|
+
toolPermissionContext,
|
|
477
|
+
operationType,
|
|
478
|
+
isCanonical ? [resolvedPath] : undefined,
|
|
479
|
+
)
|
|
480
|
+
return {
|
|
481
|
+
allowed: result.allowed,
|
|
482
|
+
resolvedPath,
|
|
483
|
+
decisionReason: result.decisionReason,
|
|
484
|
+
}
|
|
485
|
+
}
|