0xray 2.0.0 → 2.0.1
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/.opencode/codex.codex +2 -2
- package/.opencode/commands/dependency-audit.md +3 -3
- package/.opencode/enforcer-config.json +2 -2
- package/.opencode/init.sh +22 -19
- package/AGENTS.md +5 -5
- package/README.md +276 -76
- package/dist/AGENTS.md +5 -5
- package/dist/CHANGELOG.md +91 -10
- package/dist/README.md +276 -76
- package/dist/agents/architect.d.ts +2 -0
- package/dist/agents/backend-engineer.d.ts +8 -0
- package/dist/agents/bug-triage-specialist.d.ts +2 -0
- package/dist/agents/code-analyzer.d.ts +7 -0
- package/dist/agents/code-reviewer.d.ts +2 -0
- package/dist/agents/code-reviewer.js +1 -1
- package/dist/agents/content-creator.d.ts +9 -0
- package/dist/agents/database-engineer.d.ts +8 -0
- package/dist/agents/devops-engineer.d.ts +8 -0
- package/dist/agents/frontend-engineer.d.ts +8 -0
- package/dist/agents/frontend-ui-ux-engineer.d.ts +8 -0
- package/dist/agents/growth-strategist.d.ts +8 -0
- package/dist/agents/index.d.ts +24 -0
- package/dist/agents/librarian-agents-updater.d.ts +30 -0
- package/dist/agents/log-monitor.d.ts +2 -0
- package/dist/agents/mobile-developer.d.ts +9 -0
- package/dist/agents/multimodal-looker.d.ts +9 -0
- package/dist/agents/performance-engineer.d.ts +8 -0
- package/dist/agents/refactorer.d.ts +2 -0
- package/dist/agents/registry.d.ts +35 -0
- package/dist/agents/researcher.d.ts +2 -0
- package/dist/agents/security-auditor.d.ts +2 -0
- package/dist/agents/seo-consultant.d.ts +8 -0
- package/dist/agents/strategist.d.ts +7 -0
- package/dist/agents/tech-writer.d.ts +8 -0
- package/dist/agents/testing-lead.d.ts +2 -0
- package/dist/agents/types.d.ts +45 -0
- package/dist/analytics/consent-manager.d.ts +93 -0
- package/dist/analytics/emerging-pattern-detector.d.ts +67 -0
- package/dist/analytics/pattern-learning-engine.d.ts +80 -0
- package/dist/analytics/pattern-performance-tracker.d.ts +97 -0
- package/dist/analytics/predictive-analytics.d.ts +41 -0
- package/dist/analytics/prompt-pattern-analyzer.d.ts +99 -0
- package/dist/analytics/routing-performance-analyzer.d.ts +101 -0
- package/dist/analytics/routing-refiner.d.ts +104 -0
- package/dist/analytics/routing-refiner.js +1 -1
- package/dist/analytics/simple-pattern-analyzer.d.ts +80 -0
- package/dist/architect/architect-tools.d.ts +70 -0
- package/dist/architect/architectural-integrity.d.ts +20 -0
- package/dist/benchmark/performance-benchmark.d.ts +103 -0
- package/dist/cli/commands/analytics-disable.d.ts +9 -0
- package/dist/cli/commands/analytics-enable-action.d.ts +8 -0
- package/dist/cli/commands/analytics-preview.d.ts +9 -0
- package/dist/cli/commands/analytics-status.d.ts +9 -0
- package/dist/cli/commands/antigravity-status.d.ts +9 -0
- package/dist/cli/commands/archive-logs.d.ts +24 -0
- package/dist/cli/commands/credible-init.d.ts +11 -0
- package/dist/cli/commands/grok-install.d.ts +7 -0
- package/dist/cli/commands/hermes-install.d.ts +2 -0
- package/dist/cli/commands/mcp-install.d.ts +4 -0
- package/dist/cli/commands/openclaw-install.d.ts +2 -0
- package/dist/cli/commands/opencode-install.d.ts +2 -0
- package/dist/cli/commands/plugin-commands.d.ts +19 -0
- package/dist/cli/commands/publish-agent.d.ts +15 -0
- package/dist/cli/commands/security-audit.d.ts +23 -0
- package/dist/cli/commands/skill-install.d.ts +5 -0
- package/dist/cli/commands/status.d.ts +41 -0
- package/dist/cli/commands/storyteller.d.ts +19 -0
- package/dist/cli/index.d.ts +7 -0
- package/dist/cli/server.d.ts +1 -0
- package/dist/config/default-agents.d.ts +12 -0
- package/dist/core/activity-logger.d.ts +72 -0
- package/dist/core/adaptive-kernel.d.ts +109 -0
- package/dist/core/agent-spawn-gate.d.ts +56 -0
- package/dist/core/boot-orchestrator.d.ts +99 -0
- package/dist/core/boot-orchestrator.js +2 -2
- package/dist/core/codex-formatter.d.ts +96 -0
- package/dist/core/codex-injector.d.ts +74 -0
- package/dist/core/config-loader.d.ts +70 -0
- package/dist/core/config-paths.d.ts +61 -0
- package/dist/core/context-loader.d.ts +121 -0
- package/dist/core/context-validator.d.ts +53 -0
- package/dist/core/features-config.d.ts +462 -0
- package/dist/core/features-config.js +1 -1
- package/dist/core/framework-logger.d.ts +76 -0
- package/dist/core/index.d.ts +5 -0
- package/dist/core/kernel-patterns.d.ts +130 -0
- package/dist/core/logging-config.d.ts +10 -0
- package/dist/core/model-router.d.ts +61 -0
- package/dist/core/orchestrator.d.ts +71 -0
- package/dist/core/system-prompt-generator.d.ts +35 -0
- package/dist/core/trace-context.d.ts +12 -0
- package/dist/core/xray-activation.d.ts +14 -0
- package/dist/delegation/agent-delegator.d.ts +186 -0
- package/dist/delegation/agent-expertise.d.ts +16 -0
- package/dist/delegation/analytics/index.d.ts +12 -0
- package/dist/delegation/analytics/learning-engine.d.ts +85 -0
- package/dist/delegation/analytics/outcome-tracker.d.ts +118 -0
- package/dist/delegation/analytics/routing-analytics.d.ts +61 -0
- package/dist/delegation/ast-code-parser.d.ts +174 -0
- package/dist/delegation/codebase-context-analyzer.d.ts +164 -0
- package/dist/delegation/complexity-analyzer.d.ts +111 -0
- package/dist/delegation/complexity-core.d.ts +119 -0
- package/dist/delegation/config/types.d.ts +247 -0
- package/dist/delegation/dependency-graph-builder.d.ts +95 -0
- package/dist/delegation/index.d.ts +25 -0
- package/dist/delegation/metrics-aggregator.d.ts +92 -0
- package/dist/delegation/session-coordinator.d.ts +133 -0
- package/dist/delegation/strategy-selector.d.ts +28 -0
- package/dist/delegation/voting-coordinator.d.ts +49 -0
- package/dist/delegation/voting-types.d.ts +155 -0
- package/dist/delegation/weighted-voting-aggregator.d.ts +37 -0
- package/dist/enforcement/core/index.d.ts +15 -0
- package/dist/enforcement/core/rule-executor.d.ts +158 -0
- package/dist/enforcement/core/rule-hierarchy.d.ts +146 -0
- package/dist/enforcement/core/rule-registry.d.ts +197 -0
- package/dist/enforcement/core/violation-fixer.d.ts +106 -0
- package/dist/enforcement/enforcer-tools.d.ts +78 -0
- package/dist/enforcement/index.d.ts +23 -0
- package/dist/enforcement/loaders/agent-triage-loader.d.ts +99 -0
- package/dist/enforcement/loaders/agents-md-validation-loader.d.ts +76 -0
- package/dist/enforcement/loaders/base-loader.d.ts +83 -0
- package/dist/enforcement/loaders/codex-loader.d.ts +77 -0
- package/dist/enforcement/loaders/index.d.ts +37 -0
- package/dist/enforcement/loaders/loader-orchestrator.d.ts +97 -0
- package/dist/enforcement/loaders/processor-loader.d.ts +60 -0
- package/dist/enforcement/rule-enforcer.d.ts +142 -0
- package/dist/enforcement/test-auto-healing.d.ts +83 -0
- package/dist/enforcement/types.d.ts +501 -0
- package/dist/enforcement/validators/architecture-validators.d.ts +155 -0
- package/dist/enforcement/validators/base-validator.d.ts +88 -0
- package/dist/enforcement/validators/code-quality-validators.d.ts +89 -0
- package/dist/enforcement/validators/index.d.ts +15 -0
- package/dist/enforcement/validators/security-validators.d.ts +53 -0
- package/dist/enforcement/validators/testing-validators.d.ts +81 -0
- package/dist/enforcement/validators/validator-registry.d.ts +92 -0
- package/dist/execution/opencode-cli-invoker.d.ts +8 -0
- package/dist/execution/proposal-applier.d.ts +24 -0
- package/dist/governance/codex-policy.service.d.ts +57 -0
- package/dist/governance/governance-core.d.ts +46 -0
- package/dist/governance/governance-service.d.ts +38 -0
- package/dist/governance/governance-types.d.ts +83 -0
- package/dist/index.d.ts +28 -0
- package/dist/inference/deploy-verifier.d.ts +26 -0
- package/dist/inference/index.d.ts +10 -0
- package/dist/inference/inference-accumulator.d.ts +29 -0
- package/dist/inference/inference-cycle.d.ts +110 -0
- package/dist/inference/semantic-patterns.d.ts +7 -0
- package/dist/inference/session-capture.d.ts +32 -0
- package/dist/integrations/base/ExampleIntegration.d.ts +47 -0
- package/dist/integrations/base/Integration.d.ts +267 -0
- package/dist/integrations/base/index.d.ts +12 -0
- package/dist/integrations/base/registry.d.ts +273 -0
- package/dist/integrations/base/types.d.ts +168 -0
- package/dist/integrations/governance/governance-client.d.ts +76 -0
- package/dist/integrations/governance/index.d.ts +99 -0
- package/dist/integrations/governance/types.d.ts +239 -0
- package/dist/integrations/grok/grok-cli.d.ts +25 -0
- package/dist/integrations/hermes-agent/__init__.py +1 -1
- package/dist/integrations/openclaw/api-server.d.ts +87 -0
- package/dist/integrations/openclaw/client.d.ts +122 -0
- package/dist/integrations/openclaw/config.d.ts +96 -0
- package/dist/integrations/openclaw/hooks/strray-hooks.d.ts +124 -0
- package/dist/integrations/openclaw/index.d.ts +101 -0
- package/dist/integrations/openclaw/types.d.ts +426 -0
- package/dist/integrations/plugins/index.d.ts +10 -0
- package/dist/integrations/plugins/plugin-integration.d.ts +289 -0
- package/dist/integrations/plugins/plugin-registry.d.ts +224 -0
- package/dist/mcps/agent-resolver.d.ts +46 -0
- package/dist/mcps/architect-tools.server.d.ts +17 -0
- package/dist/mcps/architect-tools.server.js +1 -1
- package/dist/mcps/auto-format.server.d.ts +19 -0
- package/dist/mcps/auto-format.server.js +1 -1
- package/dist/mcps/boot-orchestrator.server.d.ts +49 -0
- package/dist/mcps/boot-orchestrator.server.js +1 -1
- package/dist/mcps/config/config-loader.d.ts +52 -0
- package/dist/mcps/config/config-validator.d.ts +40 -0
- package/dist/mcps/config/index.d.ts +31 -0
- package/dist/mcps/config/plugin-server-registry.d.ts +127 -0
- package/dist/mcps/config/server-config-registry.d.ts +51 -0
- package/dist/mcps/connection/connection-manager.d.ts +39 -0
- package/dist/mcps/connection/connection-pool.d.ts +64 -0
- package/dist/mcps/connection/mcp-connection.d.ts +66 -0
- package/dist/mcps/connection/process-spawner.d.ts +24 -0
- package/dist/mcps/enforcer-tools.server.d.ts +27 -0
- package/dist/mcps/enforcer-tools.server.js +1 -1
- package/dist/mcps/estimation.server.d.ts +21 -0
- package/dist/mcps/estimation.server.js +1 -1
- package/dist/mcps/framework-compliance-audit.server.d.ts +22 -0
- package/dist/mcps/framework-compliance-audit.server.js +1 -1
- package/dist/mcps/framework-help.server.d.ts +14 -0
- package/dist/mcps/framework-help.server.js +1 -1
- package/dist/mcps/governance.server.d.ts +33 -0
- package/dist/mcps/in-process-skill-registry.d.ts +20 -0
- package/dist/mcps/knowledge-skills/api-design.server.d.ts +15 -0
- package/dist/mcps/knowledge-skills/api-design.server.js +1 -1
- package/dist/mcps/knowledge-skills/architecture-patterns.server.d.ts +15 -0
- package/dist/mcps/knowledge-skills/architecture-patterns.server.js +1 -1
- package/dist/mcps/knowledge-skills/bug-triage-specialist.server.d.ts +33 -0
- package/dist/mcps/knowledge-skills/bug-triage-specialist.server.js +1 -1
- package/dist/mcps/knowledge-skills/code-analyzer.server.d.ts +31 -0
- package/dist/mcps/knowledge-skills/code-analyzer.server.js +1 -1
- package/dist/mcps/knowledge-skills/code-review.server.d.ts +46 -0
- package/dist/mcps/knowledge-skills/code-review.server.js +1 -1
- package/dist/mcps/knowledge-skills/content-creator.server.d.ts +13 -0
- package/dist/mcps/knowledge-skills/content-creator.server.js +1 -1
- package/dist/mcps/knowledge-skills/database-design.server.d.ts +43 -0
- package/dist/mcps/knowledge-skills/database-design.server.js +1 -1
- package/dist/mcps/knowledge-skills/devops-deployment.server.d.ts +43 -0
- package/dist/mcps/knowledge-skills/devops-deployment.server.js +1 -1
- package/dist/mcps/knowledge-skills/git-workflow.server.d.ts +15 -0
- package/dist/mcps/knowledge-skills/git-workflow.server.js +1 -1
- package/dist/mcps/knowledge-skills/growth-strategist.server.d.ts +13 -0
- package/dist/mcps/knowledge-skills/growth-strategist.server.js +1 -1
- package/dist/mcps/knowledge-skills/log-monitor.server.d.ts +24 -0
- package/dist/mcps/knowledge-skills/log-monitor.server.js +1 -1
- package/dist/mcps/knowledge-skills/mobile-development.server.d.ts +19 -0
- package/dist/mcps/knowledge-skills/mobile-development.server.js +1 -1
- package/dist/mcps/knowledge-skills/multimodal-looker.server.d.ts +55 -0
- package/dist/mcps/knowledge-skills/multimodal-looker.server.js +3 -2
- package/dist/mcps/knowledge-skills/performance-optimization.server.d.ts +72 -0
- package/dist/mcps/knowledge-skills/performance-optimization.server.js +1 -1
- package/dist/mcps/knowledge-skills/project-analysis.server.d.ts +37 -0
- package/dist/mcps/knowledge-skills/project-analysis.server.js +1 -1
- package/dist/mcps/knowledge-skills/refactoring-strategies.server.d.ts +33 -0
- package/dist/mcps/knowledge-skills/refactoring-strategies.server.js +1 -1
- package/dist/mcps/knowledge-skills/security-audit.server.d.ts +48 -0
- package/dist/mcps/knowledge-skills/security-audit.server.js +1 -1
- package/dist/mcps/knowledge-skills/seo-consultant.server.d.ts +26 -0
- package/dist/mcps/knowledge-skills/seo-consultant.server.js +1 -1
- package/dist/mcps/knowledge-skills/session-management.server.d.ts +23 -0
- package/dist/mcps/knowledge-skills/session-management.server.js +1 -1
- package/dist/mcps/knowledge-skills/skill-invocation.server.d.ts +29 -0
- package/dist/mcps/knowledge-skills/skill-invocation.server.js +1 -1
- package/dist/mcps/knowledge-skills/strategist.server.d.ts +17 -0
- package/dist/mcps/knowledge-skills/strategist.server.js +1 -1
- package/dist/mcps/knowledge-skills/tech-writer.server.d.ts +47 -0
- package/dist/mcps/knowledge-skills/tech-writer.server.js +2 -2
- package/dist/mcps/knowledge-skills/testing-best-practices.server.d.ts +36 -0
- package/dist/mcps/knowledge-skills/testing-best-practices.server.js +1 -1
- package/dist/mcps/knowledge-skills/testing-strategy.server.d.ts +47 -0
- package/dist/mcps/knowledge-skills/testing-strategy.server.js +1 -1
- package/dist/mcps/knowledge-skills/ui-ux-design.server.d.ts +69 -0
- package/dist/mcps/knowledge-skills/ui-ux-design.server.js +1 -1
- package/dist/mcps/lint.server.d.ts +17 -0
- package/dist/mcps/lint.server.js +1 -1
- package/dist/mcps/mcp-client.d.ts +157 -0
- package/dist/mcps/model-health-check.server.d.ts +16 -0
- package/dist/mcps/model-health-check.server.js +1 -1
- package/dist/mcps/orchestrator/config/agent-capabilities.d.ts +35 -0
- package/dist/mcps/orchestrator/execution/execution-planner.d.ts +62 -0
- package/dist/mcps/orchestrator/handlers/complexity-handler.d.ts +32 -0
- package/dist/mcps/orchestrator/handlers/status-handler.d.ts +69 -0
- package/dist/mcps/orchestrator/handlers/task-handler.d.ts +52 -0
- package/dist/mcps/orchestrator/server.d.ts +38 -0
- package/dist/mcps/orchestrator/types.d.ts +79 -0
- package/dist/mcps/orchestrator.server.d.ts +10 -0
- package/dist/mcps/performance-analysis.server.d.ts +27 -0
- package/dist/mcps/performance-analysis.server.js +1 -1
- package/dist/mcps/processor-pipeline.server.d.ts +31 -0
- package/dist/mcps/processor-pipeline.server.js +1 -1
- package/dist/mcps/protocol/protocol-constants.d.ts +46 -0
- package/dist/mcps/registry.json +1 -1
- package/dist/mcps/researcher.server.d.ts +31 -0
- package/dist/mcps/researcher.server.js +1 -1
- package/dist/mcps/security-scan.server.d.ts +20 -0
- package/dist/mcps/security-scan.server.js +1 -1
- package/dist/mcps/simulation/index.d.ts +12 -0
- package/dist/mcps/simulation/server-simulations.d.ts +39 -0
- package/dist/mcps/simulation/simulation-engine.d.ts +51 -0
- package/dist/mcps/state-manager.server.d.ts +28 -0
- package/dist/mcps/state-manager.server.js +1 -1
- package/dist/mcps/tools/index.d.ts +14 -0
- package/dist/mcps/tools/tool-cache.d.ts +53 -0
- package/dist/mcps/tools/tool-discovery.d.ts +27 -0
- package/dist/mcps/tools/tool-executor.d.ts +41 -0
- package/dist/mcps/tools/tool-registry.d.ts +42 -0
- package/dist/mcps/types/index.d.ts +13 -0
- package/dist/mcps/types/json-rpc.types.d.ts +35 -0
- package/dist/mcps/types/mcp.types.d.ts +105 -0
- package/dist/metrics/agent-metrics.d.ts +169 -0
- package/dist/metrics/index.d.ts +6 -0
- package/dist/monitoring/advanced-profiler.d.ts +51 -0
- package/dist/monitoring/memory-monitor.d.ts +113 -0
- package/dist/monitoring/nudge-watchdog.d.ts +88 -0
- package/dist/monitoring/test-auto-generation-monitor.d.ts +64 -0
- package/dist/orchestrator/agent-spawn-governor.d.ts +127 -0
- package/dist/orchestrator/enhanced-multi-agent-orchestrator.d.ts +156 -0
- package/dist/orchestrator/intelligent-commit-batcher.d.ts +114 -0
- package/dist/orchestrator/multi-agent-orchestration-coordinator.d.ts +127 -0
- package/dist/orchestrator/orchestrator.d.ts +142 -0
- package/dist/orchestrator/self-direction-activation.d.ts +109 -0
- package/dist/orchestrator/universal-librarian-consultation.d.ts +98 -0
- package/dist/orchestrator/universal-registry-bridge.d.ts +85 -0
- package/dist/orchestrator/universal-registry-bridge.js +1 -1
- package/dist/performance/performance-budget-enforcer.d.ts +158 -0
- package/dist/performance/performance-regression-tester.d.ts +108 -0
- package/dist/plugin/xray-codex-injection.d.ts +55 -0
- package/dist/plugin/xray-codex-injection.js +7 -7
- package/dist/postprocessor/PostProcessor.d.ts +108 -0
- package/dist/postprocessor/analysis/FailureAnalysisEngine.d.ts +39 -0
- package/dist/postprocessor/autofix/AutoFixEngine.d.ts +48 -0
- package/dist/postprocessor/autofix/FixValidator.d.ts +23 -0
- package/dist/postprocessor/config.d.ts +6 -0
- package/dist/postprocessor/escalation/EscalationEngine.d.ts +154 -0
- package/dist/postprocessor/monitoring/MonitoringEngine.d.ts +40 -0
- package/dist/postprocessor/redeploy/RedeployCoordinator.d.ts +91 -0
- package/dist/postprocessor/services/RegressionAnalysisService.d.ts +40 -0
- package/dist/postprocessor/success/SuccessHandler.d.ts +57 -0
- package/dist/postprocessor/triggers/APITrigger.d.ts +35 -0
- package/dist/postprocessor/triggers/GitHookTrigger.d.ts +38 -0
- package/dist/postprocessor/triggers/WebhookTrigger.d.ts +47 -0
- package/dist/postprocessor/types.d.ts +227 -0
- package/dist/processors/doc-write-guard.d.ts +6 -0
- package/dist/processors/implementations/agents-md-validation-processor.d.ts +63 -0
- package/dist/processors/implementations/async-pattern-processor.d.ts +48 -0
- package/dist/processors/implementations/codex-compliance-processor.d.ts +7 -0
- package/dist/processors/implementations/commit-batcher-processor.d.ts +13 -0
- package/dist/processors/implementations/console-log-guard-processor.d.ts +33 -0
- package/dist/processors/implementations/coverage-analysis-processor.d.ts +20 -0
- package/dist/processors/implementations/error-boundary-processor.d.ts +7 -0
- package/dist/processors/implementations/inference-improvement-processor.d.ts +36 -0
- package/dist/processors/implementations/log-protection-processor.d.ts +30 -0
- package/dist/processors/implementations/nudge-processor.d.ts +22 -0
- package/dist/processors/implementations/performance-budget-processor.d.ts +50 -0
- package/dist/processors/implementations/postprocessor-chain-validator.d.ts +46 -0
- package/dist/processors/implementations/pre-validate-processor.d.ts +7 -0
- package/dist/processors/implementations/publish-preflight-processor.d.ts +38 -0
- package/dist/processors/implementations/refactoring-logging-processor-wrapper.d.ts +7 -0
- package/dist/processors/implementations/refactoring-logging-processor.d.ts +31 -0
- package/dist/processors/implementations/regression-testing-processor.d.ts +20 -0
- package/dist/processors/implementations/session-capture-processor.d.ts +14 -0
- package/dist/processors/implementations/session-summary-processor.d.ts +27 -0
- package/dist/processors/implementations/spawn-governance-processor.d.ts +58 -0
- package/dist/processors/implementations/state-validation-processor.d.ts +11 -0
- package/dist/processors/implementations/storytelling-trigger-processor.d.ts +42 -0
- package/dist/processors/implementations/test-auto-creation-processor.d.ts +17 -0
- package/dist/processors/implementations/test-execution-processor.d.ts +11 -0
- package/dist/processors/implementations/typescript-compilation-processor.d.ts +38 -0
- package/dist/processors/implementations/version-compliance-processor.d.ts +112 -0
- package/dist/processors/processor-interfaces.d.ts +127 -0
- package/dist/processors/processor-manager.d.ts +80 -0
- package/dist/processors/processor-types.d.ts +190 -0
- package/dist/reporting/framework-reporting-system.d.ts +19 -0
- package/dist/reporting/log-parser.d.ts +10 -0
- package/dist/reporting/metrics.d.ts +15 -0
- package/dist/reporting/report-formatter.d.ts +5 -0
- package/dist/reporting/types.d.ts +102 -0
- package/dist/scripts/activate-kernel-pipeline.d.ts +7 -0
- package/dist/scripts/integration.d.ts +37 -0
- package/dist/security/comprehensive-security-audit.d.ts +158 -0
- package/dist/security/index.d.ts +13 -0
- package/dist/security/prompt-security-validator.d.ts +44 -0
- package/dist/security/security-agent-coordinator.d.ts +72 -0
- package/dist/security/security-auditor.d.ts +56 -0
- package/dist/security/security-hardener.d.ts +62 -0
- package/dist/security/security-hardening-system.d.ts +239 -0
- package/dist/security/security-headers.d.ts +64 -0
- package/dist/security/security-orchestration-layer.d.ts +119 -0
- package/dist/security/security-scanner.d.ts +119 -0
- package/dist/services/inference-tuner.d.ts +77 -0
- package/dist/session/index.d.ts +3 -0
- package/dist/session/session-cleanup-manager.d.ts +118 -0
- package/dist/session/session-monitor.d.ts +133 -0
- package/dist/session/session-state-manager.d.ts +145 -0
- package/dist/skills/registry.json +1 -1
- package/dist/state/context-providers.d.ts +4 -0
- package/dist/state/index.d.ts +4 -0
- package/dist/state/state-manager.d.ts +42 -0
- package/dist/state/state-types.d.ts +5 -0
- package/dist/testing/memory-regression-suite.d.ts +105 -0
- package/dist/utils/batch-operations.d.ts +25 -0
- package/dist/utils/codex-parser.d.ts +61 -0
- package/dist/utils/command-runner.d.ts +32 -0
- package/dist/utils/import-resolver.d.ts +54 -0
- package/dist/utils/language-detector.d.ts +44 -0
- package/dist/utils/path-resolver.d.ts +48 -0
- package/dist/utils/shutdown-handler.d.ts +27 -0
- package/dist/utils/test-template-generator.d.ts +25 -0
- package/dist/utils/token-manager.d.ts +48 -0
- package/dist/validation/estimation-validator.d.ts +61 -0
- package/dist/validation/report-content-validator.d.ts +42 -0
- package/package.json +3 -2
- package/scripts/node/universal-version-manager.js +53 -54
- package/src/mcps/architect-tools.server.ts +1 -1
- package/src/mcps/auto-format.server.ts +1 -1
- package/src/mcps/boot-orchestrator.server.ts +1 -1
- package/src/mcps/enforcer-tools.server.ts +1 -1
- package/src/mcps/estimation.server.ts +1 -1
- package/src/mcps/framework-compliance-audit.server.ts +1 -1
- package/src/mcps/framework-help.server.ts +1 -1
- package/src/mcps/knowledge-skills/api-design.server.ts +1 -1
- package/src/mcps/knowledge-skills/architecture-patterns.server.ts +1 -1
- package/src/mcps/knowledge-skills/bug-triage-specialist.server.ts +1 -1
- package/src/mcps/knowledge-skills/code-analyzer.server.ts +1 -1
- package/src/mcps/knowledge-skills/code-review.server.ts +1 -1
- package/src/mcps/knowledge-skills/content-creator.server.ts +1 -1
- package/src/mcps/knowledge-skills/database-design.server.ts +1 -1
- package/src/mcps/knowledge-skills/devops-deployment.server.ts +1 -1
- package/src/mcps/knowledge-skills/git-workflow.server.ts +1 -1
- package/src/mcps/knowledge-skills/growth-strategist.server.ts +1 -1
- package/src/mcps/knowledge-skills/log-monitor.server.ts +1 -1
- package/src/mcps/knowledge-skills/mobile-development.server.ts +1 -1
- package/src/mcps/knowledge-skills/multimodal-looker.server.ts +3 -2
- package/src/mcps/knowledge-skills/performance-optimization.server.ts +1 -1
- package/src/mcps/knowledge-skills/project-analysis.server.ts +1 -1
- package/src/mcps/knowledge-skills/refactoring-strategies.server.ts +1 -1
- package/src/mcps/knowledge-skills/security-audit.server.ts +1 -1
- package/src/mcps/knowledge-skills/seo-consultant.server.ts +1 -1
- package/src/mcps/knowledge-skills/session-management.server.ts +1 -1
- package/src/mcps/knowledge-skills/skill-invocation.server.ts +1 -1
- package/src/mcps/knowledge-skills/strategist.server.ts +1 -1
- package/src/mcps/knowledge-skills/tech-writer.server.ts +2 -2
- package/src/mcps/knowledge-skills/testing-best-practices.server.ts +1 -1
- package/src/mcps/knowledge-skills/testing-strategy.server.ts +1 -1
- package/src/mcps/knowledge-skills/ui-ux-design.server.ts +1 -1
- package/src/mcps/lint.server.ts +1 -1
- package/src/mcps/model-health-check.server.ts +1 -1
- package/src/mcps/performance-analysis.server.ts +1 -1
- package/src/mcps/processor-pipeline.server.ts +1 -1
- package/src/mcps/registry.json +1 -1
- package/src/mcps/researcher.server.ts +1 -1
- package/src/mcps/security-scan.server.ts +1 -1
- package/src/mcps/state-manager.server.ts +1 -1
- package/src/opencode/codex.codex +2 -2
- package/src/opencode/commands/dependency-audit.md +3 -3
- package/src/opencode/enforcer-config.json +2 -2
- package/src/skills/registry.json +1 -1
- package/.opencode/hooks/hook-metrics.json +0 -380
- package/.opencode/skills/api-design/SKILL.md +0 -37
- package/.opencode/skills/architect-tools/SKILL.md +0 -37
- package/.opencode/skills/architecture-patterns/SKILL.md +0 -37
- package/.opencode/skills/auto-format/SKILL.md +0 -37
- package/.opencode/skills/backend-engineer/SKILL.md +0 -49
- package/.opencode/skills/boot-orchestrator/SKILL.md +0 -37
- package/.opencode/skills/bug-triage/SKILL.md +0 -43
- package/.opencode/skills/code-analyzer/SKILL.md +0 -45
- package/.opencode/skills/code-review/SKILL.md +0 -52
- package/.opencode/skills/content-creator/SKILL.md +0 -38
- package/.opencode/skills/database-engineer/SKILL.md +0 -46
- package/.opencode/skills/devops-engineer/SKILL.md +0 -49
- package/.opencode/skills/enforcer/SKILL.md +0 -37
- package/.opencode/skills/framework-compliance-audit/SKILL.md +0 -37
- package/.opencode/skills/frontend-engineer/SKILL.md +0 -49
- package/.opencode/skills/frontend-ui-ux-engineer/SKILL.md +0 -41
- package/.opencode/skills/git-workflow/SKILL.md +0 -37
- package/.opencode/skills/growth-strategist/SKILL.md +0 -48
- package/.opencode/skills/hermes-agent/SKILL.md +0 -212
- package/.opencode/skills/inference-improve/SKILL.md +0 -97
- package/.opencode/skills/lint/SKILL.md +0 -37
- package/.opencode/skills/log-monitor/SKILL.md +0 -44
- package/.opencode/skills/mobile-developer/SKILL.md +0 -42
- package/.opencode/skills/model-health-check/SKILL.md +0 -37
- package/.opencode/skills/multimodal-looker/SKILL.md +0 -45
- package/.opencode/skills/orchestrator/SKILL.md +0 -37
- package/.opencode/skills/performance-analysis/SKILL.md +0 -37
- package/.opencode/skills/performance-engineer/SKILL.md +0 -41
- package/.opencode/skills/performance-optimization/SKILL.md +0 -37
- package/.opencode/skills/processor-pipeline/SKILL.md +0 -37
- package/.opencode/skills/project-analysis/SKILL.md +0 -42
- package/.opencode/skills/refactoring-strategies/SKILL.md +0 -37
- package/.opencode/skills/registry.json +0 -66
- package/.opencode/skills/researcher/SKILL.md +0 -37
- package/.opencode/skills/security-audit/SKILL.md +0 -47
- package/.opencode/skills/security-scan/SKILL.md +0 -37
- package/.opencode/skills/seo-consultant/SKILL.md +0 -43
- package/.opencode/skills/session-management/SKILL.md +0 -36
- package/.opencode/skills/state-manager/SKILL.md +0 -37
- package/.opencode/skills/storyteller/SKILL.md +0 -130
- package/.opencode/skills/strategist/SKILL.md +0 -32
- package/.opencode/skills/tech-writer/SKILL.md +0 -37
- package/.opencode/skills/testing-best-practices/SKILL.md +0 -37
- package/.opencode/skills/testing-strategy/SKILL.md +0 -43
- package/.opencode/skills/ui-ux-design/SKILL.md +0 -603
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rule Registry - Storage and management for validation rules
|
|
3
|
+
*
|
|
4
|
+
* This class separates rule storage concerns from rule execution.
|
|
5
|
+
* It provides a centralized registry for adding, retrieving, and
|
|
6
|
+
* managing rule definitions with lifecycle operations.
|
|
7
|
+
*
|
|
8
|
+
* @module enforcement/core
|
|
9
|
+
* @version 1.0.0
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```typescript
|
|
13
|
+
* const registry = new RuleRegistry();
|
|
14
|
+
* registry.addRule({
|
|
15
|
+
* id: "no-console",
|
|
16
|
+
* name: "No Console Logs",
|
|
17
|
+
* description: "Prevents console.log usage",
|
|
18
|
+
* category: "code-quality",
|
|
19
|
+
* severity: "warning",
|
|
20
|
+
* enabled: true,
|
|
21
|
+
* validator: async (ctx) => ({ passed: true, message: "OK" })
|
|
22
|
+
* });
|
|
23
|
+
* ```
|
|
24
|
+
*/
|
|
25
|
+
import { RuleDefinition, IRuleRegistry } from "../types.js";
|
|
26
|
+
/**
|
|
27
|
+
* RuleRegistry provides storage and lifecycle management for validation rules.
|
|
28
|
+
*
|
|
29
|
+
* This class implements the IRuleRegistry interface and encapsulates
|
|
30
|
+
* all rule storage logic, keeping the RuleEnforcer focused on execution.
|
|
31
|
+
*
|
|
32
|
+
* Key responsibilities:
|
|
33
|
+
* - Rule storage and retrieval
|
|
34
|
+
* - Enable/disable rule state management
|
|
35
|
+
* - Rule statistics and metadata
|
|
36
|
+
* - Rule lifecycle operations (add, remove, clear)
|
|
37
|
+
*/
|
|
38
|
+
export declare class RuleRegistry implements IRuleRegistry {
|
|
39
|
+
/** Internal storage for rules */
|
|
40
|
+
private rules;
|
|
41
|
+
/**
|
|
42
|
+
* Add a rule to the registry.
|
|
43
|
+
*
|
|
44
|
+
* @param rule - The rule definition to add
|
|
45
|
+
* @throws Error if a rule with the same ID already exists
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* ```typescript
|
|
49
|
+
* registry.addRule({
|
|
50
|
+
* id: "no-console",
|
|
51
|
+
* name: "No Console Logs",
|
|
52
|
+
* description: "Prevents console.log usage",
|
|
53
|
+
* category: "code-quality",
|
|
54
|
+
* severity: "warning",
|
|
55
|
+
* enabled: true,
|
|
56
|
+
* validator: async (ctx) => ({ passed: true, message: "OK" })
|
|
57
|
+
* });
|
|
58
|
+
* ```
|
|
59
|
+
*/
|
|
60
|
+
addRule(rule: RuleDefinition): void;
|
|
61
|
+
/**
|
|
62
|
+
* Get all loaded rules as an array.
|
|
63
|
+
*
|
|
64
|
+
* @returns Array of all rule definitions
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* ```typescript
|
|
68
|
+
* const allRules = registry.getRules();
|
|
69
|
+
* console.log(`Loaded ${allRules.length} rules`);
|
|
70
|
+
* ```
|
|
71
|
+
*/
|
|
72
|
+
getRules(): RuleDefinition[];
|
|
73
|
+
/**
|
|
74
|
+
* Get a specific rule by its ID.
|
|
75
|
+
*
|
|
76
|
+
* @param ruleId - The unique identifier of the rule
|
|
77
|
+
* @returns The rule definition or undefined if not found
|
|
78
|
+
*
|
|
79
|
+
* @example
|
|
80
|
+
* ```typescript
|
|
81
|
+
* const rule = registry.getRule("no-console");
|
|
82
|
+
* if (rule) {
|
|
83
|
+
* console.log(rule.name);
|
|
84
|
+
* }
|
|
85
|
+
* ```
|
|
86
|
+
*/
|
|
87
|
+
getRule(ruleId: string): RuleDefinition | undefined;
|
|
88
|
+
/**
|
|
89
|
+
* Enable a rule by its ID.
|
|
90
|
+
*
|
|
91
|
+
* @param ruleId - The unique identifier of the rule to enable
|
|
92
|
+
* @returns true if the rule was found and enabled, false if not found
|
|
93
|
+
*
|
|
94
|
+
* @example
|
|
95
|
+
* ```typescript
|
|
96
|
+
* if (registry.enableRule("no-console")) {
|
|
97
|
+
* console.log("Rule enabled successfully");
|
|
98
|
+
* }
|
|
99
|
+
* ```
|
|
100
|
+
*/
|
|
101
|
+
enableRule(ruleId: string): boolean;
|
|
102
|
+
/**
|
|
103
|
+
* Disable a rule by its ID.
|
|
104
|
+
*
|
|
105
|
+
* @param ruleId - The unique identifier of the rule to disable
|
|
106
|
+
* @returns true if the rule was found and disabled, false if not found
|
|
107
|
+
*
|
|
108
|
+
* @example
|
|
109
|
+
* ```typescript
|
|
110
|
+
* if (registry.disableRule("no-console")) {
|
|
111
|
+
* console.log("Rule disabled successfully");
|
|
112
|
+
* }
|
|
113
|
+
* ```
|
|
114
|
+
*/
|
|
115
|
+
disableRule(ruleId: string): boolean;
|
|
116
|
+
/**
|
|
117
|
+
* Check if a rule is enabled.
|
|
118
|
+
*
|
|
119
|
+
* @param ruleId - The unique identifier of the rule
|
|
120
|
+
* @returns true if the rule exists and is enabled, false otherwise
|
|
121
|
+
*
|
|
122
|
+
* @example
|
|
123
|
+
* ```typescript
|
|
124
|
+
* if (registry.isRuleEnabled("no-console")) {
|
|
125
|
+
* // Rule is active
|
|
126
|
+
* }
|
|
127
|
+
* ```
|
|
128
|
+
*/
|
|
129
|
+
isRuleEnabled(ruleId: string): boolean;
|
|
130
|
+
/**
|
|
131
|
+
* Get the total count of rules in the registry.
|
|
132
|
+
*
|
|
133
|
+
* @returns The number of rules stored
|
|
134
|
+
*
|
|
135
|
+
* @example
|
|
136
|
+
* ```typescript
|
|
137
|
+
* console.log(`Registry contains ${registry.getRuleCount()} rules`);
|
|
138
|
+
* ```
|
|
139
|
+
*/
|
|
140
|
+
getRuleCount(): number;
|
|
141
|
+
/**
|
|
142
|
+
* Get comprehensive statistics about rules in the registry.
|
|
143
|
+
*
|
|
144
|
+
* @returns Statistics including total, enabled, disabled counts and category breakdown
|
|
145
|
+
*
|
|
146
|
+
* @example
|
|
147
|
+
* ```typescript
|
|
148
|
+
* const stats = registry.getRuleStats();
|
|
149
|
+
* console.log(`Enabled: ${stats.enabledRules}/${stats.totalRules}`);
|
|
150
|
+
* console.log("By category:", stats.ruleCategories);
|
|
151
|
+
* ```
|
|
152
|
+
*/
|
|
153
|
+
getRuleStats(): {
|
|
154
|
+
totalRules: number;
|
|
155
|
+
enabledRules: number;
|
|
156
|
+
disabledRules: number;
|
|
157
|
+
ruleCategories: Record<string, number>;
|
|
158
|
+
};
|
|
159
|
+
/**
|
|
160
|
+
* Check if a rule exists in the registry.
|
|
161
|
+
*
|
|
162
|
+
* @param ruleId - The unique identifier of the rule
|
|
163
|
+
* @returns true if the rule exists, false otherwise
|
|
164
|
+
*
|
|
165
|
+
* @example
|
|
166
|
+
* ```typescript
|
|
167
|
+
* if (registry.hasRule("no-console")) {
|
|
168
|
+
* // Rule exists
|
|
169
|
+
* }
|
|
170
|
+
* ```
|
|
171
|
+
*/
|
|
172
|
+
hasRule(ruleId: string): boolean;
|
|
173
|
+
/**
|
|
174
|
+
* Remove a rule from the registry.
|
|
175
|
+
*
|
|
176
|
+
* @param ruleId - The unique identifier of the rule to remove
|
|
177
|
+
* @returns true if the rule was found and removed, false if not found
|
|
178
|
+
*
|
|
179
|
+
* @example
|
|
180
|
+
* ```typescript
|
|
181
|
+
* if (registry.removeRule("no-console")) {
|
|
182
|
+
* console.log("Rule removed successfully");
|
|
183
|
+
* }
|
|
184
|
+
* ```
|
|
185
|
+
*/
|
|
186
|
+
removeRule(ruleId: string): boolean;
|
|
187
|
+
/**
|
|
188
|
+
* Clear all rules from the registry.
|
|
189
|
+
*
|
|
190
|
+
* @example
|
|
191
|
+
* ```typescript
|
|
192
|
+
* registry.clearRules();
|
|
193
|
+
* console.log(`Registry cleared. Count: ${registry.getRuleCount()}`);
|
|
194
|
+
* ```
|
|
195
|
+
*/
|
|
196
|
+
clearRules(): void;
|
|
197
|
+
}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Violation Fixer - Handle violation fixes via agent delegation
|
|
3
|
+
*
|
|
4
|
+
* This class maps rule violations to appropriate agents/skills and attempts
|
|
5
|
+
* automatic fixes. It serves as the central governance point for all
|
|
6
|
+
* violation remediation in the 0xRay framework.
|
|
7
|
+
*
|
|
8
|
+
* Phase 5 refactoring: Extracted from RuleEnforcer.
|
|
9
|
+
*
|
|
10
|
+
* @module enforcement/core
|
|
11
|
+
* @version 1.0.0
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```typescript
|
|
15
|
+
* const fixer = new ViolationFixer();
|
|
16
|
+
*
|
|
17
|
+
* // Register a custom fix strategy
|
|
18
|
+
* fixer.registerFixStrategy('my-rule', {
|
|
19
|
+
* agent: 'refactorer',
|
|
20
|
+
* skill: 'code-review',
|
|
21
|
+
* tool: 'analyze_code_quality',
|
|
22
|
+
* priority: 1
|
|
23
|
+
* });
|
|
24
|
+
*
|
|
25
|
+
* // Fix violations
|
|
26
|
+
* const fixes = await fixer.fixViolations(violations, context);
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
import { IViolationFixer, Violation, ViolationFix, FixStrategy, RuleValidationContext } from '../types.js';
|
|
30
|
+
/**
|
|
31
|
+
* ViolationFixer handles violation fixes by delegating to appropriate agents/skills.
|
|
32
|
+
*
|
|
33
|
+
* Key responsibilities:
|
|
34
|
+
* - Map violations to agents/skills
|
|
35
|
+
* - Attempt automatic fixes via MCP skill invocation
|
|
36
|
+
* - Track fix success/failure
|
|
37
|
+
* - Handle fix strategies
|
|
38
|
+
*
|
|
39
|
+
* This is the central governance point for all codex compliance actions.
|
|
40
|
+
*/
|
|
41
|
+
export declare class ViolationFixer implements IViolationFixer {
|
|
42
|
+
/** Map of rule IDs to their fix strategies */
|
|
43
|
+
private fixStrategies;
|
|
44
|
+
/** Default tool mapping for skills */
|
|
45
|
+
private toolMappings;
|
|
46
|
+
constructor();
|
|
47
|
+
/**
|
|
48
|
+
* Attempt to fix violations by delegating to appropriate agents/skills.
|
|
49
|
+
*
|
|
50
|
+
* For each violation:
|
|
51
|
+
* - Finds the appropriate agent/skill mapping
|
|
52
|
+
* - Invokes the skill via MCP
|
|
53
|
+
* - Tracks the result
|
|
54
|
+
*
|
|
55
|
+
* @param violations - Array of violations to fix
|
|
56
|
+
* @param context - Validation context with code and operation info
|
|
57
|
+
* @returns Array of fix attempts with results
|
|
58
|
+
*
|
|
59
|
+
* @example
|
|
60
|
+
* ```typescript
|
|
61
|
+
* const violations = [{ rule: 'no-duplicate-code', message: 'Duplicate detected' }];
|
|
62
|
+
* const fixes = await fixer.fixViolations(violations, context);
|
|
63
|
+
* console.log(fixes[0].success); // true if fix succeeded
|
|
64
|
+
* ```
|
|
65
|
+
*/
|
|
66
|
+
fixViolations(violations: Violation[], context: RuleValidationContext): Promise<ViolationFix[]>;
|
|
67
|
+
/**
|
|
68
|
+
* Register a custom fix strategy for a rule.
|
|
69
|
+
*
|
|
70
|
+
* @param ruleId - The rule ID to register the strategy for
|
|
71
|
+
* @param strategy - The fix strategy configuration
|
|
72
|
+
*
|
|
73
|
+
* @example
|
|
74
|
+
* ```typescript
|
|
75
|
+
* fixer.registerFixStrategy('custom-rule', {
|
|
76
|
+
* agent: 'refactorer',
|
|
77
|
+
* skill: 'code-review',
|
|
78
|
+
* tool: 'analyze_code_quality',
|
|
79
|
+
* priority: 1
|
|
80
|
+
* });
|
|
81
|
+
* ```
|
|
82
|
+
*/
|
|
83
|
+
registerFixStrategy(ruleId: string, strategy: FixStrategy): void;
|
|
84
|
+
/**
|
|
85
|
+
* Get the fix strategy for a rule.
|
|
86
|
+
*
|
|
87
|
+
* @param ruleId - The rule ID to get the strategy for
|
|
88
|
+
* @returns The fix strategy or undefined if not found
|
|
89
|
+
*/
|
|
90
|
+
getFixStrategy(ruleId: string): FixStrategy | undefined;
|
|
91
|
+
/**
|
|
92
|
+
* Get the appropriate tool name for a skill.
|
|
93
|
+
* Uses internal tool mappings or defaults to analyze_code_quality.
|
|
94
|
+
*
|
|
95
|
+
* @param skill - The skill name
|
|
96
|
+
* @returns The tool name to use
|
|
97
|
+
*/
|
|
98
|
+
private getToolForSkill;
|
|
99
|
+
/**
|
|
100
|
+
* Initialize default fix strategies for all known rules.
|
|
101
|
+
* This maps rule IDs to their corresponding agents/skills.
|
|
102
|
+
*
|
|
103
|
+
* Central governance mapping for all codex compliance actions.
|
|
104
|
+
*/
|
|
105
|
+
private initializeFixStrategies;
|
|
106
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Enforcer Tools - Integration layer between enforcer agent and rule enforcement system
|
|
3
|
+
* Provides tools for codex compliance, rule validation, and contextual analysis enforcement
|
|
4
|
+
*/
|
|
5
|
+
import { RuleValidationContext, ValidationReport } from "./rule-enforcer.js";
|
|
6
|
+
export interface RoutingRecommendation {
|
|
7
|
+
suggestedAgent: string;
|
|
8
|
+
suggestedSkill: string;
|
|
9
|
+
confidence: number;
|
|
10
|
+
matchedKeyword?: string;
|
|
11
|
+
}
|
|
12
|
+
export declare function getTaskRoutingRecommendation(taskDescription: string): RoutingRecommendation;
|
|
13
|
+
/**
|
|
14
|
+
* Pre-process and validate that the routing is appropriate for the operation
|
|
15
|
+
* This is the integration point between TaskSkillRouter and RuleEnforcer
|
|
16
|
+
*/
|
|
17
|
+
export declare function preProcessAndRoute(operation: string, context: RuleValidationContext): Promise<{
|
|
18
|
+
enhancedContext: RuleValidationContext;
|
|
19
|
+
routing: RoutingRecommendation;
|
|
20
|
+
}>;
|
|
21
|
+
export interface EnforcementResult {
|
|
22
|
+
operation: string;
|
|
23
|
+
passed: boolean;
|
|
24
|
+
blocked: boolean;
|
|
25
|
+
errors: string[];
|
|
26
|
+
warnings: string[];
|
|
27
|
+
fixes: Array<{
|
|
28
|
+
type: "auto" | "manual";
|
|
29
|
+
description: string;
|
|
30
|
+
action?: () => Promise<void>;
|
|
31
|
+
}>;
|
|
32
|
+
report: ValidationReport;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Rule Validation Tool - Validates operations against rule hierarchy
|
|
36
|
+
* Now with intelligent task routing via TaskSkillRouter
|
|
37
|
+
* Automatically delegates to best agent when confidence is high
|
|
38
|
+
*/
|
|
39
|
+
export declare function ruleValidation(operation: string, context: RuleValidationContext): Promise<EnforcementResult>;
|
|
40
|
+
/**
|
|
41
|
+
* Context Analysis Validation Tool - Validates contextual analysis integration
|
|
42
|
+
*/
|
|
43
|
+
export declare function contextAnalysisValidation(files: string[], operation: string): Promise<EnforcementResult>;
|
|
44
|
+
/**
|
|
45
|
+
* Codex Enforcement Tool - Comprehensive codex compliance validation
|
|
46
|
+
*/
|
|
47
|
+
export declare function codexEnforcement(operation: string, files: string[], newCode?: string): Promise<EnforcementResult>;
|
|
48
|
+
/**
|
|
49
|
+
* Quality Gate Check Tool - Final validation before commit/execution
|
|
50
|
+
*/
|
|
51
|
+
export declare function qualityGateCheck(operation: string, context: {
|
|
52
|
+
files: string[];
|
|
53
|
+
newCode?: string;
|
|
54
|
+
tests?: string[];
|
|
55
|
+
dependencies?: string[];
|
|
56
|
+
}): Promise<EnforcementResult>;
|
|
57
|
+
/**
|
|
58
|
+
* Get comprehensive enforcement status
|
|
59
|
+
*/
|
|
60
|
+
export declare function getEnforcementStatus(): Promise<{
|
|
61
|
+
rules: number;
|
|
62
|
+
validations: number;
|
|
63
|
+
violations: number;
|
|
64
|
+
fixes: number;
|
|
65
|
+
success: boolean;
|
|
66
|
+
}>;
|
|
67
|
+
/**
|
|
68
|
+
* Run comprehensive pre-commit validation
|
|
69
|
+
*/
|
|
70
|
+
export declare function runPreCommitValidation(files: string[], operation?: string): Promise<EnforcementResult>;
|
|
71
|
+
export declare const enforcerTools: {
|
|
72
|
+
ruleValidation: typeof ruleValidation;
|
|
73
|
+
contextAnalysisValidation: typeof contextAnalysisValidation;
|
|
74
|
+
codexEnforcement: typeof codexEnforcement;
|
|
75
|
+
qualityGateCheck: typeof qualityGateCheck;
|
|
76
|
+
getEnforcementStatus: typeof getEnforcementStatus;
|
|
77
|
+
runPreCommitValidation: typeof runPreCommitValidation;
|
|
78
|
+
};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rule Enforcement Module
|
|
3
|
+
*
|
|
4
|
+
* This module provides rule enforcement capabilities for the 0xRay framework.
|
|
5
|
+
* It validates code against development rules and codex compliance requirements.
|
|
6
|
+
*
|
|
7
|
+
* @module enforcement
|
|
8
|
+
* @version 1.0.0
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```typescript
|
|
12
|
+
* import { RuleEnforcer, RuleDefinition, ValidationReport } from './enforcement/index.js';
|
|
13
|
+
*
|
|
14
|
+
* const enforcer = new RuleEnforcer();
|
|
15
|
+
* const report = await enforcer.validateOperation('write', context);
|
|
16
|
+
* ```
|
|
17
|
+
*/
|
|
18
|
+
export { RuleEnforcer } from "./rule-enforcer.js";
|
|
19
|
+
export { RuleRegistry, RuleHierarchy, RuleExecutor, ViolationFixer, } from "./core/index.js";
|
|
20
|
+
export { RuleDefinition, RuleValidationContext, RuleValidationResult, ValidationReport, Violation, ViolationFix, RuleFix, RuleCategory, RuleSeverity, RuleFixType, IRuleRegistry, IValidator, IValidatorRegistry, IRuleHierarchy, IRuleExecutor, IViolationFixer, ExecutionOptions, BatchExecutionOptions, FixStrategy, isRuleValidationResult, } from "./types.js";
|
|
21
|
+
export { BaseValidator, ValidatorRegistry, globalValidatorRegistry, NoDuplicateCodeValidator, ContextAnalysisIntegrationValidator, MemoryOptimizationValidator, DocumentationRequiredValidator, NoOverEngineeringValidator, CleanDebugLogsValidator, ConsoleLogUsageValidator, } from "./validators/index.js";
|
|
22
|
+
export { BaseLoader, CodexLoader, AgentTriageLoader, ProcessorLoader, AgentsMdValidationLoader, LoaderOrchestrator, type LoaderOrchestratorOptions, type LoaderOrchestratorResult, } from "./loaders/index.js";
|
|
23
|
+
export * as enforcerTools from "./enforcer-tools.js";
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent Triage Rule Loader
|
|
3
|
+
*
|
|
4
|
+
* Loads agent triage rules from AGENTS.md file.
|
|
5
|
+
* Extracts triage guidelines and converts them to RuleDefinition objects.
|
|
6
|
+
*
|
|
7
|
+
* Phase 4 refactoring: Extracted from RuleEnforcer.loadAgentTriageRules()
|
|
8
|
+
*
|
|
9
|
+
* @module loaders/agent-triage-loader
|
|
10
|
+
* @version 1.0.0
|
|
11
|
+
*/
|
|
12
|
+
import { BaseLoader } from "./base-loader.js";
|
|
13
|
+
import { RuleDefinition } from "../types.js";
|
|
14
|
+
/**
|
|
15
|
+
* Loader for agent triage rules from AGENTS.md.
|
|
16
|
+
* Parses the markdown file to extract triage guidelines.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* const loader = new AgentTriageLoader();
|
|
21
|
+
* if (await loader.isAvailable()) {
|
|
22
|
+
* const rules = await loader.load();
|
|
23
|
+
* console.log(`Loaded ${rules.length} triage rules`);
|
|
24
|
+
* }
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare class AgentTriageLoader extends BaseLoader {
|
|
28
|
+
readonly name = "agent-triage";
|
|
29
|
+
/**
|
|
30
|
+
* Path to the AGENTS.md file.
|
|
31
|
+
*/
|
|
32
|
+
private get agentsPath();
|
|
33
|
+
/**
|
|
34
|
+
* Check if AGENTS.md exists.
|
|
35
|
+
* @returns Promise resolving to true if AGENTS.md is available
|
|
36
|
+
*/
|
|
37
|
+
isAvailable(): Promise<boolean>;
|
|
38
|
+
/**
|
|
39
|
+
* Load agent triage rules from AGENTS.md.
|
|
40
|
+
* @returns Promise resolving to array of rule definitions
|
|
41
|
+
*/
|
|
42
|
+
load(): Promise<RuleDefinition[]>;
|
|
43
|
+
/**
|
|
44
|
+
* Extract the triage section from AGENTS.md content.
|
|
45
|
+
* @param content - Full content of AGENTS.md
|
|
46
|
+
* @returns Triage section content or null if not found
|
|
47
|
+
*/
|
|
48
|
+
private extractTriageSection;
|
|
49
|
+
/**
|
|
50
|
+
* Extract additional rules from AGENTS.md content.
|
|
51
|
+
* @param content - Full content of AGENTS.md
|
|
52
|
+
* @returns Array of additional rule definitions
|
|
53
|
+
*/
|
|
54
|
+
private extractAdditionalRules;
|
|
55
|
+
/**
|
|
56
|
+
* Create the triage commit status reporting rule.
|
|
57
|
+
* @returns RuleDefinition for triage commit status
|
|
58
|
+
*/
|
|
59
|
+
private createTriageCommitStatusRule;
|
|
60
|
+
/**
|
|
61
|
+
* Create a reflection guideline rule.
|
|
62
|
+
* @returns RuleDefinition for reflection guidelines
|
|
63
|
+
*/
|
|
64
|
+
private createReflectionGuidelineRule;
|
|
65
|
+
/**
|
|
66
|
+
* Create a complexity routing rule.
|
|
67
|
+
* @returns RuleDefinition for complexity routing
|
|
68
|
+
*/
|
|
69
|
+
private createComplexityRoutingRule;
|
|
70
|
+
/**
|
|
71
|
+
* Create an agent invocation rule.
|
|
72
|
+
* @returns RuleDefinition for agent invocation
|
|
73
|
+
*/
|
|
74
|
+
private createAgentInvocationRule;
|
|
75
|
+
/**
|
|
76
|
+
* Validate triage reporting requirements.
|
|
77
|
+
* @param context - Validation context
|
|
78
|
+
* @returns Validation result
|
|
79
|
+
*/
|
|
80
|
+
private validateTriageReporting;
|
|
81
|
+
/**
|
|
82
|
+
* Validate reflection guidelines.
|
|
83
|
+
* @param context - Validation context
|
|
84
|
+
* @returns Validation result
|
|
85
|
+
*/
|
|
86
|
+
private validateReflectionGuidelines;
|
|
87
|
+
/**
|
|
88
|
+
* Validate complexity routing.
|
|
89
|
+
* @param context - Validation context
|
|
90
|
+
* @returns Validation result
|
|
91
|
+
*/
|
|
92
|
+
private validateComplexityRouting;
|
|
93
|
+
/**
|
|
94
|
+
* Validate agent invocation syntax.
|
|
95
|
+
* @param context - Validation context
|
|
96
|
+
* @returns Validation result
|
|
97
|
+
*/
|
|
98
|
+
private validateAgentInvocation;
|
|
99
|
+
}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AGENTS.md Validation Rule Loader
|
|
3
|
+
*
|
|
4
|
+
* Loads validation rules for AGENTS.md file existence and currency.
|
|
5
|
+
* Ensures that AGENTS.md exists and is properly maintained.
|
|
6
|
+
*
|
|
7
|
+
* Phase 4 refactoring: Extracted from RuleEnforcer.loadAgentsMdValidationRule()
|
|
8
|
+
*
|
|
9
|
+
* @module loaders/agents-md-validation-loader
|
|
10
|
+
* @version 1.0.0
|
|
11
|
+
*/
|
|
12
|
+
import { BaseLoader } from "./base-loader.js";
|
|
13
|
+
import { RuleDefinition } from "../types.js";
|
|
14
|
+
/**
|
|
15
|
+
* Loader for AGENTS.md validation rules.
|
|
16
|
+
* Creates rules that validate AGENTS.md existence and currency.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* const loader = new AgentsMdValidationLoader();
|
|
21
|
+
* if (await loader.isAvailable()) {
|
|
22
|
+
* const rules = await loader.load();
|
|
23
|
+
* console.log(`Loaded ${rules.length} AGENTS.md validation rules`);
|
|
24
|
+
* }
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare class AgentsMdValidationLoader extends BaseLoader {
|
|
28
|
+
readonly name = "agents-md-validation";
|
|
29
|
+
/**
|
|
30
|
+
* Path to the AGENTS.md file.
|
|
31
|
+
*/
|
|
32
|
+
private get agentsPath();
|
|
33
|
+
/**
|
|
34
|
+
* Check if AGENTS.md exists.
|
|
35
|
+
* @returns Promise resolving to true if AGENTS.md is available
|
|
36
|
+
*/
|
|
37
|
+
isAvailable(): Promise<boolean>;
|
|
38
|
+
/**
|
|
39
|
+
* Load AGENTS.md validation rules.
|
|
40
|
+
* @returns Promise resolving to array of rule definitions
|
|
41
|
+
*/
|
|
42
|
+
load(): Promise<RuleDefinition[]>;
|
|
43
|
+
/**
|
|
44
|
+
* Create AGENTS.md existence rule.
|
|
45
|
+
* @returns RuleDefinition for AGENTS.md existence
|
|
46
|
+
*/
|
|
47
|
+
private createAgentsMdExistsRule;
|
|
48
|
+
/**
|
|
49
|
+
* Create AGENTS.md currency rule.
|
|
50
|
+
* @returns RuleDefinition for AGENTS.md currency
|
|
51
|
+
*/
|
|
52
|
+
private createAgentsMdCurrentRule;
|
|
53
|
+
/**
|
|
54
|
+
* Create AGENTS.md structure rule.
|
|
55
|
+
* @returns RuleDefinition for AGENTS.md structure
|
|
56
|
+
*/
|
|
57
|
+
private createAgentsMdStructureRule;
|
|
58
|
+
/**
|
|
59
|
+
* Validate that AGENTS.md exists.
|
|
60
|
+
* @param context - Validation context
|
|
61
|
+
* @returns Validation result
|
|
62
|
+
*/
|
|
63
|
+
private validateAgentsMdExists;
|
|
64
|
+
/**
|
|
65
|
+
* Validate that AGENTS.md is current (updated within 30 days).
|
|
66
|
+
* @param context - Validation context
|
|
67
|
+
* @returns Validation result
|
|
68
|
+
*/
|
|
69
|
+
private validateAgentsMdCurrent;
|
|
70
|
+
/**
|
|
71
|
+
* Validate AGENTS.md structure.
|
|
72
|
+
* @param context - Validation context
|
|
73
|
+
* @returns Validation result
|
|
74
|
+
*/
|
|
75
|
+
private validateAgentsMdStructure;
|
|
76
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Base Rule Loader
|
|
3
|
+
*
|
|
4
|
+
* Abstract base class for all rule loaders. Provides common functionality
|
|
5
|
+
* for loading rules from various sources such as files, APIs, or databases.
|
|
6
|
+
*
|
|
7
|
+
* Phase 4 refactoring: Extracted from RuleEnforcer to separate loading logic
|
|
8
|
+
* from rule execution.
|
|
9
|
+
*
|
|
10
|
+
* @module loaders/base-loader
|
|
11
|
+
* @version 1.0.0
|
|
12
|
+
*/
|
|
13
|
+
import * as fs from "fs";
|
|
14
|
+
import { IRuleLoader, RuleDefinition } from "../types.js";
|
|
15
|
+
/**
|
|
16
|
+
* Abstract base class implementing IRuleLoader interface.
|
|
17
|
+
* Provides common file loading utilities and error handling.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```typescript
|
|
21
|
+
* class MyLoader extends BaseLoader {
|
|
22
|
+
* readonly name = 'my-loader';
|
|
23
|
+
*
|
|
24
|
+
* async load(): Promise<RuleDefinition[]> {
|
|
25
|
+
* const data = await this.loadJsonFile('rules.json');
|
|
26
|
+
* return this.transformToRules(data);
|
|
27
|
+
* }
|
|
28
|
+
*
|
|
29
|
+
* async isAvailable(): Promise<boolean> {
|
|
30
|
+
* return this.fileExists('rules.json');
|
|
31
|
+
* }
|
|
32
|
+
* }
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
export declare abstract class BaseLoader implements IRuleLoader {
|
|
36
|
+
/** Unique name identifier for this loader */
|
|
37
|
+
abstract readonly name: string;
|
|
38
|
+
/**
|
|
39
|
+
* Load rules from the source.
|
|
40
|
+
* Must be implemented by concrete loader classes.
|
|
41
|
+
* @returns Promise resolving to array of rule definitions
|
|
42
|
+
*/
|
|
43
|
+
abstract load(): Promise<RuleDefinition[]>;
|
|
44
|
+
/**
|
|
45
|
+
* Check if this loader's source is available.
|
|
46
|
+
* Must be implemented by concrete loader classes.
|
|
47
|
+
* @returns Promise resolving to true if source exists and is accessible
|
|
48
|
+
*/
|
|
49
|
+
abstract isAvailable(): Promise<boolean>;
|
|
50
|
+
/**
|
|
51
|
+
* Load and parse a JSON file.
|
|
52
|
+
* @param filePath - Path to the JSON file
|
|
53
|
+
* @returns Promise resolving to parsed JSON data
|
|
54
|
+
* @throws Error if file cannot be read or parsed
|
|
55
|
+
*/
|
|
56
|
+
protected loadJsonFile<T = unknown>(filePath: string): Promise<T>;
|
|
57
|
+
/**
|
|
58
|
+
* Check if a file exists.
|
|
59
|
+
* @param filePath - Path to check
|
|
60
|
+
* @returns Promise resolving to true if file exists
|
|
61
|
+
*/
|
|
62
|
+
protected fileExists(filePath: string): Promise<boolean>;
|
|
63
|
+
/**
|
|
64
|
+
* Read file content as string.
|
|
65
|
+
* @param filePath - Path to the file
|
|
66
|
+
* @returns Promise resolving to file content
|
|
67
|
+
* @throws Error if file cannot be read
|
|
68
|
+
*/
|
|
69
|
+
protected readFile(filePath: string): Promise<string>;
|
|
70
|
+
/**
|
|
71
|
+
* Resolve a path relative to the current working directory.
|
|
72
|
+
* @param relativePath - Path relative to process.cwd()
|
|
73
|
+
* @returns Absolute path
|
|
74
|
+
*/
|
|
75
|
+
protected resolvePath(relativePath: string): string;
|
|
76
|
+
/**
|
|
77
|
+
* Get file stats.
|
|
78
|
+
* @param filePath - Path to the file
|
|
79
|
+
* @returns Promise resolving to file stats
|
|
80
|
+
* @throws Error if file cannot be accessed
|
|
81
|
+
*/
|
|
82
|
+
protected getFileStats(filePath: string): Promise<fs.Stats>;
|
|
83
|
+
}
|