@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,684 @@
|
|
|
1
|
+
import type { ToolPermissionContext } from '../../Tool.js'
|
|
2
|
+
import { splitCommand_DEPRECATED } from '../../utils/bash/commands.js'
|
|
3
|
+
import { tryParseShellCommand } from '../../utils/bash/shellQuote.js'
|
|
4
|
+
import type { PermissionResult } from '../../utils/permissions/PermissionResult.js'
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Helper: Validate flags against an allowlist
|
|
8
|
+
* Handles both single flags and combined flags (e.g., -nE)
|
|
9
|
+
* @param flags Array of flags to validate
|
|
10
|
+
* @param allowedFlags Array of allowed single-character and long flags
|
|
11
|
+
* @returns true if all flags are valid, false otherwise
|
|
12
|
+
*/
|
|
13
|
+
function validateFlagsAgainstAllowlist(
|
|
14
|
+
flags: string[],
|
|
15
|
+
allowedFlags: string[],
|
|
16
|
+
): boolean {
|
|
17
|
+
for (const flag of flags) {
|
|
18
|
+
// Handle combined flags like -nE or -Er
|
|
19
|
+
if (flag.startsWith('-') && !flag.startsWith('--') && flag.length > 2) {
|
|
20
|
+
// Check each character in combined flag
|
|
21
|
+
for (let i = 1; i < flag.length; i++) {
|
|
22
|
+
const singleFlag = '-' + flag[i]
|
|
23
|
+
if (!allowedFlags.includes(singleFlag)) {
|
|
24
|
+
return false
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
} else {
|
|
28
|
+
// Single flag or long flag
|
|
29
|
+
if (!allowedFlags.includes(flag)) {
|
|
30
|
+
return false
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return true
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Pattern 1: Check if this is a line printing command with -n flag
|
|
39
|
+
* Allows: sed -n 'N' | sed -n 'N,M' with optional -E, -r, -z flags
|
|
40
|
+
* Allows semicolon-separated print commands like: sed -n '1p;2p;3p'
|
|
41
|
+
* File arguments are ALLOWED for this pattern
|
|
42
|
+
* @internal Exported for testing
|
|
43
|
+
*/
|
|
44
|
+
export function isLinePrintingCommand(
|
|
45
|
+
command: string,
|
|
46
|
+
expressions: string[],
|
|
47
|
+
): boolean {
|
|
48
|
+
const sedMatch = command.match(/^\s*sed\s+/)
|
|
49
|
+
if (!sedMatch) return false
|
|
50
|
+
|
|
51
|
+
const withoutSed = command.slice(sedMatch[0].length)
|
|
52
|
+
const parseResult = tryParseShellCommand(withoutSed)
|
|
53
|
+
if (!parseResult.success) return false
|
|
54
|
+
const parsed = parseResult.tokens
|
|
55
|
+
|
|
56
|
+
// Extract all flags
|
|
57
|
+
const flags: string[] = []
|
|
58
|
+
for (const arg of parsed) {
|
|
59
|
+
if (typeof arg === 'string' && arg.startsWith('-') && arg !== '--') {
|
|
60
|
+
flags.push(arg)
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// Validate flags - only allow -n, -E, -r, -z and their long forms
|
|
65
|
+
const allowedFlags = [
|
|
66
|
+
'-n',
|
|
67
|
+
'--quiet',
|
|
68
|
+
'--silent',
|
|
69
|
+
'-E',
|
|
70
|
+
'--regexp-extended',
|
|
71
|
+
'-r',
|
|
72
|
+
'-z',
|
|
73
|
+
'--zero-terminated',
|
|
74
|
+
'--posix',
|
|
75
|
+
]
|
|
76
|
+
|
|
77
|
+
if (!validateFlagsAgainstAllowlist(flags, allowedFlags)) {
|
|
78
|
+
return false
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
// Check if -n flag is present (required for Pattern 1)
|
|
82
|
+
let hasNFlag = false
|
|
83
|
+
for (const flag of flags) {
|
|
84
|
+
if (flag === '-n' || flag === '--quiet' || flag === '--silent') {
|
|
85
|
+
hasNFlag = true
|
|
86
|
+
break
|
|
87
|
+
}
|
|
88
|
+
// Check in combined flags
|
|
89
|
+
if (flag.startsWith('-') && !flag.startsWith('--') && flag.includes('n')) {
|
|
90
|
+
hasNFlag = true
|
|
91
|
+
break
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// Must have -n flag for Pattern 1
|
|
96
|
+
if (!hasNFlag) {
|
|
97
|
+
return false
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// Must have at least one expression
|
|
101
|
+
if (expressions.length === 0) {
|
|
102
|
+
return false
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// All expressions must be print commands (strict allowlist)
|
|
106
|
+
// Allow semicolon-separated commands
|
|
107
|
+
for (const expr of expressions) {
|
|
108
|
+
const commands = expr.split(';')
|
|
109
|
+
for (const cmd of commands) {
|
|
110
|
+
if (!isPrintCommand(cmd.trim())) {
|
|
111
|
+
return false
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
return true
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* Helper: Check if a single command is a valid print command
|
|
121
|
+
* STRICT ALLOWLIST - only these exact forms are allowed:
|
|
122
|
+
* - p (print all)
|
|
123
|
+
* - Np (print line N, where N is digits)
|
|
124
|
+
* - N,Mp (print lines N through M)
|
|
125
|
+
* Anything else (including w, W, e, E commands) is rejected.
|
|
126
|
+
* @internal Exported for testing
|
|
127
|
+
*/
|
|
128
|
+
export function isPrintCommand(cmd: string): boolean {
|
|
129
|
+
if (!cmd) return false
|
|
130
|
+
// Single strict regex that only matches allowed print commands
|
|
131
|
+
// ^(?:\d+|\d+,\d+)?p$ matches: p, 1p, 123p, 1,5p, 10,200p
|
|
132
|
+
return /^(?:\d+|\d+,\d+)?p$/.test(cmd)
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* Pattern 2: Check if this is a substitution command
|
|
137
|
+
* Allows: sed 's/pattern/replacement/flags' where flags are only: g, p, i, I, m, M, 1-9
|
|
138
|
+
* When allowFileWrites is true, allows -i flag and file arguments for in-place editing
|
|
139
|
+
* When allowFileWrites is false (default), requires stdout-only (no file arguments, no -i flag)
|
|
140
|
+
* @internal Exported for testing
|
|
141
|
+
*/
|
|
142
|
+
function isSubstitutionCommand(
|
|
143
|
+
command: string,
|
|
144
|
+
expressions: string[],
|
|
145
|
+
hasFileArguments: boolean,
|
|
146
|
+
options?: { allowFileWrites?: boolean },
|
|
147
|
+
): boolean {
|
|
148
|
+
const allowFileWrites = options?.allowFileWrites ?? false
|
|
149
|
+
|
|
150
|
+
// When not allowing file writes, must NOT have file arguments
|
|
151
|
+
if (!allowFileWrites && hasFileArguments) {
|
|
152
|
+
return false
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
const sedMatch = command.match(/^\s*sed\s+/)
|
|
156
|
+
if (!sedMatch) return false
|
|
157
|
+
|
|
158
|
+
const withoutSed = command.slice(sedMatch[0].length)
|
|
159
|
+
const parseResult = tryParseShellCommand(withoutSed)
|
|
160
|
+
if (!parseResult.success) return false
|
|
161
|
+
const parsed = parseResult.tokens
|
|
162
|
+
|
|
163
|
+
// Extract all flags
|
|
164
|
+
const flags: string[] = []
|
|
165
|
+
for (const arg of parsed) {
|
|
166
|
+
if (typeof arg === 'string' && arg.startsWith('-') && arg !== '--') {
|
|
167
|
+
flags.push(arg)
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
// Validate flags based on mode
|
|
172
|
+
// Base allowed flags for both modes
|
|
173
|
+
const allowedFlags = ['-E', '--regexp-extended', '-r', '--posix']
|
|
174
|
+
|
|
175
|
+
// When allowing file writes, also permit -i and --in-place
|
|
176
|
+
if (allowFileWrites) {
|
|
177
|
+
allowedFlags.push('-i', '--in-place')
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
if (!validateFlagsAgainstAllowlist(flags, allowedFlags)) {
|
|
181
|
+
return false
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
// Must have exactly one expression
|
|
185
|
+
if (expressions.length !== 1) {
|
|
186
|
+
return false
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
const expr = expressions[0]!.trim()
|
|
190
|
+
|
|
191
|
+
// STRICT ALLOWLIST: Must be exactly a substitution command starting with 's'
|
|
192
|
+
// This rejects standalone commands like 'e', 'w file', etc.
|
|
193
|
+
if (!expr.startsWith('s')) {
|
|
194
|
+
return false
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
// Parse substitution: s/pattern/replacement/flags
|
|
198
|
+
// Only allow / as delimiter (strict)
|
|
199
|
+
const substitutionMatch = expr.match(/^s\/(.*?)$/)
|
|
200
|
+
if (!substitutionMatch) {
|
|
201
|
+
return false
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
const rest = substitutionMatch[1]!
|
|
205
|
+
|
|
206
|
+
// Find the positions of / delimiters
|
|
207
|
+
let delimiterCount = 0
|
|
208
|
+
let lastDelimiterPos = -1
|
|
209
|
+
let i = 0
|
|
210
|
+
while (i < rest.length) {
|
|
211
|
+
if (rest[i] === '\\') {
|
|
212
|
+
// Skip escaped character
|
|
213
|
+
i += 2
|
|
214
|
+
continue
|
|
215
|
+
}
|
|
216
|
+
if (rest[i] === '/') {
|
|
217
|
+
delimiterCount++
|
|
218
|
+
lastDelimiterPos = i
|
|
219
|
+
}
|
|
220
|
+
i++
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
// Must have found exactly 2 delimiters (pattern and replacement)
|
|
224
|
+
if (delimiterCount !== 2) {
|
|
225
|
+
return false
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
// Extract flags (everything after the last delimiter)
|
|
229
|
+
const exprFlags = rest.slice(lastDelimiterPos + 1)
|
|
230
|
+
|
|
231
|
+
// Validate flags: only allow g, p, i, I, m, M, and optionally ONE digit 1-9
|
|
232
|
+
const allowedFlagChars = /^[gpimIM]*[1-9]?[gpimIM]*$/
|
|
233
|
+
if (!allowedFlagChars.test(exprFlags)) {
|
|
234
|
+
return false
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
return true
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
/**
|
|
241
|
+
* Checks if a sed command is allowed by the allowlist.
|
|
242
|
+
* The allowlist patterns themselves are strict enough to reject dangerous operations.
|
|
243
|
+
* @param command The sed command to check
|
|
244
|
+
* @param options.allowFileWrites When true, allows -i flag and file arguments for substitution commands
|
|
245
|
+
* @returns true if the command is allowed (matches allowlist and passes denylist check), false otherwise
|
|
246
|
+
*/
|
|
247
|
+
export function sedCommandIsAllowedByAllowlist(
|
|
248
|
+
command: string,
|
|
249
|
+
options?: { allowFileWrites?: boolean },
|
|
250
|
+
): boolean {
|
|
251
|
+
const allowFileWrites = options?.allowFileWrites ?? false
|
|
252
|
+
|
|
253
|
+
// Extract sed expressions (content inside quotes where actual sed commands live)
|
|
254
|
+
let expressions: string[]
|
|
255
|
+
try {
|
|
256
|
+
expressions = extractSedExpressions(command)
|
|
257
|
+
} catch (_error) {
|
|
258
|
+
// If parsing failed, treat as not allowed
|
|
259
|
+
return false
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
// Check if sed command has file arguments
|
|
263
|
+
const hasFileArguments = hasFileArgs(command)
|
|
264
|
+
|
|
265
|
+
// Check if command matches allowlist patterns
|
|
266
|
+
let isPattern1 = false
|
|
267
|
+
let isPattern2 = false
|
|
268
|
+
|
|
269
|
+
if (allowFileWrites) {
|
|
270
|
+
// When allowing file writes, only check substitution commands (Pattern 2 variant)
|
|
271
|
+
// Pattern 1 (line printing) doesn't need file writes
|
|
272
|
+
isPattern2 = isSubstitutionCommand(command, expressions, hasFileArguments, {
|
|
273
|
+
allowFileWrites: true,
|
|
274
|
+
})
|
|
275
|
+
} else {
|
|
276
|
+
// Standard read-only mode: check both patterns
|
|
277
|
+
isPattern1 = isLinePrintingCommand(command, expressions)
|
|
278
|
+
isPattern2 = isSubstitutionCommand(command, expressions, hasFileArguments)
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
if (!isPattern1 && !isPattern2) {
|
|
282
|
+
return false
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
// Pattern 2 does not allow semicolons (command separators)
|
|
286
|
+
// Pattern 1 allows semicolons for separating print commands
|
|
287
|
+
for (const expr of expressions) {
|
|
288
|
+
if (isPattern2 && expr.includes(';')) {
|
|
289
|
+
return false
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
// Defense-in-depth: Even if allowlist matches, check denylist
|
|
294
|
+
for (const expr of expressions) {
|
|
295
|
+
if (containsDangerousOperations(expr)) {
|
|
296
|
+
return false
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
return true
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
/**
|
|
304
|
+
* Check if a sed command has file arguments (not just stdin)
|
|
305
|
+
* @internal Exported for testing
|
|
306
|
+
*/
|
|
307
|
+
export function hasFileArgs(command: string): boolean {
|
|
308
|
+
const sedMatch = command.match(/^\s*sed\s+/)
|
|
309
|
+
if (!sedMatch) return false
|
|
310
|
+
|
|
311
|
+
const withoutSed = command.slice(sedMatch[0].length)
|
|
312
|
+
const parseResult = tryParseShellCommand(withoutSed)
|
|
313
|
+
if (!parseResult.success) return true
|
|
314
|
+
const parsed = parseResult.tokens
|
|
315
|
+
|
|
316
|
+
try {
|
|
317
|
+
let argCount = 0
|
|
318
|
+
let hasEFlag = false
|
|
319
|
+
|
|
320
|
+
for (let i = 0; i < parsed.length; i++) {
|
|
321
|
+
const arg = parsed[i]
|
|
322
|
+
|
|
323
|
+
// Handle both string arguments and glob patterns (like *.log)
|
|
324
|
+
if (typeof arg !== 'string' && typeof arg !== 'object') continue
|
|
325
|
+
|
|
326
|
+
// If it's a glob pattern, it counts as a file argument
|
|
327
|
+
if (
|
|
328
|
+
typeof arg === 'object' &&
|
|
329
|
+
arg !== null &&
|
|
330
|
+
'op' in arg &&
|
|
331
|
+
arg.op === 'glob'
|
|
332
|
+
) {
|
|
333
|
+
return true
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
// Skip non-string arguments that aren't glob patterns
|
|
337
|
+
if (typeof arg !== 'string') continue
|
|
338
|
+
|
|
339
|
+
// Handle -e flag followed by expression
|
|
340
|
+
if ((arg === '-e' || arg === '--expression') && i + 1 < parsed.length) {
|
|
341
|
+
hasEFlag = true
|
|
342
|
+
i++ // Skip the next argument since it's the expression
|
|
343
|
+
continue
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
// Handle --expression=value format
|
|
347
|
+
if (arg.startsWith('--expression=')) {
|
|
348
|
+
hasEFlag = true
|
|
349
|
+
continue
|
|
350
|
+
}
|
|
351
|
+
|
|
352
|
+
// Handle -e=value format (non-standard but defense in depth)
|
|
353
|
+
if (arg.startsWith('-e=')) {
|
|
354
|
+
hasEFlag = true
|
|
355
|
+
continue
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
// Skip other flags
|
|
359
|
+
if (arg.startsWith('-')) continue
|
|
360
|
+
|
|
361
|
+
argCount++
|
|
362
|
+
|
|
363
|
+
// If we used -e flags, ALL non-flag arguments are file arguments
|
|
364
|
+
if (hasEFlag) {
|
|
365
|
+
return true
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
// If we didn't use -e flags, the first non-flag argument is the sed expression,
|
|
369
|
+
// so we need more than 1 non-flag argument to have file arguments
|
|
370
|
+
if (argCount > 1) {
|
|
371
|
+
return true
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
return false
|
|
376
|
+
} catch (_error) {
|
|
377
|
+
return true // Assume dangerous if parsing fails
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
|
|
381
|
+
/**
|
|
382
|
+
* Extract sed expressions from command, ignoring flags and filenames
|
|
383
|
+
* @param command Full sed command
|
|
384
|
+
* @returns Array of sed expressions to check for dangerous operations
|
|
385
|
+
* @throws Error if parsing fails
|
|
386
|
+
* @internal Exported for testing
|
|
387
|
+
*/
|
|
388
|
+
export function extractSedExpressions(command: string): string[] {
|
|
389
|
+
const expressions: string[] = []
|
|
390
|
+
|
|
391
|
+
// Calculate withoutSed by trimming off the first N characters (removing 'sed ')
|
|
392
|
+
const sedMatch = command.match(/^\s*sed\s+/)
|
|
393
|
+
if (!sedMatch) return expressions
|
|
394
|
+
|
|
395
|
+
const withoutSed = command.slice(sedMatch[0].length)
|
|
396
|
+
|
|
397
|
+
// Reject dangerous flag combinations like -ew, -eW, -ee, -we (combined -e/-w with dangerous commands)
|
|
398
|
+
if (/-e[wWe]/.test(withoutSed) || /-w[eE]/.test(withoutSed)) {
|
|
399
|
+
throw new Error('Dangerous flag combination detected')
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
// Use shell-quote to parse the arguments properly
|
|
403
|
+
const parseResult = tryParseShellCommand(withoutSed)
|
|
404
|
+
if (!parseResult.success) {
|
|
405
|
+
// Malformed shell syntax - throw error to be caught by caller
|
|
406
|
+
throw new Error(`Malformed shell syntax: ${parseResult.error}`)
|
|
407
|
+
}
|
|
408
|
+
const parsed = parseResult.tokens
|
|
409
|
+
try {
|
|
410
|
+
let foundEFlag = false
|
|
411
|
+
let foundExpression = false
|
|
412
|
+
|
|
413
|
+
for (let i = 0; i < parsed.length; i++) {
|
|
414
|
+
const arg = parsed[i]
|
|
415
|
+
|
|
416
|
+
// Skip non-string arguments (like control operators)
|
|
417
|
+
if (typeof arg !== 'string') continue
|
|
418
|
+
|
|
419
|
+
// Handle -e flag followed by expression
|
|
420
|
+
if ((arg === '-e' || arg === '--expression') && i + 1 < parsed.length) {
|
|
421
|
+
foundEFlag = true
|
|
422
|
+
const nextArg = parsed[i + 1]
|
|
423
|
+
if (typeof nextArg === 'string') {
|
|
424
|
+
expressions.push(nextArg)
|
|
425
|
+
i++ // Skip the next argument since we consumed it
|
|
426
|
+
}
|
|
427
|
+
continue
|
|
428
|
+
}
|
|
429
|
+
|
|
430
|
+
// Handle --expression=value format
|
|
431
|
+
if (arg.startsWith('--expression=')) {
|
|
432
|
+
foundEFlag = true
|
|
433
|
+
expressions.push(arg.slice('--expression='.length))
|
|
434
|
+
continue
|
|
435
|
+
}
|
|
436
|
+
|
|
437
|
+
// Handle -e=value format (non-standard but defense in depth)
|
|
438
|
+
if (arg.startsWith('-e=')) {
|
|
439
|
+
foundEFlag = true
|
|
440
|
+
expressions.push(arg.slice('-e='.length))
|
|
441
|
+
continue
|
|
442
|
+
}
|
|
443
|
+
|
|
444
|
+
// Skip other flags
|
|
445
|
+
if (arg.startsWith('-')) continue
|
|
446
|
+
|
|
447
|
+
// If we haven't found any -e flags, the first non-flag argument is the sed expression
|
|
448
|
+
if (!foundEFlag && !foundExpression) {
|
|
449
|
+
expressions.push(arg)
|
|
450
|
+
foundExpression = true
|
|
451
|
+
continue
|
|
452
|
+
}
|
|
453
|
+
|
|
454
|
+
// If we've already found -e flags or a standalone expression,
|
|
455
|
+
// remaining non-flag arguments are filenames
|
|
456
|
+
break
|
|
457
|
+
}
|
|
458
|
+
} catch (error) {
|
|
459
|
+
// If shell-quote parsing fails, treat the sed command as unsafe
|
|
460
|
+
throw new Error(
|
|
461
|
+
`Failed to parse sed command: ${error instanceof Error ? error.message : 'Unknown error'}`,
|
|
462
|
+
)
|
|
463
|
+
}
|
|
464
|
+
|
|
465
|
+
return expressions
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
/**
|
|
469
|
+
* Check if a sed expression contains dangerous operations (denylist)
|
|
470
|
+
* @param expression Single sed expression (without quotes)
|
|
471
|
+
* @returns true if dangerous, false if safe
|
|
472
|
+
*/
|
|
473
|
+
function containsDangerousOperations(expression: string): boolean {
|
|
474
|
+
const cmd = expression.trim()
|
|
475
|
+
if (!cmd) return false
|
|
476
|
+
|
|
477
|
+
// CONSERVATIVE REJECTIONS: Broadly reject patterns that could be dangerous
|
|
478
|
+
// When in doubt, treat as unsafe
|
|
479
|
+
|
|
480
|
+
// Reject non-ASCII characters (Unicode homoglyphs, combining chars, etc.)
|
|
481
|
+
// Examples: w (fullwidth), ᴡ (small capital), w̃ (combining tilde)
|
|
482
|
+
// Check for characters outside ASCII range (0x01-0x7F, excluding null byte)
|
|
483
|
+
// eslint-disable-next-line no-control-regex
|
|
484
|
+
if (/[^\x01-\x7F]/.test(cmd)) {
|
|
485
|
+
return true
|
|
486
|
+
}
|
|
487
|
+
|
|
488
|
+
// Reject curly braces (blocks) - too complex to parse
|
|
489
|
+
if (cmd.includes('{') || cmd.includes('}')) {
|
|
490
|
+
return true
|
|
491
|
+
}
|
|
492
|
+
|
|
493
|
+
// Reject newlines - multi-line commands are too complex
|
|
494
|
+
if (cmd.includes('\n')) {
|
|
495
|
+
return true
|
|
496
|
+
}
|
|
497
|
+
|
|
498
|
+
// Reject comments (# not immediately after s command)
|
|
499
|
+
// Comments look like: #comment or start with #
|
|
500
|
+
// Delimiter looks like: s#pattern#replacement#
|
|
501
|
+
const hashIndex = cmd.indexOf('#')
|
|
502
|
+
if (hashIndex !== -1 && !(hashIndex > 0 && cmd[hashIndex - 1] === 's')) {
|
|
503
|
+
return true
|
|
504
|
+
}
|
|
505
|
+
|
|
506
|
+
// Reject negation operator
|
|
507
|
+
// Negation can appear: at start (!/pattern/), after address (/pattern/!, 1,10!, $!)
|
|
508
|
+
// Delimiter looks like: s!pattern!replacement! (has 's' before it)
|
|
509
|
+
if (/^!/.test(cmd) || /[/\d$]!/.test(cmd)) {
|
|
510
|
+
return true
|
|
511
|
+
}
|
|
512
|
+
|
|
513
|
+
// Reject tilde in GNU step address format (digit~digit, ,~digit, or $~digit)
|
|
514
|
+
// Allow whitespace around tilde
|
|
515
|
+
if (/\d\s*~\s*\d|,\s*~\s*\d|\$\s*~\s*\d/.test(cmd)) {
|
|
516
|
+
return true
|
|
517
|
+
}
|
|
518
|
+
|
|
519
|
+
// Reject comma at start (bare comma is shorthand for 1,$ address range)
|
|
520
|
+
if (/^,/.test(cmd)) {
|
|
521
|
+
return true
|
|
522
|
+
}
|
|
523
|
+
|
|
524
|
+
// Reject comma followed by +/- (GNU offset addresses)
|
|
525
|
+
if (/,\s*[+-]/.test(cmd)) {
|
|
526
|
+
return true
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
// Reject backslash tricks:
|
|
530
|
+
// 1. s\ (substitution with backslash delimiter)
|
|
531
|
+
// 2. \X where X could be an alternate delimiter (|, #, %, etc.) - not regex escapes
|
|
532
|
+
if (/s\\/.test(cmd) || /\\[|#%@]/.test(cmd)) {
|
|
533
|
+
return true
|
|
534
|
+
}
|
|
535
|
+
|
|
536
|
+
// Reject escaped slashes followed by w/W (patterns like /\/path\/to\/file/w)
|
|
537
|
+
if (/\\\/.*[wW]/.test(cmd)) {
|
|
538
|
+
return true
|
|
539
|
+
}
|
|
540
|
+
|
|
541
|
+
// Reject malformed/suspicious patterns we don't understand
|
|
542
|
+
// If there's a slash followed by non-slash chars, then whitespace, then dangerous commands
|
|
543
|
+
// Examples: /pattern w file, /pattern e cmd, /foo X;w file
|
|
544
|
+
if (/\/[^/]*\s+[wWeE]/.test(cmd)) {
|
|
545
|
+
return true
|
|
546
|
+
}
|
|
547
|
+
|
|
548
|
+
// Reject malformed substitution commands that don't follow normal pattern
|
|
549
|
+
// Examples: s/foobareoutput.txt (missing delimiters), s/foo/bar//w (extra delimiter)
|
|
550
|
+
if (/^s\//.test(cmd) && !/^s\/[^/]*\/[^/]*\/[^/]*$/.test(cmd)) {
|
|
551
|
+
return true
|
|
552
|
+
}
|
|
553
|
+
|
|
554
|
+
// PARANOID: Reject any command starting with 's' that ends with dangerous chars (w, W, e, E)
|
|
555
|
+
// and doesn't match our known safe substitution pattern. This catches malformed s commands
|
|
556
|
+
// with non-slash delimiters that might be trying to use dangerous flags.
|
|
557
|
+
if (/^s./.test(cmd) && /[wWeE]$/.test(cmd)) {
|
|
558
|
+
// Check if it's a properly formed substitution (any delimiter, not just /)
|
|
559
|
+
const properSubst = /^s([^\\\n]).*?\1.*?\1[^wWeE]*$/.test(cmd)
|
|
560
|
+
if (!properSubst) {
|
|
561
|
+
return true
|
|
562
|
+
}
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
// Check for dangerous write commands
|
|
566
|
+
// Patterns: [address]w filename, [address]W filename, /pattern/w filename, /pattern/W filename
|
|
567
|
+
// Simplified to avoid exponential backtracking (CodeQL issue)
|
|
568
|
+
// Check for w/W in contexts where it would be a command (with optional whitespace)
|
|
569
|
+
if (
|
|
570
|
+
/^[wW]\s*\S+/.test(cmd) || // At start: w file
|
|
571
|
+
/^\d+\s*[wW]\s*\S+/.test(cmd) || // After line number: 1w file or 1 w file
|
|
572
|
+
/^\$\s*[wW]\s*\S+/.test(cmd) || // After $: $w file or $ w file
|
|
573
|
+
/^\/[^/]*\/[IMim]*\s*[wW]\s*\S+/.test(cmd) || // After pattern: /pattern/w file
|
|
574
|
+
/^\d+,\d+\s*[wW]\s*\S+/.test(cmd) || // After range: 1,10w file
|
|
575
|
+
/^\d+,\$\s*[wW]\s*\S+/.test(cmd) || // After range: 1,$w file
|
|
576
|
+
/^\/[^/]*\/[IMim]*,\/[^/]*\/[IMim]*\s*[wW]\s*\S+/.test(cmd) // After pattern range: /s/,/e/w file
|
|
577
|
+
) {
|
|
578
|
+
return true
|
|
579
|
+
}
|
|
580
|
+
|
|
581
|
+
// Check for dangerous execute commands
|
|
582
|
+
// Patterns: [address]e [command], /pattern/e [command], or commands starting with e
|
|
583
|
+
// Simplified to avoid exponential backtracking (CodeQL issue)
|
|
584
|
+
// Check for e in contexts where it would be a command (with optional whitespace)
|
|
585
|
+
if (
|
|
586
|
+
/^e/.test(cmd) || // At start: e cmd
|
|
587
|
+
/^\d+\s*e/.test(cmd) || // After line number: 1e or 1 e
|
|
588
|
+
/^\$\s*e/.test(cmd) || // After $: $e or $ e
|
|
589
|
+
/^\/[^/]*\/[IMim]*\s*e/.test(cmd) || // After pattern: /pattern/e
|
|
590
|
+
/^\d+,\d+\s*e/.test(cmd) || // After range: 1,10e
|
|
591
|
+
/^\d+,\$\s*e/.test(cmd) || // After range: 1,$e
|
|
592
|
+
/^\/[^/]*\/[IMim]*,\/[^/]*\/[IMim]*\s*e/.test(cmd) // After pattern range: /s/,/e/e
|
|
593
|
+
) {
|
|
594
|
+
return true
|
|
595
|
+
}
|
|
596
|
+
|
|
597
|
+
// Check for substitution commands with dangerous flags
|
|
598
|
+
// Pattern: s<delim>pattern<delim>replacement<delim>flags where flags contain w or e
|
|
599
|
+
// Per POSIX, sed allows any character except backslash and newline as delimiter
|
|
600
|
+
const substitutionMatch = cmd.match(/s([^\\\n]).*?\1.*?\1(.*?)$/)
|
|
601
|
+
if (substitutionMatch) {
|
|
602
|
+
const flags = substitutionMatch[2] || ''
|
|
603
|
+
|
|
604
|
+
// Check for write flag: s/old/new/w filename or s/old/new/gw filename
|
|
605
|
+
if (flags.includes('w') || flags.includes('W')) {
|
|
606
|
+
return true
|
|
607
|
+
}
|
|
608
|
+
|
|
609
|
+
// Check for execute flag: s/old/new/e or s/old/new/ge
|
|
610
|
+
if (flags.includes('e') || flags.includes('E')) {
|
|
611
|
+
return true
|
|
612
|
+
}
|
|
613
|
+
}
|
|
614
|
+
|
|
615
|
+
// Check for y (transliterate) command followed by dangerous operations
|
|
616
|
+
// Pattern: y<delim>source<delim>dest<delim> followed by anything
|
|
617
|
+
// The y command uses same delimiter syntax as s command
|
|
618
|
+
// PARANOID: Reject any y command that has w/W/e/E anywhere after the delimiters
|
|
619
|
+
const yCommandMatch = cmd.match(/y([^\\\n])/)
|
|
620
|
+
if (yCommandMatch) {
|
|
621
|
+
// If we see a y command, check if there's any w, W, e, or E in the entire command
|
|
622
|
+
// This is paranoid but safe - y commands are rare and w/e after y is suspicious
|
|
623
|
+
if (/[wWeE]/.test(cmd)) {
|
|
624
|
+
return true
|
|
625
|
+
}
|
|
626
|
+
}
|
|
627
|
+
|
|
628
|
+
return false
|
|
629
|
+
}
|
|
630
|
+
|
|
631
|
+
/**
|
|
632
|
+
* Cross-cutting validation step for sed commands.
|
|
633
|
+
*
|
|
634
|
+
* This is a constraint check that blocks dangerous sed operations regardless of mode.
|
|
635
|
+
* It returns 'passthrough' for non-sed commands or safe sed commands,
|
|
636
|
+
* and 'ask' for dangerous sed operations (w/W/e/E commands).
|
|
637
|
+
*
|
|
638
|
+
* @param input - Object containing the command string
|
|
639
|
+
* @param toolPermissionContext - Context containing mode and permissions
|
|
640
|
+
* @returns
|
|
641
|
+
* - 'ask' if any sed command contains dangerous operations
|
|
642
|
+
* - 'passthrough' if no sed commands or all are safe
|
|
643
|
+
*/
|
|
644
|
+
export function checkSedConstraints(
|
|
645
|
+
input: { command: string },
|
|
646
|
+
toolPermissionContext: ToolPermissionContext,
|
|
647
|
+
): PermissionResult {
|
|
648
|
+
const commands = splitCommand_DEPRECATED(input.command)
|
|
649
|
+
|
|
650
|
+
for (const cmd of commands) {
|
|
651
|
+
// Skip non-sed commands
|
|
652
|
+
const trimmed = cmd.trim()
|
|
653
|
+
const baseCmd = trimmed.split(/\s+/)[0]
|
|
654
|
+
if (baseCmd !== 'sed') {
|
|
655
|
+
continue
|
|
656
|
+
}
|
|
657
|
+
|
|
658
|
+
// In acceptEdits mode, allow file writes (-i flag) but still block dangerous operations
|
|
659
|
+
const allowFileWrites = toolPermissionContext.mode === 'acceptEdits'
|
|
660
|
+
|
|
661
|
+
const isAllowed = sedCommandIsAllowedByAllowlist(trimmed, {
|
|
662
|
+
allowFileWrites,
|
|
663
|
+
})
|
|
664
|
+
|
|
665
|
+
if (!isAllowed) {
|
|
666
|
+
return {
|
|
667
|
+
behavior: 'ask',
|
|
668
|
+
message:
|
|
669
|
+
'sed command requires approval (contains potentially dangerous operations)',
|
|
670
|
+
decisionReason: {
|
|
671
|
+
type: 'other',
|
|
672
|
+
reason:
|
|
673
|
+
'sed command contains operations that require explicit approval (e.g., write commands, execute commands)',
|
|
674
|
+
},
|
|
675
|
+
}
|
|
676
|
+
}
|
|
677
|
+
}
|
|
678
|
+
|
|
679
|
+
// No dangerous sed commands found (or no sed commands at all)
|
|
680
|
+
return {
|
|
681
|
+
behavior: 'passthrough',
|
|
682
|
+
message: 'No dangerous sed operations detected',
|
|
683
|
+
}
|
|
684
|
+
}
|