@google/gemini-cli-core 0.37.0-preview.1 → 0.38.0-preview.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +58 -50
- package/dist/docs/changelogs/index.md +25 -0
- package/dist/docs/changelogs/latest.md +353 -362
- package/dist/docs/changelogs/preview.md +399 -366
- package/dist/docs/cli/plan-mode.md +1 -0
- package/dist/docs/cli/sandbox.md +52 -0
- package/dist/docs/cli/settings.md +49 -46
- package/dist/docs/core/remote-agents.md +14 -18
- package/dist/docs/core/subagents.md +63 -27
- package/dist/docs/get-started/authentication.md +2 -2
- package/dist/docs/get-started/installation.md +7 -0
- package/dist/docs/hooks/index.md +6 -6
- package/dist/docs/reference/configuration.md +43 -13
- package/dist/docs/reference/keyboard-shortcuts.md +14 -9
- package/dist/docs/reference/tools.md +4 -4
- package/dist/docs/release-confidence.md +0 -6
- package/dist/docs/releases.md +4 -0
- package/dist/docs/tools/mcp-server.md +3 -3
- package/dist/docs/tools/web-fetch.md +3 -0
- package/dist/src/agent/agent-session.test.js +14 -6
- package/dist/src/agent/agent-session.test.js.map +1 -1
- package/dist/src/agent/event-translator.js +2 -1
- package/dist/src/agent/event-translator.js.map +1 -1
- package/dist/src/agent/event-translator.test.js +1 -0
- package/dist/src/agent/event-translator.test.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.d.ts +47 -4
- package/dist/src/agent/legacy-agent-session.js +38 -15
- package/dist/src/agent/legacy-agent-session.js.map +1 -1
- package/dist/src/agent/legacy-agent-session.test.js +60 -73
- package/dist/src/agent/legacy-agent-session.test.js.map +1 -1
- package/dist/src/agent/mock.js +7 -1
- package/dist/src/agent/mock.js.map +1 -1
- package/dist/src/agent/mock.test.js +1 -1
- package/dist/src/agent/mock.test.js.map +1 -1
- package/dist/src/agent/types.d.ts +34 -1
- package/dist/src/agents/agent-scheduler.js +6 -1
- package/dist/src/agents/agent-scheduler.js.map +1 -1
- package/dist/src/agents/agent-scheduler.test.js +38 -0
- package/dist/src/agents/agent-scheduler.test.js.map +1 -1
- package/dist/src/agents/auth-provider/api-key-provider.test.js +18 -2
- package/dist/src/agents/auth-provider/api-key-provider.test.js.map +1 -1
- package/dist/src/agents/auth-provider/value-resolver.test.js +30 -0
- package/dist/src/agents/auth-provider/value-resolver.test.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.js +36 -6
- package/dist/src/agents/browser/analyzeScreenshot.js.map +1 -1
- package/dist/src/agents/browser/analyzeScreenshot.test.js +35 -3
- package/dist/src/agents/browser/analyzeScreenshot.test.js.map +1 -1
- package/dist/src/agents/browser/browserAgentFactory.d.ts +8 -0
- package/dist/src/agents/browser/browserAgentFactory.js +174 -118
- package/dist/src/agents/browser/browserAgentFactory.js.map +1 -1
- package/dist/src/agents/browser/browserAgentFactory.test.js +70 -1
- package/dist/src/agents/browser/browserAgentFactory.test.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.js +29 -2
- package/dist/src/agents/browser/browserAgentInvocation.js.map +1 -1
- package/dist/src/agents/browser/browserAgentInvocation.test.js +51 -5
- package/dist/src/agents/browser/browserAgentInvocation.test.js.map +1 -1
- package/dist/src/agents/browser/browserManager.d.ts +38 -0
- package/dist/src/agents/browser/browserManager.js +117 -6
- package/dist/src/agents/browser/browserManager.js.map +1 -1
- package/dist/src/agents/browser/browserManager.test.js +156 -2
- package/dist/src/agents/browser/browserManager.test.js.map +1 -1
- package/dist/src/agents/browser/modelAvailability.d.ts +5 -0
- package/dist/src/agents/browser/modelAvailability.js +12 -0
- package/dist/src/agents/browser/modelAvailability.js.map +1 -1
- package/dist/src/agents/local-executor.d.ts +5 -0
- package/dist/src/agents/local-executor.js +98 -181
- package/dist/src/agents/local-executor.js.map +1 -1
- package/dist/src/agents/local-executor.test.js +386 -101
- package/dist/src/agents/local-executor.test.js.map +1 -1
- package/dist/src/agents/memory-manager-agent.js +1 -0
- package/dist/src/agents/memory-manager-agent.js.map +1 -1
- package/dist/src/agents/memory-manager-agent.test.js +6 -0
- package/dist/src/agents/memory-manager-agent.test.js.map +1 -1
- package/dist/src/agents/registry.js +3 -10
- package/dist/src/agents/registry.js.map +1 -1
- package/dist/src/agents/skill-extraction-agent.d.ts +24 -0
- package/dist/src/agents/skill-extraction-agent.js +269 -0
- package/dist/src/agents/skill-extraction-agent.js.map +1 -0
- package/dist/src/agents/types.d.ts +11 -0
- package/dist/src/code_assist/admin/admin_controls.js +1 -1
- package/dist/src/code_assist/admin/admin_controls.js.map +1 -1
- package/dist/src/code_assist/experiments/flagNames.d.ts +1 -0
- package/dist/src/code_assist/experiments/flagNames.js +1 -0
- package/dist/src/code_assist/experiments/flagNames.js.map +1 -1
- package/dist/src/code_assist/server.js +1 -1
- package/dist/src/code_assist/server.js.map +1 -1
- package/dist/src/commands/memory.js +1 -1
- package/dist/src/commands/memory.js.map +1 -1
- package/dist/src/config/config.d.ts +34 -31
- package/dist/src/config/config.js +101 -38
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +102 -15
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/extensions/integrity.js +1 -1
- package/dist/src/config/extensions/integrity.js.map +1 -1
- package/dist/src/config/projectRegistry.js +5 -3
- package/dist/src/config/projectRegistry.js.map +1 -1
- package/dist/src/config/scoped-config.d.ts +30 -0
- package/dist/src/config/scoped-config.js +69 -0
- package/dist/src/config/scoped-config.js.map +1 -0
- package/dist/src/config/scoped-config.test.d.ts +6 -0
- package/dist/src/config/scoped-config.test.js +161 -0
- package/dist/src/config/scoped-config.test.js.map +1 -0
- package/dist/src/config/storage.d.ts +2 -0
- package/dist/src/config/storage.js +7 -2
- package/dist/src/config/storage.js.map +1 -1
- package/dist/src/config/storage.test.js +7 -7
- package/dist/src/config/storage.test.js.map +1 -1
- package/dist/src/confirmation-bus/types.d.ts +2 -2
- package/dist/src/context/agentHistoryProvider.d.ts +1 -1
- package/dist/src/context/agentHistoryProvider.js +1 -5
- package/dist/src/context/agentHistoryProvider.js.map +1 -1
- package/dist/src/context/agentHistoryProvider.test.js +2 -39
- package/dist/src/context/agentHistoryProvider.test.js.map +1 -1
- package/dist/src/context/contextCompressionService.d.ts +30 -0
- package/dist/src/context/contextCompressionService.js +405 -0
- package/dist/src/context/contextCompressionService.js.map +1 -0
- package/dist/src/context/contextCompressionService.test.d.ts +1 -0
- package/dist/src/context/contextCompressionService.test.js +253 -0
- package/dist/src/context/contextCompressionService.test.js.map +1 -0
- package/dist/src/context/{contextManager.d.ts → memoryContextManager.d.ts} +1 -1
- package/dist/src/context/{contextManager.js → memoryContextManager.js} +2 -2
- package/dist/src/context/memoryContextManager.js.map +1 -0
- package/dist/src/context/{contextManager.test.js → memoryContextManager.test.js} +22 -28
- package/dist/src/context/memoryContextManager.test.js.map +1 -0
- package/dist/src/context/profiles.d.ts +7 -0
- package/dist/src/context/profiles.js +21 -0
- package/dist/src/context/profiles.js.map +1 -0
- package/dist/src/context/toolDistillationService.test.js +3 -0
- package/dist/src/context/toolDistillationService.test.js.map +1 -1
- package/dist/src/context/types.d.ts +36 -0
- package/dist/src/context/types.js.map +1 -0
- package/dist/src/core/baseLlmClient.js +1 -1
- package/dist/src/core/baseLlmClient.js.map +1 -1
- package/dist/src/core/baseLlmClient.test.js +1 -0
- package/dist/src/core/baseLlmClient.test.js.map +1 -1
- package/dist/src/core/client.js +1 -1
- package/dist/src/core/client.js.map +1 -1
- package/dist/src/core/client.test.js +7 -6
- package/dist/src/core/client.test.js.map +1 -1
- package/dist/src/core/geminiChat.js +8 -0
- package/dist/src/core/geminiChat.js.map +1 -1
- package/dist/src/core/geminiChat.test.js +1 -0
- package/dist/src/core/geminiChat.test.js.map +1 -1
- package/dist/src/core/geminiChat_network_retry.test.js +1 -0
- package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
- package/dist/src/core/logger.js +4 -4
- package/dist/src/core/logger.js.map +1 -1
- package/dist/src/core/logger.test.js +1 -1
- package/dist/src/core/logger.test.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.js +1 -1
- package/dist/src/core/loggingContentGenerator.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +2 -2
- package/dist/src/generated/git-commit.js +2 -2
- package/dist/src/hooks/hookEventHandler.js +8 -0
- package/dist/src/hooks/hookEventHandler.js.map +1 -1
- package/dist/src/hooks/hookRunner.js +9 -5
- package/dist/src/hooks/hookRunner.js.map +1 -1
- package/dist/src/hooks/hookRunner.test.js +20 -3
- package/dist/src/hooks/hookRunner.test.js.map +1 -1
- package/dist/src/hooks/hookSystem.d.ts +2 -0
- package/dist/src/hooks/hookSystem.js +1 -0
- package/dist/src/hooks/hookSystem.js.map +1 -1
- package/dist/src/hooks/hookTranslator.js +20 -13
- package/dist/src/hooks/hookTranslator.js.map +1 -1
- package/dist/src/hooks/hookTranslator.test.js +36 -0
- package/dist/src/hooks/hookTranslator.test.js.map +1 -1
- package/dist/src/hooks/types.d.ts +2 -0
- package/dist/src/ide/ide-client.js +3 -3
- package/dist/src/ide/ide-client.js.map +1 -1
- package/dist/src/ide/ide-connection-utils.js +1 -1
- package/dist/src/ide/ide-connection-utils.js.map +1 -1
- package/dist/src/ide/ide-installer.js +3 -3
- package/dist/src/ide/ide-installer.js.map +1 -1
- package/dist/src/ide/process-utils.js +3 -3
- package/dist/src/ide/process-utils.js.map +1 -1
- package/dist/src/index.d.ts +4 -1
- package/dist/src/index.js +5 -1
- package/dist/src/index.js.map +1 -1
- package/dist/src/output/json-formatter.js +2 -1
- package/dist/src/output/json-formatter.js.map +1 -1
- package/dist/src/policy/config.test.js +21 -20
- package/dist/src/policy/config.test.js.map +1 -1
- package/dist/src/policy/policies/memory-manager.toml +11 -1
- package/dist/src/policy/policies/plan.toml +4 -3
- package/dist/src/policy/policies/read-only.toml +6 -0
- package/dist/src/policy/policies/sandbox-default.toml +2 -3
- package/dist/src/policy/policy-engine.js +23 -0
- package/dist/src/policy/policy-engine.js.map +1 -1
- package/dist/src/policy/policy-engine.test.js +129 -1
- package/dist/src/policy/policy-engine.test.js.map +1 -1
- package/dist/src/policy/sandboxPolicyManager.d.ts +26 -1
- package/dist/src/policy/sandboxPolicyManager.js +41 -12
- package/dist/src/policy/sandboxPolicyManager.js.map +1 -1
- package/dist/src/policy/sandboxPolicyManager.test.d.ts +6 -0
- package/dist/src/policy/sandboxPolicyManager.test.js +61 -0
- package/dist/src/policy/sandboxPolicyManager.test.js.map +1 -0
- package/dist/src/policy/workspace-policy.test.js +18 -15
- package/dist/src/policy/workspace-policy.test.js.map +1 -1
- package/dist/src/prompts/snippets.js +6 -3
- package/dist/src/prompts/snippets.js.map +1 -1
- package/dist/src/prompts/snippets.legacy.js +6 -2
- package/dist/src/prompts/snippets.legacy.js.map +1 -1
- package/dist/src/prompts/utils.test.js +7 -5
- package/dist/src/prompts/utils.test.js.map +1 -1
- package/dist/src/safety/built-in.js +1 -1
- package/dist/src/safety/built-in.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.d.ts +4 -4
- package/dist/src/sandbox/linux/LinuxSandboxManager.js +47 -191
- package/dist/src/sandbox/linux/LinuxSandboxManager.js.map +1 -1
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js +33 -395
- package/dist/src/sandbox/linux/LinuxSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/linux/bwrapArgsBuilder.d.ts +24 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js +200 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.js.map +1 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.d.ts +6 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js +247 -0
- package/dist/src/sandbox/linux/bwrapArgsBuilder.test.js.map +1 -0
- package/dist/src/sandbox/macos/MacOsSandboxManager.d.ts +3 -0
- package/dist/src/sandbox/macos/MacOsSandboxManager.js +12 -5
- package/dist/src/sandbox/macos/MacOsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js +20 -0
- package/dist/src/sandbox/macos/MacOsSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/macos/baseProfile.d.ts +1 -1
- package/dist/src/sandbox/macos/baseProfile.js +28 -4
- package/dist/src/sandbox/macos/baseProfile.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.js.map +1 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js +2 -1
- package/dist/src/sandbox/macos/seatbeltArgsBuilder.test.js.map +1 -1
- package/dist/src/sandbox/utils/fsUtils.js +8 -6
- package/dist/src/sandbox/utils/fsUtils.js.map +1 -1
- package/dist/src/sandbox/utils/fsUtils.test.d.ts +6 -0
- package/dist/src/sandbox/utils/fsUtils.test.js +43 -0
- package/dist/src/sandbox/utils/fsUtils.test.js.map +1 -0
- package/dist/src/sandbox/utils/proactivePermissions.d.ts +19 -0
- package/dist/src/sandbox/utils/proactivePermissions.js +163 -0
- package/dist/src/sandbox/utils/proactivePermissions.js.map +1 -0
- package/dist/src/sandbox/utils/proactivePermissions.test.d.ts +6 -0
- package/dist/src/sandbox/utils/proactivePermissions.test.js +145 -0
- package/dist/src/sandbox/utils/proactivePermissions.test.js.map +1 -0
- package/dist/src/sandbox/utils/sandboxDenialUtils.d.ts +16 -1
- package/dist/src/sandbox/utils/sandboxDenialUtils.js +98 -24
- package/dist/src/sandbox/utils/sandboxDenialUtils.js.map +1 -1
- package/dist/src/sandbox/utils/sandboxDenialUtils.test.js +152 -1
- package/dist/src/sandbox/utils/sandboxDenialUtils.test.js.map +1 -1
- package/dist/src/sandbox/utils/sandboxReadWriteUtils.js +4 -0
- package/dist/src/sandbox/utils/sandboxReadWriteUtils.js.map +1 -1
- package/dist/src/sandbox/windows/GeminiSandbox.cs +90 -42
- package/dist/src/sandbox/windows/WindowsSandboxManager.d.ts +4 -0
- package/dist/src/sandbox/windows/WindowsSandboxManager.js +65 -60
- package/dist/src/sandbox/windows/WindowsSandboxManager.js.map +1 -1
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js +99 -54
- package/dist/src/sandbox/windows/WindowsSandboxManager.test.js.map +1 -1
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.d.ts +2 -1
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.js +19 -18
- package/dist/src/sandbox/windows/windowsSandboxDenialUtils.js.map +1 -1
- package/dist/src/scheduler/scheduler.js +1 -1
- package/dist/src/scheduler/scheduler.js.map +1 -1
- package/dist/src/scheduler/scheduler_hooks.test.js +1 -1
- package/dist/src/scheduler/scheduler_hooks.test.js.map +1 -1
- package/dist/src/scheduler/tool-executor.js +1 -1
- package/dist/src/scheduler/tool-executor.js.map +1 -1
- package/dist/src/scheduler/tool-executor.test.js +1 -1
- package/dist/src/scheduler/tool-executor.test.js.map +1 -1
- package/dist/src/services/executionLifecycleService.d.ts +1 -0
- package/dist/src/services/executionLifecycleService.js +3 -0
- package/dist/src/services/executionLifecycleService.js.map +1 -1
- package/dist/src/services/gitService.js +1 -1
- package/dist/src/services/gitService.js.map +1 -1
- package/dist/src/services/memoryService.d.ts +65 -0
- package/dist/src/services/memoryService.js +511 -0
- package/dist/src/services/memoryService.js.map +1 -0
- package/dist/src/services/memoryService.test.d.ts +6 -0
- package/dist/src/services/memoryService.test.js +563 -0
- package/dist/src/services/memoryService.test.js.map +1 -0
- package/dist/src/services/sandboxManager.d.ts +17 -0
- package/dist/src/services/sandboxManager.integration.test.js +18 -11
- package/dist/src/services/sandboxManager.integration.test.js.map +1 -1
- package/dist/src/services/sandboxManager.js +20 -0
- package/dist/src/services/sandboxManager.js.map +1 -1
- package/dist/src/services/sandboxManager.test.js +84 -56
- package/dist/src/services/sandboxManager.test.js.map +1 -1
- package/dist/src/services/sandboxManagerFactory.js +2 -5
- package/dist/src/services/sandboxManagerFactory.js.map +1 -1
- package/dist/src/services/sandboxedFileSystemService.js +14 -3
- package/dist/src/services/sandboxedFileSystemService.js.map +1 -1
- package/dist/src/services/sandboxedFileSystemService.test.js +29 -14
- package/dist/src/services/sandboxedFileSystemService.test.js.map +1 -1
- package/dist/src/services/shellExecutionService.d.ts +16 -1
- package/dist/src/services/shellExecutionService.js +70 -10
- package/dist/src/services/shellExecutionService.js.map +1 -1
- package/dist/src/services/shellExecutionService.test.js +65 -4
- package/dist/src/services/shellExecutionService.test.js.map +1 -1
- package/dist/src/services/worktreeService.test.js +7 -7
- package/dist/src/services/worktreeService.test.js.map +1 -1
- package/dist/src/skills/skillLoader.d.ts +8 -0
- package/dist/src/skills/skillLoader.js +1 -1
- package/dist/src/skills/skillLoader.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +29 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +101 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +167 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +9 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +20 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
- package/dist/src/telemetry/loggers.d.ts +22 -0
- package/dist/src/telemetry/loggers.js +40 -1
- package/dist/src/telemetry/loggers.js.map +1 -1
- package/dist/src/telemetry/metrics.d.ts +108 -0
- package/dist/src/telemetry/metrics.js +177 -0
- package/dist/src/telemetry/metrics.js.map +1 -1
- package/dist/src/telemetry/metrics.test.js +254 -0
- package/dist/src/telemetry/metrics.test.js.map +1 -1
- package/dist/src/tools/complete-task.d.ts +29 -0
- package/dist/src/tools/complete-task.js +123 -0
- package/dist/src/tools/complete-task.js.map +1 -0
- package/dist/src/tools/complete-task.test.d.ts +6 -0
- package/dist/src/tools/complete-task.test.js +114 -0
- package/dist/src/tools/complete-task.test.js.map +1 -0
- package/dist/src/tools/definitions/base-declarations.d.ts +2 -0
- package/dist/src/tools/definitions/base-declarations.js +3 -0
- package/dist/src/tools/definitions/base-declarations.js.map +1 -1
- package/dist/src/tools/definitions/coreTools.d.ts +1 -1
- package/dist/src/tools/definitions/coreTools.js +1 -1
- package/dist/src/tools/definitions/coreTools.js.map +1 -1
- package/dist/src/tools/definitions/dynamic-declaration-helpers.js +4 -0
- package/dist/src/tools/definitions/dynamic-declaration-helpers.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js +3 -3
- package/dist/src/tools/definitions/model-family-sets/default-legacy.js.map +1 -1
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js +3 -3
- package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
- package/dist/src/tools/grep.test.js +2 -2
- package/dist/src/tools/grep.test.js.map +1 -1
- package/dist/src/tools/jit-context.js +3 -3
- package/dist/src/tools/jit-context.js.map +1 -1
- package/dist/src/tools/jit-context.test.js +15 -13
- package/dist/src/tools/jit-context.test.js.map +1 -1
- package/dist/src/tools/mcp-client.js +1 -1
- package/dist/src/tools/mcp-client.js.map +1 -1
- package/dist/src/tools/mcp-tool.test.js +1 -1
- package/dist/src/tools/mcp-tool.test.js.map +1 -1
- package/dist/src/tools/ripGrep.test.js +1 -1
- package/dist/src/tools/ripGrep.test.js.map +1 -1
- package/dist/src/tools/shell.d.ts +7 -4
- package/dist/src/tools/shell.js +255 -37
- package/dist/src/tools/shell.js.map +1 -1
- package/dist/src/tools/shell.test.js +182 -8
- package/dist/src/tools/shell.test.js.map +1 -1
- package/dist/src/tools/shellBackgroundTools.d.ts +38 -0
- package/dist/src/tools/shellBackgroundTools.integration.test.d.ts +6 -0
- package/dist/src/tools/shellBackgroundTools.integration.test.js +86 -0
- package/dist/src/tools/shellBackgroundTools.integration.test.js.map +1 -0
- package/dist/src/tools/shellBackgroundTools.js +186 -0
- package/dist/src/tools/shellBackgroundTools.js.map +1 -0
- package/dist/src/tools/shellBackgroundTools.test.d.ts +6 -0
- package/dist/src/tools/shellBackgroundTools.test.js +230 -0
- package/dist/src/tools/shellBackgroundTools.test.js.map +1 -0
- package/dist/src/tools/shell_proactive.test.d.ts +6 -0
- package/dist/src/tools/shell_proactive.test.js +122 -0
- package/dist/src/tools/shell_proactive.test.js.map +1 -0
- package/dist/src/tools/tool-names.d.ts +3 -3
- package/dist/src/tools/tool-names.js +3 -2
- package/dist/src/tools/tool-names.js.map +1 -1
- package/dist/src/tools/tools.js +1 -1
- package/dist/src/tools/tools.js.map +1 -1
- package/dist/src/tools/web-fetch.js +8 -8
- package/dist/src/tools/web-fetch.js.map +1 -1
- package/dist/src/tools/web-fetch.test.js +5 -5
- package/dist/src/tools/web-fetch.test.js.map +1 -1
- package/dist/src/tools/xcode-mcp-fix-transport.js +1 -1
- package/dist/src/tools/xcode-mcp-fix-transport.js.map +1 -1
- package/dist/src/utils/bfsFileSearch.js +3 -6
- package/dist/src/utils/bfsFileSearch.js.map +1 -1
- package/dist/src/utils/checkpointUtils.js +11 -8
- package/dist/src/utils/checkpointUtils.js.map +1 -1
- package/dist/src/utils/compatibility.js +0 -7
- package/dist/src/utils/compatibility.js.map +1 -1
- package/dist/src/utils/compatibility.test.js +0 -9
- package/dist/src/utils/compatibility.test.js.map +1 -1
- package/dist/src/utils/editor.js +3 -0
- package/dist/src/utils/editor.js.map +1 -1
- package/dist/src/utils/errorParsing.js +2 -2
- package/dist/src/utils/errorParsing.js.map +1 -1
- package/dist/src/utils/events.d.ts +12 -0
- package/dist/src/utils/events.js +7 -0
- package/dist/src/utils/events.js.map +1 -1
- package/dist/src/utils/fetch.d.ts +1 -0
- package/dist/src/utils/fetch.js +22 -6
- package/dist/src/utils/fetch.js.map +1 -1
- package/dist/src/utils/fetch.test.js +26 -1
- package/dist/src/utils/fetch.test.js.map +1 -1
- package/dist/src/utils/fileUtils.js +1 -1
- package/dist/src/utils/fileUtils.js.map +1 -1
- package/dist/src/utils/filesearch/crawler.js +1 -1
- package/dist/src/utils/filesearch/crawler.js.map +1 -1
- package/dist/src/utils/filesearch/fileSearch.test.js +7 -2
- package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -1
- package/dist/src/utils/getPty.js +2 -2
- package/dist/src/utils/getPty.js.map +1 -1
- package/dist/src/utils/gitIgnoreParser.js +2 -2
- package/dist/src/utils/gitIgnoreParser.js.map +1 -1
- package/dist/src/utils/gitUtils.js +2 -2
- package/dist/src/utils/gitUtils.js.map +1 -1
- package/dist/src/utils/googleErrors.js +5 -5
- package/dist/src/utils/googleErrors.js.map +1 -1
- package/dist/src/utils/ignoreFileParser.js +1 -1
- package/dist/src/utils/ignoreFileParser.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.js +3 -7
- package/dist/src/utils/memoryDiscovery.js.map +1 -1
- package/dist/src/utils/paths.d.ts +8 -0
- package/dist/src/utils/paths.js +37 -6
- package/dist/src/utils/paths.js.map +1 -1
- package/dist/src/utils/paths.test.js +61 -3
- package/dist/src/utils/paths.test.js.map +1 -1
- package/dist/src/utils/process-utils.js +2 -2
- package/dist/src/utils/process-utils.js.map +1 -1
- package/dist/src/utils/retry.js +7 -0
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/utils/retry.test.js +41 -0
- package/dist/src/utils/retry.test.js.map +1 -1
- package/dist/src/utils/secure-browser-launcher.js +1 -1
- package/dist/src/utils/secure-browser-launcher.js.map +1 -1
- package/dist/src/utils/shell-utils.d.ts +9 -0
- package/dist/src/utils/shell-utils.integration.test.js +1 -1
- package/dist/src/utils/shell-utils.integration.test.js.map +1 -1
- package/dist/src/utils/shell-utils.js +43 -4
- package/dist/src/utils/shell-utils.js.map +1 -1
- package/dist/src/utils/shell-utils.test.js +13 -1
- package/dist/src/utils/shell-utils.test.js.map +1 -1
- package/dist/src/utils/systemEncoding.js +1 -1
- package/dist/src/utils/systemEncoding.js.map +1 -1
- package/dist/src/utils/terminalSerializer.d.ts +1 -0
- package/dist/src/utils/terminalSerializer.js +31 -8
- package/dist/src/utils/terminalSerializer.js.map +1 -1
- package/dist/src/utils/terminalSerializer.test.js +3 -2
- package/dist/src/utils/terminalSerializer.test.js.map +1 -1
- package/dist/src/utils/workspaceContext.js +2 -2
- package/dist/src/utils/workspaceContext.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/dist/google-gemini-cli-core-0.37.0-preview.0.tgz +0 -0
- package/dist/src/context/contextManager.js.map +0 -1
- package/dist/src/context/contextManager.test.js.map +0 -1
- package/dist/src/services/types.d.ts +0 -14
- package/dist/src/services/types.js.map +0 -1
- /package/dist/src/context/{contextManager.test.d.ts → memoryContextManager.test.d.ts} +0 -0
- /package/dist/src/{services → context}/types.js +0 -0
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2026 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { describe, it, expect, vi, beforeEach } from 'vitest';
|
|
7
|
+
import { getProactiveToolSuggestions, isNetworkReliantCommand, } from './proactivePermissions.js';
|
|
8
|
+
import os from 'node:os';
|
|
9
|
+
import path from 'node:path';
|
|
10
|
+
import fs from 'node:fs';
|
|
11
|
+
vi.mock('node:os');
|
|
12
|
+
vi.mock('node:fs', () => ({
|
|
13
|
+
default: {
|
|
14
|
+
promises: {
|
|
15
|
+
access: vi.fn(),
|
|
16
|
+
},
|
|
17
|
+
constants: {
|
|
18
|
+
F_OK: 0,
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
promises: {
|
|
22
|
+
access: vi.fn(),
|
|
23
|
+
},
|
|
24
|
+
constants: {
|
|
25
|
+
F_OK: 0,
|
|
26
|
+
},
|
|
27
|
+
}));
|
|
28
|
+
describe('proactivePermissions', () => {
|
|
29
|
+
const homeDir = '/Users/testuser';
|
|
30
|
+
beforeEach(() => {
|
|
31
|
+
vi.clearAllMocks();
|
|
32
|
+
vi.mocked(os.homedir).mockReturnValue(homeDir);
|
|
33
|
+
vi.mocked(os.platform).mockReturnValue('darwin');
|
|
34
|
+
});
|
|
35
|
+
describe('isNetworkReliantCommand', () => {
|
|
36
|
+
it('should return true for always-network tools', () => {
|
|
37
|
+
expect(isNetworkReliantCommand('ssh')).toBe(true);
|
|
38
|
+
expect(isNetworkReliantCommand('git')).toBe(true);
|
|
39
|
+
expect(isNetworkReliantCommand('curl')).toBe(true);
|
|
40
|
+
});
|
|
41
|
+
it('should return true for network-heavy node subcommands', () => {
|
|
42
|
+
expect(isNetworkReliantCommand('npm', 'install')).toBe(true);
|
|
43
|
+
expect(isNetworkReliantCommand('yarn', 'add')).toBe(true);
|
|
44
|
+
expect(isNetworkReliantCommand('bun', '')).toBe(true);
|
|
45
|
+
});
|
|
46
|
+
it('should return false for local node subcommands', () => {
|
|
47
|
+
expect(isNetworkReliantCommand('npm', 'test')).toBe(false);
|
|
48
|
+
expect(isNetworkReliantCommand('yarn', 'run')).toBe(false);
|
|
49
|
+
});
|
|
50
|
+
it('should return false for unknown tools', () => {
|
|
51
|
+
expect(isNetworkReliantCommand('ls')).toBe(false);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
describe('getProactiveToolSuggestions', () => {
|
|
55
|
+
it('should return undefined for unknown tools', async () => {
|
|
56
|
+
expect(await getProactiveToolSuggestions('ls')).toBeUndefined();
|
|
57
|
+
expect(await getProactiveToolSuggestions('node')).toBeUndefined();
|
|
58
|
+
});
|
|
59
|
+
it('should return permissions for npm if paths exist', async () => {
|
|
60
|
+
vi.mocked(fs.promises.access).mockImplementation((p, _mode) => {
|
|
61
|
+
const pathStr = p.toString();
|
|
62
|
+
if (pathStr === path.join(homeDir, '.npm') ||
|
|
63
|
+
pathStr === path.join(homeDir, '.cache') ||
|
|
64
|
+
pathStr === path.join(homeDir, '.npmrc')) {
|
|
65
|
+
return Promise.resolve();
|
|
66
|
+
}
|
|
67
|
+
return Promise.reject(new Error('ENOENT'));
|
|
68
|
+
});
|
|
69
|
+
const permissions = await getProactiveToolSuggestions('npm');
|
|
70
|
+
expect(permissions).toBeDefined();
|
|
71
|
+
expect(permissions?.network).toBe(true);
|
|
72
|
+
// .npmrc should be read-only
|
|
73
|
+
expect(permissions?.fileSystem?.read).toContain(path.join(homeDir, '.npmrc'));
|
|
74
|
+
expect(permissions?.fileSystem?.write).not.toContain(path.join(homeDir, '.npmrc'));
|
|
75
|
+
// .npm should be read-write
|
|
76
|
+
expect(permissions?.fileSystem?.read).toContain(path.join(homeDir, '.npm'));
|
|
77
|
+
expect(permissions?.fileSystem?.write).toContain(path.join(homeDir, '.npm'));
|
|
78
|
+
// .cache should be read-write
|
|
79
|
+
expect(permissions?.fileSystem?.write).toContain(path.join(homeDir, '.cache'));
|
|
80
|
+
// should NOT contain .ssh or .gitconfig for npm
|
|
81
|
+
expect(permissions?.fileSystem?.read).not.toContain(path.join(homeDir, '.ssh'));
|
|
82
|
+
});
|
|
83
|
+
it('should grant network access and suggest primary cache paths even if they do not exist', async () => {
|
|
84
|
+
vi.mocked(fs.promises.access).mockRejectedValue(new Error('ENOENT'));
|
|
85
|
+
const permissions = await getProactiveToolSuggestions('npm');
|
|
86
|
+
expect(permissions).toBeDefined();
|
|
87
|
+
expect(permissions?.network).toBe(true);
|
|
88
|
+
expect(permissions?.fileSystem?.write).toContain(path.join(homeDir, '.npm'));
|
|
89
|
+
// .cache is optional and should NOT be included if it doesn't exist
|
|
90
|
+
expect(permissions?.fileSystem?.write).not.toContain(path.join(homeDir, '.cache'));
|
|
91
|
+
});
|
|
92
|
+
it('should suggest .ssh and .gitconfig only for git', async () => {
|
|
93
|
+
vi.mocked(fs.promises.access).mockImplementation((p, _mode) => {
|
|
94
|
+
const pathStr = p.toString();
|
|
95
|
+
if (pathStr === path.join(homeDir, '.ssh') ||
|
|
96
|
+
pathStr === path.join(homeDir, '.gitconfig')) {
|
|
97
|
+
return Promise.resolve();
|
|
98
|
+
}
|
|
99
|
+
return Promise.reject(new Error('ENOENT'));
|
|
100
|
+
});
|
|
101
|
+
const permissions = await getProactiveToolSuggestions('git');
|
|
102
|
+
expect(permissions?.network).toBe(true);
|
|
103
|
+
expect(permissions?.fileSystem?.read).toContain(path.join(homeDir, '.ssh'));
|
|
104
|
+
expect(permissions?.fileSystem?.read).toContain(path.join(homeDir, '.gitconfig'));
|
|
105
|
+
});
|
|
106
|
+
it('should suggest .ssh but NOT .gitconfig for ssh', async () => {
|
|
107
|
+
vi.mocked(fs.promises.access).mockImplementation((p, _mode) => {
|
|
108
|
+
const pathStr = p.toString();
|
|
109
|
+
if (pathStr === path.join(homeDir, '.ssh')) {
|
|
110
|
+
return Promise.resolve();
|
|
111
|
+
}
|
|
112
|
+
return Promise.reject(new Error('ENOENT'));
|
|
113
|
+
});
|
|
114
|
+
const permissions = await getProactiveToolSuggestions('ssh');
|
|
115
|
+
expect(permissions?.network).toBe(true);
|
|
116
|
+
expect(permissions?.fileSystem?.read).toContain(path.join(homeDir, '.ssh'));
|
|
117
|
+
expect(permissions?.fileSystem?.read).not.toContain(path.join(homeDir, '.gitconfig'));
|
|
118
|
+
});
|
|
119
|
+
it('should handle Windows specific paths', async () => {
|
|
120
|
+
vi.mocked(os.platform).mockReturnValue('win32');
|
|
121
|
+
const appData = 'C:\\Users\\testuser\\AppData\\Roaming';
|
|
122
|
+
vi.stubEnv('AppData', appData);
|
|
123
|
+
vi.mocked(fs.promises.access).mockImplementation((p, _mode) => {
|
|
124
|
+
const pathStr = p.toString();
|
|
125
|
+
if (pathStr === path.join(appData, 'npm')) {
|
|
126
|
+
return Promise.resolve();
|
|
127
|
+
}
|
|
128
|
+
return Promise.reject(new Error('ENOENT'));
|
|
129
|
+
});
|
|
130
|
+
const permissions = await getProactiveToolSuggestions('npm.exe');
|
|
131
|
+
expect(permissions).toBeDefined();
|
|
132
|
+
expect(permissions?.fileSystem?.read).toContain(path.join(appData, 'npm'));
|
|
133
|
+
vi.unstubAllEnvs();
|
|
134
|
+
});
|
|
135
|
+
it('should include bun, pnpm, and yarn specific paths', async () => {
|
|
136
|
+
vi.mocked(fs.promises.access).mockResolvedValue(undefined);
|
|
137
|
+
const bun = await getProactiveToolSuggestions('bun');
|
|
138
|
+
expect(bun?.fileSystem?.read).toContain(path.join(homeDir, '.bun'));
|
|
139
|
+
expect(bun?.fileSystem?.read).not.toContain(path.join(homeDir, '.yarn'));
|
|
140
|
+
const yarn = await getProactiveToolSuggestions('yarn');
|
|
141
|
+
expect(yarn?.fileSystem?.read).toContain(path.join(homeDir, '.yarn'));
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
//# sourceMappingURL=proactivePermissions.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proactivePermissions.test.js","sourceRoot":"","sources":["../../../../src/sandbox/utils/proactivePermissions.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,10 +3,25 @@
|
|
|
3
3
|
* Copyright 2026 Google LLC
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
|
+
import { LRUCache } from 'mnemonist';
|
|
6
7
|
import { type ParsedSandboxDenial } from '../../services/sandboxManager.js';
|
|
7
8
|
import type { ShellExecutionResult } from '../../services/shellExecutionService.js';
|
|
9
|
+
/**
|
|
10
|
+
* Type for the sandbox denial error cache.
|
|
11
|
+
* Stores normalized error output to prevent redundant processing.
|
|
12
|
+
*/
|
|
13
|
+
export type SandboxDenialCache = LRUCache<string, boolean>;
|
|
14
|
+
/**
|
|
15
|
+
* Creates a new sandbox denial cache with a standard LRU policy.
|
|
16
|
+
*/
|
|
17
|
+
export declare function createSandboxDenialCache(maxSize?: number): SandboxDenialCache;
|
|
18
|
+
/**
|
|
19
|
+
* Sanitizes extracted paths to prevent path traversal vulnerabilities.
|
|
20
|
+
* Filters out paths containing '..' or null bytes.
|
|
21
|
+
*/
|
|
22
|
+
export declare function sanitizeExtractedPath(p: string): string | undefined;
|
|
8
23
|
/**
|
|
9
24
|
* Common POSIX-style sandbox denial detection.
|
|
10
25
|
* Used by macOS and Linux sandbox managers.
|
|
11
26
|
*/
|
|
12
|
-
export declare function parsePosixSandboxDenials(result: ShellExecutionResult): ParsedSandboxDenial | undefined;
|
|
27
|
+
export declare function parsePosixSandboxDenials(result: ShellExecutionResult, cache?: SandboxDenialCache): ParsedSandboxDenial | undefined;
|
|
@@ -3,21 +3,72 @@
|
|
|
3
3
|
* Copyright 2026 Google LLC
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
|
+
import { LRUCache } from 'mnemonist';
|
|
6
7
|
import {} from '../../services/sandboxManager.js';
|
|
8
|
+
import { isValidPathString } from '../../utils/paths.js';
|
|
9
|
+
/**
|
|
10
|
+
* Creates a new sandbox denial cache with a standard LRU policy.
|
|
11
|
+
*/
|
|
12
|
+
export function createSandboxDenialCache(maxSize = 10) {
|
|
13
|
+
return new LRUCache(maxSize);
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Sanitizes extracted paths to prevent path traversal vulnerabilities.
|
|
17
|
+
* Filters out paths containing '..' or null bytes.
|
|
18
|
+
*/
|
|
19
|
+
export function sanitizeExtractedPath(p) {
|
|
20
|
+
if (!isValidPathString(p))
|
|
21
|
+
return undefined;
|
|
22
|
+
// Reject paths with directory traversal components
|
|
23
|
+
const parts = p.split(/[/\\]/);
|
|
24
|
+
if (parts.includes('..')) {
|
|
25
|
+
return undefined;
|
|
26
|
+
}
|
|
27
|
+
// Reject paths with internal tildes (tilde should only be at the beginning)
|
|
28
|
+
if (p.indexOf('~') > 0) {
|
|
29
|
+
return undefined;
|
|
30
|
+
}
|
|
31
|
+
// Basic normalization without resolving symlinks or accessing the file system
|
|
32
|
+
let normalized = p;
|
|
33
|
+
// Collapse multiple slashes
|
|
34
|
+
normalized = normalized.replace(/\/+/g, '/');
|
|
35
|
+
// Remove single dot segments
|
|
36
|
+
normalized = normalized.replace(/\/\.\//g, '/');
|
|
37
|
+
// Remove trailing slashes (unless it's exactly '/')
|
|
38
|
+
if (normalized.length > 1 && normalized.endsWith('/')) {
|
|
39
|
+
normalized = normalized.slice(0, -1);
|
|
40
|
+
}
|
|
41
|
+
return normalized;
|
|
42
|
+
}
|
|
7
43
|
/**
|
|
8
44
|
* Common POSIX-style sandbox denial detection.
|
|
9
45
|
* Used by macOS and Linux sandbox managers.
|
|
10
46
|
*/
|
|
11
|
-
export function parsePosixSandboxDenials(result) {
|
|
47
|
+
export function parsePosixSandboxDenials(result, cache) {
|
|
12
48
|
const output = result.output || '';
|
|
13
49
|
const errorOutput = result.error?.message;
|
|
14
|
-
const
|
|
50
|
+
const fullText = output + '\n' + (errorOutput || '');
|
|
51
|
+
const combined = fullText.toLowerCase();
|
|
52
|
+
// Cache by the first 200 characters of the error to handle variable data (timestamps, PIDs)
|
|
53
|
+
const cacheKey = combined.trim().slice(0, 200);
|
|
54
|
+
if (cacheKey && cache?.has(cacheKey)) {
|
|
55
|
+
return undefined;
|
|
56
|
+
}
|
|
15
57
|
const isFileDenial = [
|
|
16
58
|
'operation not permitted',
|
|
59
|
+
'permission denied',
|
|
60
|
+
'eperm',
|
|
61
|
+
'eacces',
|
|
17
62
|
'vim:e303',
|
|
18
63
|
'should be read/write',
|
|
19
64
|
'sandbox_apply',
|
|
20
65
|
'sandbox: ',
|
|
66
|
+
'access denied',
|
|
67
|
+
'read-only file system',
|
|
68
|
+
'permissionerror',
|
|
69
|
+
'fs.permissiondenied',
|
|
70
|
+
'forbidden',
|
|
71
|
+
'system.unauthorizedaccessexception',
|
|
21
72
|
].some((keyword) => combined.includes(keyword));
|
|
22
73
|
const isNetworkDenial = [
|
|
23
74
|
'error connecting to',
|
|
@@ -25,41 +76,64 @@ export function parsePosixSandboxDenials(result) {
|
|
|
25
76
|
'could not resolve host',
|
|
26
77
|
'connection refused',
|
|
27
78
|
'no address associated with hostname',
|
|
79
|
+
'econnrefused',
|
|
80
|
+
'enotfound',
|
|
81
|
+
'etimedout',
|
|
82
|
+
'econnreset',
|
|
83
|
+
'network error',
|
|
84
|
+
'getaddrinfo',
|
|
85
|
+
'socket hang up',
|
|
86
|
+
'connect-timeout',
|
|
87
|
+
'err_pnpm_fetch',
|
|
88
|
+
'err_pnpm_no_matching_version',
|
|
89
|
+
"syscall: 'listen'",
|
|
90
|
+
'socketexception',
|
|
91
|
+
'networkaccessdenied',
|
|
28
92
|
].some((keyword) => combined.includes(keyword));
|
|
29
93
|
if (!isFileDenial && !isNetworkDenial) {
|
|
30
94
|
return undefined;
|
|
31
95
|
}
|
|
32
96
|
const filePaths = new Set();
|
|
33
|
-
// Extract denied paths (POSIX absolute paths)
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
97
|
+
// Extract denied paths (POSIX absolute paths or home-relative paths starting with ~)
|
|
98
|
+
const regexes = [
|
|
99
|
+
// format: /path: operation not permitted
|
|
100
|
+
/(?:^|\s)['"]?((?:\/|~)(?:[\w.\-/:~]*[\w.\-/~])?)['"]?[\s:,'"[\]]*operation not permitted/gi,
|
|
101
|
+
// format: operation not permitted, open '/path'
|
|
102
|
+
/operation not permitted[\s:,'"[\]]*open[\s:,'"[\]]*['"]?((?:\/|~)(?:[\w.\-/:~]*[\w.\-/~])?)['"]?/gi,
|
|
103
|
+
// format: permission denied, open '/path'
|
|
104
|
+
/permission denied[\s:,'"[\]]*open[\s:,'"[\]]*['"]?((?:\/|~)(?:[\w.\-/:~]*[\w.\-/~])?)['"]?/gi,
|
|
105
|
+
// format: npm error path /path or npm ERR! path /path
|
|
106
|
+
/npm[\s!]*[A-Za-z]*err[A-Za-z!]*[\s!]+path[\s!]*((?:\/|~)(?:[\w.\-/:~]*[\w.\-/~])?)/gi,
|
|
107
|
+
// format: eacces: permission denied, mkdir '/path'
|
|
108
|
+
/eacces[\s:,'"[\]]*permission denied[\s:,'"[\]]*\w+[\s:,'"[\]]*['"]?((?:\/|~)[\w.\-/:~]*[\w.\-/~])?/gi,
|
|
109
|
+
// format: PermissionError: [Errno 13] Permission denied: '/path'
|
|
110
|
+
/permissionerror[\s:,'"[\]]*(?:[^'"]*)['"]((?:\/|~)[\w.\-/:~]*[\w.\-/~])?['"]/gi,
|
|
111
|
+
// format: FileNotFoundError: [Errno 2] No such file or directory: '/path' (sometimes returned in sandbox denials if directory is hidden)
|
|
112
|
+
/filenotfounderror[\s:,'"[\]]*(?:[^'"]*)['"]((?:\/|~)[\w.\-/:~]*[\w.\-/~])?['"]/gi,
|
|
113
|
+
// format: Error: EACCES: permission denied, open '/path'
|
|
114
|
+
/error[\s:,'"[\]]*eacces[\s:,'"[\]]*permission denied[\s:,'"[\]]*(?:[^'"]*)['"]((?:\/|~)[\w.\-/:~]*[\w.\-/~])?['"]/gi,
|
|
115
|
+
];
|
|
116
|
+
for (const regex of regexes) {
|
|
117
|
+
let match;
|
|
118
|
+
while ((match = regex.exec(fullText)) !== null) {
|
|
119
|
+
const sanitized = sanitizeExtractedPath(match[1]);
|
|
120
|
+
if (sanitized)
|
|
121
|
+
filePaths.add(sanitized);
|
|
42
122
|
}
|
|
43
123
|
}
|
|
44
124
|
// Fallback heuristic: look for any absolute path in the output if it was a file denial
|
|
45
125
|
if (isFileDenial && filePaths.size === 0) {
|
|
46
126
|
const fallbackRegex = /(?:^|[\s"'[\]])(\/[a-zA-Z0-9_.-]+(?:\/[a-zA-Z0-9_.-]+)+)(?:$|[\s"'[\]:])/gi;
|
|
47
127
|
let m;
|
|
48
|
-
while ((m = fallbackRegex.exec(
|
|
49
|
-
const
|
|
50
|
-
if (
|
|
51
|
-
filePaths.add(
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
if (errorOutput) {
|
|
55
|
-
while ((m = fallbackRegex.exec(errorOutput)) !== null) {
|
|
56
|
-
const p = m[1];
|
|
57
|
-
if (p && !p.startsWith('/bin/') && !p.startsWith('/usr/bin/')) {
|
|
58
|
-
filePaths.add(p);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
128
|
+
while ((m = fallbackRegex.exec(fullText)) !== null) {
|
|
129
|
+
const sanitized = sanitizeExtractedPath(m[1]);
|
|
130
|
+
if (sanitized)
|
|
131
|
+
filePaths.add(sanitized);
|
|
61
132
|
}
|
|
62
133
|
}
|
|
134
|
+
if (cacheKey && cache) {
|
|
135
|
+
cache.set(cacheKey, true);
|
|
136
|
+
}
|
|
63
137
|
return {
|
|
64
138
|
network: isNetworkDenial || undefined,
|
|
65
139
|
filePaths: filePaths.size > 0 ? Array.from(filePaths) : undefined,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sandboxDenialUtils.js","sourceRoot":"","sources":["../../../../src/sandbox/utils/sandboxDenialUtils.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAA4B,MAAM,kCAAkC,CAAC;
|
|
1
|
+
{"version":3,"file":"sandboxDenialUtils.js","sourceRoot":"","sources":["../../../../src/sandbox/utils/sandboxDenialUtils.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
6
|
import { describe, it, expect } from 'vitest';
|
|
7
|
-
import { parsePosixSandboxDenials } from './sandboxDenialUtils.js';
|
|
7
|
+
import { parsePosixSandboxDenials, createSandboxDenialCache, } from './sandboxDenialUtils.js';
|
|
8
8
|
describe('parsePosixSandboxDenials', () => {
|
|
9
9
|
it('should detect file system denial and extract paths', () => {
|
|
10
10
|
const parsed = parsePosixSandboxDenials({
|
|
@@ -33,5 +33,156 @@ describe('parsePosixSandboxDenials', () => {
|
|
|
33
33
|
});
|
|
34
34
|
expect(parsed).toBeUndefined();
|
|
35
35
|
});
|
|
36
|
+
it('should detect npm specific file system denials', () => {
|
|
37
|
+
const output = `
|
|
38
|
+
npm verbose logfile could not be created: Error: EPERM: operation not permitted, open '/Users/galzahavi/.npm/_logs/2026-04-01T02_47_18_624Z-debug-0.log'
|
|
39
|
+
`;
|
|
40
|
+
const parsed = parsePosixSandboxDenials({
|
|
41
|
+
output,
|
|
42
|
+
});
|
|
43
|
+
expect(parsed).toBeDefined();
|
|
44
|
+
expect(parsed?.filePaths).toContain('/Users/galzahavi/.npm/_logs/2026-04-01T02_47_18_624Z-debug-0.log');
|
|
45
|
+
});
|
|
46
|
+
it('should detect npm specific path errors', () => {
|
|
47
|
+
const output = `
|
|
48
|
+
npm error code EPERM
|
|
49
|
+
npm error syscall open
|
|
50
|
+
npm error path /Users/galzahavi/.npm/_cacache/tmp/ccf579a2
|
|
51
|
+
`;
|
|
52
|
+
const parsed = parsePosixSandboxDenials({
|
|
53
|
+
output,
|
|
54
|
+
});
|
|
55
|
+
expect(parsed).toBeDefined();
|
|
56
|
+
expect(parsed?.filePaths).toContain('/Users/galzahavi/.npm/_cacache/tmp/ccf579a2');
|
|
57
|
+
});
|
|
58
|
+
it('should detect network denials with ENOTFOUND', () => {
|
|
59
|
+
const output = `
|
|
60
|
+
npm http fetch GET https://registry.npmjs.org/2 attempt 1 failed with ENOTFOUND
|
|
61
|
+
`;
|
|
62
|
+
const parsed = parsePosixSandboxDenials({
|
|
63
|
+
output,
|
|
64
|
+
});
|
|
65
|
+
expect(parsed).toBeDefined();
|
|
66
|
+
expect(parsed?.network).toBe(true);
|
|
67
|
+
});
|
|
68
|
+
it('should detect non-verbose npm path errors', () => {
|
|
69
|
+
const output = `
|
|
70
|
+
npm ERR! code EPERM
|
|
71
|
+
npm ERR! syscall open
|
|
72
|
+
npm ERR! path /Users/galzahavi/.npm/_cacache/tmp/ccf579a2
|
|
73
|
+
`;
|
|
74
|
+
const parsed = parsePosixSandboxDenials({
|
|
75
|
+
output,
|
|
76
|
+
});
|
|
77
|
+
expect(parsed).toBeDefined();
|
|
78
|
+
expect(parsed?.filePaths).toContain('/Users/galzahavi/.npm/_cacache/tmp/ccf579a2');
|
|
79
|
+
});
|
|
80
|
+
it('should detect pnpm specific network errors', () => {
|
|
81
|
+
const output = `
|
|
82
|
+
ERR_PNPM_FETCH_404 GET https://registry.npmjs.org/nonexistent: Not Found
|
|
83
|
+
`;
|
|
84
|
+
const parsed = parsePosixSandboxDenials({
|
|
85
|
+
output,
|
|
86
|
+
});
|
|
87
|
+
expect(parsed).toBeDefined();
|
|
88
|
+
expect(parsed?.network).toBe(true);
|
|
89
|
+
});
|
|
90
|
+
it('should detect pnpm specific file system errors', () => {
|
|
91
|
+
const output = `
|
|
92
|
+
EACCES: permission denied, mkdir '/Users/galzahavi/.pnpm-store/v3'
|
|
93
|
+
`;
|
|
94
|
+
const parsed = parsePosixSandboxDenials({
|
|
95
|
+
output,
|
|
96
|
+
});
|
|
97
|
+
expect(parsed).toBeDefined();
|
|
98
|
+
expect(parsed?.filePaths).toContain('/Users/galzahavi/.pnpm-store/v3');
|
|
99
|
+
});
|
|
100
|
+
it('should detect Python PermissionError and extract path accurately', () => {
|
|
101
|
+
const output = `Caught exception: [Errno 13] Permission denied: '/etc/test_sandbox_denial'
|
|
102
|
+
Traceback (most recent call last):
|
|
103
|
+
File "/usr/local/google/home/davidapierce/gemini-cli/repro_sandbox.py", line 9, in <module>
|
|
104
|
+
raise e
|
|
105
|
+
File "/usr/local/google/home/davidapierce/gemini-cli/repro_sandbox.py", line 5, in <module>
|
|
106
|
+
with open('/etc/test_sandbox_denial', 'w') as f:
|
|
107
|
+
~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
108
|
+
PermissionError: [Errno 13] Permission denied: '/etc/test_sandbox_denial'`;
|
|
109
|
+
const parsed = parsePosixSandboxDenials({
|
|
110
|
+
output,
|
|
111
|
+
exitCode: 1,
|
|
112
|
+
error: null,
|
|
113
|
+
});
|
|
114
|
+
expect(parsed?.filePaths).toEqual(['/etc/test_sandbox_denial']);
|
|
115
|
+
});
|
|
116
|
+
it('should detect new keywords like "access denied" and "forbidden"', () => {
|
|
117
|
+
const parsed1 = parsePosixSandboxDenials({
|
|
118
|
+
output: 'Access denied to /var/log/syslog',
|
|
119
|
+
exitCode: 1,
|
|
120
|
+
error: null,
|
|
121
|
+
});
|
|
122
|
+
expect(parsed1?.filePaths).toContain('/var/log/syslog');
|
|
123
|
+
const parsed2 = parsePosixSandboxDenials({
|
|
124
|
+
output: 'Forbidden: access to /root/secret is not allowed',
|
|
125
|
+
exitCode: 1,
|
|
126
|
+
error: null,
|
|
127
|
+
});
|
|
128
|
+
expect(parsed2?.filePaths).toContain('/root/secret');
|
|
129
|
+
});
|
|
130
|
+
it('should detect read-only file system error', () => {
|
|
131
|
+
const parsed = parsePosixSandboxDenials({
|
|
132
|
+
output: 'rm: cannot remove /mnt/usb/test: Read-only file system',
|
|
133
|
+
exitCode: 1,
|
|
134
|
+
error: null,
|
|
135
|
+
});
|
|
136
|
+
expect(parsed?.filePaths).toContain('/mnt/usb/test');
|
|
137
|
+
});
|
|
138
|
+
it('should reject paths with directory traversal', () => {
|
|
139
|
+
const output = 'ls: /etc/shadow/../../etc/passwd: Operation not permitted';
|
|
140
|
+
const parsed = parsePosixSandboxDenials({
|
|
141
|
+
output,
|
|
142
|
+
});
|
|
143
|
+
expect(parsed?.filePaths || []).not.toContain('/etc/shadow/../../etc/passwd');
|
|
144
|
+
});
|
|
145
|
+
it('should reject home-relative paths with directory traversal', () => {
|
|
146
|
+
const output = "Operation not permitted, open '~/../../etc/shadow'";
|
|
147
|
+
const parsed = parsePosixSandboxDenials({
|
|
148
|
+
output,
|
|
149
|
+
});
|
|
150
|
+
expect(parsed?.filePaths || []).not.toContain('~/../../etc/shadow');
|
|
151
|
+
});
|
|
152
|
+
it('should reject paths with null bytes', () => {
|
|
153
|
+
const output = "Operation not permitted, open '/etc/passwd\0/foo'";
|
|
154
|
+
const parsed = parsePosixSandboxDenials({
|
|
155
|
+
output,
|
|
156
|
+
});
|
|
157
|
+
expect(parsed?.filePaths || []).not.toContain('/etc/passwd\0/foo');
|
|
158
|
+
});
|
|
159
|
+
it('should reject paths with internal tildes', () => {
|
|
160
|
+
const output = "Operation not permitted, open '/home/user/~/config'";
|
|
161
|
+
const parsed = parsePosixSandboxDenials({
|
|
162
|
+
output,
|
|
163
|
+
});
|
|
164
|
+
expect(parsed?.filePaths || []).not.toContain('/home/user/~/config');
|
|
165
|
+
});
|
|
166
|
+
it('should suppress redundant denials if cache is provided', () => {
|
|
167
|
+
const cache = createSandboxDenialCache();
|
|
168
|
+
const result = {
|
|
169
|
+
output: 'ls: /root: Operation not permitted',
|
|
170
|
+
};
|
|
171
|
+
// First call: should process
|
|
172
|
+
const parsed1 = parsePosixSandboxDenials(result, cache);
|
|
173
|
+
expect(parsed1).toBeDefined();
|
|
174
|
+
// Second call: should be suppressed
|
|
175
|
+
const parsed2 = parsePosixSandboxDenials(result, cache);
|
|
176
|
+
expect(parsed2).toBeUndefined();
|
|
177
|
+
});
|
|
178
|
+
it('should not suppress denials if no cache is provided', () => {
|
|
179
|
+
const result = {
|
|
180
|
+
output: 'ls: /root: Operation not permitted',
|
|
181
|
+
};
|
|
182
|
+
const parsed1 = parsePosixSandboxDenials(result);
|
|
183
|
+
expect(parsed1).toBeDefined();
|
|
184
|
+
const parsed2 = parsePosixSandboxDenials(result);
|
|
185
|
+
expect(parsed2).toBeDefined();
|
|
186
|
+
});
|
|
36
187
|
});
|
|
37
188
|
//# sourceMappingURL=sandboxDenialUtils.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sandboxDenialUtils.test.js","sourceRoot":"","sources":["../../../../src/sandbox/utils/sandboxDenialUtils.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,
|
|
1
|
+
{"version":3,"file":"sandboxDenialUtils.test.js","sourceRoot":"","sources":["../../../../src/sandbox/utils/sandboxDenialUtils.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,11 +5,15 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import * as path from 'node:path';
|
|
7
7
|
import {} from '../../services/sandboxManager.js';
|
|
8
|
+
import { isValidPathString } from '../../utils/paths.js';
|
|
8
9
|
/**
|
|
9
10
|
* Validates if the requested paths are within the allowed workspace or allowed paths.
|
|
10
11
|
*/
|
|
11
12
|
function validatePaths(paths, workspace, allowedPaths) {
|
|
12
13
|
for (const p of paths) {
|
|
14
|
+
if (!isValidPathString(p)) {
|
|
15
|
+
return false; // Reject malicious paths
|
|
16
|
+
}
|
|
13
17
|
const resolvedPath = path.resolve(p);
|
|
14
18
|
const resolvedWorkspace = path.resolve(workspace);
|
|
15
19
|
const isInsideWorkspace = resolvedPath.startsWith(resolvedWorkspace + path.sep) ||
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sandboxReadWriteUtils.js","sourceRoot":"","sources":["../../../../src/sandbox/utils/sandboxReadWriteUtils.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,KAAK,IAAI,MAAM,WAAW,CAAC;AAClC,OAAO,EAGN,MAAM,kCAAkC,CAAC;
|
|
1
|
+
{"version":3,"file":"sandboxReadWriteUtils.js","sourceRoot":"","sources":["../../../../src/sandbox/utils/sandboxReadWriteUtils.ts"],"names":[],"mappings":"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"}
|