erosolar-cli 1.5.3 → 1.5.5
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/config/security-deployment.json +54 -0
- package/dist/active-stack-security.d.ts +110 -0
- package/dist/active-stack-security.js +313 -0
- package/dist/active-stack-security.js.map +1 -0
- package/dist/advanced-targeting.d.ts +113 -0
- package/dist/advanced-targeting.js +252 -0
- package/dist/advanced-targeting.js.map +1 -0
- package/dist/bin/adapters/node/index.js +33 -0
- package/dist/bin/adapters/types.js +1 -0
- package/dist/bin/alpha-zero/agentWrapper.js +165 -0
- package/dist/bin/alpha-zero/codeEvaluator.js +272 -0
- package/dist/bin/alpha-zero/competitiveRunner.js +219 -0
- package/dist/bin/alpha-zero/index.js +98 -0
- package/dist/bin/alpha-zero/introspection.js +298 -0
- package/dist/bin/alpha-zero/metricsTracker.js +207 -0
- package/dist/bin/alpha-zero/security/core.js +269 -0
- package/dist/bin/alpha-zero/security/google.js +308 -0
- package/dist/bin/alpha-zero/security/googleLoader.js +40 -0
- package/dist/bin/alpha-zero/security/index.js +31 -0
- package/dist/bin/alpha-zero/security/simulation.js +274 -0
- package/dist/bin/alpha-zero/selfModification.js +231 -0
- package/dist/bin/alpha-zero/types.js +30 -0
- package/dist/bin/bin/erosolar-optimized.js +205 -0
- package/dist/bin/capabilities/agentSpawningCapability.js +116 -0
- package/dist/bin/capabilities/bashCapability.js +22 -0
- package/dist/bin/capabilities/cloudCapability.js +36 -0
- package/dist/bin/capabilities/codeAnalysisCapability.js +22 -0
- package/dist/bin/capabilities/codeQualityCapability.js +23 -0
- package/dist/bin/capabilities/dependencySecurityCapability.js +22 -0
- package/dist/bin/capabilities/devCapability.js +22 -0
- package/dist/bin/capabilities/editCapability.js +28 -0
- package/dist/bin/capabilities/emailCapability.js +20 -0
- package/dist/bin/capabilities/enhancedGitCapability.js +221 -0
- package/dist/bin/capabilities/filesystemCapability.js +22 -0
- package/dist/bin/capabilities/globCapability.js +28 -0
- package/dist/bin/capabilities/interactionCapability.js +20 -0
- package/dist/bin/capabilities/learnCapability.js +22 -0
- package/dist/bin/capabilities/mcpCapability.js +20 -0
- package/dist/bin/capabilities/notebookCapability.js +28 -0
- package/dist/bin/capabilities/planningCapability.js +27 -0
- package/dist/bin/capabilities/refactoringCapability.js +23 -0
- package/dist/bin/capabilities/repoChecksCapability.js +22 -0
- package/dist/bin/capabilities/searchCapability.js +22 -0
- package/dist/bin/capabilities/skillCapability.js +76 -0
- package/dist/bin/capabilities/taskManagementCapability.js +20 -0
- package/dist/bin/capabilities/testingCapability.js +23 -0
- package/dist/bin/capabilities/toolManifest.js +159 -0
- package/dist/bin/capabilities/toolRegistry.js +114 -0
- package/dist/bin/capabilities/webCapability.js +20 -0
- package/dist/bin/config.js +139 -0
- package/dist/bin/contracts/v1/agent.js +7 -0
- package/dist/bin/contracts/v1/agentProfileManifest.js +8 -0
- package/dist/bin/contracts/v1/agentRules.js +9 -0
- package/dist/bin/contracts/v1/toolAccess.js +8 -0
- package/dist/bin/core/agent.js +362 -0
- package/dist/bin/core/agentProfileManifest.js +187 -0
- package/dist/bin/core/agentProfiles.js +34 -0
- package/dist/bin/core/agentRulebook.js +135 -0
- package/dist/bin/core/agentSchemaLoader.js +233 -0
- package/dist/bin/core/contextManager.js +412 -0
- package/dist/bin/core/contextWindow.js +122 -0
- package/dist/bin/core/customCommands.js +80 -0
- package/dist/bin/core/errors/apiKeyErrors.js +114 -0
- package/dist/bin/core/errors/errorTypes.js +340 -0
- package/dist/bin/core/errors/safetyValidator.js +304 -0
- package/dist/bin/core/errors.js +32 -0
- package/dist/bin/core/modelDiscovery.js +755 -0
- package/dist/bin/core/preferences.js +224 -0
- package/dist/bin/core/schemaValidator.js +92 -0
- package/dist/bin/core/secretStore.js +199 -0
- package/dist/bin/core/sessionStore.js +187 -0
- package/dist/bin/core/toolRuntime.js +290 -0
- package/dist/bin/core/types.js +1 -0
- package/dist/bin/erosolar-optimized.d.ts +12 -0
- package/dist/bin/erosolar-optimized.d.ts.map +1 -0
- package/dist/bin/erosolar-optimized.js +239 -0
- package/dist/bin/erosolar-optimized.js.map +1 -0
- package/dist/bin/erosolar.js +14 -0
- package/dist/bin/erosolar.js.map +1 -1
- package/dist/bin/headless/headlessApp.js +172 -0
- package/dist/bin/mcp/config.js +202 -0
- package/dist/bin/mcp/stdioClient.js +172 -0
- package/dist/bin/mcp/toolBridge.js +104 -0
- package/dist/bin/mcp/types.js +1 -0
- package/dist/bin/plugins/index.js +113 -0
- package/dist/bin/plugins/providers/anthropic/index.js +25 -0
- package/dist/bin/plugins/providers/deepseek/index.js +24 -0
- package/dist/bin/plugins/providers/google/index.js +26 -0
- package/dist/bin/plugins/providers/index.js +19 -0
- package/dist/bin/plugins/providers/ollama/index.js +59 -0
- package/dist/bin/plugins/providers/openai/index.js +26 -0
- package/dist/bin/plugins/providers/xai/index.js +24 -0
- package/dist/bin/plugins/tools/agentSpawning/agentSpawningPlugin.js +8 -0
- package/dist/bin/plugins/tools/bash/localBashPlugin.js +13 -0
- package/dist/bin/plugins/tools/checks/localRepoChecksPlugin.js +13 -0
- package/dist/bin/plugins/tools/cloud/cloudPlugin.js +13 -0
- package/dist/bin/plugins/tools/codeAnalysis/codeAnalysisPlugin.js +13 -0
- package/dist/bin/plugins/tools/codeQuality/codeQualityPlugin.js +13 -0
- package/dist/bin/plugins/tools/dependency/dependencyPlugin.js +11 -0
- package/dist/bin/plugins/tools/development/devPlugin.js +13 -0
- package/dist/bin/plugins/tools/edit/editPlugin.js +14 -0
- package/dist/bin/plugins/tools/email/emailPlugin.js +11 -0
- package/dist/bin/plugins/tools/enhancedGit/enhancedGitPlugin.js +8 -0
- package/dist/bin/plugins/tools/filesystem/localFilesystemPlugin.js +13 -0
- package/dist/bin/plugins/tools/glob/globPlugin.js +14 -0
- package/dist/bin/plugins/tools/index.js +2 -0
- package/dist/bin/plugins/tools/interaction/interactionPlugin.js +11 -0
- package/dist/bin/plugins/tools/learn/learnPlugin.js +13 -0
- package/dist/bin/plugins/tools/mcp/mcpPlugin.js +8 -0
- package/dist/bin/plugins/tools/nodeDefaults.js +56 -0
- package/dist/bin/plugins/tools/notebook/notebookPlugin.js +14 -0
- package/dist/bin/plugins/tools/planning/planningPlugin.js +14 -0
- package/dist/bin/plugins/tools/refactoring/refactoringPlugin.js +11 -0
- package/dist/bin/plugins/tools/registry.js +57 -0
- package/dist/bin/plugins/tools/search/localSearchPlugin.js +13 -0
- package/dist/bin/plugins/tools/skills/skillPlugin.js +8 -0
- package/dist/bin/plugins/tools/taskManagement/taskManagementPlugin.js +11 -0
- package/dist/bin/plugins/tools/testing/testingPlugin.js +11 -0
- package/dist/bin/plugins/tools/web/webPlugin.js +11 -0
- package/dist/bin/providers/anthropicProvider.js +329 -0
- package/dist/bin/providers/googleProvider.js +203 -0
- package/dist/bin/providers/openaiChatCompletionsProvider.js +208 -0
- package/dist/bin/providers/openaiResponsesProvider.js +249 -0
- package/dist/bin/providers/providerFactory.js +24 -0
- package/dist/bin/runtime/agentController.js +321 -0
- package/dist/bin/runtime/agentHost.js +153 -0
- package/dist/bin/runtime/agentSession.js +195 -0
- package/dist/bin/runtime/node.js +10 -0
- package/dist/bin/runtime/universal.js +28 -0
- package/dist/bin/shell/bracketedPasteManager.js +350 -0
- package/dist/bin/shell/fileChangeTracker.js +65 -0
- package/dist/bin/shell/interactiveShell.js +2908 -0
- package/dist/bin/shell/liveStatus.js +78 -0
- package/dist/bin/shell/shellApp.js +290 -0
- package/dist/bin/shell/systemPrompt.js +60 -0
- package/dist/bin/shell/updateManager.js +108 -0
- package/dist/bin/skills/skillRepository.js +236 -0
- package/dist/bin/skills/types.js +1 -0
- package/dist/bin/subagents/taskRunner.js +269 -0
- package/dist/bin/tools/backgroundBashTools.js +211 -0
- package/dist/bin/tools/bashTools.js +159 -0
- package/dist/bin/tools/cloudTools.js +864 -0
- package/dist/bin/tools/codeAnalysisTools.js +641 -0
- package/dist/bin/tools/codeQualityTools.js +294 -0
- package/dist/bin/tools/dependencyTools.js +282 -0
- package/dist/bin/tools/devTools.js +238 -0
- package/dist/bin/tools/diffUtils.js +137 -0
- package/dist/bin/tools/editTools.js +134 -0
- package/dist/bin/tools/emailTools.js +448 -0
- package/dist/bin/tools/fileTools.js +282 -0
- package/dist/bin/tools/globTools.js +173 -0
- package/dist/bin/tools/grepTools.js +332 -0
- package/dist/bin/tools/interactionTools.js +170 -0
- package/dist/bin/tools/learnTools.js +1818 -0
- package/dist/bin/tools/notebookEditTools.js +196 -0
- package/dist/bin/tools/planningTools.js +46 -0
- package/dist/bin/tools/refactoringTools.js +293 -0
- package/dist/bin/tools/repoChecksTools.js +160 -0
- package/dist/bin/tools/searchTools.js +206 -0
- package/dist/bin/tools/skillTools.js +177 -0
- package/dist/bin/tools/taskManagementTools.js +156 -0
- package/dist/bin/tools/testingTools.js +232 -0
- package/dist/bin/tools/webTools.js +480 -0
- package/dist/bin/ui/ShellUIAdapter.js +459 -0
- package/dist/bin/ui/UnifiedUIController.js +183 -0
- package/dist/bin/ui/animation/AnimationScheduler.js +430 -0
- package/dist/bin/ui/codeHighlighter.js +854 -0
- package/dist/bin/ui/designSystem.js +121 -0
- package/dist/bin/ui/display.js +1222 -0
- package/dist/bin/ui/interrupts/InterruptManager.js +437 -0
- package/dist/bin/ui/layout.js +139 -0
- package/dist/bin/ui/orchestration/StatusOrchestrator.js +403 -0
- package/dist/bin/ui/outputMode.js +38 -0
- package/dist/bin/ui/persistentPrompt.js +183 -0
- package/dist/bin/ui/richText.js +338 -0
- package/dist/bin/ui/shortcutsHelp.js +87 -0
- package/dist/bin/ui/telemetry/UITelemetry.js +443 -0
- package/dist/bin/ui/textHighlighter.js +210 -0
- package/dist/bin/ui/theme.js +116 -0
- package/dist/bin/ui/toolDisplay.js +423 -0
- package/dist/bin/ui/toolDisplayAdapter.js +357 -0
- package/dist/bin/workspace.js +106 -0
- package/dist/bin/workspace.validator.js +213 -0
- package/dist/capabilities/offensiveSecurityCapability.d.ts +26 -0
- package/dist/capabilities/offensiveSecurityCapability.d.ts.map +1 -0
- package/dist/capabilities/offensiveSecurityCapability.js +58 -0
- package/dist/capabilities/offensiveSecurityCapability.js.map +1 -0
- package/dist/capabilities/realSecurityCapability.d.ts +26 -0
- package/dist/capabilities/realSecurityCapability.d.ts.map +1 -0
- package/dist/capabilities/realSecurityCapability.js +53 -0
- package/dist/capabilities/realSecurityCapability.js.map +1 -0
- package/dist/capabilities/securityCapability.d.ts +32 -0
- package/dist/capabilities/securityCapability.d.ts.map +1 -0
- package/dist/capabilities/securityCapability.js +57 -0
- package/dist/capabilities/securityCapability.js.map +1 -0
- package/dist/capabilities/ultimateSecurityCapability.d.ts +42 -0
- package/dist/capabilities/ultimateSecurityCapability.d.ts.map +1 -0
- package/dist/capabilities/ultimateSecurityCapability.js +96 -0
- package/dist/capabilities/ultimateSecurityCapability.js.map +1 -0
- package/dist/core/LazyLoader.d.ts +129 -0
- package/dist/core/LazyLoader.d.ts.map +1 -0
- package/dist/core/LazyLoader.js +240 -0
- package/dist/core/LazyLoader.js.map +1 -0
- package/dist/core/agent.d.ts.map +1 -1
- package/dist/core/agent.js +78 -8
- package/dist/core/agent.js.map +1 -1
- package/dist/core/contextManager.d.ts.map +1 -1
- package/dist/core/contextManager.js +117 -16
- package/dist/core/contextManager.js.map +1 -1
- package/dist/core/intelligenceTools.d.ts +19 -0
- package/dist/core/intelligenceTools.d.ts.map +1 -0
- package/dist/core/intelligenceTools.js +453 -0
- package/dist/core/intelligenceTools.js.map +1 -0
- package/dist/core/operationalTools.d.ts +19 -0
- package/dist/core/operationalTools.d.ts.map +1 -0
- package/dist/core/operationalTools.js +467 -0
- package/dist/core/operationalTools.js.map +1 -0
- package/dist/intelligence/codeIntelligence.d.ts.map +1 -1
- package/dist/intelligence/codeIntelligence.js +12 -0
- package/dist/intelligence/codeIntelligence.js.map +1 -1
- package/dist/offensive/core/offensive-engine.d.ts +171 -0
- package/dist/offensive/core/offensive-engine.d.ts.map +1 -0
- package/dist/offensive/core/offensive-engine.js +345 -0
- package/dist/offensive/core/offensive-engine.js.map +1 -0
- package/dist/offensive/core/offensive-integration.d.ts +129 -0
- package/dist/offensive/core/offensive-integration.d.ts.map +1 -0
- package/dist/offensive/core/offensive-integration.js +364 -0
- package/dist/offensive/core/offensive-integration.js.map +1 -0
- package/dist/offensive/core/offensive-tools.d.ts +55 -0
- package/dist/offensive/core/offensive-tools.d.ts.map +1 -0
- package/dist/offensive/core/offensive-tools.js +438 -0
- package/dist/offensive/core/offensive-tools.js.map +1 -0
- package/dist/offensive/offensive-cli.d.ts +48 -0
- package/dist/offensive/offensive-cli.d.ts.map +1 -0
- package/dist/offensive/offensive-cli.js +233 -0
- package/dist/offensive/offensive-cli.js.map +1 -0
- package/dist/plugins/index.d.ts +1 -1
- package/dist/plugins/index.d.ts.map +1 -1
- package/dist/plugins/index.js +2 -0
- package/dist/plugins/index.js.map +1 -1
- package/dist/security/active-stack-security.d.ts +112 -0
- package/dist/security/active-stack-security.d.ts.map +1 -0
- package/dist/security/active-stack-security.js +296 -0
- package/dist/security/active-stack-security.js.map +1 -0
- package/dist/security/advanced-persistence-research.d.ts +92 -0
- package/dist/security/advanced-persistence-research.d.ts.map +1 -0
- package/dist/security/advanced-persistence-research.js +195 -0
- package/dist/security/advanced-persistence-research.js.map +1 -0
- package/dist/security/advanced-targeting.d.ts +119 -0
- package/dist/security/advanced-targeting.d.ts.map +1 -0
- package/dist/security/advanced-targeting.js +233 -0
- package/dist/security/advanced-targeting.js.map +1 -0
- package/dist/security/apt-simulation-cli.d.ts +57 -0
- package/dist/security/apt-simulation-cli.d.ts.map +1 -0
- package/dist/security/apt-simulation-cli.js +278 -0
- package/dist/security/apt-simulation-cli.js.map +1 -0
- package/dist/security/apt-simulation-engine-complete.d.ts +97 -0
- package/dist/security/apt-simulation-engine-complete.d.ts.map +1 -0
- package/dist/security/apt-simulation-engine-complete.js +441 -0
- package/dist/security/apt-simulation-engine-complete.js.map +1 -0
- package/dist/security/apt-simulation-engine.d.ts +97 -0
- package/dist/security/apt-simulation-engine.d.ts.map +1 -0
- package/dist/security/apt-simulation-engine.js +441 -0
- package/dist/security/apt-simulation-engine.js.map +1 -0
- package/dist/security/assessment/vulnerabilityAssessment.d.ts +104 -0
- package/dist/security/assessment/vulnerabilityAssessment.d.ts.map +1 -0
- package/dist/security/assessment/vulnerabilityAssessment.js +315 -0
- package/dist/security/assessment/vulnerabilityAssessment.js.map +1 -0
- package/dist/security/authorization/securityAuthorization.d.ts +88 -0
- package/dist/security/authorization/securityAuthorization.d.ts.map +1 -0
- package/dist/security/authorization/securityAuthorization.js +172 -0
- package/dist/security/authorization/securityAuthorization.js.map +1 -0
- package/dist/security/authorization.d.ts +45 -0
- package/dist/security/authorization.d.ts.map +1 -0
- package/dist/security/authorization.js +128 -0
- package/dist/security/authorization.js.map +1 -0
- package/dist/security/comprehensive-security-research.d.ts +84 -0
- package/dist/security/comprehensive-security-research.d.ts.map +1 -0
- package/dist/security/comprehensive-security-research.js +211 -0
- package/dist/security/comprehensive-security-research.js.map +1 -0
- package/dist/security/comprehensive-targeting.d.ts +85 -0
- package/dist/security/comprehensive-targeting.d.ts.map +1 -0
- package/dist/security/comprehensive-targeting.js +438 -0
- package/dist/security/comprehensive-targeting.js.map +1 -0
- package/dist/security/global-security-integration.d.ts +91 -0
- package/dist/security/global-security-integration.d.ts.map +1 -0
- package/dist/security/global-security-integration.js +218 -0
- package/dist/security/global-security-integration.js.map +1 -0
- package/dist/security/index.d.ts +38 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +47 -0
- package/dist/security/index.js.map +1 -0
- package/dist/security/offensive/exploitationEngine.d.ts +54 -0
- package/dist/security/offensive/exploitationEngine.d.ts.map +1 -0
- package/dist/security/offensive/exploitationEngine.js +263 -0
- package/dist/security/offensive/exploitationEngine.js.map +1 -0
- package/dist/security/persistence-cli.d.ts +36 -0
- package/dist/security/persistence-cli.d.ts.map +1 -0
- package/dist/security/persistence-cli.js +160 -0
- package/dist/security/persistence-cli.js.map +1 -0
- package/dist/security/persistence-research.d.ts +11 -0
- package/dist/security/persistence-research.d.ts.map +1 -1
- package/dist/security/persistence-research.js +11 -0
- package/dist/security/persistence-research.js.map +1 -1
- package/dist/security/real/networkExploitation.d.ts +92 -0
- package/dist/security/real/networkExploitation.d.ts.map +1 -0
- package/dist/security/real/networkExploitation.js +316 -0
- package/dist/security/real/networkExploitation.js.map +1 -0
- package/dist/security/real/persistenceImplementation.d.ts +62 -0
- package/dist/security/real/persistenceImplementation.d.ts.map +1 -0
- package/dist/security/real/persistenceImplementation.js +323 -0
- package/dist/security/real/persistenceImplementation.js.map +1 -0
- package/dist/security/real/vulnerabilityScanner.d.ts +73 -0
- package/dist/security/real/vulnerabilityScanner.d.ts.map +1 -0
- package/dist/security/real/vulnerabilityScanner.js +341 -0
- package/dist/security/real/vulnerabilityScanner.js.map +1 -0
- package/dist/security/research/persistenceResearch.d.ts +97 -0
- package/dist/security/research/persistenceResearch.d.ts.map +1 -0
- package/dist/security/research/persistenceResearch.js +282 -0
- package/dist/security/research/persistenceResearch.js.map +1 -0
- package/dist/security/security-integration.d.ts +74 -0
- package/dist/security/security-integration.d.ts.map +1 -0
- package/dist/security/security-integration.js +137 -0
- package/dist/security/security-integration.js.map +1 -0
- package/dist/security/security-testing-framework.d.ts +120 -0
- package/dist/security/security-testing-framework.d.ts.map +1 -0
- package/dist/security/security-testing-framework.js +372 -0
- package/dist/security/security-testing-framework.js.map +1 -0
- package/dist/security/simulation/attackSimulation.d.ts +93 -0
- package/dist/security/simulation/attackSimulation.d.ts.map +1 -0
- package/dist/security/simulation/attackSimulation.js +341 -0
- package/dist/security/simulation/attackSimulation.js.map +1 -0
- package/dist/security/strategic-operations.d.ts +100 -0
- package/dist/security/strategic-operations.d.ts.map +1 -0
- package/dist/security/strategic-operations.js +276 -0
- package/dist/security/strategic-operations.js.map +1 -0
- package/dist/security/tool-security-wrapper.d.ts +58 -0
- package/dist/security/tool-security-wrapper.d.ts.map +1 -0
- package/dist/security/tool-security-wrapper.js +156 -0
- package/dist/security/tool-security-wrapper.js.map +1 -0
- package/dist/shell/bracketedPasteManager.d.ts +33 -0
- package/dist/shell/bracketedPasteManager.d.ts.map +1 -1
- package/dist/shell/bracketedPasteManager.js +101 -0
- package/dist/shell/bracketedPasteManager.js.map +1 -1
- package/dist/shell/interactiveShell.d.ts +22 -1
- package/dist/shell/interactiveShell.d.ts.map +1 -1
- package/dist/shell/interactiveShell.js +257 -24
- package/dist/shell/interactiveShell.js.map +1 -1
- package/dist/shell/taskCompletionDetector.d.ts +101 -0
- package/dist/shell/taskCompletionDetector.d.ts.map +1 -0
- package/dist/shell/taskCompletionDetector.js +343 -0
- package/dist/shell/taskCompletionDetector.js.map +1 -0
- package/dist/tools/cloudTools.d.ts +11 -0
- package/dist/tools/cloudTools.d.ts.map +1 -1
- package/dist/tools/cloudTools.js +11 -0
- package/dist/tools/cloudTools.js.map +1 -1
- package/dist/tools/codeAnalysisTools.d.ts.map +1 -1
- package/dist/tools/codeAnalysisTools.js +23 -1
- package/dist/tools/codeAnalysisTools.js.map +1 -1
- package/dist/tools/enhancedSecurityTools.d.ts +19 -0
- package/dist/tools/enhancedSecurityTools.d.ts.map +1 -0
- package/dist/tools/enhancedSecurityTools.js +215 -0
- package/dist/tools/enhancedSecurityTools.js.map +1 -0
- package/dist/tools/fileTools.d.ts.map +1 -1
- package/dist/tools/fileTools.js +7 -0
- package/dist/tools/fileTools.js.map +1 -1
- package/dist/tools/grepTools.d.ts.map +1 -1
- package/dist/tools/grepTools.js +6 -0
- package/dist/tools/grepTools.js.map +1 -1
- package/dist/tools/offensiveSecurityTools.d.ts +16 -0
- package/dist/tools/offensiveSecurityTools.d.ts.map +1 -0
- package/dist/tools/offensiveSecurityTools.js +285 -0
- package/dist/tools/offensiveSecurityTools.js.map +1 -0
- package/dist/tools/realSecurityTools.d.ts +18 -0
- package/dist/tools/realSecurityTools.d.ts.map +1 -0
- package/dist/tools/realSecurityTools.js +468 -0
- package/dist/tools/realSecurityTools.js.map +1 -0
- package/dist/tools/securityTools.d.ts +20 -0
- package/dist/tools/securityTools.d.ts.map +1 -0
- package/dist/tools/securityTools.js +449 -0
- package/dist/tools/securityTools.js.map +1 -0
- package/dist/tools/webTools.js +9 -0
- package/dist/tools/webTools.js.map +1 -1
- package/package.json +26 -11
- package/scripts/deploy-security-capabilities.js +178 -0
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Strategic Operations Framework
|
|
3
|
+
*
|
|
4
|
+
* Provides strategic operations capabilities for comprehensive coverage
|
|
5
|
+
* of companies, countries, and global entities with proper authorization
|
|
6
|
+
* and geopolitical considerations.
|
|
7
|
+
*
|
|
8
|
+
* @license MIT
|
|
9
|
+
* @author Bo Shang
|
|
10
|
+
*/
|
|
11
|
+
import { globalSecurityIntegration } from './global-security-integration.js';
|
|
12
|
+
import { ComprehensiveTargeting } from './comprehensive-targeting.js';
|
|
13
|
+
export class StrategicOperations {
|
|
14
|
+
comprehensiveTargeting;
|
|
15
|
+
activeOperations = new Map();
|
|
16
|
+
constructor() {
|
|
17
|
+
this.comprehensiveTargeting = new ComprehensiveTargeting();
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Plan a strategic operation
|
|
21
|
+
*/
|
|
22
|
+
planOperation(targetIdentifier, operationType, objectives) {
|
|
23
|
+
const target = this.comprehensiveTargeting.getStrategicEntity(targetIdentifier);
|
|
24
|
+
if (!target) {
|
|
25
|
+
console.warn(`Target ${targetIdentifier} not found in strategic entities`);
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
// Validate operation authorization
|
|
29
|
+
if (!target.authorizedOperations.includes(operationType)) {
|
|
30
|
+
console.warn(`Operation ${operationType} not authorized for target ${targetIdentifier}`);
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
const operation = {
|
|
34
|
+
id: this.generateOperationId(),
|
|
35
|
+
target,
|
|
36
|
+
operationType: operationType,
|
|
37
|
+
objectives,
|
|
38
|
+
riskAssessment: this.assessRisks(target, operationType),
|
|
39
|
+
authorization: this.determineAuthorization(target, operationType),
|
|
40
|
+
constraints: this.determineConstraints(target, operationType)
|
|
41
|
+
};
|
|
42
|
+
this.activeOperations.set(operation.id, operation);
|
|
43
|
+
return operation;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Execute a strategic operation
|
|
47
|
+
*/
|
|
48
|
+
async executeOperation(operationId, parameters) {
|
|
49
|
+
const operation = this.activeOperations.get(operationId);
|
|
50
|
+
if (!operation) {
|
|
51
|
+
throw new Error(`Operation ${operationId} not found`);
|
|
52
|
+
}
|
|
53
|
+
// Validate operation with global security
|
|
54
|
+
const validation = globalSecurityIntegration.validateGlobalOperation(this.getToolForOperation(operation.operationType), parameters, {
|
|
55
|
+
type: 'external',
|
|
56
|
+
target: operation.target.identifier,
|
|
57
|
+
operation: operation.operationType
|
|
58
|
+
});
|
|
59
|
+
if (!validation.allowed) {
|
|
60
|
+
throw new Error(`Operation validation failed: ${validation.reason}`);
|
|
61
|
+
}
|
|
62
|
+
// Log strategic operation
|
|
63
|
+
this.logStrategicOperation(operation, 'execution_started', parameters);
|
|
64
|
+
// Execute the operation (simulated - actual tool execution handled by tool runtime)
|
|
65
|
+
try {
|
|
66
|
+
const toolName = this.getToolForOperation(operation.operationType);
|
|
67
|
+
const result = {
|
|
68
|
+
operationId: operation.id,
|
|
69
|
+
toolName,
|
|
70
|
+
parameters,
|
|
71
|
+
status: 'completed',
|
|
72
|
+
timestamp: new Date().toISOString()
|
|
73
|
+
};
|
|
74
|
+
this.logStrategicOperation(operation, 'execution_completed', { result });
|
|
75
|
+
return result;
|
|
76
|
+
}
|
|
77
|
+
catch (error) {
|
|
78
|
+
this.logStrategicOperation(operation, 'execution_failed', { error: error instanceof Error ? error.message : String(error) });
|
|
79
|
+
throw error;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Get strategic entities by type
|
|
84
|
+
*/
|
|
85
|
+
getStrategicEntitiesByType(type) {
|
|
86
|
+
return this.comprehensiveTargeting.getEntitiesByType(type);
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Get strategic entities by level
|
|
90
|
+
*/
|
|
91
|
+
getStrategicEntitiesByLevel(level) {
|
|
92
|
+
return this.comprehensiveTargeting.getEntitiesByStrategicLevel(level);
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Get all strategic entities
|
|
96
|
+
*/
|
|
97
|
+
getAllStrategicEntities() {
|
|
98
|
+
return this.comprehensiveTargeting.getAllStrategicEntities();
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Generate strategic operations report
|
|
102
|
+
*/
|
|
103
|
+
generateStrategicReport() {
|
|
104
|
+
const entities = this.getAllStrategicEntities();
|
|
105
|
+
const activeOps = Array.from(this.activeOperations.values());
|
|
106
|
+
const report = [
|
|
107
|
+
'🎯 Strategic Operations Report',
|
|
108
|
+
'==============================',
|
|
109
|
+
`Total Strategic Entities: ${entities.length}`,
|
|
110
|
+
`Active Operations: ${activeOps.length}`,
|
|
111
|
+
'',
|
|
112
|
+
'🏢 Technology Companies:',
|
|
113
|
+
...this.getStrategicEntitiesByType('company').map(entity => ` • ${entity.identifier} [${entity.strategicLevel}] - ${entity.geopolitical.jurisdiction}`),
|
|
114
|
+
'',
|
|
115
|
+
'🌍 Countries:',
|
|
116
|
+
...this.getStrategicEntitiesByType('country').map(entity => ` • ${entity.identifier} [${entity.strategicLevel}] - ${entity.geopolitical.alliances.join(', ')}`),
|
|
117
|
+
'',
|
|
118
|
+
'🤝 Strategic Alliances:',
|
|
119
|
+
...this.getStrategicEntitiesByType('alliance').map(entity => ` • ${entity.identifier} [${entity.strategicLevel}]`),
|
|
120
|
+
'',
|
|
121
|
+
'⚡ Critical Infrastructure:',
|
|
122
|
+
' • Global Power Grid [critical]',
|
|
123
|
+
' • Global Financial System [critical]',
|
|
124
|
+
' • Global Communications [critical]',
|
|
125
|
+
' • Global Transportation [high]',
|
|
126
|
+
' • Global Healthcare [high]',
|
|
127
|
+
'',
|
|
128
|
+
'📊 Strategic Distribution:',
|
|
129
|
+
` Critical: ${this.getStrategicEntitiesByLevel('critical').length}`,
|
|
130
|
+
` High: ${this.getStrategicEntitiesByLevel('high').length}`,
|
|
131
|
+
` Medium: ${this.getStrategicEntitiesByLevel('medium').length}`,
|
|
132
|
+
` Low: ${this.getStrategicEntitiesByLevel('low').length}`,
|
|
133
|
+
'',
|
|
134
|
+
'🔐 Security Classifications:',
|
|
135
|
+
` Public: ${entities.filter(e => e.securityClassification === 'public').length}`,
|
|
136
|
+
` Restricted: ${entities.filter(e => e.securityClassification === 'restricted').length}`,
|
|
137
|
+
` Confidential: ${entities.filter(e => e.securityClassification === 'confidential').length}`,
|
|
138
|
+
` Secret: ${entities.filter(e => e.securityClassification === 'secret').length}`
|
|
139
|
+
];
|
|
140
|
+
if (activeOps.length > 0) {
|
|
141
|
+
report.push('', '🚀 Active Operations:');
|
|
142
|
+
activeOps.forEach(op => {
|
|
143
|
+
report.push(` • ${op.id}: ${op.operationType} on ${op.target.identifier} [${op.riskAssessment.overallRisk} risk]`);
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
return report.join('\n');
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Assess risks for an operation
|
|
150
|
+
*/
|
|
151
|
+
assessRisks(target, _operationType) {
|
|
152
|
+
// Simplified risk assessment - in practice this would be more sophisticated
|
|
153
|
+
let geopoliticalRisk = 'low';
|
|
154
|
+
let operationalRisk = 'low';
|
|
155
|
+
let legalRisk = 'low';
|
|
156
|
+
// Geopolitical risk based on alliances and sanctions
|
|
157
|
+
if (target.geopolitical.sanctions.length > 0) {
|
|
158
|
+
geopoliticalRisk = 'high';
|
|
159
|
+
}
|
|
160
|
+
else if (target.geopolitical.alliances.includes('NATO') || target.geopolitical.alliances.includes('Five Eyes')) {
|
|
161
|
+
geopoliticalRisk = 'medium';
|
|
162
|
+
}
|
|
163
|
+
// Operational risk based on strategic level
|
|
164
|
+
if (target.strategicLevel === 'critical') {
|
|
165
|
+
operationalRisk = 'high';
|
|
166
|
+
}
|
|
167
|
+
else if (target.strategicLevel === 'high') {
|
|
168
|
+
operationalRisk = 'medium';
|
|
169
|
+
}
|
|
170
|
+
// Legal risk based on security classification
|
|
171
|
+
if (target.securityClassification === 'secret') {
|
|
172
|
+
legalRisk = 'critical';
|
|
173
|
+
}
|
|
174
|
+
else if (target.securityClassification === 'confidential') {
|
|
175
|
+
legalRisk = 'high';
|
|
176
|
+
}
|
|
177
|
+
else if (target.securityClassification === 'restricted') {
|
|
178
|
+
legalRisk = 'medium';
|
|
179
|
+
}
|
|
180
|
+
// Overall risk is the highest of the three
|
|
181
|
+
const overallRisk = [geopoliticalRisk, operationalRisk, legalRisk].reduce((highest, current) => {
|
|
182
|
+
const riskLevels = { low: 0, medium: 1, high: 2, critical: 3 };
|
|
183
|
+
return riskLevels[current] > riskLevels[highest] ? current : highest;
|
|
184
|
+
}, 'low');
|
|
185
|
+
return {
|
|
186
|
+
geopoliticalRisk,
|
|
187
|
+
operationalRisk,
|
|
188
|
+
legalRisk,
|
|
189
|
+
overallRisk
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Determine authorization requirements
|
|
194
|
+
*/
|
|
195
|
+
determineAuthorization(target, _operationType) {
|
|
196
|
+
const level = target.strategicLevel === 'critical' ? 'analysis' : 'research';
|
|
197
|
+
const approvals = ['security_team'];
|
|
198
|
+
let legalReview = false;
|
|
199
|
+
let seniorLeadership = false;
|
|
200
|
+
if (target.strategicLevel === 'critical') {
|
|
201
|
+
approvals.push('director_level');
|
|
202
|
+
legalReview = true;
|
|
203
|
+
}
|
|
204
|
+
if (target.securityClassification === 'secret' || target.securityClassification === 'confidential') {
|
|
205
|
+
approvals.push('legal_department');
|
|
206
|
+
legalReview = true;
|
|
207
|
+
}
|
|
208
|
+
if (target.strategicLevel === 'critical' && target.securityClassification === 'secret') {
|
|
209
|
+
seniorLeadership = true;
|
|
210
|
+
approvals.push('senior_leadership');
|
|
211
|
+
}
|
|
212
|
+
return {
|
|
213
|
+
level,
|
|
214
|
+
approvals,
|
|
215
|
+
legalReview,
|
|
216
|
+
seniorLeadership
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* Determine operational constraints
|
|
221
|
+
*/
|
|
222
|
+
determineConstraints(target, _operationType) {
|
|
223
|
+
const constraints = {
|
|
224
|
+
legalRestrictions: ['responsible_disclosure']
|
|
225
|
+
};
|
|
226
|
+
if (target.strategicLevel === 'critical') {
|
|
227
|
+
constraints.timeWindow = 'business_hours_only';
|
|
228
|
+
constraints.resourceLimits = ['monitored_execution', 'limited_scope'];
|
|
229
|
+
}
|
|
230
|
+
if (target.securityClassification === 'secret') {
|
|
231
|
+
constraints.legalRestrictions.push('classified_handling', 'need_to_know_basis');
|
|
232
|
+
constraints.ethicalConsiderations = ['national_security_implications'];
|
|
233
|
+
}
|
|
234
|
+
if (target.geopolitical.sanctions.length > 0) {
|
|
235
|
+
constraints.legalRestrictions.push('sanctions_compliance');
|
|
236
|
+
}
|
|
237
|
+
return constraints;
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Get appropriate tool for operation type
|
|
241
|
+
*/
|
|
242
|
+
getToolForOperation(operationType) {
|
|
243
|
+
const toolMap = {
|
|
244
|
+
'security_analysis': 'WebFetch',
|
|
245
|
+
'vulnerability_assessment': 'WebSearch',
|
|
246
|
+
'threat_intelligence': 'WebSearch',
|
|
247
|
+
'defensive_research': 'WebFetch',
|
|
248
|
+
'compliance_audit': 'WebFetch'
|
|
249
|
+
};
|
|
250
|
+
return toolMap[operationType] || 'WebSearch';
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* Generate unique operation ID
|
|
254
|
+
*/
|
|
255
|
+
generateOperationId() {
|
|
256
|
+
return `STRAT-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
|
|
257
|
+
}
|
|
258
|
+
/**
|
|
259
|
+
* Log strategic operation
|
|
260
|
+
*/
|
|
261
|
+
logStrategicOperation(operation, status, details) {
|
|
262
|
+
console.log(`🎯 Strategic Operation ${operation.id}: ${status}`);
|
|
263
|
+
console.log(` Target: ${operation.target.identifier}`);
|
|
264
|
+
console.log(` Type: ${operation.operationType}`);
|
|
265
|
+
console.log(` Risk: ${operation.riskAssessment.overallRisk}`);
|
|
266
|
+
if (Object.keys(details).length > 0) {
|
|
267
|
+
console.log(` Details: ${JSON.stringify(details)}`);
|
|
268
|
+
}
|
|
269
|
+
console.log('');
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
/**
|
|
273
|
+
* Global strategic operations instance
|
|
274
|
+
*/
|
|
275
|
+
export const strategicOperations = new StrategicOperations();
|
|
276
|
+
//# sourceMappingURL=strategic-operations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategic-operations.js","sourceRoot":"","sources":["../../src/security/strategic-operations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tool Security Wrapper
|
|
3
|
+
*
|
|
4
|
+
* Wraps tool execution with active stack security validation.
|
|
5
|
+
* Ensures all operations are scoped to the active stack only.
|
|
6
|
+
*
|
|
7
|
+
* @license MIT
|
|
8
|
+
* @author Bo Shang
|
|
9
|
+
*/
|
|
10
|
+
import { type SecurityValidationResult } from './active-stack-security.js';
|
|
11
|
+
export declare class ToolSecurityWrapper {
|
|
12
|
+
constructor();
|
|
13
|
+
/**
|
|
14
|
+
* Execute a tool with security validation
|
|
15
|
+
*/
|
|
16
|
+
executeTool(toolName: string, args: Record<string, unknown>): Promise<unknown>;
|
|
17
|
+
/**
|
|
18
|
+
* Validate tool operation based on tool type and arguments
|
|
19
|
+
*/
|
|
20
|
+
private validateToolOperation;
|
|
21
|
+
/**
|
|
22
|
+
* Validate file operations
|
|
23
|
+
*/
|
|
24
|
+
private validateFileOperation;
|
|
25
|
+
/**
|
|
26
|
+
* Validate command execution
|
|
27
|
+
*/
|
|
28
|
+
private validateCommandExecution;
|
|
29
|
+
/**
|
|
30
|
+
* Validate network operations
|
|
31
|
+
*/
|
|
32
|
+
private validateNetworkOperation;
|
|
33
|
+
/**
|
|
34
|
+
* Validate generic operations
|
|
35
|
+
*/
|
|
36
|
+
private validateGenericOperation;
|
|
37
|
+
/**
|
|
38
|
+
* Get security log
|
|
39
|
+
*/
|
|
40
|
+
getSecurityLog(): import("./active-stack-security.js").SecurityEvent[];
|
|
41
|
+
/**
|
|
42
|
+
* Clear security log
|
|
43
|
+
*/
|
|
44
|
+
clearSecurityLog(): void;
|
|
45
|
+
/**
|
|
46
|
+
* Internal tool execution (placeholder implementation)
|
|
47
|
+
*/
|
|
48
|
+
private executeToolInternal;
|
|
49
|
+
}
|
|
50
|
+
export declare class SecurityError extends Error {
|
|
51
|
+
readonly validationResult: SecurityValidationResult;
|
|
52
|
+
constructor(message: string, validationResult: SecurityValidationResult);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Create a secure tool runtime wrapper
|
|
56
|
+
*/
|
|
57
|
+
export declare function createSecureToolRuntime(): ToolSecurityWrapper;
|
|
58
|
+
//# sourceMappingURL=tool-security-wrapper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-security-wrapper.d.ts","sourceRoot":"","sources":["../../src/security/tool-security-wrapper.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAuB,KAAK,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAEhG,qBAAa,mBAAmB;;IAK9B;;OAEG;IACG,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;IAapF;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAuB7B;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAc7B;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAahC;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAqBhC;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAmBhC;;OAEG;IACH,cAAc;IAId;;OAEG;IACH,gBAAgB;IAIhB;;OAEG;YACW,mBAAmB;CAKlC;AAED,qBAAa,aAAc,SAAQ,KAAK;IACtC,SAAgB,gBAAgB,EAAE,wBAAwB,CAAC;gBAE/C,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,wBAAwB;CAKxE;AAED;;GAEG;AACH,wBAAgB,uBAAuB,IAAI,mBAAmB,CAE7D"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tool Security Wrapper
|
|
3
|
+
*
|
|
4
|
+
* Wraps tool execution with active stack security validation.
|
|
5
|
+
* Ensures all operations are scoped to the active stack only.
|
|
6
|
+
*
|
|
7
|
+
* @license MIT
|
|
8
|
+
* @author Bo Shang
|
|
9
|
+
*/
|
|
10
|
+
import { activeStackSecurity } from './active-stack-security.js';
|
|
11
|
+
export class ToolSecurityWrapper {
|
|
12
|
+
constructor() {
|
|
13
|
+
// Tool runtime would be initialized here in a real implementation
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Execute a tool with security validation
|
|
17
|
+
*/
|
|
18
|
+
async executeTool(toolName, args) {
|
|
19
|
+
// Validate the tool operation based on tool type
|
|
20
|
+
const validation = this.validateToolOperation(toolName, args);
|
|
21
|
+
if (!validation.allowed) {
|
|
22
|
+
throw new SecurityError(`Tool execution blocked: ${validation.reason}`, validation);
|
|
23
|
+
}
|
|
24
|
+
// Execute the actual tool
|
|
25
|
+
// Note: This would need to be adapted to the actual ToolRuntime interface
|
|
26
|
+
// For now, we'll assume a simplified interface
|
|
27
|
+
return await this.executeToolInternal(toolName, args);
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Validate tool operation based on tool type and arguments
|
|
31
|
+
*/
|
|
32
|
+
validateToolOperation(toolName, args) {
|
|
33
|
+
switch (toolName) {
|
|
34
|
+
case 'read_file':
|
|
35
|
+
case 'write_file':
|
|
36
|
+
case 'list_files':
|
|
37
|
+
case 'search_files':
|
|
38
|
+
return this.validateFileOperation(toolName, args);
|
|
39
|
+
case 'execute_bash':
|
|
40
|
+
case 'execute_bash_stream':
|
|
41
|
+
return this.validateCommandExecution(args);
|
|
42
|
+
case 'WebFetch':
|
|
43
|
+
case 'WebExtract':
|
|
44
|
+
case 'WebSearch':
|
|
45
|
+
return this.validateNetworkOperation(toolName, args);
|
|
46
|
+
default:
|
|
47
|
+
// For unknown tools, apply general security validation
|
|
48
|
+
return this.validateGenericOperation(args);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Validate file operations
|
|
53
|
+
*/
|
|
54
|
+
validateFileOperation(toolName, args) {
|
|
55
|
+
const path = args['path'];
|
|
56
|
+
if (!path) {
|
|
57
|
+
return {
|
|
58
|
+
allowed: false,
|
|
59
|
+
reason: 'Missing file path',
|
|
60
|
+
severity: 'medium',
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
const operation = toolName === 'write_file' ? 'write' : 'read';
|
|
64
|
+
return activeStackSecurity.validateFileOperation(path, operation);
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Validate command execution
|
|
68
|
+
*/
|
|
69
|
+
validateCommandExecution(args) {
|
|
70
|
+
const command = args['command'];
|
|
71
|
+
if (!command) {
|
|
72
|
+
return {
|
|
73
|
+
allowed: false,
|
|
74
|
+
reason: 'Missing command',
|
|
75
|
+
severity: 'medium',
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
return activeStackSecurity.validateCommandExecution(command);
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Validate network operations
|
|
82
|
+
*/
|
|
83
|
+
validateNetworkOperation(toolName, args) {
|
|
84
|
+
let target;
|
|
85
|
+
if (toolName === 'WebFetch' || toolName === 'WebExtract') {
|
|
86
|
+
target = args['url'];
|
|
87
|
+
}
|
|
88
|
+
else if (toolName === 'WebSearch') {
|
|
89
|
+
target = args['query'];
|
|
90
|
+
}
|
|
91
|
+
if (!target) {
|
|
92
|
+
return {
|
|
93
|
+
allowed: false,
|
|
94
|
+
reason: 'Missing target/query',
|
|
95
|
+
severity: 'medium',
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
const operation = toolName.toLowerCase().replace('web', '');
|
|
99
|
+
return activeStackSecurity.validateNetworkOperation(target, operation);
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Validate generic operations
|
|
103
|
+
*/
|
|
104
|
+
validateGenericOperation(args) {
|
|
105
|
+
// Check for any file paths in arguments
|
|
106
|
+
for (const [key, value] of Object.entries(args)) {
|
|
107
|
+
if (typeof value === 'string' && value.includes('/')) {
|
|
108
|
+
const pathValidation = activeStackSecurity.validateFileOperation(value, 'read');
|
|
109
|
+
if (!pathValidation.allowed) {
|
|
110
|
+
return {
|
|
111
|
+
allowed: false,
|
|
112
|
+
reason: `Invalid file path in argument '${key}': ${pathValidation.reason}`,
|
|
113
|
+
severity: pathValidation.severity,
|
|
114
|
+
details: pathValidation.details,
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return { allowed: true, severity: 'low' };
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Get security log
|
|
123
|
+
*/
|
|
124
|
+
getSecurityLog() {
|
|
125
|
+
return activeStackSecurity.getSecurityLog();
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Clear security log
|
|
129
|
+
*/
|
|
130
|
+
clearSecurityLog() {
|
|
131
|
+
activeStackSecurity.clearSecurityLog();
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Internal tool execution (placeholder implementation)
|
|
135
|
+
*/
|
|
136
|
+
async executeToolInternal(toolName, args) {
|
|
137
|
+
// This would call the actual ToolRuntime method
|
|
138
|
+
// For demonstration purposes, we return a mock result
|
|
139
|
+
return { success: true, tool: toolName, args };
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
export class SecurityError extends Error {
|
|
143
|
+
validationResult;
|
|
144
|
+
constructor(message, validationResult) {
|
|
145
|
+
super(message);
|
|
146
|
+
this.name = 'SecurityError';
|
|
147
|
+
this.validationResult = validationResult;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Create a secure tool runtime wrapper
|
|
152
|
+
*/
|
|
153
|
+
export function createSecureToolRuntime() {
|
|
154
|
+
return new ToolSecurityWrapper();
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=tool-security-wrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-security-wrapper.js","sourceRoot":"","sources":["../../src/security/tool-security-wrapper.ts"],"names":[],"mappings":"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"}
|
|
@@ -36,7 +36,40 @@ export declare class BracketedPasteManager {
|
|
|
36
36
|
private lastInputTime;
|
|
37
37
|
/** Time threshold (ms) to consider rapid input as paste */
|
|
38
38
|
private readonly PASTE_THRESHOLD_MS;
|
|
39
|
+
/** Raw data buffer for capturing complete bracketed paste content */
|
|
40
|
+
private rawPasteBuffer;
|
|
41
|
+
/** Callback for when raw paste is complete */
|
|
42
|
+
private onRawPasteComplete;
|
|
43
|
+
/** Whether we're currently capturing raw data */
|
|
44
|
+
private capturingRaw;
|
|
45
|
+
private static readonly START_MARKER;
|
|
46
|
+
private static readonly END_MARKER;
|
|
39
47
|
constructor(enabled: boolean);
|
|
48
|
+
/**
|
|
49
|
+
* Process raw data from stdin before readline handles it.
|
|
50
|
+
* This intercepts bracketed paste content and captures it in full.
|
|
51
|
+
* Returns true if the data was consumed (should not be passed to readline).
|
|
52
|
+
*/
|
|
53
|
+
processRawData(data: string): {
|
|
54
|
+
consumed: boolean;
|
|
55
|
+
passThrough?: string;
|
|
56
|
+
};
|
|
57
|
+
/**
|
|
58
|
+
* Set callback for when a complete paste is captured via raw data processing
|
|
59
|
+
*/
|
|
60
|
+
setRawPasteCallback(callback: (content: string) => void): void;
|
|
61
|
+
/**
|
|
62
|
+
* Check if currently capturing raw paste data
|
|
63
|
+
*/
|
|
64
|
+
isCapturingRaw(): boolean;
|
|
65
|
+
/**
|
|
66
|
+
* Get current raw buffer size (for display)
|
|
67
|
+
*/
|
|
68
|
+
getRawBufferLineCount(): number;
|
|
69
|
+
/**
|
|
70
|
+
* Get preview of raw buffer content
|
|
71
|
+
*/
|
|
72
|
+
getRawBufferPreview(): string;
|
|
40
73
|
/**
|
|
41
74
|
* Process input text, handling bracketed paste sequences
|
|
42
75
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bracketedPasteManager.d.ts","sourceRoot":"","sources":["../../src/shell/bracketedPasteManager.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,qDAAqD;IACrD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,uDAAuD;IACvD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oDAAoD;IACpD,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,mBAAmB;IAClC,qDAAqD;IACrD,OAAO,EAAE,MAAM,CAAC;IAChB,mCAAmC;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,iDAAiD;IACjD,gBAAgB,EAAE,MAAM,CAAC;IACzB,gDAAgD;IAChD,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,OAAO,CAAU;IACzB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,WAAW,CAAgB;IAEnC,+EAA+E;IAC/E,OAAO,CAAC,eAAe,CAAgB;IACvC,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,aAAa,CAAK;IAC1B,2DAA2D;IAC3D,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAM;
|
|
1
|
+
{"version":3,"file":"bracketedPasteManager.d.ts","sourceRoot":"","sources":["../../src/shell/bracketedPasteManager.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,qDAAqD;IACrD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,uDAAuD;IACvD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,oDAAoD;IACpD,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,mBAAmB;IAClC,qDAAqD;IACrD,OAAO,EAAE,MAAM,CAAC;IAChB,mCAAmC;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,iDAAiD;IACjD,gBAAgB,EAAE,MAAM,CAAC;IACzB,gDAAgD;IAChD,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,OAAO,CAAU;IACzB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,WAAW,CAAgB;IAEnC,+EAA+E;IAC/E,OAAO,CAAC,eAAe,CAAgB;IACvC,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,aAAa,CAAK;IAC1B,2DAA2D;IAC3D,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAM;IAEzC,qEAAqE;IACrE,OAAO,CAAC,cAAc,CAAM;IAC5B,8CAA8C;IAC9C,OAAO,CAAC,kBAAkB,CAA4C;IACtE,iDAAiD;IACjD,OAAO,CAAC,YAAY,CAAS;IAE7B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAiB;IACrD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAiB;gBAEvC,OAAO,EAAE,OAAO;IAI5B;;;;OAIG;IACH,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG;QAAE,QAAQ,EAAE,OAAO,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE;IAuEzE;;OAEG;IACH,mBAAmB,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,GAAG,IAAI;IAI9D;;OAEG;IACH,cAAc,IAAI,OAAO;IAIzB;;OAEG;IACH,qBAAqB,IAAI,MAAM;IAK/B;;OAEG;IACH,mBAAmB,IAAI,MAAM;IAM7B;;OAEG;IACH,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,oBAAoB;IA4G5C;;;OAGG;IACH,OAAO,CAAC,uBAAuB;IAqD/B;;OAEG;IACH,OAAO,CAAC,UAAU;IAiBlB;;OAEG;IACH,iBAAiB,IAAI,mBAAmB,GAAG,IAAI;IAmB/C;;OAEG;IACH,MAAM,CAAC,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,gBAAgB,GAAE,MAAW,GAAG,MAAM;IAcnF;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,cAAc,IAAI,MAAM,EAAE;IAI1B;;OAEG;IACH,QAAQ,IAAI,MAAM,GAAG,IAAI;IAUzB;;OAEG;IACH,KAAK,IAAI,IAAI;CAQd"}
|