agentic-qe 1.4.3 → 1.5.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/.claude/agents/qe-api-contract-validator.md +133 -27
- package/.claude/agents/qe-api-contract-validator.md.backup +1148 -0
- package/.claude/agents/qe-api-contract-validator.md.backup-20251107-134747 +1148 -0
- package/.claude/agents/qe-api-contract-validator.md.backup-phase2-20251107-140039 +1123 -0
- package/.claude/agents/qe-chaos-engineer.md +142 -23
- package/.claude/agents/qe-chaos-engineer.md.backup +808 -0
- package/.claude/agents/qe-chaos-engineer.md.backup-20251107-134747 +808 -0
- package/.claude/agents/qe-chaos-engineer.md.backup-phase2-20251107-140039 +787 -0
- package/.claude/agents/qe-code-complexity.md +111 -23
- package/.claude/agents/qe-code-complexity.md.backup +291 -0
- package/.claude/agents/qe-code-complexity.md.backup-20251107-134747 +291 -0
- package/.claude/agents/qe-code-complexity.md.backup-phase2-20251107-140039 +286 -0
- package/.claude/agents/qe-coverage-analyzer.md +306 -30
- package/.claude/agents/qe-coverage-analyzer.md.backup +467 -0
- package/.claude/agents/qe-coverage-analyzer.md.backup-20251107-134747 +467 -0
- package/.claude/agents/qe-coverage-analyzer.md.backup-phase2-20251107-140039 +438 -0
- package/.claude/agents/qe-deployment-readiness.md +84 -28
- package/.claude/agents/qe-deployment-readiness.md.backup +1166 -0
- package/.claude/agents/qe-deployment-readiness.md.backup-20251107-134747 +1166 -0
- package/.claude/agents/qe-deployment-readiness.md.backup-phase2-20251107-140039 +1140 -0
- package/.claude/agents/qe-flaky-test-hunter.md +277 -35
- package/.claude/agents/qe-flaky-test-hunter.md.backup +1195 -0
- package/.claude/agents/qe-flaky-test-hunter.md.backup-20251107-134747 +1195 -0
- package/.claude/agents/qe-flaky-test-hunter.md.backup-phase2-20251107-140039 +1162 -0
- package/.claude/agents/qe-fleet-commander.md +126 -23
- package/.claude/agents/qe-fleet-commander.md.backup +718 -0
- package/.claude/agents/qe-fleet-commander.md.backup-20251107-134747 +718 -0
- package/.claude/agents/qe-fleet-commander.md.backup-phase2-20251107-140039 +697 -0
- package/.claude/agents/qe-performance-tester.md +314 -57
- package/.claude/agents/qe-performance-tester.md.backup +428 -0
- package/.claude/agents/qe-performance-tester.md.backup-20251107-134747 +428 -0
- package/.claude/agents/qe-performance-tester.md.backup-phase2-20251107-140039 +372 -0
- package/.claude/agents/qe-production-intelligence.md +126 -27
- package/.claude/agents/qe-production-intelligence.md.backup +1219 -0
- package/.claude/agents/qe-production-intelligence.md.backup-20251107-134747 +1219 -0
- package/.claude/agents/qe-production-intelligence.md.backup-phase2-20251107-140039 +1194 -0
- package/.claude/agents/qe-quality-analyzer.md +127 -32
- package/.claude/agents/qe-quality-analyzer.md.backup +425 -0
- package/.claude/agents/qe-quality-analyzer.md.backup-20251107-134747 +425 -0
- package/.claude/agents/qe-quality-analyzer.md.backup-phase2-20251107-140039 +394 -0
- package/.claude/agents/qe-quality-gate.md +148 -33
- package/.claude/agents/qe-quality-gate.md.backup +446 -0
- package/.claude/agents/qe-quality-gate.md.backup-20251107-134747 +446 -0
- package/.claude/agents/qe-quality-gate.md.backup-phase2-20251107-140039 +415 -0
- package/.claude/agents/qe-regression-risk-analyzer.md +78 -27
- package/.claude/agents/qe-regression-risk-analyzer.md.backup +1009 -0
- package/.claude/agents/qe-regression-risk-analyzer.md.backup-20251107-134747 +1009 -0
- package/.claude/agents/qe-regression-risk-analyzer.md.backup-phase2-20251107-140039 +984 -0
- package/.claude/agents/qe-requirements-validator.md +131 -27
- package/.claude/agents/qe-requirements-validator.md.backup +748 -0
- package/.claude/agents/qe-requirements-validator.md.backup-20251107-134747 +748 -0
- package/.claude/agents/qe-requirements-validator.md.backup-phase2-20251107-140039 +723 -0
- package/.claude/agents/qe-security-scanner.md +137 -62
- package/.claude/agents/qe-security-scanner.md.backup +634 -0
- package/.claude/agents/qe-security-scanner.md.backup-20251107-134747 +634 -0
- package/.claude/agents/qe-security-scanner.md.backup-phase2-20251107-140039 +573 -0
- package/.claude/agents/qe-test-data-architect.md +129 -26
- package/.claude/agents/qe-test-data-architect.md.backup +1064 -0
- package/.claude/agents/qe-test-data-architect.md.backup-20251107-134747 +1064 -0
- package/.claude/agents/qe-test-data-architect.md.backup-phase2-20251107-140039 +1040 -0
- package/.claude/agents/qe-test-executor.md +165 -21
- package/.claude/agents/qe-test-executor.md.backup +389 -0
- package/.claude/agents/qe-test-executor.md.backup-20251107-134747 +389 -0
- package/.claude/agents/qe-test-executor.md.backup-phase2-20251107-140039 +369 -0
- package/.claude/agents/qe-test-generator.md +379 -34
- package/.claude/agents/qe-test-generator.md.backup +997 -0
- package/.claude/agents/qe-test-generator.md.backup-20251107-134747 +997 -0
- package/.claude/agents/qe-visual-tester.md +236 -23
- package/.claude/agents/qe-visual-tester.md.backup +777 -0
- package/.claude/agents/qe-visual-tester.md.backup-20251107-134747 +777 -0
- package/.claude/agents/qe-visual-tester.md.backup-phase2-20251107-140039 +756 -0
- package/.claude/agents/subagents/qe-code-reviewer.md +59 -0
- package/.claude/agents/subagents/qe-data-generator.md +60 -0
- package/.claude/agents/subagents/qe-integration-tester.md +77 -0
- package/.claude/agents/subagents/qe-performance-validator.md +55 -0
- package/.claude/agents/subagents/qe-security-auditor.md +51 -0
- package/.claude/agents/subagents/qe-test-implementer.md +371 -0
- package/.claude/agents/subagents/qe-test-refactorer.md +510 -0
- package/.claude/agents/subagents/qe-test-writer.md +603 -0
- package/.claude/skills/accessibility-testing/SKILL.md +764 -777
- package/.claude/skills/agentic-quality-engineering/SKILL.md +0 -6
- package/.claude/skills/api-testing-patterns/SKILL.md +0 -12
- package/.claude/skills/bug-reporting-excellence/SKILL.md +0 -6
- package/.claude/skills/chaos-engineering-resilience/SKILL.md +0 -6
- package/.claude/skills/code-review-quality/SKILL.md +0 -6
- package/.claude/skills/compatibility-testing/SKILL.md +0 -6
- package/.claude/skills/compliance-testing/SKILL.md +0 -6
- package/.claude/skills/consultancy-practices/SKILL.md +0 -6
- package/.claude/skills/context-driven-testing/SKILL.md +0 -6
- package/.claude/skills/contract-testing/SKILL.md +0 -6
- package/.claude/skills/database-testing/SKILL.md +0 -6
- package/.claude/skills/exploratory-testing-advanced/SKILL.md +0 -6
- package/.claude/skills/holistic-testing-pact/SKILL.md +0 -6
- package/.claude/skills/localization-testing/SKILL.md +0 -6
- package/.claude/skills/mobile-testing/SKILL.md +535 -548
- package/.claude/skills/mutation-testing/SKILL.md +0 -6
- package/.claude/skills/performance-testing/SKILL.md +0 -6
- package/.claude/skills/quality-metrics/SKILL.md +0 -12
- package/.claude/skills/refactoring-patterns/SKILL.md +0 -6
- package/.claude/skills/regression-testing/SKILL.md +1033 -1045
- package/.claude/skills/risk-based-testing/SKILL.md +0 -12
- package/.claude/skills/security-testing/SKILL.md +0 -6
- package/.claude/skills/shift-left-testing/SKILL.md +529 -535
- package/.claude/skills/shift-right-testing/SKILL.md +585 -591
- package/.claude/skills/tdd-london-chicago/SKILL.md +0 -6
- package/.claude/skills/technical-writing/SKILL.md +0 -6
- package/.claude/skills/test-automation-strategy/SKILL.md +0 -6
- package/.claude/skills/test-data-management/SKILL.md +1054 -1067
- package/.claude/skills/test-design-techniques/SKILL.md +0 -6
- package/.claude/skills/test-environment-management/SKILL.md +0 -6
- package/.claude/skills/test-reporting-analytics/SKILL.md +0 -6
- package/.claude/skills/visual-testing-advanced/SKILL.md +0 -6
- package/.claude/skills/xp-practices/SKILL.md +0 -6
- package/CHANGELOG.md +504 -0
- package/README.md +24 -16
- package/dist/cli/commands/init.d.ts +4 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +97 -44
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/core/FleetManager.d.ts.map +1 -1
- package/dist/core/FleetManager.js +17 -5
- package/dist/core/FleetManager.js.map +1 -1
- package/dist/core/MemoryManager.d.ts +27 -0
- package/dist/core/MemoryManager.d.ts.map +1 -1
- package/dist/core/MemoryManager.js +69 -4
- package/dist/core/MemoryManager.js.map +1 -1
- package/dist/core/PatternDatabaseAdapter.d.ts.map +1 -1
- package/dist/core/PatternDatabaseAdapter.js +14 -4
- package/dist/core/PatternDatabaseAdapter.js.map +1 -1
- package/dist/learning/LearningEngine.d.ts.map +1 -1
- package/dist/learning/LearningEngine.js +18 -4
- package/dist/learning/LearningEngine.js.map +1 -1
- package/dist/mcp/handlers/coordination/index.d.ts +14 -14
- package/dist/mcp/handlers/coordination/index.d.ts.map +1 -1
- package/dist/mcp/handlers/coordination/index.js +14 -14
- package/dist/mcp/handlers/coordination/index.js.map +1 -1
- package/dist/mcp/handlers/coordination/task-status.d.ts.map +1 -1
- package/dist/mcp/handlers/coordination/task-status.js +3 -5
- package/dist/mcp/handlers/coordination/task-status.js.map +1 -1
- package/dist/mcp/handlers/phase2/Phase2Tools.d.ts.map +1 -1
- package/dist/mcp/handlers/phase2/Phase2Tools.js +39 -10
- package/dist/mcp/handlers/phase2/Phase2Tools.js.map +1 -1
- package/dist/mcp/handlers/phase3/Phase3DomainTools.d.ts +63 -0
- package/dist/mcp/handlers/phase3/Phase3DomainTools.d.ts.map +1 -0
- package/dist/mcp/handlers/phase3/Phase3DomainTools.js +885 -0
- package/dist/mcp/handlers/phase3/Phase3DomainTools.js.map +1 -0
- package/dist/mcp/handlers/phase3/index.d.ts +6 -0
- package/dist/mcp/handlers/phase3/index.d.ts.map +1 -0
- package/dist/mcp/handlers/phase3/index.js +10 -0
- package/dist/mcp/handlers/phase3/index.js.map +1 -0
- package/dist/mcp/handlers/prediction/index.d.ts +10 -10
- package/dist/mcp/handlers/prediction/index.d.ts.map +1 -1
- package/dist/mcp/handlers/prediction/index.js +10 -10
- package/dist/mcp/handlers/prediction/index.js.map +1 -1
- package/dist/mcp/handlers/security/check-authz.d.ts +152 -0
- package/dist/mcp/handlers/security/check-authz.d.ts.map +1 -0
- package/dist/mcp/handlers/security/check-authz.js +434 -0
- package/dist/mcp/handlers/security/check-authz.js.map +1 -0
- package/dist/mcp/handlers/security/generate-report.d.ts +156 -0
- package/dist/mcp/handlers/security/generate-report.d.ts.map +1 -0
- package/dist/mcp/handlers/security/generate-report.js +469 -0
- package/dist/mcp/handlers/security/generate-report.js.map +1 -0
- package/dist/mcp/handlers/security/index.d.ts +80 -0
- package/dist/mcp/handlers/security/index.d.ts.map +1 -0
- package/dist/mcp/handlers/security/index.js +91 -0
- package/dist/mcp/handlers/security/index.js.map +1 -0
- package/dist/mcp/handlers/security/scan-comprehensive.d.ts +66 -0
- package/dist/mcp/handlers/security/scan-comprehensive.d.ts.map +1 -0
- package/dist/mcp/handlers/security/scan-comprehensive.js +296 -0
- package/dist/mcp/handlers/security/scan-comprehensive.js.map +1 -0
- package/dist/mcp/handlers/security/scan-dependencies.d.ts +148 -0
- package/dist/mcp/handlers/security/scan-dependencies.d.ts.map +1 -0
- package/dist/mcp/handlers/security/scan-dependencies.js +354 -0
- package/dist/mcp/handlers/security/scan-dependencies.js.map +1 -0
- package/dist/mcp/handlers/security/validate-auth.d.ts +128 -0
- package/dist/mcp/handlers/security/validate-auth.d.ts.map +1 -0
- package/dist/mcp/handlers/security/validate-auth.js +294 -0
- package/dist/mcp/handlers/security/validate-auth.js.map +1 -0
- package/dist/mcp/handlers/task-orchestrate.d.ts +21 -1
- package/dist/mcp/handlers/task-orchestrate.d.ts.map +1 -1
- package/dist/mcp/handlers/task-orchestrate.js +32 -2
- package/dist/mcp/handlers/task-orchestrate.js.map +1 -1
- package/dist/mcp/handlers/test/generate-integration-tests.d.ts +95 -0
- package/dist/mcp/handlers/test/generate-integration-tests.d.ts.map +1 -0
- package/dist/mcp/handlers/test/generate-integration-tests.js +286 -0
- package/dist/mcp/handlers/test/generate-integration-tests.js.map +1 -0
- package/dist/mcp/handlers/test/generate-unit-tests.d.ts +89 -0
- package/dist/mcp/handlers/test/generate-unit-tests.d.ts.map +1 -0
- package/dist/mcp/handlers/test/generate-unit-tests.js +273 -0
- package/dist/mcp/handlers/test/generate-unit-tests.js.map +1 -0
- package/dist/mcp/handlers/test/optimize-test-suite.d.ts +97 -0
- package/dist/mcp/handlers/test/optimize-test-suite.d.ts.map +1 -0
- package/dist/mcp/handlers/test/optimize-test-suite.js +282 -0
- package/dist/mcp/handlers/test/optimize-test-suite.js.map +1 -0
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +212 -1
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/tools/deprecated.d.ts +1390 -0
- package/dist/mcp/tools/deprecated.d.ts.map +1 -0
- package/dist/mcp/tools/deprecated.js +859 -0
- package/dist/mcp/tools/deprecated.js.map +1 -0
- package/dist/mcp/tools/qe/api-contract/index.d.ts +138 -0
- package/dist/mcp/tools/qe/api-contract/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/api-contract/index.js +572 -0
- package/dist/mcp/tools/qe/api-contract/index.js.map +1 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.d.ts +110 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.d.ts.map +1 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.js +381 -0
- package/dist/mcp/tools/qe/code-quality/analyze-complexity.js.map +1 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.d.ts +115 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.d.ts.map +1 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.js +461 -0
- package/dist/mcp/tools/qe/code-quality/calculate-quality-metrics.js.map +1 -0
- package/dist/mcp/tools/qe/code-quality/index.d.ts +12 -0
- package/dist/mcp/tools/qe/code-quality/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/code-quality/index.js +30 -0
- package/dist/mcp/tools/qe/code-quality/index.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.d.ts +58 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.js +172 -0
- package/dist/mcp/tools/qe/coverage/analyze-with-risk-scoring.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.d.ts +73 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.js +240 -0
- package/dist/mcp/tools/qe/coverage/calculate-trends.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.d.ts +38 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.js +204 -0
- package/dist/mcp/tools/qe/coverage/detect-gaps-ml.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/index.d.ts +12 -0
- package/dist/mcp/tools/qe/coverage/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/index.js +23 -0
- package/dist/mcp/tools/qe/coverage/index.js.map +1 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.d.ts +46 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.js +248 -0
- package/dist/mcp/tools/qe/coverage/recommend-tests.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.d.ts +179 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.js +554 -0
- package/dist/mcp/tools/qe/flaky-detection/analyze-patterns.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.d.ts +172 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.js +498 -0
- package/dist/mcp/tools/qe/flaky-detection/detect-statistical.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/index.d.ts +35 -0
- package/dist/mcp/tools/qe/flaky-detection/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/index.js +66 -0
- package/dist/mcp/tools/qe/flaky-detection/index.js.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.d.ts +159 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.d.ts.map +1 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.js +462 -0
- package/dist/mcp/tools/qe/flaky-detection/stabilize-auto.js.map +1 -0
- package/dist/mcp/tools/qe/fleet/index.d.ts +422 -0
- package/dist/mcp/tools/qe/fleet/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/fleet/index.js +652 -0
- package/dist/mcp/tools/qe/fleet/index.js.map +1 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.d.ts +180 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.js +347 -0
- package/dist/mcp/tools/qe/performance/analyze-bottlenecks.js.map +1 -0
- package/dist/mcp/tools/qe/performance/generate-report.d.ts +146 -0
- package/dist/mcp/tools/qe/performance/generate-report.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/generate-report.js +354 -0
- package/dist/mcp/tools/qe/performance/generate-report.js.map +1 -0
- package/dist/mcp/tools/qe/performance/index.d.ts +13 -0
- package/dist/mcp/tools/qe/performance/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/index.js +24 -0
- package/dist/mcp/tools/qe/performance/index.js.map +1 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.d.ts +120 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.js +215 -0
- package/dist/mcp/tools/qe/performance/monitor-realtime.js.map +1 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.d.ts +68 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.d.ts.map +1 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.js +120 -0
- package/dist/mcp/tools/qe/performance/run-benchmark.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.d.ts +239 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.js +671 -0
- package/dist/mcp/tools/qe/quality-gates/assess-deployment-risk.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.d.ts +219 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.js +732 -0
- package/dist/mcp/tools/qe/quality-gates/evaluate-quality-gate.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.d.ts +447 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.js +551 -0
- package/dist/mcp/tools/qe/quality-gates/generate-quality-report.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/index.d.ts +40 -0
- package/dist/mcp/tools/qe/quality-gates/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/index.js +56 -0
- package/dist/mcp/tools/qe/quality-gates/index.js.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.d.ts +226 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.d.ts.map +1 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.js +603 -0
- package/dist/mcp/tools/qe/quality-gates/validate-quality-metrics.js.map +1 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.d.ts +212 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.d.ts.map +1 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.js +617 -0
- package/dist/mcp/tools/qe/regression/analyze-risk.js.map +1 -0
- package/dist/mcp/tools/qe/regression/index.d.ts +36 -0
- package/dist/mcp/tools/qe/regression/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/regression/index.js +63 -0
- package/dist/mcp/tools/qe/regression/index.js.map +1 -0
- package/dist/mcp/tools/qe/regression/select-tests.d.ts +241 -0
- package/dist/mcp/tools/qe/regression/select-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/regression/select-tests.js +601 -0
- package/dist/mcp/tools/qe/regression/select-tests.js.map +1 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.d.ts +134 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.d.ts.map +1 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.js +737 -0
- package/dist/mcp/tools/qe/requirements/generate-bdd-scenarios.js.map +1 -0
- package/dist/mcp/tools/qe/requirements/index.d.ts +40 -0
- package/dist/mcp/tools/qe/requirements/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/requirements/index.js +84 -0
- package/dist/mcp/tools/qe/requirements/index.js.map +1 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.d.ts +196 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.d.ts.map +1 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.js +740 -0
- package/dist/mcp/tools/qe/requirements/validate-requirements.js.map +1 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.d.ts +300 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.js +492 -0
- package/dist/mcp/tools/qe/security/detect-vulnerabilities.js.map +1 -0
- package/dist/mcp/tools/qe/security/index.d.ts +34 -0
- package/dist/mcp/tools/qe/security/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/index.js +44 -0
- package/dist/mcp/tools/qe/security/index.js.map +1 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.d.ts +240 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.js +535 -0
- package/dist/mcp/tools/qe/security/scan-comprehensive.js.map +1 -0
- package/dist/mcp/tools/qe/security/validate-compliance.d.ts +299 -0
- package/dist/mcp/tools/qe/security/validate-compliance.d.ts.map +1 -0
- package/dist/mcp/tools/qe/security/validate-compliance.js +517 -0
- package/dist/mcp/tools/qe/security/validate-compliance.js.map +1 -0
- package/dist/mcp/tools/qe/shared/types.d.ts +840 -0
- package/dist/mcp/tools/qe/shared/types.d.ts.map +1 -0
- package/dist/mcp/tools/qe/shared/types.js +13 -0
- package/dist/mcp/tools/qe/shared/types.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.d.ts +264 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.js +553 -0
- package/dist/mcp/tools/qe/test-data/analyze-schema.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.d.ts +167 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.js +336 -0
- package/dist/mcp/tools/qe/test-data/generate-test-data.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/index.d.ts +44 -0
- package/dist/mcp/tools/qe/test-data/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/index.js +90 -0
- package/dist/mcp/tools/qe/test-data/index.js.map +1 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.d.ts +165 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.js +342 -0
- package/dist/mcp/tools/qe/test-data/mask-sensitive-data.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.d.ts +144 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.js +432 -0
- package/dist/mcp/tools/qe/test-generation/analyze-test-quality.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.d.ts +98 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.js +459 -0
- package/dist/mcp/tools/qe/test-generation/generate-integration-tests.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.d.ts +83 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.js +483 -0
- package/dist/mcp/tools/qe/test-generation/generate-unit-tests.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/index.d.ts +56 -0
- package/dist/mcp/tools/qe/test-generation/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/index.js +97 -0
- package/dist/mcp/tools/qe/test-generation/index.js.map +1 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.d.ts +124 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.d.ts.map +1 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.js +362 -0
- package/dist/mcp/tools/qe/test-generation/optimize-test-suite.js.map +1 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.d.ts +119 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.js +280 -0
- package/dist/mcp/tools/qe/visual/compare-screenshots.js.map +1 -0
- package/dist/mcp/tools/qe/visual/detect-regression.d.ts +138 -0
- package/dist/mcp/tools/qe/visual/detect-regression.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/detect-regression.js +271 -0
- package/dist/mcp/tools/qe/visual/detect-regression.js.map +1 -0
- package/dist/mcp/tools/qe/visual/index.d.ts +16 -0
- package/dist/mcp/tools/qe/visual/index.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/index.js +22 -0
- package/dist/mcp/tools/qe/visual/index.js.map +1 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.d.ts +276 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.d.ts.map +1 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.js +413 -0
- package/dist/mcp/tools/qe/visual/validate-accessibility.js.map +1 -0
- package/dist/mcp/tools.d.ts +44 -0
- package/dist/mcp/tools.d.ts.map +1 -1
- package/dist/mcp/tools.js +1980 -1
- package/dist/mcp/tools.js.map +1 -1
- package/package.json +2 -2
- package/dist/learning/__mocks__/LearningEngine.d.ts +0 -39
- package/dist/learning/__mocks__/LearningEngine.d.ts.map +0 -1
- package/dist/learning/__mocks__/LearningEngine.js +0 -116
- package/dist/learning/__mocks__/LearningEngine.js.map +0 -1
- package/dist/utils/__mocks__/Database.d.ts +0 -85
- package/dist/utils/__mocks__/Database.d.ts.map +0 -1
- package/dist/utils/__mocks__/Database.js +0 -125
- package/dist/utils/__mocks__/Database.js.map +0 -1
- package/dist/utils/__mocks__/Logger.d.ts +0 -26
- package/dist/utils/__mocks__/Logger.d.ts.map +0 -1
- package/dist/utils/__mocks__/Logger.js +0 -44
- package/dist/utils/__mocks__/Logger.js.map +0 -1
|
@@ -0,0 +1,434 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Authorization Rule Checking Tool
|
|
4
|
+
*
|
|
5
|
+
* Validates authorization rules, policy enforcement, and role-based access control
|
|
6
|
+
* with comprehensive RBAC/ABAC testing and permission validation.
|
|
7
|
+
*
|
|
8
|
+
* @module security/check-authz
|
|
9
|
+
* @version 1.0.0
|
|
10
|
+
* @author Agentic QE Team
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```typescript
|
|
14
|
+
* import { checkAuthorizationRules } from './check-authz';
|
|
15
|
+
*
|
|
16
|
+
* const result = await checkAuthorizationRules({
|
|
17
|
+
* roles: ['admin', 'user', 'guest'],
|
|
18
|
+
* resources: ['/api/users', '/api/admin', '/api/reports'],
|
|
19
|
+
* policies: './security-policies.json'
|
|
20
|
+
* });
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
24
|
+
if (k2 === undefined) k2 = k;
|
|
25
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
26
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
27
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
28
|
+
}
|
|
29
|
+
Object.defineProperty(o, k2, desc);
|
|
30
|
+
}) : (function(o, m, k, k2) {
|
|
31
|
+
if (k2 === undefined) k2 = k;
|
|
32
|
+
o[k2] = m[k];
|
|
33
|
+
}));
|
|
34
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
35
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
36
|
+
}) : function(o, v) {
|
|
37
|
+
o["default"] = v;
|
|
38
|
+
});
|
|
39
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
40
|
+
var ownKeys = function(o) {
|
|
41
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
42
|
+
var ar = [];
|
|
43
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
44
|
+
return ar;
|
|
45
|
+
};
|
|
46
|
+
return ownKeys(o);
|
|
47
|
+
};
|
|
48
|
+
return function (mod) {
|
|
49
|
+
if (mod && mod.__esModule) return mod;
|
|
50
|
+
var result = {};
|
|
51
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
52
|
+
__setModuleDefault(result, mod);
|
|
53
|
+
return result;
|
|
54
|
+
};
|
|
55
|
+
})();
|
|
56
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
57
|
+
exports.CheckAuthorizationRulesHandler = void 0;
|
|
58
|
+
exports.checkAuthorizationRules = checkAuthorizationRules;
|
|
59
|
+
const base_handler_js_1 = require("../base-handler.js");
|
|
60
|
+
const SecureRandom_js_1 = require("../../../utils/SecureRandom.js");
|
|
61
|
+
const fs = __importStar(require("fs/promises"));
|
|
62
|
+
class CheckAuthorizationRulesHandler extends base_handler_js_1.BaseHandler {
|
|
63
|
+
async handle(args) {
|
|
64
|
+
return this.safeHandle(async () => {
|
|
65
|
+
const requestId = this.generateRequestId();
|
|
66
|
+
this.log('info', 'Checking authorization rules', { requestId, roles: args.roles.length });
|
|
67
|
+
// Validate required parameters
|
|
68
|
+
this.validateRequired(args, ['roles', 'resources', 'policies']);
|
|
69
|
+
const { result, executionTime } = await this.measureExecutionTime(async () => {
|
|
70
|
+
return await checkAuthorizationRules(args);
|
|
71
|
+
});
|
|
72
|
+
this.log('info', `Authorization check completed in ${executionTime.toFixed(2)}ms`, {
|
|
73
|
+
status: result.summary.overallStatus,
|
|
74
|
+
criticalIssues: result.summary.criticalIssues
|
|
75
|
+
});
|
|
76
|
+
return this.createSuccessResponse(result, requestId);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
exports.CheckAuthorizationRulesHandler = CheckAuthorizationRulesHandler;
|
|
81
|
+
/**
|
|
82
|
+
* Check authorization rules and validate RBAC/ABAC configuration
|
|
83
|
+
*
|
|
84
|
+
* @param params - Authorization check parameters
|
|
85
|
+
* @returns Authorization validation results with security findings
|
|
86
|
+
*/
|
|
87
|
+
async function checkAuthorizationRules(params) {
|
|
88
|
+
const startTime = Date.now();
|
|
89
|
+
const { roles, resources, policies: policyFile, testHierarchy = true, testABAC = false, testInheritance = true, testPrivilegeEscalation = true } = params;
|
|
90
|
+
// Load and validate policies
|
|
91
|
+
const policy = await loadAuthorizationPolicy(policyFile);
|
|
92
|
+
const policyValidation = validatePolicies(policy, roles, resources);
|
|
93
|
+
// Test role access to resources
|
|
94
|
+
const roleAccessResults = await testRoleAccess(policy, roles, resources);
|
|
95
|
+
// Build access matrix
|
|
96
|
+
const accessMatrix = buildAccessMatrix(roleAccessResults, roles, resources);
|
|
97
|
+
// Test privilege escalation if enabled
|
|
98
|
+
let privilegeEscalation;
|
|
99
|
+
if (testPrivilegeEscalation) {
|
|
100
|
+
privilegeEscalation = await testPrivilegeEscalationVulnerabilities(policy, roles);
|
|
101
|
+
}
|
|
102
|
+
// Test ABAC if enabled
|
|
103
|
+
let abacValidation;
|
|
104
|
+
if (testABAC) {
|
|
105
|
+
abacValidation = await validateABAC(policy, resources);
|
|
106
|
+
}
|
|
107
|
+
// Test inheritance if enabled
|
|
108
|
+
let inheritanceValidation;
|
|
109
|
+
if (testInheritance) {
|
|
110
|
+
inheritanceValidation = await validateInheritance(policy);
|
|
111
|
+
}
|
|
112
|
+
// Calculate critical issues
|
|
113
|
+
let criticalIssues = 0;
|
|
114
|
+
let highIssues = 0;
|
|
115
|
+
let mediumIssues = 0;
|
|
116
|
+
roleAccessResults.forEach(result => {
|
|
117
|
+
result.issues.forEach(issue => {
|
|
118
|
+
if (issue.severity === 'critical')
|
|
119
|
+
criticalIssues++;
|
|
120
|
+
else if (issue.severity === 'high')
|
|
121
|
+
highIssues++;
|
|
122
|
+
else if (issue.severity === 'medium')
|
|
123
|
+
mediumIssues++;
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
if (privilegeEscalation) {
|
|
127
|
+
privilegeEscalation.vulnerabilities.forEach(vuln => {
|
|
128
|
+
if (vuln.severity === 'critical')
|
|
129
|
+
criticalIssues++;
|
|
130
|
+
else if (vuln.severity === 'high')
|
|
131
|
+
highIssues++;
|
|
132
|
+
else if (vuln.severity === 'medium')
|
|
133
|
+
mediumIssues++;
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
// Generate recommendations
|
|
137
|
+
const recommendations = generateAuthzRecommendations({
|
|
138
|
+
policyValidation,
|
|
139
|
+
privilegeEscalation,
|
|
140
|
+
abacValidation,
|
|
141
|
+
inheritanceValidation,
|
|
142
|
+
criticalIssues
|
|
143
|
+
});
|
|
144
|
+
// Determine overall status
|
|
145
|
+
const overallStatus = criticalIssues > 0 ? 'vulnerable' :
|
|
146
|
+
highIssues > 0 ? 'needs-review' : 'secure';
|
|
147
|
+
return {
|
|
148
|
+
roleAccessResults,
|
|
149
|
+
accessMatrix,
|
|
150
|
+
policyValidation,
|
|
151
|
+
privilegeEscalation,
|
|
152
|
+
abacValidation,
|
|
153
|
+
inheritanceValidation,
|
|
154
|
+
summary: {
|
|
155
|
+
overallStatus,
|
|
156
|
+
totalRoles: roles.length,
|
|
157
|
+
totalResources: resources.length,
|
|
158
|
+
totalPermissions: policy.roles.reduce((sum, role) => sum + role.permissions.length, 0),
|
|
159
|
+
criticalIssues,
|
|
160
|
+
highIssues,
|
|
161
|
+
mediumIssues,
|
|
162
|
+
recommendations
|
|
163
|
+
},
|
|
164
|
+
metadata: {
|
|
165
|
+
policyFile,
|
|
166
|
+
validationDuration: Date.now() - startTime,
|
|
167
|
+
timestamp: new Date().toISOString()
|
|
168
|
+
}
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
async function loadAuthorizationPolicy(policyFile) {
|
|
172
|
+
try {
|
|
173
|
+
// Check if file exists
|
|
174
|
+
const fileExists = await fs.access(policyFile).then(() => true).catch(() => false);
|
|
175
|
+
if (!fileExists) {
|
|
176
|
+
// Return mock policy for testing
|
|
177
|
+
return createMockPolicy();
|
|
178
|
+
}
|
|
179
|
+
const content = await fs.readFile(policyFile, 'utf-8');
|
|
180
|
+
const policy = JSON.parse(content);
|
|
181
|
+
return policy;
|
|
182
|
+
}
|
|
183
|
+
catch (error) {
|
|
184
|
+
// Return mock policy if file can't be loaded
|
|
185
|
+
return createMockPolicy();
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
function createMockPolicy() {
|
|
189
|
+
return {
|
|
190
|
+
version: '1.0.0',
|
|
191
|
+
roles: [
|
|
192
|
+
{
|
|
193
|
+
name: 'admin',
|
|
194
|
+
permissions: ['read', 'write', 'delete', 'admin'],
|
|
195
|
+
attributes: { level: 'admin' }
|
|
196
|
+
},
|
|
197
|
+
{
|
|
198
|
+
name: 'user',
|
|
199
|
+
permissions: ['read', 'write'],
|
|
200
|
+
inherits: [],
|
|
201
|
+
attributes: { level: 'user' }
|
|
202
|
+
},
|
|
203
|
+
{
|
|
204
|
+
name: 'guest',
|
|
205
|
+
permissions: ['read'],
|
|
206
|
+
inherits: [],
|
|
207
|
+
attributes: { level: 'guest' }
|
|
208
|
+
}
|
|
209
|
+
],
|
|
210
|
+
resources: [
|
|
211
|
+
{
|
|
212
|
+
path: '/api/users',
|
|
213
|
+
allowedRoles: ['admin', 'user'],
|
|
214
|
+
requiredPermissions: ['read']
|
|
215
|
+
},
|
|
216
|
+
{
|
|
217
|
+
path: '/api/admin',
|
|
218
|
+
allowedRoles: ['admin'],
|
|
219
|
+
requiredPermissions: ['admin']
|
|
220
|
+
},
|
|
221
|
+
{
|
|
222
|
+
path: '/api/reports',
|
|
223
|
+
allowedRoles: ['admin', 'user'],
|
|
224
|
+
requiredPermissions: ['read']
|
|
225
|
+
}
|
|
226
|
+
]
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
function validatePolicies(policy, roles, resources) {
|
|
230
|
+
const conflicts = [];
|
|
231
|
+
// Check for role conflicts
|
|
232
|
+
const policyRoles = policy.roles.map(r => r.name);
|
|
233
|
+
const undefinedRoles = roles.filter(r => !policyRoles.includes(r));
|
|
234
|
+
if (undefinedRoles.length > 0) {
|
|
235
|
+
conflicts.push({
|
|
236
|
+
type: 'role-conflict',
|
|
237
|
+
description: `Roles not defined in policy: ${undefinedRoles.join(', ')}`,
|
|
238
|
+
affectedRoles: undefinedRoles,
|
|
239
|
+
affectedResources: []
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
// Check for resource conflicts
|
|
243
|
+
const policyResources = policy.resources.map(r => r.path);
|
|
244
|
+
const undefinedResources = resources.filter(r => !policyResources.includes(r));
|
|
245
|
+
if (undefinedResources.length > 0) {
|
|
246
|
+
conflicts.push({
|
|
247
|
+
type: 'resource-conflict',
|
|
248
|
+
description: `Resources not defined in policy: ${undefinedResources.join(', ')}`,
|
|
249
|
+
affectedRoles: [],
|
|
250
|
+
affectedResources: undefinedResources
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
return {
|
|
254
|
+
policiesLoaded: policy.roles.length + policy.resources.length,
|
|
255
|
+
policiesValid: policy.roles.length + policy.resources.length - conflicts.length,
|
|
256
|
+
policiesInvalid: conflicts.length,
|
|
257
|
+
conflicts
|
|
258
|
+
};
|
|
259
|
+
}
|
|
260
|
+
async function testRoleAccess(policy, roles, resources) {
|
|
261
|
+
const results = [];
|
|
262
|
+
for (const roleName of roles) {
|
|
263
|
+
const role = policy.roles.find(r => r.name === roleName);
|
|
264
|
+
const allowedResources = [];
|
|
265
|
+
const deniedResources = [];
|
|
266
|
+
const issues = [];
|
|
267
|
+
for (const resourcePath of resources) {
|
|
268
|
+
const resource = policy.resources.find(r => r.path === resourcePath);
|
|
269
|
+
if (!resource) {
|
|
270
|
+
deniedResources.push(resourcePath);
|
|
271
|
+
continue;
|
|
272
|
+
}
|
|
273
|
+
const hasAccess = resource.allowedRoles.includes(roleName);
|
|
274
|
+
if (hasAccess) {
|
|
275
|
+
allowedResources.push(resourcePath);
|
|
276
|
+
// Check for over-permissive access
|
|
277
|
+
if (roleName === 'guest' && resourcePath.includes('admin')) {
|
|
278
|
+
issues.push({
|
|
279
|
+
severity: 'critical',
|
|
280
|
+
category: 'access-control',
|
|
281
|
+
title: 'Over-permissive access for guest role',
|
|
282
|
+
description: `Guest role has access to admin resource: ${resourcePath}`,
|
|
283
|
+
role: roleName,
|
|
284
|
+
resource: resourcePath,
|
|
285
|
+
cwe: 'CWE-269',
|
|
286
|
+
remediation: 'Restrict admin resources to admin role only'
|
|
287
|
+
});
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
else {
|
|
291
|
+
deniedResources.push(resourcePath);
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
results.push({
|
|
295
|
+
role: roleName,
|
|
296
|
+
allowedResources,
|
|
297
|
+
deniedResources,
|
|
298
|
+
permissions: role?.permissions || [],
|
|
299
|
+
issues
|
|
300
|
+
});
|
|
301
|
+
}
|
|
302
|
+
return results;
|
|
303
|
+
}
|
|
304
|
+
function buildAccessMatrix(roleAccessResults, roles, resources) {
|
|
305
|
+
const matrix = [];
|
|
306
|
+
for (let roleIdx = 0; roleIdx < roles.length; roleIdx++) {
|
|
307
|
+
const roleResult = roleAccessResults.find(r => r.role === roles[roleIdx]);
|
|
308
|
+
const row = [];
|
|
309
|
+
for (const resource of resources) {
|
|
310
|
+
const hasAccess = roleResult?.allowedResources.includes(resource) || false;
|
|
311
|
+
row.push(hasAccess);
|
|
312
|
+
}
|
|
313
|
+
matrix.push(row);
|
|
314
|
+
}
|
|
315
|
+
return {
|
|
316
|
+
resources,
|
|
317
|
+
roles,
|
|
318
|
+
matrix
|
|
319
|
+
};
|
|
320
|
+
}
|
|
321
|
+
async function testPrivilegeEscalationVulnerabilities(policy, roles) {
|
|
322
|
+
const vulnerabilities = [];
|
|
323
|
+
// Test for privilege escalation through permission combination
|
|
324
|
+
for (const roleName of roles) {
|
|
325
|
+
const role = policy.roles.find(r => r.name === roleName);
|
|
326
|
+
if (!role)
|
|
327
|
+
continue;
|
|
328
|
+
// Check if low-privilege role has admin permissions
|
|
329
|
+
if (roleName !== 'admin' && role.permissions.includes('admin')) {
|
|
330
|
+
vulnerabilities.push({
|
|
331
|
+
severity: 'critical',
|
|
332
|
+
role: roleName,
|
|
333
|
+
escalationPath: [roleName, 'admin'],
|
|
334
|
+
description: `Role "${roleName}" has admin permissions but is not an admin role`,
|
|
335
|
+
remediation: 'Remove admin permissions from non-admin roles'
|
|
336
|
+
});
|
|
337
|
+
}
|
|
338
|
+
// Check for dangerous permission combinations
|
|
339
|
+
if (role.permissions.includes('write') && role.permissions.includes('delete') && roleName === 'guest') {
|
|
340
|
+
vulnerabilities.push({
|
|
341
|
+
severity: 'high',
|
|
342
|
+
role: roleName,
|
|
343
|
+
escalationPath: [roleName, 'write+delete'],
|
|
344
|
+
description: `Guest role has dangerous permission combination: write and delete`,
|
|
345
|
+
remediation: 'Restrict write and delete permissions to authenticated users'
|
|
346
|
+
});
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
return {
|
|
350
|
+
vulnerabilitiesFound: vulnerabilities.length,
|
|
351
|
+
vulnerabilities
|
|
352
|
+
};
|
|
353
|
+
}
|
|
354
|
+
async function validateABAC(policy, resources) {
|
|
355
|
+
let attributesValidated = 0;
|
|
356
|
+
let attributesFailed = 0;
|
|
357
|
+
const issues = [];
|
|
358
|
+
for (const resource of policy.resources) {
|
|
359
|
+
if (resource.conditions) {
|
|
360
|
+
attributesValidated += resource.conditions.length;
|
|
361
|
+
for (const condition of resource.conditions) {
|
|
362
|
+
// Simulate ABAC validation
|
|
363
|
+
if (SecureRandom_js_1.SecureRandom.randomFloat() > 0.8) {
|
|
364
|
+
attributesFailed++;
|
|
365
|
+
issues.push(`ABAC condition failed for ${resource.path}: ${condition.attribute} ${condition.operator} ${condition.value}`);
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
return {
|
|
371
|
+
attributesValidated,
|
|
372
|
+
attributesFailed,
|
|
373
|
+
issues
|
|
374
|
+
};
|
|
375
|
+
}
|
|
376
|
+
async function validateInheritance(policy) {
|
|
377
|
+
const inheritanceChains = [];
|
|
378
|
+
const circularDependencies = [];
|
|
379
|
+
const issues = [];
|
|
380
|
+
for (const role of policy.roles) {
|
|
381
|
+
const inheritsFrom = role.inherits || [];
|
|
382
|
+
const totalPermissions = role.permissions.length;
|
|
383
|
+
let inheritedPermissions = 0;
|
|
384
|
+
// Calculate inherited permissions
|
|
385
|
+
for (const parentRole of inheritsFrom) {
|
|
386
|
+
const parent = policy.roles.find(r => r.name === parentRole);
|
|
387
|
+
if (parent) {
|
|
388
|
+
inheritedPermissions += parent.permissions.length;
|
|
389
|
+
}
|
|
390
|
+
else {
|
|
391
|
+
issues.push(`Role "${role.name}" inherits from undefined role "${parentRole}"`);
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
inheritanceChains.push({
|
|
395
|
+
role: role.name,
|
|
396
|
+
inheritsFrom,
|
|
397
|
+
totalPermissions,
|
|
398
|
+
inheritedPermissions
|
|
399
|
+
});
|
|
400
|
+
// Check for circular dependencies (simplified)
|
|
401
|
+
if (inheritsFrom.includes(role.name)) {
|
|
402
|
+
circularDependencies.push([role.name, role.name]);
|
|
403
|
+
issues.push(`Circular inheritance detected in role "${role.name}"`);
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
return {
|
|
407
|
+
inheritanceChains,
|
|
408
|
+
circularDependencies,
|
|
409
|
+
issues
|
|
410
|
+
};
|
|
411
|
+
}
|
|
412
|
+
function generateAuthzRecommendations(context) {
|
|
413
|
+
const recommendations = [];
|
|
414
|
+
if (context.criticalIssues > 0) {
|
|
415
|
+
recommendations.push(`URGENT: ${context.criticalIssues} critical authorization vulnerabilities require immediate attention`);
|
|
416
|
+
}
|
|
417
|
+
if (context.policyValidation.conflicts.length > 0) {
|
|
418
|
+
recommendations.push(`Resolve ${context.policyValidation.conflicts.length} policy conflicts`);
|
|
419
|
+
}
|
|
420
|
+
if (context.privilegeEscalation && context.privilegeEscalation.vulnerabilitiesFound > 0) {
|
|
421
|
+
recommendations.push('Fix privilege escalation vulnerabilities by reviewing role permissions');
|
|
422
|
+
}
|
|
423
|
+
if (context.inheritanceValidation?.circularDependencies.length) {
|
|
424
|
+
recommendations.push('Remove circular inheritance dependencies');
|
|
425
|
+
}
|
|
426
|
+
if (context.abacValidation && context.abacValidation.attributesFailed > 0) {
|
|
427
|
+
recommendations.push('Review ABAC attribute conditions for accuracy');
|
|
428
|
+
}
|
|
429
|
+
if (recommendations.length === 0) {
|
|
430
|
+
recommendations.push('Authorization configuration appears secure. Continue regular policy reviews');
|
|
431
|
+
}
|
|
432
|
+
return recommendations;
|
|
433
|
+
}
|
|
434
|
+
//# sourceMappingURL=check-authz.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-authz.js","sourceRoot":"","sources":["../../../../src/mcp/handlers/security/check-authz.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Security Report Generation Tool
|
|
3
|
+
*
|
|
4
|
+
* Generates comprehensive security reports in multiple formats (HTML, SARIF, JSON)
|
|
5
|
+
* with remediation steps, risk scoring, and compliance mapping.
|
|
6
|
+
*
|
|
7
|
+
* @module security/generate-report
|
|
8
|
+
* @version 1.0.0
|
|
9
|
+
* @author Agentic QE Team
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```typescript
|
|
13
|
+
* import { generateSecurityReport } from './generate-report';
|
|
14
|
+
*
|
|
15
|
+
* const result = await generateSecurityReport({
|
|
16
|
+
* scanResults: [sarifData, dependencyData, authData],
|
|
17
|
+
* format: 'html',
|
|
18
|
+
* includeFixes: true
|
|
19
|
+
* });
|
|
20
|
+
* ```
|
|
21
|
+
*/
|
|
22
|
+
import { BaseHandler, HandlerResponse } from '../base-handler.js';
|
|
23
|
+
export interface SecurityScanData {
|
|
24
|
+
/** Scan type */
|
|
25
|
+
scanType: 'sast' | 'dast' | 'dependencies' | 'authentication' | 'authorization' | 'comprehensive';
|
|
26
|
+
/** Scan timestamp */
|
|
27
|
+
timestamp: string;
|
|
28
|
+
/** Vulnerabilities found */
|
|
29
|
+
vulnerabilities: Array<{
|
|
30
|
+
id: string;
|
|
31
|
+
severity: 'critical' | 'high' | 'medium' | 'low';
|
|
32
|
+
title: string;
|
|
33
|
+
description: string;
|
|
34
|
+
cwe?: string;
|
|
35
|
+
cve?: string;
|
|
36
|
+
cvssScore?: number;
|
|
37
|
+
location?: {
|
|
38
|
+
file?: string;
|
|
39
|
+
line?: number;
|
|
40
|
+
};
|
|
41
|
+
recommendation: string;
|
|
42
|
+
fixSuggestion?: string;
|
|
43
|
+
}>;
|
|
44
|
+
/** Scan summary */
|
|
45
|
+
summary: {
|
|
46
|
+
totalVulnerabilities: number;
|
|
47
|
+
critical: number;
|
|
48
|
+
high: number;
|
|
49
|
+
medium: number;
|
|
50
|
+
low: number;
|
|
51
|
+
};
|
|
52
|
+
/** Additional metadata */
|
|
53
|
+
metadata?: Record<string, any>;
|
|
54
|
+
}
|
|
55
|
+
export interface GenerateSecurityReportParams {
|
|
56
|
+
/** Security scan results to include in report */
|
|
57
|
+
scanResults: SecurityScanData[];
|
|
58
|
+
/** Output format */
|
|
59
|
+
format: 'html' | 'sarif' | 'json' | 'pdf' | 'markdown';
|
|
60
|
+
/** Include fix suggestions */
|
|
61
|
+
includeFixes?: boolean;
|
|
62
|
+
/** Include compliance mapping */
|
|
63
|
+
includeCompliance?: boolean;
|
|
64
|
+
/** Compliance standards to map */
|
|
65
|
+
complianceStandards?: Array<'OWASP' | 'CWE' | 'NIST' | 'PCI-DSS' | 'HIPAA' | 'SOC2'>;
|
|
66
|
+
/** Include risk scoring */
|
|
67
|
+
includeRiskScoring?: boolean;
|
|
68
|
+
/** Include executive summary */
|
|
69
|
+
includeExecutiveSummary?: boolean;
|
|
70
|
+
/** Output file path */
|
|
71
|
+
outputPath?: string;
|
|
72
|
+
/** Report title */
|
|
73
|
+
title?: string;
|
|
74
|
+
/** Project name */
|
|
75
|
+
projectName?: string;
|
|
76
|
+
}
|
|
77
|
+
export interface SecurityReport {
|
|
78
|
+
/** Report metadata */
|
|
79
|
+
metadata: {
|
|
80
|
+
title: string;
|
|
81
|
+
projectName: string;
|
|
82
|
+
generatedAt: string;
|
|
83
|
+
reportVersion: string;
|
|
84
|
+
format: string;
|
|
85
|
+
};
|
|
86
|
+
/** Executive summary */
|
|
87
|
+
executiveSummary?: {
|
|
88
|
+
overallRiskLevel: 'critical' | 'high' | 'medium' | 'low';
|
|
89
|
+
totalVulnerabilities: number;
|
|
90
|
+
criticalVulnerabilities: number;
|
|
91
|
+
highVulnerabilities: number;
|
|
92
|
+
recommendations: string[];
|
|
93
|
+
complianceStatus?: Record<string, 'compliant' | 'non-compliant' | 'partial'>;
|
|
94
|
+
};
|
|
95
|
+
/** Detailed findings */
|
|
96
|
+
findings: {
|
|
97
|
+
bySeverity: Record<'critical' | 'high' | 'medium' | 'low', SecurityScanData['vulnerabilities']>;
|
|
98
|
+
byScanType: Record<string, SecurityScanData['vulnerabilities']>;
|
|
99
|
+
byCompliance?: Record<string, SecurityScanData['vulnerabilities']>;
|
|
100
|
+
};
|
|
101
|
+
/** Risk scoring */
|
|
102
|
+
riskScoring?: {
|
|
103
|
+
overallScore: number;
|
|
104
|
+
categoryScores: Record<string, number>;
|
|
105
|
+
trendAnalysis?: {
|
|
106
|
+
previousScore?: number;
|
|
107
|
+
trend: 'improving' | 'declining' | 'stable';
|
|
108
|
+
change: number;
|
|
109
|
+
};
|
|
110
|
+
};
|
|
111
|
+
/** Remediation plan */
|
|
112
|
+
remediationPlan: {
|
|
113
|
+
immediate: Array<{
|
|
114
|
+
vulnerability: string;
|
|
115
|
+
action: string;
|
|
116
|
+
priority: number;
|
|
117
|
+
estimatedEffort: string;
|
|
118
|
+
}>;
|
|
119
|
+
shortTerm: Array<{
|
|
120
|
+
vulnerability: string;
|
|
121
|
+
action: string;
|
|
122
|
+
priority: number;
|
|
123
|
+
estimatedEffort: string;
|
|
124
|
+
}>;
|
|
125
|
+
longTerm: Array<{
|
|
126
|
+
vulnerability: string;
|
|
127
|
+
action: string;
|
|
128
|
+
priority: number;
|
|
129
|
+
estimatedEffort: string;
|
|
130
|
+
}>;
|
|
131
|
+
};
|
|
132
|
+
/** Compliance mapping */
|
|
133
|
+
complianceMapping?: Record<string, {
|
|
134
|
+
standard: string;
|
|
135
|
+
requirements: Array<{
|
|
136
|
+
requirement: string;
|
|
137
|
+
status: 'met' | 'not-met' | 'partial';
|
|
138
|
+
relatedVulnerabilities: string[];
|
|
139
|
+
}>;
|
|
140
|
+
}>;
|
|
141
|
+
/** Report content */
|
|
142
|
+
content: string;
|
|
143
|
+
/** Output file path */
|
|
144
|
+
outputPath?: string;
|
|
145
|
+
}
|
|
146
|
+
export declare class GenerateSecurityReportHandler extends BaseHandler {
|
|
147
|
+
handle(args: GenerateSecurityReportParams): Promise<HandlerResponse>;
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Generate comprehensive security report
|
|
151
|
+
*
|
|
152
|
+
* @param params - Report generation parameters
|
|
153
|
+
* @returns Generated security report with remediation plan
|
|
154
|
+
*/
|
|
155
|
+
export declare function generateSecurityReport(params: GenerateSecurityReportParams): Promise<SecurityReport>;
|
|
156
|
+
//# sourceMappingURL=generate-report.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate-report.d.ts","sourceRoot":"","sources":["../../../../src/mcp/handlers/security/generate-report.ts"],"names":[],"mappings":"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"}
|