@planu/cli 0.30.1 → 0.32.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/config/ide-registry.json +204 -0
- package/dist/config/injection-patterns.json +30 -0
- package/dist/config/known-cves.json +41 -0
- package/dist/config/license-plans.json +26 -2
- package/dist/config/llm-providers.json +198 -0
- package/dist/config/model-equivalences.json +41 -0
- package/dist/config/model-language-affinity.json +16 -0
- package/dist/config/orchestration-templates.json +76 -0
- package/dist/config/orchestration-topologies.json +36 -0
- package/dist/config/plugin-marketplace.json +59 -0
- package/dist/config/security-runtime-config.json +26 -0
- package/dist/config/workers-registry.json +100 -0
- package/dist/engine/deleter/audit-logger.d.ts +11 -0
- package/dist/engine/deleter/audit-logger.d.ts.map +1 -0
- package/dist/engine/deleter/audit-logger.js +30 -0
- package/dist/engine/deleter/audit-logger.js.map +1 -0
- package/dist/engine/deleter/core.d.ts +39 -0
- package/dist/engine/deleter/core.d.ts.map +1 -0
- package/dist/engine/deleter/core.js +267 -0
- package/dist/engine/deleter/core.js.map +1 -0
- package/dist/engine/deleter/trash-manager.d.ts +18 -0
- package/dist/engine/deleter/trash-manager.d.ts.map +1 -0
- package/dist/engine/deleter/trash-manager.js +92 -0
- package/dist/engine/deleter/trash-manager.js.map +1 -0
- package/dist/engine/github/adapters/bitbucket-adapter.d.ts +12 -0
- package/dist/engine/github/adapters/bitbucket-adapter.d.ts.map +1 -0
- package/dist/engine/github/adapters/bitbucket-adapter.js +32 -0
- package/dist/engine/github/adapters/bitbucket-adapter.js.map +1 -0
- package/dist/engine/github/adapters/github-adapter.d.ts +20 -0
- package/dist/engine/github/adapters/github-adapter.d.ts.map +1 -0
- package/dist/engine/github/adapters/github-adapter.js +221 -0
- package/dist/engine/github/adapters/github-adapter.js.map +1 -0
- package/dist/engine/github/adapters/gitlab-adapter.d.ts +12 -0
- package/dist/engine/github/adapters/gitlab-adapter.d.ts.map +1 -0
- package/dist/engine/github/adapters/gitlab-adapter.js +32 -0
- package/dist/engine/github/adapters/gitlab-adapter.js.map +1 -0
- package/dist/engine/github/adapters/index.d.ts +4 -0
- package/dist/engine/github/adapters/index.d.ts.map +1 -0
- package/dist/engine/github/adapters/index.js +5 -0
- package/dist/engine/github/adapters/index.js.map +1 -0
- package/dist/engine/github/auth.d.ts +13 -0
- package/dist/engine/github/auth.d.ts.map +1 -0
- package/dist/engine/github/auth.js +59 -0
- package/dist/engine/github/auth.js.map +1 -0
- package/dist/engine/github/changelog.d.ts +26 -0
- package/dist/engine/github/changelog.d.ts.map +1 -0
- package/dist/engine/github/changelog.js +117 -0
- package/dist/engine/github/changelog.js.map +1 -0
- package/dist/engine/github/ci-status.d.ts +13 -0
- package/dist/engine/github/ci-status.d.ts.map +1 -0
- package/dist/engine/github/ci-status.js +32 -0
- package/dist/engine/github/ci-status.js.map +1 -0
- package/dist/engine/github/client.d.ts +18 -0
- package/dist/engine/github/client.d.ts.map +1 -0
- package/dist/engine/github/client.js +55 -0
- package/dist/engine/github/client.js.map +1 -0
- package/dist/engine/github/gh-cli.d.ts +22 -0
- package/dist/engine/github/gh-cli.d.ts.map +1 -0
- package/dist/engine/github/gh-cli.js +53 -0
- package/dist/engine/github/gh-cli.js.map +1 -0
- package/dist/engine/github/index.d.ts +9 -0
- package/dist/engine/github/index.d.ts.map +1 -0
- package/dist/engine/github/index.js +10 -0
- package/dist/engine/github/index.js.map +1 -0
- package/dist/engine/github/pr-template.d.ts +17 -0
- package/dist/engine/github/pr-template.d.ts.map +1 -0
- package/dist/engine/github/pr-template.js +79 -0
- package/dist/engine/github/pr-template.js.map +1 -0
- package/dist/engine/github/review-analyzer.d.ts +19 -0
- package/dist/engine/github/review-analyzer.d.ts.map +1 -0
- package/dist/engine/github/review-analyzer.js +146 -0
- package/dist/engine/github/review-analyzer.js.map +1 -0
- package/dist/engine/github/spec-linker.d.ts +18 -0
- package/dist/engine/github/spec-linker.d.ts.map +1 -0
- package/dist/engine/github/spec-linker.js +54 -0
- package/dist/engine/github/spec-linker.js.map +1 -0
- package/dist/engine/ide-config/core.d.ts +14 -0
- package/dist/engine/ide-config/core.d.ts.map +1 -0
- package/dist/engine/ide-config/core.js +103 -0
- package/dist/engine/ide-config/core.js.map +1 -0
- package/dist/engine/ide-config/detector.d.ts +18 -0
- package/dist/engine/ide-config/detector.d.ts.map +1 -0
- package/dist/engine/ide-config/detector.js +97 -0
- package/dist/engine/ide-config/detector.js.map +1 -0
- package/dist/engine/ide-config/generators.d.ts +6 -0
- package/dist/engine/ide-config/generators.d.ts.map +1 -0
- package/dist/engine/ide-config/generators.js +146 -0
- package/dist/engine/ide-config/generators.js.map +1 -0
- package/dist/engine/ide-config/index.d.ts +6 -0
- package/dist/engine/ide-config/index.d.ts.map +1 -0
- package/dist/engine/ide-config/index.js +7 -0
- package/dist/engine/ide-config/index.js.map +1 -0
- package/dist/engine/ide-config/path-resolver.d.ts +23 -0
- package/dist/engine/ide-config/path-resolver.d.ts.map +1 -0
- package/dist/engine/ide-config/path-resolver.js +55 -0
- package/dist/engine/ide-config/path-resolver.js.map +1 -0
- package/dist/engine/ide-config/validator.d.ts +7 -0
- package/dist/engine/ide-config/validator.d.ts.map +1 -0
- package/dist/engine/ide-config/validator.js +55 -0
- package/dist/engine/ide-config/validator.js.map +1 -0
- package/dist/engine/license-validator/lemon-squeezy.d.ts.map +1 -1
- package/dist/engine/license-validator/lemon-squeezy.js +16 -12
- package/dist/engine/license-validator/lemon-squeezy.js.map +1 -1
- package/dist/engine/llm-providers/cost-optimizer.d.ts +26 -0
- package/dist/engine/llm-providers/cost-optimizer.d.ts.map +1 -0
- package/dist/engine/llm-providers/cost-optimizer.js +101 -0
- package/dist/engine/llm-providers/cost-optimizer.js.map +1 -0
- package/dist/engine/llm-providers/cost-tracker.d.ts +26 -0
- package/dist/engine/llm-providers/cost-tracker.d.ts.map +1 -0
- package/dist/engine/llm-providers/cost-tracker.js +75 -0
- package/dist/engine/llm-providers/cost-tracker.js.map +1 -0
- package/dist/engine/llm-providers/failover-chain.d.ts +23 -0
- package/dist/engine/llm-providers/failover-chain.d.ts.map +1 -0
- package/dist/engine/llm-providers/failover-chain.js +88 -0
- package/dist/engine/llm-providers/failover-chain.js.map +1 -0
- package/dist/engine/llm-providers/health-checker.d.ts +18 -0
- package/dist/engine/llm-providers/health-checker.d.ts.map +1 -0
- package/dist/engine/llm-providers/health-checker.js +45 -0
- package/dist/engine/llm-providers/health-checker.js.map +1 -0
- package/dist/engine/llm-providers/index.d.ts +10 -0
- package/dist/engine/llm-providers/index.d.ts.map +1 -0
- package/dist/engine/llm-providers/index.js +11 -0
- package/dist/engine/llm-providers/index.js.map +1 -0
- package/dist/engine/llm-providers/key-manager.d.ts +23 -0
- package/dist/engine/llm-providers/key-manager.d.ts.map +1 -0
- package/dist/engine/llm-providers/key-manager.js +47 -0
- package/dist/engine/llm-providers/key-manager.js.map +1 -0
- package/dist/engine/llm-providers/load-balancer.d.ts +13 -0
- package/dist/engine/llm-providers/load-balancer.d.ts.map +1 -0
- package/dist/engine/llm-providers/load-balancer.js +94 -0
- package/dist/engine/llm-providers/load-balancer.js.map +1 -0
- package/dist/engine/llm-providers/provider-adapter.d.ts +25 -0
- package/dist/engine/llm-providers/provider-adapter.d.ts.map +1 -0
- package/dist/engine/llm-providers/provider-adapter.js +86 -0
- package/dist/engine/llm-providers/provider-adapter.js.map +1 -0
- package/dist/engine/llm-providers/rate-limiter.d.ts +29 -0
- package/dist/engine/llm-providers/rate-limiter.d.ts.map +1 -0
- package/dist/engine/llm-providers/rate-limiter.js +70 -0
- package/dist/engine/llm-providers/rate-limiter.js.map +1 -0
- package/dist/engine/orchestrator/agent-spawner.d.ts +22 -0
- package/dist/engine/orchestrator/agent-spawner.d.ts.map +1 -0
- package/dist/engine/orchestrator/agent-spawner.js +117 -0
- package/dist/engine/orchestrator/agent-spawner.js.map +1 -0
- package/dist/engine/orchestrator/conflict-resolver.d.ts +11 -0
- package/dist/engine/orchestrator/conflict-resolver.d.ts.map +1 -0
- package/dist/engine/orchestrator/conflict-resolver.js +81 -0
- package/dist/engine/orchestrator/conflict-resolver.js.map +1 -0
- package/dist/engine/orchestrator/file-ownership.d.ts +25 -0
- package/dist/engine/orchestrator/file-ownership.d.ts.map +1 -0
- package/dist/engine/orchestrator/file-ownership.js +62 -0
- package/dist/engine/orchestrator/file-ownership.js.map +1 -0
- package/dist/engine/orchestrator/handoff-generator.d.ts +20 -0
- package/dist/engine/orchestrator/handoff-generator.d.ts.map +1 -0
- package/dist/engine/orchestrator/handoff-generator.js +95 -0
- package/dist/engine/orchestrator/handoff-generator.js.map +1 -0
- package/dist/engine/orchestrator/index.d.ts +10 -0
- package/dist/engine/orchestrator/index.d.ts.map +1 -0
- package/dist/engine/orchestrator/index.js +11 -0
- package/dist/engine/orchestrator/index.js.map +1 -0
- package/dist/engine/orchestrator/progress-tracker.d.ts +32 -0
- package/dist/engine/orchestrator/progress-tracker.d.ts.map +1 -0
- package/dist/engine/orchestrator/progress-tracker.js +102 -0
- package/dist/engine/orchestrator/progress-tracker.js.map +1 -0
- package/dist/engine/orchestrator/result-collector.d.ts +23 -0
- package/dist/engine/orchestrator/result-collector.d.ts.map +1 -0
- package/dist/engine/orchestrator/result-collector.js +124 -0
- package/dist/engine/orchestrator/result-collector.js.map +1 -0
- package/dist/engine/orchestrator/runtime.d.ts +21 -0
- package/dist/engine/orchestrator/runtime.d.ts.map +1 -0
- package/dist/engine/orchestrator/runtime.js +231 -0
- package/dist/engine/orchestrator/runtime.js.map +1 -0
- package/dist/engine/orchestrator/task-distributor.d.ts +8 -0
- package/dist/engine/orchestrator/task-distributor.d.ts.map +1 -0
- package/dist/engine/orchestrator/task-distributor.js +106 -0
- package/dist/engine/orchestrator/task-distributor.js.map +1 -0
- package/dist/engine/orchestrator/topologies.d.ts +30 -0
- package/dist/engine/orchestrator/topologies.d.ts.map +1 -0
- package/dist/engine/orchestrator/topologies.js +89 -0
- package/dist/engine/orchestrator/topologies.js.map +1 -0
- package/dist/engine/plugins/compatibility.d.ts +24 -0
- package/dist/engine/plugins/compatibility.d.ts.map +1 -0
- package/dist/engine/plugins/compatibility.js +140 -0
- package/dist/engine/plugins/compatibility.js.map +1 -0
- package/dist/engine/plugins/doc-generator.d.ts +6 -0
- package/dist/engine/plugins/doc-generator.d.ts.map +1 -0
- package/dist/engine/plugins/doc-generator.js +79 -0
- package/dist/engine/plugins/doc-generator.js.map +1 -0
- package/dist/engine/plugins/extensions/analyzer-extension.d.ts +26 -0
- package/dist/engine/plugins/extensions/analyzer-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/analyzer-extension.js +100 -0
- package/dist/engine/plugins/extensions/analyzer-extension.js.map +1 -0
- package/dist/engine/plugins/extensions/template-extension.d.ts +25 -0
- package/dist/engine/plugins/extensions/template-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/template-extension.js +65 -0
- package/dist/engine/plugins/extensions/template-extension.js.map +1 -0
- package/dist/engine/plugins/extensions/tool-extension.d.ts +34 -0
- package/dist/engine/plugins/extensions/tool-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/tool-extension.js +80 -0
- package/dist/engine/plugins/extensions/tool-extension.js.map +1 -0
- package/dist/engine/plugins/extensions/worker-extension.d.ts +24 -0
- package/dist/engine/plugins/extensions/worker-extension.d.ts.map +1 -0
- package/dist/engine/plugins/extensions/worker-extension.js +88 -0
- package/dist/engine/plugins/extensions/worker-extension.js.map +1 -0
- package/dist/engine/plugins/index.d.ts +11 -0
- package/dist/engine/plugins/index.d.ts.map +1 -0
- package/dist/engine/plugins/index.js +12 -0
- package/dist/engine/plugins/index.js.map +1 -0
- package/dist/engine/plugins/lifecycle.d.ts +26 -0
- package/dist/engine/plugins/lifecycle.d.ts.map +1 -0
- package/dist/engine/plugins/lifecycle.js +208 -0
- package/dist/engine/plugins/lifecycle.js.map +1 -0
- package/dist/engine/plugins/loader.d.ts +17 -0
- package/dist/engine/plugins/loader.d.ts.map +1 -0
- package/dist/engine/plugins/loader.js +113 -0
- package/dist/engine/plugins/loader.js.map +1 -0
- package/dist/engine/plugins/sandbox.d.ts +20 -0
- package/dist/engine/plugins/sandbox.d.ts.map +1 -0
- package/dist/engine/plugins/sandbox.js +111 -0
- package/dist/engine/plugins/sandbox.js.map +1 -0
- package/dist/engine/plugins/validator.d.ts +18 -0
- package/dist/engine/plugins/validator.d.ts.map +1 -0
- package/dist/engine/plugins/validator.js +125 -0
- package/dist/engine/plugins/validator.js.map +1 -0
- package/dist/engine/runtime-security/audit-logger.d.ts +7 -0
- package/dist/engine/runtime-security/audit-logger.d.ts.map +1 -0
- package/dist/engine/runtime-security/audit-logger.js +120 -0
- package/dist/engine/runtime-security/audit-logger.js.map +1 -0
- package/dist/engine/runtime-security/checkers/command-injection.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/command-injection.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/command-injection.js +91 -0
- package/dist/engine/runtime-security/checkers/command-injection.js.map +1 -0
- package/dist/engine/runtime-security/checkers/content-security.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/content-security.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/content-security.js +106 -0
- package/dist/engine/runtime-security/checkers/content-security.js.map +1 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.d.ts +4 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.js +93 -0
- package/dist/engine/runtime-security/checkers/dependency-vuln.js.map +1 -0
- package/dist/engine/runtime-security/checkers/file-permissions.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/file-permissions.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/file-permissions.js +60 -0
- package/dist/engine/runtime-security/checkers/file-permissions.js.map +1 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.d.ts +4 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.js +101 -0
- package/dist/engine/runtime-security/checkers/input-sanitizer.js.map +1 -0
- package/dist/engine/runtime-security/checkers/path-traversal.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/path-traversal.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/path-traversal.js +102 -0
- package/dist/engine/runtime-security/checkers/path-traversal.js.map +1 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.d.ts +7 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.js +103 -0
- package/dist/engine/runtime-security/checkers/prompt-injection.js.map +1 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.d.ts +3 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.d.ts.map +1 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.js +71 -0
- package/dist/engine/runtime-security/checkers/sensitive-data.js.map +1 -0
- package/dist/engine/runtime-security/index.d.ts +12 -0
- package/dist/engine/runtime-security/index.d.ts.map +1 -0
- package/dist/engine/runtime-security/index.js +13 -0
- package/dist/engine/runtime-security/index.js.map +1 -0
- package/dist/engine/runtime-security/rate-limiter.d.ts +5 -0
- package/dist/engine/runtime-security/rate-limiter.d.ts.map +1 -0
- package/dist/engine/runtime-security/rate-limiter.js +91 -0
- package/dist/engine/runtime-security/rate-limiter.js.map +1 -0
- package/dist/engine/runtime-security/validator.d.ts +9 -0
- package/dist/engine/runtime-security/validator.d.ts.map +1 -0
- package/dist/engine/runtime-security/validator.js +118 -0
- package/dist/engine/runtime-security/validator.js.map +1 -0
- package/dist/engine/session/auto-save.d.ts +18 -0
- package/dist/engine/session/auto-save.d.ts.map +1 -0
- package/dist/engine/session/auto-save.js +96 -0
- package/dist/engine/session/auto-save.js.map +1 -0
- package/dist/engine/session/context-snapshot.d.ts +8 -0
- package/dist/engine/session/context-snapshot.d.ts.map +1 -0
- package/dist/engine/session/context-snapshot.js +49 -0
- package/dist/engine/session/context-snapshot.js.map +1 -0
- package/dist/engine/session/index.d.ts +6 -0
- package/dist/engine/session/index.d.ts.map +1 -0
- package/dist/engine/session/index.js +7 -0
- package/dist/engine/session/index.js.map +1 -0
- package/dist/engine/session/memory-sync.d.ts +12 -0
- package/dist/engine/session/memory-sync.d.ts.map +1 -0
- package/dist/engine/session/memory-sync.js +34 -0
- package/dist/engine/session/memory-sync.js.map +1 -0
- package/dist/engine/session/session-diff.d.ts +11 -0
- package/dist/engine/session/session-diff.d.ts.map +1 -0
- package/dist/engine/session/session-diff.js +42 -0
- package/dist/engine/session/session-diff.js.map +1 -0
- package/dist/engine/session/session-merge.d.ts +12 -0
- package/dist/engine/session/session-merge.d.ts.map +1 -0
- package/dist/engine/session/session-merge.js +55 -0
- package/dist/engine/session/session-merge.js.map +1 -0
- package/dist/engine/spec-templates/fintech-compliance.d.ts +4 -0
- package/dist/engine/spec-templates/fintech-compliance.d.ts.map +1 -0
- package/dist/engine/spec-templates/fintech-compliance.js +111 -0
- package/dist/engine/spec-templates/fintech-compliance.js.map +1 -0
- package/dist/engine/spec-templates/fintech-kyc.d.ts +4 -0
- package/dist/engine/spec-templates/fintech-kyc.d.ts.map +1 -0
- package/dist/engine/spec-templates/fintech-kyc.js +125 -0
- package/dist/engine/spec-templates/fintech-kyc.js.map +1 -0
- package/dist/engine/spec-templates/fintech-transactions.d.ts +4 -0
- package/dist/engine/spec-templates/fintech-transactions.d.ts.map +1 -0
- package/dist/engine/spec-templates/fintech-transactions.js +120 -0
- package/dist/engine/spec-templates/fintech-transactions.js.map +1 -0
- package/dist/engine/spec-templates/templates-industry-fintech.d.ts +3 -7
- package/dist/engine/spec-templates/templates-industry-fintech.d.ts.map +1 -1
- package/dist/engine/spec-templates/templates-industry-fintech.js +4 -348
- package/dist/engine/spec-templates/templates-industry-fintech.js.map +1 -1
- package/dist/engine/token-optimizer/batcher.d.ts +34 -0
- package/dist/engine/token-optimizer/batcher.d.ts.map +1 -0
- package/dist/engine/token-optimizer/batcher.js +89 -0
- package/dist/engine/token-optimizer/batcher.js.map +1 -0
- package/dist/engine/token-optimizer/budget.d.ts +54 -0
- package/dist/engine/token-optimizer/budget.d.ts.map +1 -0
- package/dist/engine/token-optimizer/budget.js +102 -0
- package/dist/engine/token-optimizer/budget.js.map +1 -0
- package/dist/engine/token-optimizer/context-compressor.d.ts +16 -0
- package/dist/engine/token-optimizer/context-compressor.d.ts.map +1 -0
- package/dist/engine/token-optimizer/context-compressor.js +148 -0
- package/dist/engine/token-optimizer/context-compressor.js.map +1 -0
- package/dist/engine/token-optimizer/counter.d.ts +16 -0
- package/dist/engine/token-optimizer/counter.d.ts.map +1 -0
- package/dist/engine/token-optimizer/counter.js +68 -0
- package/dist/engine/token-optimizer/counter.js.map +1 -0
- package/dist/engine/token-optimizer/deduplicator.d.ts +32 -0
- package/dist/engine/token-optimizer/deduplicator.d.ts.map +1 -0
- package/dist/engine/token-optimizer/deduplicator.js +102 -0
- package/dist/engine/token-optimizer/deduplicator.js.map +1 -0
- package/dist/engine/token-optimizer/incremental.d.ts +30 -0
- package/dist/engine/token-optimizer/incremental.d.ts.map +1 -0
- package/dist/engine/token-optimizer/incremental.js +88 -0
- package/dist/engine/token-optimizer/incremental.js.map +1 -0
- package/dist/engine/token-optimizer/index.d.ts +10 -0
- package/dist/engine/token-optimizer/index.d.ts.map +1 -0
- package/dist/engine/token-optimizer/index.js +11 -0
- package/dist/engine/token-optimizer/index.js.map +1 -0
- package/dist/engine/token-optimizer/optimizer.d.ts +47 -0
- package/dist/engine/token-optimizer/optimizer.d.ts.map +1 -0
- package/dist/engine/token-optimizer/optimizer.js +126 -0
- package/dist/engine/token-optimizer/optimizer.js.map +1 -0
- package/dist/engine/token-optimizer/reporter.d.ts +51 -0
- package/dist/engine/token-optimizer/reporter.d.ts.map +1 -0
- package/dist/engine/token-optimizer/reporter.js +143 -0
- package/dist/engine/token-optimizer/reporter.js.map +1 -0
- package/dist/engine/token-optimizer/response-cache.d.ts +49 -0
- package/dist/engine/token-optimizer/response-cache.d.ts.map +1 -0
- package/dist/engine/token-optimizer/response-cache.js +158 -0
- package/dist/engine/token-optimizer/response-cache.js.map +1 -0
- package/dist/engine/workers/handlers/code-map.d.ts +3 -0
- package/dist/engine/workers/handlers/code-map.d.ts.map +1 -0
- package/dist/engine/workers/handlers/code-map.js +227 -0
- package/dist/engine/workers/handlers/code-map.js.map +1 -0
- package/dist/engine/workers/handlers/dependency-health.d.ts +3 -0
- package/dist/engine/workers/handlers/dependency-health.d.ts.map +1 -0
- package/dist/engine/workers/handlers/dependency-health.js +254 -0
- package/dist/engine/workers/handlers/dependency-health.js.map +1 -0
- package/dist/engine/workers/handlers/documentation.d.ts +3 -0
- package/dist/engine/workers/handlers/documentation.d.ts.map +1 -0
- package/dist/engine/workers/handlers/documentation.js +207 -0
- package/dist/engine/workers/handlers/documentation.js.map +1 -0
- package/dist/engine/workers/handlers/optimization.d.ts +3 -0
- package/dist/engine/workers/handlers/optimization.d.ts.map +1 -0
- package/dist/engine/workers/handlers/optimization.js +161 -0
- package/dist/engine/workers/handlers/optimization.js.map +1 -0
- package/dist/engine/workers/handlers/security-audit.d.ts +3 -0
- package/dist/engine/workers/handlers/security-audit.d.ts.map +1 -0
- package/dist/engine/workers/handlers/security-audit.js +222 -0
- package/dist/engine/workers/handlers/security-audit.js.map +1 -0
- package/dist/engine/workers/handlers/test-gaps.d.ts +3 -0
- package/dist/engine/workers/handlers/test-gaps.d.ts.map +1 -0
- package/dist/engine/workers/handlers/test-gaps.js +186 -0
- package/dist/engine/workers/handlers/test-gaps.js.map +1 -0
- package/dist/engine/workers/index.d.ts +8 -0
- package/dist/engine/workers/index.d.ts.map +1 -0
- package/dist/engine/workers/index.js +9 -0
- package/dist/engine/workers/index.js.map +1 -0
- package/dist/engine/workers/worker-engine.d.ts +24 -0
- package/dist/engine/workers/worker-engine.d.ts.map +1 -0
- package/dist/engine/workers/worker-engine.js +233 -0
- package/dist/engine/workers/worker-engine.js.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -1
- package/dist/storage/index.d.ts +1 -0
- package/dist/storage/index.d.ts.map +1 -1
- package/dist/storage/index.js +1 -0
- package/dist/storage/index.js.map +1 -1
- package/dist/storage/session-store.d.ts +20 -0
- package/dist/storage/session-store.d.ts.map +1 -0
- package/dist/storage/session-store.js +118 -0
- package/dist/storage/session-store.js.map +1 -0
- package/dist/storage/token-cache-store.d.ts +10 -0
- package/dist/storage/token-cache-store.d.ts.map +1 -0
- package/dist/storage/token-cache-store.js +67 -0
- package/dist/storage/token-cache-store.js.map +1 -0
- package/dist/storage/trash-store.d.ts +35 -0
- package/dist/storage/trash-store.d.ts.map +1 -0
- package/dist/storage/trash-store.js +163 -0
- package/dist/storage/trash-store.js.map +1 -0
- package/dist/storage/worker-store.d.ts +11 -0
- package/dist/storage/worker-store.d.ts.map +1 -0
- package/dist/storage/worker-store.js +120 -0
- package/dist/storage/worker-store.js.map +1 -0
- package/dist/tools/agent-swarm-status.d.ts +7 -0
- package/dist/tools/agent-swarm-status.d.ts.map +1 -0
- package/dist/tools/agent-swarm-status.js +94 -0
- package/dist/tools/agent-swarm-status.js.map +1 -0
- package/dist/tools/configure-llm-providers-handler.d.ts +18 -0
- package/dist/tools/configure-llm-providers-handler.d.ts.map +1 -0
- package/dist/tools/configure-llm-providers-handler.js +127 -0
- package/dist/tools/configure-llm-providers-handler.js.map +1 -0
- package/dist/tools/configure-workers-handler.d.ts +3 -0
- package/dist/tools/configure-workers-handler.d.ts.map +1 -0
- package/dist/tools/configure-workers-handler.js +116 -0
- package/dist/tools/configure-workers-handler.js.map +1 -0
- package/dist/tools/delete-decision.d.ts +7 -0
- package/dist/tools/delete-decision.d.ts.map +1 -0
- package/dist/tools/delete-decision.js +54 -0
- package/dist/tools/delete-decision.js.map +1 -0
- package/dist/tools/delete-pattern.d.ts +7 -0
- package/dist/tools/delete-pattern.d.ts.map +1 -0
- package/dist/tools/delete-pattern.js +54 -0
- package/dist/tools/delete-pattern.js.map +1 -0
- package/dist/tools/delete-project.d.ts +7 -0
- package/dist/tools/delete-project.d.ts.map +1 -0
- package/dist/tools/delete-project.js +53 -0
- package/dist/tools/delete-project.js.map +1 -0
- package/dist/tools/delete-spec.d.ts +7 -0
- package/dist/tools/delete-spec.d.ts.map +1 -0
- package/dist/tools/delete-spec.js +54 -0
- package/dist/tools/delete-spec.js.map +1 -0
- package/dist/tools/export-session.d.ts +3 -0
- package/dist/tools/export-session.d.ts.map +1 -0
- package/dist/tools/export-session.js +87 -0
- package/dist/tools/export-session.js.map +1 -0
- package/dist/tools/github-pr-handler.d.ts +13 -0
- package/dist/tools/github-pr-handler.d.ts.map +1 -0
- package/dist/tools/github-pr-handler.js +109 -0
- package/dist/tools/github-pr-handler.js.map +1 -0
- package/dist/tools/github-release-handler.d.ts +14 -0
- package/dist/tools/github-release-handler.d.ts.map +1 -0
- package/dist/tools/github-release-handler.js +55 -0
- package/dist/tools/github-release-handler.js.map +1 -0
- package/dist/tools/github-review-handler.d.ts +7 -0
- package/dist/tools/github-review-handler.d.ts.map +1 -0
- package/dist/tools/github-review-handler.js +61 -0
- package/dist/tools/github-review-handler.js.map +1 -0
- package/dist/tools/ide-config-handler.d.ts +11 -0
- package/dist/tools/ide-config-handler.d.ts.map +1 -0
- package/dist/tools/ide-config-handler.js +56 -0
- package/dist/tools/ide-config-handler.js.map +1 -0
- package/dist/tools/list-sessions.d.ts +3 -0
- package/dist/tools/list-sessions.d.ts.map +1 -0
- package/dist/tools/list-sessions.js +28 -0
- package/dist/tools/list-sessions.js.map +1 -0
- package/dist/tools/llm-provider-status-handler.d.ts +7 -0
- package/dist/tools/llm-provider-status-handler.d.ts.map +1 -0
- package/dist/tools/llm-provider-status-handler.js +63 -0
- package/dist/tools/llm-provider-status-handler.js.map +1 -0
- package/dist/tools/manage-plugins-handler.d.ts +6 -0
- package/dist/tools/manage-plugins-handler.d.ts.map +1 -0
- package/dist/tools/manage-plugins-handler.js +128 -0
- package/dist/tools/manage-plugins-handler.js.map +1 -0
- package/dist/tools/manage-trash.d.ts +7 -0
- package/dist/tools/manage-trash.d.ts.map +1 -0
- package/dist/tools/manage-trash.js +54 -0
- package/dist/tools/manage-trash.js.map +1 -0
- package/dist/tools/orchestrate-runtime.d.ts +7 -0
- package/dist/tools/orchestrate-runtime.d.ts.map +1 -0
- package/dist/tools/orchestrate-runtime.js +72 -0
- package/dist/tools/orchestrate-runtime.js.map +1 -0
- package/dist/tools/register-delete-tools.d.ts +6 -0
- package/dist/tools/register-delete-tools.d.ts.map +1 -0
- package/dist/tools/register-delete-tools.js +95 -0
- package/dist/tools/register-delete-tools.js.map +1 -0
- package/dist/tools/register-github-tools.d.ts +3 -0
- package/dist/tools/register-github-tools.d.ts.map +1 -0
- package/dist/tools/register-github-tools.js +47 -0
- package/dist/tools/register-github-tools.js.map +1 -0
- package/dist/tools/register-ide-tools.d.ts +3 -0
- package/dist/tools/register-ide-tools.d.ts.map +1 -0
- package/dist/tools/register-ide-tools.js +28 -0
- package/dist/tools/register-ide-tools.js.map +1 -0
- package/dist/tools/register-llm-provider-tools.d.ts +3 -0
- package/dist/tools/register-llm-provider-tools.d.ts.map +1 -0
- package/dist/tools/register-llm-provider-tools.js +73 -0
- package/dist/tools/register-llm-provider-tools.js.map +1 -0
- package/dist/tools/register-orchestrator-tools.d.ts +3 -0
- package/dist/tools/register-orchestrator-tools.d.ts.map +1 -0
- package/dist/tools/register-orchestrator-tools.js +68 -0
- package/dist/tools/register-orchestrator-tools.js.map +1 -0
- package/dist/tools/register-plugin-tools.d.ts +3 -0
- package/dist/tools/register-plugin-tools.d.ts.map +1 -0
- package/dist/tools/register-plugin-tools.js +27 -0
- package/dist/tools/register-plugin-tools.js.map +1 -0
- package/dist/tools/register-runtime-security-tools.d.ts +3 -0
- package/dist/tools/register-runtime-security-tools.d.ts.map +1 -0
- package/dist/tools/register-runtime-security-tools.js +19 -0
- package/dist/tools/register-runtime-security-tools.js.map +1 -0
- package/dist/tools/register-session-tools.d.ts +3 -0
- package/dist/tools/register-session-tools.d.ts.map +1 -0
- package/dist/tools/register-session-tools.js +34 -0
- package/dist/tools/register-session-tools.js.map +1 -0
- package/dist/tools/register-token-tools.d.ts +3 -0
- package/dist/tools/register-token-tools.d.ts.map +1 -0
- package/dist/tools/register-token-tools.js +17 -0
- package/dist/tools/register-token-tools.js.map +1 -0
- package/dist/tools/register-worker-tools.d.ts +3 -0
- package/dist/tools/register-worker-tools.d.ts.map +1 -0
- package/dist/tools/register-worker-tools.js +31 -0
- package/dist/tools/register-worker-tools.js.map +1 -0
- package/dist/tools/restore-session.d.ts +3 -0
- package/dist/tools/restore-session.d.ts.map +1 -0
- package/dist/tools/restore-session.js +60 -0
- package/dist/tools/restore-session.js.map +1 -0
- package/dist/tools/scaffold-plugin-handler.d.ts +6 -0
- package/dist/tools/scaffold-plugin-handler.d.ts.map +1 -0
- package/dist/tools/scaffold-plugin-handler.js +208 -0
- package/dist/tools/scaffold-plugin-handler.js.map +1 -0
- package/dist/tools/schemas/delete.d.ts +19 -0
- package/dist/tools/schemas/delete.d.ts.map +1 -0
- package/dist/tools/schemas/delete.js +12 -0
- package/dist/tools/schemas/delete.js.map +1 -0
- package/dist/tools/schemas/github.d.ts +51 -0
- package/dist/tools/schemas/github.d.ts.map +1 -0
- package/dist/tools/schemas/github.js +52 -0
- package/dist/tools/schemas/github.js.map +1 -0
- package/dist/tools/schemas/ide-config.d.ts +36 -0
- package/dist/tools/schemas/ide-config.d.ts.map +1 -0
- package/dist/tools/schemas/ide-config.js +27 -0
- package/dist/tools/schemas/ide-config.js.map +1 -0
- package/dist/tools/schemas/index.d.ts +9 -0
- package/dist/tools/schemas/index.d.ts.map +1 -1
- package/dist/tools/schemas/index.js +9 -0
- package/dist/tools/schemas/index.js.map +1 -1
- package/dist/tools/schemas/llm-provider-schemas.d.ts +26 -0
- package/dist/tools/schemas/llm-provider-schemas.d.ts.map +1 -0
- package/dist/tools/schemas/llm-provider-schemas.js +16 -0
- package/dist/tools/schemas/llm-provider-schemas.js.map +1 -0
- package/dist/tools/schemas/plugins-schemas.d.ts +40 -0
- package/dist/tools/schemas/plugins-schemas.d.ts.map +1 -0
- package/dist/tools/schemas/plugins-schemas.js +29 -0
- package/dist/tools/schemas/plugins-schemas.js.map +1 -0
- package/dist/tools/schemas/runtime-security.d.ts +12 -0
- package/dist/tools/schemas/runtime-security.d.ts.map +1 -0
- package/dist/tools/schemas/runtime-security.js +9 -0
- package/dist/tools/schemas/runtime-security.js.map +1 -0
- package/dist/tools/schemas/session.d.ts +22 -0
- package/dist/tools/schemas/session.d.ts.map +1 -0
- package/dist/tools/schemas/session.js +25 -0
- package/dist/tools/schemas/session.js.map +1 -0
- package/dist/tools/schemas/token-optimization.d.ts +12 -0
- package/dist/tools/schemas/token-optimization.d.ts.map +1 -0
- package/dist/tools/schemas/token-optimization.js +9 -0
- package/dist/tools/schemas/token-optimization.js.map +1 -0
- package/dist/tools/schemas/workers-schema.d.ts +75 -0
- package/dist/tools/schemas/workers-schema.d.ts.map +1 -0
- package/dist/tools/schemas/workers-schema.js +63 -0
- package/dist/tools/schemas/workers-schema.js.map +1 -0
- package/dist/tools/security-report-handler.d.ts +3 -0
- package/dist/tools/security-report-handler.d.ts.map +1 -0
- package/dist/tools/security-report-handler.js +66 -0
- package/dist/tools/security-report-handler.js.map +1 -0
- package/dist/tools/token-usage-handler.d.ts +15 -0
- package/dist/tools/token-usage-handler.d.ts.map +1 -0
- package/dist/tools/token-usage-handler.js +53 -0
- package/dist/tools/token-usage-handler.js.map +1 -0
- package/dist/tools/worker-status-handler.d.ts +3 -0
- package/dist/tools/worker-status-handler.d.ts.map +1 -0
- package/dist/tools/worker-status-handler.js +93 -0
- package/dist/tools/worker-status-handler.js.map +1 -0
- package/dist/types/delete.d.ts +68 -0
- package/dist/types/delete.d.ts.map +1 -0
- package/dist/types/delete.js +3 -0
- package/dist/types/delete.js.map +1 -0
- package/dist/types/github.d.ts +156 -0
- package/dist/types/github.d.ts.map +1 -0
- package/dist/types/github.js +11 -0
- package/dist/types/github.js.map +1 -0
- package/dist/types/ide.d.ts +70 -0
- package/dist/types/ide.d.ts.map +1 -0
- package/dist/types/ide.js +3 -0
- package/dist/types/ide.js.map +1 -0
- package/dist/types/index.d.ts +10 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +10 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/llm-providers.d.ts +140 -0
- package/dist/types/llm-providers.d.ts.map +1 -0
- package/dist/types/llm-providers.js +3 -0
- package/dist/types/llm-providers.js.map +1 -0
- package/dist/types/orchestration-runtime.d.ts +198 -0
- package/dist/types/orchestration-runtime.d.ts.map +1 -0
- package/dist/types/orchestration-runtime.js +4 -0
- package/dist/types/orchestration-runtime.js.map +1 -0
- package/dist/types/plugins.d.ts +144 -0
- package/dist/types/plugins.d.ts.map +1 -0
- package/dist/types/plugins.js +3 -0
- package/dist/types/plugins.js.map +1 -0
- package/dist/types/project/agent.d.ts +12 -0
- package/dist/types/project/agent.d.ts.map +1 -0
- package/dist/types/project/agent.js +3 -0
- package/dist/types/project/agent.js.map +1 -0
- package/dist/types/project/architecture-detection.d.ts +23 -0
- package/dist/types/project/architecture-detection.d.ts.map +1 -0
- package/dist/types/project/architecture-detection.js +2 -0
- package/dist/types/project/architecture-detection.js.map +1 -0
- package/dist/types/project/config-metrics.d.ts +29 -0
- package/dist/types/project/config-metrics.d.ts.map +1 -0
- package/dist/types/project/config-metrics.js +2 -0
- package/dist/types/project/config-metrics.js.map +1 -0
- package/dist/types/project/constitution.d.ts +31 -0
- package/dist/types/project/constitution.d.ts.map +1 -0
- package/dist/types/project/constitution.js +3 -0
- package/dist/types/project/constitution.js.map +1 -0
- package/dist/types/project/core.d.ts +18 -163
- package/dist/types/project/core.d.ts.map +1 -1
- package/dist/types/project/core.js +7 -1
- package/dist/types/project/core.js.map +1 -1
- package/dist/types/project/mfe-detection.d.ts +18 -0
- package/dist/types/project/mfe-detection.d.ts.map +1 -0
- package/dist/types/project/mfe-detection.js +3 -0
- package/dist/types/project/mfe-detection.js.map +1 -0
- package/dist/types/project/planu-config.d.ts +55 -0
- package/dist/types/project/planu-config.d.ts.map +1 -0
- package/dist/types/project/planu-config.js +2 -0
- package/dist/types/project/planu-config.js.map +1 -0
- package/dist/types/runtime-security.d.ts +110 -0
- package/dist/types/runtime-security.d.ts.map +1 -0
- package/dist/types/runtime-security.js +4 -0
- package/dist/types/runtime-security.js.map +1 -0
- package/dist/types/session.d.ts +82 -0
- package/dist/types/session.d.ts.map +1 -0
- package/dist/types/session.js +3 -0
- package/dist/types/session.js.map +1 -0
- package/dist/types/token-optimization.d.ts +121 -0
- package/dist/types/token-optimization.d.ts.map +1 -0
- package/dist/types/token-optimization.js +3 -0
- package/dist/types/token-optimization.js.map +1 -0
- package/dist/types/workers.d.ts +132 -0
- package/dist/types/workers.d.ts.map +1 -0
- package/dist/types/workers.js +3 -0
- package/dist/types/workers.js.map +1 -0
- package/package.json +1 -1
- package/src/config/ide-registry.json +204 -0
- package/src/config/injection-patterns.json +30 -0
- package/src/config/known-cves.json +41 -0
- package/src/config/license-plans.json +26 -2
- package/src/config/llm-providers.json +198 -0
- package/src/config/model-equivalences.json +41 -0
- package/src/config/model-language-affinity.json +16 -0
- package/src/config/orchestration-templates.json +76 -0
- package/src/config/orchestration-topologies.json +36 -0
- package/src/config/plugin-marketplace.json +59 -0
- package/src/config/security-runtime-config.json +26 -0
- package/src/config/workers-registry.json +100 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
// engine/runtime-security/checkers/prompt-injection.ts — SPEC-084 AC-03
|
|
2
|
+
// Detects prompt injection patterns in text inputs using regex + heuristics.
|
|
3
|
+
import { readFileSync } from 'node:fs';
|
|
4
|
+
import { resolve, dirname } from 'node:path';
|
|
5
|
+
import { fileURLToPath } from 'node:url';
|
|
6
|
+
const MODULE_DIR = dirname(fileURLToPath(import.meta.url));
|
|
7
|
+
const PATTERNS_PATH = resolve(MODULE_DIR, '../../../config/injection-patterns.json');
|
|
8
|
+
let cachedPatterns = null;
|
|
9
|
+
function loadPatterns() {
|
|
10
|
+
if (cachedPatterns) {
|
|
11
|
+
return cachedPatterns;
|
|
12
|
+
}
|
|
13
|
+
try {
|
|
14
|
+
const raw = readFileSync(PATTERNS_PATH, 'utf-8');
|
|
15
|
+
const parsed = JSON.parse(raw);
|
|
16
|
+
cachedPatterns = parsed.patterns;
|
|
17
|
+
return cachedPatterns;
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
return [];
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
// Unicode homoglyph detection: characters that look like ASCII but aren't
|
|
24
|
+
const HOMOGLYPH_RANGES = /[\u0400-\u04FF\u2000-\u206F\uFF00-\uFFEF\u200B-\u200F\u202A-\u202E]/;
|
|
25
|
+
// Role delimiter patterns used by various LLM APIs
|
|
26
|
+
const ROLE_DELIMITERS = [
|
|
27
|
+
/<\|im_start\|>/i,
|
|
28
|
+
/<\|im_end\|>/i,
|
|
29
|
+
/\[INST\]/i,
|
|
30
|
+
/\[\/INST\]/i,
|
|
31
|
+
/<<SYS>>/i,
|
|
32
|
+
/<\/SYS>>/i,
|
|
33
|
+
/\bsystem\s*:/i,
|
|
34
|
+
/\bassistant\s*:/i,
|
|
35
|
+
/\buser\s*:/i,
|
|
36
|
+
];
|
|
37
|
+
function computeInjectionScore(text, patterns, customPatterns) {
|
|
38
|
+
let score = 0;
|
|
39
|
+
const lowerText = text.toLowerCase();
|
|
40
|
+
// Check configurable patterns
|
|
41
|
+
const allPatterns = [...patterns, ...customPatterns];
|
|
42
|
+
for (const p of allPatterns) {
|
|
43
|
+
if (lowerText.includes(p.toLowerCase())) {
|
|
44
|
+
score += 0.25;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
// Check role delimiters (higher weight)
|
|
48
|
+
for (const regex of ROLE_DELIMITERS) {
|
|
49
|
+
if (regex.test(text)) {
|
|
50
|
+
score += 0.35;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
// Check homoglyphs
|
|
54
|
+
if (HOMOGLYPH_RANGES.test(text)) {
|
|
55
|
+
score += 0.15;
|
|
56
|
+
}
|
|
57
|
+
return Math.min(score, 1.0);
|
|
58
|
+
}
|
|
59
|
+
function isTextInput(value) {
|
|
60
|
+
return typeof value === 'string' && value.length > 10;
|
|
61
|
+
}
|
|
62
|
+
export const promptInjectionChecker = {
|
|
63
|
+
type: 'prompt-injection',
|
|
64
|
+
check(_toolName, inputs, config) {
|
|
65
|
+
const threats = [];
|
|
66
|
+
const patterns = loadPatterns();
|
|
67
|
+
const customPatterns = config.customInjectionPatterns;
|
|
68
|
+
for (const [key, value] of Object.entries(inputs)) {
|
|
69
|
+
if (!isTextInput(value)) {
|
|
70
|
+
continue;
|
|
71
|
+
}
|
|
72
|
+
const score = computeInjectionScore(value, patterns, customPatterns);
|
|
73
|
+
if (score > 0.7) {
|
|
74
|
+
threats.push({
|
|
75
|
+
type: 'prompt-injection',
|
|
76
|
+
severity: 'critical',
|
|
77
|
+
message: `High-risk prompt injection detected (score: ${score.toFixed(2)})`,
|
|
78
|
+
field: key,
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
else if (score > 0.3) {
|
|
82
|
+
threats.push({
|
|
83
|
+
type: 'prompt-injection',
|
|
84
|
+
severity: 'warning',
|
|
85
|
+
message: `Possible prompt injection detected (score: ${score.toFixed(2)})`,
|
|
86
|
+
field: key,
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
else if (score > 0) {
|
|
90
|
+
threats.push({
|
|
91
|
+
type: 'prompt-injection',
|
|
92
|
+
severity: 'info',
|
|
93
|
+
message: `Low-risk injection pattern detected (score: ${score.toFixed(2)})`,
|
|
94
|
+
field: key,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
return threats;
|
|
99
|
+
},
|
|
100
|
+
};
|
|
101
|
+
/** Exported for testing */
|
|
102
|
+
export { computeInjectionScore, loadPatterns };
|
|
103
|
+
//# sourceMappingURL=prompt-injection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompt-injection.js","sourceRoot":"","sources":["../../../../src/engine/runtime-security/checkers/prompt-injection.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sensitive-data.d.ts","sourceRoot":"","sources":["../../../../src/engine/runtime-security/checkers/sensitive-data.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,sBAAsB,EAIvB,MAAM,yBAAyB,CAAC;AA0DjC,eAAO,MAAM,oBAAoB,EAAE,sBAwBlC,CAAC"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
// engine/runtime-security/checkers/sensitive-data.ts — SPEC-084 AC-08
|
|
2
|
+
// Detects PII, API keys, passwords, and private keys in tool inputs.
|
|
3
|
+
const SENSITIVE_PATTERNS = [
|
|
4
|
+
// PII
|
|
5
|
+
{ name: 'email', regex: /[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/g, category: 'pii' },
|
|
6
|
+
{ name: 'phone', regex: /(?:\+?1[-.\s]?)?\(?\d{3}\)?[-.\s]?\d{3}[-.\s]?\d{4}/g, category: 'pii' },
|
|
7
|
+
{ name: 'ssn', regex: /\b\d{3}-\d{2}-\d{4}\b/g, category: 'pii' },
|
|
8
|
+
{ name: 'ip-address', regex: /\b(?:\d{1,3}\.){3}\d{1,3}\b/g, category: 'pii' },
|
|
9
|
+
// API Keys
|
|
10
|
+
{ name: 'aws-key', regex: /AKIA[0-9A-Z]{16}/g, category: 'secret' },
|
|
11
|
+
{ name: 'gcp-key', regex: /AIza[0-9A-Za-z_-]{35}/g, category: 'secret' },
|
|
12
|
+
{ name: 'openai-key', regex: /sk-[a-zA-Z0-9]{20,}/g, category: 'secret' },
|
|
13
|
+
{ name: 'anthropic-key', regex: /sk-ant-[a-zA-Z0-9]{20,}/g, category: 'secret' },
|
|
14
|
+
{ name: 'github-token', regex: /gh[pousr]_[A-Za-z0-9_]{36,}/g, category: 'secret' },
|
|
15
|
+
{ name: 'stripe-key', regex: /sk_(?:live|test)_[A-Za-z0-9]{24,}/g, category: 'secret' },
|
|
16
|
+
{ name: 'azure-key', regex: /[a-zA-Z0-9/+=]{44}/g, category: 'secret' },
|
|
17
|
+
// Passwords and tokens in plaintext
|
|
18
|
+
{
|
|
19
|
+
name: 'password-field',
|
|
20
|
+
regex: /(?:password|passwd|pwd|secret|token)\s*[=:]\s*\S+/gi,
|
|
21
|
+
category: 'secret',
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
name: 'private-key',
|
|
25
|
+
regex: /-----BEGIN (?:RSA |EC |DSA )?PRIVATE KEY-----/g,
|
|
26
|
+
category: 'secret',
|
|
27
|
+
},
|
|
28
|
+
// URLs with embedded credentials
|
|
29
|
+
{
|
|
30
|
+
name: 'credential-url',
|
|
31
|
+
regex: /https?:\/\/[^:\s]+:[^@\s]+@[^\s]+/g,
|
|
32
|
+
category: 'credential-url',
|
|
33
|
+
},
|
|
34
|
+
];
|
|
35
|
+
function checkStringForSensitiveData(value, field) {
|
|
36
|
+
const threats = [];
|
|
37
|
+
for (const pattern of SENSITIVE_PATTERNS) {
|
|
38
|
+
// Reset regex lastIndex
|
|
39
|
+
pattern.regex.lastIndex = 0;
|
|
40
|
+
if (pattern.regex.test(value)) {
|
|
41
|
+
threats.push({
|
|
42
|
+
type: 'sensitive-data',
|
|
43
|
+
severity: 'warning',
|
|
44
|
+
message: `Sensitive data detected: ${pattern.name} (${pattern.category})`,
|
|
45
|
+
field,
|
|
46
|
+
pattern: pattern.name,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return threats;
|
|
51
|
+
}
|
|
52
|
+
export const sensitiveDataChecker = {
|
|
53
|
+
type: 'sensitive-data',
|
|
54
|
+
check(_toolName, inputs, _config) {
|
|
55
|
+
const threats = [];
|
|
56
|
+
for (const [key, value] of Object.entries(inputs)) {
|
|
57
|
+
if (typeof value === 'string' && value.length > 5) {
|
|
58
|
+
threats.push(...checkStringForSensitiveData(value, key));
|
|
59
|
+
}
|
|
60
|
+
if (Array.isArray(value)) {
|
|
61
|
+
for (const item of value) {
|
|
62
|
+
if (typeof item === 'string' && item.length > 5) {
|
|
63
|
+
threats.push(...checkStringForSensitiveData(item, key));
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return threats;
|
|
69
|
+
},
|
|
70
|
+
};
|
|
71
|
+
//# sourceMappingURL=sensitive-data.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sensitive-data.js","sourceRoot":"","sources":["../../../../src/engine/runtime-security/checkers/sensitive-data.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export { validateToolInput, loadSecurityConfig, getSecurityConfig, getProjectConfig, resetConfigCache, } from './validator.js';
|
|
2
|
+
export { checkRateLimit, resetRateLimits } from './rate-limiter.js';
|
|
3
|
+
export { logAuditEntry, getAuditSummary } from './audit-logger.js';
|
|
4
|
+
export { pathTraversalChecker } from './checkers/path-traversal.js';
|
|
5
|
+
export { promptInjectionChecker } from './checkers/prompt-injection.js';
|
|
6
|
+
export { commandInjectionChecker } from './checkers/command-injection.js';
|
|
7
|
+
export { inputSanitizerChecker, sanitizeString } from './checkers/input-sanitizer.js';
|
|
8
|
+
export { sensitiveDataChecker } from './checkers/sensitive-data.js';
|
|
9
|
+
export { filePermissionsChecker } from './checkers/file-permissions.js';
|
|
10
|
+
export { contentSecurityChecker } from './checkers/content-security.js';
|
|
11
|
+
export { dependencyVulnChecker, checkDependencies } from './checkers/dependency-vuln.js';
|
|
12
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/engine/runtime-security/index.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// engine/runtime-security/index.ts — SPEC-084 barrel export
|
|
2
|
+
export { validateToolInput, loadSecurityConfig, getSecurityConfig, getProjectConfig, resetConfigCache, } from './validator.js';
|
|
3
|
+
export { checkRateLimit, resetRateLimits } from './rate-limiter.js';
|
|
4
|
+
export { logAuditEntry, getAuditSummary } from './audit-logger.js';
|
|
5
|
+
export { pathTraversalChecker } from './checkers/path-traversal.js';
|
|
6
|
+
export { promptInjectionChecker } from './checkers/prompt-injection.js';
|
|
7
|
+
export { commandInjectionChecker } from './checkers/command-injection.js';
|
|
8
|
+
export { inputSanitizerChecker, sanitizeString } from './checkers/input-sanitizer.js';
|
|
9
|
+
export { sensitiveDataChecker } from './checkers/sensitive-data.js';
|
|
10
|
+
export { filePermissionsChecker } from './checkers/file-permissions.js';
|
|
11
|
+
export { contentSecurityChecker } from './checkers/content-security.js';
|
|
12
|
+
export { dependencyVulnChecker, checkDependencies } from './checkers/dependency-vuln.js';
|
|
13
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/engine/runtime-security/index.ts"],"names":[],"mappings":"AAAA,4DAA4D;AAE5D,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { RuntimeRateLimitResult, RuntimeSecurityConfig } from '../../types/index.js';
|
|
2
|
+
export declare function checkRateLimit(toolName: string, config: RuntimeSecurityConfig, now?: number): RuntimeRateLimitResult;
|
|
3
|
+
/** Reset all rate limit state (for testing) */
|
|
4
|
+
export declare function resetRateLimits(): void;
|
|
5
|
+
//# sourceMappingURL=rate-limiter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limiter.d.ts","sourceRoot":"","sources":["../../../src/engine/runtime-security/rate-limiter.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAGV,sBAAsB,EACtB,qBAAqB,EACtB,MAAM,sBAAsB,CAAC;AAgE9B,wBAAgB,cAAc,CAC5B,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,qBAAqB,EAC7B,GAAG,CAAC,EAAE,MAAM,GACX,sBAAsB,CAkDxB;AAED,+CAA+C;AAC/C,wBAAgB,eAAe,IAAI,IAAI,CAEtC"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
// engine/runtime-security/rate-limiter.ts — SPEC-084 AC-06
|
|
2
|
+
// Token bucket rate limiting per tool name, in-memory only.
|
|
3
|
+
// Tool categories for rate limiting
|
|
4
|
+
const READ_TOOLS = new Set([
|
|
5
|
+
'list_specs',
|
|
6
|
+
'validate',
|
|
7
|
+
'check_readiness',
|
|
8
|
+
'security_report',
|
|
9
|
+
'audit_spec',
|
|
10
|
+
'estimate',
|
|
11
|
+
'semantic_search',
|
|
12
|
+
'list_groups',
|
|
13
|
+
'license_status',
|
|
14
|
+
'usage_stats',
|
|
15
|
+
'usage_report',
|
|
16
|
+
'spec_history',
|
|
17
|
+
]);
|
|
18
|
+
const DESTRUCTIVE_TOOLS = new Set(['delete_spec', 'delete_project', 'empty_trash']);
|
|
19
|
+
const buckets = new Map();
|
|
20
|
+
function getToolCategory(toolName) {
|
|
21
|
+
if (DESTRUCTIVE_TOOLS.has(toolName)) {
|
|
22
|
+
return 'destructive';
|
|
23
|
+
}
|
|
24
|
+
if (READ_TOOLS.has(toolName)) {
|
|
25
|
+
return 'read';
|
|
26
|
+
}
|
|
27
|
+
return 'write';
|
|
28
|
+
}
|
|
29
|
+
function getRateLimitConfig(toolName, config) {
|
|
30
|
+
const category = getToolCategory(toolName);
|
|
31
|
+
return config.rateLimits[category];
|
|
32
|
+
}
|
|
33
|
+
function computeRefill(bucket, rlConfig, now) {
|
|
34
|
+
const elapsed = (now - bucket.lastRefill) / 1000;
|
|
35
|
+
const refilled = elapsed * rlConfig.refillRatePerSecond;
|
|
36
|
+
return {
|
|
37
|
+
tokens: Math.min(rlConfig.maxTokens, bucket.tokens + refilled),
|
|
38
|
+
lastRefill: now,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
function isBurstActive(bucket, rlConfig, now) {
|
|
42
|
+
if (bucket.burstStart === null) {
|
|
43
|
+
return false;
|
|
44
|
+
}
|
|
45
|
+
return now - bucket.burstStart < rlConfig.burstDurationMs;
|
|
46
|
+
}
|
|
47
|
+
export function checkRateLimit(toolName, config, now) {
|
|
48
|
+
const currentTime = now ?? Date.now();
|
|
49
|
+
const rlConfig = getRateLimitConfig(toolName, config);
|
|
50
|
+
const existing = buckets.get(toolName);
|
|
51
|
+
const bucket = existing ?? {
|
|
52
|
+
tokens: rlConfig.maxTokens,
|
|
53
|
+
lastRefill: currentTime,
|
|
54
|
+
burstStart: null,
|
|
55
|
+
};
|
|
56
|
+
// Refill tokens
|
|
57
|
+
const refill = computeRefill(bucket, rlConfig, currentTime);
|
|
58
|
+
// Check burst allowance
|
|
59
|
+
const effectiveMax = isBurstActive(bucket, rlConfig, currentTime)
|
|
60
|
+
? rlConfig.maxTokens * rlConfig.burstMultiplier
|
|
61
|
+
: rlConfig.maxTokens;
|
|
62
|
+
let tokens = Math.min(refill.tokens, effectiveMax);
|
|
63
|
+
let burstStart = bucket.burstStart;
|
|
64
|
+
if (tokens >= 1) {
|
|
65
|
+
tokens -= 1;
|
|
66
|
+
// Activate burst if near empty (below 20% of max)
|
|
67
|
+
if (tokens < rlConfig.maxTokens * 0.2 && burstStart === null) {
|
|
68
|
+
burstStart = currentTime;
|
|
69
|
+
}
|
|
70
|
+
buckets.set(toolName, { tokens, lastRefill: refill.lastRefill, burstStart });
|
|
71
|
+
return {
|
|
72
|
+
allowed: true,
|
|
73
|
+
retryAfterMs: 0,
|
|
74
|
+
remainingTokens: Math.floor(tokens),
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
buckets.set(toolName, { tokens, lastRefill: refill.lastRefill, burstStart });
|
|
78
|
+
// Calculate retry time
|
|
79
|
+
const tokensNeeded = 1 - tokens;
|
|
80
|
+
const retryAfterMs = Math.ceil((tokensNeeded / rlConfig.refillRatePerSecond) * 1000);
|
|
81
|
+
return {
|
|
82
|
+
allowed: false,
|
|
83
|
+
retryAfterMs,
|
|
84
|
+
remainingTokens: 0,
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
/** Reset all rate limit state (for testing) */
|
|
88
|
+
export function resetRateLimits() {
|
|
89
|
+
buckets.clear();
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=rate-limiter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limiter.js","sourceRoot":"","sources":["../../../src/engine/runtime-security/rate-limiter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { RuntimeSecurityConfig, RuntimeSecurityValidationResult } from '../../types/index.js';
|
|
2
|
+
export declare function loadSecurityConfig(configPath?: string): RuntimeSecurityConfig;
|
|
3
|
+
export declare function getSecurityConfig(): RuntimeSecurityConfig;
|
|
4
|
+
/** Load project-level override config if it exists */
|
|
5
|
+
export declare function getProjectConfig(projectPath: string): RuntimeSecurityConfig;
|
|
6
|
+
/** Reset cached config (for testing) */
|
|
7
|
+
export declare function resetConfigCache(): void;
|
|
8
|
+
export declare function validateToolInput(toolName: string, inputs: Record<string, unknown>, config?: RuntimeSecurityConfig): RuntimeSecurityValidationResult;
|
|
9
|
+
//# sourceMappingURL=validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validator.d.ts","sourceRoot":"","sources":["../../../src/engine/runtime-security/validator.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAEV,qBAAqB,EACrB,+BAA+B,EAChC,MAAM,sBAAsB,CAAC;AA2B9B,wBAAgB,kBAAkB,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,qBAAqB,CA4B7E;AAED,wBAAgB,iBAAiB,IAAI,qBAAqB,CAGzD;AAED,sDAAsD;AACtD,wBAAgB,gBAAgB,CAAC,WAAW,EAAE,MAAM,GAAG,qBAAqB,CAM3E;AAED,wCAAwC;AACxC,wBAAgB,gBAAgB,IAAI,IAAI,CAEvC;AAcD,wBAAgB,iBAAiB,CAC/B,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC/B,MAAM,CAAC,EAAE,qBAAqB,GAC7B,+BAA+B,CAmCjC"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
// engine/runtime-security/validator.ts — SPEC-084 AC-01
|
|
2
|
+
// Orchestrates all security checkers over tool inputs (OCP — add checkers without modifying).
|
|
3
|
+
import { readFileSync, existsSync } from 'node:fs';
|
|
4
|
+
import { resolve, dirname } from 'node:path';
|
|
5
|
+
import { fileURLToPath } from 'node:url';
|
|
6
|
+
import { pathTraversalChecker } from './checkers/path-traversal.js';
|
|
7
|
+
import { promptInjectionChecker } from './checkers/prompt-injection.js';
|
|
8
|
+
import { commandInjectionChecker } from './checkers/command-injection.js';
|
|
9
|
+
import { inputSanitizerChecker, sanitizeString } from './checkers/input-sanitizer.js';
|
|
10
|
+
import { sensitiveDataChecker } from './checkers/sensitive-data.js';
|
|
11
|
+
import { filePermissionsChecker } from './checkers/file-permissions.js';
|
|
12
|
+
import { contentSecurityChecker } from './checkers/content-security.js';
|
|
13
|
+
import { dependencyVulnChecker } from './checkers/dependency-vuln.js';
|
|
14
|
+
const MODULE_DIR = dirname(fileURLToPath(import.meta.url));
|
|
15
|
+
const DEFAULT_CONFIG_PATH = resolve(MODULE_DIR, '../../config/security-runtime-config.json');
|
|
16
|
+
// Registry of all checkers (OCP — add new checkers here without modifying orchestration logic)
|
|
17
|
+
const defaultCheckers = [
|
|
18
|
+
pathTraversalChecker,
|
|
19
|
+
promptInjectionChecker,
|
|
20
|
+
commandInjectionChecker,
|
|
21
|
+
inputSanitizerChecker,
|
|
22
|
+
sensitiveDataChecker,
|
|
23
|
+
filePermissionsChecker,
|
|
24
|
+
contentSecurityChecker,
|
|
25
|
+
dependencyVulnChecker,
|
|
26
|
+
];
|
|
27
|
+
let cachedConfig = null;
|
|
28
|
+
export function loadSecurityConfig(configPath) {
|
|
29
|
+
const path = configPath ?? DEFAULT_CONFIG_PATH;
|
|
30
|
+
try {
|
|
31
|
+
const raw = readFileSync(path, 'utf-8');
|
|
32
|
+
return JSON.parse(raw);
|
|
33
|
+
}
|
|
34
|
+
catch {
|
|
35
|
+
return {
|
|
36
|
+
level: 'standard',
|
|
37
|
+
rateLimits: {
|
|
38
|
+
read: { maxTokens: 60, refillRatePerSecond: 1, burstMultiplier: 2, burstDurationMs: 5000 },
|
|
39
|
+
write: {
|
|
40
|
+
maxTokens: 30,
|
|
41
|
+
refillRatePerSecond: 0.5,
|
|
42
|
+
burstMultiplier: 2,
|
|
43
|
+
burstDurationMs: 5000,
|
|
44
|
+
},
|
|
45
|
+
destructive: {
|
|
46
|
+
maxTokens: 10,
|
|
47
|
+
refillRatePerSecond: 0.167,
|
|
48
|
+
burstMultiplier: 2,
|
|
49
|
+
burstDurationMs: 5000,
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
allowedDirectories: [],
|
|
53
|
+
customInjectionPatterns: [],
|
|
54
|
+
disabledCheckers: [],
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
export function getSecurityConfig() {
|
|
59
|
+
cachedConfig ??= loadSecurityConfig();
|
|
60
|
+
return cachedConfig;
|
|
61
|
+
}
|
|
62
|
+
/** Load project-level override config if it exists */
|
|
63
|
+
export function getProjectConfig(projectPath) {
|
|
64
|
+
const projectConfigPath = resolve(projectPath, 'security-config.json');
|
|
65
|
+
if (existsSync(projectConfigPath)) {
|
|
66
|
+
return loadSecurityConfig(projectConfigPath);
|
|
67
|
+
}
|
|
68
|
+
return getSecurityConfig();
|
|
69
|
+
}
|
|
70
|
+
/** Reset cached config (for testing) */
|
|
71
|
+
export function resetConfigCache() {
|
|
72
|
+
cachedConfig = null;
|
|
73
|
+
}
|
|
74
|
+
function sanitizeInputs(inputs) {
|
|
75
|
+
const sanitized = {};
|
|
76
|
+
for (const [key, value] of Object.entries(inputs)) {
|
|
77
|
+
if (typeof value === 'string') {
|
|
78
|
+
sanitized[key] = sanitizeString(value);
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
sanitized[key] = value;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return sanitized;
|
|
85
|
+
}
|
|
86
|
+
export function validateToolInput(toolName, inputs, config) {
|
|
87
|
+
const effectiveConfig = config ?? getSecurityConfig();
|
|
88
|
+
const allThreats = [];
|
|
89
|
+
// Run all enabled checkers
|
|
90
|
+
for (const checker of defaultCheckers) {
|
|
91
|
+
if (effectiveConfig.disabledCheckers.includes(checker.type)) {
|
|
92
|
+
continue;
|
|
93
|
+
}
|
|
94
|
+
const threats = checker.check(toolName, inputs, effectiveConfig);
|
|
95
|
+
allThreats.push(...threats);
|
|
96
|
+
}
|
|
97
|
+
// Determine safety based on security level
|
|
98
|
+
const hasCritical = allThreats.some((t) => t.severity === 'critical');
|
|
99
|
+
const hasWarning = allThreats.some((t) => t.severity === 'warning');
|
|
100
|
+
let safe;
|
|
101
|
+
switch (effectiveConfig.level) {
|
|
102
|
+
case 'strict':
|
|
103
|
+
safe = !hasCritical && !hasWarning;
|
|
104
|
+
break;
|
|
105
|
+
case 'standard':
|
|
106
|
+
safe = !hasCritical;
|
|
107
|
+
break;
|
|
108
|
+
case 'permissive':
|
|
109
|
+
safe = true;
|
|
110
|
+
break;
|
|
111
|
+
}
|
|
112
|
+
return {
|
|
113
|
+
safe,
|
|
114
|
+
threats: allThreats,
|
|
115
|
+
sanitizedInputs: sanitizeInputs(inputs),
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validator.js","sourceRoot":"","sources":["../../../src/engine/runtime-security/validator.ts"],"names":[],"mappings":"AAAA,wDAAwD;AACxD,8FAA8F;AAE9F,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAMzC,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AAEtE,MAAM,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC3D,MAAM,mBAAmB,GAAG,OAAO,CAAC,UAAU,EAAE,2CAA2C,CAAC,CAAC;AAE7F,+FAA+F;AAC/F,MAAM,eAAe,GAA6B;IAChD,oBAAoB;IACpB,sBAAsB;IACtB,uBAAuB;IACvB,qBAAqB;IACrB,oBAAoB;IACpB,sBAAsB;IACtB,sBAAsB;IACtB,qBAAqB;CACtB,CAAC;AAEF,IAAI,YAAY,GAAiC,IAAI,CAAC;AAEtD,MAAM,UAAU,kBAAkB,CAAC,UAAmB;IACpD,MAAM,IAAI,GAAG,UAAU,IAAI,mBAAmB,CAAC;IAC/C,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACxC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAA0B,CAAC;IAClD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO;YACL,KAAK,EAAE,UAAU;YACjB,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,mBAAmB,EAAE,CAAC,EAAE,eAAe,EAAE,CAAC,EAAE,eAAe,EAAE,IAAI,EAAE;gBAC1F,KAAK,EAAE;oBACL,SAAS,EAAE,EAAE;oBACb,mBAAmB,EAAE,GAAG;oBACxB,eAAe,EAAE,CAAC;oBAClB,eAAe,EAAE,IAAI;iBACtB;gBACD,WAAW,EAAE;oBACX,SAAS,EAAE,EAAE;oBACb,mBAAmB,EAAE,KAAK;oBAC1B,eAAe,EAAE,CAAC;oBAClB,eAAe,EAAE,IAAI;iBACtB;aACF;YACD,kBAAkB,EAAE,EAAE;YACtB,uBAAuB,EAAE,EAAE;YAC3B,gBAAgB,EAAE,EAAE;SACrB,CAAC;IACJ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,iBAAiB;IAC/B,YAAY,KAAK,kBAAkB,EAAE,CAAC;IACtC,OAAO,YAAY,CAAC;AACtB,CAAC;AAED,sDAAsD;AACtD,MAAM,UAAU,gBAAgB,CAAC,WAAmB;IAClD,MAAM,iBAAiB,GAAG,OAAO,CAAC,WAAW,EAAE,sBAAsB,CAAC,CAAC;IACvE,IAAI,UAAU,CAAC,iBAAiB,CAAC,EAAE,CAAC;QAClC,OAAO,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IAC/C,CAAC;IACD,OAAO,iBAAiB,EAAE,CAAC;AAC7B,CAAC;AAED,wCAAwC;AACxC,MAAM,UAAU,gBAAgB;IAC9B,YAAY,GAAG,IAAI,CAAC;AACtB,CAAC;AAED,SAAS,cAAc,CAAC,MAA+B;IACrD,MAAM,SAAS,GAA4B,EAAE,CAAC;IAC9C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;QAClD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,SAAS,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACzB,CAAC;IACH,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,QAAgB,EAChB,MAA+B,EAC/B,MAA8B;IAE9B,MAAM,eAAe,GAAG,MAAM,IAAI,iBAAiB,EAAE,CAAC;IACtD,MAAM,UAAU,GAAG,EAAE,CAAC;IAEtB,2BAA2B;IAC3B,KAAK,MAAM,OAAO,IAAI,eAAe,EAAE,CAAC;QACtC,IAAI,eAAe,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YAC5D,SAAS;QACX,CAAC;QACD,MAAM,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,EAAE,eAAe,CAAC,CAAC;QACjE,UAAU,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED,2CAA2C;IAC3C,MAAM,WAAW,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC;IACtE,MAAM,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC;IAEpE,IAAI,IAAa,CAAC;IAClB,QAAQ,eAAe,CAAC,KAAK,EAAE,CAAC;QAC9B,KAAK,QAAQ;YACX,IAAI,GAAG,CAAC,WAAW,IAAI,CAAC,UAAU,CAAC;YACnC,MAAM;QACR,KAAK,UAAU;YACb,IAAI,GAAG,CAAC,WAAW,CAAC;YACpB,MAAM;QACR,KAAK,YAAY;YACf,IAAI,GAAG,IAAI,CAAC;YACZ,MAAM;IACV,CAAC;IAED,OAAO;QACL,IAAI;QACJ,OAAO,EAAE,UAAU;QACnB,eAAe,EAAE,cAAc,CAAC,MAAM,CAAC;KACxC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Session, SessionDecision, SessionFile, SessionActiveSpec } from '../../types/index.js';
|
|
2
|
+
/** Get the current in-memory session (may be null if none started). */
|
|
3
|
+
export declare function getCurrentSession(): Session | null;
|
|
4
|
+
/** Reset module state (for testing). */
|
|
5
|
+
export declare function resetSessionState(): void;
|
|
6
|
+
/** Start or resume a session for a project. */
|
|
7
|
+
export declare function startSession(projectId: string, existingSession?: Session): Session;
|
|
8
|
+
/** Record a tool call and maybe persist (debounce). */
|
|
9
|
+
export declare function onToolCall(projectId: string): Promise<void>;
|
|
10
|
+
/** Add an active spec to the current session. */
|
|
11
|
+
export declare function addActiveSpec(spec: SessionActiveSpec): void;
|
|
12
|
+
/** Add a decision to the current session. */
|
|
13
|
+
export declare function addDecision(decision: SessionDecision): void;
|
|
14
|
+
/** Add a modified file to the current session. */
|
|
15
|
+
export declare function addModifiedFile(file: SessionFile): void;
|
|
16
|
+
/** Force-save the current session to disk (bypasses debounce). */
|
|
17
|
+
export declare function persistCurrentSession(): Promise<void>;
|
|
18
|
+
//# sourceMappingURL=auto-save.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auto-save.d.ts","sourceRoot":"","sources":["../../../src/engine/session/auto-save.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,OAAO,EACP,eAAe,EACf,WAAW,EACX,iBAAiB,EAClB,MAAM,sBAAsB,CAAC;AAe9B,uEAAuE;AACvE,wBAAgB,iBAAiB,IAAI,OAAO,GAAG,IAAI,CAElD;AAED,wCAAwC;AACxC,wBAAgB,iBAAiB,IAAI,IAAI,CAGxC;AAED,+CAA+C;AAC/C,wBAAgB,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,eAAe,CAAC,EAAE,OAAO,GAAG,OAAO,CAmBlF;AAED,uDAAuD;AACvD,wBAAsB,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAYjE;AAED,iDAAiD;AACjD,wBAAgB,aAAa,CAAC,IAAI,EAAE,iBAAiB,GAAG,IAAI,CAQ3D;AAED,6CAA6C;AAC7C,wBAAgB,WAAW,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI,CAK3D;AAED,kDAAkD;AAClD,wBAAgB,eAAe,CAAC,IAAI,EAAE,WAAW,GAAG,IAAI,CAUvD;AAED,kEAAkE;AAClE,wBAAsB,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC,CAU3D"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import * as sessionStore from '../../storage/session-store.js';
|
|
2
|
+
import { randomUUID } from 'node:crypto';
|
|
3
|
+
import { buildContextSnapshot } from './context-snapshot.js';
|
|
4
|
+
import { updateCrossConversationMemory } from './memory-sync.js';
|
|
5
|
+
// --- module state ---
|
|
6
|
+
let currentSession = null;
|
|
7
|
+
let lastSaveTimestamp = 0;
|
|
8
|
+
const DEBOUNCE_MS = 30_000; // 30 seconds
|
|
9
|
+
// --- public API ---
|
|
10
|
+
/** Get the current in-memory session (may be null if none started). */
|
|
11
|
+
export function getCurrentSession() {
|
|
12
|
+
return currentSession;
|
|
13
|
+
}
|
|
14
|
+
/** Reset module state (for testing). */
|
|
15
|
+
export function resetSessionState() {
|
|
16
|
+
currentSession = null;
|
|
17
|
+
lastSaveTimestamp = 0;
|
|
18
|
+
}
|
|
19
|
+
/** Start or resume a session for a project. */
|
|
20
|
+
export function startSession(projectId, existingSession) {
|
|
21
|
+
if (existingSession) {
|
|
22
|
+
currentSession = { ...existingSession };
|
|
23
|
+
return currentSession;
|
|
24
|
+
}
|
|
25
|
+
const now = new Date().toISOString();
|
|
26
|
+
currentSession = {
|
|
27
|
+
id: randomUUID(),
|
|
28
|
+
projectId,
|
|
29
|
+
startedAt: now,
|
|
30
|
+
lastSavedAt: now,
|
|
31
|
+
activeSpecs: [],
|
|
32
|
+
decisions: [],
|
|
33
|
+
modifiedFiles: [],
|
|
34
|
+
contextSummary: '',
|
|
35
|
+
toolCallCount: 0,
|
|
36
|
+
metadata: {},
|
|
37
|
+
};
|
|
38
|
+
return currentSession;
|
|
39
|
+
}
|
|
40
|
+
/** Record a tool call and maybe persist (debounce). */
|
|
41
|
+
export async function onToolCall(projectId) {
|
|
42
|
+
if (!currentSession) {
|
|
43
|
+
startSession(projectId);
|
|
44
|
+
}
|
|
45
|
+
if (currentSession) {
|
|
46
|
+
currentSession.toolCallCount++;
|
|
47
|
+
const now = Date.now();
|
|
48
|
+
if (now - lastSaveTimestamp >= DEBOUNCE_MS) {
|
|
49
|
+
await persistCurrentSession();
|
|
50
|
+
lastSaveTimestamp = now;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
/** Add an active spec to the current session. */
|
|
55
|
+
export function addActiveSpec(spec) {
|
|
56
|
+
if (!currentSession) {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const exists = currentSession.activeSpecs.some((s) => s.specId === spec.specId);
|
|
60
|
+
if (!exists) {
|
|
61
|
+
currentSession.activeSpecs.push(spec);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
/** Add a decision to the current session. */
|
|
65
|
+
export function addDecision(decision) {
|
|
66
|
+
if (!currentSession) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
currentSession.decisions.push(decision);
|
|
70
|
+
}
|
|
71
|
+
/** Add a modified file to the current session. */
|
|
72
|
+
export function addModifiedFile(file) {
|
|
73
|
+
if (!currentSession) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
const idx = currentSession.modifiedFiles.findIndex((f) => f.path === file.path);
|
|
77
|
+
if (idx >= 0) {
|
|
78
|
+
currentSession.modifiedFiles[idx] = file;
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
currentSession.modifiedFiles.push(file);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
/** Force-save the current session to disk (bypasses debounce). */
|
|
85
|
+
export async function persistCurrentSession() {
|
|
86
|
+
if (!currentSession) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
currentSession.lastSavedAt = new Date().toISOString();
|
|
90
|
+
currentSession.contextSummary = buildContextSnapshot(currentSession);
|
|
91
|
+
await sessionStore.save(currentSession);
|
|
92
|
+
await updateCrossConversationMemory(currentSession);
|
|
93
|
+
// Fire-and-forget cleanup
|
|
94
|
+
void sessionStore.cleanup(currentSession.projectId);
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=auto-save.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auto-save.js","sourceRoot":"","sources":["../../../src/engine/session/auto-save.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Session } from '../../types/index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Build a markdown context summary from the current session state.
|
|
4
|
+
* Includes: specs in progress, last 5 modified files, last 3 decisions.
|
|
5
|
+
* Truncated to 2000 chars max.
|
|
6
|
+
*/
|
|
7
|
+
export declare function buildContextSnapshot(session: Session): string;
|
|
8
|
+
//# sourceMappingURL=context-snapshot.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-snapshot.d.ts","sourceRoot":"","sources":["../../../src/engine/session/context-snapshot.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAIpD;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,CA8C7D"}
|