yzcode-cli 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/QueryEngine.ts +1295 -0
- package/Task.ts +125 -0
- package/Tool.ts +792 -0
- package/bin/yzcode-init.js +31 -0
- package/bin/yzcode.js +35 -0
- package/cli/exit.ts +31 -0
- package/cli/handlers/agents.ts +70 -0
- package/cli/handlers/auth.ts +330 -0
- package/cli/handlers/autoMode.ts +170 -0
- package/cli/handlers/mcp.tsx +362 -0
- package/cli/handlers/plugins.ts +878 -0
- package/cli/handlers/util.tsx +110 -0
- package/cli/ndjsonSafeStringify.ts +32 -0
- package/cli/print.ts +5594 -0
- package/cli/remoteIO.ts +255 -0
- package/cli/structuredIO.ts +859 -0
- package/cli/transports/HybridTransport.ts +282 -0
- package/cli/transports/SSETransport.ts +711 -0
- package/cli/transports/SerialBatchEventUploader.ts +275 -0
- package/cli/transports/WebSocketTransport.ts +800 -0
- package/cli/transports/WorkerStateUploader.ts +131 -0
- package/cli/transports/ccrClient.ts +998 -0
- package/cli/transports/transportUtils.ts +45 -0
- package/cli/update.ts +422 -0
- package/commands/add-dir/add-dir.tsx +126 -0
- package/commands/add-dir/index.ts +11 -0
- package/commands/add-dir/validation.ts +110 -0
- package/commands/advisor.ts +109 -0
- package/commands/agents/agents.tsx +12 -0
- package/commands/agents/index.ts +10 -0
- package/commands/ant-trace/index.js +1 -0
- package/commands/autofix-pr/index.js +1 -0
- package/commands/backfill-sessions/index.js +1 -0
- package/commands/branch/branch.ts +296 -0
- package/commands/branch/index.ts +14 -0
- package/commands/break-cache/index.js +1 -0
- package/commands/bridge/bridge.tsx +509 -0
- package/commands/bridge/index.ts +26 -0
- package/commands/bridge-kick.ts +200 -0
- package/commands/brief.ts +130 -0
- package/commands/btw/btw.tsx +243 -0
- package/commands/btw/index.ts +13 -0
- package/commands/bughunter/index.js +1 -0
- package/commands/chrome/chrome.tsx +285 -0
- package/commands/chrome/index.ts +13 -0
- package/commands/clear/caches.ts +144 -0
- package/commands/clear/clear.ts +7 -0
- package/commands/clear/conversation.ts +251 -0
- package/commands/clear/index.ts +19 -0
- package/commands/color/color.ts +93 -0
- package/commands/color/index.ts +16 -0
- package/commands/commit-push-pr.ts +158 -0
- package/commands/commit.ts +92 -0
- package/commands/compact/compact.ts +287 -0
- package/commands/compact/index.ts +15 -0
- package/commands/config/config.tsx +7 -0
- package/commands/config/index.ts +11 -0
- package/commands/context/context-noninteractive.ts +325 -0
- package/commands/context/context.tsx +64 -0
- package/commands/context/index.ts +24 -0
- package/commands/copy/copy.tsx +371 -0
- package/commands/copy/index.ts +15 -0
- package/commands/cost/cost.ts +24 -0
- package/commands/cost/index.ts +23 -0
- package/commands/createMovedToPluginCommand.ts +65 -0
- package/commands/ctx_viz/index.js +1 -0
- package/commands/debug-tool-call/index.js +1 -0
- package/commands/desktop/desktop.tsx +9 -0
- package/commands/desktop/index.ts +26 -0
- package/commands/diff/diff.tsx +9 -0
- package/commands/diff/index.ts +8 -0
- package/commands/doctor/doctor.tsx +7 -0
- package/commands/doctor/index.ts +12 -0
- package/commands/effort/effort.tsx +183 -0
- package/commands/effort/index.ts +13 -0
- package/commands/env/index.js +1 -0
- package/commands/exit/exit.tsx +33 -0
- package/commands/exit/index.ts +12 -0
- package/commands/export/export.tsx +91 -0
- package/commands/export/index.ts +11 -0
- package/commands/extra-usage/extra-usage-core.ts +118 -0
- package/commands/extra-usage/extra-usage-noninteractive.ts +16 -0
- package/commands/extra-usage/extra-usage.tsx +17 -0
- package/commands/extra-usage/index.ts +31 -0
- package/commands/fast/fast.tsx +269 -0
- package/commands/fast/index.ts +26 -0
- package/commands/feedback/feedback.tsx +25 -0
- package/commands/feedback/index.ts +26 -0
- package/commands/files/files.ts +19 -0
- package/commands/files/index.ts +12 -0
- package/commands/good-claude/index.js +1 -0
- package/commands/heapdump/heapdump.ts +17 -0
- package/commands/heapdump/index.ts +12 -0
- package/commands/help/help.tsx +11 -0
- package/commands/help/index.ts +10 -0
- package/commands/hooks/hooks.tsx +13 -0
- package/commands/hooks/index.ts +11 -0
- package/commands/ide/ide.tsx +646 -0
- package/commands/ide/index.ts +11 -0
- package/commands/init-verifiers.ts +262 -0
- package/commands/init.ts +256 -0
- package/commands/insights.ts +3200 -0
- package/commands/install-github-app/ApiKeyStep.tsx +231 -0
- package/commands/install-github-app/CheckExistingSecretStep.tsx +190 -0
- package/commands/install-github-app/CheckGitHubStep.tsx +15 -0
- package/commands/install-github-app/ChooseRepoStep.tsx +211 -0
- package/commands/install-github-app/CreatingStep.tsx +65 -0
- package/commands/install-github-app/ErrorStep.tsx +85 -0
- package/commands/install-github-app/ExistingWorkflowStep.tsx +103 -0
- package/commands/install-github-app/InstallAppStep.tsx +94 -0
- package/commands/install-github-app/OAuthFlowStep.tsx +276 -0
- package/commands/install-github-app/SuccessStep.tsx +96 -0
- package/commands/install-github-app/WarningsStep.tsx +73 -0
- package/commands/install-github-app/index.ts +13 -0
- package/commands/install-github-app/install-github-app.tsx +587 -0
- package/commands/install-github-app/setupGitHubActions.ts +325 -0
- package/commands/install-slack-app/index.ts +12 -0
- package/commands/install-slack-app/install-slack-app.ts +30 -0
- package/commands/install.tsx +300 -0
- package/commands/issue/index.js +1 -0
- package/commands/keybindings/index.ts +13 -0
- package/commands/keybindings/keybindings.ts +53 -0
- package/commands/login/index.ts +14 -0
- package/commands/login/login.tsx +104 -0
- package/commands/logout/index.ts +10 -0
- package/commands/logout/logout.tsx +82 -0
- package/commands/mcp/addCommand.ts +280 -0
- package/commands/mcp/index.ts +12 -0
- package/commands/mcp/mcp.tsx +85 -0
- package/commands/mcp/xaaIdpCommand.ts +266 -0
- package/commands/memory/index.ts +10 -0
- package/commands/memory/memory.tsx +90 -0
- package/commands/mobile/index.ts +11 -0
- package/commands/mobile/mobile.tsx +274 -0
- package/commands/mock-limits/index.js +1 -0
- package/commands/model/index.ts +16 -0
- package/commands/model/model.tsx +297 -0
- package/commands/oauth-refresh/index.js +1 -0
- package/commands/onboarding/index.js +1 -0
- package/commands/output-style/index.ts +11 -0
- package/commands/output-style/output-style.tsx +7 -0
- package/commands/passes/index.ts +22 -0
- package/commands/passes/passes.tsx +24 -0
- package/commands/perf-issue/index.js +1 -0
- package/commands/permissions/index.ts +11 -0
- package/commands/permissions/permissions.tsx +10 -0
- package/commands/plan/index.ts +11 -0
- package/commands/plan/plan.tsx +122 -0
- package/commands/plugin/AddMarketplace.tsx +162 -0
- package/commands/plugin/BrowseMarketplace.tsx +802 -0
- package/commands/plugin/DiscoverPlugins.tsx +781 -0
- package/commands/plugin/ManageMarketplaces.tsx +838 -0
- package/commands/plugin/ManagePlugins.tsx +2215 -0
- package/commands/plugin/PluginErrors.tsx +124 -0
- package/commands/plugin/PluginOptionsDialog.tsx +357 -0
- package/commands/plugin/PluginOptionsFlow.tsx +135 -0
- package/commands/plugin/PluginSettings.tsx +1072 -0
- package/commands/plugin/PluginTrustWarning.tsx +32 -0
- package/commands/plugin/UnifiedInstalledCell.tsx +565 -0
- package/commands/plugin/ValidatePlugin.tsx +98 -0
- package/commands/plugin/index.tsx +11 -0
- package/commands/plugin/parseArgs.ts +103 -0
- package/commands/plugin/plugin.tsx +7 -0
- package/commands/plugin/pluginDetailsHelpers.tsx +117 -0
- package/commands/plugin/usePagination.ts +171 -0
- package/commands/pr_comments/index.ts +50 -0
- package/commands/privacy-settings/index.ts +14 -0
- package/commands/privacy-settings/privacy-settings.tsx +58 -0
- package/commands/rate-limit-options/index.ts +19 -0
- package/commands/rate-limit-options/rate-limit-options.tsx +210 -0
- package/commands/release-notes/index.ts +11 -0
- package/commands/release-notes/release-notes.ts +50 -0
- package/commands/reload-plugins/index.ts +18 -0
- package/commands/reload-plugins/reload-plugins.ts +61 -0
- package/commands/remote-env/index.ts +15 -0
- package/commands/remote-env/remote-env.tsx +7 -0
- package/commands/remote-setup/api.ts +182 -0
- package/commands/remote-setup/index.ts +20 -0
- package/commands/remote-setup/remote-setup.tsx +187 -0
- package/commands/rename/generateSessionName.ts +67 -0
- package/commands/rename/index.ts +12 -0
- package/commands/rename/rename.ts +87 -0
- package/commands/reset-limits/index.js +4 -0
- package/commands/resume/index.ts +12 -0
- package/commands/resume/resume.tsx +275 -0
- package/commands/review/UltrareviewOverageDialog.tsx +96 -0
- package/commands/review/reviewRemote.ts +316 -0
- package/commands/review/ultrareviewCommand.tsx +58 -0
- package/commands/review/ultrareviewEnabled.ts +14 -0
- package/commands/review.ts +57 -0
- package/commands/rewind/index.ts +13 -0
- package/commands/rewind/rewind.ts +13 -0
- package/commands/sandbox-toggle/index.ts +50 -0
- package/commands/sandbox-toggle/sandbox-toggle.tsx +83 -0
- package/commands/security-review.ts +243 -0
- package/commands/session/index.ts +16 -0
- package/commands/session/session.tsx +140 -0
- package/commands/share/index.js +1 -0
- package/commands/skills/index.ts +10 -0
- package/commands/skills/skills.tsx +8 -0
- package/commands/stats/index.ts +10 -0
- package/commands/stats/stats.tsx +7 -0
- package/commands/status/index.ts +12 -0
- package/commands/status/status.tsx +8 -0
- package/commands/statusline.tsx +24 -0
- package/commands/stickers/index.ts +11 -0
- package/commands/stickers/stickers.ts +16 -0
- package/commands/summary/index.js +1 -0
- package/commands/tag/index.ts +12 -0
- package/commands/tag/tag.tsx +215 -0
- package/commands/tasks/index.ts +11 -0
- package/commands/tasks/tasks.tsx +8 -0
- package/commands/teleport/index.js +1 -0
- package/commands/terminalSetup/index.ts +23 -0
- package/commands/terminalSetup/terminalSetup.tsx +531 -0
- package/commands/theme/index.ts +10 -0
- package/commands/theme/theme.tsx +57 -0
- package/commands/thinkback/index.ts +13 -0
- package/commands/thinkback/thinkback.tsx +554 -0
- package/commands/thinkback-play/index.ts +17 -0
- package/commands/thinkback-play/thinkback-play.ts +43 -0
- package/commands/ultraplan.tsx +471 -0
- package/commands/upgrade/index.ts +16 -0
- package/commands/upgrade/upgrade.tsx +38 -0
- package/commands/usage/index.ts +9 -0
- package/commands/usage/usage.tsx +7 -0
- package/commands/version.ts +22 -0
- package/commands/vim/index.ts +11 -0
- package/commands/vim/vim.ts +38 -0
- package/commands/voice/index.ts +20 -0
- package/commands/voice/voice.ts +150 -0
- package/commands.ts +754 -0
- package/components/AgentProgressLine.tsx +136 -0
- package/components/App.tsx +56 -0
- package/components/ApproveApiKey.tsx +123 -0
- package/components/AutoModeOptInDialog.tsx +142 -0
- package/components/AutoUpdater.tsx +198 -0
- package/components/AutoUpdaterWrapper.tsx +91 -0
- package/components/AwsAuthStatusBox.tsx +82 -0
- package/components/BaseTextInput.tsx +136 -0
- package/components/BashModeProgress.tsx +56 -0
- package/components/BridgeDialog.tsx +401 -0
- package/components/BypassPermissionsModeDialog.tsx +87 -0
- package/components/ChannelDowngradeDialog.tsx +102 -0
- package/components/ClaudeCodeHint/PluginHintMenu.tsx +78 -0
- package/components/ClaudeInChromeOnboarding.tsx +121 -0
- package/components/ClaudeMdExternalIncludesDialog.tsx +137 -0
- package/components/ClickableImageRef.tsx +73 -0
- package/components/CompactSummary.tsx +118 -0
- package/components/ConfigurableShortcutHint.tsx +57 -0
- package/components/ConsoleOAuthFlow.tsx +631 -0
- package/components/ContextSuggestions.tsx +47 -0
- package/components/ContextVisualization.tsx +489 -0
- package/components/CoordinatorAgentStatus.tsx +273 -0
- package/components/CostThresholdDialog.tsx +50 -0
- package/components/CtrlOToExpand.tsx +51 -0
- package/components/CustomSelect/SelectMulti.tsx +213 -0
- package/components/CustomSelect/index.ts +3 -0
- package/components/CustomSelect/option-map.ts +50 -0
- package/components/CustomSelect/select-input-option.tsx +488 -0
- package/components/CustomSelect/select-option.tsx +68 -0
- package/components/CustomSelect/select.tsx +690 -0
- package/components/CustomSelect/use-multi-select-state.ts +414 -0
- package/components/CustomSelect/use-select-input.ts +287 -0
- package/components/CustomSelect/use-select-navigation.ts +653 -0
- package/components/CustomSelect/use-select-state.ts +157 -0
- package/components/DesktopHandoff.tsx +193 -0
- package/components/DesktopUpsell/DesktopUpsellStartup.tsx +171 -0
- package/components/DevBar.tsx +49 -0
- package/components/DevChannelsDialog.tsx +105 -0
- package/components/DiagnosticsDisplay.tsx +95 -0
- package/components/EffortCallout.tsx +265 -0
- package/components/EffortIndicator.ts +42 -0
- package/components/ExitFlow.tsx +48 -0
- package/components/ExportDialog.tsx +128 -0
- package/components/FallbackToolUseErrorMessage.tsx +116 -0
- package/components/FallbackToolUseRejectedMessage.tsx +16 -0
- package/components/FastIcon.tsx +46 -0
- package/components/Feedback.tsx +592 -0
- package/components/FeedbackSurvey/FeedbackSurvey.tsx +174 -0
- package/components/FeedbackSurvey/FeedbackSurveyView.tsx +108 -0
- package/components/FeedbackSurvey/TranscriptSharePrompt.tsx +88 -0
- package/components/FeedbackSurvey/submitTranscriptShare.ts +112 -0
- package/components/FeedbackSurvey/useDebouncedDigitInput.ts +82 -0
- package/components/FeedbackSurvey/useFeedbackSurvey.tsx +296 -0
- package/components/FeedbackSurvey/useMemorySurvey.tsx +213 -0
- package/components/FeedbackSurvey/usePostCompactSurvey.tsx +206 -0
- package/components/FeedbackSurvey/useSurveyState.tsx +100 -0
- package/components/FileEditToolDiff.tsx +181 -0
- package/components/FileEditToolUpdatedMessage.tsx +124 -0
- package/components/FileEditToolUseRejectedMessage.tsx +170 -0
- package/components/FilePathLink.tsx +43 -0
- package/components/FullscreenLayout.tsx +637 -0
- package/components/GlobalSearchDialog.tsx +343 -0
- package/components/HelpV2/Commands.tsx +82 -0
- package/components/HelpV2/General.tsx +23 -0
- package/components/HelpV2/HelpV2.tsx +184 -0
- package/components/HighlightedCode/Fallback.tsx +193 -0
- package/components/HighlightedCode.tsx +190 -0
- package/components/HistorySearchDialog.tsx +118 -0
- package/components/IdeAutoConnectDialog.tsx +154 -0
- package/components/IdeOnboardingDialog.tsx +167 -0
- package/components/IdeStatusIndicator.tsx +58 -0
- package/components/IdleReturnDialog.tsx +118 -0
- package/components/InterruptedByUser.tsx +15 -0
- package/components/InvalidConfigDialog.tsx +156 -0
- package/components/InvalidSettingsDialog.tsx +89 -0
- package/components/KeybindingWarnings.tsx +55 -0
- package/components/LanguagePicker.tsx +86 -0
- package/components/LogSelector.tsx +1575 -0
- package/components/LogoV2/AnimatedAsterisk.tsx +50 -0
- package/components/LogoV2/AnimatedClawd.tsx +124 -0
- package/components/LogoV2/ChannelsNotice.tsx +266 -0
- package/components/LogoV2/Clawd.tsx +240 -0
- package/components/LogoV2/CondensedLogo.tsx +161 -0
- package/components/LogoV2/EmergencyTip.tsx +58 -0
- package/components/LogoV2/Feed.tsx +112 -0
- package/components/LogoV2/FeedColumn.tsx +59 -0
- package/components/LogoV2/GuestPassesUpsell.tsx +70 -0
- package/components/LogoV2/LogoV2.tsx +543 -0
- package/components/LogoV2/Opus1mMergeNotice.tsx +55 -0
- package/components/LogoV2/OverageCreditUpsell.tsx +166 -0
- package/components/LogoV2/VoiceModeNotice.tsx +68 -0
- package/components/LogoV2/WelcomeV2.tsx +433 -0
- package/components/LogoV2/feedConfigs.tsx +92 -0
- package/components/LspRecommendation/LspRecommendationMenu.tsx +88 -0
- package/components/MCPServerApprovalDialog.tsx +115 -0
- package/components/MCPServerDesktopImportDialog.tsx +203 -0
- package/components/MCPServerDialogCopy.tsx +15 -0
- package/components/MCPServerMultiselectDialog.tsx +133 -0
- package/components/ManagedSettingsSecurityDialog/ManagedSettingsSecurityDialog.tsx +149 -0
- package/components/ManagedSettingsSecurityDialog/utils.ts +144 -0
- package/components/Markdown.tsx +236 -0
- package/components/MarkdownTable.tsx +322 -0
- package/components/MemoryUsageIndicator.tsx +37 -0
- package/components/Message.tsx +627 -0
- package/components/MessageModel.tsx +43 -0
- package/components/MessageResponse.tsx +78 -0
- package/components/MessageRow.tsx +383 -0
- package/components/MessageSelector.tsx +831 -0
- package/components/MessageTimestamp.tsx +63 -0
- package/components/Messages.tsx +834 -0
- package/components/ModelPicker.tsx +448 -0
- package/components/NativeAutoUpdater.tsx +193 -0
- package/components/NotebookEditToolUseRejectedMessage.tsx +92 -0
- package/components/OffscreenFreeze.tsx +44 -0
- package/components/Onboarding.tsx +244 -0
- package/components/OutputStylePicker.tsx +112 -0
- package/components/PackageManagerAutoUpdater.tsx +104 -0
- package/components/Passes/Passes.tsx +184 -0
- package/components/PrBadge.tsx +97 -0
- package/components/PressEnterToContinue.tsx +15 -0
- package/components/PromptInput/HistorySearchInput.tsx +51 -0
- package/components/PromptInput/IssueFlagBanner.tsx +12 -0
- package/components/PromptInput/Notifications.tsx +332 -0
- package/components/PromptInput/PromptInput.tsx +2339 -0
- package/components/PromptInput/PromptInputFooter.tsx +191 -0
- package/components/PromptInput/PromptInputFooterLeftSide.tsx +517 -0
- package/components/PromptInput/PromptInputFooterSuggestions.tsx +293 -0
- package/components/PromptInput/PromptInputHelpMenu.tsx +358 -0
- package/components/PromptInput/PromptInputModeIndicator.tsx +93 -0
- package/components/PromptInput/PromptInputQueuedCommands.tsx +117 -0
- package/components/PromptInput/PromptInputStashNotice.tsx +25 -0
- package/components/PromptInput/SandboxPromptFooterHint.tsx +64 -0
- package/components/PromptInput/ShimmeredInput.tsx +143 -0
- package/components/PromptInput/VoiceIndicator.tsx +137 -0
- package/components/PromptInput/inputModes.ts +33 -0
- package/components/PromptInput/inputPaste.ts +90 -0
- package/components/PromptInput/useMaybeTruncateInput.ts +58 -0
- package/components/PromptInput/usePromptInputPlaceholder.ts +76 -0
- package/components/PromptInput/useShowFastIconHint.ts +31 -0
- package/components/PromptInput/useSwarmBanner.ts +155 -0
- package/components/PromptInput/utils.ts +60 -0
- package/components/QuickOpenDialog.tsx +244 -0
- package/components/RemoteCallout.tsx +76 -0
- package/components/RemoteEnvironmentDialog.tsx +340 -0
- package/components/ResumeTask.tsx +268 -0
- package/components/SandboxViolationExpandedView.tsx +99 -0
- package/components/ScrollKeybindingHandler.tsx +1012 -0
- package/components/SearchBox.tsx +72 -0
- package/components/SentryErrorBoundary.ts +28 -0
- package/components/SessionBackgroundHint.tsx +108 -0
- package/components/SessionPreview.tsx +194 -0
- package/components/Settings/Config.tsx +1822 -0
- package/components/Settings/Settings.tsx +137 -0
- package/components/Settings/Status.tsx +241 -0
- package/components/Settings/Usage.tsx +377 -0
- package/components/ShowInIDEPrompt.tsx +170 -0
- package/components/SkillImprovementSurvey.tsx +152 -0
- package/components/Spinner/FlashingChar.tsx +61 -0
- package/components/Spinner/GlimmerMessage.tsx +328 -0
- package/components/Spinner/ShimmerChar.tsx +36 -0
- package/components/Spinner/SpinnerAnimationRow.tsx +265 -0
- package/components/Spinner/SpinnerGlyph.tsx +80 -0
- package/components/Spinner/TeammateSpinnerLine.tsx +233 -0
- package/components/Spinner/TeammateSpinnerTree.tsx +272 -0
- package/components/Spinner/index.ts +10 -0
- package/components/Spinner/teammateSelectHint.ts +1 -0
- package/components/Spinner/useShimmerAnimation.ts +31 -0
- package/components/Spinner/useStalledAnimation.ts +75 -0
- package/components/Spinner/utils.ts +84 -0
- package/components/Spinner.tsx +562 -0
- package/components/Stats.tsx +1228 -0
- package/components/StatusLine.tsx +324 -0
- package/components/StatusNotices.tsx +55 -0
- package/components/StructuredDiff/Fallback.tsx +487 -0
- package/components/StructuredDiff/colorDiff.ts +37 -0
- package/components/StructuredDiff.tsx +190 -0
- package/components/StructuredDiffList.tsx +30 -0
- package/components/TagTabs.tsx +139 -0
- package/components/TaskListV2.tsx +378 -0
- package/components/TeammateViewHeader.tsx +82 -0
- package/components/TeleportError.tsx +189 -0
- package/components/TeleportProgress.tsx +140 -0
- package/components/TeleportRepoMismatchDialog.tsx +104 -0
- package/components/TeleportResumeWrapper.tsx +167 -0
- package/components/TeleportStash.tsx +116 -0
- package/components/TextInput.tsx +124 -0
- package/components/ThemePicker.tsx +333 -0
- package/components/ThinkingToggle.tsx +153 -0
- package/components/TokenWarning.tsx +179 -0
- package/components/ToolUseLoader.tsx +42 -0
- package/components/TrustDialog/TrustDialog.tsx +290 -0
- package/components/TrustDialog/utils.ts +245 -0
- package/components/ValidationErrorsList.tsx +148 -0
- package/components/VimTextInput.tsx +140 -0
- package/components/VirtualMessageList.tsx +1082 -0
- package/components/WorkflowMultiselectDialog.tsx +128 -0
- package/components/WorktreeExitDialog.tsx +231 -0
- package/components/agents/AgentDetail.tsx +220 -0
- package/components/agents/AgentEditor.tsx +178 -0
- package/components/agents/AgentNavigationFooter.tsx +26 -0
- package/components/agents/AgentsList.tsx +440 -0
- package/components/agents/AgentsMenu.tsx +800 -0
- package/components/agents/ColorPicker.tsx +112 -0
- package/components/agents/ModelSelector.tsx +68 -0
- package/components/agents/ToolSelector.tsx +562 -0
- package/components/agents/agentFileUtils.ts +272 -0
- package/components/agents/generateAgent.ts +197 -0
- package/components/agents/new-agent-creation/CreateAgentWizard.tsx +97 -0
- package/components/agents/new-agent-creation/wizard-steps/ColorStep.tsx +84 -0
- package/components/agents/new-agent-creation/wizard-steps/ConfirmStep.tsx +378 -0
- package/components/agents/new-agent-creation/wizard-steps/ConfirmStepWrapper.tsx +74 -0
- package/components/agents/new-agent-creation/wizard-steps/DescriptionStep.tsx +123 -0
- package/components/agents/new-agent-creation/wizard-steps/GenerateStep.tsx +143 -0
- package/components/agents/new-agent-creation/wizard-steps/LocationStep.tsx +80 -0
- package/components/agents/new-agent-creation/wizard-steps/MemoryStep.tsx +113 -0
- package/components/agents/new-agent-creation/wizard-steps/MethodStep.tsx +80 -0
- package/components/agents/new-agent-creation/wizard-steps/ModelStep.tsx +52 -0
- package/components/agents/new-agent-creation/wizard-steps/PromptStep.tsx +128 -0
- package/components/agents/new-agent-creation/wizard-steps/ToolsStep.tsx +61 -0
- package/components/agents/new-agent-creation/wizard-steps/TypeStep.tsx +103 -0
- package/components/agents/types.ts +27 -0
- package/components/agents/utils.ts +18 -0
- package/components/agents/validateAgent.ts +109 -0
- package/components/design-system/Byline.tsx +77 -0
- package/components/design-system/Dialog.tsx +138 -0
- package/components/design-system/Divider.tsx +149 -0
- package/components/design-system/FuzzyPicker.tsx +312 -0
- package/components/design-system/KeyboardShortcutHint.tsx +81 -0
- package/components/design-system/ListItem.tsx +244 -0
- package/components/design-system/LoadingState.tsx +94 -0
- package/components/design-system/Pane.tsx +77 -0
- package/components/design-system/ProgressBar.tsx +86 -0
- package/components/design-system/Ratchet.tsx +80 -0
- package/components/design-system/StatusIcon.tsx +95 -0
- package/components/design-system/Tabs.tsx +340 -0
- package/components/design-system/ThemeProvider.tsx +170 -0
- package/components/design-system/ThemedBox.tsx +156 -0
- package/components/design-system/ThemedText.tsx +124 -0
- package/components/design-system/color.ts +30 -0
- package/components/diff/DiffDetailView.tsx +281 -0
- package/components/diff/DiffDialog.tsx +383 -0
- package/components/diff/DiffFileList.tsx +292 -0
- package/components/grove/Grove.tsx +463 -0
- package/components/hooks/HooksConfigMenu.tsx +578 -0
- package/components/hooks/PromptDialog.tsx +90 -0
- package/components/hooks/SelectEventMode.tsx +127 -0
- package/components/hooks/SelectHookMode.tsx +112 -0
- package/components/hooks/SelectMatcherMode.tsx +144 -0
- package/components/hooks/ViewHookMode.tsx +199 -0
- package/components/mcp/CapabilitiesSection.tsx +61 -0
- package/components/mcp/ElicitationDialog.tsx +1169 -0
- package/components/mcp/MCPAgentServerMenu.tsx +183 -0
- package/components/mcp/MCPListPanel.tsx +504 -0
- package/components/mcp/MCPReconnect.tsx +167 -0
- package/components/mcp/MCPRemoteServerMenu.tsx +649 -0
- package/components/mcp/MCPSettings.tsx +398 -0
- package/components/mcp/MCPStdioServerMenu.tsx +177 -0
- package/components/mcp/MCPToolDetailView.tsx +212 -0
- package/components/mcp/MCPToolListView.tsx +141 -0
- package/components/mcp/McpParsingWarnings.tsx +213 -0
- package/components/mcp/index.ts +9 -0
- package/components/mcp/utils/reconnectHelpers.tsx +49 -0
- package/components/memory/MemoryFileSelector.tsx +438 -0
- package/components/memory/MemoryUpdateNotification.tsx +45 -0
- package/components/messageActions.tsx +450 -0
- package/components/messages/AdvisorMessage.tsx +158 -0
- package/components/messages/AssistantRedactedThinkingMessage.tsx +31 -0
- package/components/messages/AssistantTextMessage.tsx +270 -0
- package/components/messages/AssistantThinkingMessage.tsx +86 -0
- package/components/messages/AssistantToolUseMessage.tsx +368 -0
- package/components/messages/AttachmentMessage.tsx +536 -0
- package/components/messages/CollapsedReadSearchContent.tsx +484 -0
- package/components/messages/CompactBoundaryMessage.tsx +18 -0
- package/components/messages/GroupedToolUseContent.tsx +58 -0
- package/components/messages/HighlightedThinkingText.tsx +162 -0
- package/components/messages/HookProgressMessage.tsx +116 -0
- package/components/messages/PlanApprovalMessage.tsx +222 -0
- package/components/messages/RateLimitMessage.tsx +161 -0
- package/components/messages/ShutdownMessage.tsx +132 -0
- package/components/messages/SystemAPIErrorMessage.tsx +141 -0
- package/components/messages/SystemTextMessage.tsx +827 -0
- package/components/messages/TaskAssignmentMessage.tsx +76 -0
- package/components/messages/UserAgentNotificationMessage.tsx +83 -0
- package/components/messages/UserBashInputMessage.tsx +58 -0
- package/components/messages/UserBashOutputMessage.tsx +54 -0
- package/components/messages/UserChannelMessage.tsx +137 -0
- package/components/messages/UserCommandMessage.tsx +108 -0
- package/components/messages/UserImageMessage.tsx +59 -0
- package/components/messages/UserLocalCommandOutputMessage.tsx +167 -0
- package/components/messages/UserMemoryInputMessage.tsx +75 -0
- package/components/messages/UserPlanMessage.tsx +42 -0
- package/components/messages/UserPromptMessage.tsx +80 -0
- package/components/messages/UserResourceUpdateMessage.tsx +121 -0
- package/components/messages/UserTeammateMessage.tsx +206 -0
- package/components/messages/UserTextMessage.tsx +275 -0
- package/components/messages/UserToolResultMessage/RejectedPlanMessage.tsx +31 -0
- package/components/messages/UserToolResultMessage/RejectedToolUseMessage.tsx +16 -0
- package/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +16 -0
- package/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +103 -0
- package/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +95 -0
- package/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +106 -0
- package/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +104 -0
- package/components/messages/UserToolResultMessage/utils.tsx +44 -0
- package/components/messages/nullRenderingAttachments.ts +70 -0
- package/components/messages/teamMemCollapsed.tsx +140 -0
- package/components/messages/teamMemSaved.ts +19 -0
- package/components/permissions/AskUserQuestionPermissionRequest/AskUserQuestionPermissionRequest.tsx +645 -0
- package/components/permissions/AskUserQuestionPermissionRequest/PreviewBox.tsx +229 -0
- package/components/permissions/AskUserQuestionPermissionRequest/PreviewQuestionView.tsx +328 -0
- package/components/permissions/AskUserQuestionPermissionRequest/QuestionNavigationBar.tsx +178 -0
- package/components/permissions/AskUserQuestionPermissionRequest/QuestionView.tsx +465 -0
- package/components/permissions/AskUserQuestionPermissionRequest/SubmitQuestionsView.tsx +144 -0
- package/components/permissions/AskUserQuestionPermissionRequest/use-multiple-choice-state.ts +179 -0
- package/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +482 -0
- package/components/permissions/BashPermissionRequest/bashToolUseOptions.tsx +147 -0
- package/components/permissions/ComputerUseApproval/ComputerUseApproval.tsx +441 -0
- package/components/permissions/EnterPlanModePermissionRequest/EnterPlanModePermissionRequest.tsx +122 -0
- package/components/permissions/ExitPlanModePermissionRequest/ExitPlanModePermissionRequest.tsx +768 -0
- package/components/permissions/FallbackPermissionRequest.tsx +333 -0
- package/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +182 -0
- package/components/permissions/FilePermissionDialog/FilePermissionDialog.tsx +204 -0
- package/components/permissions/FilePermissionDialog/ideDiffConfig.ts +42 -0
- package/components/permissions/FilePermissionDialog/permissionOptions.tsx +177 -0
- package/components/permissions/FilePermissionDialog/useFilePermissionDialog.ts +212 -0
- package/components/permissions/FilePermissionDialog/usePermissionHandler.ts +185 -0
- package/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +161 -0
- package/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +89 -0
- package/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +115 -0
- package/components/permissions/NotebookEditPermissionRequest/NotebookEditPermissionRequest.tsx +166 -0
- package/components/permissions/NotebookEditPermissionRequest/NotebookEditToolDiff.tsx +235 -0
- package/components/permissions/PermissionDecisionDebugInfo.tsx +460 -0
- package/components/permissions/PermissionDialog.tsx +72 -0
- package/components/permissions/PermissionExplanation.tsx +272 -0
- package/components/permissions/PermissionPrompt.tsx +336 -0
- package/components/permissions/PermissionRequest.tsx +217 -0
- package/components/permissions/PermissionRequestTitle.tsx +66 -0
- package/components/permissions/PermissionRuleExplanation.tsx +121 -0
- package/components/permissions/PowerShellPermissionRequest/PowerShellPermissionRequest.tsx +235 -0
- package/components/permissions/PowerShellPermissionRequest/powershellToolUseOptions.tsx +91 -0
- package/components/permissions/SandboxPermissionRequest.tsx +163 -0
- package/components/permissions/SedEditPermissionRequest/SedEditPermissionRequest.tsx +230 -0
- package/components/permissions/SkillPermissionRequest/SkillPermissionRequest.tsx +369 -0
- package/components/permissions/WebFetchPermissionRequest/WebFetchPermissionRequest.tsx +258 -0
- package/components/permissions/WorkerBadge.tsx +49 -0
- package/components/permissions/WorkerPendingPermission.tsx +105 -0
- package/components/permissions/hooks.ts +209 -0
- package/components/permissions/rules/AddPermissionRules.tsx +180 -0
- package/components/permissions/rules/AddWorkspaceDirectory.tsx +340 -0
- package/components/permissions/rules/PermissionRuleDescription.tsx +76 -0
- package/components/permissions/rules/PermissionRuleInput.tsx +138 -0
- package/components/permissions/rules/PermissionRuleList.tsx +1179 -0
- package/components/permissions/rules/RecentDenialsTab.tsx +207 -0
- package/components/permissions/rules/RemoveWorkspaceDirectory.tsx +110 -0
- package/components/permissions/rules/WorkspaceTab.tsx +150 -0
- package/components/permissions/shellPermissionHelpers.tsx +164 -0
- package/components/permissions/useShellPermissionFeedback.ts +148 -0
- package/components/permissions/utils.ts +25 -0
- package/components/sandbox/SandboxConfigTab.tsx +45 -0
- package/components/sandbox/SandboxDependenciesTab.tsx +120 -0
- package/components/sandbox/SandboxDoctorSection.tsx +46 -0
- package/components/sandbox/SandboxOverridesTab.tsx +193 -0
- package/components/sandbox/SandboxSettings.tsx +296 -0
- package/components/shell/ExpandShellOutputContext.tsx +36 -0
- package/components/shell/OutputLine.tsx +118 -0
- package/components/shell/ShellProgressMessage.tsx +150 -0
- package/components/shell/ShellTimeDisplay.tsx +74 -0
- package/components/skills/SkillsMenu.tsx +237 -0
- package/components/tasks/AsyncAgentDetailDialog.tsx +229 -0
- package/components/tasks/BackgroundTask.tsx +345 -0
- package/components/tasks/BackgroundTaskStatus.tsx +429 -0
- package/components/tasks/BackgroundTasksDialog.tsx +652 -0
- package/components/tasks/DreamDetailDialog.tsx +251 -0
- package/components/tasks/InProcessTeammateDetailDialog.tsx +266 -0
- package/components/tasks/RemoteSessionDetailDialog.tsx +904 -0
- package/components/tasks/RemoteSessionProgress.tsx +243 -0
- package/components/tasks/ShellDetailDialog.tsx +404 -0
- package/components/tasks/ShellProgress.tsx +87 -0
- package/components/tasks/renderToolActivity.tsx +33 -0
- package/components/tasks/taskStatusUtils.tsx +107 -0
- package/components/teams/TeamStatus.tsx +80 -0
- package/components/teams/TeamsDialog.tsx +715 -0
- package/components/ui/OrderedList.tsx +71 -0
- package/components/ui/OrderedListItem.tsx +45 -0
- package/components/ui/TreeSelect.tsx +397 -0
- package/components/wizard/WizardDialogLayout.tsx +65 -0
- package/components/wizard/WizardNavigationFooter.tsx +24 -0
- package/components/wizard/WizardProvider.tsx +213 -0
- package/components/wizard/index.ts +9 -0
- package/components/wizard/useWizard.ts +13 -0
- package/constants/apiLimits.ts +94 -0
- package/constants/betas.ts +52 -0
- package/constants/common.ts +33 -0
- package/constants/cyberRiskInstruction.ts +24 -0
- package/constants/errorIds.ts +15 -0
- package/constants/figures.ts +45 -0
- package/constants/files.ts +156 -0
- package/constants/github-app.ts +144 -0
- package/constants/keys.ts +11 -0
- package/constants/messages.ts +1 -0
- package/constants/oauth.ts +234 -0
- package/constants/outputStyles.ts +216 -0
- package/constants/product.ts +76 -0
- package/constants/prompts.ts +914 -0
- package/constants/spinnerVerbs.ts +204 -0
- package/constants/system.ts +95 -0
- package/constants/systemPromptSections.ts +68 -0
- package/constants/toolLimits.ts +56 -0
- package/constants/tools.ts +112 -0
- package/constants/turnCompletionVerbs.ts +12 -0
- package/constants/xml.ts +86 -0
- package/context/QueuedMessageContext.tsx +63 -0
- package/context/fpsMetrics.tsx +30 -0
- package/context/mailbox.tsx +38 -0
- package/context/modalContext.tsx +58 -0
- package/context/notifications.tsx +240 -0
- package/context/overlayContext.tsx +151 -0
- package/context/promptOverlayContext.tsx +125 -0
- package/context/stats.tsx +220 -0
- package/context/voice.tsx +88 -0
- package/context.ts +189 -0
- package/cost-tracker.ts +323 -0
- package/costHook.ts +22 -0
- package/dialogLaunchers.tsx +133 -0
- package/entrypoints/agentSdkTypes.ts +443 -0
- package/entrypoints/cli.tsx +310 -0
- package/entrypoints/init.ts +340 -0
- package/entrypoints/mcp.ts +196 -0
- package/entrypoints/sandboxTypes.ts +156 -0
- package/entrypoints/sdk/controlSchemas.ts +663 -0
- package/entrypoints/sdk/coreSchemas.ts +1889 -0
- package/entrypoints/sdk/coreTypes.generated.ts +73 -0
- package/entrypoints/sdk/coreTypes.ts +62 -0
- package/entrypoints/sdk/runtimeTypes.ts +74 -0
- package/entrypoints/sdk/toolTypes.ts +12 -0
- package/global.d.ts +18 -0
- package/history.ts +464 -0
- package/hooks/fileSuggestions.ts +811 -0
- package/hooks/notifs/useAutoModeUnavailableNotification.ts +56 -0
- package/hooks/notifs/useCanSwitchToExistingSubscription.tsx +60 -0
- package/hooks/notifs/useDeprecationWarningNotification.tsx +44 -0
- package/hooks/notifs/useFastModeNotification.tsx +162 -0
- package/hooks/notifs/useIDEStatusIndicator.tsx +186 -0
- package/hooks/notifs/useInstallMessages.tsx +26 -0
- package/hooks/notifs/useLspInitializationNotification.tsx +143 -0
- package/hooks/notifs/useMcpConnectivityStatus.tsx +88 -0
- package/hooks/notifs/useModelMigrationNotifications.tsx +52 -0
- package/hooks/notifs/useNpmDeprecationNotification.tsx +25 -0
- package/hooks/notifs/usePluginAutoupdateNotification.tsx +83 -0
- package/hooks/notifs/usePluginInstallationStatus.tsx +128 -0
- package/hooks/notifs/useRateLimitWarningNotification.tsx +114 -0
- package/hooks/notifs/useSettingsErrors.tsx +69 -0
- package/hooks/notifs/useStartupNotification.ts +41 -0
- package/hooks/notifs/useTeammateShutdownNotification.ts +78 -0
- package/hooks/renderPlaceholder.ts +51 -0
- package/hooks/toolPermission/PermissionContext.ts +388 -0
- package/hooks/toolPermission/handlers/coordinatorHandler.ts +65 -0
- package/hooks/toolPermission/handlers/interactiveHandler.ts +536 -0
- package/hooks/toolPermission/handlers/swarmWorkerHandler.ts +159 -0
- package/hooks/toolPermission/permissionLogging.ts +238 -0
- package/hooks/unifiedSuggestions.ts +202 -0
- package/hooks/useAfterFirstRender.ts +17 -0
- package/hooks/useApiKeyVerification.ts +84 -0
- package/hooks/useArrowKeyHistory.tsx +229 -0
- package/hooks/useAssistantHistory.ts +250 -0
- package/hooks/useAwaySummary.ts +125 -0
- package/hooks/useBackgroundTaskNavigation.ts +251 -0
- package/hooks/useBlink.ts +34 -0
- package/hooks/useCanUseTool.tsx +204 -0
- package/hooks/useCancelRequest.ts +276 -0
- package/hooks/useChromeExtensionNotification.tsx +50 -0
- package/hooks/useClaudeCodeHintRecommendation.tsx +129 -0
- package/hooks/useClipboardImageHint.ts +77 -0
- package/hooks/useCommandKeybindings.tsx +108 -0
- package/hooks/useCommandQueue.ts +15 -0
- package/hooks/useCopyOnSelect.ts +98 -0
- package/hooks/useDeferredHookMessages.ts +46 -0
- package/hooks/useDiffData.ts +110 -0
- package/hooks/useDiffInIDE.ts +379 -0
- package/hooks/useDirectConnect.ts +229 -0
- package/hooks/useDoublePress.ts +62 -0
- package/hooks/useDynamicConfig.ts +22 -0
- package/hooks/useElapsedTime.ts +37 -0
- package/hooks/useExitOnCtrlCD.ts +95 -0
- package/hooks/useExitOnCtrlCDWithKeybindings.ts +24 -0
- package/hooks/useFileHistorySnapshotInit.ts +25 -0
- package/hooks/useGlobalKeybindings.tsx +249 -0
- package/hooks/useHistorySearch.ts +303 -0
- package/hooks/useIDEIntegration.tsx +70 -0
- package/hooks/useIdeAtMentioned.ts +76 -0
- package/hooks/useIdeConnectionStatus.ts +33 -0
- package/hooks/useIdeLogging.ts +41 -0
- package/hooks/useIdeSelection.ts +150 -0
- package/hooks/useInboxPoller.ts +969 -0
- package/hooks/useInputBuffer.ts +132 -0
- package/hooks/useIssueFlagBanner.ts +133 -0
- package/hooks/useLogMessages.ts +119 -0
- package/hooks/useLspPluginRecommendation.tsx +194 -0
- package/hooks/useMailboxBridge.ts +21 -0
- package/hooks/useMainLoopModel.ts +34 -0
- package/hooks/useManagePlugins.ts +304 -0
- package/hooks/useMemoryUsage.ts +39 -0
- package/hooks/useMergedClients.ts +23 -0
- package/hooks/useMergedCommands.ts +15 -0
- package/hooks/useMergedTools.ts +44 -0
- package/hooks/useMinDisplayTime.ts +35 -0
- package/hooks/useNotifyAfterTimeout.ts +65 -0
- package/hooks/useOfficialMarketplaceNotification.tsx +48 -0
- package/hooks/usePasteHandler.ts +285 -0
- package/hooks/usePluginRecommendationBase.tsx +105 -0
- package/hooks/usePrStatus.ts +106 -0
- package/hooks/usePromptSuggestion.ts +177 -0
- package/hooks/usePromptsFromClaudeInChrome.tsx +71 -0
- package/hooks/useQueueProcessor.ts +68 -0
- package/hooks/useRemoteSession.ts +605 -0
- package/hooks/useReplBridge.tsx +723 -0
- package/hooks/useSSHSession.ts +241 -0
- package/hooks/useScheduledTasks.ts +139 -0
- package/hooks/useSearchInput.ts +364 -0
- package/hooks/useSessionBackgrounding.ts +158 -0
- package/hooks/useSettings.ts +17 -0
- package/hooks/useSettingsChange.ts +25 -0
- package/hooks/useSkillImprovementSurvey.ts +105 -0
- package/hooks/useSkillsChange.ts +62 -0
- package/hooks/useSwarmInitialization.ts +81 -0
- package/hooks/useSwarmPermissionPoller.ts +330 -0
- package/hooks/useTaskListWatcher.ts +221 -0
- package/hooks/useTasksV2.ts +250 -0
- package/hooks/useTeammateViewAutoExit.ts +63 -0
- package/hooks/useTeleportResume.tsx +85 -0
- package/hooks/useTerminalSize.ts +15 -0
- package/hooks/useTextInput.ts +529 -0
- package/hooks/useTimeout.ts +14 -0
- package/hooks/useTurnDiffs.ts +213 -0
- package/hooks/useTypeahead.tsx +1385 -0
- package/hooks/useUpdateNotification.ts +34 -0
- package/hooks/useVimInput.ts +316 -0
- package/hooks/useVirtualScroll.ts +721 -0
- package/hooks/useVoice.ts +1144 -0
- package/hooks/useVoiceEnabled.ts +25 -0
- package/hooks/useVoiceIntegration.tsx +677 -0
- package/ink/Ansi.tsx +292 -0
- package/ink/bidi.ts +139 -0
- package/ink/clearTerminal.ts +74 -0
- package/ink/colorize.ts +231 -0
- package/ink/components/AlternateScreen.tsx +80 -0
- package/ink/components/App.tsx +658 -0
- package/ink/components/AppContext.ts +21 -0
- package/ink/components/Box.tsx +214 -0
- package/ink/components/Button.tsx +192 -0
- package/ink/components/ClockContext.tsx +112 -0
- package/ink/components/CursorDeclarationContext.ts +32 -0
- package/ink/components/ErrorOverview.tsx +109 -0
- package/ink/components/Link.tsx +42 -0
- package/ink/components/Newline.tsx +39 -0
- package/ink/components/NoSelect.tsx +68 -0
- package/ink/components/RawAnsi.tsx +57 -0
- package/ink/components/ScrollBox.tsx +237 -0
- package/ink/components/Spacer.tsx +20 -0
- package/ink/components/StdinContext.ts +49 -0
- package/ink/components/TerminalFocusContext.tsx +52 -0
- package/ink/components/TerminalSizeContext.tsx +7 -0
- package/ink/components/Text.tsx +254 -0
- package/ink/constants.ts +2 -0
- package/ink/dom.ts +484 -0
- package/ink/events/click-event.ts +38 -0
- package/ink/events/dispatcher.ts +235 -0
- package/ink/events/emitter.ts +39 -0
- package/ink/events/event-handlers.ts +73 -0
- package/ink/events/event.ts +11 -0
- package/ink/events/focus-event.ts +21 -0
- package/ink/events/input-event.ts +205 -0
- package/ink/events/keyboard-event.ts +51 -0
- package/ink/events/terminal-event.ts +107 -0
- package/ink/events/terminal-focus-event.ts +19 -0
- package/ink/focus.ts +181 -0
- package/ink/frame.ts +124 -0
- package/ink/get-max-width.ts +27 -0
- package/ink/global.d.ts +14 -0
- package/ink/hit-test.ts +130 -0
- package/ink/hooks/use-animation-frame.ts +57 -0
- package/ink/hooks/use-app.ts +8 -0
- package/ink/hooks/use-declared-cursor.ts +73 -0
- package/ink/hooks/use-input.ts +92 -0
- package/ink/hooks/use-interval.ts +67 -0
- package/ink/hooks/use-search-highlight.ts +53 -0
- package/ink/hooks/use-selection.ts +104 -0
- package/ink/hooks/use-stdin.ts +8 -0
- package/ink/hooks/use-tab-status.ts +72 -0
- package/ink/hooks/use-terminal-focus.ts +16 -0
- package/ink/hooks/use-terminal-title.ts +31 -0
- package/ink/hooks/use-terminal-viewport.ts +96 -0
- package/ink/ink.tsx +1723 -0
- package/ink/instances.ts +10 -0
- package/ink/layout/engine.ts +6 -0
- package/ink/layout/geometry.ts +97 -0
- package/ink/layout/node.ts +152 -0
- package/ink/layout/yoga.ts +308 -0
- package/ink/line-width-cache.ts +24 -0
- package/ink/log-update.ts +773 -0
- package/ink/measure-element.ts +23 -0
- package/ink/measure-text.ts +47 -0
- package/ink/node-cache.ts +54 -0
- package/ink/optimizer.ts +93 -0
- package/ink/output.ts +797 -0
- package/ink/parse-keypress.ts +801 -0
- package/ink/reconciler.ts +512 -0
- package/ink/render-border.ts +231 -0
- package/ink/render-node-to-output.ts +1462 -0
- package/ink/render-to-screen.ts +231 -0
- package/ink/renderer.ts +178 -0
- package/ink/root.ts +184 -0
- package/ink/screen.ts +1486 -0
- package/ink/searchHighlight.ts +93 -0
- package/ink/selection.ts +917 -0
- package/ink/squash-text-nodes.ts +92 -0
- package/ink/stringWidth.ts +222 -0
- package/ink/styles.ts +771 -0
- package/ink/supports-hyperlinks.ts +57 -0
- package/ink/tabstops.ts +46 -0
- package/ink/terminal-focus-state.ts +47 -0
- package/ink/terminal-querier.ts +212 -0
- package/ink/terminal.ts +248 -0
- package/ink/termio/ansi.ts +75 -0
- package/ink/termio/csi.ts +319 -0
- package/ink/termio/dec.ts +60 -0
- package/ink/termio/esc.ts +67 -0
- package/ink/termio/osc.ts +493 -0
- package/ink/termio/parser.ts +394 -0
- package/ink/termio/sgr.ts +308 -0
- package/ink/termio/tokenize.ts +319 -0
- package/ink/termio/types.ts +236 -0
- package/ink/termio.ts +42 -0
- package/ink/useTerminalNotification.ts +126 -0
- package/ink/warn.ts +9 -0
- package/ink/widest-line.ts +19 -0
- package/ink/wrap-text.ts +74 -0
- package/ink/wrapAnsi.ts +20 -0
- package/ink.ts +85 -0
- package/interactiveHelpers.tsx +366 -0
- package/main.tsx +4702 -0
- package/package.json +95 -0
- package/projectOnboardingState.ts +83 -0
- package/query/config.ts +46 -0
- package/query/deps.ts +40 -0
- package/query/stopHooks.ts +473 -0
- package/query/tokenBudget.ts +93 -0
- package/query.ts +1729 -0
- package/replLauncher.tsx +23 -0
- package/services/AgentSummary/agentSummary.ts +179 -0
- package/services/MagicDocs/magicDocs.ts +254 -0
- package/services/MagicDocs/prompts.ts +127 -0
- package/services/PromptSuggestion/promptSuggestion.ts +523 -0
- package/services/PromptSuggestion/speculation.ts +991 -0
- package/services/SessionMemory/prompts.ts +324 -0
- package/services/SessionMemory/sessionMemory.ts +495 -0
- package/services/SessionMemory/sessionMemoryUtils.ts +207 -0
- package/services/analytics/config.ts +38 -0
- package/services/analytics/datadog.ts +307 -0
- package/services/analytics/firstPartyEventLogger.ts +449 -0
- package/services/analytics/firstPartyEventLoggingExporter.ts +806 -0
- package/services/analytics/growthbook.ts +1155 -0
- package/services/analytics/index.ts +173 -0
- package/services/analytics/metadata.ts +973 -0
- package/services/analytics/sink.ts +114 -0
- package/services/analytics/sinkKillswitch.ts +25 -0
- package/services/api/adminRequests.ts +119 -0
- package/services/api/bootstrap.ts +141 -0
- package/services/api/claude.ts +3419 -0
- package/services/api/client.ts +389 -0
- package/services/api/dumpPrompts.ts +226 -0
- package/services/api/emptyUsage.ts +22 -0
- package/services/api/errorUtils.ts +260 -0
- package/services/api/errors.ts +1207 -0
- package/services/api/filesApi.ts +748 -0
- package/services/api/firstTokenDate.ts +60 -0
- package/services/api/grove.ts +357 -0
- package/services/api/logging.ts +788 -0
- package/services/api/metricsOptOut.ts +159 -0
- package/services/api/overageCreditGrant.ts +137 -0
- package/services/api/promptCacheBreakDetection.ts +727 -0
- package/services/api/referral.ts +281 -0
- package/services/api/sessionIngress.ts +514 -0
- package/services/api/ultrareviewQuota.ts +38 -0
- package/services/api/usage.ts +63 -0
- package/services/api/withRetry.ts +822 -0
- package/services/autoDream/autoDream.ts +324 -0
- package/services/autoDream/config.ts +21 -0
- package/services/autoDream/consolidationLock.ts +140 -0
- package/services/autoDream/consolidationPrompt.ts +65 -0
- package/services/awaySummary.ts +74 -0
- package/services/claudeAiLimits.ts +515 -0
- package/services/claudeAiLimitsHook.ts +23 -0
- package/services/compact/apiMicrocompact.ts +153 -0
- package/services/compact/autoCompact.ts +351 -0
- package/services/compact/compact.ts +1705 -0
- package/services/compact/compactWarningHook.ts +16 -0
- package/services/compact/compactWarningState.ts +18 -0
- package/services/compact/grouping.ts +63 -0
- package/services/compact/microCompact.ts +530 -0
- package/services/compact/postCompactCleanup.ts +77 -0
- package/services/compact/prompt.ts +374 -0
- package/services/compact/sessionMemoryCompact.ts +630 -0
- package/services/compact/timeBasedMCConfig.ts +43 -0
- package/services/diagnosticTracking.ts +397 -0
- package/services/extractMemories/extractMemories.ts +615 -0
- package/services/extractMemories/prompts.ts +154 -0
- package/services/internalLogging.ts +90 -0
- package/services/lsp/LSPClient.ts +447 -0
- package/services/lsp/LSPDiagnosticRegistry.ts +386 -0
- package/services/lsp/LSPServerInstance.ts +511 -0
- package/services/lsp/LSPServerManager.ts +420 -0
- package/services/lsp/config.ts +79 -0
- package/services/lsp/manager.ts +289 -0
- package/services/lsp/passiveFeedback.ts +328 -0
- package/services/mcp/InProcessTransport.ts +63 -0
- package/services/mcp/MCPConnectionManager.tsx +73 -0
- package/services/mcp/SdkControlTransport.ts +136 -0
- package/services/mcp/auth.ts +2465 -0
- package/services/mcp/channelAllowlist.ts +76 -0
- package/services/mcp/channelNotification.ts +316 -0
- package/services/mcp/channelPermissions.ts +240 -0
- package/services/mcp/claudeai.ts +164 -0
- package/services/mcp/client.ts +3348 -0
- package/services/mcp/config.ts +1578 -0
- package/services/mcp/elicitationHandler.ts +313 -0
- package/services/mcp/envExpansion.ts +38 -0
- package/services/mcp/headersHelper.ts +138 -0
- package/services/mcp/mcpStringUtils.ts +106 -0
- package/services/mcp/normalization.ts +23 -0
- package/services/mcp/oauthPort.ts +78 -0
- package/services/mcp/officialRegistry.ts +72 -0
- package/services/mcp/types.ts +258 -0
- package/services/mcp/useManageMCPConnections.ts +1141 -0
- package/services/mcp/utils.ts +575 -0
- package/services/mcp/vscodeSdkMcp.ts +112 -0
- package/services/mcp/xaa.ts +511 -0
- package/services/mcp/xaaIdpLogin.ts +487 -0
- package/services/mcpServerApproval.tsx +41 -0
- package/services/mockRateLimits.ts +882 -0
- package/services/notifier.ts +156 -0
- package/services/oauth/auth-code-listener.ts +211 -0
- package/services/oauth/client.ts +566 -0
- package/services/oauth/crypto.ts +23 -0
- package/services/oauth/getOauthProfile.ts +53 -0
- package/services/oauth/index.ts +198 -0
- package/services/plugins/PluginInstallationManager.ts +184 -0
- package/services/plugins/pluginCliCommands.ts +344 -0
- package/services/plugins/pluginOperations.ts +1088 -0
- package/services/policyLimits/index.ts +663 -0
- package/services/policyLimits/types.ts +27 -0
- package/services/preventSleep.ts +165 -0
- package/services/rateLimitMessages.ts +344 -0
- package/services/rateLimitMocking.ts +144 -0
- package/services/remoteManagedSettings/index.ts +638 -0
- package/services/remoteManagedSettings/securityCheck.tsx +74 -0
- package/services/remoteManagedSettings/syncCache.ts +112 -0
- package/services/remoteManagedSettings/syncCacheState.ts +96 -0
- package/services/remoteManagedSettings/types.ts +31 -0
- package/services/settingsSync/index.ts +581 -0
- package/services/settingsSync/types.ts +67 -0
- package/services/teamMemorySync/index.ts +1256 -0
- package/services/teamMemorySync/secretScanner.ts +324 -0
- package/services/teamMemorySync/teamMemSecretGuard.ts +44 -0
- package/services/teamMemorySync/types.ts +156 -0
- package/services/teamMemorySync/watcher.ts +387 -0
- package/services/tips/tipHistory.ts +17 -0
- package/services/tips/tipRegistry.ts +686 -0
- package/services/tips/tipScheduler.ts +58 -0
- package/services/tokenEstimation.ts +495 -0
- package/services/toolUseSummary/toolUseSummaryGenerator.ts +112 -0
- package/services/tools/StreamingToolExecutor.ts +530 -0
- package/services/tools/toolExecution.ts +1745 -0
- package/services/tools/toolHooks.ts +650 -0
- package/services/tools/toolOrchestration.ts +188 -0
- package/services/vcr.ts +406 -0
- package/services/voice.ts +525 -0
- package/services/voiceKeyterms.ts +106 -0
- package/services/voiceStreamSTT.ts +544 -0
- package/setup.ts +477 -0
- package/state/AppState.tsx +200 -0
- package/state/AppStateStore.ts +569 -0
- package/state/onChangeAppState.ts +171 -0
- package/state/selectors.ts +76 -0
- package/state/store.ts +34 -0
- package/state/teammateViewHelpers.ts +141 -0
- package/tasks.ts +39 -0
- package/tools/AgentTool/AgentTool.tsx +1398 -0
- package/tools/AgentTool/UI.tsx +872 -0
- package/tools/AgentTool/agentColorManager.ts +66 -0
- package/tools/AgentTool/agentDisplay.ts +104 -0
- package/tools/AgentTool/agentMemory.ts +177 -0
- package/tools/AgentTool/agentMemorySnapshot.ts +197 -0
- package/tools/AgentTool/agentToolUtils.ts +686 -0
- package/tools/AgentTool/built-in/claudeCodeGuideAgent.ts +205 -0
- package/tools/AgentTool/built-in/exploreAgent.ts +83 -0
- package/tools/AgentTool/built-in/generalPurposeAgent.ts +34 -0
- package/tools/AgentTool/built-in/planAgent.ts +92 -0
- package/tools/AgentTool/built-in/statuslineSetup.ts +144 -0
- package/tools/AgentTool/built-in/verificationAgent.ts +152 -0
- package/tools/AgentTool/builtInAgents.ts +72 -0
- package/tools/AgentTool/constants.ts +12 -0
- package/tools/AgentTool/forkSubagent.ts +210 -0
- package/tools/AgentTool/loadAgentsDir.ts +755 -0
- package/tools/AgentTool/prompt.ts +287 -0
- package/tools/AgentTool/resumeAgent.ts +265 -0
- package/tools/AgentTool/runAgent.ts +973 -0
- package/tools/AskUserQuestionTool/AskUserQuestionTool.tsx +266 -0
- package/tools/AskUserQuestionTool/prompt.ts +44 -0
- package/tools/BashTool/BashTool.tsx +1144 -0
- package/tools/BashTool/BashToolResultMessage.tsx +191 -0
- package/tools/BashTool/UI.tsx +185 -0
- package/tools/BashTool/bashCommandHelpers.ts +265 -0
- package/tools/BashTool/bashPermissions.ts +2621 -0
- package/tools/BashTool/bashSecurity.ts +2592 -0
- package/tools/BashTool/commandSemantics.ts +140 -0
- package/tools/BashTool/commentLabel.ts +13 -0
- package/tools/BashTool/destructiveCommandWarning.ts +102 -0
- package/tools/BashTool/modeValidation.ts +115 -0
- package/tools/BashTool/pathValidation.ts +1303 -0
- package/tools/BashTool/prompt.ts +369 -0
- package/tools/BashTool/readOnlyValidation.ts +1990 -0
- package/tools/BashTool/sedEditParser.ts +322 -0
- package/tools/BashTool/sedValidation.ts +684 -0
- package/tools/BashTool/shouldUseSandbox.ts +153 -0
- package/tools/BashTool/toolName.ts +2 -0
- package/tools/BashTool/utils.ts +223 -0
- package/tools/BriefTool/BriefTool.ts +204 -0
- package/tools/BriefTool/UI.tsx +101 -0
- package/tools/BriefTool/attachments.ts +110 -0
- package/tools/BriefTool/prompt.ts +22 -0
- package/tools/BriefTool/upload.ts +174 -0
- package/tools/ConfigTool/ConfigTool.ts +467 -0
- package/tools/ConfigTool/UI.tsx +38 -0
- package/tools/ConfigTool/constants.ts +1 -0
- package/tools/ConfigTool/prompt.ts +93 -0
- package/tools/ConfigTool/supportedSettings.ts +211 -0
- package/tools/EnterPlanModeTool/EnterPlanModeTool.ts +126 -0
- package/tools/EnterPlanModeTool/UI.tsx +33 -0
- package/tools/EnterPlanModeTool/constants.ts +1 -0
- package/tools/EnterPlanModeTool/prompt.ts +170 -0
- package/tools/EnterWorktreeTool/EnterWorktreeTool.ts +127 -0
- package/tools/EnterWorktreeTool/UI.tsx +20 -0
- package/tools/EnterWorktreeTool/constants.ts +1 -0
- package/tools/EnterWorktreeTool/prompt.ts +30 -0
- package/tools/ExitPlanModeTool/ExitPlanModeV2Tool.ts +493 -0
- package/tools/ExitPlanModeTool/UI.tsx +82 -0
- package/tools/ExitPlanModeTool/constants.ts +2 -0
- package/tools/ExitPlanModeTool/prompt.ts +29 -0
- package/tools/ExitWorktreeTool/ExitWorktreeTool.ts +329 -0
- package/tools/ExitWorktreeTool/UI.tsx +25 -0
- package/tools/ExitWorktreeTool/constants.ts +1 -0
- package/tools/ExitWorktreeTool/prompt.ts +32 -0
- package/tools/FileEditTool/FileEditTool.ts +625 -0
- package/tools/FileEditTool/UI.tsx +289 -0
- package/tools/FileEditTool/constants.ts +11 -0
- package/tools/FileEditTool/prompt.ts +28 -0
- package/tools/FileEditTool/types.ts +85 -0
- package/tools/FileEditTool/utils.ts +775 -0
- package/tools/FileReadTool/FileReadTool.ts +1183 -0
- package/tools/FileReadTool/UI.tsx +185 -0
- package/tools/FileReadTool/imageProcessor.ts +94 -0
- package/tools/FileReadTool/limits.ts +92 -0
- package/tools/FileReadTool/prompt.ts +49 -0
- package/tools/FileWriteTool/FileWriteTool.ts +434 -0
- package/tools/FileWriteTool/UI.tsx +405 -0
- package/tools/FileWriteTool/prompt.ts +18 -0
- package/tools/GlobTool/GlobTool.ts +198 -0
- package/tools/GlobTool/UI.tsx +63 -0
- package/tools/GlobTool/prompt.ts +7 -0
- package/tools/GrepTool/GrepTool.ts +577 -0
- package/tools/GrepTool/UI.tsx +201 -0
- package/tools/GrepTool/prompt.ts +18 -0
- package/tools/LSPTool/LSPTool.ts +860 -0
- package/tools/LSPTool/UI.tsx +228 -0
- package/tools/LSPTool/formatters.ts +592 -0
- package/tools/LSPTool/prompt.ts +21 -0
- package/tools/LSPTool/schemas.ts +215 -0
- package/tools/LSPTool/symbolContext.ts +90 -0
- package/tools/ListMcpResourcesTool/ListMcpResourcesTool.ts +123 -0
- package/tools/ListMcpResourcesTool/UI.tsx +29 -0
- package/tools/ListMcpResourcesTool/prompt.ts +20 -0
- package/tools/MCPTool/MCPTool.ts +77 -0
- package/tools/MCPTool/UI.tsx +403 -0
- package/tools/MCPTool/classifyForCollapse.ts +604 -0
- package/tools/MCPTool/prompt.ts +3 -0
- package/tools/McpAuthTool/McpAuthTool.ts +215 -0
- package/tools/NotebookEditTool/NotebookEditTool.ts +490 -0
- package/tools/NotebookEditTool/UI.tsx +93 -0
- package/tools/NotebookEditTool/constants.ts +2 -0
- package/tools/NotebookEditTool/prompt.ts +3 -0
- package/tools/PowerShellTool/PowerShellTool.tsx +1001 -0
- package/tools/PowerShellTool/UI.tsx +131 -0
- package/tools/PowerShellTool/clmTypes.ts +211 -0
- package/tools/PowerShellTool/commandSemantics.ts +142 -0
- package/tools/PowerShellTool/commonParameters.ts +30 -0
- package/tools/PowerShellTool/destructiveCommandWarning.ts +109 -0
- package/tools/PowerShellTool/gitSafety.ts +176 -0
- package/tools/PowerShellTool/modeValidation.ts +404 -0
- package/tools/PowerShellTool/pathValidation.ts +2049 -0
- package/tools/PowerShellTool/powershellPermissions.ts +1648 -0
- package/tools/PowerShellTool/powershellSecurity.ts +1090 -0
- package/tools/PowerShellTool/prompt.ts +145 -0
- package/tools/PowerShellTool/readOnlyValidation.ts +1823 -0
- package/tools/PowerShellTool/toolName.ts +2 -0
- package/tools/REPLTool/constants.ts +46 -0
- package/tools/REPLTool/primitiveTools.ts +39 -0
- package/tools/ReadMcpResourceTool/ReadMcpResourceTool.ts +158 -0
- package/tools/ReadMcpResourceTool/UI.tsx +37 -0
- package/tools/ReadMcpResourceTool/prompt.ts +16 -0
- package/tools/RemoteTriggerTool/RemoteTriggerTool.ts +161 -0
- package/tools/RemoteTriggerTool/UI.tsx +17 -0
- package/tools/RemoteTriggerTool/prompt.ts +15 -0
- package/tools/ScheduleCronTool/CronCreateTool.ts +157 -0
- package/tools/ScheduleCronTool/CronDeleteTool.ts +95 -0
- package/tools/ScheduleCronTool/CronListTool.ts +97 -0
- package/tools/ScheduleCronTool/UI.tsx +60 -0
- package/tools/ScheduleCronTool/prompt.ts +135 -0
- package/tools/SendMessageTool/SendMessageTool.ts +917 -0
- package/tools/SendMessageTool/UI.tsx +31 -0
- package/tools/SendMessageTool/constants.ts +1 -0
- package/tools/SendMessageTool/prompt.ts +49 -0
- package/tools/SkillTool/SkillTool.ts +1108 -0
- package/tools/SkillTool/UI.tsx +128 -0
- package/tools/SkillTool/constants.ts +1 -0
- package/tools/SkillTool/prompt.ts +241 -0
- package/tools/SleepTool/prompt.ts +17 -0
- package/tools/SyntheticOutputTool/SyntheticOutputTool.ts +163 -0
- package/tools/TaskCreateTool/TaskCreateTool.ts +138 -0
- package/tools/TaskCreateTool/constants.ts +1 -0
- package/tools/TaskCreateTool/prompt.ts +56 -0
- package/tools/TaskGetTool/TaskGetTool.ts +128 -0
- package/tools/TaskGetTool/constants.ts +1 -0
- package/tools/TaskGetTool/prompt.ts +24 -0
- package/tools/TaskListTool/TaskListTool.ts +116 -0
- package/tools/TaskListTool/constants.ts +1 -0
- package/tools/TaskListTool/prompt.ts +49 -0
- package/tools/TaskOutputTool/TaskOutputTool.tsx +584 -0
- package/tools/TaskOutputTool/constants.ts +1 -0
- package/tools/TaskStopTool/TaskStopTool.ts +131 -0
- package/tools/TaskStopTool/UI.tsx +41 -0
- package/tools/TaskStopTool/prompt.ts +8 -0
- package/tools/TaskUpdateTool/TaskUpdateTool.ts +406 -0
- package/tools/TaskUpdateTool/constants.ts +1 -0
- package/tools/TaskUpdateTool/prompt.ts +77 -0
- package/tools/TeamCreateTool/TeamCreateTool.ts +240 -0
- package/tools/TeamCreateTool/UI.tsx +6 -0
- package/tools/TeamCreateTool/constants.ts +1 -0
- package/tools/TeamCreateTool/prompt.ts +113 -0
- package/tools/TeamDeleteTool/TeamDeleteTool.ts +139 -0
- package/tools/TeamDeleteTool/UI.tsx +20 -0
- package/tools/TeamDeleteTool/constants.ts +1 -0
- package/tools/TeamDeleteTool/prompt.ts +16 -0
- package/tools/TodoWriteTool/TodoWriteTool.ts +115 -0
- package/tools/TodoWriteTool/constants.ts +1 -0
- package/tools/TodoWriteTool/prompt.ts +184 -0
- package/tools/ToolSearchTool/ToolSearchTool.ts +471 -0
- package/tools/ToolSearchTool/constants.ts +1 -0
- package/tools/ToolSearchTool/prompt.ts +121 -0
- package/tools/WebFetchTool/UI.tsx +72 -0
- package/tools/WebFetchTool/WebFetchTool.ts +318 -0
- package/tools/WebFetchTool/preapproved.ts +166 -0
- package/tools/WebFetchTool/prompt.ts +46 -0
- package/tools/WebFetchTool/utils.ts +530 -0
- package/tools/WebSearchTool/UI.tsx +101 -0
- package/tools/WebSearchTool/WebSearchTool.ts +435 -0
- package/tools/WebSearchTool/prompt.ts +34 -0
- package/tools/WorkflowTool/constants.ts +5 -0
- package/tools/shared/gitOperationTracking.ts +277 -0
- package/tools/shared/spawnMultiAgent.ts +1093 -0
- package/tools/testing/TestingPermissionTool.tsx +74 -0
- package/tools/utils.ts +40 -0
- package/tools.ts +392 -0
- package/types/command.ts +216 -0
- package/types/connectorText.ts +21 -0
- package/types/generated/events_mono/claude_code/v1/claude_code_internal_event.ts +865 -0
- package/types/generated/events_mono/common/v1/auth.ts +100 -0
- package/types/generated/events_mono/growthbook/v1/growthbook_experiment_event.ts +223 -0
- package/types/generated/google/protobuf/timestamp.ts +187 -0
- package/types/hooks.ts +290 -0
- package/types/ids.ts +44 -0
- package/types/logs.ts +330 -0
- package/types/permissions.ts +441 -0
- package/types/plugin.ts +363 -0
- package/types/textInputTypes.ts +387 -0
- package/utils/CircularBuffer.ts +84 -0
- package/utils/Cursor.ts +1530 -0
- package/utils/QueryGuard.ts +121 -0
- package/utils/Shell.ts +474 -0
- package/utils/ShellCommand.ts +465 -0
- package/utils/abortController.ts +99 -0
- package/utils/activityManager.ts +164 -0
- package/utils/advisor.ts +145 -0
- package/utils/agentContext.ts +178 -0
- package/utils/agentId.ts +99 -0
- package/utils/agentSwarmsEnabled.ts +44 -0
- package/utils/agenticSessionSearch.ts +307 -0
- package/utils/analyzeContext.ts +1382 -0
- package/utils/ansiToPng.ts +334 -0
- package/utils/ansiToSvg.ts +272 -0
- package/utils/api.ts +718 -0
- package/utils/apiPreconnect.ts +71 -0
- package/utils/appleTerminalBackup.ts +124 -0
- package/utils/argumentSubstitution.ts +145 -0
- package/utils/array.ts +13 -0
- package/utils/asciicast.ts +239 -0
- package/utils/attachments.ts +3997 -0
- package/utils/attribution.ts +393 -0
- package/utils/auth.ts +2002 -0
- package/utils/authFileDescriptor.ts +196 -0
- package/utils/authPortable.ts +19 -0
- package/utils/autoModeDenials.ts +26 -0
- package/utils/autoRunIssue.tsx +122 -0
- package/utils/autoUpdater.ts +561 -0
- package/utils/aws.ts +74 -0
- package/utils/awsAuthStatusManager.ts +81 -0
- package/utils/background/remote/preconditions.ts +235 -0
- package/utils/background/remote/remoteSession.ts +98 -0
- package/utils/backgroundHousekeeping.ts +94 -0
- package/utils/bash/ParsedCommand.ts +318 -0
- package/utils/bash/ShellSnapshot.ts +582 -0
- package/utils/bash/ast.ts +2679 -0
- package/utils/bash/bashParser.ts +4436 -0
- package/utils/bash/bashPipeCommand.ts +294 -0
- package/utils/bash/commands.ts +1339 -0
- package/utils/bash/heredoc.ts +733 -0
- package/utils/bash/parser.ts +230 -0
- package/utils/bash/prefix.ts +204 -0
- package/utils/bash/registry.ts +53 -0
- package/utils/bash/shellCompletion.ts +259 -0
- package/utils/bash/shellPrefix.ts +28 -0
- package/utils/bash/shellQuote.ts +304 -0
- package/utils/bash/shellQuoting.ts +128 -0
- package/utils/bash/specs/alias.ts +14 -0
- package/utils/bash/specs/index.ts +18 -0
- package/utils/bash/specs/nohup.ts +13 -0
- package/utils/bash/specs/pyright.ts +91 -0
- package/utils/bash/specs/sleep.ts +13 -0
- package/utils/bash/specs/srun.ts +31 -0
- package/utils/bash/specs/time.ts +13 -0
- package/utils/bash/specs/timeout.ts +20 -0
- package/utils/bash/treeSitterAnalysis.ts +506 -0
- package/utils/betas.ts +434 -0
- package/utils/billing.ts +78 -0
- package/utils/binaryCheck.ts +53 -0
- package/utils/browser.ts +68 -0
- package/utils/bufferedWriter.ts +100 -0
- package/utils/bundledMode.ts +22 -0
- package/utils/caCerts.ts +115 -0
- package/utils/caCertsConfig.ts +88 -0
- package/utils/cachePaths.ts +38 -0
- package/utils/classifierApprovals.ts +88 -0
- package/utils/classifierApprovalsHook.ts +17 -0
- package/utils/claudeCodeHints.ts +193 -0
- package/utils/claudeDesktop.ts +152 -0
- package/utils/claudeInChrome/chromeNativeHost.ts +527 -0
- package/utils/claudeInChrome/common.ts +540 -0
- package/utils/claudeInChrome/mcpServer.ts +293 -0
- package/utils/claudeInChrome/prompt.ts +83 -0
- package/utils/claudeInChrome/setup.ts +400 -0
- package/utils/claudeInChrome/setupPortable.ts +233 -0
- package/utils/claudeInChrome/toolRendering.tsx +262 -0
- package/utils/claudemd.ts +1479 -0
- package/utils/cleanup.ts +602 -0
- package/utils/cleanupRegistry.ts +25 -0
- package/utils/cliArgs.ts +60 -0
- package/utils/cliHighlight.ts +54 -0
- package/utils/codeIndexing.ts +206 -0
- package/utils/collapseBackgroundBashNotifications.ts +84 -0
- package/utils/collapseHookSummaries.ts +59 -0
- package/utils/collapseReadSearch.ts +1109 -0
- package/utils/collapseTeammateShutdowns.ts +55 -0
- package/utils/combinedAbortSignal.ts +47 -0
- package/utils/commandLifecycle.ts +21 -0
- package/utils/commitAttribution.ts +961 -0
- package/utils/completionCache.ts +166 -0
- package/utils/computerUse/appNames.ts +196 -0
- package/utils/computerUse/cleanup.ts +86 -0
- package/utils/computerUse/common.ts +61 -0
- package/utils/computerUse/computerUseLock.ts +215 -0
- package/utils/computerUse/drainRunLoop.ts +79 -0
- package/utils/computerUse/escHotkey.ts +54 -0
- package/utils/computerUse/executor.ts +658 -0
- package/utils/computerUse/gates.ts +72 -0
- package/utils/computerUse/hostAdapter.ts +69 -0
- package/utils/computerUse/inputLoader.ts +30 -0
- package/utils/computerUse/mcpServer.ts +106 -0
- package/utils/computerUse/setup.ts +53 -0
- package/utils/computerUse/swiftLoader.ts +23 -0
- package/utils/computerUse/toolRendering.tsx +125 -0
- package/utils/computerUse/wrapper.tsx +336 -0
- package/utils/concurrentSessions.ts +204 -0
- package/utils/config.ts +1817 -0
- package/utils/configConstants.ts +21 -0
- package/utils/contentArray.ts +51 -0
- package/utils/context.ts +221 -0
- package/utils/contextAnalysis.ts +272 -0
- package/utils/contextSuggestions.ts +235 -0
- package/utils/controlMessageCompat.ts +32 -0
- package/utils/conversationRecovery.ts +597 -0
- package/utils/cron.ts +308 -0
- package/utils/cronJitterConfig.ts +75 -0
- package/utils/cronScheduler.ts +565 -0
- package/utils/cronTasks.ts +458 -0
- package/utils/cronTasksLock.ts +195 -0
- package/utils/crossProjectResume.ts +75 -0
- package/utils/crypto.ts +13 -0
- package/utils/cwd.ts +32 -0
- package/utils/debug.ts +268 -0
- package/utils/debugFilter.ts +157 -0
- package/utils/deepLink/banner.ts +123 -0
- package/utils/deepLink/parseDeepLink.ts +170 -0
- package/utils/deepLink/protocolHandler.ts +136 -0
- package/utils/deepLink/registerProtocol.ts +348 -0
- package/utils/deepLink/terminalLauncher.ts +557 -0
- package/utils/deepLink/terminalPreference.ts +54 -0
- package/utils/desktopDeepLink.ts +236 -0
- package/utils/detectRepository.ts +178 -0
- package/utils/diagLogs.ts +94 -0
- package/utils/diff.ts +177 -0
- package/utils/directMemberMessage.ts +69 -0
- package/utils/displayTags.ts +51 -0
- package/utils/doctorContextWarnings.ts +265 -0
- package/utils/doctorDiagnostic.ts +625 -0
- package/utils/dxt/helpers.ts +88 -0
- package/utils/dxt/zip.ts +226 -0
- package/utils/earlyInput.ts +191 -0
- package/utils/editor.ts +183 -0
- package/utils/effort.ts +329 -0
- package/utils/embeddedTools.ts +29 -0
- package/utils/env.ts +347 -0
- package/utils/envDynamic.ts +151 -0
- package/utils/envUtils.ts +183 -0
- package/utils/envValidation.ts +38 -0
- package/utils/errorLogSink.ts +235 -0
- package/utils/errors.ts +238 -0
- package/utils/exampleCommands.ts +184 -0
- package/utils/execFileNoThrow.ts +150 -0
- package/utils/execFileNoThrowPortable.ts +89 -0
- package/utils/execSyncWrapper.ts +38 -0
- package/utils/exportRenderer.tsx +98 -0
- package/utils/extraUsage.ts +23 -0
- package/utils/fastMode.ts +532 -0
- package/utils/file.ts +584 -0
- package/utils/fileHistory.ts +1115 -0
- package/utils/fileOperationAnalytics.ts +71 -0
- package/utils/filePersistence/filePersistence.ts +287 -0
- package/utils/filePersistence/outputsScanner.ts +126 -0
- package/utils/filePersistence/types.ts +28 -0
- package/utils/fileRead.ts +102 -0
- package/utils/fileReadCache.ts +96 -0
- package/utils/fileStateCache.ts +142 -0
- package/utils/findExecutable.ts +17 -0
- package/utils/fingerprint.ts +76 -0
- package/utils/forkedAgent.ts +689 -0
- package/utils/format.ts +308 -0
- package/utils/formatBriefTimestamp.ts +81 -0
- package/utils/fpsTracker.ts +47 -0
- package/utils/frontmatterParser.ts +370 -0
- package/utils/fsOperations.ts +770 -0
- package/utils/fullscreen.ts +202 -0
- package/utils/generatedFiles.ts +136 -0
- package/utils/generators.ts +88 -0
- package/utils/genericProcessUtils.ts +184 -0
- package/utils/getWorktreePaths.ts +70 -0
- package/utils/getWorktreePathsPortable.ts +27 -0
- package/utils/ghPrStatus.ts +106 -0
- package/utils/git/gitConfigParser.ts +277 -0
- package/utils/git/gitFilesystem.ts +699 -0
- package/utils/git/gitignore.ts +99 -0
- package/utils/git.ts +926 -0
- package/utils/gitDiff.ts +532 -0
- package/utils/gitSettings.ts +18 -0
- package/utils/github/ghAuthStatus.ts +29 -0
- package/utils/githubRepoPathMapping.ts +162 -0
- package/utils/glob.ts +130 -0
- package/utils/gracefulShutdown.ts +529 -0
- package/utils/groupToolUses.ts +182 -0
- package/utils/handlePromptSubmit.ts +610 -0
- package/utils/hash.ts +46 -0
- package/utils/headlessProfiler.ts +178 -0
- package/utils/heapDumpService.ts +303 -0
- package/utils/heatmap.ts +198 -0
- package/utils/highlightMatch.tsx +28 -0
- package/utils/hooks/AsyncHookRegistry.ts +309 -0
- package/utils/hooks/apiQueryHookHelper.ts +141 -0
- package/utils/hooks/execAgentHook.ts +339 -0
- package/utils/hooks/execHttpHook.ts +242 -0
- package/utils/hooks/execPromptHook.ts +211 -0
- package/utils/hooks/fileChangedWatcher.ts +191 -0
- package/utils/hooks/hookEvents.ts +192 -0
- package/utils/hooks/hookHelpers.ts +83 -0
- package/utils/hooks/hooksConfigManager.ts +400 -0
- package/utils/hooks/hooksConfigSnapshot.ts +133 -0
- package/utils/hooks/hooksSettings.ts +271 -0
- package/utils/hooks/postSamplingHooks.ts +70 -0
- package/utils/hooks/registerFrontmatterHooks.ts +67 -0
- package/utils/hooks/registerSkillHooks.ts +64 -0
- package/utils/hooks/sessionHooks.ts +447 -0
- package/utils/hooks/skillImprovement.ts +267 -0
- package/utils/hooks/ssrfGuard.ts +294 -0
- package/utils/hooks.ts +5022 -0
- package/utils/horizontalScroll.ts +137 -0
- package/utils/http.ts +136 -0
- package/utils/hyperlink.ts +39 -0
- package/utils/iTermBackup.ts +73 -0
- package/utils/ide.ts +1494 -0
- package/utils/idePathConversion.ts +90 -0
- package/utils/idleTimeout.ts +53 -0
- package/utils/imagePaste.ts +416 -0
- package/utils/imageResizer.ts +880 -0
- package/utils/imageStore.ts +167 -0
- package/utils/imageValidation.ts +104 -0
- package/utils/immediateCommand.ts +15 -0
- package/utils/inProcessTeammateHelpers.ts +102 -0
- package/utils/ink.ts +26 -0
- package/utils/intl.ts +94 -0
- package/utils/jetbrains.ts +191 -0
- package/utils/json.ts +277 -0
- package/utils/jsonRead.ts +16 -0
- package/utils/keyboardShortcuts.ts +14 -0
- package/utils/lazySchema.ts +8 -0
- package/utils/listSessionsImpl.ts +454 -0
- package/utils/localInstaller.ts +162 -0
- package/utils/lockfile.ts +43 -0
- package/utils/log.ts +362 -0
- package/utils/logoV2Utils.ts +350 -0
- package/utils/mailbox.ts +73 -0
- package/utils/managedEnv.ts +199 -0
- package/utils/managedEnvConstants.ts +191 -0
- package/utils/markdown.ts +381 -0
- package/utils/markdownConfigLoader.ts +600 -0
- package/utils/mcp/dateTimeParser.ts +121 -0
- package/utils/mcp/elicitationValidation.ts +336 -0
- package/utils/mcpInstructionsDelta.ts +130 -0
- package/utils/mcpOutputStorage.ts +189 -0
- package/utils/mcpValidation.ts +208 -0
- package/utils/mcpWebSocketTransport.ts +200 -0
- package/utils/memoize.ts +269 -0
- package/utils/memory/types.ts +12 -0
- package/utils/memory/versions.ts +8 -0
- package/utils/memoryFileDetection.ts +289 -0
- package/utils/messagePredicates.ts +8 -0
- package/utils/messageQueueManager.ts +547 -0
- package/utils/messages/mappers.ts +290 -0
- package/utils/messages/systemInit.ts +96 -0
- package/utils/messages.ts +5512 -0
- package/utils/model/agent.ts +157 -0
- package/utils/model/aliases.ts +25 -0
- package/utils/model/antModels.ts +64 -0
- package/utils/model/bedrock.ts +265 -0
- package/utils/model/check1mAccess.ts +72 -0
- package/utils/model/configs.ts +118 -0
- package/utils/model/contextWindowUpgradeCheck.ts +47 -0
- package/utils/model/deprecation.ts +101 -0
- package/utils/model/model.ts +618 -0
- package/utils/model/modelAllowlist.ts +170 -0
- package/utils/model/modelCapabilities.ts +118 -0
- package/utils/model/modelOptions.ts +540 -0
- package/utils/model/modelStrings.ts +166 -0
- package/utils/model/modelSupportOverrides.ts +50 -0
- package/utils/model/providers.ts +40 -0
- package/utils/model/validateModel.ts +159 -0
- package/utils/modelCost.ts +231 -0
- package/utils/modifiers.ts +36 -0
- package/utils/mtls.ts +179 -0
- package/utils/nativeInstaller/download.ts +523 -0
- package/utils/nativeInstaller/index.ts +18 -0
- package/utils/nativeInstaller/installer.ts +1708 -0
- package/utils/nativeInstaller/packageManagers.ts +336 -0
- package/utils/nativeInstaller/pidLock.ts +433 -0
- package/utils/notebook.ts +224 -0
- package/utils/objectGroupBy.ts +18 -0
- package/utils/pasteStore.ts +104 -0
- package/utils/path.ts +155 -0
- package/utils/pdf.ts +300 -0
- package/utils/pdfUtils.ts +70 -0
- package/utils/peerAddress.ts +21 -0
- package/utils/permissions/PermissionMode.ts +141 -0
- package/utils/permissions/PermissionPromptToolResultSchema.ts +127 -0
- package/utils/permissions/PermissionResult.ts +35 -0
- package/utils/permissions/PermissionRule.ts +40 -0
- package/utils/permissions/PermissionUpdate.ts +389 -0
- package/utils/permissions/PermissionUpdateSchema.ts +78 -0
- package/utils/permissions/autoModeState.ts +39 -0
- package/utils/permissions/bashClassifier.ts +61 -0
- package/utils/permissions/bypassPermissionsKillswitch.ts +155 -0
- package/utils/permissions/classifierDecision.ts +98 -0
- package/utils/permissions/classifierShared.ts +39 -0
- package/utils/permissions/dangerousPatterns.ts +80 -0
- package/utils/permissions/denialTracking.ts +45 -0
- package/utils/permissions/filesystem.ts +1777 -0
- package/utils/permissions/getNextPermissionMode.ts +101 -0
- package/utils/permissions/pathValidation.ts +485 -0
- package/utils/permissions/permissionExplainer.ts +250 -0
- package/utils/permissions/permissionRuleParser.ts +198 -0
- package/utils/permissions/permissionSetup.ts +1532 -0
- package/utils/permissions/permissions.ts +1486 -0
- package/utils/permissions/permissionsLoader.ts +296 -0
- package/utils/permissions/shadowedRuleDetection.ts +234 -0
- package/utils/permissions/shellRuleMatching.ts +228 -0
- package/utils/permissions/yoloClassifier.ts +1495 -0
- package/utils/planModeV2.ts +95 -0
- package/utils/plans.ts +397 -0
- package/utils/platform.ts +150 -0
- package/utils/plugins/addDirPluginSettings.ts +71 -0
- package/utils/plugins/cacheUtils.ts +196 -0
- package/utils/plugins/dependencyResolver.ts +305 -0
- package/utils/plugins/fetchTelemetry.ts +135 -0
- package/utils/plugins/gitAvailability.ts +69 -0
- package/utils/plugins/headlessPluginInstall.ts +174 -0
- package/utils/plugins/hintRecommendation.ts +164 -0
- package/utils/plugins/installCounts.ts +292 -0
- package/utils/plugins/installedPluginsManager.ts +1268 -0
- package/utils/plugins/loadPluginAgents.ts +348 -0
- package/utils/plugins/loadPluginCommands.ts +946 -0
- package/utils/plugins/loadPluginHooks.ts +287 -0
- package/utils/plugins/loadPluginOutputStyles.ts +178 -0
- package/utils/plugins/lspPluginIntegration.ts +387 -0
- package/utils/plugins/lspRecommendation.ts +374 -0
- package/utils/plugins/managedPlugins.ts +27 -0
- package/utils/plugins/marketplaceHelpers.ts +592 -0
- package/utils/plugins/marketplaceManager.ts +2643 -0
- package/utils/plugins/mcpPluginIntegration.ts +634 -0
- package/utils/plugins/mcpbHandler.ts +968 -0
- package/utils/plugins/officialMarketplace.ts +25 -0
- package/utils/plugins/officialMarketplaceGcs.ts +216 -0
- package/utils/plugins/officialMarketplaceStartupCheck.ts +439 -0
- package/utils/plugins/orphanedPluginFilter.ts +114 -0
- package/utils/plugins/parseMarketplaceInput.ts +162 -0
- package/utils/plugins/performStartupChecks.tsx +70 -0
- package/utils/plugins/pluginAutoupdate.ts +284 -0
- package/utils/plugins/pluginBlocklist.ts +127 -0
- package/utils/plugins/pluginDirectories.ts +178 -0
- package/utils/plugins/pluginFlagging.ts +208 -0
- package/utils/plugins/pluginIdentifier.ts +123 -0
- package/utils/plugins/pluginInstallationHelpers.ts +595 -0
- package/utils/plugins/pluginLoader.ts +3302 -0
- package/utils/plugins/pluginOptionsStorage.ts +400 -0
- package/utils/plugins/pluginPolicy.ts +20 -0
- package/utils/plugins/pluginStartupCheck.ts +341 -0
- package/utils/plugins/pluginVersioning.ts +157 -0
- package/utils/plugins/reconciler.ts +265 -0
- package/utils/plugins/refresh.ts +215 -0
- package/utils/plugins/schemas.ts +1681 -0
- package/utils/plugins/validatePlugin.ts +903 -0
- package/utils/plugins/walkPluginMarkdown.ts +69 -0
- package/utils/plugins/zipCache.ts +406 -0
- package/utils/plugins/zipCacheAdapters.ts +164 -0
- package/utils/powershell/dangerousCmdlets.ts +185 -0
- package/utils/powershell/parser.ts +1804 -0
- package/utils/powershell/staticPrefix.ts +316 -0
- package/utils/preflightChecks.tsx +151 -0
- package/utils/privacyLevel.ts +55 -0
- package/utils/process.ts +68 -0
- package/utils/processUserInput/processBashCommand.tsx +140 -0
- package/utils/processUserInput/processSlashCommand.tsx +922 -0
- package/utils/processUserInput/processTextPrompt.ts +100 -0
- package/utils/processUserInput/processUserInput.ts +605 -0
- package/utils/profilerBase.ts +46 -0
- package/utils/promptCategory.ts +49 -0
- package/utils/promptEditor.ts +188 -0
- package/utils/promptShellExecution.ts +183 -0
- package/utils/proxy.ts +426 -0
- package/utils/queryContext.ts +179 -0
- package/utils/queryHelpers.ts +552 -0
- package/utils/queryProfiler.ts +301 -0
- package/utils/queueProcessor.ts +95 -0
- package/utils/readEditContext.ts +227 -0
- package/utils/readFileInRange.ts +383 -0
- package/utils/releaseNotes.ts +360 -0
- package/utils/renderOptions.ts +77 -0
- package/utils/ripgrep.ts +679 -0
- package/utils/sandbox/sandbox-adapter.ts +987 -0
- package/utils/sandbox/sandbox-ui-utils.ts +12 -0
- package/utils/sanitization.ts +91 -0
- package/utils/screenshotClipboard.ts +121 -0
- package/utils/sdkEventQueue.ts +134 -0
- package/utils/secureStorage/fallbackStorage.ts +70 -0
- package/utils/secureStorage/index.ts +17 -0
- package/utils/secureStorage/keychainPrefetch.ts +116 -0
- package/utils/secureStorage/macOsKeychainHelpers.ts +111 -0
- package/utils/secureStorage/macOsKeychainStorage.ts +231 -0
- package/utils/secureStorage/plainTextStorage.ts +84 -0
- package/utils/semanticBoolean.ts +29 -0
- package/utils/semanticNumber.ts +36 -0
- package/utils/semver.ts +59 -0
- package/utils/sequential.ts +56 -0
- package/utils/sessionActivity.ts +133 -0
- package/utils/sessionEnvVars.ts +22 -0
- package/utils/sessionEnvironment.ts +166 -0
- package/utils/sessionFileAccessHooks.ts +250 -0
- package/utils/sessionIngressAuth.ts +140 -0
- package/utils/sessionRestore.ts +551 -0
- package/utils/sessionStart.ts +232 -0
- package/utils/sessionState.ts +150 -0
- package/utils/sessionStorage.ts +5105 -0
- package/utils/sessionStoragePortable.ts +793 -0
- package/utils/sessionTitle.ts +129 -0
- package/utils/sessionUrl.ts +64 -0
- package/utils/set.ts +53 -0
- package/utils/settings/allErrors.ts +32 -0
- package/utils/settings/applySettingsChange.ts +92 -0
- package/utils/settings/changeDetector.ts +488 -0
- package/utils/settings/constants.ts +202 -0
- package/utils/settings/internalWrites.ts +37 -0
- package/utils/settings/managedPath.ts +34 -0
- package/utils/settings/mdm/constants.ts +81 -0
- package/utils/settings/mdm/rawRead.ts +130 -0
- package/utils/settings/mdm/settings.ts +316 -0
- package/utils/settings/permissionValidation.ts +262 -0
- package/utils/settings/pluginOnlyPolicy.ts +60 -0
- package/utils/settings/schemaOutput.ts +8 -0
- package/utils/settings/settings.ts +1015 -0
- package/utils/settings/settingsCache.ts +80 -0
- package/utils/settings/toolValidationConfig.ts +103 -0
- package/utils/settings/types.ts +1148 -0
- package/utils/settings/validateEditTool.ts +45 -0
- package/utils/settings/validation.ts +265 -0
- package/utils/settings/validationTips.ts +164 -0
- package/utils/shell/bashProvider.ts +255 -0
- package/utils/shell/outputLimits.ts +14 -0
- package/utils/shell/powershellDetection.ts +107 -0
- package/utils/shell/powershellProvider.ts +123 -0
- package/utils/shell/prefix.ts +367 -0
- package/utils/shell/readOnlyCommandValidation.ts +1893 -0
- package/utils/shell/resolveDefaultShell.ts +14 -0
- package/utils/shell/shellProvider.ts +33 -0
- package/utils/shell/shellToolUtils.ts +22 -0
- package/utils/shell/specPrefix.ts +241 -0
- package/utils/shellConfig.ts +167 -0
- package/utils/sideQuery.ts +222 -0
- package/utils/sideQuestion.ts +155 -0
- package/utils/signal.ts +43 -0
- package/utils/sinks.ts +16 -0
- package/utils/skills/skillChangeDetector.ts +311 -0
- package/utils/slashCommandParsing.ts +60 -0
- package/utils/sleep.ts +84 -0
- package/utils/sliceAnsi.ts +91 -0
- package/utils/slowOperations.ts +286 -0
- package/utils/standaloneAgent.ts +23 -0
- package/utils/startupProfiler.ts +194 -0
- package/utils/staticRender.tsx +116 -0
- package/utils/stats.ts +1061 -0
- package/utils/statsCache.ts +434 -0
- package/utils/status.tsx +362 -0
- package/utils/statusNoticeDefinitions.tsx +198 -0
- package/utils/statusNoticeHelpers.ts +20 -0
- package/utils/stream.ts +76 -0
- package/utils/streamJsonStdoutGuard.ts +123 -0
- package/utils/streamlinedTransform.ts +201 -0
- package/utils/stringUtils.ts +235 -0
- package/utils/subprocessEnv.ts +99 -0
- package/utils/suggestions/commandSuggestions.ts +567 -0
- package/utils/suggestions/directoryCompletion.ts +263 -0
- package/utils/suggestions/shellHistoryCompletion.ts +119 -0
- package/utils/suggestions/skillUsageTracking.ts +55 -0
- package/utils/suggestions/slackChannelSuggestions.ts +209 -0
- package/utils/swarm/It2SetupPrompt.tsx +380 -0
- package/utils/swarm/backends/ITermBackend.ts +370 -0
- package/utils/swarm/backends/InProcessBackend.ts +339 -0
- package/utils/swarm/backends/PaneBackendExecutor.ts +354 -0
- package/utils/swarm/backends/TmuxBackend.ts +764 -0
- package/utils/swarm/backends/detection.ts +128 -0
- package/utils/swarm/backends/it2Setup.ts +245 -0
- package/utils/swarm/backends/registry.ts +464 -0
- package/utils/swarm/backends/teammateModeSnapshot.ts +87 -0
- package/utils/swarm/backends/types.ts +311 -0
- package/utils/swarm/constants.ts +33 -0
- package/utils/swarm/inProcessRunner.ts +1552 -0
- package/utils/swarm/leaderPermissionBridge.ts +54 -0
- package/utils/swarm/permissionSync.ts +928 -0
- package/utils/swarm/reconnection.ts +119 -0
- package/utils/swarm/spawnInProcess.ts +328 -0
- package/utils/swarm/spawnUtils.ts +146 -0
- package/utils/swarm/teamHelpers.ts +683 -0
- package/utils/swarm/teammateInit.ts +129 -0
- package/utils/swarm/teammateLayoutManager.ts +107 -0
- package/utils/swarm/teammateModel.ts +10 -0
- package/utils/swarm/teammatePromptAddendum.ts +18 -0
- package/utils/systemDirectories.ts +74 -0
- package/utils/systemPrompt.ts +123 -0
- package/utils/systemPromptType.ts +14 -0
- package/utils/systemTheme.ts +119 -0
- package/utils/taggedId.ts +54 -0
- package/utils/task/TaskOutput.ts +390 -0
- package/utils/task/diskOutput.ts +451 -0
- package/utils/task/framework.ts +308 -0
- package/utils/task/outputFormatting.ts +38 -0
- package/utils/task/sdkProgress.ts +36 -0
- package/utils/tasks.ts +862 -0
- package/utils/teamDiscovery.ts +81 -0
- package/utils/teamMemoryOps.ts +88 -0
- package/utils/teammate.ts +292 -0
- package/utils/teammateContext.ts +96 -0
- package/utils/teammateMailbox.ts +1183 -0
- package/utils/telemetry/betaSessionTracing.ts +491 -0
- package/utils/telemetry/bigqueryExporter.ts +252 -0
- package/utils/telemetry/events.ts +75 -0
- package/utils/telemetry/instrumentation.ts +825 -0
- package/utils/telemetry/logger.ts +26 -0
- package/utils/telemetry/perfettoTracing.ts +1120 -0
- package/utils/telemetry/pluginTelemetry.ts +289 -0
- package/utils/telemetry/sessionTracing.ts +927 -0
- package/utils/telemetry/skillLoadedEvent.ts +39 -0
- package/utils/telemetryAttributes.ts +71 -0
- package/utils/teleport/api.ts +466 -0
- package/utils/teleport/environmentSelection.ts +77 -0
- package/utils/teleport/environments.ts +120 -0
- package/utils/teleport/gitBundle.ts +292 -0
- package/utils/teleport.tsx +1226 -0
- package/utils/tempfile.ts +31 -0
- package/utils/terminal.ts +131 -0
- package/utils/terminalPanel.ts +191 -0
- package/utils/textHighlighting.ts +166 -0
- package/utils/theme.ts +639 -0
- package/utils/thinking.ts +162 -0
- package/utils/timeouts.ts +39 -0
- package/utils/tmuxSocket.ts +427 -0
- package/utils/todo/types.ts +18 -0
- package/utils/tokenBudget.ts +73 -0
- package/utils/tokens.ts +261 -0
- package/utils/toolErrors.ts +132 -0
- package/utils/toolPool.ts +79 -0
- package/utils/toolResultStorage.ts +1040 -0
- package/utils/toolSchemaCache.ts +26 -0
- package/utils/toolSearch.ts +756 -0
- package/utils/transcriptSearch.ts +202 -0
- package/utils/treeify.ts +170 -0
- package/utils/truncate.ts +179 -0
- package/utils/ultraplan/ccrSession.ts +349 -0
- package/utils/ultraplan/keyword.ts +127 -0
- package/utils/unaryLogging.ts +39 -0
- package/utils/undercover.ts +89 -0
- package/utils/user.ts +194 -0
- package/utils/userAgent.ts +10 -0
- package/utils/userConfig.ts +181 -0
- package/utils/userPromptKeywords.ts +27 -0
- package/utils/uuid.ts +27 -0
- package/utils/warningHandler.ts +121 -0
- package/utils/which.ts +82 -0
- package/utils/windowsPaths.ts +173 -0
- package/utils/withResolvers.ts +13 -0
- package/utils/words.ts +800 -0
- package/utils/workloadContext.ts +57 -0
- package/utils/worktree.ts +1519 -0
- package/utils/worktreeModeEnabled.ts +11 -0
- package/utils/xdg.ts +65 -0
- package/utils/xml.ts +16 -0
- package/utils/yaml.ts +15 -0
- package/utils/zodToJsonSchema.ts +23 -0
|
@@ -0,0 +1,1486 @@
|
|
|
1
|
+
import { feature } from 'bun:bundle'
|
|
2
|
+
import { APIUserAbortError } from '@anthropic-ai/sdk'
|
|
3
|
+
import type { CanUseToolFn } from '../../hooks/useCanUseTool.js'
|
|
4
|
+
import {
|
|
5
|
+
getToolNameForPermissionCheck,
|
|
6
|
+
mcpInfoFromString,
|
|
7
|
+
} from '../../services/mcp/mcpStringUtils.js'
|
|
8
|
+
import type { Tool, ToolPermissionContext, ToolUseContext } from '../../Tool.js'
|
|
9
|
+
import { AGENT_TOOL_NAME } from '../../tools/AgentTool/constants.js'
|
|
10
|
+
import { shouldUseSandbox } from '../../tools/BashTool/shouldUseSandbox.js'
|
|
11
|
+
import { BASH_TOOL_NAME } from '../../tools/BashTool/toolName.js'
|
|
12
|
+
import { POWERSHELL_TOOL_NAME } from '../../tools/PowerShellTool/toolName.js'
|
|
13
|
+
import { REPL_TOOL_NAME } from '../../tools/REPLTool/constants.js'
|
|
14
|
+
import type { AssistantMessage } from '../../types/message.js'
|
|
15
|
+
import { extractOutputRedirections } from '../bash/commands.js'
|
|
16
|
+
import { logForDebugging } from '../debug.js'
|
|
17
|
+
import { AbortError, toError } from '../errors.js'
|
|
18
|
+
import { logError } from '../log.js'
|
|
19
|
+
import { SandboxManager } from '../sandbox/sandbox-adapter.js'
|
|
20
|
+
import {
|
|
21
|
+
getSettingSourceDisplayNameLowercase,
|
|
22
|
+
SETTING_SOURCES,
|
|
23
|
+
} from '../settings/constants.js'
|
|
24
|
+
import { plural } from '../stringUtils.js'
|
|
25
|
+
import { permissionModeTitle } from './PermissionMode.js'
|
|
26
|
+
import type {
|
|
27
|
+
PermissionAskDecision,
|
|
28
|
+
PermissionDecision,
|
|
29
|
+
PermissionDecisionReason,
|
|
30
|
+
PermissionDenyDecision,
|
|
31
|
+
PermissionResult,
|
|
32
|
+
} from './PermissionResult.js'
|
|
33
|
+
import type {
|
|
34
|
+
PermissionBehavior,
|
|
35
|
+
PermissionRule,
|
|
36
|
+
PermissionRuleSource,
|
|
37
|
+
PermissionRuleValue,
|
|
38
|
+
} from './PermissionRule.js'
|
|
39
|
+
import {
|
|
40
|
+
applyPermissionUpdate,
|
|
41
|
+
applyPermissionUpdates,
|
|
42
|
+
persistPermissionUpdates,
|
|
43
|
+
} from './PermissionUpdate.js'
|
|
44
|
+
import type {
|
|
45
|
+
PermissionUpdate,
|
|
46
|
+
PermissionUpdateDestination,
|
|
47
|
+
} from './PermissionUpdateSchema.js'
|
|
48
|
+
import {
|
|
49
|
+
permissionRuleValueFromString,
|
|
50
|
+
permissionRuleValueToString,
|
|
51
|
+
} from './permissionRuleParser.js'
|
|
52
|
+
import {
|
|
53
|
+
deletePermissionRuleFromSettings,
|
|
54
|
+
type PermissionRuleFromEditableSettings,
|
|
55
|
+
shouldAllowManagedPermissionRulesOnly,
|
|
56
|
+
} from './permissionsLoader.js'
|
|
57
|
+
|
|
58
|
+
/* eslint-disable @typescript-eslint/no-require-imports */
|
|
59
|
+
const classifierDecisionModule = feature('TRANSCRIPT_CLASSIFIER')
|
|
60
|
+
? (require('./classifierDecision.js') as typeof import('./classifierDecision.js'))
|
|
61
|
+
: null
|
|
62
|
+
const autoModeStateModule = feature('TRANSCRIPT_CLASSIFIER')
|
|
63
|
+
? (require('./autoModeState.js') as typeof import('./autoModeState.js'))
|
|
64
|
+
: null
|
|
65
|
+
|
|
66
|
+
import {
|
|
67
|
+
addToTurnClassifierDuration,
|
|
68
|
+
getTotalCacheCreationInputTokens,
|
|
69
|
+
getTotalCacheReadInputTokens,
|
|
70
|
+
getTotalInputTokens,
|
|
71
|
+
getTotalOutputTokens,
|
|
72
|
+
} from '../../bootstrap/state.js'
|
|
73
|
+
import { getFeatureValue_CACHED_WITH_REFRESH } from '../../services/analytics/growthbook.js'
|
|
74
|
+
import {
|
|
75
|
+
type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
76
|
+
logEvent,
|
|
77
|
+
} from '../../services/analytics/index.js'
|
|
78
|
+
import { sanitizeToolNameForAnalytics } from '../../services/analytics/metadata.js'
|
|
79
|
+
import {
|
|
80
|
+
clearClassifierChecking,
|
|
81
|
+
setClassifierChecking,
|
|
82
|
+
} from '../classifierApprovals.js'
|
|
83
|
+
import { isInProtectedNamespace } from '../envUtils.js'
|
|
84
|
+
import { executePermissionRequestHooks } from '../hooks.js'
|
|
85
|
+
import {
|
|
86
|
+
AUTO_REJECT_MESSAGE,
|
|
87
|
+
buildClassifierUnavailableMessage,
|
|
88
|
+
buildYoloRejectionMessage,
|
|
89
|
+
DONT_ASK_REJECT_MESSAGE,
|
|
90
|
+
} from '../messages.js'
|
|
91
|
+
import { calculateCostFromTokens } from '../modelCost.js'
|
|
92
|
+
/* eslint-enable @typescript-eslint/no-require-imports */
|
|
93
|
+
import { jsonStringify } from '../slowOperations.js'
|
|
94
|
+
import {
|
|
95
|
+
createDenialTrackingState,
|
|
96
|
+
DENIAL_LIMITS,
|
|
97
|
+
type DenialTrackingState,
|
|
98
|
+
recordDenial,
|
|
99
|
+
recordSuccess,
|
|
100
|
+
shouldFallbackToPrompting,
|
|
101
|
+
} from './denialTracking.js'
|
|
102
|
+
import {
|
|
103
|
+
classifyYoloAction,
|
|
104
|
+
formatActionForClassifier,
|
|
105
|
+
} from './yoloClassifier.js'
|
|
106
|
+
|
|
107
|
+
const CLASSIFIER_FAIL_CLOSED_REFRESH_MS = 30 * 60 * 1000 // 30 minutes
|
|
108
|
+
|
|
109
|
+
const PERMISSION_RULE_SOURCES = [
|
|
110
|
+
...SETTING_SOURCES,
|
|
111
|
+
'cliArg',
|
|
112
|
+
'command',
|
|
113
|
+
'session',
|
|
114
|
+
] as const satisfies readonly PermissionRuleSource[]
|
|
115
|
+
|
|
116
|
+
export function permissionRuleSourceDisplayString(
|
|
117
|
+
source: PermissionRuleSource,
|
|
118
|
+
): string {
|
|
119
|
+
return getSettingSourceDisplayNameLowercase(source)
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
export function getAllowRules(
|
|
123
|
+
context: ToolPermissionContext,
|
|
124
|
+
): PermissionRule[] {
|
|
125
|
+
return PERMISSION_RULE_SOURCES.flatMap(source =>
|
|
126
|
+
(context.alwaysAllowRules[source] || []).map(ruleString => ({
|
|
127
|
+
source,
|
|
128
|
+
ruleBehavior: 'allow',
|
|
129
|
+
ruleValue: permissionRuleValueFromString(ruleString),
|
|
130
|
+
})),
|
|
131
|
+
)
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Creates a permission request message that explain the permission request
|
|
136
|
+
*/
|
|
137
|
+
export function createPermissionRequestMessage(
|
|
138
|
+
toolName: string,
|
|
139
|
+
decisionReason?: PermissionDecisionReason,
|
|
140
|
+
): string {
|
|
141
|
+
// Handle different decision reason types
|
|
142
|
+
if (decisionReason) {
|
|
143
|
+
if (
|
|
144
|
+
(feature('BASH_CLASSIFIER') || feature('TRANSCRIPT_CLASSIFIER')) &&
|
|
145
|
+
decisionReason.type === 'classifier'
|
|
146
|
+
) {
|
|
147
|
+
return `Classifier '${decisionReason.classifier}' requires approval for this ${toolName} command: ${decisionReason.reason}`
|
|
148
|
+
}
|
|
149
|
+
switch (decisionReason.type) {
|
|
150
|
+
case 'hook': {
|
|
151
|
+
const hookMessage = decisionReason.reason
|
|
152
|
+
? `Hook '${decisionReason.hookName}' blocked this action: ${decisionReason.reason}`
|
|
153
|
+
: `Hook '${decisionReason.hookName}' requires approval for this ${toolName} command`
|
|
154
|
+
return hookMessage
|
|
155
|
+
}
|
|
156
|
+
case 'rule': {
|
|
157
|
+
const ruleString = permissionRuleValueToString(
|
|
158
|
+
decisionReason.rule.ruleValue,
|
|
159
|
+
)
|
|
160
|
+
const sourceString = permissionRuleSourceDisplayString(
|
|
161
|
+
decisionReason.rule.source,
|
|
162
|
+
)
|
|
163
|
+
return `Permission rule '${ruleString}' from ${sourceString} requires approval for this ${toolName} command`
|
|
164
|
+
}
|
|
165
|
+
case 'subcommandResults': {
|
|
166
|
+
const needsApproval: string[] = []
|
|
167
|
+
for (const [cmd, result] of decisionReason.reasons) {
|
|
168
|
+
if (result.behavior === 'ask' || result.behavior === 'passthrough') {
|
|
169
|
+
// Strip output redirections for display to avoid showing filenames as commands
|
|
170
|
+
// Only do this for Bash tool to avoid affecting other tools
|
|
171
|
+
if (toolName === 'Bash') {
|
|
172
|
+
const { commandWithoutRedirections, redirections } =
|
|
173
|
+
extractOutputRedirections(cmd)
|
|
174
|
+
// Only use stripped version if there were actual redirections
|
|
175
|
+
const displayCmd =
|
|
176
|
+
redirections.length > 0 ? commandWithoutRedirections : cmd
|
|
177
|
+
needsApproval.push(displayCmd)
|
|
178
|
+
} else {
|
|
179
|
+
needsApproval.push(cmd)
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
if (needsApproval.length > 0) {
|
|
184
|
+
const n = needsApproval.length
|
|
185
|
+
return `This ${toolName} command contains multiple operations. The following ${plural(n, 'part')} ${plural(n, 'requires', 'require')} approval: ${needsApproval.join(', ')}`
|
|
186
|
+
}
|
|
187
|
+
return `This ${toolName} command contains multiple operations that require approval`
|
|
188
|
+
}
|
|
189
|
+
case 'permissionPromptTool':
|
|
190
|
+
return `Tool '${decisionReason.permissionPromptToolName}' requires approval for this ${toolName} command`
|
|
191
|
+
case 'sandboxOverride':
|
|
192
|
+
return 'Run outside of the sandbox'
|
|
193
|
+
case 'workingDir':
|
|
194
|
+
return decisionReason.reason
|
|
195
|
+
case 'safetyCheck':
|
|
196
|
+
case 'other':
|
|
197
|
+
return decisionReason.reason
|
|
198
|
+
case 'mode': {
|
|
199
|
+
const modeTitle = permissionModeTitle(decisionReason.mode)
|
|
200
|
+
return `Current permission mode (${modeTitle}) requires approval for this ${toolName} command`
|
|
201
|
+
}
|
|
202
|
+
case 'asyncAgent':
|
|
203
|
+
return decisionReason.reason
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
// Default message without listing allowed commands
|
|
208
|
+
const message = `Claude requested permissions to use ${toolName}, but you haven't granted it yet.`
|
|
209
|
+
|
|
210
|
+
return message
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
export function getDenyRules(context: ToolPermissionContext): PermissionRule[] {
|
|
214
|
+
return PERMISSION_RULE_SOURCES.flatMap(source =>
|
|
215
|
+
(context.alwaysDenyRules[source] || []).map(ruleString => ({
|
|
216
|
+
source,
|
|
217
|
+
ruleBehavior: 'deny',
|
|
218
|
+
ruleValue: permissionRuleValueFromString(ruleString),
|
|
219
|
+
})),
|
|
220
|
+
)
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
export function getAskRules(context: ToolPermissionContext): PermissionRule[] {
|
|
224
|
+
return PERMISSION_RULE_SOURCES.flatMap(source =>
|
|
225
|
+
(context.alwaysAskRules[source] || []).map(ruleString => ({
|
|
226
|
+
source,
|
|
227
|
+
ruleBehavior: 'ask',
|
|
228
|
+
ruleValue: permissionRuleValueFromString(ruleString),
|
|
229
|
+
})),
|
|
230
|
+
)
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
/**
|
|
234
|
+
* Check if the entire tool matches a rule
|
|
235
|
+
* For example, this matches "Bash" but not "Bash(prefix:*)" for BashTool
|
|
236
|
+
* This also matches MCP tools with a server name, e.g. the rule "mcp__server1"
|
|
237
|
+
*/
|
|
238
|
+
function toolMatchesRule(
|
|
239
|
+
tool: Pick<Tool, 'name' | 'mcpInfo'>,
|
|
240
|
+
rule: PermissionRule,
|
|
241
|
+
): boolean {
|
|
242
|
+
// Rule must not have content to match the entire tool
|
|
243
|
+
if (rule.ruleValue.ruleContent !== undefined) {
|
|
244
|
+
return false
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
// MCP tools are matched by their fully qualified mcp__server__tool name. In
|
|
248
|
+
// skip-prefix mode (CLAUDE_AGENT_SDK_MCP_NO_PREFIX), MCP tools have unprefixed
|
|
249
|
+
// display names (e.g., "Write") that collide with builtin names; rules targeting
|
|
250
|
+
// builtins should not match their MCP replacements.
|
|
251
|
+
const nameForRuleMatch = getToolNameForPermissionCheck(tool)
|
|
252
|
+
|
|
253
|
+
// Direct tool name match
|
|
254
|
+
if (rule.ruleValue.toolName === nameForRuleMatch) {
|
|
255
|
+
return true
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
// MCP server-level permission: rule "mcp__server1" matches tool "mcp__server1__tool1"
|
|
259
|
+
// Also supports wildcard: rule "mcp__server1__*" matches all tools from server1
|
|
260
|
+
const ruleInfo = mcpInfoFromString(rule.ruleValue.toolName)
|
|
261
|
+
const toolInfo = mcpInfoFromString(nameForRuleMatch)
|
|
262
|
+
|
|
263
|
+
return (
|
|
264
|
+
ruleInfo !== null &&
|
|
265
|
+
toolInfo !== null &&
|
|
266
|
+
(ruleInfo.toolName === undefined || ruleInfo.toolName === '*') &&
|
|
267
|
+
ruleInfo.serverName === toolInfo.serverName
|
|
268
|
+
)
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
/**
|
|
272
|
+
* Check if the entire tool is listed in the always allow rules
|
|
273
|
+
* For example, this finds "Bash" but not "Bash(prefix:*)" for BashTool
|
|
274
|
+
*/
|
|
275
|
+
export function toolAlwaysAllowedRule(
|
|
276
|
+
context: ToolPermissionContext,
|
|
277
|
+
tool: Pick<Tool, 'name' | 'mcpInfo'>,
|
|
278
|
+
): PermissionRule | null {
|
|
279
|
+
return (
|
|
280
|
+
getAllowRules(context).find(rule => toolMatchesRule(tool, rule)) || null
|
|
281
|
+
)
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
/**
|
|
285
|
+
* Check if the tool is listed in the always deny rules
|
|
286
|
+
*/
|
|
287
|
+
export function getDenyRuleForTool(
|
|
288
|
+
context: ToolPermissionContext,
|
|
289
|
+
tool: Pick<Tool, 'name' | 'mcpInfo'>,
|
|
290
|
+
): PermissionRule | null {
|
|
291
|
+
return getDenyRules(context).find(rule => toolMatchesRule(tool, rule)) || null
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
/**
|
|
295
|
+
* Check if the tool is listed in the always ask rules
|
|
296
|
+
*/
|
|
297
|
+
export function getAskRuleForTool(
|
|
298
|
+
context: ToolPermissionContext,
|
|
299
|
+
tool: Pick<Tool, 'name' | 'mcpInfo'>,
|
|
300
|
+
): PermissionRule | null {
|
|
301
|
+
return getAskRules(context).find(rule => toolMatchesRule(tool, rule)) || null
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
/**
|
|
305
|
+
* Check if a specific agent is denied via Agent(agentType) syntax.
|
|
306
|
+
* For example, Agent(Explore) would deny the Explore agent.
|
|
307
|
+
*/
|
|
308
|
+
export function getDenyRuleForAgent(
|
|
309
|
+
context: ToolPermissionContext,
|
|
310
|
+
agentToolName: string,
|
|
311
|
+
agentType: string,
|
|
312
|
+
): PermissionRule | null {
|
|
313
|
+
return (
|
|
314
|
+
getDenyRules(context).find(
|
|
315
|
+
rule =>
|
|
316
|
+
rule.ruleValue.toolName === agentToolName &&
|
|
317
|
+
rule.ruleValue.ruleContent === agentType,
|
|
318
|
+
) || null
|
|
319
|
+
)
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
/**
|
|
323
|
+
* Filter agents to exclude those that are denied via Agent(agentType) syntax.
|
|
324
|
+
*/
|
|
325
|
+
export function filterDeniedAgents<T extends { agentType: string }>(
|
|
326
|
+
agents: T[],
|
|
327
|
+
context: ToolPermissionContext,
|
|
328
|
+
agentToolName: string,
|
|
329
|
+
): T[] {
|
|
330
|
+
// Parse deny rules once and collect Agent(x) contents into a Set.
|
|
331
|
+
// Previously this called getDenyRuleForAgent per agent, which re-parsed
|
|
332
|
+
// every deny rule for every agent (O(agents×rules) parse calls).
|
|
333
|
+
const deniedAgentTypes = new Set<string>()
|
|
334
|
+
for (const rule of getDenyRules(context)) {
|
|
335
|
+
if (
|
|
336
|
+
rule.ruleValue.toolName === agentToolName &&
|
|
337
|
+
rule.ruleValue.ruleContent !== undefined
|
|
338
|
+
) {
|
|
339
|
+
deniedAgentTypes.add(rule.ruleValue.ruleContent)
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
return agents.filter(agent => !deniedAgentTypes.has(agent.agentType))
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
/**
|
|
346
|
+
* Map of rule contents to the associated rule for a given tool.
|
|
347
|
+
* e.g. the string key is "prefix:*" from "Bash(prefix:*)" for BashTool
|
|
348
|
+
*/
|
|
349
|
+
export function getRuleByContentsForTool(
|
|
350
|
+
context: ToolPermissionContext,
|
|
351
|
+
tool: Tool,
|
|
352
|
+
behavior: PermissionBehavior,
|
|
353
|
+
): Map<string, PermissionRule> {
|
|
354
|
+
return getRuleByContentsForToolName(
|
|
355
|
+
context,
|
|
356
|
+
getToolNameForPermissionCheck(tool),
|
|
357
|
+
behavior,
|
|
358
|
+
)
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
// Used to break circular dependency where a Tool calls this function
|
|
362
|
+
export function getRuleByContentsForToolName(
|
|
363
|
+
context: ToolPermissionContext,
|
|
364
|
+
toolName: string,
|
|
365
|
+
behavior: PermissionBehavior,
|
|
366
|
+
): Map<string, PermissionRule> {
|
|
367
|
+
const ruleByContents = new Map<string, PermissionRule>()
|
|
368
|
+
let rules: PermissionRule[] = []
|
|
369
|
+
switch (behavior) {
|
|
370
|
+
case 'allow':
|
|
371
|
+
rules = getAllowRules(context)
|
|
372
|
+
break
|
|
373
|
+
case 'deny':
|
|
374
|
+
rules = getDenyRules(context)
|
|
375
|
+
break
|
|
376
|
+
case 'ask':
|
|
377
|
+
rules = getAskRules(context)
|
|
378
|
+
break
|
|
379
|
+
}
|
|
380
|
+
for (const rule of rules) {
|
|
381
|
+
if (
|
|
382
|
+
rule.ruleValue.toolName === toolName &&
|
|
383
|
+
rule.ruleValue.ruleContent !== undefined &&
|
|
384
|
+
rule.ruleBehavior === behavior
|
|
385
|
+
) {
|
|
386
|
+
ruleByContents.set(rule.ruleValue.ruleContent, rule)
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
return ruleByContents
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
/**
|
|
393
|
+
* Runs PermissionRequest hooks for headless/async agents that cannot show
|
|
394
|
+
* permission prompts. This gives hooks an opportunity to allow or deny
|
|
395
|
+
* tool use before the fallback auto-deny kicks in.
|
|
396
|
+
*
|
|
397
|
+
* Returns a PermissionDecision if a hook made a decision, or null if no
|
|
398
|
+
* hook provided a decision (caller should proceed to auto-deny).
|
|
399
|
+
*/
|
|
400
|
+
async function runPermissionRequestHooksForHeadlessAgent(
|
|
401
|
+
tool: Tool,
|
|
402
|
+
input: { [key: string]: unknown },
|
|
403
|
+
toolUseID: string,
|
|
404
|
+
context: ToolUseContext,
|
|
405
|
+
permissionMode: string | undefined,
|
|
406
|
+
suggestions: PermissionUpdate[] | undefined,
|
|
407
|
+
): Promise<PermissionDecision | null> {
|
|
408
|
+
try {
|
|
409
|
+
for await (const hookResult of executePermissionRequestHooks(
|
|
410
|
+
tool.name,
|
|
411
|
+
toolUseID,
|
|
412
|
+
input,
|
|
413
|
+
context,
|
|
414
|
+
permissionMode,
|
|
415
|
+
suggestions,
|
|
416
|
+
context.abortController.signal,
|
|
417
|
+
)) {
|
|
418
|
+
if (!hookResult.permissionRequestResult) {
|
|
419
|
+
continue
|
|
420
|
+
}
|
|
421
|
+
const decision = hookResult.permissionRequestResult
|
|
422
|
+
if (decision.behavior === 'allow') {
|
|
423
|
+
const finalInput = decision.updatedInput ?? input
|
|
424
|
+
// Persist permission updates if provided
|
|
425
|
+
if (decision.updatedPermissions?.length) {
|
|
426
|
+
persistPermissionUpdates(decision.updatedPermissions)
|
|
427
|
+
context.setAppState(prev => ({
|
|
428
|
+
...prev,
|
|
429
|
+
toolPermissionContext: applyPermissionUpdates(
|
|
430
|
+
prev.toolPermissionContext,
|
|
431
|
+
decision.updatedPermissions!,
|
|
432
|
+
),
|
|
433
|
+
}))
|
|
434
|
+
}
|
|
435
|
+
return {
|
|
436
|
+
behavior: 'allow',
|
|
437
|
+
updatedInput: finalInput,
|
|
438
|
+
decisionReason: {
|
|
439
|
+
type: 'hook',
|
|
440
|
+
hookName: 'PermissionRequest',
|
|
441
|
+
},
|
|
442
|
+
}
|
|
443
|
+
}
|
|
444
|
+
if (decision.behavior === 'deny') {
|
|
445
|
+
if (decision.interrupt) {
|
|
446
|
+
logForDebugging(
|
|
447
|
+
`Hook interrupt: tool=${tool.name} hookMessage=${decision.message}`,
|
|
448
|
+
)
|
|
449
|
+
context.abortController.abort()
|
|
450
|
+
}
|
|
451
|
+
return {
|
|
452
|
+
behavior: 'deny',
|
|
453
|
+
message: decision.message || 'Permission denied by hook',
|
|
454
|
+
decisionReason: {
|
|
455
|
+
type: 'hook',
|
|
456
|
+
hookName: 'PermissionRequest',
|
|
457
|
+
reason: decision.message,
|
|
458
|
+
},
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
} catch (error) {
|
|
463
|
+
// If hooks fail, fall through to auto-deny rather than crashing
|
|
464
|
+
logError(
|
|
465
|
+
new Error('PermissionRequest hook failed for headless agent', {
|
|
466
|
+
cause: toError(error),
|
|
467
|
+
}),
|
|
468
|
+
)
|
|
469
|
+
}
|
|
470
|
+
return null
|
|
471
|
+
}
|
|
472
|
+
|
|
473
|
+
export const hasPermissionsToUseTool: CanUseToolFn = async (
|
|
474
|
+
tool,
|
|
475
|
+
input,
|
|
476
|
+
context,
|
|
477
|
+
assistantMessage,
|
|
478
|
+
toolUseID,
|
|
479
|
+
): Promise<PermissionDecision> => {
|
|
480
|
+
const result = await hasPermissionsToUseToolInner(tool, input, context)
|
|
481
|
+
|
|
482
|
+
|
|
483
|
+
// Reset consecutive denials on any allowed tool use in auto mode.
|
|
484
|
+
// This ensures that a successful tool use (even one auto-allowed by rules)
|
|
485
|
+
// breaks the consecutive denial streak.
|
|
486
|
+
if (result.behavior === 'allow') {
|
|
487
|
+
const appState = context.getAppState()
|
|
488
|
+
if (feature('TRANSCRIPT_CLASSIFIER')) {
|
|
489
|
+
const currentDenialState =
|
|
490
|
+
context.localDenialTracking ?? appState.denialTracking
|
|
491
|
+
if (
|
|
492
|
+
appState.toolPermissionContext.mode === 'auto' &&
|
|
493
|
+
currentDenialState &&
|
|
494
|
+
currentDenialState.consecutiveDenials > 0
|
|
495
|
+
) {
|
|
496
|
+
const newDenialState = recordSuccess(currentDenialState)
|
|
497
|
+
persistDenialState(context, newDenialState)
|
|
498
|
+
}
|
|
499
|
+
}
|
|
500
|
+
return result
|
|
501
|
+
}
|
|
502
|
+
|
|
503
|
+
// Apply dontAsk mode transformation: convert 'ask' to 'deny'
|
|
504
|
+
// This is done at the end so it can't be bypassed by early returns
|
|
505
|
+
if (result.behavior === 'ask') {
|
|
506
|
+
const appState = context.getAppState()
|
|
507
|
+
|
|
508
|
+
if (appState.toolPermissionContext.mode === 'dontAsk') {
|
|
509
|
+
return {
|
|
510
|
+
behavior: 'deny',
|
|
511
|
+
decisionReason: {
|
|
512
|
+
type: 'mode',
|
|
513
|
+
mode: 'dontAsk',
|
|
514
|
+
},
|
|
515
|
+
message: DONT_ASK_REJECT_MESSAGE(tool.name),
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
// Apply auto mode: use AI classifier instead of prompting user
|
|
519
|
+
// Check this BEFORE shouldAvoidPermissionPrompts so classifiers work in headless mode
|
|
520
|
+
if (
|
|
521
|
+
feature('TRANSCRIPT_CLASSIFIER') &&
|
|
522
|
+
(appState.toolPermissionContext.mode === 'auto' ||
|
|
523
|
+
(appState.toolPermissionContext.mode === 'plan' &&
|
|
524
|
+
(autoModeStateModule?.isAutoModeActive() ?? false)))
|
|
525
|
+
) {
|
|
526
|
+
// Non-classifier-approvable safetyCheck decisions stay immune to ALL
|
|
527
|
+
// auto-approve paths: the acceptEdits fast-path, the safe-tool allowlist,
|
|
528
|
+
// and the classifier. Step 1g only guards bypassPermissions; this guards
|
|
529
|
+
// auto. classifierApprovable safetyChecks (sensitive-file paths) fall
|
|
530
|
+
// through to the classifier — the fast-paths below naturally don't fire
|
|
531
|
+
// because the tool's own checkPermissions still returns 'ask'.
|
|
532
|
+
if (
|
|
533
|
+
result.decisionReason?.type === 'safetyCheck' &&
|
|
534
|
+
!result.decisionReason.classifierApprovable
|
|
535
|
+
) {
|
|
536
|
+
if (appState.toolPermissionContext.shouldAvoidPermissionPrompts) {
|
|
537
|
+
return {
|
|
538
|
+
behavior: 'deny',
|
|
539
|
+
message: result.message,
|
|
540
|
+
decisionReason: {
|
|
541
|
+
type: 'asyncAgent',
|
|
542
|
+
reason:
|
|
543
|
+
'Safety check requires interactive approval and permission prompts are not available in this context',
|
|
544
|
+
},
|
|
545
|
+
}
|
|
546
|
+
}
|
|
547
|
+
return result
|
|
548
|
+
}
|
|
549
|
+
if (tool.requiresUserInteraction?.() && result.behavior === 'ask') {
|
|
550
|
+
return result
|
|
551
|
+
}
|
|
552
|
+
|
|
553
|
+
// Use local denial tracking for async subagents (whose setAppState
|
|
554
|
+
// is a no-op), otherwise read from appState as before.
|
|
555
|
+
const denialState =
|
|
556
|
+
context.localDenialTracking ??
|
|
557
|
+
appState.denialTracking ??
|
|
558
|
+
createDenialTrackingState()
|
|
559
|
+
|
|
560
|
+
// PowerShell requires explicit user permission in auto mode unless
|
|
561
|
+
// POWERSHELL_AUTO_MODE (ant-only build flag) is on. When disabled, this
|
|
562
|
+
// guard keeps PS out of the classifier and skips the acceptEdits
|
|
563
|
+
// fast-path below. When enabled, PS flows through to the classifier like
|
|
564
|
+
// Bash — the classifier prompt gets POWERSHELL_DENY_GUIDANCE appended so
|
|
565
|
+
// it recognizes `iex (iwr ...)` as download-and-execute, etc.
|
|
566
|
+
// Note: this runs inside the behavior === 'ask' branch, so allow rules
|
|
567
|
+
// that fire earlier (step 2b toolAlwaysAllowedRule, PS prefix allow)
|
|
568
|
+
// return before reaching here. Allow-rule protection is handled by
|
|
569
|
+
// permissionSetup.ts: isOverlyBroadPowerShellAllowRule strips PowerShell(*)
|
|
570
|
+
// and isDangerousPowerShellPermission strips iex/pwsh/Start-Process
|
|
571
|
+
// prefix rules for ant users and auto mode entry.
|
|
572
|
+
if (
|
|
573
|
+
tool.name === POWERSHELL_TOOL_NAME &&
|
|
574
|
+
!feature('POWERSHELL_AUTO_MODE')
|
|
575
|
+
) {
|
|
576
|
+
if (appState.toolPermissionContext.shouldAvoidPermissionPrompts) {
|
|
577
|
+
return {
|
|
578
|
+
behavior: 'deny',
|
|
579
|
+
message: 'PowerShell tool requires interactive approval',
|
|
580
|
+
decisionReason: {
|
|
581
|
+
type: 'asyncAgent',
|
|
582
|
+
reason:
|
|
583
|
+
'PowerShell tool requires interactive approval and permission prompts are not available in this context',
|
|
584
|
+
},
|
|
585
|
+
}
|
|
586
|
+
}
|
|
587
|
+
logForDebugging(
|
|
588
|
+
`Skipping auto mode classifier for ${tool.name}: tool requires explicit user permission`,
|
|
589
|
+
)
|
|
590
|
+
return result
|
|
591
|
+
}
|
|
592
|
+
|
|
593
|
+
// Before running the auto mode classifier, check if acceptEdits mode would
|
|
594
|
+
// allow this action. This avoids expensive classifier API calls for safe
|
|
595
|
+
// operations like file edits in the working directory.
|
|
596
|
+
// Skip for Agent and REPL — their checkPermissions returns 'allow' for
|
|
597
|
+
// acceptEdits mode, which would silently bypass the classifier. REPL
|
|
598
|
+
// code can contain VM escapes between inner tool calls; the classifier
|
|
599
|
+
// must see the glue JavaScript, not just the inner tool calls.
|
|
600
|
+
if (
|
|
601
|
+
result.behavior === 'ask' &&
|
|
602
|
+
tool.name !== AGENT_TOOL_NAME &&
|
|
603
|
+
tool.name !== REPL_TOOL_NAME
|
|
604
|
+
) {
|
|
605
|
+
try {
|
|
606
|
+
const parsedInput = tool.inputSchema.parse(input)
|
|
607
|
+
const acceptEditsResult = await tool.checkPermissions(parsedInput, {
|
|
608
|
+
...context,
|
|
609
|
+
getAppState: () => {
|
|
610
|
+
const state = context.getAppState()
|
|
611
|
+
return {
|
|
612
|
+
...state,
|
|
613
|
+
toolPermissionContext: {
|
|
614
|
+
...state.toolPermissionContext,
|
|
615
|
+
mode: 'acceptEdits' as const,
|
|
616
|
+
},
|
|
617
|
+
}
|
|
618
|
+
},
|
|
619
|
+
})
|
|
620
|
+
if (acceptEditsResult.behavior === 'allow') {
|
|
621
|
+
const newDenialState = recordSuccess(denialState)
|
|
622
|
+
persistDenialState(context, newDenialState)
|
|
623
|
+
logForDebugging(
|
|
624
|
+
`Skipping auto mode classifier for ${tool.name}: would be allowed in acceptEdits mode`,
|
|
625
|
+
)
|
|
626
|
+
logEvent('tengu_auto_mode_decision', {
|
|
627
|
+
decision:
|
|
628
|
+
'allowed' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
629
|
+
toolName: sanitizeToolNameForAnalytics(tool.name),
|
|
630
|
+
inProtectedNamespace: isInProtectedNamespace(),
|
|
631
|
+
// msg_id of the agent completion that produced this tool_use —
|
|
632
|
+
// the action at the bottom of the classifier transcript. Joins
|
|
633
|
+
// the decision back to the main agent's API response.
|
|
634
|
+
agentMsgId: assistantMessage.message
|
|
635
|
+
.id as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
636
|
+
confidence:
|
|
637
|
+
'high' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
638
|
+
fastPath:
|
|
639
|
+
'acceptEdits' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
640
|
+
})
|
|
641
|
+
return {
|
|
642
|
+
behavior: 'allow',
|
|
643
|
+
updatedInput: acceptEditsResult.updatedInput ?? input,
|
|
644
|
+
decisionReason: {
|
|
645
|
+
type: 'mode',
|
|
646
|
+
mode: 'auto',
|
|
647
|
+
},
|
|
648
|
+
}
|
|
649
|
+
}
|
|
650
|
+
} catch (e) {
|
|
651
|
+
if (e instanceof AbortError || e instanceof APIUserAbortError) {
|
|
652
|
+
throw e
|
|
653
|
+
}
|
|
654
|
+
// If the acceptEdits check fails, fall through to the classifier
|
|
655
|
+
}
|
|
656
|
+
}
|
|
657
|
+
|
|
658
|
+
// Allowlisted tools are safe and don't need YOLO classification.
|
|
659
|
+
// This uses the safe-tool allowlist to skip unnecessary classifier API calls.
|
|
660
|
+
if (classifierDecisionModule!.isAutoModeAllowlistedTool(tool.name)) {
|
|
661
|
+
const newDenialState = recordSuccess(denialState)
|
|
662
|
+
persistDenialState(context, newDenialState)
|
|
663
|
+
logForDebugging(
|
|
664
|
+
`Skipping auto mode classifier for ${tool.name}: tool is on the safe allowlist`,
|
|
665
|
+
)
|
|
666
|
+
logEvent('tengu_auto_mode_decision', {
|
|
667
|
+
decision:
|
|
668
|
+
'allowed' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
669
|
+
toolName: sanitizeToolNameForAnalytics(tool.name),
|
|
670
|
+
inProtectedNamespace: isInProtectedNamespace(),
|
|
671
|
+
agentMsgId: assistantMessage.message
|
|
672
|
+
.id as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
673
|
+
confidence:
|
|
674
|
+
'high' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
675
|
+
fastPath:
|
|
676
|
+
'allowlist' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
677
|
+
})
|
|
678
|
+
return {
|
|
679
|
+
behavior: 'allow',
|
|
680
|
+
updatedInput: input,
|
|
681
|
+
decisionReason: {
|
|
682
|
+
type: 'mode',
|
|
683
|
+
mode: 'auto',
|
|
684
|
+
},
|
|
685
|
+
}
|
|
686
|
+
}
|
|
687
|
+
|
|
688
|
+
// Run the auto mode classifier
|
|
689
|
+
const action = formatActionForClassifier(tool.name, input)
|
|
690
|
+
setClassifierChecking(toolUseID)
|
|
691
|
+
let classifierResult
|
|
692
|
+
try {
|
|
693
|
+
classifierResult = await classifyYoloAction(
|
|
694
|
+
context.messages,
|
|
695
|
+
action,
|
|
696
|
+
context.options.tools,
|
|
697
|
+
appState.toolPermissionContext,
|
|
698
|
+
context.abortController.signal,
|
|
699
|
+
)
|
|
700
|
+
} finally {
|
|
701
|
+
clearClassifierChecking(toolUseID)
|
|
702
|
+
}
|
|
703
|
+
|
|
704
|
+
// Notify ants when classifier error dumped prompts (will be in /share)
|
|
705
|
+
if (
|
|
706
|
+
process.env.USER_TYPE === 'ant' &&
|
|
707
|
+
classifierResult.errorDumpPath &&
|
|
708
|
+
context.addNotification
|
|
709
|
+
) {
|
|
710
|
+
context.addNotification({
|
|
711
|
+
key: 'auto-mode-error-dump',
|
|
712
|
+
text: `Auto mode classifier error — prompts dumped to ${classifierResult.errorDumpPath} (included in /share)`,
|
|
713
|
+
priority: 'immediate',
|
|
714
|
+
color: 'error',
|
|
715
|
+
})
|
|
716
|
+
}
|
|
717
|
+
|
|
718
|
+
// Log classifier decision for metrics (including overhead telemetry)
|
|
719
|
+
const yoloDecision = classifierResult.unavailable
|
|
720
|
+
? 'unavailable'
|
|
721
|
+
: classifierResult.shouldBlock
|
|
722
|
+
? 'blocked'
|
|
723
|
+
: 'allowed'
|
|
724
|
+
|
|
725
|
+
// Compute classifier cost in USD for overhead analysis
|
|
726
|
+
const classifierCostUSD =
|
|
727
|
+
classifierResult.usage && classifierResult.model
|
|
728
|
+
? calculateCostFromTokens(
|
|
729
|
+
classifierResult.model,
|
|
730
|
+
classifierResult.usage,
|
|
731
|
+
)
|
|
732
|
+
: undefined
|
|
733
|
+
logEvent('tengu_auto_mode_decision', {
|
|
734
|
+
decision:
|
|
735
|
+
yoloDecision as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
736
|
+
toolName: sanitizeToolNameForAnalytics(tool.name),
|
|
737
|
+
inProtectedNamespace: isInProtectedNamespace(),
|
|
738
|
+
// msg_id of the agent completion that produced this tool_use —
|
|
739
|
+
// the action at the bottom of the classifier transcript.
|
|
740
|
+
agentMsgId: assistantMessage.message
|
|
741
|
+
.id as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
742
|
+
classifierModel:
|
|
743
|
+
classifierResult.model as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
744
|
+
consecutiveDenials: classifierResult.shouldBlock
|
|
745
|
+
? denialState.consecutiveDenials + 1
|
|
746
|
+
: 0,
|
|
747
|
+
totalDenials: classifierResult.shouldBlock
|
|
748
|
+
? denialState.totalDenials + 1
|
|
749
|
+
: denialState.totalDenials,
|
|
750
|
+
// Overhead telemetry: token usage and latency for the classifier API call
|
|
751
|
+
classifierInputTokens: classifierResult.usage?.inputTokens,
|
|
752
|
+
classifierOutputTokens: classifierResult.usage?.outputTokens,
|
|
753
|
+
classifierCacheReadInputTokens:
|
|
754
|
+
classifierResult.usage?.cacheReadInputTokens,
|
|
755
|
+
classifierCacheCreationInputTokens:
|
|
756
|
+
classifierResult.usage?.cacheCreationInputTokens,
|
|
757
|
+
classifierDurationMs: classifierResult.durationMs,
|
|
758
|
+
// Character lengths of the prompt components sent to the classifier
|
|
759
|
+
classifierSystemPromptLength:
|
|
760
|
+
classifierResult.promptLengths?.systemPrompt,
|
|
761
|
+
classifierToolCallsLength: classifierResult.promptLengths?.toolCalls,
|
|
762
|
+
classifierUserPromptsLength:
|
|
763
|
+
classifierResult.promptLengths?.userPrompts,
|
|
764
|
+
// Session totals at time of classifier call (for computing overhead %).
|
|
765
|
+
// These are main-transcript-only — sideQuery (used by the classifier)
|
|
766
|
+
// does NOT call addToTotalSessionCost, so classifier tokens are excluded.
|
|
767
|
+
sessionInputTokens: getTotalInputTokens(),
|
|
768
|
+
sessionOutputTokens: getTotalOutputTokens(),
|
|
769
|
+
sessionCacheReadInputTokens: getTotalCacheReadInputTokens(),
|
|
770
|
+
sessionCacheCreationInputTokens: getTotalCacheCreationInputTokens(),
|
|
771
|
+
classifierCostUSD,
|
|
772
|
+
classifierStage:
|
|
773
|
+
classifierResult.stage as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
774
|
+
classifierStage1InputTokens: classifierResult.stage1Usage?.inputTokens,
|
|
775
|
+
classifierStage1OutputTokens:
|
|
776
|
+
classifierResult.stage1Usage?.outputTokens,
|
|
777
|
+
classifierStage1CacheReadInputTokens:
|
|
778
|
+
classifierResult.stage1Usage?.cacheReadInputTokens,
|
|
779
|
+
classifierStage1CacheCreationInputTokens:
|
|
780
|
+
classifierResult.stage1Usage?.cacheCreationInputTokens,
|
|
781
|
+
classifierStage1DurationMs: classifierResult.stage1DurationMs,
|
|
782
|
+
classifierStage1RequestId:
|
|
783
|
+
classifierResult.stage1RequestId as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
784
|
+
classifierStage1MsgId:
|
|
785
|
+
classifierResult.stage1MsgId as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
786
|
+
classifierStage1CostUSD:
|
|
787
|
+
classifierResult.stage1Usage && classifierResult.model
|
|
788
|
+
? calculateCostFromTokens(
|
|
789
|
+
classifierResult.model,
|
|
790
|
+
classifierResult.stage1Usage,
|
|
791
|
+
)
|
|
792
|
+
: undefined,
|
|
793
|
+
classifierStage2InputTokens: classifierResult.stage2Usage?.inputTokens,
|
|
794
|
+
classifierStage2OutputTokens:
|
|
795
|
+
classifierResult.stage2Usage?.outputTokens,
|
|
796
|
+
classifierStage2CacheReadInputTokens:
|
|
797
|
+
classifierResult.stage2Usage?.cacheReadInputTokens,
|
|
798
|
+
classifierStage2CacheCreationInputTokens:
|
|
799
|
+
classifierResult.stage2Usage?.cacheCreationInputTokens,
|
|
800
|
+
classifierStage2DurationMs: classifierResult.stage2DurationMs,
|
|
801
|
+
classifierStage2RequestId:
|
|
802
|
+
classifierResult.stage2RequestId as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
803
|
+
classifierStage2MsgId:
|
|
804
|
+
classifierResult.stage2MsgId as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
805
|
+
classifierStage2CostUSD:
|
|
806
|
+
classifierResult.stage2Usage && classifierResult.model
|
|
807
|
+
? calculateCostFromTokens(
|
|
808
|
+
classifierResult.model,
|
|
809
|
+
classifierResult.stage2Usage,
|
|
810
|
+
)
|
|
811
|
+
: undefined,
|
|
812
|
+
})
|
|
813
|
+
|
|
814
|
+
if (classifierResult.durationMs !== undefined) {
|
|
815
|
+
addToTurnClassifierDuration(classifierResult.durationMs)
|
|
816
|
+
}
|
|
817
|
+
|
|
818
|
+
if (classifierResult.shouldBlock) {
|
|
819
|
+
// Transcript exceeded the classifier's context window — deterministic
|
|
820
|
+
// error, won't recover on retry. Skip iron_gate and fall back to
|
|
821
|
+
// normal prompting so the user can approve/deny manually.
|
|
822
|
+
if (classifierResult.transcriptTooLong) {
|
|
823
|
+
if (appState.toolPermissionContext.shouldAvoidPermissionPrompts) {
|
|
824
|
+
// Permanent condition (transcript only grows) — deny-retry-deny
|
|
825
|
+
// wastes tokens without ever hitting the denial-limit abort.
|
|
826
|
+
throw new AbortError(
|
|
827
|
+
'Agent aborted: auto mode classifier transcript exceeded context window in headless mode',
|
|
828
|
+
)
|
|
829
|
+
}
|
|
830
|
+
logForDebugging(
|
|
831
|
+
'Auto mode classifier transcript too long, falling back to normal permission handling',
|
|
832
|
+
{ level: 'warn' },
|
|
833
|
+
)
|
|
834
|
+
return {
|
|
835
|
+
...result,
|
|
836
|
+
decisionReason: {
|
|
837
|
+
type: 'other',
|
|
838
|
+
reason:
|
|
839
|
+
'Auto mode classifier transcript exceeded context window — falling back to manual approval',
|
|
840
|
+
},
|
|
841
|
+
}
|
|
842
|
+
}
|
|
843
|
+
// When classifier is unavailable (API error), behavior depends on
|
|
844
|
+
// the tengu_iron_gate_closed gate.
|
|
845
|
+
if (classifierResult.unavailable) {
|
|
846
|
+
if (
|
|
847
|
+
getFeatureValue_CACHED_WITH_REFRESH(
|
|
848
|
+
'tengu_iron_gate_closed',
|
|
849
|
+
true,
|
|
850
|
+
CLASSIFIER_FAIL_CLOSED_REFRESH_MS,
|
|
851
|
+
)
|
|
852
|
+
) {
|
|
853
|
+
logForDebugging(
|
|
854
|
+
'Auto mode classifier unavailable, denying with retry guidance (fail closed)',
|
|
855
|
+
{ level: 'warn' },
|
|
856
|
+
)
|
|
857
|
+
return {
|
|
858
|
+
behavior: 'deny',
|
|
859
|
+
decisionReason: {
|
|
860
|
+
type: 'classifier',
|
|
861
|
+
classifier: 'auto-mode',
|
|
862
|
+
reason: 'Classifier unavailable',
|
|
863
|
+
},
|
|
864
|
+
message: buildClassifierUnavailableMessage(
|
|
865
|
+
tool.name,
|
|
866
|
+
classifierResult.model,
|
|
867
|
+
),
|
|
868
|
+
}
|
|
869
|
+
}
|
|
870
|
+
// Fail open: fall back to normal permission handling
|
|
871
|
+
logForDebugging(
|
|
872
|
+
'Auto mode classifier unavailable, falling back to normal permission handling (fail open)',
|
|
873
|
+
{ level: 'warn' },
|
|
874
|
+
)
|
|
875
|
+
return result
|
|
876
|
+
}
|
|
877
|
+
|
|
878
|
+
// Update denial tracking and check limits
|
|
879
|
+
const newDenialState = recordDenial(denialState)
|
|
880
|
+
persistDenialState(context, newDenialState)
|
|
881
|
+
|
|
882
|
+
logForDebugging(
|
|
883
|
+
`Auto mode classifier blocked action: ${classifierResult.reason}`,
|
|
884
|
+
{ level: 'warn' },
|
|
885
|
+
)
|
|
886
|
+
|
|
887
|
+
// If denial limit hit, fall back to prompting so the user
|
|
888
|
+
// can review. We check after the classifier so we can include
|
|
889
|
+
// its reason in the prompt.
|
|
890
|
+
const denialLimitResult = handleDenialLimitExceeded(
|
|
891
|
+
newDenialState,
|
|
892
|
+
appState,
|
|
893
|
+
classifierResult.reason,
|
|
894
|
+
assistantMessage,
|
|
895
|
+
tool,
|
|
896
|
+
result,
|
|
897
|
+
context,
|
|
898
|
+
)
|
|
899
|
+
if (denialLimitResult) {
|
|
900
|
+
return denialLimitResult
|
|
901
|
+
}
|
|
902
|
+
|
|
903
|
+
return {
|
|
904
|
+
behavior: 'deny',
|
|
905
|
+
decisionReason: {
|
|
906
|
+
type: 'classifier',
|
|
907
|
+
classifier: 'auto-mode',
|
|
908
|
+
reason: classifierResult.reason,
|
|
909
|
+
},
|
|
910
|
+
message: buildYoloRejectionMessage(classifierResult.reason),
|
|
911
|
+
}
|
|
912
|
+
}
|
|
913
|
+
|
|
914
|
+
// Reset consecutive denials on success
|
|
915
|
+
const newDenialState = recordSuccess(denialState)
|
|
916
|
+
persistDenialState(context, newDenialState)
|
|
917
|
+
|
|
918
|
+
return {
|
|
919
|
+
behavior: 'allow',
|
|
920
|
+
updatedInput: input,
|
|
921
|
+
decisionReason: {
|
|
922
|
+
type: 'classifier',
|
|
923
|
+
classifier: 'auto-mode',
|
|
924
|
+
reason: classifierResult.reason,
|
|
925
|
+
},
|
|
926
|
+
}
|
|
927
|
+
}
|
|
928
|
+
|
|
929
|
+
// When permission prompts should be avoided (e.g., background/headless agents),
|
|
930
|
+
// run PermissionRequest hooks first to give them a chance to allow/deny.
|
|
931
|
+
// Only auto-deny if no hook provides a decision.
|
|
932
|
+
if (appState.toolPermissionContext.shouldAvoidPermissionPrompts) {
|
|
933
|
+
const hookDecision = await runPermissionRequestHooksForHeadlessAgent(
|
|
934
|
+
tool,
|
|
935
|
+
input,
|
|
936
|
+
toolUseID,
|
|
937
|
+
context,
|
|
938
|
+
appState.toolPermissionContext.mode,
|
|
939
|
+
result.suggestions,
|
|
940
|
+
)
|
|
941
|
+
if (hookDecision) {
|
|
942
|
+
return hookDecision
|
|
943
|
+
}
|
|
944
|
+
return {
|
|
945
|
+
behavior: 'deny',
|
|
946
|
+
decisionReason: {
|
|
947
|
+
type: 'asyncAgent',
|
|
948
|
+
reason: 'Permission prompts are not available in this context',
|
|
949
|
+
},
|
|
950
|
+
message: AUTO_REJECT_MESSAGE(tool.name),
|
|
951
|
+
}
|
|
952
|
+
}
|
|
953
|
+
}
|
|
954
|
+
|
|
955
|
+
return result
|
|
956
|
+
}
|
|
957
|
+
|
|
958
|
+
/**
|
|
959
|
+
* Persist denial tracking state. For async subagents with localDenialTracking,
|
|
960
|
+
* mutate the local state in place (since setAppState is a no-op). Otherwise,
|
|
961
|
+
* write to appState as usual.
|
|
962
|
+
*/
|
|
963
|
+
function persistDenialState(
|
|
964
|
+
context: ToolUseContext,
|
|
965
|
+
newState: DenialTrackingState,
|
|
966
|
+
): void {
|
|
967
|
+
if (context.localDenialTracking) {
|
|
968
|
+
Object.assign(context.localDenialTracking, newState)
|
|
969
|
+
} else {
|
|
970
|
+
context.setAppState(prev => {
|
|
971
|
+
// recordSuccess returns the same reference when state is
|
|
972
|
+
// unchanged. Returning prev here lets store.setState's Object.is check
|
|
973
|
+
// skip the listener loop entirely.
|
|
974
|
+
if (prev.denialTracking === newState) return prev
|
|
975
|
+
return { ...prev, denialTracking: newState }
|
|
976
|
+
})
|
|
977
|
+
}
|
|
978
|
+
}
|
|
979
|
+
|
|
980
|
+
/**
|
|
981
|
+
* Check if a denial limit was exceeded and return an 'ask' result
|
|
982
|
+
* so the user can review. Returns null if no limit was hit.
|
|
983
|
+
*/
|
|
984
|
+
function handleDenialLimitExceeded(
|
|
985
|
+
denialState: DenialTrackingState,
|
|
986
|
+
appState: {
|
|
987
|
+
toolPermissionContext: { shouldAvoidPermissionPrompts?: boolean }
|
|
988
|
+
},
|
|
989
|
+
classifierReason: string,
|
|
990
|
+
assistantMessage: AssistantMessage,
|
|
991
|
+
tool: Tool,
|
|
992
|
+
result: PermissionDecision,
|
|
993
|
+
context: ToolUseContext,
|
|
994
|
+
): PermissionDecision | null {
|
|
995
|
+
if (!shouldFallbackToPrompting(denialState)) {
|
|
996
|
+
return null
|
|
997
|
+
}
|
|
998
|
+
|
|
999
|
+
const hitTotalLimit = denialState.totalDenials >= DENIAL_LIMITS.maxTotal
|
|
1000
|
+
const isHeadless = appState.toolPermissionContext.shouldAvoidPermissionPrompts
|
|
1001
|
+
// Capture counts before persistDenialState, which may mutate denialState
|
|
1002
|
+
// in-place via Object.assign for subagents with localDenialTracking.
|
|
1003
|
+
const totalCount = denialState.totalDenials
|
|
1004
|
+
const consecutiveCount = denialState.consecutiveDenials
|
|
1005
|
+
const warning = hitTotalLimit
|
|
1006
|
+
? `${totalCount} actions were blocked this session. Please review the transcript before continuing.`
|
|
1007
|
+
: `${consecutiveCount} consecutive actions were blocked. Please review the transcript before continuing.`
|
|
1008
|
+
|
|
1009
|
+
logEvent('tengu_auto_mode_denial_limit_exceeded', {
|
|
1010
|
+
limit: (hitTotalLimit
|
|
1011
|
+
? 'total'
|
|
1012
|
+
: 'consecutive') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
1013
|
+
mode: (isHeadless
|
|
1014
|
+
? 'headless'
|
|
1015
|
+
: 'cli') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
1016
|
+
messageID: assistantMessage.message
|
|
1017
|
+
.id as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,
|
|
1018
|
+
consecutiveDenials: consecutiveCount,
|
|
1019
|
+
totalDenials: totalCount,
|
|
1020
|
+
toolName: sanitizeToolNameForAnalytics(tool.name),
|
|
1021
|
+
})
|
|
1022
|
+
|
|
1023
|
+
if (isHeadless) {
|
|
1024
|
+
throw new AbortError(
|
|
1025
|
+
'Agent aborted: too many classifier denials in headless mode',
|
|
1026
|
+
)
|
|
1027
|
+
}
|
|
1028
|
+
|
|
1029
|
+
logForDebugging(
|
|
1030
|
+
`Classifier denial limit exceeded, falling back to prompting: ${warning}`,
|
|
1031
|
+
{ level: 'warn' },
|
|
1032
|
+
)
|
|
1033
|
+
|
|
1034
|
+
if (hitTotalLimit) {
|
|
1035
|
+
persistDenialState(context, {
|
|
1036
|
+
...denialState,
|
|
1037
|
+
totalDenials: 0,
|
|
1038
|
+
consecutiveDenials: 0,
|
|
1039
|
+
})
|
|
1040
|
+
}
|
|
1041
|
+
|
|
1042
|
+
// Preserve the original classifier value (e.g. 'dangerous-agent-action')
|
|
1043
|
+
// so downstream analytics in interactiveHandler can log the correct
|
|
1044
|
+
// user override event.
|
|
1045
|
+
const originalClassifier =
|
|
1046
|
+
result.decisionReason?.type === 'classifier'
|
|
1047
|
+
? result.decisionReason.classifier
|
|
1048
|
+
: 'auto-mode'
|
|
1049
|
+
|
|
1050
|
+
return {
|
|
1051
|
+
...result,
|
|
1052
|
+
decisionReason: {
|
|
1053
|
+
type: 'classifier',
|
|
1054
|
+
classifier: originalClassifier,
|
|
1055
|
+
reason: `${warning}\n\nLatest blocked action: ${classifierReason}`,
|
|
1056
|
+
},
|
|
1057
|
+
}
|
|
1058
|
+
}
|
|
1059
|
+
|
|
1060
|
+
/**
|
|
1061
|
+
* Check only the rule-based steps of the permission pipeline — the subset
|
|
1062
|
+
* that bypassPermissions mode respects (everything that fires before step 2a).
|
|
1063
|
+
*
|
|
1064
|
+
* Returns a deny/ask decision if a rule blocks the tool, or null if no rule
|
|
1065
|
+
* objects. Unlike hasPermissionsToUseTool, this does NOT run the auto mode classifier,
|
|
1066
|
+
* mode-based transformations (dontAsk/auto/asyncAgent), PermissionRequest hooks,
|
|
1067
|
+
* or bypassPermissions / always-allowed checks.
|
|
1068
|
+
*
|
|
1069
|
+
* Caller must pre-check tool.requiresUserInteraction() — step 1e is not replicated.
|
|
1070
|
+
*/
|
|
1071
|
+
export async function checkRuleBasedPermissions(
|
|
1072
|
+
tool: Tool,
|
|
1073
|
+
input: { [key: string]: unknown },
|
|
1074
|
+
context: ToolUseContext,
|
|
1075
|
+
): Promise<PermissionAskDecision | PermissionDenyDecision | null> {
|
|
1076
|
+
const appState = context.getAppState()
|
|
1077
|
+
|
|
1078
|
+
// 1a. Entire tool is denied by rule
|
|
1079
|
+
const denyRule = getDenyRuleForTool(appState.toolPermissionContext, tool)
|
|
1080
|
+
if (denyRule) {
|
|
1081
|
+
return {
|
|
1082
|
+
behavior: 'deny',
|
|
1083
|
+
decisionReason: {
|
|
1084
|
+
type: 'rule',
|
|
1085
|
+
rule: denyRule,
|
|
1086
|
+
},
|
|
1087
|
+
message: `Permission to use ${tool.name} has been denied.`,
|
|
1088
|
+
}
|
|
1089
|
+
}
|
|
1090
|
+
|
|
1091
|
+
// 1b. Entire tool has an ask rule
|
|
1092
|
+
const askRule = getAskRuleForTool(appState.toolPermissionContext, tool)
|
|
1093
|
+
if (askRule) {
|
|
1094
|
+
const canSandboxAutoAllow =
|
|
1095
|
+
tool.name === BASH_TOOL_NAME &&
|
|
1096
|
+
SandboxManager.isSandboxingEnabled() &&
|
|
1097
|
+
SandboxManager.isAutoAllowBashIfSandboxedEnabled() &&
|
|
1098
|
+
shouldUseSandbox(input)
|
|
1099
|
+
|
|
1100
|
+
if (!canSandboxAutoAllow) {
|
|
1101
|
+
return {
|
|
1102
|
+
behavior: 'ask',
|
|
1103
|
+
decisionReason: {
|
|
1104
|
+
type: 'rule',
|
|
1105
|
+
rule: askRule,
|
|
1106
|
+
},
|
|
1107
|
+
message: createPermissionRequestMessage(tool.name),
|
|
1108
|
+
}
|
|
1109
|
+
}
|
|
1110
|
+
// Fall through to let tool.checkPermissions handle command-specific rules
|
|
1111
|
+
}
|
|
1112
|
+
|
|
1113
|
+
// 1c. Tool-specific permission check (e.g. bash subcommand rules)
|
|
1114
|
+
let toolPermissionResult: PermissionResult = {
|
|
1115
|
+
behavior: 'passthrough',
|
|
1116
|
+
message: createPermissionRequestMessage(tool.name),
|
|
1117
|
+
}
|
|
1118
|
+
try {
|
|
1119
|
+
const parsedInput = tool.inputSchema.parse(input)
|
|
1120
|
+
toolPermissionResult = await tool.checkPermissions(parsedInput, context)
|
|
1121
|
+
} catch (e) {
|
|
1122
|
+
if (e instanceof AbortError || e instanceof APIUserAbortError) {
|
|
1123
|
+
throw e
|
|
1124
|
+
}
|
|
1125
|
+
logError(e)
|
|
1126
|
+
}
|
|
1127
|
+
|
|
1128
|
+
// 1d. Tool implementation denied (catches bash subcommand denies wrapped
|
|
1129
|
+
// in subcommandResults — no need to inspect decisionReason.type)
|
|
1130
|
+
if (toolPermissionResult?.behavior === 'deny') {
|
|
1131
|
+
return toolPermissionResult
|
|
1132
|
+
}
|
|
1133
|
+
|
|
1134
|
+
// 1f. Content-specific ask rules from tool.checkPermissions
|
|
1135
|
+
// (e.g. Bash(npm publish:*) → {ask, type:'rule', ruleBehavior:'ask'})
|
|
1136
|
+
if (
|
|
1137
|
+
toolPermissionResult?.behavior === 'ask' &&
|
|
1138
|
+
toolPermissionResult.decisionReason?.type === 'rule' &&
|
|
1139
|
+
toolPermissionResult.decisionReason.rule.ruleBehavior === 'ask'
|
|
1140
|
+
) {
|
|
1141
|
+
return toolPermissionResult
|
|
1142
|
+
}
|
|
1143
|
+
|
|
1144
|
+
// 1g. Safety checks (e.g. .git/, .claude/, .vscode/, shell configs) are
|
|
1145
|
+
// bypass-immune — they must prompt even when a PreToolUse hook returned
|
|
1146
|
+
// allow. checkPathSafetyForAutoEdit returns {type:'safetyCheck'} for these.
|
|
1147
|
+
if (
|
|
1148
|
+
toolPermissionResult?.behavior === 'ask' &&
|
|
1149
|
+
toolPermissionResult.decisionReason?.type === 'safetyCheck'
|
|
1150
|
+
) {
|
|
1151
|
+
return toolPermissionResult
|
|
1152
|
+
}
|
|
1153
|
+
|
|
1154
|
+
// No rule-based objection
|
|
1155
|
+
return null
|
|
1156
|
+
}
|
|
1157
|
+
|
|
1158
|
+
async function hasPermissionsToUseToolInner(
|
|
1159
|
+
tool: Tool,
|
|
1160
|
+
input: { [key: string]: unknown },
|
|
1161
|
+
context: ToolUseContext,
|
|
1162
|
+
): Promise<PermissionDecision> {
|
|
1163
|
+
if (context.abortController.signal.aborted) {
|
|
1164
|
+
throw new AbortError()
|
|
1165
|
+
}
|
|
1166
|
+
|
|
1167
|
+
let appState = context.getAppState()
|
|
1168
|
+
|
|
1169
|
+
// 1. Check if the tool is denied
|
|
1170
|
+
// 1a. Entire tool is denied
|
|
1171
|
+
const denyRule = getDenyRuleForTool(appState.toolPermissionContext, tool)
|
|
1172
|
+
if (denyRule) {
|
|
1173
|
+
return {
|
|
1174
|
+
behavior: 'deny',
|
|
1175
|
+
decisionReason: {
|
|
1176
|
+
type: 'rule',
|
|
1177
|
+
rule: denyRule,
|
|
1178
|
+
},
|
|
1179
|
+
message: `Permission to use ${tool.name} has been denied.`,
|
|
1180
|
+
}
|
|
1181
|
+
}
|
|
1182
|
+
|
|
1183
|
+
// 1b. Check if the entire tool should always ask for permission
|
|
1184
|
+
const askRule = getAskRuleForTool(appState.toolPermissionContext, tool)
|
|
1185
|
+
if (askRule) {
|
|
1186
|
+
// When autoAllowBashIfSandboxed is on, sandboxed commands skip the ask rule and
|
|
1187
|
+
// auto-allow via Bash's checkPermissions. Commands that won't be sandboxed (excluded
|
|
1188
|
+
// commands, dangerouslyDisableSandbox) still need to respect the ask rule.
|
|
1189
|
+
const canSandboxAutoAllow =
|
|
1190
|
+
tool.name === BASH_TOOL_NAME &&
|
|
1191
|
+
SandboxManager.isSandboxingEnabled() &&
|
|
1192
|
+
SandboxManager.isAutoAllowBashIfSandboxedEnabled() &&
|
|
1193
|
+
shouldUseSandbox(input)
|
|
1194
|
+
|
|
1195
|
+
if (!canSandboxAutoAllow) {
|
|
1196
|
+
return {
|
|
1197
|
+
behavior: 'ask',
|
|
1198
|
+
decisionReason: {
|
|
1199
|
+
type: 'rule',
|
|
1200
|
+
rule: askRule,
|
|
1201
|
+
},
|
|
1202
|
+
message: createPermissionRequestMessage(tool.name),
|
|
1203
|
+
}
|
|
1204
|
+
}
|
|
1205
|
+
// Fall through to let Bash's checkPermissions handle command-specific rules
|
|
1206
|
+
}
|
|
1207
|
+
|
|
1208
|
+
// 1c. Ask the tool implementation for a permission result
|
|
1209
|
+
// Overridden unless tool input schema is not valid
|
|
1210
|
+
let toolPermissionResult: PermissionResult = {
|
|
1211
|
+
behavior: 'passthrough',
|
|
1212
|
+
message: createPermissionRequestMessage(tool.name),
|
|
1213
|
+
}
|
|
1214
|
+
try {
|
|
1215
|
+
const parsedInput = tool.inputSchema.parse(input)
|
|
1216
|
+
toolPermissionResult = await tool.checkPermissions(parsedInput, context)
|
|
1217
|
+
} catch (e) {
|
|
1218
|
+
// Rethrow abort errors so they propagate properly
|
|
1219
|
+
if (e instanceof AbortError || e instanceof APIUserAbortError) {
|
|
1220
|
+
throw e
|
|
1221
|
+
}
|
|
1222
|
+
logError(e)
|
|
1223
|
+
}
|
|
1224
|
+
|
|
1225
|
+
// 1d. Tool implementation denied permission
|
|
1226
|
+
if (toolPermissionResult?.behavior === 'deny') {
|
|
1227
|
+
return toolPermissionResult
|
|
1228
|
+
}
|
|
1229
|
+
|
|
1230
|
+
// 1e. Tool requires user interaction even in bypass mode
|
|
1231
|
+
if (
|
|
1232
|
+
tool.requiresUserInteraction?.() &&
|
|
1233
|
+
toolPermissionResult?.behavior === 'ask'
|
|
1234
|
+
) {
|
|
1235
|
+
return toolPermissionResult
|
|
1236
|
+
}
|
|
1237
|
+
|
|
1238
|
+
// 1f. Content-specific ask rules from tool.checkPermissions take precedence
|
|
1239
|
+
// over bypassPermissions mode. When a user explicitly configures a
|
|
1240
|
+
// content-specific ask rule (e.g. Bash(npm publish:*)), the tool's
|
|
1241
|
+
// checkPermissions returns {behavior:'ask', decisionReason:{type:'rule',
|
|
1242
|
+
// rule:{ruleBehavior:'ask'}}}. This must be respected even in bypass mode,
|
|
1243
|
+
// just as deny rules are respected at step 1d.
|
|
1244
|
+
if (
|
|
1245
|
+
toolPermissionResult?.behavior === 'ask' &&
|
|
1246
|
+
toolPermissionResult.decisionReason?.type === 'rule' &&
|
|
1247
|
+
toolPermissionResult.decisionReason.rule.ruleBehavior === 'ask'
|
|
1248
|
+
) {
|
|
1249
|
+
return toolPermissionResult
|
|
1250
|
+
}
|
|
1251
|
+
|
|
1252
|
+
// 1g. Safety checks (e.g. .git/, .claude/, .vscode/, shell configs) are
|
|
1253
|
+
// bypass-immune — they must prompt even in bypassPermissions mode.
|
|
1254
|
+
// checkPathSafetyForAutoEdit returns {type:'safetyCheck'} for these paths.
|
|
1255
|
+
if (
|
|
1256
|
+
toolPermissionResult?.behavior === 'ask' &&
|
|
1257
|
+
toolPermissionResult.decisionReason?.type === 'safetyCheck'
|
|
1258
|
+
) {
|
|
1259
|
+
return toolPermissionResult
|
|
1260
|
+
}
|
|
1261
|
+
|
|
1262
|
+
// 2a. Check if mode allows the tool to run
|
|
1263
|
+
// IMPORTANT: Call getAppState() to get the latest value
|
|
1264
|
+
appState = context.getAppState()
|
|
1265
|
+
// Check if permissions should be bypassed:
|
|
1266
|
+
// - Direct bypassPermissions mode
|
|
1267
|
+
// - Plan mode when the user originally started with bypass mode (isBypassPermissionsModeAvailable)
|
|
1268
|
+
const shouldBypassPermissions =
|
|
1269
|
+
appState.toolPermissionContext.mode === 'bypassPermissions' ||
|
|
1270
|
+
(appState.toolPermissionContext.mode === 'plan' &&
|
|
1271
|
+
appState.toolPermissionContext.isBypassPermissionsModeAvailable)
|
|
1272
|
+
if (shouldBypassPermissions) {
|
|
1273
|
+
return {
|
|
1274
|
+
behavior: 'allow',
|
|
1275
|
+
updatedInput: getUpdatedInputOrFallback(toolPermissionResult, input),
|
|
1276
|
+
decisionReason: {
|
|
1277
|
+
type: 'mode',
|
|
1278
|
+
mode: appState.toolPermissionContext.mode,
|
|
1279
|
+
},
|
|
1280
|
+
}
|
|
1281
|
+
}
|
|
1282
|
+
|
|
1283
|
+
// 2b. Entire tool is allowed
|
|
1284
|
+
const alwaysAllowedRule = toolAlwaysAllowedRule(
|
|
1285
|
+
appState.toolPermissionContext,
|
|
1286
|
+
tool,
|
|
1287
|
+
)
|
|
1288
|
+
if (alwaysAllowedRule) {
|
|
1289
|
+
return {
|
|
1290
|
+
behavior: 'allow',
|
|
1291
|
+
updatedInput: getUpdatedInputOrFallback(toolPermissionResult, input),
|
|
1292
|
+
decisionReason: {
|
|
1293
|
+
type: 'rule',
|
|
1294
|
+
rule: alwaysAllowedRule,
|
|
1295
|
+
},
|
|
1296
|
+
}
|
|
1297
|
+
}
|
|
1298
|
+
|
|
1299
|
+
// 3. Convert "passthrough" to "ask"
|
|
1300
|
+
const result: PermissionDecision =
|
|
1301
|
+
toolPermissionResult.behavior === 'passthrough'
|
|
1302
|
+
? {
|
|
1303
|
+
...toolPermissionResult,
|
|
1304
|
+
behavior: 'ask' as const,
|
|
1305
|
+
message: createPermissionRequestMessage(
|
|
1306
|
+
tool.name,
|
|
1307
|
+
toolPermissionResult.decisionReason,
|
|
1308
|
+
),
|
|
1309
|
+
}
|
|
1310
|
+
: toolPermissionResult
|
|
1311
|
+
|
|
1312
|
+
if (result.behavior === 'ask' && result.suggestions) {
|
|
1313
|
+
logForDebugging(
|
|
1314
|
+
`Permission suggestions for ${tool.name}: ${jsonStringify(result.suggestions, null, 2)}`,
|
|
1315
|
+
)
|
|
1316
|
+
}
|
|
1317
|
+
|
|
1318
|
+
return result
|
|
1319
|
+
}
|
|
1320
|
+
|
|
1321
|
+
type EditPermissionRuleArgs = {
|
|
1322
|
+
initialContext: ToolPermissionContext
|
|
1323
|
+
setToolPermissionContext: (updatedContext: ToolPermissionContext) => void
|
|
1324
|
+
}
|
|
1325
|
+
|
|
1326
|
+
/**
|
|
1327
|
+
* Delete a permission rule from the appropriate destination
|
|
1328
|
+
*/
|
|
1329
|
+
export async function deletePermissionRule({
|
|
1330
|
+
rule,
|
|
1331
|
+
initialContext,
|
|
1332
|
+
setToolPermissionContext,
|
|
1333
|
+
}: EditPermissionRuleArgs & { rule: PermissionRule }): Promise<void> {
|
|
1334
|
+
if (
|
|
1335
|
+
rule.source === 'policySettings' ||
|
|
1336
|
+
rule.source === 'flagSettings' ||
|
|
1337
|
+
rule.source === 'command'
|
|
1338
|
+
) {
|
|
1339
|
+
throw new Error('Cannot delete permission rules from read-only settings')
|
|
1340
|
+
}
|
|
1341
|
+
|
|
1342
|
+
const updatedContext = applyPermissionUpdate(initialContext, {
|
|
1343
|
+
type: 'removeRules',
|
|
1344
|
+
rules: [rule.ruleValue],
|
|
1345
|
+
behavior: rule.ruleBehavior,
|
|
1346
|
+
destination: rule.source as PermissionUpdateDestination,
|
|
1347
|
+
})
|
|
1348
|
+
|
|
1349
|
+
// Per-destination logic to delete the rule from settings
|
|
1350
|
+
const destination = rule.source
|
|
1351
|
+
switch (destination) {
|
|
1352
|
+
case 'localSettings':
|
|
1353
|
+
case 'userSettings':
|
|
1354
|
+
case 'projectSettings': {
|
|
1355
|
+
// Note: Typescript doesn't know that rule conforms to `PermissionRuleFromEditableSettings` even when we switch on `rule.source`
|
|
1356
|
+
deletePermissionRuleFromSettings(
|
|
1357
|
+
rule as PermissionRuleFromEditableSettings,
|
|
1358
|
+
)
|
|
1359
|
+
break
|
|
1360
|
+
}
|
|
1361
|
+
case 'cliArg':
|
|
1362
|
+
case 'session': {
|
|
1363
|
+
// No action needed for in-memory sources - not persisted to disk
|
|
1364
|
+
break
|
|
1365
|
+
}
|
|
1366
|
+
}
|
|
1367
|
+
|
|
1368
|
+
// Update React state with updated context
|
|
1369
|
+
setToolPermissionContext(updatedContext)
|
|
1370
|
+
}
|
|
1371
|
+
|
|
1372
|
+
/**
|
|
1373
|
+
* Helper to convert PermissionRule array to PermissionUpdate array
|
|
1374
|
+
*/
|
|
1375
|
+
function convertRulesToUpdates(
|
|
1376
|
+
rules: PermissionRule[],
|
|
1377
|
+
updateType: 'addRules' | 'replaceRules',
|
|
1378
|
+
): PermissionUpdate[] {
|
|
1379
|
+
// Group rules by source and behavior
|
|
1380
|
+
const grouped = new Map<string, PermissionRuleValue[]>()
|
|
1381
|
+
|
|
1382
|
+
for (const rule of rules) {
|
|
1383
|
+
const key = `${rule.source}:${rule.ruleBehavior}`
|
|
1384
|
+
if (!grouped.has(key)) {
|
|
1385
|
+
grouped.set(key, [])
|
|
1386
|
+
}
|
|
1387
|
+
grouped.get(key)!.push(rule.ruleValue)
|
|
1388
|
+
}
|
|
1389
|
+
|
|
1390
|
+
// Convert to PermissionUpdate array
|
|
1391
|
+
const updates: PermissionUpdate[] = []
|
|
1392
|
+
for (const [key, ruleValues] of grouped) {
|
|
1393
|
+
const [source, behavior] = key.split(':')
|
|
1394
|
+
updates.push({
|
|
1395
|
+
type: updateType,
|
|
1396
|
+
rules: ruleValues,
|
|
1397
|
+
behavior: behavior as PermissionBehavior,
|
|
1398
|
+
destination: source as PermissionUpdateDestination,
|
|
1399
|
+
})
|
|
1400
|
+
}
|
|
1401
|
+
|
|
1402
|
+
return updates
|
|
1403
|
+
}
|
|
1404
|
+
|
|
1405
|
+
/**
|
|
1406
|
+
* Apply permission rules to context (additive - for initial setup)
|
|
1407
|
+
*/
|
|
1408
|
+
export function applyPermissionRulesToPermissionContext(
|
|
1409
|
+
toolPermissionContext: ToolPermissionContext,
|
|
1410
|
+
rules: PermissionRule[],
|
|
1411
|
+
): ToolPermissionContext {
|
|
1412
|
+
const updates = convertRulesToUpdates(rules, 'addRules')
|
|
1413
|
+
return applyPermissionUpdates(toolPermissionContext, updates)
|
|
1414
|
+
}
|
|
1415
|
+
|
|
1416
|
+
/**
|
|
1417
|
+
* Sync permission rules from disk (replacement - for settings changes)
|
|
1418
|
+
*/
|
|
1419
|
+
export function syncPermissionRulesFromDisk(
|
|
1420
|
+
toolPermissionContext: ToolPermissionContext,
|
|
1421
|
+
rules: PermissionRule[],
|
|
1422
|
+
): ToolPermissionContext {
|
|
1423
|
+
let context = toolPermissionContext
|
|
1424
|
+
|
|
1425
|
+
// When allowManagedPermissionRulesOnly is enabled, clear all non-policy sources
|
|
1426
|
+
if (shouldAllowManagedPermissionRulesOnly()) {
|
|
1427
|
+
const sourcesToClear: PermissionUpdateDestination[] = [
|
|
1428
|
+
'userSettings',
|
|
1429
|
+
'projectSettings',
|
|
1430
|
+
'localSettings',
|
|
1431
|
+
'cliArg',
|
|
1432
|
+
'session',
|
|
1433
|
+
]
|
|
1434
|
+
const behaviors: PermissionBehavior[] = ['allow', 'deny', 'ask']
|
|
1435
|
+
|
|
1436
|
+
for (const source of sourcesToClear) {
|
|
1437
|
+
for (const behavior of behaviors) {
|
|
1438
|
+
context = applyPermissionUpdate(context, {
|
|
1439
|
+
type: 'replaceRules',
|
|
1440
|
+
rules: [],
|
|
1441
|
+
behavior,
|
|
1442
|
+
destination: source,
|
|
1443
|
+
})
|
|
1444
|
+
}
|
|
1445
|
+
}
|
|
1446
|
+
}
|
|
1447
|
+
|
|
1448
|
+
// Clear all disk-based source:behavior combos before applying new rules.
|
|
1449
|
+
// Without this, removing a rule from settings (e.g. deleting a deny entry)
|
|
1450
|
+
// would leave the old rule in the context because convertRulesToUpdates
|
|
1451
|
+
// only generates replaceRules for source:behavior pairs that have rules —
|
|
1452
|
+
// an empty group produces no update, so stale rules persist.
|
|
1453
|
+
const diskSources: PermissionUpdateDestination[] = [
|
|
1454
|
+
'userSettings',
|
|
1455
|
+
'projectSettings',
|
|
1456
|
+
'localSettings',
|
|
1457
|
+
]
|
|
1458
|
+
for (const diskSource of diskSources) {
|
|
1459
|
+
for (const behavior of ['allow', 'deny', 'ask'] as PermissionBehavior[]) {
|
|
1460
|
+
context = applyPermissionUpdate(context, {
|
|
1461
|
+
type: 'replaceRules',
|
|
1462
|
+
rules: [],
|
|
1463
|
+
behavior,
|
|
1464
|
+
destination: diskSource,
|
|
1465
|
+
})
|
|
1466
|
+
}
|
|
1467
|
+
}
|
|
1468
|
+
|
|
1469
|
+
const updates = convertRulesToUpdates(rules, 'replaceRules')
|
|
1470
|
+
return applyPermissionUpdates(context, updates)
|
|
1471
|
+
}
|
|
1472
|
+
|
|
1473
|
+
/**
|
|
1474
|
+
* Extract updatedInput from a permission result, falling back to the original input.
|
|
1475
|
+
* Handles the case where some PermissionResult variants don't have updatedInput.
|
|
1476
|
+
*/
|
|
1477
|
+
function getUpdatedInputOrFallback(
|
|
1478
|
+
permissionResult: PermissionResult,
|
|
1479
|
+
fallback: Record<string, unknown>,
|
|
1480
|
+
): Record<string, unknown> {
|
|
1481
|
+
return (
|
|
1482
|
+
('updatedInput' in permissionResult
|
|
1483
|
+
? permissionResult.updatedInput
|
|
1484
|
+
: undefined) ?? fallback
|
|
1485
|
+
)
|
|
1486
|
+
}
|