@vee-stack/delta-cli 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/dist/analyzer/commands/analyze.d.ts +14 -0
- package/dist/analyzer/commands/analyze.d.ts.map +1 -0
- package/dist/analyzer/commands/analyze.js +260 -0
- package/dist/analyzer/commands/analyze.js.map +1 -0
- package/dist/analyzer/commands/config.d.ts +12 -0
- package/dist/analyzer/commands/config.d.ts.map +1 -0
- package/dist/analyzer/commands/config.js +83 -0
- package/dist/analyzer/commands/config.js.map +1 -0
- package/dist/analyzer/commands/report.d.ts +11 -0
- package/dist/analyzer/commands/report.d.ts.map +1 -0
- package/dist/analyzer/commands/report.js +38 -0
- package/dist/analyzer/commands/report.js.map +1 -0
- package/dist/analyzer/generators/report.generator.d.ts +43 -0
- package/dist/analyzer/generators/report.generator.d.ts.map +1 -0
- package/dist/analyzer/generators/report.generator.js +123 -0
- package/dist/analyzer/generators/report.generator.js.map +1 -0
- package/dist/analyzer/index.d.ts +8 -0
- package/dist/analyzer/index.d.ts.map +1 -0
- package/dist/analyzer/index.js +44 -0
- package/dist/analyzer/index.js.map +1 -0
- package/dist/analyzer/scanners/project.scanner.d.ts +29 -0
- package/dist/analyzer/scanners/project.scanner.d.ts.map +1 -0
- package/dist/analyzer/scanners/project.scanner.js +92 -0
- package/dist/analyzer/scanners/project.scanner.js.map +1 -0
- package/dist/analyzer/validators/contracts.validator.d.ts +27 -0
- package/dist/analyzer/validators/contracts.validator.d.ts.map +1 -0
- package/dist/analyzer/validators/contracts.validator.js +42 -0
- package/dist/analyzer/validators/contracts.validator.js.map +1 -0
- package/dist/analyzer/validators/maintainability.validator.d.ts +27 -0
- package/dist/analyzer/validators/maintainability.validator.d.ts.map +1 -0
- package/dist/analyzer/validators/maintainability.validator.js +40 -0
- package/dist/analyzer/validators/maintainability.validator.js.map +1 -0
- package/dist/analyzer/validators/observability.validator.d.ts +27 -0
- package/dist/analyzer/validators/observability.validator.d.ts.map +1 -0
- package/dist/analyzer/validators/observability.validator.js +39 -0
- package/dist/analyzer/validators/observability.validator.js.map +1 -0
- package/dist/analyzer/validators/performance.validator.d.ts +27 -0
- package/dist/analyzer/validators/performance.validator.d.ts.map +1 -0
- package/dist/analyzer/validators/performance.validator.js +42 -0
- package/dist/analyzer/validators/performance.validator.js.map +1 -0
- package/dist/analyzer/validators/security.validator.d.ts +27 -0
- package/dist/analyzer/validators/security.validator.d.ts.map +1 -0
- package/dist/analyzer/validators/security.validator.js +66 -0
- package/dist/analyzer/validators/security.validator.js.map +1 -0
- package/dist/analyzer/validators/soc.validator.d.ts +27 -0
- package/dist/analyzer/validators/soc.validator.d.ts.map +1 -0
- package/dist/analyzer/validators/soc.validator.js +75 -0
- package/dist/analyzer/validators/soc.validator.js.map +1 -0
- package/dist/apps/cli/src/analyzer/commands/analyze.d.ts +14 -0
- package/dist/apps/cli/src/analyzer/commands/analyze.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/commands/analyze.js +256 -0
- package/dist/apps/cli/src/analyzer/commands/analyze.js.map +1 -0
- package/dist/apps/cli/src/analyzer/commands/config.d.ts +12 -0
- package/dist/apps/cli/src/analyzer/commands/config.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/commands/config.js +83 -0
- package/dist/apps/cli/src/analyzer/commands/config.js.map +1 -0
- package/dist/apps/cli/src/analyzer/commands/report.d.ts +11 -0
- package/dist/apps/cli/src/analyzer/commands/report.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/commands/report.js +38 -0
- package/dist/apps/cli/src/analyzer/commands/report.js.map +1 -0
- package/dist/apps/cli/src/analyzer/generators/report.generator.d.ts +43 -0
- package/dist/apps/cli/src/analyzer/generators/report.generator.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/generators/report.generator.js +123 -0
- package/dist/apps/cli/src/analyzer/generators/report.generator.js.map +1 -0
- package/dist/apps/cli/src/analyzer/index.d.ts +8 -0
- package/dist/apps/cli/src/analyzer/index.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/index.js +44 -0
- package/dist/apps/cli/src/analyzer/index.js.map +1 -0
- package/dist/apps/cli/src/analyzer/scanners/project.scanner.d.ts +29 -0
- package/dist/apps/cli/src/analyzer/scanners/project.scanner.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/scanners/project.scanner.js +92 -0
- package/dist/apps/cli/src/analyzer/scanners/project.scanner.js.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/contracts.validator.d.ts +27 -0
- package/dist/apps/cli/src/analyzer/validators/contracts.validator.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/contracts.validator.js +42 -0
- package/dist/apps/cli/src/analyzer/validators/contracts.validator.js.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/maintainability.validator.d.ts +27 -0
- package/dist/apps/cli/src/analyzer/validators/maintainability.validator.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/maintainability.validator.js +40 -0
- package/dist/apps/cli/src/analyzer/validators/maintainability.validator.js.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/observability.validator.d.ts +27 -0
- package/dist/apps/cli/src/analyzer/validators/observability.validator.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/observability.validator.js +39 -0
- package/dist/apps/cli/src/analyzer/validators/observability.validator.js.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/performance.validator.d.ts +27 -0
- package/dist/apps/cli/src/analyzer/validators/performance.validator.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/performance.validator.js +42 -0
- package/dist/apps/cli/src/analyzer/validators/performance.validator.js.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/security.validator.d.ts +27 -0
- package/dist/apps/cli/src/analyzer/validators/security.validator.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/security.validator.js +66 -0
- package/dist/apps/cli/src/analyzer/validators/security.validator.js.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/soc.validator.d.ts +27 -0
- package/dist/apps/cli/src/analyzer/validators/soc.validator.d.ts.map +1 -0
- package/dist/apps/cli/src/analyzer/validators/soc.validator.js +75 -0
- package/dist/apps/cli/src/analyzer/validators/soc.validator.js.map +1 -0
- package/dist/apps/cli/src/auth/secure-auth.d.ts +29 -0
- package/dist/apps/cli/src/auth/secure-auth.d.ts.map +1 -0
- package/dist/apps/cli/src/auth/secure-auth.js +312 -0
- package/dist/apps/cli/src/auth/secure-auth.js.map +1 -0
- package/dist/apps/cli/src/commands/analyze.d.ts +12 -0
- package/dist/apps/cli/src/commands/analyze.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/analyze.js +286 -0
- package/dist/apps/cli/src/commands/analyze.js.map +1 -0
- package/dist/apps/cli/src/commands/auth-new.d.ts +6 -0
- package/dist/apps/cli/src/commands/auth-new.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/auth-new.js +37 -0
- package/dist/apps/cli/src/commands/auth-new.js.map +1 -0
- package/dist/apps/cli/src/commands/auth.d.ts +18 -0
- package/dist/apps/cli/src/commands/auth.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/auth.js +122 -0
- package/dist/apps/cli/src/commands/auth.js.map +1 -0
- package/dist/apps/cli/src/commands/config.d.ts +8 -0
- package/dist/apps/cli/src/commands/config.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/config.js +49 -0
- package/dist/apps/cli/src/commands/config.js.map +1 -0
- package/dist/apps/cli/src/commands/deploy.d.ts +5 -0
- package/dist/apps/cli/src/commands/deploy.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/deploy.js +6 -0
- package/dist/apps/cli/src/commands/deploy.js.map +1 -0
- package/dist/apps/cli/src/commands/init.d.ts +7 -0
- package/dist/apps/cli/src/commands/init.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/init.js +47 -0
- package/dist/apps/cli/src/commands/init.js.map +1 -0
- package/dist/apps/cli/src/commands/logout.d.ts +2 -0
- package/dist/apps/cli/src/commands/logout.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/logout.js +23 -0
- package/dist/apps/cli/src/commands/logout.js.map +1 -0
- package/dist/apps/cli/src/commands/plugins.d.ts +7 -0
- package/dist/apps/cli/src/commands/plugins.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/plugins.js +21 -0
- package/dist/apps/cli/src/commands/plugins.js.map +1 -0
- package/dist/apps/cli/src/commands/status.d.ts +5 -0
- package/dist/apps/cli/src/commands/status.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/status.js +80 -0
- package/dist/apps/cli/src/commands/status.js.map +1 -0
- package/dist/apps/cli/src/commands/sync.d.ts +5 -0
- package/dist/apps/cli/src/commands/sync.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/sync.js +6 -0
- package/dist/apps/cli/src/commands/sync.js.map +1 -0
- package/dist/apps/cli/src/commands/whoami.d.ts +4 -0
- package/dist/apps/cli/src/commands/whoami.d.ts.map +1 -0
- package/dist/apps/cli/src/commands/whoami.js +115 -0
- package/dist/apps/cli/src/commands/whoami.js.map +1 -0
- package/dist/apps/cli/src/components/Dashboard.d.ts +8 -0
- package/dist/apps/cli/src/components/Dashboard.d.ts.map +1 -0
- package/dist/apps/cli/src/components/Dashboard.js +168 -0
- package/dist/apps/cli/src/components/Dashboard.js.map +1 -0
- package/dist/apps/cli/src/components/DeltaApp.d.ts +13 -0
- package/dist/apps/cli/src/components/DeltaApp.d.ts.map +1 -0
- package/dist/apps/cli/src/components/DeltaApp.js +56 -0
- package/dist/apps/cli/src/components/DeltaApp.js.map +1 -0
- package/dist/apps/cli/src/components/UnifiedManager.d.ts +10 -0
- package/dist/apps/cli/src/components/UnifiedManager.d.ts.map +1 -0
- package/dist/apps/cli/src/components/UnifiedManager.js +324 -0
- package/dist/apps/cli/src/components/UnifiedManager.js.map +1 -0
- package/dist/apps/cli/src/core/audit.d.ts +60 -0
- package/dist/apps/cli/src/core/audit.d.ts.map +1 -0
- package/dist/apps/cli/src/core/audit.js +184 -0
- package/dist/apps/cli/src/core/audit.js.map +1 -0
- package/dist/apps/cli/src/core/completion.d.ts +79 -0
- package/dist/apps/cli/src/core/completion.d.ts.map +1 -0
- package/dist/apps/cli/src/core/completion.js +294 -0
- package/dist/apps/cli/src/core/completion.js.map +1 -0
- package/dist/apps/cli/src/core/contracts.d.ts +127 -0
- package/dist/apps/cli/src/core/contracts.d.ts.map +1 -0
- package/dist/apps/cli/src/core/contracts.js +6 -0
- package/dist/apps/cli/src/core/contracts.js.map +1 -0
- package/dist/apps/cli/src/core/engine.d.ts +26 -0
- package/dist/apps/cli/src/core/engine.d.ts.map +1 -0
- package/dist/apps/cli/src/core/engine.js +124 -0
- package/dist/apps/cli/src/core/engine.js.map +1 -0
- package/dist/apps/cli/src/core/exit-codes.d.ts +19 -0
- package/dist/apps/cli/src/core/exit-codes.d.ts.map +1 -0
- package/dist/apps/cli/src/core/exit-codes.js +71 -0
- package/dist/apps/cli/src/core/exit-codes.js.map +1 -0
- package/dist/apps/cli/src/core/hooks.d.ts +50 -0
- package/dist/apps/cli/src/core/hooks.d.ts.map +1 -0
- package/dist/apps/cli/src/core/hooks.js +181 -0
- package/dist/apps/cli/src/core/hooks.js.map +1 -0
- package/dist/apps/cli/src/core/index.d.ts +7 -0
- package/dist/apps/cli/src/core/index.d.ts.map +1 -0
- package/dist/apps/cli/src/core/index.js +7 -0
- package/dist/apps/cli/src/core/index.js.map +1 -0
- package/dist/apps/cli/src/core/policy.d.ts +24 -0
- package/dist/apps/cli/src/core/policy.d.ts.map +1 -0
- package/dist/apps/cli/src/core/policy.js +115 -0
- package/dist/apps/cli/src/core/policy.js.map +1 -0
- package/dist/apps/cli/src/core/profiles.d.ts +45 -0
- package/dist/apps/cli/src/core/profiles.d.ts.map +1 -0
- package/dist/apps/cli/src/core/profiles.js +161 -0
- package/dist/apps/cli/src/core/profiles.js.map +1 -0
- package/dist/apps/cli/src/core/wizard.d.ts +28 -0
- package/dist/apps/cli/src/core/wizard.d.ts.map +1 -0
- package/dist/apps/cli/src/core/wizard.js +203 -0
- package/dist/apps/cli/src/core/wizard.js.map +1 -0
- package/dist/apps/cli/src/index.d.ts +32 -0
- package/dist/apps/cli/src/index.d.ts.map +1 -0
- package/dist/apps/cli/src/index.js +636 -0
- package/dist/apps/cli/src/index.js.map +1 -0
- package/dist/apps/cli/src/interactive/index.d.ts +5 -0
- package/dist/apps/cli/src/interactive/index.d.ts.map +1 -0
- package/dist/apps/cli/src/interactive/index.js +11 -0
- package/dist/apps/cli/src/interactive/index.js.map +1 -0
- package/dist/apps/cli/src/plugins/GitStatusPlugin.d.ts +25 -0
- package/dist/apps/cli/src/plugins/GitStatusPlugin.d.ts.map +1 -0
- package/dist/apps/cli/src/plugins/GitStatusPlugin.js +99 -0
- package/dist/apps/cli/src/plugins/GitStatusPlugin.js.map +1 -0
- package/dist/apps/cli/src/providers/ai-provider.d.ts +21 -0
- package/dist/apps/cli/src/providers/ai-provider.d.ts.map +1 -0
- package/dist/apps/cli/src/providers/ai-provider.js +74 -0
- package/dist/apps/cli/src/providers/ai-provider.js.map +1 -0
- package/dist/apps/cli/src/providers/local-provider.d.ts +21 -0
- package/dist/apps/cli/src/providers/local-provider.d.ts.map +1 -0
- package/dist/apps/cli/src/providers/local-provider.js +302 -0
- package/dist/apps/cli/src/providers/local-provider.js.map +1 -0
- package/dist/apps/cli/src/providers/remote-provider.d.ts +15 -0
- package/dist/apps/cli/src/providers/remote-provider.d.ts.map +1 -0
- package/dist/apps/cli/src/providers/remote-provider.js +100 -0
- package/dist/apps/cli/src/providers/remote-provider.js.map +1 -0
- package/dist/apps/cli/src/types/api.d.ts +46 -0
- package/dist/apps/cli/src/types/api.d.ts.map +1 -0
- package/dist/apps/cli/src/types/api.js +3 -0
- package/dist/apps/cli/src/types/api.js.map +1 -0
- package/dist/apps/cli/src/ui.d.ts +52 -0
- package/dist/apps/cli/src/ui.d.ts.map +1 -0
- package/dist/apps/cli/src/ui.js +219 -0
- package/dist/apps/cli/src/ui.js.map +1 -0
- package/dist/apps/cli/src/welcome.d.ts +8 -0
- package/dist/apps/cli/src/welcome.d.ts.map +1 -0
- package/dist/apps/cli/src/welcome.js +81 -0
- package/dist/apps/cli/src/welcome.js.map +1 -0
- package/dist/auth/secure-auth.d.ts +31 -0
- package/dist/auth/secure-auth.d.ts.map +1 -0
- package/dist/auth/secure-auth.js +418 -0
- package/dist/auth/secure-auth.js.map +1 -0
- package/dist/commands/analyze.d.ts +12 -0
- package/dist/commands/analyze.d.ts.map +1 -0
- package/dist/commands/analyze.js +363 -0
- package/dist/commands/analyze.js.map +1 -0
- package/dist/commands/auth-new.d.ts +6 -0
- package/dist/commands/auth-new.d.ts.map +1 -0
- package/dist/commands/auth-new.js +37 -0
- package/dist/commands/auth-new.js.map +1 -0
- package/dist/commands/auth.d.ts +17 -0
- package/dist/commands/auth.d.ts.map +1 -0
- package/dist/commands/auth.js +133 -0
- package/dist/commands/auth.js.map +1 -0
- package/dist/commands/config.d.ts +8 -0
- package/dist/commands/config.d.ts.map +1 -0
- package/dist/commands/config.js +50 -0
- package/dist/commands/config.js.map +1 -0
- package/dist/commands/deploy.d.ts +5 -0
- package/dist/commands/deploy.d.ts.map +1 -0
- package/dist/commands/deploy.js +6 -0
- package/dist/commands/deploy.js.map +1 -0
- package/dist/commands/init.d.ts +7 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +47 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/logout.d.ts +2 -0
- package/dist/commands/logout.d.ts.map +1 -0
- package/dist/commands/logout.js +30 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/plugins.d.ts +7 -0
- package/dist/commands/plugins.d.ts.map +1 -0
- package/dist/commands/plugins.js +21 -0
- package/dist/commands/plugins.js.map +1 -0
- package/dist/commands/status.d.ts +5 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +82 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/sync.d.ts +5 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +6 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/commands/whoami.d.ts +4 -0
- package/dist/commands/whoami.d.ts.map +1 -0
- package/dist/commands/whoami.js +71 -0
- package/dist/commands/whoami.js.map +1 -0
- package/dist/components/Dashboard.d.ts +8 -0
- package/dist/components/Dashboard.d.ts.map +1 -0
- package/dist/components/Dashboard.js +169 -0
- package/dist/components/Dashboard.js.map +1 -0
- package/dist/components/DeltaApp.d.ts +13 -0
- package/dist/components/DeltaApp.d.ts.map +1 -0
- package/dist/components/DeltaApp.js +57 -0
- package/dist/components/DeltaApp.js.map +1 -0
- package/dist/components/UnifiedManager.d.ts +10 -0
- package/dist/components/UnifiedManager.d.ts.map +1 -0
- package/dist/components/UnifiedManager.js +344 -0
- package/dist/components/UnifiedManager.js.map +1 -0
- package/dist/core/audit.d.ts +60 -0
- package/dist/core/audit.d.ts.map +1 -0
- package/dist/core/audit.js +184 -0
- package/dist/core/audit.js.map +1 -0
- package/dist/core/completion.d.ts +79 -0
- package/dist/core/completion.d.ts.map +1 -0
- package/dist/core/completion.js +294 -0
- package/dist/core/completion.js.map +1 -0
- package/dist/core/contracts.d.ts +127 -0
- package/dist/core/contracts.d.ts.map +1 -0
- package/dist/core/contracts.js +6 -0
- package/dist/core/contracts.js.map +1 -0
- package/dist/core/engine.d.ts +26 -0
- package/dist/core/engine.d.ts.map +1 -0
- package/dist/core/engine.js +124 -0
- package/dist/core/engine.js.map +1 -0
- package/dist/core/exit-codes.d.ts +19 -0
- package/dist/core/exit-codes.d.ts.map +1 -0
- package/dist/core/exit-codes.js +71 -0
- package/dist/core/exit-codes.js.map +1 -0
- package/dist/core/hooks.d.ts +50 -0
- package/dist/core/hooks.d.ts.map +1 -0
- package/dist/core/hooks.js +181 -0
- package/dist/core/hooks.js.map +1 -0
- package/dist/core/index.d.ts +7 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +7 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/policy.d.ts +24 -0
- package/dist/core/policy.d.ts.map +1 -0
- package/dist/core/policy.js +115 -0
- package/dist/core/policy.js.map +1 -0
- package/dist/core/profiles.d.ts +45 -0
- package/dist/core/profiles.d.ts.map +1 -0
- package/dist/core/profiles.js +161 -0
- package/dist/core/profiles.js.map +1 -0
- package/dist/core/wizard.d.ts +28 -0
- package/dist/core/wizard.d.ts.map +1 -0
- package/dist/core/wizard.js +203 -0
- package/dist/core/wizard.js.map +1 -0
- package/dist/index.d.ts +32 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +387 -0
- package/dist/index.js.map +1 -0
- package/dist/interactive/index.d.ts +5 -0
- package/dist/interactive/index.d.ts.map +1 -0
- package/dist/interactive/index.js +11 -0
- package/dist/interactive/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/contracts/index.d.ts +35 -0
- package/dist/packages/domain/src/constitution/contracts/index.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/contracts/index.js +43 -0
- package/dist/packages/domain/src/constitution/contracts/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/contracts/ts.rules.d.ts +176 -0
- package/dist/packages/domain/src/constitution/contracts/ts.rules.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/contracts/ts.rules.js +268 -0
- package/dist/packages/domain/src/constitution/contracts/ts.rules.js.map +1 -0
- package/dist/packages/domain/src/constitution/index.d.ts +151 -0
- package/dist/packages/domain/src/constitution/index.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/index.js +139 -0
- package/dist/packages/domain/src/constitution/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/maintainability/index.d.ts +35 -0
- package/dist/packages/domain/src/constitution/maintainability/index.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/maintainability/index.js +43 -0
- package/dist/packages/domain/src/constitution/maintainability/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/maintainability/ts.rules.d.ts +277 -0
- package/dist/packages/domain/src/constitution/maintainability/ts.rules.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/maintainability/ts.rules.js +344 -0
- package/dist/packages/domain/src/constitution/maintainability/ts.rules.js.map +1 -0
- package/dist/packages/domain/src/constitution/observability/index.d.ts +35 -0
- package/dist/packages/domain/src/constitution/observability/index.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/observability/index.js +43 -0
- package/dist/packages/domain/src/constitution/observability/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/observability/ts.rules.d.ts +277 -0
- package/dist/packages/domain/src/constitution/observability/ts.rules.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/observability/ts.rules.js +307 -0
- package/dist/packages/domain/src/constitution/observability/ts.rules.js.map +1 -0
- package/dist/packages/domain/src/constitution/performance/index.d.ts +35 -0
- package/dist/packages/domain/src/constitution/performance/index.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/performance/index.js +43 -0
- package/dist/packages/domain/src/constitution/performance/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/performance/ts.rules.d.ts +243 -0
- package/dist/packages/domain/src/constitution/performance/ts.rules.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/performance/ts.rules.js +325 -0
- package/dist/packages/domain/src/constitution/performance/ts.rules.js.map +1 -0
- package/dist/packages/domain/src/constitution/security/index.d.ts +35 -0
- package/dist/packages/domain/src/constitution/security/index.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/security/index.js +50 -0
- package/dist/packages/domain/src/constitution/security/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/security/ts.rules.d.ts +213 -0
- package/dist/packages/domain/src/constitution/security/ts.rules.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/security/ts.rules.js +267 -0
- package/dist/packages/domain/src/constitution/security/ts.rules.js.map +1 -0
- package/dist/packages/domain/src/constitution/soc/index.d.ts +35 -0
- package/dist/packages/domain/src/constitution/soc/index.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/soc/index.js +43 -0
- package/dist/packages/domain/src/constitution/soc/index.js.map +1 -0
- package/dist/packages/domain/src/constitution/soc/ts.rules.d.ts +252 -0
- package/dist/packages/domain/src/constitution/soc/ts.rules.d.ts.map +1 -0
- package/dist/packages/domain/src/constitution/soc/ts.rules.js +360 -0
- package/dist/packages/domain/src/constitution/soc/ts.rules.js.map +1 -0
- package/dist/packages/domain/src/contracts/analysis.contract.d.ts +206 -0
- package/dist/packages/domain/src/contracts/analysis.contract.d.ts.map +1 -0
- package/dist/packages/domain/src/contracts/analysis.contract.js +18 -0
- package/dist/packages/domain/src/contracts/analysis.contract.js.map +1 -0
- package/dist/packages/domain/src/contracts/index.d.ts +7 -0
- package/dist/packages/domain/src/contracts/index.d.ts.map +1 -0
- package/dist/packages/domain/src/contracts/index.js +7 -0
- package/dist/packages/domain/src/contracts/index.js.map +1 -0
- package/dist/packages/domain/src/contracts/projects.contract.d.ts +328 -0
- package/dist/packages/domain/src/contracts/projects.contract.d.ts.map +1 -0
- package/dist/packages/domain/src/contracts/projects.contract.js +18 -0
- package/dist/packages/domain/src/contracts/projects.contract.js.map +1 -0
- package/dist/packages/domain/src/control/registry/rules.registry.d.ts +24 -0
- package/dist/packages/domain/src/control/registry/rules.registry.d.ts.map +1 -0
- package/dist/packages/domain/src/control/registry/rules.registry.js +29 -0
- package/dist/packages/domain/src/control/registry/rules.registry.js.map +1 -0
- package/dist/packages/domain/src/control/schemas/policies.d.ts +65 -0
- package/dist/packages/domain/src/control/schemas/policies.d.ts.map +1 -0
- package/dist/packages/domain/src/control/schemas/policies.js +6 -0
- package/dist/packages/domain/src/control/schemas/policies.js.map +1 -0
- package/dist/packages/domain/src/core/analysis/discovery.d.ts +63 -0
- package/dist/packages/domain/src/core/analysis/discovery.d.ts.map +1 -0
- package/dist/packages/domain/src/core/analysis/discovery.js +163 -0
- package/dist/packages/domain/src/core/analysis/discovery.js.map +1 -0
- package/dist/packages/domain/src/core/analysis/engine.contract.d.ts +83 -0
- package/dist/packages/domain/src/core/analysis/engine.contract.d.ts.map +1 -0
- package/dist/packages/domain/src/core/analysis/engine.contract.js +298 -0
- package/dist/packages/domain/src/core/analysis/engine.contract.js.map +1 -0
- package/dist/packages/domain/src/core/analysis/engine.d.ts +51 -0
- package/dist/packages/domain/src/core/analysis/engine.d.ts.map +1 -0
- package/dist/packages/domain/src/core/analysis/engine.js +77 -0
- package/dist/packages/domain/src/core/analysis/engine.js.map +1 -0
- package/dist/packages/domain/src/core/analysis/index.d.ts +11 -0
- package/dist/packages/domain/src/core/analysis/index.d.ts.map +1 -0
- package/dist/packages/domain/src/core/analysis/index.js +14 -0
- package/dist/packages/domain/src/core/analysis/index.js.map +1 -0
- package/dist/packages/domain/src/core/analysis/orchestrator.d.ts +85 -0
- package/dist/packages/domain/src/core/analysis/orchestrator.d.ts.map +1 -0
- package/dist/packages/domain/src/core/analysis/orchestrator.js +242 -0
- package/dist/packages/domain/src/core/analysis/orchestrator.js.map +1 -0
- package/dist/packages/domain/src/core/comparison/engine.d.ts +26 -0
- package/dist/packages/domain/src/core/comparison/engine.d.ts.map +1 -0
- package/dist/packages/domain/src/core/comparison/engine.js +29 -0
- package/dist/packages/domain/src/core/comparison/engine.js.map +1 -0
- package/dist/packages/domain/src/core/comparison/index.d.ts +5 -0
- package/dist/packages/domain/src/core/comparison/index.d.ts.map +1 -0
- package/dist/packages/domain/src/core/comparison/index.js +5 -0
- package/dist/packages/domain/src/core/comparison/index.js.map +1 -0
- package/dist/packages/domain/src/core/documentation/index.d.ts +5 -0
- package/dist/packages/domain/src/core/documentation/index.d.ts.map +1 -0
- package/dist/packages/domain/src/core/documentation/index.js +5 -0
- package/dist/packages/domain/src/core/documentation/index.js.map +1 -0
- package/dist/packages/domain/src/core/documentation/pipeline.d.ts +22 -0
- package/dist/packages/domain/src/core/documentation/pipeline.d.ts.map +1 -0
- package/dist/packages/domain/src/core/documentation/pipeline.js +41 -0
- package/dist/packages/domain/src/core/documentation/pipeline.js.map +1 -0
- package/dist/packages/domain/src/core/fs/adapter.d.ts +41 -0
- package/dist/packages/domain/src/core/fs/adapter.d.ts.map +1 -0
- package/dist/packages/domain/src/core/fs/adapter.js +111 -0
- package/dist/packages/domain/src/core/fs/adapter.js.map +1 -0
- package/dist/packages/domain/src/core/fs/index.d.ts +5 -0
- package/dist/packages/domain/src/core/fs/index.d.ts.map +1 -0
- package/dist/packages/domain/src/core/fs/index.js +5 -0
- package/dist/packages/domain/src/core/fs/index.js.map +1 -0
- package/dist/packages/domain/src/core/parser/unified-parser.d.ts +36 -0
- package/dist/packages/domain/src/core/parser/unified-parser.d.ts.map +1 -0
- package/dist/packages/domain/src/core/parser/unified-parser.js +166 -0
- package/dist/packages/domain/src/core/parser/unified-parser.js.map +1 -0
- package/dist/packages/domain/src/index.d.ts +31 -0
- package/dist/packages/domain/src/index.d.ts.map +1 -0
- package/dist/packages/domain/src/index.js +33 -0
- package/dist/packages/domain/src/index.js.map +1 -0
- package/dist/packages/domain/src/plugin/registry.d.ts +72 -0
- package/dist/packages/domain/src/plugin/registry.d.ts.map +1 -0
- package/dist/packages/domain/src/plugin/registry.js +195 -0
- package/dist/packages/domain/src/plugin/registry.js.map +1 -0
- package/dist/packages/domain/src/plugin/types.d.ts +172 -0
- package/dist/packages/domain/src/plugin/types.d.ts.map +1 -0
- package/dist/packages/domain/src/plugin/types.js +6 -0
- package/dist/packages/domain/src/plugin/types.js.map +1 -0
- package/dist/packages/domain/src/ports/analysis.engine.d.ts +33 -0
- package/dist/packages/domain/src/ports/analysis.engine.d.ts.map +1 -0
- package/dist/packages/domain/src/ports/analysis.engine.js +7 -0
- package/dist/packages/domain/src/ports/analysis.engine.js.map +1 -0
- package/dist/packages/domain/src/ports/audit.logger.d.ts +34 -0
- package/dist/packages/domain/src/ports/audit.logger.d.ts.map +1 -0
- package/dist/packages/domain/src/ports/audit.logger.js +7 -0
- package/dist/packages/domain/src/ports/audit.logger.js.map +1 -0
- package/dist/packages/domain/src/ports/project.repository.d.ts +39 -0
- package/dist/packages/domain/src/ports/project.repository.d.ts.map +1 -0
- package/dist/packages/domain/src/ports/project.repository.js +7 -0
- package/dist/packages/domain/src/ports/project.repository.js.map +1 -0
- package/dist/packages/domain/src/rules/index.d.ts +10 -0
- package/dist/packages/domain/src/rules/index.d.ts.map +1 -0
- package/dist/packages/domain/src/rules/index.js +134 -0
- package/dist/packages/domain/src/rules/index.js.map +1 -0
- package/dist/packages/domain/src/types/analysis.d.ts +81 -0
- package/dist/packages/domain/src/types/analysis.d.ts.map +1 -0
- package/dist/packages/domain/src/types/analysis.js +6 -0
- package/dist/packages/domain/src/types/analysis.js.map +1 -0
- package/dist/packages/domain/src/types/errors.d.ts +35 -0
- package/dist/packages/domain/src/types/errors.d.ts.map +1 -0
- package/dist/packages/domain/src/types/errors.js +53 -0
- package/dist/packages/domain/src/types/errors.js.map +1 -0
- package/dist/packages/domain/src/types/fs.d.ts +32 -0
- package/dist/packages/domain/src/types/fs.d.ts.map +1 -0
- package/dist/packages/domain/src/types/fs.js +6 -0
- package/dist/packages/domain/src/types/fs.js.map +1 -0
- package/dist/packages/domain/src/types/index.d.ts +7 -0
- package/dist/packages/domain/src/types/index.d.ts.map +1 -0
- package/dist/packages/domain/src/types/index.js +7 -0
- package/dist/packages/domain/src/types/index.js.map +1 -0
- package/dist/plugins/GitStatusPlugin.d.ts +25 -0
- package/dist/plugins/GitStatusPlugin.d.ts.map +1 -0
- package/dist/plugins/GitStatusPlugin.js +93 -0
- package/dist/plugins/GitStatusPlugin.js.map +1 -0
- package/dist/providers/ai-provider.d.ts +21 -0
- package/dist/providers/ai-provider.d.ts.map +1 -0
- package/dist/providers/ai-provider.js +74 -0
- package/dist/providers/ai-provider.js.map +1 -0
- package/dist/providers/local-provider.d.ts +21 -0
- package/dist/providers/local-provider.d.ts.map +1 -0
- package/dist/providers/local-provider.js +304 -0
- package/dist/providers/local-provider.js.map +1 -0
- package/dist/providers/remote-provider.d.ts +15 -0
- package/dist/providers/remote-provider.d.ts.map +1 -0
- package/dist/providers/remote-provider.js +100 -0
- package/dist/providers/remote-provider.js.map +1 -0
- package/dist/types/api.d.ts +46 -0
- package/dist/types/api.d.ts.map +1 -0
- package/dist/types/api.js +3 -0
- package/dist/types/api.js.map +1 -0
- package/dist/ui.d.ts +52 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +219 -0
- package/dist/ui.js.map +1 -0
- package/dist/welcome.d.ts +8 -0
- package/dist/welcome.d.ts.map +1 -0
- package/dist/welcome.js +81 -0
- package/dist/welcome.js.map +1 -0
- package/package.json +97 -0
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* Delta CLI Analyzer
|
|
4
|
+
* @description Analyze projects against Delta Constitution
|
|
5
|
+
* @version 1.0.0
|
|
6
|
+
*/
|
|
7
|
+
import { Command } from 'commander';
|
|
8
|
+
import { analyzeCommand } from './commands/analyze';
|
|
9
|
+
import { reportCommand } from './commands/report';
|
|
10
|
+
import { configCommand } from './commands/config';
|
|
11
|
+
const program = new Command();
|
|
12
|
+
program
|
|
13
|
+
.name('delta-analyze')
|
|
14
|
+
.description('Analyze projects against Delta Constitution')
|
|
15
|
+
.version('1.0.0');
|
|
16
|
+
// Analyze command
|
|
17
|
+
program
|
|
18
|
+
.command('analyze')
|
|
19
|
+
.description('Analyze a project against Delta Constitution')
|
|
20
|
+
.argument('<path>', 'Project path to analyze')
|
|
21
|
+
.option('-l, --language <lang>', 'Project language', 'typescript')
|
|
22
|
+
.option('-o, --output <format>', 'Output format (json|html|markdown)', 'json')
|
|
23
|
+
.option('-d, --depth <level>', 'Analysis depth (quick|standard|deep)', 'standard')
|
|
24
|
+
.option('--config <path>', 'Configuration file path')
|
|
25
|
+
.option('--strict', 'Fail on any violation', false)
|
|
26
|
+
.action(analyzeCommand);
|
|
27
|
+
// Report command
|
|
28
|
+
program
|
|
29
|
+
.command('report')
|
|
30
|
+
.description('Generate report from previous analysis')
|
|
31
|
+
.argument('<analysis-file>', 'Previous analysis JSON file')
|
|
32
|
+
.option('-t, --template <type>', 'Report template (html|markdown|pdf)', 'html')
|
|
33
|
+
.option('-o, --output <path>', 'Output file path')
|
|
34
|
+
.action(reportCommand);
|
|
35
|
+
// Config command
|
|
36
|
+
program
|
|
37
|
+
.command('config')
|
|
38
|
+
.description('Manage analyzer configuration')
|
|
39
|
+
.option('--init', 'Initialize configuration file')
|
|
40
|
+
.option('--show', 'Show current configuration')
|
|
41
|
+
.option('--set <key=value>', 'Set configuration value')
|
|
42
|
+
.action(configCommand);
|
|
43
|
+
program.parse();
|
|
44
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/analyzer/index.ts"],"names":[],"mappings":";AACA;;;;GAIG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO;KACJ,IAAI,CAAC,eAAe,CAAC;KACrB,WAAW,CAAC,6CAA6C,CAAC;KAC1D,OAAO,CAAC,OAAO,CAAC,CAAC;AAEpB,kBAAkB;AAClB,OAAO;KACJ,OAAO,CAAC,SAAS,CAAC;KAClB,WAAW,CAAC,8CAA8C,CAAC;KAC3D,QAAQ,CAAC,QAAQ,EAAE,yBAAyB,CAAC;KAC7C,MAAM,CAAC,uBAAuB,EAAE,kBAAkB,EAAE,YAAY,CAAC;KACjE,MAAM,CAAC,uBAAuB,EAAE,oCAAoC,EAAE,MAAM,CAAC;KAC7E,MAAM,CAAC,qBAAqB,EAAE,sCAAsC,EAAE,UAAU,CAAC;KACjF,MAAM,CAAC,iBAAiB,EAAE,yBAAyB,CAAC;KACpD,MAAM,CAAC,UAAU,EAAE,uBAAuB,EAAE,KAAK,CAAC;KAClD,MAAM,CAAC,cAAc,CAAC,CAAC;AAE1B,iBAAiB;AACjB,OAAO;KACJ,OAAO,CAAC,QAAQ,CAAC;KACjB,WAAW,CAAC,wCAAwC,CAAC;KACrD,QAAQ,CAAC,iBAAiB,EAAE,6BAA6B,CAAC;KAC1D,MAAM,CAAC,uBAAuB,EAAE,qCAAqC,EAAE,MAAM,CAAC;KAC9E,MAAM,CAAC,qBAAqB,EAAE,kBAAkB,CAAC;KACjD,MAAM,CAAC,aAAa,CAAC,CAAC;AAEzB,iBAAiB;AACjB,OAAO;KACJ,OAAO,CAAC,QAAQ,CAAC;KACjB,WAAW,CAAC,+BAA+B,CAAC;KAC5C,MAAM,CAAC,QAAQ,EAAE,+BAA+B,CAAC;KACjD,MAAM,CAAC,QAAQ,EAAE,4BAA4B,CAAC;KAC9C,MAAM,CAAC,mBAAmB,EAAE,yBAAyB,CAAC;KACtD,MAAM,CAAC,aAAa,CAAC,CAAC;AAEzB,OAAO,CAAC,KAAK,EAAE,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Project Scanner
|
|
3
|
+
* @description Scans project structure and extracts metadata
|
|
4
|
+
*/
|
|
5
|
+
export interface ProjectInfo {
|
|
6
|
+
path: string;
|
|
7
|
+
name: string;
|
|
8
|
+
language: string;
|
|
9
|
+
size: number;
|
|
10
|
+
fileCount: number;
|
|
11
|
+
files: string[];
|
|
12
|
+
directories: string[];
|
|
13
|
+
imports: ImportInfo[];
|
|
14
|
+
hasPackageJson: boolean;
|
|
15
|
+
hasTsConfig: boolean;
|
|
16
|
+
hasTests: boolean;
|
|
17
|
+
}
|
|
18
|
+
export interface ImportInfo {
|
|
19
|
+
source: string;
|
|
20
|
+
target: string;
|
|
21
|
+
type: 'internal' | 'external';
|
|
22
|
+
}
|
|
23
|
+
export declare class ProjectScanner {
|
|
24
|
+
static scan(projectPath: string, language: string): Promise<ProjectInfo>;
|
|
25
|
+
private static scanDirectory;
|
|
26
|
+
private static isSourceFile;
|
|
27
|
+
private static extractImports;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=project.scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.scanner.d.ts","sourceRoot":"","sources":["../../../src/analyzer/scanners/project.scanner.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,OAAO,EAAE,UAAU,EAAE,CAAC;IACtB,cAAc,EAAE,OAAO,CAAC;IACxB,WAAW,EAAE,OAAO,CAAC;IACrB,QAAQ,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,UAAU,GAAG,UAAU,CAAC;CAC/B;AAED,qBAAa,cAAc;WACZ,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;mBA+BzD,aAAa;IAqClC,OAAO,CAAC,MAAM,CAAC,YAAY;mBAKN,cAAc;CA2BpC"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Project Scanner
|
|
3
|
+
* @description Scans project structure and extracts metadata
|
|
4
|
+
*/
|
|
5
|
+
import * as fs from 'fs/promises';
|
|
6
|
+
import * as path from 'path';
|
|
7
|
+
export class ProjectScanner {
|
|
8
|
+
static async scan(projectPath, language) {
|
|
9
|
+
const files = [];
|
|
10
|
+
const directories = [];
|
|
11
|
+
const totalSize = 0;
|
|
12
|
+
// Scan directory recursively
|
|
13
|
+
await this.scanDirectory(projectPath, '', files, directories, totalSize);
|
|
14
|
+
// Detect project metadata
|
|
15
|
+
const hasPackageJson = files.some(f => f.endsWith('package.json'));
|
|
16
|
+
const hasTsConfig = files.some(f => f.endsWith('tsconfig.json'));
|
|
17
|
+
const hasTests = files.some(f => f.includes('.test.') || f.includes('.spec.'));
|
|
18
|
+
// Extract imports
|
|
19
|
+
const imports = await this.extractImports(files, projectPath);
|
|
20
|
+
return {
|
|
21
|
+
path: projectPath,
|
|
22
|
+
name: path.basename(projectPath),
|
|
23
|
+
language,
|
|
24
|
+
size: totalSize,
|
|
25
|
+
fileCount: files.length,
|
|
26
|
+
files,
|
|
27
|
+
directories,
|
|
28
|
+
imports,
|
|
29
|
+
hasPackageJson,
|
|
30
|
+
hasTsConfig,
|
|
31
|
+
hasTests,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
static async scanDirectory(basePath, relativePath, files, directories, totalSize) {
|
|
35
|
+
const fullPath = path.join(basePath, relativePath);
|
|
36
|
+
try {
|
|
37
|
+
const entries = await fs.readdir(fullPath, { withFileTypes: true });
|
|
38
|
+
for (const entry of entries) {
|
|
39
|
+
const entryRelativePath = path.join(relativePath, entry.name);
|
|
40
|
+
// Skip node_modules and hidden directories
|
|
41
|
+
if (entry.name === 'node_modules' || entry.name.startsWith('.')) {
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
if (entry.isDirectory()) {
|
|
45
|
+
directories.push(entryRelativePath);
|
|
46
|
+
await this.scanDirectory(basePath, entryRelativePath, files, directories, totalSize);
|
|
47
|
+
}
|
|
48
|
+
else if (entry.isFile()) {
|
|
49
|
+
// Only include source files
|
|
50
|
+
if (this.isSourceFile(entry.name)) {
|
|
51
|
+
files.push(entryRelativePath);
|
|
52
|
+
const stats = await fs.stat(path.join(fullPath, entry.name));
|
|
53
|
+
totalSize += stats.size;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
// Directory not accessible, skip
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
static isSourceFile(filename) {
|
|
63
|
+
const extensions = ['.ts', '.tsx', '.js', '.jsx', '.json', '.md'];
|
|
64
|
+
return extensions.some(ext => filename.endsWith(ext));
|
|
65
|
+
}
|
|
66
|
+
static async extractImports(files, projectPath) {
|
|
67
|
+
const imports = [];
|
|
68
|
+
for (const file of files) {
|
|
69
|
+
if (!file.endsWith('.ts') && !file.endsWith('.tsx'))
|
|
70
|
+
continue;
|
|
71
|
+
try {
|
|
72
|
+
const content = await fs.readFile(path.join(projectPath, file), 'utf-8');
|
|
73
|
+
const importMatches = content.match(/import\s+.*?\s+from\s+['"]([^'"]+)['"];?/g) || [];
|
|
74
|
+
for (const match of importMatches) {
|
|
75
|
+
const importPath = match.match(/from\s+['"]([^'"]+)['"]/)?.[1];
|
|
76
|
+
if (importPath) {
|
|
77
|
+
imports.push({
|
|
78
|
+
source: file,
|
|
79
|
+
target: importPath,
|
|
80
|
+
type: importPath.startsWith('.') ? 'internal' : 'external',
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
catch (error) {
|
|
86
|
+
// Skip files that can't be read
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
return imports;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=project.scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.scanner.js","sourceRoot":"","sources":["../../../src/analyzer/scanners/project.scanner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Contracts Validator
|
|
3
|
+
* @description Validates Contracts rules
|
|
4
|
+
*/
|
|
5
|
+
import { ProjectInfo } from '../scanners/project.scanner';
|
|
6
|
+
interface ValidationOptions {
|
|
7
|
+
depth: string;
|
|
8
|
+
}
|
|
9
|
+
interface ValidationResult {
|
|
10
|
+
score: number;
|
|
11
|
+
maxScore: number;
|
|
12
|
+
percentage: number;
|
|
13
|
+
violations: Violation[];
|
|
14
|
+
}
|
|
15
|
+
interface Violation {
|
|
16
|
+
id: string;
|
|
17
|
+
severity: 'critical' | 'error' | 'warning' | 'info';
|
|
18
|
+
message: string;
|
|
19
|
+
file?: string;
|
|
20
|
+
line?: number;
|
|
21
|
+
rule: string;
|
|
22
|
+
}
|
|
23
|
+
export declare class ContractsValidator {
|
|
24
|
+
static validate(project: ProjectInfo, _options: ValidationOptions): Promise<ValidationResult>;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=contracts.validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contracts.validator.d.ts","sourceRoot":"","sources":["../../../src/analyzer/validators/contracts.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB;AAED,UAAU,SAAS;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,kBAAkB;WAChB,QAAQ,CACnB,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,gBAAgB,CAAC;CAyC7B"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Contracts Validator
|
|
3
|
+
* @description Validates Contracts rules
|
|
4
|
+
*/
|
|
5
|
+
export class ContractsValidator {
|
|
6
|
+
static async validate(project, _options) {
|
|
7
|
+
const violations = [];
|
|
8
|
+
let score = 100;
|
|
9
|
+
// Check for contract files
|
|
10
|
+
const contractFiles = project.files.filter(f => f.includes('.contract.'));
|
|
11
|
+
if (contractFiles.length === 0) {
|
|
12
|
+
violations.push({
|
|
13
|
+
id: 'CONTRACT-001',
|
|
14
|
+
severity: 'error',
|
|
15
|
+
message: 'No contract files found',
|
|
16
|
+
rule: 'Contracts Required',
|
|
17
|
+
});
|
|
18
|
+
score -= 30;
|
|
19
|
+
}
|
|
20
|
+
// Check for required contracts
|
|
21
|
+
const requiredContracts = ['auth', 'upload', 'projects', 'analysis'];
|
|
22
|
+
for (const contract of requiredContracts) {
|
|
23
|
+
const hasContract = contractFiles.some(f => f.includes(`${contract}.contract`));
|
|
24
|
+
if (!hasContract) {
|
|
25
|
+
violations.push({
|
|
26
|
+
id: 'CONTRACT-002',
|
|
27
|
+
severity: 'warning',
|
|
28
|
+
message: `Missing ${contract}.contract.ts`,
|
|
29
|
+
rule: 'Required Contracts',
|
|
30
|
+
});
|
|
31
|
+
score -= 10;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return {
|
|
35
|
+
score: Math.max(0, score),
|
|
36
|
+
maxScore: 100,
|
|
37
|
+
percentage: Math.max(0, score),
|
|
38
|
+
violations,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=contracts.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contracts.validator.js","sourceRoot":"","sources":["../../../src/analyzer/validators/contracts.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAwBH,MAAM,OAAO,kBAAkB;IAC7B,MAAM,CAAC,KAAK,CAAC,QAAQ,CACnB,OAAoB,EACpB,QAA2B;QAE3B,MAAM,UAAU,GAAgB,EAAE,CAAC;QACnC,IAAI,KAAK,GAAG,GAAG,CAAC;QAEhB,2BAA2B;QAC3B,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;QAE1E,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC/B,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,cAAc;gBAClB,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,yBAAyB;gBAClC,IAAI,EAAE,oBAAoB;aAC3B,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,+BAA+B;QAC/B,MAAM,iBAAiB,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAErE,KAAK,MAAM,QAAQ,IAAI,iBAAiB,EAAE,CAAC;YACzC,MAAM,WAAW,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,QAAQ,WAAW,CAAC,CAAC,CAAC;YAEhF,IAAI,CAAC,WAAW,EAAE,CAAC;gBACjB,UAAU,CAAC,IAAI,CAAC;oBACd,EAAE,EAAE,cAAc;oBAClB,QAAQ,EAAE,SAAS;oBACnB,OAAO,EAAE,WAAW,QAAQ,cAAc;oBAC1C,IAAI,EAAE,oBAAoB;iBAC3B,CAAC,CAAC;gBACH,KAAK,IAAI,EAAE,CAAC;YACd,CAAC;QACH,CAAC;QAED,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YACzB,QAAQ,EAAE,GAAG;YACb,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YAC9B,UAAU;SACX,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Maintainability Validator
|
|
3
|
+
* @description Validates Maintainability rules
|
|
4
|
+
*/
|
|
5
|
+
import { ProjectInfo } from '../scanners/project.scanner';
|
|
6
|
+
interface ValidationOptions {
|
|
7
|
+
depth: string;
|
|
8
|
+
}
|
|
9
|
+
interface ValidationResult {
|
|
10
|
+
score: number;
|
|
11
|
+
maxScore: number;
|
|
12
|
+
percentage: number;
|
|
13
|
+
violations: Violation[];
|
|
14
|
+
}
|
|
15
|
+
interface Violation {
|
|
16
|
+
id: string;
|
|
17
|
+
severity: 'critical' | 'error' | 'warning' | 'info';
|
|
18
|
+
message: string;
|
|
19
|
+
file?: string;
|
|
20
|
+
line?: number;
|
|
21
|
+
rule: string;
|
|
22
|
+
}
|
|
23
|
+
export declare class MaintainabilityValidator {
|
|
24
|
+
static validate(project: ProjectInfo, _options: ValidationOptions): Promise<ValidationResult>;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=maintainability.validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"maintainability.validator.d.ts","sourceRoot":"","sources":["../../../src/analyzer/validators/maintainability.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB;AAED,UAAU,SAAS;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,wBAAwB;WACtB,QAAQ,CACnB,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,gBAAgB,CAAC;CAyC7B"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Maintainability Validator
|
|
3
|
+
* @description Validates Maintainability rules
|
|
4
|
+
*/
|
|
5
|
+
export class MaintainabilityValidator {
|
|
6
|
+
static async validate(project, _options) {
|
|
7
|
+
const violations = [];
|
|
8
|
+
let score = 100;
|
|
9
|
+
// Check for tests
|
|
10
|
+
const testFiles = project.files.filter(f => f.includes('.test.') || f.includes('.spec.'));
|
|
11
|
+
const testRatio = testFiles.length / (project.fileCount || 1);
|
|
12
|
+
if (testRatio < 0.1) {
|
|
13
|
+
violations.push({
|
|
14
|
+
id: 'MAINT-TEST-001',
|
|
15
|
+
severity: 'warning',
|
|
16
|
+
message: `Low test coverage: ${(testRatio * 100).toFixed(1)}% of files are tests`,
|
|
17
|
+
rule: 'Testing Required',
|
|
18
|
+
});
|
|
19
|
+
score -= 20;
|
|
20
|
+
}
|
|
21
|
+
// Check for documentation
|
|
22
|
+
const hasReadme = project.files.some(f => f.toLowerCase() === 'readme.md' || f.toLowerCase().endsWith('/readme.md'));
|
|
23
|
+
if (!hasReadme) {
|
|
24
|
+
violations.push({
|
|
25
|
+
id: 'MAINT-DOC-001',
|
|
26
|
+
severity: 'warning',
|
|
27
|
+
message: 'No README.md found',
|
|
28
|
+
rule: 'Documentation Required',
|
|
29
|
+
});
|
|
30
|
+
score -= 10;
|
|
31
|
+
}
|
|
32
|
+
return {
|
|
33
|
+
score: Math.max(0, score),
|
|
34
|
+
maxScore: 100,
|
|
35
|
+
percentage: Math.max(0, score),
|
|
36
|
+
violations,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=maintainability.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"maintainability.validator.js","sourceRoot":"","sources":["../../../src/analyzer/validators/maintainability.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAwBH,MAAM,OAAO,wBAAwB;IACnC,MAAM,CAAC,KAAK,CAAC,QAAQ,CACnB,OAAoB,EACpB,QAA2B;QAE3B,MAAM,UAAU,GAAgB,EAAE,CAAC;QACnC,IAAI,KAAK,GAAG,GAAG,CAAC;QAEhB,kBAAkB;QAClB,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;QAE1F,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,GAAG,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC;QAE9D,IAAI,SAAS,GAAG,GAAG,EAAE,CAAC;YACpB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,gBAAgB;gBACpB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,sBAAsB,CAAC,SAAS,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,sBAAsB;gBACjF,IAAI,EAAE,kBAAkB;aACzB,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,0BAA0B;QAC1B,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAClC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,KAAK,WAAW,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC,CAC/E,CAAC;QAEF,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,eAAe;gBACnB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,oBAAoB;gBAC7B,IAAI,EAAE,wBAAwB;aAC/B,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YACzB,QAAQ,EAAE,GAAG;YACb,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YAC9B,UAAU;SACX,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Observability Validator
|
|
3
|
+
* @description Validates Observability rules
|
|
4
|
+
*/
|
|
5
|
+
import { ProjectInfo } from '../scanners/project.scanner';
|
|
6
|
+
interface ValidationOptions {
|
|
7
|
+
depth: string;
|
|
8
|
+
}
|
|
9
|
+
interface ValidationResult {
|
|
10
|
+
score: number;
|
|
11
|
+
maxScore: number;
|
|
12
|
+
percentage: number;
|
|
13
|
+
violations: Violation[];
|
|
14
|
+
}
|
|
15
|
+
interface Violation {
|
|
16
|
+
id: string;
|
|
17
|
+
severity: 'critical' | 'error' | 'warning' | 'info';
|
|
18
|
+
message: string;
|
|
19
|
+
file?: string;
|
|
20
|
+
line?: number;
|
|
21
|
+
rule: string;
|
|
22
|
+
}
|
|
23
|
+
export declare class ObservabilityValidator {
|
|
24
|
+
static validate(project: ProjectInfo, _options: ValidationOptions): Promise<ValidationResult>;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=observability.validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"observability.validator.d.ts","sourceRoot":"","sources":["../../../src/analyzer/validators/observability.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB;AAED,UAAU,SAAS;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,sBAAsB;WACpB,QAAQ,CACnB,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,gBAAgB,CAAC;CAuC7B"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Observability Validator
|
|
3
|
+
* @description Validates Observability rules
|
|
4
|
+
*/
|
|
5
|
+
export class ObservabilityValidator {
|
|
6
|
+
static async validate(project, _options) {
|
|
7
|
+
const violations = [];
|
|
8
|
+
let score = 100;
|
|
9
|
+
// Check for health endpoint
|
|
10
|
+
const hasHealthEndpoint = project.files.some(f => f.includes('health') || f.includes('ready') || f.includes('live'));
|
|
11
|
+
if (!hasHealthEndpoint) {
|
|
12
|
+
violations.push({
|
|
13
|
+
id: 'OBS-HEALTH-001',
|
|
14
|
+
severity: 'warning',
|
|
15
|
+
message: 'No health check endpoint found',
|
|
16
|
+
rule: 'Health Checks Required',
|
|
17
|
+
});
|
|
18
|
+
score -= 20;
|
|
19
|
+
}
|
|
20
|
+
// Check for logging
|
|
21
|
+
const hasLogging = project.files.some(f => f.includes('logger') || f.includes('log'));
|
|
22
|
+
if (!hasLogging) {
|
|
23
|
+
violations.push({
|
|
24
|
+
id: 'OBS-LOG-001',
|
|
25
|
+
severity: 'warning',
|
|
26
|
+
message: 'No logging implementation found',
|
|
27
|
+
rule: 'Structured Logging Required',
|
|
28
|
+
});
|
|
29
|
+
score -= 20;
|
|
30
|
+
}
|
|
31
|
+
return {
|
|
32
|
+
score: Math.max(0, score),
|
|
33
|
+
maxScore: 100,
|
|
34
|
+
percentage: Math.max(0, score),
|
|
35
|
+
violations,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=observability.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"observability.validator.js","sourceRoot":"","sources":["../../../src/analyzer/validators/observability.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAwBH,MAAM,OAAO,sBAAsB;IACjC,MAAM,CAAC,KAAK,CAAC,QAAQ,CACnB,OAAoB,EACpB,QAA2B;QAE3B,MAAM,UAAU,GAAgB,EAAE,CAAC;QACnC,IAAI,KAAK,GAAG,GAAG,CAAC;QAEhB,4BAA4B;QAC5B,MAAM,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAC1C,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CACvE,CAAC;QAEF,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACvB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,gBAAgB;gBACpB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,gCAAgC;gBACzC,IAAI,EAAE,wBAAwB;aAC/B,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,oBAAoB;QACpB,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAEtF,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,aAAa;gBACjB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,iCAAiC;gBAC1C,IAAI,EAAE,6BAA6B;aACpC,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YACzB,QAAQ,EAAE,GAAG;YACb,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YAC9B,UAAU;SACX,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Performance Validator
|
|
3
|
+
* @description Validates performance rules
|
|
4
|
+
*/
|
|
5
|
+
import { ProjectInfo } from '../scanners/project.scanner';
|
|
6
|
+
interface ValidationOptions {
|
|
7
|
+
depth: string;
|
|
8
|
+
}
|
|
9
|
+
interface ValidationResult {
|
|
10
|
+
score: number;
|
|
11
|
+
maxScore: number;
|
|
12
|
+
percentage: number;
|
|
13
|
+
violations: Violation[];
|
|
14
|
+
}
|
|
15
|
+
interface Violation {
|
|
16
|
+
id: string;
|
|
17
|
+
severity: 'critical' | 'error' | 'warning' | 'info';
|
|
18
|
+
message: string;
|
|
19
|
+
file?: string;
|
|
20
|
+
line?: number;
|
|
21
|
+
rule: string;
|
|
22
|
+
}
|
|
23
|
+
export declare class PerformanceValidator {
|
|
24
|
+
static validate(project: ProjectInfo, _options: ValidationOptions): Promise<ValidationResult>;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=performance.validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"performance.validator.d.ts","sourceRoot":"","sources":["../../../src/analyzer/validators/performance.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB;AAED,UAAU,SAAS;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,oBAAoB;WAClB,QAAQ,CACnB,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,gBAAgB,CAAC;CA0C7B"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Performance Validator
|
|
3
|
+
* @description Validates performance rules
|
|
4
|
+
*/
|
|
5
|
+
export class PerformanceValidator {
|
|
6
|
+
static async validate(project, _options) {
|
|
7
|
+
const violations = [];
|
|
8
|
+
let score = 100;
|
|
9
|
+
// Check for lazy loading patterns
|
|
10
|
+
const hasDynamicImports = project.files.some(f => {
|
|
11
|
+
// Would check file content for dynamic imports
|
|
12
|
+
return f.includes('dynamic') || f.includes('lazy');
|
|
13
|
+
});
|
|
14
|
+
if (!hasDynamicImports && project.fileCount > 50) {
|
|
15
|
+
violations.push({
|
|
16
|
+
id: 'PERF-LAZY-001',
|
|
17
|
+
severity: 'warning',
|
|
18
|
+
message: 'No lazy loading patterns detected in large project',
|
|
19
|
+
rule: 'Lazy Loading Recommended',
|
|
20
|
+
});
|
|
21
|
+
score -= 10;
|
|
22
|
+
}
|
|
23
|
+
// Check for caching implementation
|
|
24
|
+
const hasCaching = project.files.some(f => f.includes('cache') || f.includes('redis') || f.includes('swr'));
|
|
25
|
+
if (!hasCaching) {
|
|
26
|
+
violations.push({
|
|
27
|
+
id: 'PERF-CACHE-001',
|
|
28
|
+
severity: 'warning',
|
|
29
|
+
message: 'No caching implementation found',
|
|
30
|
+
rule: 'Caching Layer Recommended',
|
|
31
|
+
});
|
|
32
|
+
score -= 15;
|
|
33
|
+
}
|
|
34
|
+
return {
|
|
35
|
+
score: Math.max(0, score),
|
|
36
|
+
maxScore: 100,
|
|
37
|
+
percentage: Math.max(0, score),
|
|
38
|
+
violations,
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=performance.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"performance.validator.js","sourceRoot":"","sources":["../../../src/analyzer/validators/performance.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAwBH,MAAM,OAAO,oBAAoB;IAC/B,MAAM,CAAC,KAAK,CAAC,QAAQ,CACnB,OAAoB,EACpB,QAA2B;QAE3B,MAAM,UAAU,GAAgB,EAAE,CAAC;QACnC,IAAI,KAAK,GAAG,GAAG,CAAC;QAEhB,kCAAkC;QAClC,MAAM,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;YAC/C,+CAA+C;YAC/C,OAAO,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,IAAI,OAAO,CAAC,SAAS,GAAG,EAAE,EAAE,CAAC;YACjD,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,eAAe;gBACnB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,oDAAoD;gBAC7D,IAAI,EAAE,0BAA0B;aACjC,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,mCAAmC;QACnC,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CACnC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CACrE,CAAC;QAEF,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,gBAAgB;gBACpB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,iCAAiC;gBAC1C,IAAI,EAAE,2BAA2B;aAClC,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YACzB,QAAQ,EAAE,GAAG;YACb,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YAC9B,UAAU;SACX,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Security Validator
|
|
3
|
+
* @description Validates security rules against project
|
|
4
|
+
*/
|
|
5
|
+
import { ProjectInfo } from '../scanners/project.scanner';
|
|
6
|
+
interface ValidationOptions {
|
|
7
|
+
depth: string;
|
|
8
|
+
}
|
|
9
|
+
interface ValidationResult {
|
|
10
|
+
score: number;
|
|
11
|
+
maxScore: number;
|
|
12
|
+
percentage: number;
|
|
13
|
+
violations: Violation[];
|
|
14
|
+
}
|
|
15
|
+
interface Violation {
|
|
16
|
+
id: string;
|
|
17
|
+
severity: 'critical' | 'error' | 'warning' | 'info';
|
|
18
|
+
message: string;
|
|
19
|
+
file?: string;
|
|
20
|
+
line?: number;
|
|
21
|
+
rule: string;
|
|
22
|
+
}
|
|
23
|
+
export declare class SecurityValidator {
|
|
24
|
+
static validate(project: ProjectInfo, options: ValidationOptions): Promise<ValidationResult>;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=security.validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security.validator.d.ts","sourceRoot":"","sources":["../../../src/analyzer/validators/security.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB;AAED,UAAU,SAAS;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,iBAAiB;WACf,QAAQ,CACnB,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,iBAAiB,GACzB,OAAO,CAAC,gBAAgB,CAAC;CAuE7B"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Security Validator
|
|
3
|
+
* @description Validates security rules against project
|
|
4
|
+
*/
|
|
5
|
+
export class SecurityValidator {
|
|
6
|
+
static async validate(project, options) {
|
|
7
|
+
const violations = [];
|
|
8
|
+
let score = 100;
|
|
9
|
+
// Check 1: Policy Registry exists
|
|
10
|
+
const hasPolicyRegistry = project.directories.some(d => d.includes('modules') && d.includes('policies'));
|
|
11
|
+
if (!hasPolicyRegistry) {
|
|
12
|
+
violations.push({
|
|
13
|
+
id: 'SEC-POL-002',
|
|
14
|
+
severity: 'error',
|
|
15
|
+
message: 'Missing policies/ directory in modules',
|
|
16
|
+
rule: 'Policy Registry Required',
|
|
17
|
+
});
|
|
18
|
+
score -= 15;
|
|
19
|
+
}
|
|
20
|
+
// Check 2: Audit logging
|
|
21
|
+
const hasAuditFile = project.files.some(f => f.includes('audit') || f.includes('logger'));
|
|
22
|
+
if (!hasAuditFile) {
|
|
23
|
+
violations.push({
|
|
24
|
+
id: 'SEC-AUDIT-001',
|
|
25
|
+
severity: 'warning',
|
|
26
|
+
message: 'No audit logging implementation found',
|
|
27
|
+
rule: 'Audit Logging Required',
|
|
28
|
+
});
|
|
29
|
+
score -= 10;
|
|
30
|
+
}
|
|
31
|
+
// Check 3: Rate limiting
|
|
32
|
+
const hasRateLimit = project.files.some(f => f.includes('rate') || f.includes('limit'));
|
|
33
|
+
if (!hasRateLimit) {
|
|
34
|
+
violations.push({
|
|
35
|
+
id: 'SEC-RATE-001',
|
|
36
|
+
severity: 'warning',
|
|
37
|
+
message: 'No rate limiting implementation found',
|
|
38
|
+
rule: 'Rate Limiting Required',
|
|
39
|
+
});
|
|
40
|
+
score -= 10;
|
|
41
|
+
}
|
|
42
|
+
// Check 4: Security directory
|
|
43
|
+
const hasSecurityDir = project.directories.some(d => d.includes('security'));
|
|
44
|
+
if (!hasSecurityDir) {
|
|
45
|
+
violations.push({
|
|
46
|
+
id: 'SEC-DIR-001',
|
|
47
|
+
severity: 'error',
|
|
48
|
+
message: 'Missing security/ directory',
|
|
49
|
+
rule: 'Security Layer Required',
|
|
50
|
+
});
|
|
51
|
+
score -= 15;
|
|
52
|
+
}
|
|
53
|
+
// Deep scan for Fail-Open patterns (if requested)
|
|
54
|
+
if (options.depth === 'deep') {
|
|
55
|
+
// This would scan file contents for fail-open patterns
|
|
56
|
+
// For now, just check structure
|
|
57
|
+
}
|
|
58
|
+
return {
|
|
59
|
+
score: Math.max(0, score),
|
|
60
|
+
maxScore: 100,
|
|
61
|
+
percentage: Math.max(0, score),
|
|
62
|
+
violations,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=security.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security.validator.js","sourceRoot":"","sources":["../../../src/analyzer/validators/security.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAwBH,MAAM,OAAO,iBAAiB;IAC5B,MAAM,CAAC,KAAK,CAAC,QAAQ,CACnB,OAAoB,EACpB,OAA0B;QAE1B,MAAM,UAAU,GAAgB,EAAE,CAAC;QACnC,IAAI,KAAK,GAAG,GAAG,CAAC;QAEhB,kCAAkC;QAClC,MAAM,iBAAiB,GAAG,OAAO,CAAC,WAAW,CAAC,IAAI,CAChD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CACrD,CAAC;QAEF,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACvB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,aAAa;gBACjB,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,wCAAwC;gBACjD,IAAI,EAAE,0BAA0B;aACjC,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,yBAAyB;QACzB,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;QAE1F,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,eAAe;gBACnB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,uCAAuC;gBAChD,IAAI,EAAE,wBAAwB;aAC/B,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,yBAAyB;QACzB,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;QAExF,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,cAAc;gBAClB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,uCAAuC;gBAChD,IAAI,EAAE,wBAAwB;aAC/B,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,8BAA8B;QAC9B,MAAM,cAAc,GAAG,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC;QAE7E,IAAI,CAAC,cAAc,EAAE,CAAC;YACpB,UAAU,CAAC,IAAI,CAAC;gBACd,EAAE,EAAE,aAAa;gBACjB,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,6BAA6B;gBACtC,IAAI,EAAE,yBAAyB;aAChC,CAAC,CAAC;YACH,KAAK,IAAI,EAAE,CAAC;QACd,CAAC;QAED,kDAAkD;QAClD,IAAI,OAAO,CAAC,KAAK,KAAK,MAAM,EAAE,CAAC;YAC7B,uDAAuD;YACvD,gCAAgC;QAClC,CAAC;QAED,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YACzB,QAAQ,EAAE,GAAG;YACb,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;YAC9B,UAAU;SACX,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SoC Validator
|
|
3
|
+
* @description Validates Separation of Concerns rules
|
|
4
|
+
*/
|
|
5
|
+
import { ProjectInfo } from '../scanners/project.scanner';
|
|
6
|
+
interface ValidationOptions {
|
|
7
|
+
depth: string;
|
|
8
|
+
}
|
|
9
|
+
interface ValidationResult {
|
|
10
|
+
score: number;
|
|
11
|
+
maxScore: number;
|
|
12
|
+
percentage: number;
|
|
13
|
+
violations: Violation[];
|
|
14
|
+
}
|
|
15
|
+
interface Violation {
|
|
16
|
+
id: string;
|
|
17
|
+
severity: 'critical' | 'error' | 'warning' | 'info';
|
|
18
|
+
message: string;
|
|
19
|
+
file?: string;
|
|
20
|
+
line?: number;
|
|
21
|
+
rule: string;
|
|
22
|
+
}
|
|
23
|
+
export declare class SocValidator {
|
|
24
|
+
static validate(project: ProjectInfo, _options: ValidationOptions): Promise<ValidationResult>;
|
|
25
|
+
}
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=soc.validator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"soc.validator.d.ts","sourceRoot":"","sources":["../../../src/analyzer/validators/soc.validator.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,UAAU,iBAAiB;IACzB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,UAAU,gBAAgB;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,SAAS,EAAE,CAAC;CACzB;AAED,UAAU,SAAS;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,UAAU,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,YAAY;WACV,QAAQ,CACnB,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAE,iBAAiB,GAC1B,OAAO,CAAC,gBAAgB,CAAC;CA+E7B"}
|