@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,1532 @@
|
|
|
1
|
+
import { feature } from 'bun:bundle'
|
|
2
|
+
import { relative } from 'path'
|
|
3
|
+
import {
|
|
4
|
+
getOriginalCwd,
|
|
5
|
+
handleAutoModeTransition,
|
|
6
|
+
handlePlanModeTransition,
|
|
7
|
+
setHasExitedPlanMode,
|
|
8
|
+
setNeedsAutoModeExitAttachment,
|
|
9
|
+
} from '../../bootstrap/state.js'
|
|
10
|
+
import type {
|
|
11
|
+
ToolPermissionContext,
|
|
12
|
+
ToolPermissionRulesBySource,
|
|
13
|
+
} from '../../Tool.js'
|
|
14
|
+
import { getCwd } from '../cwd.js'
|
|
15
|
+
import { isEnvTruthy } from '../envUtils.js'
|
|
16
|
+
import type { SettingSource } from '../settings/constants.js'
|
|
17
|
+
import { SETTING_SOURCES } from '../settings/constants.js'
|
|
18
|
+
import {
|
|
19
|
+
getSettings_DEPRECATED,
|
|
20
|
+
getSettingsFilePathForSource,
|
|
21
|
+
getUseAutoModeDuringPlan,
|
|
22
|
+
hasAutoModeOptIn,
|
|
23
|
+
} from '../settings/settings.js'
|
|
24
|
+
import {
|
|
25
|
+
type PermissionMode,
|
|
26
|
+
permissionModeFromString,
|
|
27
|
+
} from './PermissionMode.js'
|
|
28
|
+
import { applyPermissionRulesToPermissionContext } from './permissions.js'
|
|
29
|
+
import { loadAllPermissionRulesFromDisk } from './permissionsLoader.js'
|
|
30
|
+
|
|
31
|
+
/* eslint-disable @typescript-eslint/no-require-imports */
|
|
32
|
+
const autoModeStateModule = feature('TRANSCRIPT_CLASSIFIER')
|
|
33
|
+
? (require('./autoModeState.js') as typeof import('./autoModeState.js'))
|
|
34
|
+
: null
|
|
35
|
+
|
|
36
|
+
import { resolve } from 'path'
|
|
37
|
+
import {
|
|
38
|
+
checkSecurityRestrictionGate,
|
|
39
|
+
checkStatsigFeatureGate_CACHED_MAY_BE_STALE,
|
|
40
|
+
getDynamicConfig_BLOCKS_ON_INIT,
|
|
41
|
+
getFeatureValue_CACHED_MAY_BE_STALE,
|
|
42
|
+
} from 'src/services/analytics/growthbook.js'
|
|
43
|
+
import {
|
|
44
|
+
addDirHelpMessage,
|
|
45
|
+
validateDirectoryForWorkspace,
|
|
46
|
+
} from '../../commands/add-dir/validation.js'
|
|
47
|
+
import {
|
|
48
|
+
type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
49
|
+
logEvent,
|
|
50
|
+
} from '../../services/analytics/index.js'
|
|
51
|
+
import { AGENT_TOOL_NAME } from '../../tools/AgentTool/constants.js'
|
|
52
|
+
import { BASH_TOOL_NAME } from '../../tools/BashTool/toolName.js'
|
|
53
|
+
/* eslint-enable @typescript-eslint/no-require-imports */
|
|
54
|
+
import { POWERSHELL_TOOL_NAME } from '../../tools/PowerShellTool/toolName.js'
|
|
55
|
+
import { getToolsForDefaultPreset, parseToolPreset } from '../../tools.js'
|
|
56
|
+
import {
|
|
57
|
+
getFsImplementation,
|
|
58
|
+
safeResolvePath,
|
|
59
|
+
} from '../../utils/fsOperations.js'
|
|
60
|
+
import { modelSupportsAutoMode } from '../betas.js'
|
|
61
|
+
import { logForDebugging } from '../debug.js'
|
|
62
|
+
import { gracefulShutdown } from '../gracefulShutdown.js'
|
|
63
|
+
import { getMainLoopModel } from '../model/model.js'
|
|
64
|
+
import {
|
|
65
|
+
CROSS_PLATFORM_CODE_EXEC,
|
|
66
|
+
DANGEROUS_BASH_PATTERNS,
|
|
67
|
+
} from './dangerousPatterns.js'
|
|
68
|
+
import type {
|
|
69
|
+
PermissionRule,
|
|
70
|
+
PermissionRuleSource,
|
|
71
|
+
PermissionRuleValue,
|
|
72
|
+
} from './PermissionRule.js'
|
|
73
|
+
import {
|
|
74
|
+
type AdditionalWorkingDirectory,
|
|
75
|
+
applyPermissionUpdate,
|
|
76
|
+
} from './PermissionUpdate.js'
|
|
77
|
+
import type { PermissionUpdateDestination } from './PermissionUpdateSchema.js'
|
|
78
|
+
import {
|
|
79
|
+
normalizeLegacyToolName,
|
|
80
|
+
permissionRuleValueFromString,
|
|
81
|
+
permissionRuleValueToString,
|
|
82
|
+
} from './permissionRuleParser.js'
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* Checks if a Bash permission rule is dangerous for auto mode.
|
|
86
|
+
* A rule is dangerous if it would auto-allow commands that execute arbitrary code,
|
|
87
|
+
* bypassing the classifier's safety evaluation.
|
|
88
|
+
*
|
|
89
|
+
* Dangerous patterns:
|
|
90
|
+
* 1. Tool-level allow (Bash with no ruleContent) - allows ALL commands
|
|
91
|
+
* 2. Prefix rules for script interpreters (python:*, node:*, etc.)
|
|
92
|
+
* 3. Wildcard rules matching interpreters (python*, node*, etc.)
|
|
93
|
+
*/
|
|
94
|
+
export function isDangerousBashPermission(
|
|
95
|
+
toolName: string,
|
|
96
|
+
ruleContent: string | undefined,
|
|
97
|
+
): boolean {
|
|
98
|
+
// Only check Bash rules
|
|
99
|
+
if (toolName !== BASH_TOOL_NAME) {
|
|
100
|
+
return false
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
// Tool-level allow (Bash with no content, or Bash(*)) - allows ALL commands
|
|
104
|
+
if (ruleContent === undefined || ruleContent === '') {
|
|
105
|
+
return true
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const content = ruleContent.trim().toLowerCase()
|
|
109
|
+
|
|
110
|
+
// Standalone wildcard (*) matches everything
|
|
111
|
+
if (content === '*') {
|
|
112
|
+
return true
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
// Check for dangerous patterns with prefix syntax (e.g., "python:*")
|
|
116
|
+
// or wildcard syntax (e.g., "python*")
|
|
117
|
+
for (const pattern of DANGEROUS_BASH_PATTERNS) {
|
|
118
|
+
const lowerPattern = pattern.toLowerCase()
|
|
119
|
+
|
|
120
|
+
// Exact match to the pattern itself (e.g., "python" as a rule)
|
|
121
|
+
if (content === lowerPattern) {
|
|
122
|
+
return true
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// Prefix syntax: "python:*" allows any python command
|
|
126
|
+
if (content === `${lowerPattern}:*`) {
|
|
127
|
+
return true
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
// Wildcard at end: "python*" matches python, python3, etc.
|
|
131
|
+
if (content === `${lowerPattern}*`) {
|
|
132
|
+
return true
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// Wildcard with space: "python *" would match "python script.py"
|
|
136
|
+
if (content === `${lowerPattern} *`) {
|
|
137
|
+
return true
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
// Check for patterns like "python -*" which would match "python -c 'code'"
|
|
141
|
+
if (content.startsWith(`${lowerPattern} -`) && content.endsWith('*')) {
|
|
142
|
+
return true
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
return false
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
/**
|
|
150
|
+
* Checks if a PowerShell permission rule is dangerous for auto mode.
|
|
151
|
+
* A rule is dangerous if it would auto-allow commands that execute arbitrary
|
|
152
|
+
* code (nested shells, Invoke-Expression, Start-Process, etc.), bypassing the
|
|
153
|
+
* classifier's safety evaluation.
|
|
154
|
+
*
|
|
155
|
+
* PowerShell is case-insensitive, so rule content is lowercased before matching.
|
|
156
|
+
*/
|
|
157
|
+
export function isDangerousPowerShellPermission(
|
|
158
|
+
toolName: string,
|
|
159
|
+
ruleContent: string | undefined,
|
|
160
|
+
): boolean {
|
|
161
|
+
if (toolName !== POWERSHELL_TOOL_NAME) {
|
|
162
|
+
return false
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
// Tool-level allow (PowerShell with no content, or PowerShell(*)) - allows ALL commands
|
|
166
|
+
if (ruleContent === undefined || ruleContent === '') {
|
|
167
|
+
return true
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
const content = ruleContent.trim().toLowerCase()
|
|
171
|
+
|
|
172
|
+
// Standalone wildcard (*) matches everything
|
|
173
|
+
if (content === '*') {
|
|
174
|
+
return true
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
// PS-specific cmdlet names. CROSS_PLATFORM_CODE_EXEC is shared with bash.
|
|
178
|
+
const patterns: readonly string[] = [
|
|
179
|
+
...CROSS_PLATFORM_CODE_EXEC,
|
|
180
|
+
// Nested PS + shells launchable from PS
|
|
181
|
+
'pwsh',
|
|
182
|
+
'powershell',
|
|
183
|
+
'cmd',
|
|
184
|
+
'wsl',
|
|
185
|
+
// String/scriptblock evaluators
|
|
186
|
+
'iex',
|
|
187
|
+
'invoke-expression',
|
|
188
|
+
'icm',
|
|
189
|
+
'invoke-command',
|
|
190
|
+
// Process spawners
|
|
191
|
+
'start-process',
|
|
192
|
+
'saps',
|
|
193
|
+
'start',
|
|
194
|
+
'start-job',
|
|
195
|
+
'sajb',
|
|
196
|
+
'start-threadjob', // bundled PS 6.1+; takes -ScriptBlock like Start-Job
|
|
197
|
+
// Event/session code exec
|
|
198
|
+
'register-objectevent',
|
|
199
|
+
'register-engineevent',
|
|
200
|
+
'register-wmievent',
|
|
201
|
+
'register-scheduledjob',
|
|
202
|
+
'new-pssession',
|
|
203
|
+
'nsn', // alias
|
|
204
|
+
'enter-pssession',
|
|
205
|
+
'etsn', // alias
|
|
206
|
+
// .NET escape hatches
|
|
207
|
+
'add-type', // Add-Type -TypeDefinition '<C#>' → P/Invoke
|
|
208
|
+
'new-object', // New-Object -ComObject WScript.Shell → .Run()
|
|
209
|
+
]
|
|
210
|
+
|
|
211
|
+
for (const pattern of patterns) {
|
|
212
|
+
// patterns stored lowercase; content lowercased above
|
|
213
|
+
if (content === pattern) return true
|
|
214
|
+
if (content === `${pattern}:*`) return true
|
|
215
|
+
if (content === `${pattern}*`) return true
|
|
216
|
+
if (content === `${pattern} *`) return true
|
|
217
|
+
if (content.startsWith(`${pattern} -`) && content.endsWith('*')) return true
|
|
218
|
+
// .exe — goes on the FIRST word. `python` → `python.exe`.
|
|
219
|
+
// `npm run` → `npm.exe run` (npm.exe is the real Windows binary name).
|
|
220
|
+
// A rule like `PowerShell(npm.exe run:*)` needs to match `npm run`.
|
|
221
|
+
const sp = pattern.indexOf(' ')
|
|
222
|
+
const exe =
|
|
223
|
+
sp === -1
|
|
224
|
+
? `${pattern}.exe`
|
|
225
|
+
: `${pattern.slice(0, sp)}.exe${pattern.slice(sp)}`
|
|
226
|
+
if (content === exe) return true
|
|
227
|
+
if (content === `${exe}:*`) return true
|
|
228
|
+
if (content === `${exe}*`) return true
|
|
229
|
+
if (content === `${exe} *`) return true
|
|
230
|
+
if (content.startsWith(`${exe} -`) && content.endsWith('*')) return true
|
|
231
|
+
}
|
|
232
|
+
return false
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
/**
|
|
236
|
+
* Checks if an Agent (sub-agent) permission rule is dangerous for auto mode.
|
|
237
|
+
* Any Agent allow rule would auto-approve sub-agent spawns before the auto mode classifier
|
|
238
|
+
* can evaluate the sub-agent's prompt, defeating delegation attack prevention.
|
|
239
|
+
*/
|
|
240
|
+
export function isDangerousTaskPermission(
|
|
241
|
+
toolName: string,
|
|
242
|
+
_ruleContent: string | undefined,
|
|
243
|
+
): boolean {
|
|
244
|
+
return normalizeLegacyToolName(toolName) === AGENT_TOOL_NAME
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
function formatPermissionSource(source: PermissionRuleSource): string {
|
|
248
|
+
if ((SETTING_SOURCES as readonly string[]).includes(source)) {
|
|
249
|
+
const filePath = getSettingsFilePathForSource(source as SettingSource)
|
|
250
|
+
if (filePath) {
|
|
251
|
+
const relativePath = relative(getCwd(), filePath)
|
|
252
|
+
return relativePath.length < filePath.length ? relativePath : filePath
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
return source
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
export type DangerousPermissionInfo = {
|
|
259
|
+
ruleValue: PermissionRuleValue
|
|
260
|
+
source: PermissionRuleSource
|
|
261
|
+
/** The permission rule formatted for display, e.g. "Bash(*)" or "Bash(python:*)" */
|
|
262
|
+
ruleDisplay: string
|
|
263
|
+
/** The source formatted for display, e.g. a file path or "--allowed-tools" */
|
|
264
|
+
sourceDisplay: string
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
/**
|
|
268
|
+
* Checks if a permission rule is dangerous for auto mode.
|
|
269
|
+
* A rule is dangerous if it would auto-allow actions before the auto mode classifier
|
|
270
|
+
* can evaluate them, bypassing safety checks.
|
|
271
|
+
*/
|
|
272
|
+
function isDangerousClassifierPermission(
|
|
273
|
+
toolName: string,
|
|
274
|
+
ruleContent: string | undefined,
|
|
275
|
+
): boolean {
|
|
276
|
+
if (process.env.USER_TYPE === 'ant') {
|
|
277
|
+
// Tmux send-keys executes arbitrary shell, bypassing the classifier same as Bash(*)
|
|
278
|
+
if (toolName === 'Tmux') return true
|
|
279
|
+
}
|
|
280
|
+
return (
|
|
281
|
+
isDangerousBashPermission(toolName, ruleContent) ||
|
|
282
|
+
isDangerousPowerShellPermission(toolName, ruleContent) ||
|
|
283
|
+
isDangerousTaskPermission(toolName, ruleContent)
|
|
284
|
+
)
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
/**
|
|
288
|
+
* Finds all dangerous permissions from rules loaded from disk and CLI arguments.
|
|
289
|
+
* Returns structured info about each dangerous permission found.
|
|
290
|
+
*
|
|
291
|
+
* Checks Bash permissions (wildcard/interpreter patterns), PowerShell permissions
|
|
292
|
+
* (wildcard/iex/Start-Process patterns), and Agent permissions (any allow rule
|
|
293
|
+
* bypasses the classifier's sub-agent evaluation).
|
|
294
|
+
*/
|
|
295
|
+
export function findDangerousClassifierPermissions(
|
|
296
|
+
rules: PermissionRule[],
|
|
297
|
+
cliAllowedTools: string[],
|
|
298
|
+
): DangerousPermissionInfo[] {
|
|
299
|
+
const dangerous: DangerousPermissionInfo[] = []
|
|
300
|
+
|
|
301
|
+
// Check rules loaded from settings
|
|
302
|
+
for (const rule of rules) {
|
|
303
|
+
if (
|
|
304
|
+
rule.ruleBehavior === 'allow' &&
|
|
305
|
+
isDangerousClassifierPermission(
|
|
306
|
+
rule.ruleValue.toolName,
|
|
307
|
+
rule.ruleValue.ruleContent,
|
|
308
|
+
)
|
|
309
|
+
) {
|
|
310
|
+
const ruleString = rule.ruleValue.ruleContent
|
|
311
|
+
? `${rule.ruleValue.toolName}(${rule.ruleValue.ruleContent})`
|
|
312
|
+
: `${rule.ruleValue.toolName}(*)`
|
|
313
|
+
dangerous.push({
|
|
314
|
+
ruleValue: rule.ruleValue,
|
|
315
|
+
source: rule.source,
|
|
316
|
+
ruleDisplay: ruleString,
|
|
317
|
+
sourceDisplay: formatPermissionSource(rule.source),
|
|
318
|
+
})
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
// Check CLI --allowed-tools arguments
|
|
323
|
+
for (const toolSpec of cliAllowedTools) {
|
|
324
|
+
// Parse tool spec: "Bash" or "Bash(pattern)" or "Agent" or "Agent(subagent_type)"
|
|
325
|
+
const match = toolSpec.match(/^([^(]+)(?:\(([^)]*)\))?$/)
|
|
326
|
+
if (match) {
|
|
327
|
+
const toolName = match[1]!.trim()
|
|
328
|
+
const ruleContent = match[2]?.trim()
|
|
329
|
+
|
|
330
|
+
if (isDangerousClassifierPermission(toolName, ruleContent)) {
|
|
331
|
+
dangerous.push({
|
|
332
|
+
ruleValue: { toolName, ruleContent },
|
|
333
|
+
source: 'cliArg',
|
|
334
|
+
ruleDisplay: ruleContent ? toolSpec : `${toolName}(*)`,
|
|
335
|
+
sourceDisplay: '--allowed-tools',
|
|
336
|
+
})
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
|
|
341
|
+
return dangerous
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
/**
|
|
345
|
+
* Checks if a Bash allow rule is overly broad (equivalent to YOLO mode).
|
|
346
|
+
* Returns true for tool-level Bash allow rules with no content restriction,
|
|
347
|
+
* which auto-allow every bash command.
|
|
348
|
+
*
|
|
349
|
+
* Matches: Bash, Bash(*), Bash() — all parse to { toolName: 'Bash' } with no ruleContent.
|
|
350
|
+
*/
|
|
351
|
+
export function isOverlyBroadBashAllowRule(
|
|
352
|
+
ruleValue: PermissionRuleValue,
|
|
353
|
+
): boolean {
|
|
354
|
+
return (
|
|
355
|
+
ruleValue.toolName === BASH_TOOL_NAME && ruleValue.ruleContent === undefined
|
|
356
|
+
)
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
/**
|
|
360
|
+
* PowerShell equivalent of isOverlyBroadBashAllowRule.
|
|
361
|
+
*
|
|
362
|
+
* Matches: PowerShell, PowerShell(*), PowerShell() — all parse to
|
|
363
|
+
* { toolName: 'PowerShell' } with no ruleContent.
|
|
364
|
+
*/
|
|
365
|
+
export function isOverlyBroadPowerShellAllowRule(
|
|
366
|
+
ruleValue: PermissionRuleValue,
|
|
367
|
+
): boolean {
|
|
368
|
+
return (
|
|
369
|
+
ruleValue.toolName === POWERSHELL_TOOL_NAME &&
|
|
370
|
+
ruleValue.ruleContent === undefined
|
|
371
|
+
)
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
/**
|
|
375
|
+
* Finds all overly broad Bash allow rules from settings and CLI arguments.
|
|
376
|
+
* An overly broad rule allows ALL bash commands (e.g., Bash or Bash(*)),
|
|
377
|
+
* which is effectively equivalent to YOLO/bypass-permissions mode.
|
|
378
|
+
*/
|
|
379
|
+
export function findOverlyBroadBashPermissions(
|
|
380
|
+
rules: PermissionRule[],
|
|
381
|
+
cliAllowedTools: string[],
|
|
382
|
+
): DangerousPermissionInfo[] {
|
|
383
|
+
const overlyBroad: DangerousPermissionInfo[] = []
|
|
384
|
+
|
|
385
|
+
for (const rule of rules) {
|
|
386
|
+
if (
|
|
387
|
+
rule.ruleBehavior === 'allow' &&
|
|
388
|
+
isOverlyBroadBashAllowRule(rule.ruleValue)
|
|
389
|
+
) {
|
|
390
|
+
overlyBroad.push({
|
|
391
|
+
ruleValue: rule.ruleValue,
|
|
392
|
+
source: rule.source,
|
|
393
|
+
ruleDisplay: `${BASH_TOOL_NAME}(*)`,
|
|
394
|
+
sourceDisplay: formatPermissionSource(rule.source),
|
|
395
|
+
})
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
for (const toolSpec of cliAllowedTools) {
|
|
400
|
+
const parsed = permissionRuleValueFromString(toolSpec)
|
|
401
|
+
if (isOverlyBroadBashAllowRule(parsed)) {
|
|
402
|
+
overlyBroad.push({
|
|
403
|
+
ruleValue: parsed,
|
|
404
|
+
source: 'cliArg',
|
|
405
|
+
ruleDisplay: `${BASH_TOOL_NAME}(*)`,
|
|
406
|
+
sourceDisplay: '--allowed-tools',
|
|
407
|
+
})
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
return overlyBroad
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
/**
|
|
415
|
+
* PowerShell equivalent of findOverlyBroadBashPermissions.
|
|
416
|
+
*/
|
|
417
|
+
export function findOverlyBroadPowerShellPermissions(
|
|
418
|
+
rules: PermissionRule[],
|
|
419
|
+
cliAllowedTools: string[],
|
|
420
|
+
): DangerousPermissionInfo[] {
|
|
421
|
+
const overlyBroad: DangerousPermissionInfo[] = []
|
|
422
|
+
|
|
423
|
+
for (const rule of rules) {
|
|
424
|
+
if (
|
|
425
|
+
rule.ruleBehavior === 'allow' &&
|
|
426
|
+
isOverlyBroadPowerShellAllowRule(rule.ruleValue)
|
|
427
|
+
) {
|
|
428
|
+
overlyBroad.push({
|
|
429
|
+
ruleValue: rule.ruleValue,
|
|
430
|
+
source: rule.source,
|
|
431
|
+
ruleDisplay: `${POWERSHELL_TOOL_NAME}(*)`,
|
|
432
|
+
sourceDisplay: formatPermissionSource(rule.source),
|
|
433
|
+
})
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
|
|
437
|
+
for (const toolSpec of cliAllowedTools) {
|
|
438
|
+
const parsed = permissionRuleValueFromString(toolSpec)
|
|
439
|
+
if (isOverlyBroadPowerShellAllowRule(parsed)) {
|
|
440
|
+
overlyBroad.push({
|
|
441
|
+
ruleValue: parsed,
|
|
442
|
+
source: 'cliArg',
|
|
443
|
+
ruleDisplay: `${POWERSHELL_TOOL_NAME}(*)`,
|
|
444
|
+
sourceDisplay: '--allowed-tools',
|
|
445
|
+
})
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
return overlyBroad
|
|
450
|
+
}
|
|
451
|
+
|
|
452
|
+
/**
|
|
453
|
+
* Type guard to check if a PermissionRuleSource is a valid PermissionUpdateDestination.
|
|
454
|
+
* Sources like 'flagSettings', 'policySettings', and 'command' are not valid destinations.
|
|
455
|
+
*/
|
|
456
|
+
function isPermissionUpdateDestination(
|
|
457
|
+
source: PermissionRuleSource,
|
|
458
|
+
): source is PermissionUpdateDestination {
|
|
459
|
+
return [
|
|
460
|
+
'userSettings',
|
|
461
|
+
'projectSettings',
|
|
462
|
+
'localSettings',
|
|
463
|
+
'session',
|
|
464
|
+
'cliArg',
|
|
465
|
+
].includes(source)
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
/**
|
|
469
|
+
* Removes dangerous permissions from the in-memory context, and optionally
|
|
470
|
+
* persists the removal to settings files on disk.
|
|
471
|
+
*/
|
|
472
|
+
export function removeDangerousPermissions(
|
|
473
|
+
context: ToolPermissionContext,
|
|
474
|
+
dangerousPermissions: DangerousPermissionInfo[],
|
|
475
|
+
): ToolPermissionContext {
|
|
476
|
+
// Group dangerous rules by their source (destination for updates)
|
|
477
|
+
const rulesBySource = new Map<
|
|
478
|
+
PermissionUpdateDestination,
|
|
479
|
+
PermissionRuleValue[]
|
|
480
|
+
>()
|
|
481
|
+
for (const perm of dangerousPermissions) {
|
|
482
|
+
// Skip sources that can't be persisted (flagSettings, policySettings, command)
|
|
483
|
+
if (!isPermissionUpdateDestination(perm.source)) {
|
|
484
|
+
continue
|
|
485
|
+
}
|
|
486
|
+
const destination = perm.source
|
|
487
|
+
const existing = rulesBySource.get(destination) || []
|
|
488
|
+
existing.push(perm.ruleValue)
|
|
489
|
+
rulesBySource.set(destination, existing)
|
|
490
|
+
}
|
|
491
|
+
|
|
492
|
+
let updatedContext = context
|
|
493
|
+
for (const [destination, rules] of rulesBySource) {
|
|
494
|
+
updatedContext = applyPermissionUpdate(updatedContext, {
|
|
495
|
+
type: 'removeRules' as const,
|
|
496
|
+
rules,
|
|
497
|
+
behavior: 'allow' as const,
|
|
498
|
+
destination,
|
|
499
|
+
})
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
return updatedContext
|
|
503
|
+
}
|
|
504
|
+
|
|
505
|
+
/**
|
|
506
|
+
* Prepares a ToolPermissionContext for auto mode by stripping
|
|
507
|
+
* dangerous permissions that would bypass the classifier.
|
|
508
|
+
* Returns the cleaned context (with mode unchanged — caller sets the mode).
|
|
509
|
+
*/
|
|
510
|
+
export function stripDangerousPermissionsForAutoMode(
|
|
511
|
+
context: ToolPermissionContext,
|
|
512
|
+
): ToolPermissionContext {
|
|
513
|
+
const rules: PermissionRule[] = []
|
|
514
|
+
for (const [source, ruleStrings] of Object.entries(
|
|
515
|
+
context.alwaysAllowRules,
|
|
516
|
+
)) {
|
|
517
|
+
if (!ruleStrings) {
|
|
518
|
+
continue
|
|
519
|
+
}
|
|
520
|
+
for (const ruleString of ruleStrings) {
|
|
521
|
+
const ruleValue = permissionRuleValueFromString(ruleString)
|
|
522
|
+
rules.push({
|
|
523
|
+
source: source as PermissionRuleSource,
|
|
524
|
+
ruleBehavior: 'allow',
|
|
525
|
+
ruleValue,
|
|
526
|
+
})
|
|
527
|
+
}
|
|
528
|
+
}
|
|
529
|
+
const dangerousPermissions = findDangerousClassifierPermissions(rules, [])
|
|
530
|
+
if (dangerousPermissions.length === 0) {
|
|
531
|
+
return {
|
|
532
|
+
...context,
|
|
533
|
+
strippedDangerousRules: context.strippedDangerousRules ?? {},
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
for (const permission of dangerousPermissions) {
|
|
537
|
+
logForDebugging(
|
|
538
|
+
`Ignoring dangerous permission ${permission.ruleDisplay} from ${permission.sourceDisplay} (bypasses classifier)`,
|
|
539
|
+
)
|
|
540
|
+
}
|
|
541
|
+
// Mirror removeDangerousPermissions' source filter so stash == what was actually removed.
|
|
542
|
+
const stripped: ToolPermissionRulesBySource = {}
|
|
543
|
+
for (const perm of dangerousPermissions) {
|
|
544
|
+
if (!isPermissionUpdateDestination(perm.source)) continue
|
|
545
|
+
;(stripped[perm.source] ??= []).push(
|
|
546
|
+
permissionRuleValueToString(perm.ruleValue),
|
|
547
|
+
)
|
|
548
|
+
}
|
|
549
|
+
return {
|
|
550
|
+
...removeDangerousPermissions(context, dangerousPermissions),
|
|
551
|
+
strippedDangerousRules: stripped,
|
|
552
|
+
}
|
|
553
|
+
}
|
|
554
|
+
|
|
555
|
+
/**
|
|
556
|
+
* Restores dangerous allow rules previously stashed by
|
|
557
|
+
* stripDangerousPermissionsForAutoMode. Called when leaving auto mode so that
|
|
558
|
+
* the user's Bash(python:*), Agent(*), etc. rules work again in default mode.
|
|
559
|
+
* Clears the stash so a second exit is a no-op.
|
|
560
|
+
*/
|
|
561
|
+
export function restoreDangerousPermissions(
|
|
562
|
+
context: ToolPermissionContext,
|
|
563
|
+
): ToolPermissionContext {
|
|
564
|
+
const stash = context.strippedDangerousRules
|
|
565
|
+
if (!stash) {
|
|
566
|
+
return context
|
|
567
|
+
}
|
|
568
|
+
let result = context
|
|
569
|
+
for (const [source, ruleStrings] of Object.entries(stash)) {
|
|
570
|
+
if (!ruleStrings || ruleStrings.length === 0) continue
|
|
571
|
+
result = applyPermissionUpdate(result, {
|
|
572
|
+
type: 'addRules',
|
|
573
|
+
rules: ruleStrings.map(permissionRuleValueFromString),
|
|
574
|
+
behavior: 'allow',
|
|
575
|
+
destination: source as PermissionUpdateDestination,
|
|
576
|
+
})
|
|
577
|
+
}
|
|
578
|
+
return { ...result, strippedDangerousRules: undefined }
|
|
579
|
+
}
|
|
580
|
+
|
|
581
|
+
/**
|
|
582
|
+
* Handles all state transitions when switching permission modes.
|
|
583
|
+
* Centralises side-effects so that every activation path (CLI Shift+Tab,
|
|
584
|
+
* SDK control messages, etc.) behaves identically.
|
|
585
|
+
*
|
|
586
|
+
* Currently handles:
|
|
587
|
+
* - Plan mode enter/exit attachments (via handlePlanModeTransition)
|
|
588
|
+
* - Auto mode activation: setAutoModeActive, stripDangerousPermissionsForAutoMode
|
|
589
|
+
*
|
|
590
|
+
* Returns the (possibly modified) context. Caller is responsible for setting
|
|
591
|
+
* the mode on the returned context.
|
|
592
|
+
*
|
|
593
|
+
* @param fromMode The current permission mode
|
|
594
|
+
* @param toMode The target permission mode
|
|
595
|
+
* @param context The current tool permission context
|
|
596
|
+
*/
|
|
597
|
+
export function transitionPermissionMode(
|
|
598
|
+
fromMode: string,
|
|
599
|
+
toMode: string,
|
|
600
|
+
context: ToolPermissionContext,
|
|
601
|
+
): ToolPermissionContext {
|
|
602
|
+
// plan→plan (SDK set_permission_mode) would wrongly hit the leave branch below
|
|
603
|
+
if (fromMode === toMode) return context
|
|
604
|
+
|
|
605
|
+
handlePlanModeTransition(fromMode, toMode)
|
|
606
|
+
handleAutoModeTransition(fromMode, toMode)
|
|
607
|
+
|
|
608
|
+
if (fromMode === 'plan' && toMode !== 'plan') {
|
|
609
|
+
setHasExitedPlanMode(true)
|
|
610
|
+
}
|
|
611
|
+
|
|
612
|
+
if (feature('TRANSCRIPT_CLASSIFIER')) {
|
|
613
|
+
if (toMode === 'plan' && fromMode !== 'plan') {
|
|
614
|
+
return prepareContextForPlanMode(context)
|
|
615
|
+
}
|
|
616
|
+
|
|
617
|
+
// Plan with auto active counts as using the classifier (for the leaving side).
|
|
618
|
+
// isAutoModeActive() is the authoritative signal — prePlanMode/strippedDangerousRules
|
|
619
|
+
// are unreliable proxies because auto can be deactivated mid-plan (non-opt-in
|
|
620
|
+
// entry, transitionPlanAutoMode) while those fields remain set/unset.
|
|
621
|
+
const fromUsesClassifier =
|
|
622
|
+
fromMode === 'auto' ||
|
|
623
|
+
(fromMode === 'plan' &&
|
|
624
|
+
(autoModeStateModule?.isAutoModeActive() ?? false))
|
|
625
|
+
const toUsesClassifier = toMode === 'auto' // plan entry handled above
|
|
626
|
+
|
|
627
|
+
if (toUsesClassifier && !fromUsesClassifier) {
|
|
628
|
+
if (!isAutoModeGateEnabled()) {
|
|
629
|
+
throw new Error('Cannot transition to auto mode: gate is not enabled')
|
|
630
|
+
}
|
|
631
|
+
autoModeStateModule?.setAutoModeActive(true)
|
|
632
|
+
context = stripDangerousPermissionsForAutoMode(context)
|
|
633
|
+
} else if (fromUsesClassifier && !toUsesClassifier) {
|
|
634
|
+
autoModeStateModule?.setAutoModeActive(false)
|
|
635
|
+
setNeedsAutoModeExitAttachment(true)
|
|
636
|
+
context = restoreDangerousPermissions(context)
|
|
637
|
+
}
|
|
638
|
+
}
|
|
639
|
+
|
|
640
|
+
// Only spread if there's something to clear (preserves ref equality)
|
|
641
|
+
if (fromMode === 'plan' && toMode !== 'plan' && context.prePlanMode) {
|
|
642
|
+
return { ...context, prePlanMode: undefined }
|
|
643
|
+
}
|
|
644
|
+
|
|
645
|
+
return context
|
|
646
|
+
}
|
|
647
|
+
|
|
648
|
+
/**
|
|
649
|
+
* Parse base tools specification from CLI
|
|
650
|
+
* Handles both preset names (default, none) and custom tool lists
|
|
651
|
+
*/
|
|
652
|
+
export function parseBaseToolsFromCLI(baseTools: string[]): string[] {
|
|
653
|
+
// Join all array elements and check if it's a single preset name
|
|
654
|
+
const joinedInput = baseTools.join(' ').trim()
|
|
655
|
+
const preset = parseToolPreset(joinedInput)
|
|
656
|
+
|
|
657
|
+
if (preset) {
|
|
658
|
+
return getToolsForDefaultPreset()
|
|
659
|
+
}
|
|
660
|
+
|
|
661
|
+
// Parse as a custom tool list using the same parsing logic as allowedTools/disallowedTools
|
|
662
|
+
const parsedTools = parseToolListFromCLI(baseTools)
|
|
663
|
+
|
|
664
|
+
return parsedTools
|
|
665
|
+
}
|
|
666
|
+
|
|
667
|
+
/**
|
|
668
|
+
* Check if processPwd is a symlink that resolves to originalCwd
|
|
669
|
+
*/
|
|
670
|
+
function isSymlinkTo({
|
|
671
|
+
processPwd,
|
|
672
|
+
originalCwd,
|
|
673
|
+
}: {
|
|
674
|
+
processPwd: string
|
|
675
|
+
originalCwd: string
|
|
676
|
+
}): boolean {
|
|
677
|
+
// Use safeResolvePath to check if processPwd is a symlink and get its resolved path
|
|
678
|
+
const { resolvedPath: resolvedProcessPwd, isSymlink: isProcessPwdSymlink } =
|
|
679
|
+
safeResolvePath(getFsImplementation(), processPwd)
|
|
680
|
+
|
|
681
|
+
return isProcessPwdSymlink
|
|
682
|
+
? resolvedProcessPwd === resolve(originalCwd)
|
|
683
|
+
: false
|
|
684
|
+
}
|
|
685
|
+
|
|
686
|
+
/**
|
|
687
|
+
* Safely convert CLI flags to a PermissionMode
|
|
688
|
+
*/
|
|
689
|
+
export function initialPermissionModeFromCLI({
|
|
690
|
+
permissionModeCli,
|
|
691
|
+
dangerouslySkipPermissions,
|
|
692
|
+
}: {
|
|
693
|
+
permissionModeCli: string | undefined
|
|
694
|
+
dangerouslySkipPermissions: boolean | undefined
|
|
695
|
+
}): { mode: PermissionMode; notification?: string } {
|
|
696
|
+
const settings = getSettings_DEPRECATED() || {}
|
|
697
|
+
|
|
698
|
+
// Check GrowthBook gate first - highest precedence
|
|
699
|
+
const growthBookDisableBypassPermissionsMode =
|
|
700
|
+
checkStatsigFeatureGate_CACHED_MAY_BE_STALE(
|
|
701
|
+
'tengu_disable_bypass_permissions_mode',
|
|
702
|
+
)
|
|
703
|
+
|
|
704
|
+
// Then check settings - lower precedence
|
|
705
|
+
const settingsDisableBypassPermissionsMode =
|
|
706
|
+
settings.permissions?.disableBypassPermissionsMode === 'disable'
|
|
707
|
+
|
|
708
|
+
// Statsig gate takes precedence over settings
|
|
709
|
+
const disableBypassPermissionsMode =
|
|
710
|
+
growthBookDisableBypassPermissionsMode ||
|
|
711
|
+
settingsDisableBypassPermissionsMode
|
|
712
|
+
|
|
713
|
+
// Sync circuit-breaker check (cached GB read). Prevents the
|
|
714
|
+
// AutoModeOptInDialog from showing in showSetupScreens() when auto can't
|
|
715
|
+
// actually be entered. autoModeFlagCli still carries intent through to
|
|
716
|
+
// verifyAutoModeGateAccess, which notifies the user why.
|
|
717
|
+
const autoModeCircuitBrokenSync = feature('TRANSCRIPT_CLASSIFIER')
|
|
718
|
+
? getAutoModeEnabledStateIfCached() === 'disabled'
|
|
719
|
+
: false
|
|
720
|
+
|
|
721
|
+
// Modes in order of priority
|
|
722
|
+
const orderedModes: PermissionMode[] = []
|
|
723
|
+
let notification: string | undefined
|
|
724
|
+
|
|
725
|
+
if (dangerouslySkipPermissions) {
|
|
726
|
+
orderedModes.push('bypassPermissions')
|
|
727
|
+
}
|
|
728
|
+
if (permissionModeCli) {
|
|
729
|
+
const parsedMode = permissionModeFromString(permissionModeCli)
|
|
730
|
+
if (feature('TRANSCRIPT_CLASSIFIER') && parsedMode === 'auto') {
|
|
731
|
+
if (autoModeCircuitBrokenSync) {
|
|
732
|
+
logForDebugging(
|
|
733
|
+
'auto mode circuit breaker active (cached) — falling back to default',
|
|
734
|
+
{ level: 'warn' },
|
|
735
|
+
)
|
|
736
|
+
} else {
|
|
737
|
+
orderedModes.push('auto')
|
|
738
|
+
}
|
|
739
|
+
} else {
|
|
740
|
+
orderedModes.push(parsedMode)
|
|
741
|
+
}
|
|
742
|
+
}
|
|
743
|
+
if (settings.permissions?.defaultMode) {
|
|
744
|
+
const settingsMode = settings.permissions.defaultMode as PermissionMode
|
|
745
|
+
// CCR only supports acceptEdits and plan — ignore other defaultModes from
|
|
746
|
+
// settings (e.g. bypassPermissions would otherwise silently grant full
|
|
747
|
+
// access in a remote environment).
|
|
748
|
+
if (
|
|
749
|
+
isEnvTruthy(process.env.CLAUDE_CODE_REMOTE) &&
|
|
750
|
+
!['acceptEdits', 'plan', 'default'].includes(settingsMode)
|
|
751
|
+
) {
|
|
752
|
+
logForDebugging(
|
|
753
|
+
`settings defaultMode "${settingsMode}" is not supported in CLAUDE_CODE_REMOTE — only acceptEdits and plan are allowed`,
|
|
754
|
+
{ level: 'warn' },
|
|
755
|
+
)
|
|
756
|
+
logEvent('tengu_ccr_unsupported_default_mode_ignored', {
|
|
757
|
+
mode: settingsMode as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
758
|
+
})
|
|
759
|
+
}
|
|
760
|
+
// auto from settings requires the same gate check as from CLI
|
|
761
|
+
else if (feature('TRANSCRIPT_CLASSIFIER') && settingsMode === 'auto') {
|
|
762
|
+
if (autoModeCircuitBrokenSync) {
|
|
763
|
+
logForDebugging(
|
|
764
|
+
'auto mode circuit breaker active (cached) — falling back to default',
|
|
765
|
+
{ level: 'warn' },
|
|
766
|
+
)
|
|
767
|
+
} else {
|
|
768
|
+
orderedModes.push('auto')
|
|
769
|
+
}
|
|
770
|
+
} else {
|
|
771
|
+
orderedModes.push(settingsMode)
|
|
772
|
+
}
|
|
773
|
+
}
|
|
774
|
+
|
|
775
|
+
let result: { mode: PermissionMode; notification?: string } | undefined
|
|
776
|
+
|
|
777
|
+
for (const mode of orderedModes) {
|
|
778
|
+
if (mode === 'bypassPermissions' && disableBypassPermissionsMode) {
|
|
779
|
+
if (growthBookDisableBypassPermissionsMode) {
|
|
780
|
+
logForDebugging('bypassPermissions mode is disabled by Statsig gate', {
|
|
781
|
+
level: 'warn',
|
|
782
|
+
})
|
|
783
|
+
notification =
|
|
784
|
+
'Bypass permissions mode was disabled by your organization policy'
|
|
785
|
+
} else {
|
|
786
|
+
logForDebugging('bypassPermissions mode is disabled by settings', {
|
|
787
|
+
level: 'warn',
|
|
788
|
+
})
|
|
789
|
+
notification = 'Bypass permissions mode was disabled by settings'
|
|
790
|
+
}
|
|
791
|
+
continue // Skip this mode if it's disabled
|
|
792
|
+
}
|
|
793
|
+
|
|
794
|
+
result = { mode, notification } // Use the first valid mode
|
|
795
|
+
break
|
|
796
|
+
}
|
|
797
|
+
|
|
798
|
+
if (!result) {
|
|
799
|
+
result = { mode: 'default', notification }
|
|
800
|
+
}
|
|
801
|
+
|
|
802
|
+
if (!result) {
|
|
803
|
+
result = { mode: 'default', notification }
|
|
804
|
+
}
|
|
805
|
+
|
|
806
|
+
if (feature('TRANSCRIPT_CLASSIFIER') && result.mode === 'auto') {
|
|
807
|
+
autoModeStateModule?.setAutoModeActive(true)
|
|
808
|
+
}
|
|
809
|
+
|
|
810
|
+
return result
|
|
811
|
+
}
|
|
812
|
+
|
|
813
|
+
export function parseToolListFromCLI(tools: string[]): string[] {
|
|
814
|
+
if (tools.length === 0) {
|
|
815
|
+
return []
|
|
816
|
+
}
|
|
817
|
+
|
|
818
|
+
const result: string[] = []
|
|
819
|
+
|
|
820
|
+
// Process each string in the array
|
|
821
|
+
for (const toolString of tools) {
|
|
822
|
+
if (!toolString) continue
|
|
823
|
+
|
|
824
|
+
let current = ''
|
|
825
|
+
let isInParens = false
|
|
826
|
+
|
|
827
|
+
// Parse each character in the string
|
|
828
|
+
for (const char of toolString) {
|
|
829
|
+
switch (char) {
|
|
830
|
+
case '(':
|
|
831
|
+
isInParens = true
|
|
832
|
+
current += char
|
|
833
|
+
break
|
|
834
|
+
case ')':
|
|
835
|
+
isInParens = false
|
|
836
|
+
current += char
|
|
837
|
+
break
|
|
838
|
+
case ',':
|
|
839
|
+
if (isInParens) {
|
|
840
|
+
current += char
|
|
841
|
+
} else {
|
|
842
|
+
// Comma separator - push current tool and start new one
|
|
843
|
+
if (current.trim()) {
|
|
844
|
+
result.push(current.trim())
|
|
845
|
+
}
|
|
846
|
+
current = ''
|
|
847
|
+
}
|
|
848
|
+
break
|
|
849
|
+
case ' ':
|
|
850
|
+
if (isInParens) {
|
|
851
|
+
current += char
|
|
852
|
+
} else if (current.trim()) {
|
|
853
|
+
// Space separator - push current tool and start new one
|
|
854
|
+
result.push(current.trim())
|
|
855
|
+
current = ''
|
|
856
|
+
}
|
|
857
|
+
break
|
|
858
|
+
default:
|
|
859
|
+
current += char
|
|
860
|
+
}
|
|
861
|
+
}
|
|
862
|
+
|
|
863
|
+
// Push any remaining tool
|
|
864
|
+
if (current.trim()) {
|
|
865
|
+
result.push(current.trim())
|
|
866
|
+
}
|
|
867
|
+
}
|
|
868
|
+
|
|
869
|
+
return result
|
|
870
|
+
}
|
|
871
|
+
|
|
872
|
+
export async function initializeToolPermissionContext({
|
|
873
|
+
allowedToolsCli,
|
|
874
|
+
disallowedToolsCli,
|
|
875
|
+
baseToolsCli,
|
|
876
|
+
permissionMode,
|
|
877
|
+
allowDangerouslySkipPermissions,
|
|
878
|
+
addDirs,
|
|
879
|
+
}: {
|
|
880
|
+
allowedToolsCli: string[]
|
|
881
|
+
disallowedToolsCli: string[]
|
|
882
|
+
baseToolsCli?: string[]
|
|
883
|
+
permissionMode: PermissionMode
|
|
884
|
+
allowDangerouslySkipPermissions: boolean
|
|
885
|
+
addDirs: string[]
|
|
886
|
+
}): Promise<{
|
|
887
|
+
toolPermissionContext: ToolPermissionContext
|
|
888
|
+
warnings: string[]
|
|
889
|
+
dangerousPermissions: DangerousPermissionInfo[]
|
|
890
|
+
overlyBroadBashPermissions: DangerousPermissionInfo[]
|
|
891
|
+
}> {
|
|
892
|
+
// Parse comma-separated allowed and disallowed tools if provided
|
|
893
|
+
// Normalize legacy tool names (e.g., 'Task' → 'Agent') so that in-memory
|
|
894
|
+
// rule removal in stripDangerousPermissionsForAutoMode matches correctly.
|
|
895
|
+
const parsedAllowedToolsCli = parseToolListFromCLI(allowedToolsCli).map(
|
|
896
|
+
rule => permissionRuleValueToString(permissionRuleValueFromString(rule)),
|
|
897
|
+
)
|
|
898
|
+
let parsedDisallowedToolsCli = parseToolListFromCLI(disallowedToolsCli)
|
|
899
|
+
|
|
900
|
+
// If base tools are specified, automatically deny all tools NOT in the base set
|
|
901
|
+
// We need to check if base tools were explicitly provided (not just empty default)
|
|
902
|
+
if (baseToolsCli && baseToolsCli.length > 0) {
|
|
903
|
+
const baseToolsResult = parseBaseToolsFromCLI(baseToolsCli)
|
|
904
|
+
// Normalize legacy tool names (e.g., 'Task' → 'Agent') so user-provided
|
|
905
|
+
// base tool lists using old names still match canonical names.
|
|
906
|
+
const baseToolsSet = new Set(baseToolsResult.map(normalizeLegacyToolName))
|
|
907
|
+
const allToolNames = getToolsForDefaultPreset()
|
|
908
|
+
const toolsToDisallow = allToolNames.filter(tool => !baseToolsSet.has(tool))
|
|
909
|
+
parsedDisallowedToolsCli = [...parsedDisallowedToolsCli, ...toolsToDisallow]
|
|
910
|
+
}
|
|
911
|
+
|
|
912
|
+
const warnings: string[] = []
|
|
913
|
+
const additionalWorkingDirectories = new Map<
|
|
914
|
+
string,
|
|
915
|
+
AdditionalWorkingDirectory
|
|
916
|
+
>()
|
|
917
|
+
// process.env.PWD may be a symlink, while getOriginalCwd() uses the real path
|
|
918
|
+
const processPwd = process.env.PWD
|
|
919
|
+
if (
|
|
920
|
+
processPwd &&
|
|
921
|
+
processPwd !== getOriginalCwd() &&
|
|
922
|
+
isSymlinkTo({ originalCwd: getOriginalCwd(), processPwd })
|
|
923
|
+
) {
|
|
924
|
+
additionalWorkingDirectories.set(processPwd, {
|
|
925
|
+
path: processPwd,
|
|
926
|
+
source: 'session',
|
|
927
|
+
})
|
|
928
|
+
}
|
|
929
|
+
|
|
930
|
+
// Check if bypassPermissions mode is available (not disabled by Statsig gate or settings)
|
|
931
|
+
// Use cached values to avoid blocking on startup
|
|
932
|
+
const growthBookDisableBypassPermissionsMode =
|
|
933
|
+
checkStatsigFeatureGate_CACHED_MAY_BE_STALE(
|
|
934
|
+
'tengu_disable_bypass_permissions_mode',
|
|
935
|
+
)
|
|
936
|
+
const settings = getSettings_DEPRECATED() || {}
|
|
937
|
+
const settingsDisableBypassPermissionsMode =
|
|
938
|
+
settings.permissions?.disableBypassPermissionsMode === 'disable'
|
|
939
|
+
const isBypassPermissionsModeAvailable =
|
|
940
|
+
(permissionMode === 'bypassPermissions' ||
|
|
941
|
+
allowDangerouslySkipPermissions) &&
|
|
942
|
+
!growthBookDisableBypassPermissionsMode &&
|
|
943
|
+
!settingsDisableBypassPermissionsMode
|
|
944
|
+
|
|
945
|
+
// Load all permission rules from disk
|
|
946
|
+
const rulesFromDisk = loadAllPermissionRulesFromDisk()
|
|
947
|
+
|
|
948
|
+
// Ant-only: Detect overly broad shell allow rules for all modes.
|
|
949
|
+
// Bash(*) or PowerShell(*) are equivalent to YOLO mode for that shell.
|
|
950
|
+
// Skip in CCR/BYOC where --allowed-tools is the intended pre-approval mechanism.
|
|
951
|
+
// Variable name kept for return-field compat; contains both shells.
|
|
952
|
+
let overlyBroadBashPermissions: DangerousPermissionInfo[] = []
|
|
953
|
+
if (
|
|
954
|
+
process.env.USER_TYPE === 'ant' &&
|
|
955
|
+
!isEnvTruthy(process.env.CLAUDE_CODE_REMOTE) &&
|
|
956
|
+
process.env.CLAUDE_CODE_ENTRYPOINT !== 'local-agent'
|
|
957
|
+
) {
|
|
958
|
+
overlyBroadBashPermissions = [
|
|
959
|
+
...findOverlyBroadBashPermissions(rulesFromDisk, parsedAllowedToolsCli),
|
|
960
|
+
...findOverlyBroadPowerShellPermissions(
|
|
961
|
+
rulesFromDisk,
|
|
962
|
+
parsedAllowedToolsCli,
|
|
963
|
+
),
|
|
964
|
+
]
|
|
965
|
+
}
|
|
966
|
+
|
|
967
|
+
// Ant-only: Detect dangerous shell permissions for auto mode
|
|
968
|
+
// Dangerous permissions (like Bash(*), Bash(python:*), PowerShell(iex:*)) would auto-allow
|
|
969
|
+
// before the classifier can evaluate them, defeating the purpose of safer YOLO mode
|
|
970
|
+
let dangerousPermissions: DangerousPermissionInfo[] = []
|
|
971
|
+
if (feature('TRANSCRIPT_CLASSIFIER') && permissionMode === 'auto') {
|
|
972
|
+
dangerousPermissions = findDangerousClassifierPermissions(
|
|
973
|
+
rulesFromDisk,
|
|
974
|
+
parsedAllowedToolsCli,
|
|
975
|
+
)
|
|
976
|
+
}
|
|
977
|
+
|
|
978
|
+
let toolPermissionContext = applyPermissionRulesToPermissionContext(
|
|
979
|
+
{
|
|
980
|
+
mode: permissionMode,
|
|
981
|
+
additionalWorkingDirectories,
|
|
982
|
+
alwaysAllowRules: { cliArg: parsedAllowedToolsCli },
|
|
983
|
+
alwaysDenyRules: { cliArg: parsedDisallowedToolsCli },
|
|
984
|
+
alwaysAskRules: {},
|
|
985
|
+
isBypassPermissionsModeAvailable,
|
|
986
|
+
...(feature('TRANSCRIPT_CLASSIFIER')
|
|
987
|
+
? { isAutoModeAvailable: isAutoModeGateEnabled() }
|
|
988
|
+
: {}),
|
|
989
|
+
},
|
|
990
|
+
rulesFromDisk,
|
|
991
|
+
)
|
|
992
|
+
|
|
993
|
+
// Add directories from settings and --add-dir
|
|
994
|
+
const allAdditionalDirectories = [
|
|
995
|
+
...(settings.permissions?.additionalDirectories || []),
|
|
996
|
+
...addDirs,
|
|
997
|
+
]
|
|
998
|
+
// Parallelize fs validation; apply updates serially (cumulative context).
|
|
999
|
+
// validateDirectoryForWorkspace only reads permissionContext to check if the
|
|
1000
|
+
// dir is already covered — behavioral difference from parallelizing is benign
|
|
1001
|
+
// (two overlapping --add-dirs both succeed instead of one being flagged
|
|
1002
|
+
// alreadyInWorkingDirectory, which was silently skipped anyway).
|
|
1003
|
+
const validationResults = await Promise.all(
|
|
1004
|
+
allAdditionalDirectories.map(dir =>
|
|
1005
|
+
validateDirectoryForWorkspace(dir, toolPermissionContext),
|
|
1006
|
+
),
|
|
1007
|
+
)
|
|
1008
|
+
for (const result of validationResults) {
|
|
1009
|
+
if (result.resultType === 'success') {
|
|
1010
|
+
toolPermissionContext = applyPermissionUpdate(toolPermissionContext, {
|
|
1011
|
+
type: 'addDirectories',
|
|
1012
|
+
directories: [result.absolutePath],
|
|
1013
|
+
destination: 'cliArg',
|
|
1014
|
+
})
|
|
1015
|
+
} else if (
|
|
1016
|
+
result.resultType !== 'alreadyInWorkingDirectory' &&
|
|
1017
|
+
result.resultType !== 'pathNotFound'
|
|
1018
|
+
) {
|
|
1019
|
+
// Warn for actual config mistakes (e.g. specifying a file instead of a
|
|
1020
|
+
// directory). But if the directory doesn't exist anymore (e.g. someone
|
|
1021
|
+
// was working under /tmp and it got cleared), silently skip. They'll get
|
|
1022
|
+
// prompted again if they try to access it later.
|
|
1023
|
+
warnings.push(addDirHelpMessage(result))
|
|
1024
|
+
}
|
|
1025
|
+
}
|
|
1026
|
+
|
|
1027
|
+
return {
|
|
1028
|
+
toolPermissionContext,
|
|
1029
|
+
warnings,
|
|
1030
|
+
dangerousPermissions,
|
|
1031
|
+
overlyBroadBashPermissions,
|
|
1032
|
+
}
|
|
1033
|
+
}
|
|
1034
|
+
|
|
1035
|
+
export type AutoModeGateCheckResult = {
|
|
1036
|
+
// Transform function (not a pre-computed context) so callers can apply it
|
|
1037
|
+
// inside setAppState(prev => ...) against the CURRENT context. Pre-computing
|
|
1038
|
+
// the context here captured a stale snapshot: the async GrowthBook await
|
|
1039
|
+
// below can be outrun by a mid-turn shift-tab, and returning
|
|
1040
|
+
// { ...currentContext, ... } would overwrite the user's mode change.
|
|
1041
|
+
updateContext: (ctx: ToolPermissionContext) => ToolPermissionContext
|
|
1042
|
+
notification?: string
|
|
1043
|
+
}
|
|
1044
|
+
|
|
1045
|
+
export type AutoModeUnavailableReason = 'settings' | 'circuit-breaker' | 'model'
|
|
1046
|
+
|
|
1047
|
+
export function getAutoModeUnavailableNotification(
|
|
1048
|
+
reason: AutoModeUnavailableReason,
|
|
1049
|
+
): string {
|
|
1050
|
+
let base: string
|
|
1051
|
+
switch (reason) {
|
|
1052
|
+
case 'settings':
|
|
1053
|
+
base = 'auto mode disabled by settings'
|
|
1054
|
+
break
|
|
1055
|
+
case 'circuit-breaker':
|
|
1056
|
+
base = 'auto mode is unavailable for your plan'
|
|
1057
|
+
break
|
|
1058
|
+
case 'model':
|
|
1059
|
+
base = 'auto mode unavailable for this model'
|
|
1060
|
+
break
|
|
1061
|
+
}
|
|
1062
|
+
return process.env.USER_TYPE === 'ant'
|
|
1063
|
+
? `${base} · #claude-code-feedback`
|
|
1064
|
+
: base
|
|
1065
|
+
}
|
|
1066
|
+
|
|
1067
|
+
/**
|
|
1068
|
+
* Async check of auto mode availability.
|
|
1069
|
+
*
|
|
1070
|
+
* Returns a transform function (not a pre-computed context) that callers
|
|
1071
|
+
* apply inside setAppState(prev => ...) against the CURRENT context. This
|
|
1072
|
+
* prevents the async GrowthBook await from clobbering mid-turn mode changes
|
|
1073
|
+
* (e.g., user shift-tabs to acceptEdits while this check is in flight).
|
|
1074
|
+
*
|
|
1075
|
+
* The transform re-checks mode/prePlanMode against the fresh ctx to avoid
|
|
1076
|
+
* kicking the user out of a mode they've already left during the await.
|
|
1077
|
+
*/
|
|
1078
|
+
export async function verifyAutoModeGateAccess(
|
|
1079
|
+
currentContext: ToolPermissionContext,
|
|
1080
|
+
// Runtime AppState.fastMode — passed from callers with AppState access so
|
|
1081
|
+
// the disableFastMode circuit breaker reads current state, not stale
|
|
1082
|
+
// settings.fastMode (which is intentionally sticky across /model auto-
|
|
1083
|
+
// downgrades). Optional for callers without AppState (e.g. SDK init paths).
|
|
1084
|
+
fastMode?: boolean,
|
|
1085
|
+
): Promise<AutoModeGateCheckResult> {
|
|
1086
|
+
// Auto-mode config — runs in ALL builds (circuit breaker, carousel, kick-out)
|
|
1087
|
+
// Fresh read of tengu_auto_mode_config.enabled — this async check runs once
|
|
1088
|
+
// after GrowthBook initialization and is the authoritative source for
|
|
1089
|
+
// isAutoModeAvailable. The sync startup path uses stale cache; this
|
|
1090
|
+
// corrects it. Circuit breaker (enabled==='disabled') takes effect here.
|
|
1091
|
+
const autoModeConfig = await getDynamicConfig_BLOCKS_ON_INIT<{
|
|
1092
|
+
enabled?: AutoModeEnabledState
|
|
1093
|
+
disableFastMode?: boolean
|
|
1094
|
+
}>('tengu_auto_mode_config', {})
|
|
1095
|
+
const enabledState = parseAutoModeEnabledState(autoModeConfig?.enabled)
|
|
1096
|
+
const disabledBySettings = isAutoModeDisabledBySettings()
|
|
1097
|
+
// Treat settings-disable the same as GrowthBook 'disabled' for circuit-breaker
|
|
1098
|
+
// semantics — blocks SDK/explicit re-entry via isAutoModeGateEnabled().
|
|
1099
|
+
autoModeStateModule?.setAutoModeCircuitBroken(
|
|
1100
|
+
enabledState === 'disabled' || disabledBySettings,
|
|
1101
|
+
)
|
|
1102
|
+
|
|
1103
|
+
// Carousel availability: not circuit-broken, not disabled-by-settings,
|
|
1104
|
+
// model supports it, disableFastMode breaker not firing, and (enabled or opted-in)
|
|
1105
|
+
const mainModel = getMainLoopModel()
|
|
1106
|
+
// Temp circuit breaker: tengu_auto_mode_config.disableFastMode blocks auto
|
|
1107
|
+
// mode when fast mode is on. Checks runtime AppState.fastMode (if provided)
|
|
1108
|
+
// and, for ants, model name '-fast' substring (ant-internal fast models
|
|
1109
|
+
// like capybara-v2-fast[1m] encode speed in the model ID itself).
|
|
1110
|
+
// Remove once auto+fast mode interaction is validated.
|
|
1111
|
+
const disableFastModeBreakerFires =
|
|
1112
|
+
!!autoModeConfig?.disableFastMode &&
|
|
1113
|
+
(!!fastMode ||
|
|
1114
|
+
(process.env.USER_TYPE === 'ant' &&
|
|
1115
|
+
mainModel.toLowerCase().includes('-fast')))
|
|
1116
|
+
const modelSupported =
|
|
1117
|
+
modelSupportsAutoMode(mainModel) && !disableFastModeBreakerFires
|
|
1118
|
+
let carouselAvailable = false
|
|
1119
|
+
if (enabledState !== 'disabled' && !disabledBySettings && modelSupported) {
|
|
1120
|
+
carouselAvailable =
|
|
1121
|
+
enabledState === 'enabled' || hasAutoModeOptInAnySource()
|
|
1122
|
+
}
|
|
1123
|
+
// canEnterAuto gates explicit entry (--permission-mode auto, defaultMode: auto)
|
|
1124
|
+
// — explicit entry IS an opt-in, so we only block on circuit breaker + settings + model
|
|
1125
|
+
const canEnterAuto =
|
|
1126
|
+
enabledState !== 'disabled' && !disabledBySettings && modelSupported
|
|
1127
|
+
logForDebugging(
|
|
1128
|
+
`[auto-mode] verifyAutoModeGateAccess: enabledState=${enabledState} disabledBySettings=${disabledBySettings} model=${mainModel} modelSupported=${modelSupported} disableFastModeBreakerFires=${disableFastModeBreakerFires} carouselAvailable=${carouselAvailable} canEnterAuto=${canEnterAuto}`,
|
|
1129
|
+
)
|
|
1130
|
+
|
|
1131
|
+
// Capture CLI-flag intent now (doesn't depend on context).
|
|
1132
|
+
const autoModeFlagCli = autoModeStateModule?.getAutoModeFlagCli() ?? false
|
|
1133
|
+
|
|
1134
|
+
// Return a transform function that re-evaluates context-dependent conditions
|
|
1135
|
+
// against the CURRENT context at setAppState time. The async GrowthBook
|
|
1136
|
+
// results above (canEnterAuto, carouselAvailable, enabledState, reason) are
|
|
1137
|
+
// closure-captured — those don't depend on context. But mode, prePlanMode,
|
|
1138
|
+
// and isAutoModeAvailable checks MUST use the fresh ctx or a mid-await
|
|
1139
|
+
// shift-tab gets reverted (or worse, the user stays in auto despite the
|
|
1140
|
+
// circuit breaker if they entered auto DURING the await — which is possible
|
|
1141
|
+
// because setAutoModeCircuitBroken above runs AFTER the await).
|
|
1142
|
+
const setAvailable = (
|
|
1143
|
+
ctx: ToolPermissionContext,
|
|
1144
|
+
available: boolean,
|
|
1145
|
+
): ToolPermissionContext => {
|
|
1146
|
+
if (ctx.isAutoModeAvailable !== available) {
|
|
1147
|
+
logForDebugging(
|
|
1148
|
+
`[auto-mode] verifyAutoModeGateAccess setAvailable: ${ctx.isAutoModeAvailable} -> ${available}`,
|
|
1149
|
+
)
|
|
1150
|
+
}
|
|
1151
|
+
return ctx.isAutoModeAvailable === available
|
|
1152
|
+
? ctx
|
|
1153
|
+
: { ...ctx, isAutoModeAvailable: available }
|
|
1154
|
+
}
|
|
1155
|
+
|
|
1156
|
+
if (canEnterAuto) {
|
|
1157
|
+
return { updateContext: ctx => setAvailable(ctx, carouselAvailable) }
|
|
1158
|
+
}
|
|
1159
|
+
|
|
1160
|
+
// Gate is off or circuit-broken — determine reason (context-independent).
|
|
1161
|
+
let reason: AutoModeUnavailableReason
|
|
1162
|
+
if (disabledBySettings) {
|
|
1163
|
+
reason = 'settings'
|
|
1164
|
+
logForDebugging('auto mode disabled: disableAutoMode in settings', {
|
|
1165
|
+
level: 'warn',
|
|
1166
|
+
})
|
|
1167
|
+
} else if (enabledState === 'disabled') {
|
|
1168
|
+
reason = 'circuit-breaker'
|
|
1169
|
+
logForDebugging(
|
|
1170
|
+
'auto mode disabled: tengu_auto_mode_config.enabled === "disabled" (circuit breaker)',
|
|
1171
|
+
{ level: 'warn' },
|
|
1172
|
+
)
|
|
1173
|
+
} else {
|
|
1174
|
+
reason = 'model'
|
|
1175
|
+
logForDebugging(
|
|
1176
|
+
`auto mode disabled: model ${getMainLoopModel()} does not support auto mode`,
|
|
1177
|
+
{ level: 'warn' },
|
|
1178
|
+
)
|
|
1179
|
+
}
|
|
1180
|
+
const notification = getAutoModeUnavailableNotification(reason)
|
|
1181
|
+
|
|
1182
|
+
// Unified kick-out transform. Re-checks the FRESH ctx and only fires
|
|
1183
|
+
// side effects (setAutoModeActive(false), setNeedsAutoModeExitAttachment)
|
|
1184
|
+
// when the kick-out actually applies. This keeps autoModeActive in sync
|
|
1185
|
+
// with toolPermissionContext.mode even if the user changed modes during
|
|
1186
|
+
// the await: if they already left auto on their own, handleCycleMode
|
|
1187
|
+
// already deactivated the classifier and we don't fire again; if they
|
|
1188
|
+
// ENTERED auto during the await (possible before setAutoModeCircuitBroken
|
|
1189
|
+
// landed), we kick them out here.
|
|
1190
|
+
const kickOutOfAutoIfNeeded = (
|
|
1191
|
+
ctx: ToolPermissionContext,
|
|
1192
|
+
): ToolPermissionContext => {
|
|
1193
|
+
const inAuto = ctx.mode === 'auto'
|
|
1194
|
+
logForDebugging(
|
|
1195
|
+
`[auto-mode] kickOutOfAutoIfNeeded applying: ctx.mode=${ctx.mode} ctx.prePlanMode=${ctx.prePlanMode} reason=${reason}`,
|
|
1196
|
+
)
|
|
1197
|
+
// Plan mode with auto active: either from prePlanMode='auto' (entered
|
|
1198
|
+
// from auto) or from opt-in (strippedDangerousRules present).
|
|
1199
|
+
const inPlanWithAutoActive =
|
|
1200
|
+
ctx.mode === 'plan' &&
|
|
1201
|
+
(ctx.prePlanMode === 'auto' || !!ctx.strippedDangerousRules)
|
|
1202
|
+
if (!inAuto && !inPlanWithAutoActive) {
|
|
1203
|
+
return setAvailable(ctx, false)
|
|
1204
|
+
}
|
|
1205
|
+
if (inAuto) {
|
|
1206
|
+
autoModeStateModule?.setAutoModeActive(false)
|
|
1207
|
+
setNeedsAutoModeExitAttachment(true)
|
|
1208
|
+
return {
|
|
1209
|
+
...applyPermissionUpdate(restoreDangerousPermissions(ctx), {
|
|
1210
|
+
type: 'setMode',
|
|
1211
|
+
mode: 'default',
|
|
1212
|
+
destination: 'session',
|
|
1213
|
+
}),
|
|
1214
|
+
isAutoModeAvailable: false,
|
|
1215
|
+
}
|
|
1216
|
+
}
|
|
1217
|
+
// Plan with auto active: deactivate auto, restore permissions, defuse
|
|
1218
|
+
// prePlanMode so ExitPlanMode goes to default.
|
|
1219
|
+
autoModeStateModule?.setAutoModeActive(false)
|
|
1220
|
+
setNeedsAutoModeExitAttachment(true)
|
|
1221
|
+
return {
|
|
1222
|
+
...restoreDangerousPermissions(ctx),
|
|
1223
|
+
prePlanMode: ctx.prePlanMode === 'auto' ? 'default' : ctx.prePlanMode,
|
|
1224
|
+
isAutoModeAvailable: false,
|
|
1225
|
+
}
|
|
1226
|
+
}
|
|
1227
|
+
|
|
1228
|
+
// Notification decisions use the stale context — that's OK: we're deciding
|
|
1229
|
+
// WHETHER to notify based on what the user WAS doing when this check started.
|
|
1230
|
+
// (Side effects and mode mutation are decided inside the transform above,
|
|
1231
|
+
// against the fresh ctx.)
|
|
1232
|
+
const wasInAuto = currentContext.mode === 'auto'
|
|
1233
|
+
// Auto was used during plan: entered from auto or opt-in auto active
|
|
1234
|
+
const autoActiveDuringPlan =
|
|
1235
|
+
currentContext.mode === 'plan' &&
|
|
1236
|
+
(currentContext.prePlanMode === 'auto' ||
|
|
1237
|
+
!!currentContext.strippedDangerousRules)
|
|
1238
|
+
const wantedAuto = wasInAuto || autoActiveDuringPlan || autoModeFlagCli
|
|
1239
|
+
|
|
1240
|
+
if (!wantedAuto) {
|
|
1241
|
+
// User didn't want auto at call time — no notification. But still apply
|
|
1242
|
+
// the full kick-out transform: if they shift-tabbed INTO auto during the
|
|
1243
|
+
// await (before setAutoModeCircuitBroken landed), we need to evict them.
|
|
1244
|
+
return { updateContext: kickOutOfAutoIfNeeded }
|
|
1245
|
+
}
|
|
1246
|
+
|
|
1247
|
+
if (wasInAuto || autoActiveDuringPlan) {
|
|
1248
|
+
// User was in auto or had auto active during plan — kick out + notify.
|
|
1249
|
+
return { updateContext: kickOutOfAutoIfNeeded, notification }
|
|
1250
|
+
}
|
|
1251
|
+
|
|
1252
|
+
// autoModeFlagCli only: defaultMode was auto but sync check rejected it.
|
|
1253
|
+
// Suppress notification if isAutoModeAvailable is already false (already
|
|
1254
|
+
// notified on a prior check; prevents repeat notifications on successive
|
|
1255
|
+
// unsupported-model switches).
|
|
1256
|
+
return {
|
|
1257
|
+
updateContext: kickOutOfAutoIfNeeded,
|
|
1258
|
+
notification: currentContext.isAutoModeAvailable ? notification : undefined,
|
|
1259
|
+
}
|
|
1260
|
+
}
|
|
1261
|
+
|
|
1262
|
+
/**
|
|
1263
|
+
* Core logic to check if bypassPermissions should be disabled based on Statsig gate
|
|
1264
|
+
*/
|
|
1265
|
+
export function shouldDisableBypassPermissions(): Promise<boolean> {
|
|
1266
|
+
return checkSecurityRestrictionGate('tengu_disable_bypass_permissions_mode')
|
|
1267
|
+
}
|
|
1268
|
+
|
|
1269
|
+
function isAutoModeDisabledBySettings(): boolean {
|
|
1270
|
+
const settings = getSettings_DEPRECATED() || {}
|
|
1271
|
+
return (
|
|
1272
|
+
(settings as { disableAutoMode?: 'disable' }).disableAutoMode ===
|
|
1273
|
+
'disable' ||
|
|
1274
|
+
(settings.permissions as { disableAutoMode?: 'disable' } | undefined)
|
|
1275
|
+
?.disableAutoMode === 'disable'
|
|
1276
|
+
)
|
|
1277
|
+
}
|
|
1278
|
+
|
|
1279
|
+
/**
|
|
1280
|
+
* Checks if auto mode can be entered: circuit breaker is not active and settings
|
|
1281
|
+
* have not disabled it. Synchronous.
|
|
1282
|
+
*/
|
|
1283
|
+
export function isAutoModeGateEnabled(): boolean {
|
|
1284
|
+
if (autoModeStateModule?.isAutoModeCircuitBroken() ?? false) return false
|
|
1285
|
+
if (isAutoModeDisabledBySettings()) return false
|
|
1286
|
+
if (!modelSupportsAutoMode(getMainLoopModel())) return false
|
|
1287
|
+
return true
|
|
1288
|
+
}
|
|
1289
|
+
|
|
1290
|
+
/**
|
|
1291
|
+
* Returns the reason auto mode is currently unavailable, or null if available.
|
|
1292
|
+
* Synchronous — uses state populated by verifyAutoModeGateAccess.
|
|
1293
|
+
*/
|
|
1294
|
+
export function getAutoModeUnavailableReason(): AutoModeUnavailableReason | null {
|
|
1295
|
+
if (isAutoModeDisabledBySettings()) return 'settings'
|
|
1296
|
+
if (autoModeStateModule?.isAutoModeCircuitBroken() ?? false) {
|
|
1297
|
+
return 'circuit-breaker'
|
|
1298
|
+
}
|
|
1299
|
+
if (!modelSupportsAutoMode(getMainLoopModel())) return 'model'
|
|
1300
|
+
return null
|
|
1301
|
+
}
|
|
1302
|
+
|
|
1303
|
+
/**
|
|
1304
|
+
* The `enabled` field in the tengu_auto_mode_config GrowthBook JSON config.
|
|
1305
|
+
* Controls auto mode availability in UI surfaces (CLI, IDE, Desktop).
|
|
1306
|
+
* - 'enabled': auto mode is available in the shift-tab carousel (or equivalent)
|
|
1307
|
+
* - 'disabled': auto mode is fully unavailable — circuit breaker for incident response
|
|
1308
|
+
* - 'opt-in': auto mode is available only if the user has explicitly opted in
|
|
1309
|
+
* (via --enable-auto-mode in CLI, or a settings toggle in IDE/Desktop)
|
|
1310
|
+
*/
|
|
1311
|
+
export type AutoModeEnabledState = 'enabled' | 'disabled' | 'opt-in'
|
|
1312
|
+
|
|
1313
|
+
const AUTO_MODE_ENABLED_DEFAULT: AutoModeEnabledState = 'disabled'
|
|
1314
|
+
|
|
1315
|
+
function parseAutoModeEnabledState(value: unknown): AutoModeEnabledState {
|
|
1316
|
+
if (value === 'enabled' || value === 'disabled' || value === 'opt-in') {
|
|
1317
|
+
return value
|
|
1318
|
+
}
|
|
1319
|
+
return AUTO_MODE_ENABLED_DEFAULT
|
|
1320
|
+
}
|
|
1321
|
+
|
|
1322
|
+
/**
|
|
1323
|
+
* Reads the `enabled` field from tengu_auto_mode_config (cached, may be stale).
|
|
1324
|
+
* Defaults to 'disabled' if GrowthBook is unavailable or the field is unset.
|
|
1325
|
+
* Other surfaces (IDE, Desktop) should call this to decide whether to surface
|
|
1326
|
+
* auto mode in their mode pickers.
|
|
1327
|
+
*/
|
|
1328
|
+
export function getAutoModeEnabledState(): AutoModeEnabledState {
|
|
1329
|
+
const config = getFeatureValue_CACHED_MAY_BE_STALE<{
|
|
1330
|
+
enabled?: AutoModeEnabledState
|
|
1331
|
+
}>('tengu_auto_mode_config', {})
|
|
1332
|
+
return parseAutoModeEnabledState(config?.enabled)
|
|
1333
|
+
}
|
|
1334
|
+
|
|
1335
|
+
const NO_CACHED_AUTO_MODE_CONFIG = Symbol('no-cached-auto-mode-config')
|
|
1336
|
+
|
|
1337
|
+
/**
|
|
1338
|
+
* Like getAutoModeEnabledState but returns undefined when no cached value
|
|
1339
|
+
* exists (cold start, before GrowthBook init). Used by the sync
|
|
1340
|
+
* circuit-breaker check in initialPermissionModeFromCLI, which must not
|
|
1341
|
+
* conflate "not yet fetched" with "fetched and disabled" — the former
|
|
1342
|
+
* defers to verifyAutoModeGateAccess, the latter blocks immediately.
|
|
1343
|
+
*/
|
|
1344
|
+
export function getAutoModeEnabledStateIfCached():
|
|
1345
|
+
| AutoModeEnabledState
|
|
1346
|
+
| undefined {
|
|
1347
|
+
const config = getFeatureValue_CACHED_MAY_BE_STALE<
|
|
1348
|
+
{ enabled?: AutoModeEnabledState } | typeof NO_CACHED_AUTO_MODE_CONFIG
|
|
1349
|
+
>('tengu_auto_mode_config', NO_CACHED_AUTO_MODE_CONFIG)
|
|
1350
|
+
if (config === NO_CACHED_AUTO_MODE_CONFIG) return undefined
|
|
1351
|
+
return parseAutoModeEnabledState(config?.enabled)
|
|
1352
|
+
}
|
|
1353
|
+
|
|
1354
|
+
/**
|
|
1355
|
+
* Returns true if the user has opted in to auto mode via any trusted mechanism:
|
|
1356
|
+
* - CLI flag (--enable-auto-mode / --permission-mode auto) — session-scoped
|
|
1357
|
+
* availability request; the startup dialog in showSetupScreens enforces
|
|
1358
|
+
* persistent consent before the REPL renders.
|
|
1359
|
+
* - skipAutoPermissionPrompt setting (persistent; set by accepting the opt-in
|
|
1360
|
+
* dialog or by IDE/Desktop settings toggle)
|
|
1361
|
+
*/
|
|
1362
|
+
export function hasAutoModeOptInAnySource(): boolean {
|
|
1363
|
+
if (autoModeStateModule?.getAutoModeFlagCli() ?? false) return true
|
|
1364
|
+
return hasAutoModeOptIn()
|
|
1365
|
+
}
|
|
1366
|
+
|
|
1367
|
+
/**
|
|
1368
|
+
* Checks if bypassPermissions mode is currently disabled by Statsig gate or settings.
|
|
1369
|
+
* This is a synchronous version that uses cached Statsig values.
|
|
1370
|
+
*/
|
|
1371
|
+
export function isBypassPermissionsModeDisabled(): boolean {
|
|
1372
|
+
const growthBookDisableBypassPermissionsMode =
|
|
1373
|
+
checkStatsigFeatureGate_CACHED_MAY_BE_STALE(
|
|
1374
|
+
'tengu_disable_bypass_permissions_mode',
|
|
1375
|
+
)
|
|
1376
|
+
const settings = getSettings_DEPRECATED() || {}
|
|
1377
|
+
const settingsDisableBypassPermissionsMode =
|
|
1378
|
+
settings.permissions?.disableBypassPermissionsMode === 'disable'
|
|
1379
|
+
|
|
1380
|
+
return (
|
|
1381
|
+
growthBookDisableBypassPermissionsMode ||
|
|
1382
|
+
settingsDisableBypassPermissionsMode
|
|
1383
|
+
)
|
|
1384
|
+
}
|
|
1385
|
+
|
|
1386
|
+
/**
|
|
1387
|
+
* Creates an updated context with bypassPermissions disabled
|
|
1388
|
+
*/
|
|
1389
|
+
export function createDisabledBypassPermissionsContext(
|
|
1390
|
+
currentContext: ToolPermissionContext,
|
|
1391
|
+
): ToolPermissionContext {
|
|
1392
|
+
let updatedContext = currentContext
|
|
1393
|
+
if (currentContext.mode === 'bypassPermissions') {
|
|
1394
|
+
updatedContext = applyPermissionUpdate(currentContext, {
|
|
1395
|
+
type: 'setMode',
|
|
1396
|
+
mode: 'default',
|
|
1397
|
+
destination: 'session',
|
|
1398
|
+
})
|
|
1399
|
+
}
|
|
1400
|
+
|
|
1401
|
+
return {
|
|
1402
|
+
...updatedContext,
|
|
1403
|
+
isBypassPermissionsModeAvailable: false,
|
|
1404
|
+
}
|
|
1405
|
+
}
|
|
1406
|
+
|
|
1407
|
+
/**
|
|
1408
|
+
* Asynchronously checks if the bypassPermissions mode should be disabled based on Statsig gate
|
|
1409
|
+
* and returns an updated toolPermissionContext if needed
|
|
1410
|
+
*/
|
|
1411
|
+
export async function checkAndDisableBypassPermissions(
|
|
1412
|
+
currentContext: ToolPermissionContext,
|
|
1413
|
+
): Promise<void> {
|
|
1414
|
+
// Only proceed if bypassPermissions mode is available
|
|
1415
|
+
if (!currentContext.isBypassPermissionsModeAvailable) {
|
|
1416
|
+
return
|
|
1417
|
+
}
|
|
1418
|
+
|
|
1419
|
+
const shouldDisable = await shouldDisableBypassPermissions()
|
|
1420
|
+
if (!shouldDisable) {
|
|
1421
|
+
return
|
|
1422
|
+
}
|
|
1423
|
+
|
|
1424
|
+
// Gate is enabled, need to disable bypassPermissions mode
|
|
1425
|
+
logForDebugging(
|
|
1426
|
+
'bypassPermissions mode is being disabled by Statsig gate (async check)',
|
|
1427
|
+
{ level: 'warn' },
|
|
1428
|
+
)
|
|
1429
|
+
|
|
1430
|
+
void gracefulShutdown(1, 'bypass_permissions_disabled')
|
|
1431
|
+
}
|
|
1432
|
+
|
|
1433
|
+
export function isDefaultPermissionModeAuto(): boolean {
|
|
1434
|
+
if (feature('TRANSCRIPT_CLASSIFIER')) {
|
|
1435
|
+
const settings = getSettings_DEPRECATED() || {}
|
|
1436
|
+
return settings.permissions?.defaultMode === 'auto'
|
|
1437
|
+
}
|
|
1438
|
+
return false
|
|
1439
|
+
}
|
|
1440
|
+
|
|
1441
|
+
/**
|
|
1442
|
+
* Whether plan mode should use auto mode semantics (classifier runs during
|
|
1443
|
+
* plan). True when the user has opted in to auto mode and the gate is enabled.
|
|
1444
|
+
* Evaluated at permission-check time so it's reactive to config changes.
|
|
1445
|
+
*/
|
|
1446
|
+
export function shouldPlanUseAutoMode(): boolean {
|
|
1447
|
+
if (feature('TRANSCRIPT_CLASSIFIER')) {
|
|
1448
|
+
return (
|
|
1449
|
+
hasAutoModeOptIn() &&
|
|
1450
|
+
isAutoModeGateEnabled() &&
|
|
1451
|
+
getUseAutoModeDuringPlan()
|
|
1452
|
+
)
|
|
1453
|
+
}
|
|
1454
|
+
return false
|
|
1455
|
+
}
|
|
1456
|
+
|
|
1457
|
+
/**
|
|
1458
|
+
* Centralized plan-mode entry. Stashes the current mode as prePlanMode so
|
|
1459
|
+
* ExitPlanMode can restore it. When the user has opted in to auto mode,
|
|
1460
|
+
* auto semantics stay active during plan mode.
|
|
1461
|
+
*/
|
|
1462
|
+
export function prepareContextForPlanMode(
|
|
1463
|
+
context: ToolPermissionContext,
|
|
1464
|
+
): ToolPermissionContext {
|
|
1465
|
+
const currentMode = context.mode
|
|
1466
|
+
if (currentMode === 'plan') return context
|
|
1467
|
+
if (feature('TRANSCRIPT_CLASSIFIER')) {
|
|
1468
|
+
const planAutoMode = shouldPlanUseAutoMode()
|
|
1469
|
+
if (currentMode === 'auto') {
|
|
1470
|
+
if (planAutoMode) {
|
|
1471
|
+
return { ...context, prePlanMode: 'auto' }
|
|
1472
|
+
}
|
|
1473
|
+
autoModeStateModule?.setAutoModeActive(false)
|
|
1474
|
+
setNeedsAutoModeExitAttachment(true)
|
|
1475
|
+
return {
|
|
1476
|
+
...restoreDangerousPermissions(context),
|
|
1477
|
+
prePlanMode: 'auto',
|
|
1478
|
+
}
|
|
1479
|
+
}
|
|
1480
|
+
if (planAutoMode && currentMode !== 'bypassPermissions') {
|
|
1481
|
+
autoModeStateModule?.setAutoModeActive(true)
|
|
1482
|
+
return {
|
|
1483
|
+
...stripDangerousPermissionsForAutoMode(context),
|
|
1484
|
+
prePlanMode: currentMode,
|
|
1485
|
+
}
|
|
1486
|
+
}
|
|
1487
|
+
}
|
|
1488
|
+
logForDebugging(
|
|
1489
|
+
`[prepareContextForPlanMode] plain plan entry, prePlanMode=${currentMode}`,
|
|
1490
|
+
{ level: 'info' },
|
|
1491
|
+
)
|
|
1492
|
+
return { ...context, prePlanMode: currentMode }
|
|
1493
|
+
}
|
|
1494
|
+
|
|
1495
|
+
/**
|
|
1496
|
+
* Reconciles auto-mode state during plan mode after a settings change.
|
|
1497
|
+
* Compares desired state (shouldPlanUseAutoMode) against actual state
|
|
1498
|
+
* (isAutoModeActive) and activates/deactivates auto accordingly. No-op when
|
|
1499
|
+
* not in plan mode. Called from applySettingsChange so that toggling
|
|
1500
|
+
* useAutoModeDuringPlan mid-plan takes effect immediately.
|
|
1501
|
+
*/
|
|
1502
|
+
export function transitionPlanAutoMode(
|
|
1503
|
+
context: ToolPermissionContext,
|
|
1504
|
+
): ToolPermissionContext {
|
|
1505
|
+
if (!feature('TRANSCRIPT_CLASSIFIER')) return context
|
|
1506
|
+
if (context.mode !== 'plan') return context
|
|
1507
|
+
// Mirror prepareContextForPlanMode's entry-time exclusion — never activate
|
|
1508
|
+
// auto mid-plan when the user entered from a dangerous mode.
|
|
1509
|
+
if (context.prePlanMode === 'bypassPermissions') {
|
|
1510
|
+
return context
|
|
1511
|
+
}
|
|
1512
|
+
|
|
1513
|
+
const want = shouldPlanUseAutoMode()
|
|
1514
|
+
const have = autoModeStateModule?.isAutoModeActive() ?? false
|
|
1515
|
+
|
|
1516
|
+
if (want && have) {
|
|
1517
|
+
// syncPermissionRulesFromDisk (called before us in applySettingsChange)
|
|
1518
|
+
// re-adds dangerous rules from disk without touching strippedDangerousRules.
|
|
1519
|
+
// Re-strip so the classifier isn't bypassed by prefix-rule allow matches.
|
|
1520
|
+
return stripDangerousPermissionsForAutoMode(context)
|
|
1521
|
+
}
|
|
1522
|
+
if (!want && !have) return context
|
|
1523
|
+
|
|
1524
|
+
if (want) {
|
|
1525
|
+
autoModeStateModule?.setAutoModeActive(true)
|
|
1526
|
+
setNeedsAutoModeExitAttachment(false)
|
|
1527
|
+
return stripDangerousPermissionsForAutoMode(context)
|
|
1528
|
+
}
|
|
1529
|
+
autoModeStateModule?.setAutoModeActive(false)
|
|
1530
|
+
setNeedsAutoModeExitAttachment(true)
|
|
1531
|
+
return restoreDangerousPermissions(context)
|
|
1532
|
+
}
|