@machina.ai/cell-cli-core 1.10.0-rc1 → 1.13.0-rc1
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/dist/index.d.ts +5 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -1
- package/dist/package.json +13 -5
- package/dist/src/agents/codebase-investigator.js +2 -5
- package/dist/src/agents/codebase-investigator.js.map +1 -1
- package/dist/src/agents/executor.d.ts +19 -0
- package/dist/src/agents/executor.js +234 -46
- package/dist/src/agents/executor.js.map +1 -1
- package/dist/src/agents/executor.test.js +371 -40
- package/dist/src/agents/executor.test.js.map +1 -1
- package/dist/src/agents/registry.js +4 -3
- package/dist/src/agents/registry.js.map +1 -1
- package/dist/src/agents/subagent-tool-wrapper.test.js +2 -4
- package/dist/src/agents/subagent-tool-wrapper.test.js.map +1 -1
- package/dist/src/agents/types.d.ts +2 -1
- package/dist/src/agents/types.js +1 -0
- package/dist/src/agents/types.js.map +1 -1
- package/dist/src/code_assist/converter.d.ts +1 -0
- package/dist/src/code_assist/converter.js +1 -0
- package/dist/src/code_assist/converter.js.map +1 -1
- package/dist/src/code_assist/converter.test.js +19 -0
- package/dist/src/code_assist/converter.test.js.map +1 -1
- package/dist/src/code_assist/experiments/client_metadata.d.ts +12 -0
- package/dist/src/code_assist/experiments/client_metadata.js +49 -0
- package/dist/src/code_assist/experiments/client_metadata.js.map +1 -0
- package/dist/src/code_assist/experiments/experiments.d.ts +17 -0
- package/dist/src/code_assist/experiments/experiments.js +36 -0
- package/dist/src/code_assist/experiments/experiments.js.map +1 -0
- package/dist/src/code_assist/experiments/types.d.ts +35 -0
- package/dist/src/code_assist/experiments/types.js +7 -0
- package/dist/src/code_assist/experiments/types.js.map +1 -0
- package/dist/src/code_assist/oauth-credential-storage.js +5 -4
- package/dist/src/code_assist/oauth-credential-storage.js.map +1 -1
- package/dist/src/code_assist/oauth-credential-storage.test.js +15 -3
- package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -1
- package/dist/src/code_assist/oauth2.d.ts +2 -2
- package/dist/src/code_assist/oauth2.js +64 -51
- package/dist/src/code_assist/oauth2.js.map +1 -1
- package/dist/src/code_assist/oauth2.test.js +65 -33
- package/dist/src/code_assist/oauth2.test.js.map +1 -1
- package/dist/src/code_assist/server.d.ts +6 -4
- package/dist/src/code_assist/server.js +11 -0
- package/dist/src/code_assist/server.js.map +1 -1
- package/dist/src/code_assist/server.test.js +17 -0
- package/dist/src/code_assist/server.test.js.map +1 -1
- package/dist/src/code_assist/setup.d.ts +2 -2
- package/dist/src/code_assist/setup.js.map +1 -1
- package/dist/src/code_assist/types.d.ts +1 -1
- package/dist/src/code_assist/types.js.map +1 -1
- package/dist/src/commands/extensions.d.ts +7 -0
- package/dist/src/commands/extensions.js +9 -0
- package/dist/src/commands/extensions.js.map +1 -0
- package/dist/src/commands/extensions.test.js +19 -0
- package/dist/src/commands/extensions.test.js.map +1 -0
- package/dist/src/config/config.d.ts +81 -32
- package/dist/src/config/config.js +193 -66
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/config.test.js +115 -36
- package/dist/src/config/config.test.js.map +1 -1
- package/dist/src/config/models.d.ts +1 -1
- package/dist/src/config/models.js +2 -2
- package/dist/src/config/models.js.map +1 -1
- package/dist/src/config/storage.d.ts +3 -0
- package/dist/src/config/storage.js +20 -0
- package/dist/src/config/storage.js.map +1 -1
- package/dist/src/confirmation-bus/message-bus.d.ts +2 -1
- package/dist/src/confirmation-bus/message-bus.js +7 -1
- package/dist/src/confirmation-bus/message-bus.js.map +1 -1
- package/dist/src/confirmation-bus/types.d.ts +12 -2
- package/dist/src/confirmation-bus/types.js +1 -0
- package/dist/src/confirmation-bus/types.js.map +1 -1
- package/dist/src/core/apiKeyCredentialStorage.d.ts +17 -0
- package/dist/src/core/apiKeyCredentialStorage.js +64 -0
- package/dist/src/core/apiKeyCredentialStorage.js.map +1 -0
- package/dist/src/core/apiKeyCredentialStorage.test.d.ts +6 -0
- package/dist/src/core/apiKeyCredentialStorage.test.js +71 -0
- package/dist/src/core/apiKeyCredentialStorage.test.js.map +1 -0
- package/dist/src/core/client.d.ts +2 -11
- package/dist/src/core/client.js +31 -170
- package/dist/src/core/client.js.map +1 -1
- package/dist/src/core/client.test.js +107 -429
- package/dist/src/core/client.test.js.map +1 -1
- package/dist/src/core/contentGenerator.js +64 -59
- package/dist/src/core/contentGenerator.js.map +1 -1
- package/dist/src/core/contentGenerator.test.js +38 -4
- package/dist/src/core/contentGenerator.test.js.map +1 -1
- package/dist/src/core/coreToolScheduler.d.ts +8 -2
- package/dist/src/core/coreToolScheduler.js +337 -172
- package/dist/src/core/coreToolScheduler.js.map +1 -1
- package/dist/src/core/coreToolScheduler.test.js +363 -12
- package/dist/src/core/coreToolScheduler.test.js.map +1 -1
- package/dist/src/core/fakeContentGenerator.d.ts +33 -0
- package/dist/src/core/fakeContentGenerator.js +58 -0
- package/dist/src/core/fakeContentGenerator.js.map +1 -0
- package/dist/src/core/fakeContentGenerator.test.d.ts +6 -0
- package/dist/src/core/fakeContentGenerator.test.js +127 -0
- package/dist/src/core/fakeContentGenerator.test.js.map +1 -0
- package/dist/src/core/geminiChat.d.ts +2 -0
- package/dist/src/core/geminiChat.js +7 -2
- package/dist/src/core/geminiChat.js.map +1 -1
- package/dist/src/core/geminiChat.test.js +15 -3
- package/dist/src/core/geminiChat.test.js.map +1 -1
- package/dist/src/core/logger.js +21 -19
- package/dist/src/core/logger.js.map +1 -1
- package/dist/src/core/loggingContentGenerator.d.ts +1 -0
- package/dist/src/core/loggingContentGenerator.js +113 -33
- package/dist/src/core/loggingContentGenerator.js.map +1 -1
- package/dist/src/core/nonInteractiveToolExecutor.js +5 -4
- package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -1
- package/dist/src/core/nonInteractiveToolExecutor.test.js +3 -0
- package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -1
- package/dist/src/core/prompts.js +115 -72
- package/dist/src/core/prompts.js.map +1 -1
- package/dist/src/core/prompts.test.js +30 -108
- package/dist/src/core/prompts.test.js.map +1 -1
- package/dist/src/core/recordingContentGenerator.d.ts +18 -0
- package/dist/src/core/recordingContentGenerator.js +77 -0
- package/dist/src/core/recordingContentGenerator.js.map +1 -0
- package/dist/src/core/recordingContentGenerator.test.d.ts +6 -0
- package/dist/src/core/recordingContentGenerator.test.js +101 -0
- package/dist/src/core/recordingContentGenerator.test.js.map +1 -0
- package/dist/src/core/turn.d.ts +2 -0
- package/dist/src/core/turn.js +3 -1
- package/dist/src/core/turn.js.map +1 -1
- package/dist/src/core/turn.test.js +48 -0
- package/dist/src/core/turn.test.js.map +1 -1
- package/dist/src/fallback/handler.js +2 -0
- package/dist/src/fallback/handler.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/hookPlanner.d.ts +46 -0
- package/dist/src/hooks/hookPlanner.js +108 -0
- package/dist/src/hooks/hookPlanner.js.map +1 -0
- package/dist/src/hooks/hookPlanner.test.d.ts +6 -0
- package/dist/src/hooks/hookPlanner.test.js +255 -0
- package/dist/src/hooks/hookPlanner.test.js.map +1 -0
- package/dist/src/hooks/hookRegistry.d.ts +87 -0
- package/dist/src/hooks/hookRegistry.js +198 -0
- package/dist/src/hooks/hookRegistry.js.map +1 -0
- package/dist/src/hooks/hookRegistry.test.d.ts +6 -0
- package/dist/src/hooks/hookRegistry.test.js +341 -0
- package/dist/src/hooks/hookRegistry.test.js.map +1 -0
- package/dist/src/hooks/hookTranslator.d.ts +113 -0
- package/dist/src/hooks/hookTranslator.js +232 -0
- package/dist/src/hooks/hookTranslator.js.map +1 -0
- package/dist/src/hooks/hookTranslator.test.d.ts +6 -0
- package/dist/src/hooks/hookTranslator.test.js +192 -0
- package/dist/src/hooks/hookTranslator.test.js.map +1 -0
- package/dist/src/hooks/types.d.ts +384 -0
- package/dist/src/hooks/types.js +284 -0
- package/dist/src/hooks/types.js.map +1 -0
- package/dist/src/hooks/types.test.d.ts +6 -0
- package/dist/src/hooks/types.test.js +35 -0
- package/dist/src/hooks/types.test.js.map +1 -0
- package/dist/src/ide/ide-client.js +2 -1
- package/dist/src/ide/ide-client.js.map +1 -1
- package/dist/src/index.d.ts +15 -0
- package/dist/src/index.js +18 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/mcp/google-auth-provider.d.ts +2 -0
- package/dist/src/mcp/google-auth-provider.js +21 -3
- package/dist/src/mcp/google-auth-provider.js.map +1 -1
- package/dist/src/mcp/google-auth-provider.test.js +42 -9
- package/dist/src/mcp/google-auth-provider.test.js.map +1 -1
- package/dist/src/mcp/mcpLauncher.d.ts +26 -0
- package/dist/src/mcp/mcpLauncher.js +238 -0
- package/dist/src/mcp/mcpLauncher.js.map +1 -0
- package/dist/src/mcp/oauth-provider.d.ts +8 -5
- package/dist/src/mcp/oauth-provider.js +140 -55
- package/dist/src/mcp/oauth-provider.js.map +1 -1
- package/dist/src/mcp/oauth-provider.test.js +191 -2
- package/dist/src/mcp/oauth-provider.test.js.map +1 -1
- package/dist/src/mcp/oauth-token-storage.js +5 -4
- package/dist/src/mcp/oauth-token-storage.js.map +1 -1
- package/dist/src/mcp/oauth-token-storage.test.js +17 -11
- package/dist/src/mcp/oauth-token-storage.test.js.map +1 -1
- package/dist/src/mcp/oauth-utils.d.ts +7 -0
- package/dist/src/mcp/oauth-utils.js +28 -8
- package/dist/src/mcp/oauth-utils.js.map +1 -1
- package/dist/src/mcp/oauth-utils.test.js +45 -2
- package/dist/src/mcp/oauth-utils.test.js.map +1 -1
- package/dist/src/mcp/sa-impersonation-provider.d.ts +0 -6
- package/dist/src/mcp/sa-impersonation-provider.js +6 -23
- package/dist/src/mcp/sa-impersonation-provider.js.map +1 -1
- package/dist/src/mcp/token-storage/base-token-storage.test.js +75 -84
- package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -1
- package/dist/src/mcp/token-storage/file-token-storage.js +1 -1
- package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -1
- package/dist/src/mcp/token-storage/file-token-storage.test.js +7 -5
- package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -1
- package/dist/src/mcp/token-storage/hybrid-token-storage.js +1 -1
- package/dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -1
- package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +2 -2
- package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -1
- package/dist/src/mcp/token-storage/keychain-token-storage.d.ts +6 -2
- package/dist/src/mcp/token-storage/keychain-token-storage.js +63 -7
- package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -1
- package/dist/src/mcp/token-storage/keychain-token-storage.test.js +54 -3
- package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -1
- package/dist/src/mcp/token-storage/types.d.ts +6 -0
- package/dist/src/mcp/token-storage/types.js.map +1 -1
- package/dist/src/output/stream-json-formatter.d.ts +32 -0
- package/dist/src/output/stream-json-formatter.js +52 -0
- package/dist/src/output/stream-json-formatter.js.map +1 -0
- package/dist/src/output/stream-json-formatter.test.d.ts +6 -0
- package/dist/src/output/stream-json-formatter.test.js +479 -0
- package/dist/src/output/stream-json-formatter.test.js.map +1 -0
- package/dist/src/output/types.d.ts +63 -1
- package/dist/src/output/types.js +11 -0
- package/dist/src/output/types.js.map +1 -1
- package/dist/src/policy/config.d.ts +31 -0
- package/dist/src/policy/config.js +197 -0
- package/dist/src/policy/config.js.map +1 -0
- package/dist/src/policy/config.test.d.ts +6 -0
- package/dist/src/policy/config.test.js +404 -0
- package/dist/src/policy/config.test.js.map +1 -0
- package/dist/src/policy/index.d.ts +2 -0
- package/dist/src/policy/index.js +2 -0
- package/dist/src/policy/index.js.map +1 -1
- package/dist/src/policy/policies/read-only.toml +56 -0
- package/dist/src/policy/policies/write.toml +63 -0
- package/dist/src/policy/policies/yolo.toml +31 -0
- package/dist/src/policy/policy-engine.js +4 -0
- package/dist/src/policy/policy-engine.js.map +1 -1
- package/dist/src/policy/toml-loader.d.ts +46 -0
- package/dist/src/policy/toml-loader.js +314 -0
- package/dist/src/policy/toml-loader.js.map +1 -0
- package/dist/src/policy/toml-loader.test.d.ts +6 -0
- package/dist/src/policy/toml-loader.test.js +522 -0
- package/dist/src/policy/toml-loader.test.js.map +1 -0
- package/dist/src/policy/types.d.ts +18 -0
- package/dist/src/policy/types.js +6 -0
- package/dist/src/policy/types.js.map +1 -1
- package/dist/src/prompts/prompt-registry.js +2 -1
- package/dist/src/prompts/prompt-registry.js.map +1 -1
- package/dist/src/routing/strategies/classifierStrategy.js +3 -2
- package/dist/src/routing/strategies/classifierStrategy.js.map +1 -1
- package/dist/src/services/chatCompressionService.d.ts +32 -0
- package/dist/src/services/chatCompressionService.js +162 -0
- package/dist/src/services/chatCompressionService.js.map +1 -0
- package/dist/src/services/chatCompressionService.test.d.ts +6 -0
- package/dist/src/services/chatCompressionService.test.js +209 -0
- package/dist/src/services/chatCompressionService.test.js.map +1 -0
- package/dist/src/services/chatRecordingService.js +9 -8
- package/dist/src/services/chatRecordingService.js.map +1 -1
- package/dist/src/services/fileDiscoveryService.d.ts +2 -14
- package/dist/src/services/fileDiscoveryService.js +19 -55
- package/dist/src/services/fileDiscoveryService.js.map +1 -1
- package/dist/src/services/fileDiscoveryService.test.js +91 -11
- package/dist/src/services/fileDiscoveryService.test.js.map +1 -1
- package/dist/src/services/loopDetectionService.d.ts +1 -1
- package/dist/src/services/loopDetectionService.js +27 -13
- package/dist/src/services/loopDetectionService.js.map +1 -1
- package/dist/src/services/loopDetectionService.test.js +119 -11
- package/dist/src/services/loopDetectionService.test.js.map +1 -1
- package/dist/src/services/shellExecutionService.js +50 -23
- package/dist/src/services/shellExecutionService.js.map +1 -1
- package/dist/src/services/shellExecutionService.test.js +82 -15
- package/dist/src/services/shellExecutionService.test.js.map +1 -1
- package/dist/src/telemetry/activity-monitor.d.ts +116 -0
- package/dist/src/telemetry/activity-monitor.js +209 -0
- package/dist/src/telemetry/activity-monitor.js.map +1 -0
- package/dist/src/telemetry/activity-monitor.test.d.ts +6 -0
- package/dist/src/telemetry/activity-monitor.test.js +248 -0
- package/dist/src/telemetry/activity-monitor.test.js.map +1 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +5 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +135 -57
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +43 -75
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +7 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +13 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
- package/dist/src/telemetry/gcp-exporters.js +0 -1
- package/dist/src/telemetry/gcp-exporters.js.map +1 -1
- package/dist/src/telemetry/gcp-exporters.test.js +1 -1
- package/dist/src/telemetry/gcp-exporters.test.js.map +1 -1
- package/dist/src/telemetry/index.d.ts +4 -2
- package/dist/src/telemetry/index.js +5 -3
- package/dist/src/telemetry/index.js.map +1 -1
- package/dist/src/telemetry/loggers.d.ts +2 -1
- package/dist/src/telemetry/loggers.js +37 -26
- package/dist/src/telemetry/loggers.js.map +1 -1
- package/dist/src/telemetry/loggers.test.js +215 -56
- package/dist/src/telemetry/loggers.test.js.map +1 -1
- package/dist/src/telemetry/metrics.d.ts +55 -6
- package/dist/src/telemetry/metrics.js +89 -1
- package/dist/src/telemetry/metrics.js.map +1 -1
- package/dist/src/telemetry/metrics.test.js +172 -213
- package/dist/src/telemetry/metrics.test.js.map +1 -1
- package/dist/src/telemetry/sdk.js +3 -2
- package/dist/src/telemetry/sdk.js.map +1 -1
- package/dist/src/telemetry/semantic.d.ts +82 -0
- package/dist/src/telemetry/semantic.js +269 -0
- package/dist/src/telemetry/semantic.js.map +1 -0
- package/dist/src/telemetry/semantic.test.d.ts +6 -0
- package/dist/src/telemetry/semantic.test.js +387 -0
- package/dist/src/telemetry/semantic.test.js.map +1 -0
- package/dist/src/telemetry/telemetry-utils.test.js +29 -28
- package/dist/src/telemetry/telemetry-utils.test.js.map +1 -1
- package/dist/src/telemetry/trace.d.ts +46 -0
- package/dist/src/telemetry/trace.js +121 -0
- package/dist/src/telemetry/trace.js.map +1 -0
- package/dist/src/telemetry/types.d.ts +79 -34
- package/dist/src/telemetry/types.js +191 -61
- package/dist/src/telemetry/types.js.map +1 -1
- package/dist/src/telemetry/uiTelemetry.js +6 -6
- package/dist/src/telemetry/uiTelemetry.js.map +1 -1
- package/dist/src/telemetry/uiTelemetry.test.js +88 -66
- package/dist/src/telemetry/uiTelemetry.test.js.map +1 -1
- package/dist/src/tools/edit.d.ts +3 -2
- package/dist/src/tools/edit.js +24 -19
- package/dist/src/tools/edit.js.map +1 -1
- package/dist/src/tools/edit.test.js +78 -2
- package/dist/src/tools/edit.test.js.map +1 -1
- package/dist/src/tools/glob.d.ts +3 -2
- package/dist/src/tools/glob.js +15 -19
- package/dist/src/tools/glob.js.map +1 -1
- package/dist/src/tools/glob.test.js +203 -199
- package/dist/src/tools/glob.test.js.map +1 -1
- package/dist/src/tools/grep.d.ts +3 -2
- package/dist/src/tools/grep.js +22 -16
- package/dist/src/tools/grep.js.map +1 -1
- package/dist/src/tools/ls.d.ts +3 -2
- package/dist/src/tools/ls.js +15 -20
- package/dist/src/tools/ls.js.map +1 -1
- package/dist/src/tools/ls.test.js +2 -9
- package/dist/src/tools/ls.test.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.d.ts +49 -11
- package/dist/src/tools/mcp-client-manager.js +209 -31
- package/dist/src/tools/mcp-client-manager.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.test.js +132 -25
- package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
- package/dist/src/tools/mcp-client.d.ts +5 -1
- package/dist/src/tools/mcp-client.js +85 -104
- package/dist/src/tools/mcp-client.js.map +1 -1
- package/dist/src/tools/mcp-client.test.js +65 -6
- package/dist/src/tools/mcp-client.test.js.map +1 -1
- package/dist/src/tools/mcp-tool.d.ts +5 -2
- package/dist/src/tools/mcp-tool.js +16 -8
- package/dist/src/tools/mcp-tool.js.map +1 -1
- package/dist/src/tools/memoryTool.d.ts +6 -4
- package/dist/src/tools/memoryTool.js +13 -10
- package/dist/src/tools/memoryTool.js.map +1 -1
- package/dist/src/tools/message-bus-integration.test.js +14 -1
- package/dist/src/tools/message-bus-integration.test.js.map +1 -1
- package/dist/src/tools/modifiable-tool.js +3 -2
- package/dist/src/tools/modifiable-tool.js.map +1 -1
- package/dist/src/tools/read-file.d.ts +4 -3
- package/dist/src/tools/read-file.js +16 -11
- package/dist/src/tools/read-file.js.map +1 -1
- package/dist/src/tools/read-file.test.js +25 -2
- package/dist/src/tools/read-file.test.js.map +1 -1
- package/dist/src/tools/read-many-files.d.ts +4 -3
- package/dist/src/tools/read-many-files.js +19 -37
- package/dist/src/tools/read-many-files.js.map +1 -1
- package/dist/src/tools/read-many-files.test.js +0 -1
- package/dist/src/tools/read-many-files.test.js.map +1 -1
- package/dist/src/tools/ripGrep.d.ts +3 -2
- package/dist/src/tools/ripGrep.js +47 -17
- package/dist/src/tools/ripGrep.js.map +1 -1
- package/dist/src/tools/ripGrep.test.js +106 -60
- package/dist/src/tools/ripGrep.test.js.map +1 -1
- package/dist/src/tools/shell.d.ts +7 -5
- package/dist/src/tools/shell.js +39 -68
- package/dist/src/tools/shell.js.map +1 -1
- package/dist/src/tools/shell.test.js +69 -9
- package/dist/src/tools/shell.test.js.map +1 -1
- package/dist/src/tools/smart-edit.d.ts +3 -2
- package/dist/src/tools/smart-edit.js +30 -18
- package/dist/src/tools/smart-edit.js.map +1 -1
- package/dist/src/tools/smart-edit.test.js +62 -2
- package/dist/src/tools/smart-edit.test.js.map +1 -1
- package/dist/src/tools/tool-names.d.ts +8 -0
- package/dist/src/tools/tool-names.js +8 -5
- package/dist/src/tools/tool-names.js.map +1 -1
- package/dist/src/tools/tool-registry.d.ts +6 -19
- package/dist/src/tools/tool-registry.js +14 -49
- package/dist/src/tools/tool-registry.js.map +1 -1
- package/dist/src/tools/tool-registry.test.js +2 -24
- package/dist/src/tools/tool-registry.test.js.map +1 -1
- package/dist/src/tools/tools.d.ts +22 -8
- package/dist/src/tools/tools.js +65 -36
- package/dist/src/tools/tools.js.map +1 -1
- package/dist/src/tools/web-fetch.d.ts +4 -3
- package/dist/src/tools/web-fetch.js +37 -25
- package/dist/src/tools/web-fetch.js.map +1 -1
- package/dist/src/tools/web-fetch.test.js +262 -1
- package/dist/src/tools/web-fetch.test.js.map +1 -1
- package/dist/src/tools/web-search.d.ts +4 -3
- package/dist/src/tools/web-search.js +8 -6
- package/dist/src/tools/web-search.js.map +1 -1
- package/dist/src/tools/write-file.d.ts +3 -2
- package/dist/src/tools/write-file.js +8 -8
- package/dist/src/tools/write-file.js.map +1 -1
- package/dist/src/tools/write-file.test.js +1 -2
- package/dist/src/tools/write-file.test.js.map +1 -1
- package/dist/src/tools/write-todos.d.ts +4 -8
- package/dist/src/tools/write-todos.js +15 -6
- package/dist/src/tools/write-todos.js.map +1 -1
- package/dist/src/tools/write-todos.test.js +2 -2
- package/dist/src/tools/write-todos.test.js.map +1 -1
- package/dist/src/utils/bfsFileSearch.js +3 -2
- package/dist/src/utils/bfsFileSearch.js.map +1 -1
- package/dist/src/utils/channel.d.ts +19 -0
- package/dist/src/utils/channel.js +49 -0
- package/dist/src/utils/channel.js.map +1 -0
- package/dist/src/utils/channel.test.d.ts +6 -0
- package/dist/src/utils/channel.test.js +170 -0
- package/dist/src/utils/channel.test.js.map +1 -0
- package/dist/src/utils/debugLogger.d.ts +25 -0
- package/dist/src/utils/debugLogger.js +33 -0
- package/dist/src/utils/debugLogger.js.map +1 -0
- package/dist/src/utils/debugLogger.test.d.ts +6 -0
- package/dist/src/utils/debugLogger.test.js +67 -0
- package/dist/src/utils/debugLogger.test.js.map +1 -0
- package/dist/src/utils/delay.d.ts +16 -0
- package/dist/src/utils/delay.js +43 -0
- package/dist/src/utils/delay.js.map +1 -0
- package/dist/src/utils/delay.test.d.ts +6 -0
- package/dist/src/utils/delay.test.js +88 -0
- package/dist/src/utils/delay.test.js.map +1 -0
- package/dist/src/utils/editCorrector.js +5 -9
- package/dist/src/utils/editCorrector.js.map +1 -1
- package/dist/src/utils/editCorrector.test.js +3 -5
- package/dist/src/utils/editCorrector.test.js.map +1 -1
- package/dist/src/utils/editor.js +33 -38
- package/dist/src/utils/editor.js.map +1 -1
- package/dist/src/utils/environmentContext.d.ts +2 -1
- package/dist/src/utils/environmentContext.js +18 -33
- package/dist/src/utils/environmentContext.js.map +1 -1
- package/dist/src/utils/environmentContext.test.js +0 -34
- package/dist/src/utils/environmentContext.test.js.map +1 -1
- package/dist/src/utils/errorParsing.d.ts +1 -1
- package/dist/src/utils/errorParsing.js +5 -33
- package/dist/src/utils/errorParsing.js.map +1 -1
- package/dist/src/utils/errorParsing.test.js +0 -88
- package/dist/src/utils/errorParsing.test.js.map +1 -1
- package/dist/src/utils/errors.d.ts +3 -0
- package/dist/src/utils/errors.js +6 -0
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/events.d.ts +88 -0
- package/dist/src/utils/events.js +77 -0
- package/dist/src/utils/events.js.map +1 -0
- package/dist/src/utils/events.test.d.ts +6 -0
- package/dist/src/utils/events.test.js +131 -0
- package/dist/src/utils/events.test.js.map +1 -0
- package/dist/src/utils/extensionLoader.d.ts +78 -0
- package/dist/src/utils/extensionLoader.js +162 -0
- package/dist/src/utils/extensionLoader.js.map +1 -0
- package/dist/src/utils/extensionLoader.test.d.ts +6 -0
- package/dist/src/utils/extensionLoader.test.js +90 -0
- package/dist/src/utils/extensionLoader.test.js.map +1 -0
- package/dist/src/utils/fetch.d.ts +1 -0
- package/dist/src/utils/fetch.js +4 -0
- package/dist/src/utils/fetch.js.map +1 -1
- package/dist/src/utils/fileUtils.d.ts +4 -0
- package/dist/src/utils/fileUtils.js +34 -2
- package/dist/src/utils/fileUtils.js.map +1 -1
- package/dist/src/utils/fileUtils.test.js +12 -1
- package/dist/src/utils/fileUtils.test.js.map +1 -1
- package/dist/src/utils/flashFallback.test.js +26 -45
- package/dist/src/utils/flashFallback.test.js.map +1 -1
- package/dist/src/utils/getFolderStructure.js +9 -17
- package/dist/src/utils/getFolderStructure.js.map +1 -1
- package/dist/src/utils/gitIgnoreParser.d.ts +4 -1
- package/dist/src/utils/gitIgnoreParser.js +28 -10
- package/dist/src/utils/gitIgnoreParser.js.map +1 -1
- package/dist/src/utils/gitIgnoreParser.test.js +58 -0
- package/dist/src/utils/gitIgnoreParser.test.js.map +1 -1
- package/dist/src/utils/googleErrors.d.ts +104 -0
- package/dist/src/utils/googleErrors.js +152 -0
- package/dist/src/utils/googleErrors.js.map +1 -0
- package/dist/src/utils/googleErrors.test.d.ts +6 -0
- package/dist/src/utils/googleErrors.test.js +301 -0
- package/dist/src/utils/googleErrors.test.js.map +1 -0
- package/dist/src/utils/googleQuotaErrors.d.ts +36 -0
- package/dist/src/utils/googleQuotaErrors.js +149 -0
- package/dist/src/utils/googleQuotaErrors.js.map +1 -0
- package/dist/src/utils/googleQuotaErrors.test.d.ts +6 -0
- package/dist/src/utils/googleQuotaErrors.test.js +311 -0
- package/dist/src/utils/googleQuotaErrors.test.js.map +1 -0
- package/dist/src/utils/ignorePatterns.test.js +26 -30
- package/dist/src/utils/ignorePatterns.test.js.map +1 -1
- package/dist/src/utils/installationManager.js +2 -1
- package/dist/src/utils/installationManager.js.map +1 -1
- package/dist/src/utils/installationManager.test.js +3 -3
- package/dist/src/utils/installationManager.test.js.map +1 -1
- package/dist/src/utils/llm-edit-fixer.d.ts +1 -1
- package/dist/src/utils/llm-edit-fixer.js +29 -4
- package/dist/src/utils/llm-edit-fixer.js.map +1 -1
- package/dist/src/utils/llm-edit-fixer.test.js +21 -0
- package/dist/src/utils/llm-edit-fixer.test.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.d.ts +11 -1
- package/dist/src/utils/memoryDiscovery.js +150 -11
- package/dist/src/utils/memoryDiscovery.js.map +1 -1
- package/dist/src/utils/memoryDiscovery.test.js +157 -19
- package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
- package/dist/src/utils/memoryImportProcessor.js +3 -2
- package/dist/src/utils/memoryImportProcessor.js.map +1 -1
- package/dist/src/utils/nextSpeakerChecker.js +2 -1
- package/dist/src/utils/nextSpeakerChecker.js.map +1 -1
- package/dist/src/utils/package.d.ts +12 -0
- package/dist/src/utils/package.js +15 -0
- package/dist/src/utils/package.js.map +1 -0
- package/dist/src/utils/paths.js +126 -26
- package/dist/src/utils/paths.js.map +1 -1
- package/dist/src/utils/paths.test.js +200 -68
- package/dist/src/utils/paths.test.js.map +1 -1
- package/dist/src/utils/quotaErrorDetection.d.ts +0 -2
- package/dist/src/utils/quotaErrorDetection.js +0 -46
- package/dist/src/utils/quotaErrorDetection.js.map +1 -1
- package/dist/src/utils/retry.d.ts +1 -0
- package/dist/src/utils/retry.js +57 -158
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/utils/retry.test.js +48 -109
- package/dist/src/utils/retry.test.js.map +1 -1
- package/dist/src/utils/safeJsonStringify.d.ts +4 -4
- package/dist/src/utils/safeJsonStringify.js +31 -7
- package/dist/src/utils/safeJsonStringify.js.map +1 -1
- package/dist/src/utils/shell-utils.d.ts +14 -2
- package/dist/src/utils/shell-utils.js +381 -136
- package/dist/src/utils/shell-utils.js.map +1 -1
- package/dist/src/utils/shell-utils.test.js +242 -60
- package/dist/src/utils/shell-utils.test.js.map +1 -1
- package/dist/src/utils/summarizer.js +2 -1
- package/dist/src/utils/summarizer.js.map +1 -1
- package/dist/src/utils/summarizer.test.js +0 -1
- package/dist/src/utils/summarizer.test.js.map +1 -1
- package/dist/src/utils/systemEncoding.js +5 -4
- package/dist/src/utils/systemEncoding.js.map +1 -1
- package/dist/src/utils/tool-utils.d.ts +2 -2
- package/dist/src/utils/tool-utils.js +14 -5
- package/dist/src/utils/tool-utils.js.map +1 -1
- package/dist/src/utils/userAccountManager.js +5 -4
- package/dist/src/utils/userAccountManager.js.map +1 -1
- package/dist/src/utils/workspaceContext.js +3 -2
- package/dist/src/utils/workspaceContext.js.map +1 -1
- package/dist/src/utils/workspaceContext.test.js +2 -2
- package/dist/src/utils/workspaceContext.test.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +13 -5
- package/dist/src/core/subagent.d.ts +0 -236
- package/dist/src/core/subagent.js +0 -482
- package/dist/src/core/subagent.js.map +0 -1
- package/dist/src/core/subagent.test.js +0 -556
- package/dist/src/core/subagent.test.js.map +0 -1
- /package/dist/src/{core/subagent.test.d.ts → commands/extensions.test.d.ts} +0 -0
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import * as path from 'node:path';
|
|
7
|
+
import { fileURLToPath } from 'node:url';
|
|
8
|
+
import { Storage } from '../config/storage.js';
|
|
9
|
+
import { PolicyDecision, } from './types.js';
|
|
10
|
+
import { loadPoliciesFromToml } from './toml-loader.js';
|
|
11
|
+
import { MessageBusType, } from '../confirmation-bus/types.js';
|
|
12
|
+
import {} from '../confirmation-bus/message-bus.js';
|
|
13
|
+
import { coreEvents } from '../utils/events.js';
|
|
14
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
15
|
+
const __dirname = path.dirname(__filename);
|
|
16
|
+
export const DEFAULT_CORE_POLICIES_DIR = path.join(__dirname, 'policies');
|
|
17
|
+
// Policy tier constants for priority calculation
|
|
18
|
+
export const DEFAULT_POLICY_TIER = 1;
|
|
19
|
+
export const USER_POLICY_TIER = 2;
|
|
20
|
+
export const ADMIN_POLICY_TIER = 3;
|
|
21
|
+
/**
|
|
22
|
+
* Gets the list of directories to search for policy files, in order of increasing priority
|
|
23
|
+
* (Default -> User -> Admin).
|
|
24
|
+
*
|
|
25
|
+
* @param defaultPoliciesDir Optional path to a directory containing default policies.
|
|
26
|
+
*/
|
|
27
|
+
export function getPolicyDirectories(defaultPoliciesDir) {
|
|
28
|
+
const dirs = [];
|
|
29
|
+
if (defaultPoliciesDir) {
|
|
30
|
+
dirs.push(defaultPoliciesDir);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
dirs.push(DEFAULT_CORE_POLICIES_DIR);
|
|
34
|
+
}
|
|
35
|
+
dirs.push(Storage.getUserPoliciesDir());
|
|
36
|
+
dirs.push(Storage.getSystemPoliciesDir());
|
|
37
|
+
// Reverse so highest priority (Admin) is first for loading order if needed,
|
|
38
|
+
// though loadPoliciesFromToml might want them in a specific order.
|
|
39
|
+
// CLI implementation reversed them: [DEFAULT, USER, ADMIN].reverse() -> [ADMIN, USER, DEFAULT]
|
|
40
|
+
return dirs.reverse();
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Determines the policy tier (1=default, 2=user, 3=admin) for a given directory.
|
|
44
|
+
* This is used by the TOML loader to assign priority bands.
|
|
45
|
+
*/
|
|
46
|
+
export function getPolicyTier(dir, defaultPoliciesDir) {
|
|
47
|
+
const USER_POLICIES_DIR = Storage.getUserPoliciesDir();
|
|
48
|
+
const ADMIN_POLICIES_DIR = Storage.getSystemPoliciesDir();
|
|
49
|
+
const normalizedDir = path.resolve(dir);
|
|
50
|
+
const normalizedUser = path.resolve(USER_POLICIES_DIR);
|
|
51
|
+
const normalizedAdmin = path.resolve(ADMIN_POLICIES_DIR);
|
|
52
|
+
if (defaultPoliciesDir &&
|
|
53
|
+
normalizedDir === path.resolve(defaultPoliciesDir)) {
|
|
54
|
+
return DEFAULT_POLICY_TIER;
|
|
55
|
+
}
|
|
56
|
+
if (normalizedDir === path.resolve(DEFAULT_CORE_POLICIES_DIR)) {
|
|
57
|
+
return DEFAULT_POLICY_TIER;
|
|
58
|
+
}
|
|
59
|
+
if (normalizedDir === normalizedUser) {
|
|
60
|
+
return USER_POLICY_TIER;
|
|
61
|
+
}
|
|
62
|
+
if (normalizedDir === normalizedAdmin) {
|
|
63
|
+
return ADMIN_POLICY_TIER;
|
|
64
|
+
}
|
|
65
|
+
return DEFAULT_POLICY_TIER;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Formats a policy file error for console logging.
|
|
69
|
+
*/
|
|
70
|
+
export function formatPolicyError(error) {
|
|
71
|
+
const tierLabel = error.tier.toUpperCase();
|
|
72
|
+
let message = `[${tierLabel}] Policy file error in ${error.fileName}:\n`;
|
|
73
|
+
message += ` ${error.message}`;
|
|
74
|
+
if (error.details) {
|
|
75
|
+
message += `\n${error.details}`;
|
|
76
|
+
}
|
|
77
|
+
if (error.suggestion) {
|
|
78
|
+
message += `\n Suggestion: ${error.suggestion}`;
|
|
79
|
+
}
|
|
80
|
+
return message;
|
|
81
|
+
}
|
|
82
|
+
export async function createPolicyEngineConfig(settings, approvalMode, defaultPoliciesDir) {
|
|
83
|
+
const policyDirs = getPolicyDirectories(defaultPoliciesDir);
|
|
84
|
+
// Load policies from TOML files
|
|
85
|
+
const { rules: tomlRules, errors } = await loadPoliciesFromToml(approvalMode, policyDirs, (dir) => getPolicyTier(dir, defaultPoliciesDir));
|
|
86
|
+
// Emit any errors encountered during TOML loading to the UI
|
|
87
|
+
// coreEvents has a buffer that will display these once the UI is ready
|
|
88
|
+
if (errors.length > 0) {
|
|
89
|
+
for (const error of errors) {
|
|
90
|
+
coreEvents.emitFeedback('error', formatPolicyError(error));
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
const rules = [...tomlRules];
|
|
94
|
+
// Priority system for policy rules:
|
|
95
|
+
// - Higher priority numbers win over lower priority numbers
|
|
96
|
+
// - When multiple rules match, the highest priority rule is applied
|
|
97
|
+
// - Rules are evaluated in order of priority (highest first)
|
|
98
|
+
//
|
|
99
|
+
// Priority bands (tiers):
|
|
100
|
+
// - Default policies (TOML): 1 + priority/1000 (e.g., priority 100 → 1.100)
|
|
101
|
+
// - User policies (TOML): 2 + priority/1000 (e.g., priority 100 → 2.100)
|
|
102
|
+
// - Admin policies (TOML): 3 + priority/1000 (e.g., priority 100 → 3.100)
|
|
103
|
+
//
|
|
104
|
+
// This ensures Admin > User > Default hierarchy is always preserved,
|
|
105
|
+
// while allowing user-specified priorities to work within each tier.
|
|
106
|
+
//
|
|
107
|
+
// Settings-based and dynamic rules (all in user tier 2.x):
|
|
108
|
+
// 2.95: Tools that the user has selected as "Always Allow" in the interactive UI
|
|
109
|
+
// 2.9: MCP servers excluded list (security: persistent server blocks)
|
|
110
|
+
// 2.4: Command line flag --exclude-tools (explicit temporary blocks)
|
|
111
|
+
// 2.3: Command line flag --allowed-tools (explicit temporary allows)
|
|
112
|
+
// 2.2: MCP servers with trust=true (persistent trusted servers)
|
|
113
|
+
// 2.1: MCP servers allowed list (persistent general server allows)
|
|
114
|
+
//
|
|
115
|
+
// TOML policy priorities (before transformation):
|
|
116
|
+
// 10: Write tools default to ASK_USER (becomes 1.010 in default tier)
|
|
117
|
+
// 15: Auto-edit tool override (becomes 1.015 in default tier)
|
|
118
|
+
// 50: Read-only tools (becomes 1.050 in default tier)
|
|
119
|
+
// 999: YOLO mode allow-all (becomes 1.999 in default tier)
|
|
120
|
+
// MCP servers that are explicitly excluded in settings.mcp.excluded
|
|
121
|
+
// Priority: 2.9 (highest in user tier for security - persistent server blocks)
|
|
122
|
+
if (settings.mcp?.excluded) {
|
|
123
|
+
for (const serverName of settings.mcp.excluded) {
|
|
124
|
+
rules.push({
|
|
125
|
+
toolName: `${serverName}__*`,
|
|
126
|
+
decision: PolicyDecision.DENY,
|
|
127
|
+
priority: 2.9,
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
// Tools that are explicitly excluded in the settings.
|
|
132
|
+
// Priority: 2.4 (user tier - explicit temporary blocks)
|
|
133
|
+
if (settings.tools?.exclude) {
|
|
134
|
+
for (const tool of settings.tools.exclude) {
|
|
135
|
+
rules.push({
|
|
136
|
+
toolName: tool,
|
|
137
|
+
decision: PolicyDecision.DENY,
|
|
138
|
+
priority: 2.4,
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
// Tools that are explicitly allowed in the settings.
|
|
143
|
+
// Priority: 2.3 (user tier - explicit temporary allows)
|
|
144
|
+
if (settings.tools?.allowed) {
|
|
145
|
+
for (const tool of settings.tools.allowed) {
|
|
146
|
+
rules.push({
|
|
147
|
+
toolName: tool,
|
|
148
|
+
decision: PolicyDecision.ALLOW,
|
|
149
|
+
priority: 2.3,
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
// MCP servers that are trusted in the settings.
|
|
154
|
+
// Priority: 2.2 (user tier - persistent trusted servers)
|
|
155
|
+
if (settings.mcpServers) {
|
|
156
|
+
for (const [serverName, serverConfig] of Object.entries(settings.mcpServers)) {
|
|
157
|
+
if (serverConfig.trust) {
|
|
158
|
+
// Trust all tools from this MCP server
|
|
159
|
+
// Using pattern matching for MCP tool names which are formatted as "serverName__toolName"
|
|
160
|
+
rules.push({
|
|
161
|
+
toolName: `${serverName}__*`,
|
|
162
|
+
decision: PolicyDecision.ALLOW,
|
|
163
|
+
priority: 2.2,
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
// MCP servers that are explicitly allowed in settings.mcp.allowed
|
|
169
|
+
// Priority: 2.1 (user tier - persistent general server allows)
|
|
170
|
+
if (settings.mcp?.allowed) {
|
|
171
|
+
for (const serverName of settings.mcp.allowed) {
|
|
172
|
+
rules.push({
|
|
173
|
+
toolName: `${serverName}__*`,
|
|
174
|
+
decision: PolicyDecision.ALLOW,
|
|
175
|
+
priority: 2.1,
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
return {
|
|
180
|
+
rules,
|
|
181
|
+
defaultDecision: PolicyDecision.ASK_USER,
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
export function createPolicyUpdater(policyEngine, messageBus) {
|
|
185
|
+
messageBus.subscribe(MessageBusType.UPDATE_POLICY, (message) => {
|
|
186
|
+
const toolName = message.toolName;
|
|
187
|
+
policyEngine.addRule({
|
|
188
|
+
toolName,
|
|
189
|
+
decision: PolicyDecision.ALLOW,
|
|
190
|
+
// User tier (2) + high priority (950/1000) = 2.95
|
|
191
|
+
// This ensures user "always allow" selections are high priority
|
|
192
|
+
// but still lose to admin policies (3.xxx) and settings excludes (200)
|
|
193
|
+
priority: 2.95,
|
|
194
|
+
});
|
|
195
|
+
});
|
|
196
|
+
}
|
|
197
|
+
//# sourceMappingURL=config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/policy/config.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,404 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { describe, it, expect, vi, afterEach, beforeEach } from 'vitest';
|
|
7
|
+
import nodePath from 'node:path';
|
|
8
|
+
import { ApprovalMode, PolicyDecision } from './types.js';
|
|
9
|
+
import { Storage } from '../config/storage.js';
|
|
10
|
+
afterEach(() => {
|
|
11
|
+
vi.clearAllMocks();
|
|
12
|
+
vi.restoreAllMocks();
|
|
13
|
+
vi.doUnmock('node:fs/promises');
|
|
14
|
+
});
|
|
15
|
+
describe('createPolicyEngineConfig', () => {
|
|
16
|
+
beforeEach(() => {
|
|
17
|
+
// Mock Storage to avoid picking up real user/system policies from the host environment
|
|
18
|
+
vi.spyOn(Storage, 'getUserPoliciesDir').mockReturnValue('/non/existent/user/policies');
|
|
19
|
+
vi.spyOn(Storage, 'getSystemPoliciesDir').mockReturnValue('/non/existent/system/policies');
|
|
20
|
+
});
|
|
21
|
+
it('should return ASK_USER for write tools and ALLOW for read-only tools by default', async () => {
|
|
22
|
+
const actualFs = await vi.importActual('node:fs/promises');
|
|
23
|
+
const mockReaddir = vi.fn(async (path, options) => {
|
|
24
|
+
if (typeof path === 'string' &&
|
|
25
|
+
nodePath
|
|
26
|
+
.normalize(path)
|
|
27
|
+
.includes(nodePath.normalize('.cell-cli/policies'))) {
|
|
28
|
+
// Return empty array for user policies
|
|
29
|
+
return [];
|
|
30
|
+
}
|
|
31
|
+
return actualFs.readdir(path, options);
|
|
32
|
+
});
|
|
33
|
+
vi.doMock('node:fs/promises', () => ({
|
|
34
|
+
...actualFs,
|
|
35
|
+
default: { ...actualFs, readdir: mockReaddir },
|
|
36
|
+
readdir: mockReaddir,
|
|
37
|
+
}));
|
|
38
|
+
// Mock Storage to avoid actual filesystem access for policy dirs during tests if needed,
|
|
39
|
+
// but for now relying on the fs mock above might be enough if it catches the right paths.
|
|
40
|
+
// Let's see if we need to mock Storage.getUserPoliciesDir etc.
|
|
41
|
+
vi.resetModules();
|
|
42
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
43
|
+
const settings = {};
|
|
44
|
+
// Pass a dummy default policies dir to avoid it trying to resolve __dirname relative to the test file in a weird way
|
|
45
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
46
|
+
expect(config.defaultDecision).toBe(PolicyDecision.ASK_USER);
|
|
47
|
+
// The order of the rules is not guaranteed, so we sort them by tool name.
|
|
48
|
+
config.rules?.sort((a, b) => (a.toolName ?? '').localeCompare(b.toolName ?? ''));
|
|
49
|
+
// Since we are mocking an empty policy directory, we expect NO rules from TOML.
|
|
50
|
+
// Wait, the CLI test expected a bunch of default rules. Those must have come from
|
|
51
|
+
// the actual default policies directory in the CLI package.
|
|
52
|
+
// In the core package, we don't necessarily have those default policy files yet
|
|
53
|
+
// or we need to point to them.
|
|
54
|
+
// For this unit test, if we mock the default dir as empty, we should get NO rules
|
|
55
|
+
// if no settings are provided.
|
|
56
|
+
// Actually, let's look at how CLI test gets them. It uses `__dirname` in `policy.ts`.
|
|
57
|
+
// If we want to test default rules, we need to provide them.
|
|
58
|
+
// For now, let's assert it's empty if we provide no TOML files, to ensure the *mechanism* works.
|
|
59
|
+
// Or better, mock one default rule to ensure it's loaded.
|
|
60
|
+
expect(config.rules).toEqual([]);
|
|
61
|
+
vi.doUnmock('node:fs/promises');
|
|
62
|
+
});
|
|
63
|
+
it('should allow tools in tools.allowed', async () => {
|
|
64
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
65
|
+
const settings = {
|
|
66
|
+
tools: { allowed: ['run_shell_command'] },
|
|
67
|
+
};
|
|
68
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
69
|
+
const rule = config.rules?.find((r) => r.toolName === 'run_shell_command' &&
|
|
70
|
+
r.decision === PolicyDecision.ALLOW);
|
|
71
|
+
expect(rule).toBeDefined();
|
|
72
|
+
expect(rule?.priority).toBeCloseTo(2.3, 5); // Command line allow
|
|
73
|
+
});
|
|
74
|
+
it('should deny tools in tools.exclude', async () => {
|
|
75
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
76
|
+
const settings = {
|
|
77
|
+
tools: { exclude: ['run_shell_command'] },
|
|
78
|
+
};
|
|
79
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
80
|
+
const rule = config.rules?.find((r) => r.toolName === 'run_shell_command' &&
|
|
81
|
+
r.decision === PolicyDecision.DENY);
|
|
82
|
+
expect(rule).toBeDefined();
|
|
83
|
+
expect(rule?.priority).toBeCloseTo(2.4, 5); // Command line exclude
|
|
84
|
+
});
|
|
85
|
+
it('should allow tools from allowed MCP servers', async () => {
|
|
86
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
87
|
+
const settings = {
|
|
88
|
+
mcp: { allowed: ['my-server'] },
|
|
89
|
+
};
|
|
90
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
91
|
+
const rule = config.rules?.find((r) => r.toolName === 'my-server__*' && r.decision === PolicyDecision.ALLOW);
|
|
92
|
+
expect(rule).toBeDefined();
|
|
93
|
+
expect(rule?.priority).toBe(2.1); // MCP allowed server
|
|
94
|
+
});
|
|
95
|
+
it('should deny tools from excluded MCP servers', async () => {
|
|
96
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
97
|
+
const settings = {
|
|
98
|
+
mcp: { excluded: ['my-server'] },
|
|
99
|
+
};
|
|
100
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
101
|
+
const rule = config.rules?.find((r) => r.toolName === 'my-server__*' && r.decision === PolicyDecision.DENY);
|
|
102
|
+
expect(rule).toBeDefined();
|
|
103
|
+
expect(rule?.priority).toBe(2.9); // MCP excluded server
|
|
104
|
+
});
|
|
105
|
+
it('should allow tools from trusted MCP servers', async () => {
|
|
106
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
107
|
+
const settings = {
|
|
108
|
+
mcpServers: {
|
|
109
|
+
'trusted-server': {
|
|
110
|
+
trust: true,
|
|
111
|
+
},
|
|
112
|
+
'untrusted-server': {
|
|
113
|
+
trust: false,
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
};
|
|
117
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
118
|
+
const trustedRule = config.rules?.find((r) => r.toolName === 'trusted-server__*' &&
|
|
119
|
+
r.decision === PolicyDecision.ALLOW);
|
|
120
|
+
expect(trustedRule).toBeDefined();
|
|
121
|
+
expect(trustedRule?.priority).toBe(2.2); // MCP trusted server
|
|
122
|
+
// Untrusted server should not have an allow rule
|
|
123
|
+
const untrustedRule = config.rules?.find((r) => r.toolName === 'untrusted-server__*' &&
|
|
124
|
+
r.decision === PolicyDecision.ALLOW);
|
|
125
|
+
expect(untrustedRule).toBeUndefined();
|
|
126
|
+
});
|
|
127
|
+
it('should handle multiple MCP server configurations together', async () => {
|
|
128
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
129
|
+
const settings = {
|
|
130
|
+
mcp: {
|
|
131
|
+
allowed: ['allowed-server'],
|
|
132
|
+
excluded: ['excluded-server'],
|
|
133
|
+
},
|
|
134
|
+
mcpServers: {
|
|
135
|
+
'trusted-server': {
|
|
136
|
+
trust: true,
|
|
137
|
+
},
|
|
138
|
+
},
|
|
139
|
+
};
|
|
140
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
141
|
+
// Check allowed server
|
|
142
|
+
const allowedRule = config.rules?.find((r) => r.toolName === 'allowed-server__*' &&
|
|
143
|
+
r.decision === PolicyDecision.ALLOW);
|
|
144
|
+
expect(allowedRule).toBeDefined();
|
|
145
|
+
expect(allowedRule?.priority).toBe(2.1); // MCP allowed server
|
|
146
|
+
// Check trusted server
|
|
147
|
+
const trustedRule = config.rules?.find((r) => r.toolName === 'trusted-server__*' &&
|
|
148
|
+
r.decision === PolicyDecision.ALLOW);
|
|
149
|
+
expect(trustedRule).toBeDefined();
|
|
150
|
+
expect(trustedRule?.priority).toBe(2.2); // MCP trusted server
|
|
151
|
+
// Check excluded server
|
|
152
|
+
const excludedRule = config.rules?.find((r) => r.toolName === 'excluded-server__*' &&
|
|
153
|
+
r.decision === PolicyDecision.DENY);
|
|
154
|
+
expect(excludedRule).toBeDefined();
|
|
155
|
+
expect(excludedRule?.priority).toBe(2.9); // MCP excluded server
|
|
156
|
+
});
|
|
157
|
+
it('should allow all tools in YOLO mode', async () => {
|
|
158
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
159
|
+
const settings = {};
|
|
160
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.YOLO);
|
|
161
|
+
const rule = config.rules?.find((r) => r.decision === PolicyDecision.ALLOW && !r.toolName);
|
|
162
|
+
expect(rule).toBeDefined();
|
|
163
|
+
// Priority 999 in default tier → 1.999
|
|
164
|
+
expect(rule?.priority).toBeCloseTo(1.999, 5);
|
|
165
|
+
});
|
|
166
|
+
it('should allow edit tool in AUTO_EDIT mode', async () => {
|
|
167
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
168
|
+
const settings = {};
|
|
169
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.AUTO_EDIT);
|
|
170
|
+
const rule = config.rules?.find((r) => r.toolName === 'replace' && r.decision === PolicyDecision.ALLOW);
|
|
171
|
+
expect(rule).toBeDefined();
|
|
172
|
+
// Priority 15 in default tier → 1.015
|
|
173
|
+
expect(rule?.priority).toBeCloseTo(1.015, 5);
|
|
174
|
+
});
|
|
175
|
+
it('should prioritize exclude over allow', async () => {
|
|
176
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
177
|
+
const settings = {
|
|
178
|
+
tools: { allowed: ['run_shell_command'], exclude: ['run_shell_command'] },
|
|
179
|
+
};
|
|
180
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
181
|
+
const denyRule = config.rules?.find((r) => r.toolName === 'run_shell_command' &&
|
|
182
|
+
r.decision === PolicyDecision.DENY);
|
|
183
|
+
const allowRule = config.rules?.find((r) => r.toolName === 'run_shell_command' &&
|
|
184
|
+
r.decision === PolicyDecision.ALLOW);
|
|
185
|
+
expect(denyRule).toBeDefined();
|
|
186
|
+
expect(allowRule).toBeDefined();
|
|
187
|
+
expect(denyRule.priority).toBeGreaterThan(allowRule.priority);
|
|
188
|
+
});
|
|
189
|
+
it('should prioritize specific tool allows over MCP server excludes', async () => {
|
|
190
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
191
|
+
const settings = {
|
|
192
|
+
mcp: { excluded: ['my-server'] },
|
|
193
|
+
tools: { allowed: ['my-server__specific-tool'] },
|
|
194
|
+
};
|
|
195
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
196
|
+
const serverDenyRule = config.rules?.find((r) => r.toolName === 'my-server__*' && r.decision === PolicyDecision.DENY);
|
|
197
|
+
const toolAllowRule = config.rules?.find((r) => r.toolName === 'my-server__specific-tool' &&
|
|
198
|
+
r.decision === PolicyDecision.ALLOW);
|
|
199
|
+
expect(serverDenyRule).toBeDefined();
|
|
200
|
+
expect(serverDenyRule?.priority).toBe(2.9); // MCP excluded server
|
|
201
|
+
expect(toolAllowRule).toBeDefined();
|
|
202
|
+
expect(toolAllowRule?.priority).toBeCloseTo(2.3, 5); // Command line allow
|
|
203
|
+
// Server deny (2.9) has higher priority than tool allow (2.3),
|
|
204
|
+
// so server deny wins (this is expected behavior - server-level blocks are security critical)
|
|
205
|
+
});
|
|
206
|
+
it('should handle MCP server allows and tool excludes', async () => {
|
|
207
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
208
|
+
const settings = {
|
|
209
|
+
mcp: { allowed: ['my-server'] },
|
|
210
|
+
mcpServers: {
|
|
211
|
+
'my-server': {
|
|
212
|
+
trust: true,
|
|
213
|
+
},
|
|
214
|
+
},
|
|
215
|
+
tools: { exclude: ['my-server__dangerous-tool'] },
|
|
216
|
+
};
|
|
217
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
218
|
+
const serverAllowRule = config.rules?.find((r) => r.toolName === 'my-server__*' && r.decision === PolicyDecision.ALLOW);
|
|
219
|
+
const toolDenyRule = config.rules?.find((r) => r.toolName === 'my-server__dangerous-tool' &&
|
|
220
|
+
r.decision === PolicyDecision.DENY);
|
|
221
|
+
expect(serverAllowRule).toBeDefined();
|
|
222
|
+
expect(toolDenyRule).toBeDefined();
|
|
223
|
+
// Command line exclude (2.4) has higher priority than MCP server trust (2.2)
|
|
224
|
+
// This is the correct behavior - specific exclusions should beat general server trust
|
|
225
|
+
expect(toolDenyRule.priority).toBeGreaterThan(serverAllowRule.priority);
|
|
226
|
+
});
|
|
227
|
+
it('should handle complex priority scenarios correctly', async () => {
|
|
228
|
+
const settings = {
|
|
229
|
+
tools: {
|
|
230
|
+
allowed: ['my-server__tool1', 'other-tool'], // Priority 2.3
|
|
231
|
+
exclude: ['my-server__tool2', 'glob'], // Priority 2.4
|
|
232
|
+
},
|
|
233
|
+
mcp: {
|
|
234
|
+
allowed: ['allowed-server'], // Priority 2.1
|
|
235
|
+
excluded: ['excluded-server'], // Priority 2.9
|
|
236
|
+
},
|
|
237
|
+
mcpServers: {
|
|
238
|
+
'trusted-server': {
|
|
239
|
+
trust: true, // Priority 90 -> 2.2
|
|
240
|
+
},
|
|
241
|
+
},
|
|
242
|
+
};
|
|
243
|
+
// Mock a default policy for 'glob' to test priority override
|
|
244
|
+
const actualFs = await vi.importActual('node:fs/promises');
|
|
245
|
+
const mockReaddir = vi.fn(async (p, _o) => {
|
|
246
|
+
if (typeof p === 'string' && p.includes('/tmp/mock/default/policies')) {
|
|
247
|
+
return [
|
|
248
|
+
{
|
|
249
|
+
name: 'default.toml',
|
|
250
|
+
isFile: () => true,
|
|
251
|
+
isDirectory: () => false,
|
|
252
|
+
},
|
|
253
|
+
];
|
|
254
|
+
}
|
|
255
|
+
return [];
|
|
256
|
+
});
|
|
257
|
+
const mockReadFile = vi.fn(async (p, _o) => {
|
|
258
|
+
if (typeof p === 'string' && p.includes('default.toml')) {
|
|
259
|
+
return '[[rule]]\ntoolName = "glob"\ndecision = "allow"\npriority = 50\n';
|
|
260
|
+
}
|
|
261
|
+
return '';
|
|
262
|
+
});
|
|
263
|
+
vi.doMock('node:fs/promises', () => ({
|
|
264
|
+
...actualFs,
|
|
265
|
+
default: { ...actualFs, readdir: mockReaddir, readFile: mockReadFile },
|
|
266
|
+
readdir: mockReaddir,
|
|
267
|
+
readFile: mockReadFile,
|
|
268
|
+
}));
|
|
269
|
+
vi.resetModules();
|
|
270
|
+
const { createPolicyEngineConfig: createConfig } = await import('./config.js');
|
|
271
|
+
const config = await createConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
272
|
+
// Verify glob is denied even though default would allow it
|
|
273
|
+
const globDenyRule = config.rules?.find((r) => r.toolName === 'glob' && r.decision === PolicyDecision.DENY);
|
|
274
|
+
const globAllowRule = config.rules?.find((r) => r.toolName === 'glob' && r.decision === PolicyDecision.ALLOW);
|
|
275
|
+
expect(globDenyRule).toBeDefined();
|
|
276
|
+
expect(globAllowRule).toBeDefined();
|
|
277
|
+
// Deny from settings (user tier)
|
|
278
|
+
expect(globDenyRule.priority).toBeCloseTo(2.4, 5); // Command line exclude
|
|
279
|
+
// Allow from default TOML: 1 + 50/1000 = 1.05
|
|
280
|
+
expect(globAllowRule.priority).toBeCloseTo(1.05, 5);
|
|
281
|
+
// Verify all priority levels are correct
|
|
282
|
+
const priorities = config.rules
|
|
283
|
+
?.map((r) => ({
|
|
284
|
+
tool: r.toolName,
|
|
285
|
+
decision: r.decision,
|
|
286
|
+
priority: r.priority,
|
|
287
|
+
}))
|
|
288
|
+
.sort((a, b) => (b.priority ?? 0) - (a.priority ?? 0));
|
|
289
|
+
// Check that the highest priority items are the excludes (user tier: 2.4 and 2.9)
|
|
290
|
+
const highestPriorityExcludes = priorities?.filter((p) => Math.abs(p.priority - 2.4) < 0.01 ||
|
|
291
|
+
Math.abs(p.priority - 2.9) < 0.01);
|
|
292
|
+
expect(highestPriorityExcludes?.every((p) => p.decision === PolicyDecision.DENY)).toBe(true);
|
|
293
|
+
vi.doUnmock('node:fs/promises');
|
|
294
|
+
});
|
|
295
|
+
it('should handle MCP servers with undefined trust property', async () => {
|
|
296
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
297
|
+
const settings = {
|
|
298
|
+
mcpServers: {
|
|
299
|
+
'no-trust-property': {
|
|
300
|
+
// trust property is undefined/missing
|
|
301
|
+
},
|
|
302
|
+
'explicit-false': {
|
|
303
|
+
trust: false,
|
|
304
|
+
},
|
|
305
|
+
},
|
|
306
|
+
};
|
|
307
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
308
|
+
// Neither server should have an allow rule
|
|
309
|
+
const noTrustRule = config.rules?.find((r) => r.toolName === 'no-trust-property__*' &&
|
|
310
|
+
r.decision === PolicyDecision.ALLOW);
|
|
311
|
+
const explicitFalseRule = config.rules?.find((r) => r.toolName === 'explicit-false__*' &&
|
|
312
|
+
r.decision === PolicyDecision.ALLOW);
|
|
313
|
+
expect(noTrustRule).toBeUndefined();
|
|
314
|
+
expect(explicitFalseRule).toBeUndefined();
|
|
315
|
+
});
|
|
316
|
+
it('should have YOLO allow-all rule beat write tool rules in YOLO mode', async () => {
|
|
317
|
+
vi.resetModules();
|
|
318
|
+
vi.doUnmock('node:fs/promises');
|
|
319
|
+
const { createPolicyEngineConfig: createConfig } = await import('./config.js');
|
|
320
|
+
// Re-mock Storage after resetModules because it was reloaded
|
|
321
|
+
const { Storage: FreshStorage } = await import('../config/storage.js');
|
|
322
|
+
vi.spyOn(FreshStorage, 'getUserPoliciesDir').mockReturnValue('/non/existent/user/policies');
|
|
323
|
+
vi.spyOn(FreshStorage, 'getSystemPoliciesDir').mockReturnValue('/non/existent/system/policies');
|
|
324
|
+
const settings = {
|
|
325
|
+
tools: { exclude: ['dangerous-tool'] },
|
|
326
|
+
};
|
|
327
|
+
// Use default policy dir (no third arg) to load real yolo.toml and write.toml
|
|
328
|
+
const config = await createConfig(settings, ApprovalMode.YOLO);
|
|
329
|
+
// Should have the wildcard allow rule
|
|
330
|
+
const wildcardRule = config.rules?.find((r) => !r.toolName && r.decision === PolicyDecision.ALLOW);
|
|
331
|
+
expect(wildcardRule).toBeDefined();
|
|
332
|
+
// Priority 999 in default tier → 1.999
|
|
333
|
+
expect(wildcardRule?.priority).toBeCloseTo(1.999, 5);
|
|
334
|
+
// Write tool ASK_USER rules are present (from write.toml)
|
|
335
|
+
const writeToolRules = config.rules?.filter((r) => ['run_shell_command'].includes(r.toolName || '') &&
|
|
336
|
+
r.decision === PolicyDecision.ASK_USER);
|
|
337
|
+
expect(writeToolRules).toBeDefined();
|
|
338
|
+
expect(writeToolRules?.length).toBeGreaterThan(0);
|
|
339
|
+
// But YOLO allow-all rule has higher priority than all write tool rules
|
|
340
|
+
writeToolRules?.forEach((writeRule) => {
|
|
341
|
+
expect(wildcardRule.priority).toBeGreaterThan(writeRule.priority);
|
|
342
|
+
});
|
|
343
|
+
// Should still have the exclude rule (from settings, user tier)
|
|
344
|
+
const excludeRule = config.rules?.find((r) => r.toolName === 'dangerous-tool' && r.decision === PolicyDecision.DENY);
|
|
345
|
+
expect(excludeRule).toBeDefined();
|
|
346
|
+
expect(excludeRule?.priority).toBeCloseTo(2.4, 5); // Command line exclude
|
|
347
|
+
});
|
|
348
|
+
it('should support argsPattern in policy rules', async () => {
|
|
349
|
+
const actualFs = await vi.importActual('node:fs/promises');
|
|
350
|
+
const mockReaddir = vi.fn(async (path, options) => {
|
|
351
|
+
if (typeof path === 'string' &&
|
|
352
|
+
nodePath
|
|
353
|
+
.normalize(path)
|
|
354
|
+
.includes(nodePath.normalize('.cell-cli/policies'))) {
|
|
355
|
+
return [
|
|
356
|
+
{
|
|
357
|
+
name: 'write.toml',
|
|
358
|
+
isFile: () => true,
|
|
359
|
+
isDirectory: () => false,
|
|
360
|
+
},
|
|
361
|
+
];
|
|
362
|
+
}
|
|
363
|
+
return actualFs.readdir(path, options);
|
|
364
|
+
});
|
|
365
|
+
const mockReadFile = vi.fn(async (path, options) => {
|
|
366
|
+
if (typeof path === 'string' &&
|
|
367
|
+
nodePath
|
|
368
|
+
.normalize(path)
|
|
369
|
+
.includes(nodePath.normalize('.cell-cli/policies/write.toml'))) {
|
|
370
|
+
return `
|
|
371
|
+
[[rule]]
|
|
372
|
+
toolName = "run_shell_command"
|
|
373
|
+
argsPattern = "\\"command\\":\\"git (status|diff|log)\\""
|
|
374
|
+
decision = "allow"
|
|
375
|
+
priority = 150
|
|
376
|
+
`;
|
|
377
|
+
}
|
|
378
|
+
return actualFs.readFile(path, options);
|
|
379
|
+
});
|
|
380
|
+
vi.doMock('node:fs/promises', () => ({
|
|
381
|
+
...actualFs,
|
|
382
|
+
default: { ...actualFs, readFile: mockReadFile, readdir: mockReaddir },
|
|
383
|
+
readFile: mockReadFile,
|
|
384
|
+
readdir: mockReaddir,
|
|
385
|
+
}));
|
|
386
|
+
vi.resetModules();
|
|
387
|
+
const { createPolicyEngineConfig } = await import('./config.js');
|
|
388
|
+
const settings = {};
|
|
389
|
+
const config = await createPolicyEngineConfig(settings, ApprovalMode.DEFAULT, '/tmp/mock/default/policies');
|
|
390
|
+
const rule = config.rules?.find((r) => r.toolName === 'run_shell_command' &&
|
|
391
|
+
r.decision === PolicyDecision.ALLOW);
|
|
392
|
+
expect(rule).toBeDefined();
|
|
393
|
+
// Priority 150 in user tier → 2.150
|
|
394
|
+
expect(rule?.priority).toBeCloseTo(2.15, 5);
|
|
395
|
+
expect(rule?.argsPattern).toBeInstanceOf(RegExp);
|
|
396
|
+
expect(rule?.argsPattern?.test('{"command":"git status"}')).toBe(true);
|
|
397
|
+
expect(rule?.argsPattern?.test('{"command":"git diff"}')).toBe(true);
|
|
398
|
+
expect(rule?.argsPattern?.test('{"command":"git log"}')).toBe(true);
|
|
399
|
+
expect(rule?.argsPattern?.test('{"command":"git commit"}')).toBe(false);
|
|
400
|
+
expect(rule?.argsPattern?.test('{"command":"git push"}')).toBe(false);
|
|
401
|
+
vi.doUnmock('node:fs/promises');
|
|
402
|
+
});
|
|
403
|
+
});
|
|
404
|
+
//# sourceMappingURL=config.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.test.js","sourceRoot":"","sources":["../../../src/policy/config.test.ts"],"names":[],"mappings":"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"}
|