pumuki-ast-hooks 5.3.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/LICENSE +21 -0
- package/README.md +1105 -0
- package/bin/__tests__/auto-fix-violations.spec.js +132 -0
- package/bin/__tests__/auto-restart-guards.spec.js +11 -0
- package/bin/__tests__/check-doc-drift.spec.js +11 -0
- package/bin/__tests__/check-version.spec.js +240 -0
- package/bin/__tests__/cli.spec.js +11 -0
- package/bin/__tests__/guard-auto-manager.spec.js +11 -0
- package/bin/__tests__/guard-supervisor.spec.js +11 -0
- package/bin/__tests__/hook-status.spec.js +11 -0
- package/bin/__tests__/install.spec.js +11 -0
- package/bin/__tests__/nightly-metrics-report.spec.js +94 -0
- package/bin/__tests__/plan-review.spec.js +11 -0
- package/bin/__tests__/predictive-hooks.spec.js +11 -0
- package/bin/__tests__/run-ast-adapter.spec.js +11 -0
- package/bin/__tests__/run-orchestrator.spec.js +11 -0
- package/bin/__tests__/run-playbook.spec.js +11 -0
- package/bin/__tests__/setup-eslint.spec.js +11 -0
- package/bin/__tests__/violations-api.spec.js +11 -0
- package/bin/__tests__/watch-hooks.spec.js +11 -0
- package/bin/ai-commit.sh +5 -0
- package/bin/audit +5 -0
- package/bin/audit-library.js +6 -0
- package/bin/auto-fix-violations.js +19 -0
- package/bin/auto-restart-guards.js +6 -0
- package/bin/check-doc-drift.js +6 -0
- package/bin/check-version.js +19 -0
- package/bin/cleanup-branches.sh +5 -0
- package/bin/cli.js +6 -0
- package/bin/demo-recording.sh +5 -0
- package/bin/demo-violations +5 -0
- package/bin/fix-enforcer +5 -0
- package/bin/fix-gitflow-enforcement.sh +5 -0
- package/bin/generate-progress-report.sh +5 -0
- package/bin/git-analyze-pairs.sh +5 -0
- package/bin/git-leave-branch-check.sh +5 -0
- package/bin/gitflow +5 -0
- package/bin/gitflow-shell-integration.sh +5 -0
- package/bin/guard-auto-manager.js +6 -0
- package/bin/guard-autostart.sh +5 -0
- package/bin/guard-env.sh +5 -0
- package/bin/guard-supervisor.js +6 -0
- package/bin/hook-status.js +6 -0
- package/bin/install-git-wrapper.sh +5 -0
- package/bin/install.js +6 -0
- package/bin/kill-mcp-zombies.sh +5 -0
- package/bin/nightly-metrics-report.js +8 -0
- package/bin/plan-review.js +6 -0
- package/bin/predictive-hooks.js +6 -0
- package/bin/pumuki-audit.js +6 -0
- package/bin/pumuki-init.js +19 -0
- package/bin/pumuki-mcp-server.js +13 -0
- package/bin/pumuki-mcp.js +6 -0
- package/bin/pumuki-rules.js +6 -0
- package/bin/request-no-verify-approval.sh +5 -0
- package/bin/run-ast-adapter.js +6 -0
- package/bin/run-intelligent-audit.sh +5 -0
- package/bin/run-orchestrator.js +6 -0
- package/bin/run-playbook.js +6 -0
- package/bin/session-loader.sh +5 -0
- package/bin/setup-eslint.js +6 -0
- package/bin/start-guards.sh +5 -0
- package/bin/sync-autonomous-orchestrator.sh +5 -0
- package/bin/sync-to-library.sh +5 -0
- package/bin/update-evidence.sh +5 -0
- package/bin/update-session-context.sh +5 -0
- package/bin/verify-no-verify.sh +5 -0
- package/bin/violations +5 -0
- package/bin/violations-api.js +6 -0
- package/bin/watch-hooks.js +6 -0
- package/docs/API_REFERENCE.md +161 -0
- package/docs/ARCHITECTURE.md +236 -0
- package/docs/ARCHITECTURE_DETAILED.md +499 -0
- package/docs/BRANCH_PROTECTION_GUIDE.md +236 -0
- package/docs/CODE_STANDARDS.md +440 -0
- package/docs/CONTRIBUTING.md +246 -0
- package/docs/DEPENDENCIES.md +541 -0
- package/docs/HOW_IT_WORKS.md +716 -0
- package/docs/INSTALLATION.md +784 -0
- package/docs/MCP_SERVERS.md +786 -0
- package/docs/TESTING.md +423 -0
- package/docs/USAGE.md +856 -0
- package/docs/images/ast_intelligence_01.png +0 -0
- package/docs/images/ast_intelligence_02.png +0 -0
- package/docs/images/ast_intelligence_03.png +0 -0
- package/docs/images/ast_intelligence_04.png +0 -0
- package/docs/images/ast_intelligence_05.png +0 -0
- package/hooks/getSkillRulesPath.ts +52 -0
- package/hooks/git-status-monitor.ts +160 -0
- package/hooks/index.js +5 -0
- package/hooks/notify-macos.ts +42 -0
- package/hooks/package.json +16 -0
- package/hooks/post-tool-use-tracker.sh +89 -0
- package/hooks/pre-tool-use-evidence-validator.ts +252 -0
- package/hooks/pre-tool-use-guard.ts +151 -0
- package/hooks/skill-activation-prompt.sh +8 -0
- package/hooks/skill-activation-prompt.ts +307 -0
- package/index.js +49 -0
- package/package.json +117 -0
- package/presentation/cli/audit.sh +24 -0
- package/presentation/cli/autonomous-status.sh +92 -0
- package/presentation/cli/categorize-violations.sh +179 -0
- package/presentation/cli/direct-audit-option2.sh +23 -0
- package/presentation/cli/direct-audit.sh +33 -0
- package/scripts/hooks-system/.AI_TOKEN_STATUS.txt +16 -0
- package/scripts/hooks-system/.audit-reports/auto-recovery.log +1 -0
- package/scripts/hooks-system/.audit-reports/install-wizard.log +4 -0
- package/scripts/hooks-system/.audit-reports/notifications.log +425 -0
- package/scripts/hooks-system/.audit-reports/token-monitor.log +1275 -0
- package/scripts/hooks-system/.audit_tmp/intelligent-report.json +44953 -0
- package/scripts/hooks-system/.audit_tmp/intelligent-report.txt +1338 -0
- package/scripts/hooks-system/.audit_tmp/severity-history.jsonl +1 -0
- package/scripts/hooks-system/.audit_tmp/token-usage.jsonl +1 -0
- package/scripts/hooks-system/.hook-system/config.json +8 -0
- package/scripts/hooks-system/application/CompositionRoot.js +325 -0
- package/scripts/hooks-system/application/__tests__/CompositionRoot.spec.js +84 -0
- package/scripts/hooks-system/application/commands/index.js +64 -0
- package/scripts/hooks-system/application/queries/index.js +60 -0
- package/scripts/hooks-system/application/services/AutonomousOrchestrator.js +130 -0
- package/scripts/hooks-system/application/services/ContextDetectionEngine.js +181 -0
- package/scripts/hooks-system/application/services/DynamicRulesLoader.js +182 -0
- package/scripts/hooks-system/application/services/GitFlowService.js +156 -0
- package/scripts/hooks-system/application/services/GitTreeState.js +140 -0
- package/scripts/hooks-system/application/services/HookSystemScheduler.js +77 -0
- package/scripts/hooks-system/application/services/IntelligentCommitAnalyzer.js +151 -0
- package/scripts/hooks-system/application/services/IntelligentGitTreeMonitor.js +118 -0
- package/scripts/hooks-system/application/services/PlatformAnalysisService.js +173 -0
- package/scripts/hooks-system/application/services/PlatformDetectionService.js +168 -0
- package/scripts/hooks-system/application/services/PlaybookRunner.js +39 -0
- package/scripts/hooks-system/application/services/PredictiveHookAdvisor.js +56 -0
- package/scripts/hooks-system/application/services/RealtimeGuardPlugin.js +62 -0
- package/scripts/hooks-system/application/services/RealtimeGuardService.js +374 -0
- package/scripts/hooks-system/application/services/SmartDirtyTreeAnalyzer.js +63 -0
- package/scripts/hooks-system/application/services/__tests__/AutonomousOrchestrator.spec.js +36 -0
- package/scripts/hooks-system/application/services/__tests__/ContextDetectionEngine.spec.js +33 -0
- package/scripts/hooks-system/application/services/__tests__/DynamicRulesLoader.spec.js +43 -0
- package/scripts/hooks-system/application/services/__tests__/GitTreeState.spec.js +163 -0
- package/scripts/hooks-system/application/services/__tests__/HookSystemScheduler.spec.js +207 -0
- package/scripts/hooks-system/application/services/__tests__/IntelligentCommitAnalyzer.spec.js +365 -0
- package/scripts/hooks-system/application/services/__tests__/IntelligentGitTreeMonitor.spec.js +188 -0
- package/scripts/hooks-system/application/services/__tests__/PlatformDetectionService.spec.js +28 -0
- package/scripts/hooks-system/application/services/__tests__/PlaybookRunner.spec.js +143 -0
- package/scripts/hooks-system/application/services/__tests__/PredictiveHookAdvisor.spec.js +181 -0
- package/scripts/hooks-system/application/services/__tests__/RealtimeGuardPlugin.spec.js +45 -0
- package/scripts/hooks-system/application/services/__tests__/RealtimeGuardService.critical.spec.js +401 -0
- package/scripts/hooks-system/application/services/commit/CommitMessageGenerator.js +34 -0
- package/scripts/hooks-system/application/services/commit/FeatureDetector.js +101 -0
- package/scripts/hooks-system/application/services/evidence/EvidenceContextManager.js +163 -0
- package/scripts/hooks-system/application/services/evidence/__tests__/EvidenceContextManager.spec.js +98 -0
- package/scripts/hooks-system/application/services/guard/GuardAutoManagerService.js +169 -0
- package/scripts/hooks-system/application/services/guard/GuardConfig.js +15 -0
- package/scripts/hooks-system/application/services/guard/GuardEventLogger.js +70 -0
- package/scripts/hooks-system/application/services/guard/GuardHealthReminder.js +54 -0
- package/scripts/hooks-system/application/services/guard/GuardHeartbeatMonitor.js +94 -0
- package/scripts/hooks-system/application/services/guard/GuardLockManager.js +72 -0
- package/scripts/hooks-system/application/services/guard/GuardMonitorLoop.js +29 -0
- package/scripts/hooks-system/application/services/guard/GuardNotificationHandler.js +36 -0
- package/scripts/hooks-system/application/services/guard/GuardProcessManager.js +113 -0
- package/scripts/hooks-system/application/services/guard/GuardRecoveryService.js +90 -0
- package/scripts/hooks-system/application/services/guard/__tests__/GuardAutoManagerService.spec.js +77 -0
- package/scripts/hooks-system/application/services/installation/ConfigurationGeneratorService.js +123 -0
- package/scripts/hooks-system/application/services/installation/FileSystemInstallerService.js +112 -0
- package/scripts/hooks-system/application/services/installation/GitEnvironmentService.js +166 -0
- package/scripts/hooks-system/application/services/installation/HookInstaller.js +197 -0
- package/scripts/hooks-system/application/services/installation/IdeIntegrationService.js +37 -0
- package/scripts/hooks-system/application/services/installation/InstallService.js +130 -0
- package/scripts/hooks-system/application/services/installation/McpConfigurator.js +172 -0
- package/scripts/hooks-system/application/services/installation/PlatformDetectorService.js +36 -0
- package/scripts/hooks-system/application/services/installation/VSCodeTaskConfigurator.js +97 -0
- package/scripts/hooks-system/application/services/logging/UnifiedLogger.js +142 -0
- package/scripts/hooks-system/application/services/logging/__tests__/UnifiedLogger.spec.js +66 -0
- package/scripts/hooks-system/application/services/monitoring/ActivityMonitor.js +80 -0
- package/scripts/hooks-system/application/services/monitoring/AstMonitor.js +140 -0
- package/scripts/hooks-system/application/services/monitoring/DevDocsMonitor.js +85 -0
- package/scripts/hooks-system/application/services/monitoring/EvidenceMonitor.js +103 -0
- package/scripts/hooks-system/application/services/monitoring/EvidenceMonitorService.js +162 -0
- package/scripts/hooks-system/application/services/monitoring/GitTreeMonitor.js +123 -0
- package/scripts/hooks-system/application/services/monitoring/GitTreeMonitorService.js +114 -0
- package/scripts/hooks-system/application/services/monitoring/HealthCheckProviders.js +153 -0
- package/scripts/hooks-system/application/services/monitoring/HealthCheckService.js +118 -0
- package/scripts/hooks-system/application/services/monitoring/HeartbeatMonitorService.js +61 -0
- package/scripts/hooks-system/application/services/monitoring/TokenMonitor.js +60 -0
- package/scripts/hooks-system/application/services/monitoring/__tests__/EvidenceMonitorService.spec.js +107 -0
- package/scripts/hooks-system/application/services/monitoring/__tests__/GitTreeMonitorService.spec.js +27 -0
- package/scripts/hooks-system/application/services/monitoring/__tests__/HealthCheckProviders.spec.js +68 -0
- package/scripts/hooks-system/application/services/monitoring/__tests__/HealthCheckService.spec.js +69 -0
- package/scripts/hooks-system/application/services/monitoring/__tests__/HeartbeatMonitorService.spec.js +35 -0
- package/scripts/hooks-system/application/services/notification/MacNotificationSender.js +106 -0
- package/scripts/hooks-system/application/services/notification/NotificationCenterService.js +221 -0
- package/scripts/hooks-system/application/services/notification/NotificationDispatcher.js +42 -0
- package/scripts/hooks-system/application/services/notification/__tests__/NotificationCenterService.spec.js +40 -0
- package/scripts/hooks-system/application/services/notification/components/NotificationCooldownManager.js +62 -0
- package/scripts/hooks-system/application/services/notification/components/NotificationDeduplicator.js +67 -0
- package/scripts/hooks-system/application/services/notification/components/NotificationQueue.js +36 -0
- package/scripts/hooks-system/application/services/notification/components/NotificationRetryExecutor.js +58 -0
- package/scripts/hooks-system/application/services/platform/PlatformHeuristics.js +144 -0
- package/scripts/hooks-system/application/services/recovery/AutoRecoveryManager.js +137 -0
- package/scripts/hooks-system/application/services/recovery/__tests__/AutoRecoveryManager.spec.js +62 -0
- package/scripts/hooks-system/application/services/smart-commit/CommitMessageSuggester.js +97 -0
- package/scripts/hooks-system/application/services/smart-commit/FileContextGrouper.js +114 -0
- package/scripts/hooks-system/application/services/smart-commit/SmartCommitSummaryBuilder.js +53 -0
- package/scripts/hooks-system/application/services/token/CursorTokenService.js +44 -0
- package/scripts/hooks-system/application/services/token/TokenMetricsService.js +109 -0
- package/scripts/hooks-system/application/services/token/TokenMonitorService.js +160 -0
- package/scripts/hooks-system/application/services/token/TokenStatusReporter.js +56 -0
- package/scripts/hooks-system/application/services/token/__tests__/CursorTokenService.spec.js +69 -0
- package/scripts/hooks-system/application/services/token/__tests__/TokenMonitorService.spec.js +185 -0
- package/scripts/hooks-system/application/state/HookSystemStateMachine.js +59 -0
- package/scripts/hooks-system/application/state/__tests__/HookSystemStateMachine.spec.js +115 -0
- package/scripts/hooks-system/application/use-cases/AnalyzeCodebaseUseCase.js +54 -0
- package/scripts/hooks-system/application/use-cases/AnalyzeStagedFilesUseCase.js +61 -0
- package/scripts/hooks-system/application/use-cases/AutoExecuteAIStartUseCase.js +123 -0
- package/scripts/hooks-system/application/use-cases/BlockCommitUseCase.js +90 -0
- package/scripts/hooks-system/application/use-cases/GenerateAuditReportUseCase.js +184 -0
- package/scripts/hooks-system/application/use-cases/__tests__/AnalyzeCodebaseUseCase.spec.js +156 -0
- package/scripts/hooks-system/application/use-cases/__tests__/AnalyzeStagedFilesUseCase.spec.js +146 -0
- package/scripts/hooks-system/application/use-cases/__tests__/AutoExecuteAIStartUseCase.spec.js +89 -0
- package/scripts/hooks-system/application/use-cases/__tests__/BlockCommitUseCase.spec.js +171 -0
- package/scripts/hooks-system/application/use-cases/__tests__/GenerateAuditReportUseCase.spec.js +207 -0
- package/scripts/hooks-system/bin/__tests__/auto-fix-violations.spec.js +132 -0
- package/scripts/hooks-system/bin/__tests__/auto-restart-guards.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/check-doc-drift.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/check-version.spec.js +240 -0
- package/scripts/hooks-system/bin/__tests__/cli.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/guard-auto-manager.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/guard-supervisor.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/hook-status.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/install.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/nightly-metrics-report.spec.js +94 -0
- package/scripts/hooks-system/bin/__tests__/plan-review.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/predictive-hooks.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/run-ast-adapter.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/run-orchestrator.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/run-playbook.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/setup-eslint.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/violations-api.spec.js +11 -0
- package/scripts/hooks-system/bin/__tests__/watch-hooks.spec.js +11 -0
- package/scripts/hooks-system/bin/ai-commit.sh +63 -0
- package/scripts/hooks-system/bin/audit +463 -0
- package/scripts/hooks-system/bin/audit-library.js +54 -0
- package/scripts/hooks-system/bin/auto-fix-violations.js +130 -0
- package/scripts/hooks-system/bin/auto-restart-guards.js +93 -0
- package/scripts/hooks-system/bin/check-doc-drift.js +35 -0
- package/scripts/hooks-system/bin/check-version.js +201 -0
- package/scripts/hooks-system/bin/cleanup-branches.sh +106 -0
- package/scripts/hooks-system/bin/cli.js +208 -0
- package/scripts/hooks-system/bin/demo-recording.sh +57 -0
- package/scripts/hooks-system/bin/demo-violations +44 -0
- package/scripts/hooks-system/bin/fix-enforcer +27 -0
- package/scripts/hooks-system/bin/fix-gitflow-enforcement.sh +68 -0
- package/scripts/hooks-system/bin/generate-progress-report.sh +129 -0
- package/scripts/hooks-system/bin/git-analyze-pairs.sh +0 -0
- package/scripts/hooks-system/bin/git-leave-branch-check.sh +73 -0
- package/scripts/hooks-system/bin/gitflow +17 -0
- package/scripts/hooks-system/bin/gitflow-shell-integration.sh +64 -0
- package/scripts/hooks-system/bin/guard-auto-manager.js +44 -0
- package/scripts/hooks-system/bin/guard-autostart.sh +158 -0
- package/scripts/hooks-system/bin/guard-env.sh +40 -0
- package/scripts/hooks-system/bin/guard-supervisor.js +516 -0
- package/scripts/hooks-system/bin/hook-status.js +41 -0
- package/scripts/hooks-system/bin/install-git-wrapper.sh +53 -0
- package/scripts/hooks-system/bin/install.js +10 -0
- package/scripts/hooks-system/bin/kill-mcp-zombies.sh +48 -0
- package/scripts/hooks-system/bin/nightly-metrics-report.js +138 -0
- package/scripts/hooks-system/bin/plan-review.js +31 -0
- package/scripts/hooks-system/bin/predictive-hooks.js +18 -0
- package/scripts/hooks-system/bin/pumuki-audit.js +113 -0
- package/scripts/hooks-system/bin/pumuki-init.js +104 -0
- package/scripts/hooks-system/bin/pumuki-mcp.js +74 -0
- package/scripts/hooks-system/bin/pumuki-rules.js +74 -0
- package/scripts/hooks-system/bin/request-no-verify-approval.sh +116 -0
- package/scripts/hooks-system/bin/run-ast-adapter.js +86 -0
- package/scripts/hooks-system/bin/run-intelligent-audit.sh +67 -0
- package/scripts/hooks-system/bin/run-orchestrator.js +27 -0
- package/scripts/hooks-system/bin/run-playbook.js +23 -0
- package/scripts/hooks-system/bin/session-loader.sh +264 -0
- package/scripts/hooks-system/bin/setup-eslint.js +110 -0
- package/scripts/hooks-system/bin/start-guards.sh +190 -0
- package/scripts/hooks-system/bin/sync-autonomous-orchestrator.sh +32 -0
- package/scripts/hooks-system/bin/sync-to-library.sh +46 -0
- package/scripts/hooks-system/bin/update-evidence.sh +1167 -0
- package/scripts/hooks-system/bin/update-session-context.sh +261 -0
- package/scripts/hooks-system/bin/verify-no-verify.sh +68 -0
- package/scripts/hooks-system/bin/violations +20 -0
- package/scripts/hooks-system/bin/violations-api.js +345 -0
- package/scripts/hooks-system/bin/watch-hooks.js +20 -0
- package/scripts/hooks-system/config/project.config.json +36 -0
- package/scripts/hooks-system/config/state-map.json +12 -0
- package/scripts/hooks-system/domain/entities/AuditResult.js +139 -0
- package/scripts/hooks-system/domain/entities/Finding.js +116 -0
- package/scripts/hooks-system/domain/entities/SeverityConfig.js +73 -0
- package/scripts/hooks-system/domain/entities/SeverityConfig.ts +90 -0
- package/scripts/hooks-system/domain/entities/__tests__/AuditResult.spec.js +450 -0
- package/scripts/hooks-system/domain/entities/__tests__/Finding.spec.js +335 -0
- package/scripts/hooks-system/domain/entities/__tests__/SeverityConfig.spec.js +240 -0
- package/scripts/hooks-system/domain/entities/__tests__/entities.spec.js +29 -0
- package/scripts/hooks-system/domain/errors/__tests__/DomainErrors.spec.js +59 -0
- package/scripts/hooks-system/domain/errors/index.js +169 -0
- package/scripts/hooks-system/domain/events/__tests__/DomainEvents.spec.js +60 -0
- package/scripts/hooks-system/domain/events/index.js +121 -0
- package/scripts/hooks-system/domain/ports/IAstPort.js +67 -0
- package/scripts/hooks-system/domain/ports/IEvidencePort.js +86 -0
- package/scripts/hooks-system/domain/ports/IGitCommandPort.js +110 -0
- package/scripts/hooks-system/domain/ports/IGitPort.js +114 -0
- package/scripts/hooks-system/domain/ports/IGitQueryPort.js +93 -0
- package/scripts/hooks-system/domain/ports/INotificationPort.js +35 -0
- package/scripts/hooks-system/domain/ports/__tests__/ports.spec.js +36 -0
- package/scripts/hooks-system/domain/ports/index.js +14 -0
- package/scripts/hooks-system/domain/repositories/ICursorTokenRepository.js +13 -0
- package/scripts/hooks-system/domain/repositories/IFindingsRepository.js +30 -0
- package/scripts/hooks-system/domain/repositories/__tests__/IFindingsRepository.spec.js +18 -0
- package/scripts/hooks-system/domain/rules/CommitBlockingRules.js +142 -0
- package/scripts/hooks-system/domain/rules/__tests__/CommitBlockingRules.spec.js +18 -0
- package/scripts/hooks-system/domain/services/AuditAnalyzer.js +103 -0
- package/scripts/hooks-system/domain/services/AuditFilter.js +26 -0
- package/scripts/hooks-system/domain/services/AuditResultSerializer.js +35 -0
- package/scripts/hooks-system/domain/services/AuditScorer.js +38 -0
- package/scripts/hooks-system/domain/values/Severity.js +93 -0
- package/scripts/hooks-system/index.js +49 -0
- package/scripts/hooks-system/infrastructure/adapters/AstAnalyzerAdapter.js +150 -0
- package/scripts/hooks-system/infrastructure/adapters/FileEvidenceAdapter.js +140 -0
- package/scripts/hooks-system/infrastructure/adapters/GitCliAdapter.js +16 -0
- package/scripts/hooks-system/infrastructure/adapters/GitCommandAdapter.js +68 -0
- package/scripts/hooks-system/infrastructure/adapters/GitHubCliAdapter.js +85 -0
- package/scripts/hooks-system/infrastructure/adapters/GitQueryAdapter.js +58 -0
- package/scripts/hooks-system/infrastructure/adapters/LegacyAnalyzerAdapter.js +61 -0
- package/scripts/hooks-system/infrastructure/adapters/MacOSNotificationAdapter.js +99 -0
- package/scripts/hooks-system/infrastructure/adapters/__tests__/AstAnalyzerAdapter.spec.js +32 -0
- package/scripts/hooks-system/infrastructure/adapters/__tests__/FileEvidenceAdapter.spec.js +31 -0
- package/scripts/hooks-system/infrastructure/adapters/__tests__/GitCliAdapter.spec.js +39 -0
- package/scripts/hooks-system/infrastructure/adapters/__tests__/MacOSNotificationAdapter.spec.js +33 -0
- package/scripts/hooks-system/infrastructure/adapters/git/GitCommandRunner.js +78 -0
- package/scripts/hooks-system/infrastructure/adapters/git/GitCommandService.js +67 -0
- package/scripts/hooks-system/infrastructure/adapters/git/GitQueryService.js +50 -0
- package/scripts/hooks-system/infrastructure/adapters/index.js +14 -0
- package/scripts/hooks-system/infrastructure/ast/README.md +198 -0
- package/scripts/hooks-system/infrastructure/ast/__tests__/ast-core.spec.js +160 -0
- package/scripts/hooks-system/infrastructure/ast/__tests__/ast-intelligence.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/ast/android/__tests__/ast-android.spec.js +33 -0
- package/scripts/hooks-system/infrastructure/ast/android/__tests__/clean-architecture-analyzer.spec.js +96 -0
- package/scripts/hooks-system/infrastructure/ast/android/__tests__/ddd-analyzer.spec.js +113 -0
- package/scripts/hooks-system/infrastructure/ast/android/__tests__/detekt-runner.spec.js +36 -0
- package/scripts/hooks-system/infrastructure/ast/android/__tests__/feature-first-analyzer.spec.js +80 -0
- package/scripts/hooks-system/infrastructure/ast/android/__tests__/native-bridge.spec.js +31 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/AndroidASTIntelligentAnalyzer.js +15 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/AndroidASTParser.js +157 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/AndroidAnalysisOrchestrator.js +164 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/AndroidArchitectureDetector.js +334 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/AndroidClassAnalyzer.js +162 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/AndroidForbiddenLiteralsAnalyzer.js +261 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/AndroidSOLIDAnalyzer.js +287 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/__tests__/AndroidForbiddenLiteralsAnalyzer.spec.js +58 -0
- package/scripts/hooks-system/infrastructure/ast/android/analyzers/__tests__/AndroidSOLIDAnalyzer.spec.js +84 -0
- package/scripts/hooks-system/infrastructure/ast/android/ast-android.js +1785 -0
- package/scripts/hooks-system/infrastructure/ast/android/clean-architecture-analyzer.js +115 -0
- package/scripts/hooks-system/infrastructure/ast/android/ddd-analyzer.js +70 -0
- package/scripts/hooks-system/infrastructure/ast/android/detekt-runner.js +81 -0
- package/scripts/hooks-system/infrastructure/ast/android/feature-first-analyzer.js +53 -0
- package/scripts/hooks-system/infrastructure/ast/android/native-bridge.js +119 -0
- package/scripts/hooks-system/infrastructure/ast/archive/README.md +18 -0
- package/scripts/hooks-system/infrastructure/ast/archive/ast-intelligence.ts +276 -0
- package/scripts/hooks-system/infrastructure/ast/archive/ios-rules.js +329 -0
- package/scripts/hooks-system/infrastructure/ast/archive/kotlin-analyzer.js +332 -0
- package/scripts/hooks-system/infrastructure/ast/archive/kotlin-parser.js +303 -0
- package/scripts/hooks-system/infrastructure/ast/archive/swift-analyzer.js +390 -0
- package/scripts/hooks-system/infrastructure/ast/ast-core.js +594 -0
- package/scripts/hooks-system/infrastructure/ast/ast-intelligence.js +617 -0
- package/scripts/hooks-system/infrastructure/ast/backend/__tests__/ast-backend.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/ast/backend/__tests__/clean-architecture-analyzer.spec.js +151 -0
- package/scripts/hooks-system/infrastructure/ast/backend/__tests__/ddd-analyzer.spec.js +124 -0
- package/scripts/hooks-system/infrastructure/ast/backend/__tests__/feature-first-analyzer.spec.js +128 -0
- package/scripts/hooks-system/infrastructure/ast/backend/__tests__/forbidden-literals-analyzer.spec.js +95 -0
- package/scripts/hooks-system/infrastructure/ast/backend/__tests__/nestjs-patterns-analyzer.spec.js +59 -0
- package/scripts/hooks-system/infrastructure/ast/backend/__tests__/solid-analyzer.spec.js +114 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/BackendArchitectureDetector.js +141 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/BackendPatternDetector.js +23 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/__tests__/BackendArchitectureDetector.spec.js +239 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/__tests__/BackendPatternDetector.spec.js +58 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/detectors/CQRSDetector.js +41 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/detectors/CleanArchitectureDetector.js +52 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/detectors/FeatureFirstCleanDetector.js +74 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/detectors/LayeredArchitectureDetector.js +25 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/detectors/MVCDetector.js +32 -0
- package/scripts/hooks-system/infrastructure/ast/backend/analyzers/detectors/OnionArchitectureDetector.js +32 -0
- package/scripts/hooks-system/infrastructure/ast/backend/ast-backend-clean.js +44 -0
- package/scripts/hooks-system/infrastructure/ast/backend/ast-backend.js +2048 -0
- package/scripts/hooks-system/infrastructure/ast/backend/clean-architecture-analyzer.js +142 -0
- package/scripts/hooks-system/infrastructure/ast/backend/ddd-analyzer.js +256 -0
- package/scripts/hooks-system/infrastructure/ast/backend/feature-first-analyzer.js +70 -0
- package/scripts/hooks-system/infrastructure/ast/backend/forbidden-literals-analyzer.js +236 -0
- package/scripts/hooks-system/infrastructure/ast/backend/nestjs-patterns-analyzer.js +11 -0
- package/scripts/hooks-system/infrastructure/ast/backend/solid-analyzer.js +392 -0
- package/scripts/hooks-system/infrastructure/ast/common/BDDTDDWorkflowRules.js +52 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/BDDTDDWorkflowRules.spec.js +133 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/ast-common.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/documentation-analyzer.spec.js +120 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/images-backend-analyzer.spec.js +123 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/monorepo-health-analyzer.spec.js +118 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/network-resilience-analyzer.spec.js +180 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/offline-backend-analyzer.spec.js +111 -0
- package/scripts/hooks-system/infrastructure/ast/common/__tests__/push-backend-analyzer.spec.js +124 -0
- package/scripts/hooks-system/infrastructure/ast/common/ast-common.js +345 -0
- package/scripts/hooks-system/infrastructure/ast/common/documentation-analyzer.js +217 -0
- package/scripts/hooks-system/infrastructure/ast/common/images-backend-analyzer.js +36 -0
- package/scripts/hooks-system/infrastructure/ast/common/monorepo-health-analyzer.js +452 -0
- package/scripts/hooks-system/infrastructure/ast/common/network-resilience-analyzer.js +178 -0
- package/scripts/hooks-system/infrastructure/ast/common/offline-backend-analyzer.js +53 -0
- package/scripts/hooks-system/infrastructure/ast/common/push-backend-analyzer.js +42 -0
- package/scripts/hooks-system/infrastructure/ast/common/rules/BDDRules.js +87 -0
- package/scripts/hooks-system/infrastructure/ast/common/rules/ImplementationRules.js +83 -0
- package/scripts/hooks-system/infrastructure/ast/common/rules/TDDRules.js +109 -0
- package/scripts/hooks-system/infrastructure/ast/common/rules/WorkflowRules.js +137 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/__tests__/ast-frontend.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/analyzers/FrontendArchitectureDetector.js +289 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/analyzers/FrontendForbiddenLiteralsAnalyzer.js +257 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/analyzers/FrontendSOLIDAnalyzer.js +274 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/analyzers/__tests__/FrontendArchitectureDetector.spec.js +151 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/analyzers/__tests__/FrontendForbiddenLiteralsAnalyzer.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/analyzers/__tests__/FrontendSOLIDAnalyzer.spec.js +108 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/ast-frontend-clean.js +42 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/ast-frontend.js +2094 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/clean-architecture-analyzer.js +88 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/ddd-analyzer.js +94 -0
- package/scripts/hooks-system/infrastructure/ast/frontend/feature-first-analyzer.js +51 -0
- package/scripts/hooks-system/infrastructure/ast/ios/__tests__/ast-ios.spec.js +40 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSArchitectureDetector.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSArchitectureRules.spec.js +61 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSCICDRules.spec.js +10 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSEnterpriseAnalyzer.spec.js +36 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSForbiddenLiteralsAnalyzer.spec.js +64 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSNetworkingAdvancedRules.spec.js +10 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSPerformanceRules.spec.js +34 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSSPMRules.spec.js +10 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/__tests__/iOSSwiftUIAdvancedRules.spec.js +10 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSASTIntelligentAnalyzer.js +894 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSArchitectureDetector.js +445 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSArchitectureRules.js +700 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSCICDRules.js +431 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSEnterpriseAnalyzer.js +580 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSForbiddenLiteralsAnalyzer.js +261 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSNetworkingAdvancedRules.js +177 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSPerformanceRules.js +11 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSSPMRules.js +496 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSSwiftUIAdvancedRules.js +333 -0
- package/scripts/hooks-system/infrastructure/ast/ios/analyzers/iOSTestingAdvancedRules.js +225 -0
- package/scripts/hooks-system/infrastructure/ast/ios/ast-ios.js +2176 -0
- package/scripts/hooks-system/infrastructure/ast/ios/native-bridge.js +92 -0
- package/scripts/hooks-system/infrastructure/ast/ios/parsers/SourceKittenParser.js +471 -0
- package/scripts/hooks-system/infrastructure/ast/ios/parsers/__tests__/SourceKittenParser.spec.js +41 -0
- package/scripts/hooks-system/infrastructure/ast/text/__tests__/text-scanner.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/ast/text/text-scanner.js +1120 -0
- package/scripts/hooks-system/infrastructure/cache/CacheService.js +160 -0
- package/scripts/hooks-system/infrastructure/cli/__tests__/install-wizard.spec.js +16 -0
- package/scripts/hooks-system/infrastructure/cli/install-wizard.js +74 -0
- package/scripts/hooks-system/infrastructure/core/GitOperations.js +50 -0
- package/scripts/hooks-system/infrastructure/core/GitOperations.ts +112 -0
- package/scripts/hooks-system/infrastructure/core/__tests__/GitOperations.spec.js +146 -0
- package/scripts/hooks-system/infrastructure/eslint/eslint-integration.sh +75 -0
- package/scripts/hooks-system/infrastructure/events/EventListeners.js +143 -0
- package/scripts/hooks-system/infrastructure/events/__tests__/events.spec.js +14 -0
- package/scripts/hooks-system/infrastructure/external-tools/GitOperations.js +54 -0
- package/scripts/hooks-system/infrastructure/external-tools/eslint/backend.config.template.mjs +58 -0
- package/scripts/hooks-system/infrastructure/git-hooks/pre-push +35 -0
- package/scripts/hooks-system/infrastructure/git-server/pre-receive-hook +253 -0
- package/scripts/hooks-system/infrastructure/guards/git-wrapper.sh +32 -0
- package/scripts/hooks-system/infrastructure/guards/master-validator.sh +247 -0
- package/scripts/hooks-system/infrastructure/guards/prevent-no-verify.sh +34 -0
- package/scripts/hooks-system/infrastructure/hooks/__tests__/skill-activation-prompt.spec.js +11 -0
- package/scripts/hooks-system/infrastructure/hooks/pre-tool-use-intelligent-enforcer.sh +489 -0
- package/scripts/hooks-system/infrastructure/hooks/skill-activation-prompt.js +244 -0
- package/scripts/hooks-system/infrastructure/logging/UnifiedLoggerFactory.js +40 -0
- package/scripts/hooks-system/infrastructure/logging/__tests__/logging.spec.js +9 -0
- package/scripts/hooks-system/infrastructure/mcp/README.md +116 -0
- package/scripts/hooks-system/infrastructure/mcp/__tests__/ast-intelligence-automation.spec.js +38 -0
- package/scripts/hooks-system/infrastructure/mcp/__tests__/evidence-watcher.spec.js +38 -0
- package/scripts/hooks-system/infrastructure/mcp/ast-intelligence-automation.js +1097 -0
- package/scripts/hooks-system/infrastructure/mcp/evidence-watcher.js +128 -0
- package/scripts/hooks-system/infrastructure/mcp/package.json +17 -0
- package/scripts/hooks-system/infrastructure/mcp/services/EvidenceService.js +87 -0
- package/scripts/hooks-system/infrastructure/mcp/services/McpProtocolHandler.js +166 -0
- package/scripts/hooks-system/infrastructure/orchestration/__tests__/intelligent-audit.spec.js +11 -0
- package/scripts/hooks-system/infrastructure/orchestration/intelligent-audit.js +353 -0
- package/scripts/hooks-system/infrastructure/patterns/pattern-checks.sh +98 -0
- package/scripts/hooks-system/infrastructure/reporting/ReportImpactAnalyzer.js +109 -0
- package/scripts/hooks-system/infrastructure/reporting/ReportMetricsCalculator.js +114 -0
- package/scripts/hooks-system/infrastructure/reporting/ReportPresenter.js +86 -0
- package/scripts/hooks-system/infrastructure/reporting/__tests__/reporting.spec.js +15 -0
- package/scripts/hooks-system/infrastructure/reporting/report-generator.js +130 -0
- package/scripts/hooks-system/infrastructure/reporting/severity-tracker.js +105 -0
- package/scripts/hooks-system/infrastructure/repositories/CursorTokenRepository.js +76 -0
- package/scripts/hooks-system/infrastructure/repositories/FileFindingsRepository.js +88 -0
- package/scripts/hooks-system/infrastructure/repositories/__tests__/repositories.spec.js +20 -0
- package/scripts/hooks-system/infrastructure/repositories/datasources/CursorApiDataSource.js +73 -0
- package/scripts/hooks-system/infrastructure/repositories/datasources/CursorFileDataSource.js +55 -0
- package/scripts/hooks-system/infrastructure/severity/__tests__/severity-evaluator.spec.js +18 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/__tests__/maintainability-analyzer.spec.js +170 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/__tests__/performance-analyzer.spec.js +186 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/__tests__/security-analyzer.spec.js +151 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/__tests__/stability-analyzer.spec.js +143 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/maintainability-analyzer.js +100 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/performance-analyzer.js +109 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/security-analyzer.js +104 -0
- package/scripts/hooks-system/infrastructure/severity/analyzers/stability-analyzer.js +85 -0
- package/scripts/hooks-system/infrastructure/severity/context/analyzers/CodeClassificationAnalyzer.js +71 -0
- package/scripts/hooks-system/infrastructure/severity/context/analyzers/DataAnalyzer.js +64 -0
- package/scripts/hooks-system/infrastructure/severity/context/analyzers/ImpactAnalyzer.js +68 -0
- package/scripts/hooks-system/infrastructure/severity/context/analyzers/SafetyAnalyzer.js +82 -0
- package/scripts/hooks-system/infrastructure/severity/context/context-builder.js +88 -0
- package/scripts/hooks-system/infrastructure/severity/generators/RecommendationGenerator.js +153 -0
- package/scripts/hooks-system/infrastructure/severity/mappers/SeverityMapper.js +10 -0
- package/scripts/hooks-system/infrastructure/severity/policies/gate-policies.js +136 -0
- package/scripts/hooks-system/infrastructure/severity/policies/severity-policies.json +206 -0
- package/scripts/hooks-system/infrastructure/severity/scorers/ContextMultiplier.js +49 -0
- package/scripts/hooks-system/infrastructure/severity/severity-evaluator.js +117 -0
- package/scripts/hooks-system/infrastructure/shell/core/constants.sh +26 -0
- package/scripts/hooks-system/infrastructure/shell/core/utils.sh +45 -0
- package/scripts/hooks-system/infrastructure/shell/gitflow/git-wrapper.sh +646 -0
- package/scripts/hooks-system/infrastructure/shell/gitflow/gitflow-enforcer.sh +620 -0
- package/scripts/hooks-system/infrastructure/shell/gitflow/gitflow-state-manager.sh +235 -0
- package/scripts/hooks-system/infrastructure/shell/gitflow-state-manager.sh +225 -0
- package/scripts/hooks-system/infrastructure/shell/orchestrators/audit-orchestrator.sh +1106 -0
- package/scripts/hooks-system/infrastructure/shell/security/detect-secrets.sh +26 -0
- package/scripts/hooks-system/infrastructure/shell/security/detect_secrets.py +182 -0
- package/scripts/hooks-system/infrastructure/shell/validate-clean-architecture.sh +254 -0
- package/scripts/hooks-system/infrastructure/shell/validators/check-doc-structure.sh +62 -0
- package/scripts/hooks-system/infrastructure/shell/validators/ensure-critical-docs.sh +26 -0
- package/scripts/hooks-system/infrastructure/shell/validators/validate-ai-protocol.sh +474 -0
- package/scripts/hooks-system/infrastructure/shell/validators/validate-clean-architecture.sh +303 -0
- package/scripts/hooks-system/infrastructure/shell/validators/validate-conventional-commit.sh +42 -0
- package/scripts/hooks-system/infrastructure/storage/file-operations.sh +31 -0
- package/scripts/hooks-system/infrastructure/telemetry/TelemetryService.js +165 -0
- package/scripts/hooks-system/infrastructure/telemetry/__tests__/telemetry.spec.js +15 -0
- package/scripts/hooks-system/infrastructure/telemetry/metrics-logger.js +66 -0
- package/scripts/hooks-system/infrastructure/telemetry/metrics-server.js +61 -0
- package/scripts/hooks-system/infrastructure/utils/__tests__/utils.spec.js +8 -0
- package/scripts/hooks-system/infrastructure/utils/error-utils.js +28 -0
- package/scripts/hooks-system/infrastructure/utils/timestamp-helper.sh +106 -0
- package/scripts/hooks-system/infrastructure/utils/token-manager.js +121 -0
- package/scripts/hooks-system/infrastructure/validators/__tests__/detect-commit-language.spec.js +16 -0
- package/scripts/hooks-system/infrastructure/validators/__tests__/enforce-english-literals.spec.js +67 -0
- package/scripts/hooks-system/infrastructure/validators/detect-commit-language.js +145 -0
- package/scripts/hooks-system/infrastructure/validators/enforce-english-literals.js +202 -0
- package/scripts/hooks-system/infrastructure/watchdog/__tests__/.audit-reports/token-monitor.log +18 -0
- package/scripts/hooks-system/infrastructure/watchdog/__tests__/auto-recovery.spec.js +14 -0
- package/scripts/hooks-system/infrastructure/watchdog/__tests__/token-monitor.spec.js +67 -0
- package/scripts/hooks-system/infrastructure/watchdog/__tests__/watchdog.spec.js +22 -0
- package/scripts/hooks-system/infrastructure/watchdog/ai-watchdog.sh +278 -0
- package/scripts/hooks-system/infrastructure/watchdog/auto-recovery.js +32 -0
- package/scripts/hooks-system/infrastructure/watchdog/health-check.js +58 -0
- package/scripts/hooks-system/infrastructure/watchdog/token-monitor-loop.sh +20 -0
- package/scripts/hooks-system/infrastructure/watchdog/token-monitor.js +69 -0
- package/scripts/hooks-system/infrastructure/watchdog/token-tracker.sh +208 -0
- package/scripts/hooks-system/presentation/cli/audit.sh +32 -0
- package/scripts/hooks-system/presentation/cli/autonomous-status.sh +92 -0
- package/scripts/hooks-system/presentation/cli/categorize-violations.sh +179 -0
- package/scripts/hooks-system/presentation/cli/direct-audit-option2.sh +23 -0
- package/scripts/hooks-system/presentation/cli/direct-audit.sh +33 -0
- package/skills/android-guidelines/SKILL.md +475 -0
- package/skills/android-guidelines/resources/advanced-topics.md +44 -0
- package/skills/android-guidelines/resources/architecture-overview.md +44 -0
- package/skills/backend-guidelines/SKILL.md +335 -0
- package/skills/backend-guidelines/resources/architecture-overview.md +48 -0
- package/skills/frontend-guidelines/SKILL.md +367 -0
- package/skills/frontend-guidelines/resources/architecture-overview.md +44 -0
- package/skills/ios-guidelines/SKILL.md +406 -0
- package/skills/ios-guidelines/resources/architecture-overview.md +47 -0
- package/skills/skill-rules.json +334 -0
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
const path = require('path');
|
|
2
|
+
const { spawnSync } = require('child_process');
|
|
3
|
+
|
|
4
|
+
class GuardProcessManager {
|
|
5
|
+
constructor({
|
|
6
|
+
repoRoot = process.cwd(),
|
|
7
|
+
logger = console,
|
|
8
|
+
fsModule = require('fs'),
|
|
9
|
+
childProcess = { spawnSync }
|
|
10
|
+
} = {}) {
|
|
11
|
+
this.repoRoot = repoRoot;
|
|
12
|
+
this.logger = logger;
|
|
13
|
+
this.fs = fsModule;
|
|
14
|
+
this.childProcess = childProcess;
|
|
15
|
+
|
|
16
|
+
this.supervisorPidFile = path.join(this.repoRoot, '.guard-supervisor.pid');
|
|
17
|
+
this.startScript = path.join(this.repoRoot, 'bin', 'start-guards.sh');
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
isSupervisorRunning() {
|
|
21
|
+
const pid = this.readSupervisorPid();
|
|
22
|
+
return pid ? this.isProcessAlive(pid) : false;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
readSupervisorPid() {
|
|
26
|
+
if (!this.fs.existsSync(this.supervisorPidFile)) {
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
try {
|
|
30
|
+
const raw = this.fs.readFileSync(this.supervisorPidFile, 'utf8').trim();
|
|
31
|
+
if (!raw) {
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
const pid = Number(raw);
|
|
35
|
+
return Number.isFinite(pid) ? pid : null;
|
|
36
|
+
} catch (error) {
|
|
37
|
+
if (this.logger?.debug) {
|
|
38
|
+
this.logger.debug('GUARD_PROCESS_PID_READ_ERROR', { error: error.message });
|
|
39
|
+
}
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
isProcessAlive(pid) {
|
|
45
|
+
if (!pid) {
|
|
46
|
+
return false;
|
|
47
|
+
}
|
|
48
|
+
try {
|
|
49
|
+
process.kill(pid, 0);
|
|
50
|
+
return true;
|
|
51
|
+
} catch (error) {
|
|
52
|
+
// process.kill throws if process doesn't exist (ESRCH) or no permission (EPERM)
|
|
53
|
+
if (error.code !== 'ESRCH' && this.logger?.debug) {
|
|
54
|
+
this.logger.debug('GUARD_PROCESS_CHECK_ERROR', { pid, error: error.message });
|
|
55
|
+
}
|
|
56
|
+
return false;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
startSupervisor() {
|
|
61
|
+
try {
|
|
62
|
+
const result = this.childProcess.spawnSync(this.startScript, ['start'], {
|
|
63
|
+
cwd: this.repoRoot,
|
|
64
|
+
stdio: 'pipe'
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
const stdout = (result.stdout || '').toString().trim();
|
|
68
|
+
const stderr = (result.stderr || '').toString().trim();
|
|
69
|
+
|
|
70
|
+
return {
|
|
71
|
+
success: !result.error,
|
|
72
|
+
error: result.error,
|
|
73
|
+
stdout,
|
|
74
|
+
stderr
|
|
75
|
+
};
|
|
76
|
+
} catch (error) {
|
|
77
|
+
return {
|
|
78
|
+
success: false,
|
|
79
|
+
error,
|
|
80
|
+
stdout: '',
|
|
81
|
+
stderr: error.message
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
stopSupervisor() {
|
|
87
|
+
try {
|
|
88
|
+
const result = this.childProcess.spawnSync(this.startScript, ['stop'], {
|
|
89
|
+
cwd: this.repoRoot,
|
|
90
|
+
stdio: 'pipe'
|
|
91
|
+
});
|
|
92
|
+
|
|
93
|
+
const stdout = (result.stdout || '').toString().trim();
|
|
94
|
+
const stderr = (result.stderr || '').toString().trim();
|
|
95
|
+
|
|
96
|
+
return {
|
|
97
|
+
success: !result.error,
|
|
98
|
+
error: result.error,
|
|
99
|
+
stdout,
|
|
100
|
+
stderr
|
|
101
|
+
};
|
|
102
|
+
} catch (error) {
|
|
103
|
+
return {
|
|
104
|
+
success: false,
|
|
105
|
+
error,
|
|
106
|
+
stdout: '',
|
|
107
|
+
stderr: error.message
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
module.exports = GuardProcessManager;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
class GuardRecoveryService {
|
|
2
|
+
constructor({
|
|
3
|
+
repoRoot,
|
|
4
|
+
logger,
|
|
5
|
+
startScript,
|
|
6
|
+
notificationHandler,
|
|
7
|
+
restartCooldownMs = 2000
|
|
8
|
+
}) {
|
|
9
|
+
this.repoRoot = repoRoot;
|
|
10
|
+
this.logger = logger;
|
|
11
|
+
this.startScript = startScript;
|
|
12
|
+
this.notificationHandler = notificationHandler;
|
|
13
|
+
this.restartCooldownMs = restartCooldownMs;
|
|
14
|
+
this.lastEnsure = 0;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
ensureSupervisor(reason, eventLogger) {
|
|
18
|
+
const now = Date.now();
|
|
19
|
+
if (now - this.lastEnsure < this.restartCooldownMs) {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
this.lastEnsure = now;
|
|
23
|
+
|
|
24
|
+
const normalizedReason = reason || 'unknown';
|
|
25
|
+
const severity = this._determineSeverity(normalizedReason);
|
|
26
|
+
|
|
27
|
+
eventLogger.recordEvent(`Asegurando guard-supervisor (motivo: ${normalizedReason}).`);
|
|
28
|
+
|
|
29
|
+
const result = this._startSupervisor();
|
|
30
|
+
|
|
31
|
+
if (!result.success) {
|
|
32
|
+
eventLogger.log(`Failed to start supervisor (${reason}): ${result.stderr}`);
|
|
33
|
+
this._notifyUser(`Fallo al reiniciar guard-supervisor (${normalizedReason}).`, 'error', {
|
|
34
|
+
reason: `${normalizedReason}-failed`
|
|
35
|
+
});
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
if (result.stdout) eventLogger.log(`[start stdout] ${result.stdout}`);
|
|
40
|
+
if (result.stderr) eventLogger.log(`[start stderr] ${result.stderr}`);
|
|
41
|
+
|
|
42
|
+
eventLogger.log(`Supervisor ensured (${reason})`);
|
|
43
|
+
this._notifyUser(
|
|
44
|
+
normalizedReason === 'initial-start'
|
|
45
|
+
? 'Guard-supervisor operativo.'
|
|
46
|
+
: `Guard-supervisor reiniciado (${normalizedReason}).`,
|
|
47
|
+
severity,
|
|
48
|
+
{ reason: normalizedReason }
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
return true;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
_startSupervisor() {
|
|
55
|
+
try {
|
|
56
|
+
const result = require('child_process').spawnSync(this.startScript, ['start'], {
|
|
57
|
+
cwd: this.repoRoot,
|
|
58
|
+
stdio: 'pipe'
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
return {
|
|
62
|
+
success: !result.error && result.status === 0,
|
|
63
|
+
error: result.error,
|
|
64
|
+
stdout: (result.stdout || '').toString().trim(),
|
|
65
|
+
stderr: (result.stderr || '').toString().trim()
|
|
66
|
+
};
|
|
67
|
+
} catch (error) {
|
|
68
|
+
return {
|
|
69
|
+
success: false,
|
|
70
|
+
error,
|
|
71
|
+
stdout: '',
|
|
72
|
+
stderr: error.message
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
_determineSeverity(reason) {
|
|
78
|
+
if (reason === 'missing-supervisor') return 'error';
|
|
79
|
+
if (reason.startsWith('heartbeat-')) return 'warn';
|
|
80
|
+
return 'info';
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
_notifyUser(message, level, options) {
|
|
84
|
+
if (this.notificationHandler) {
|
|
85
|
+
this.notificationHandler.notify(message, level, options);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
module.exports = GuardRecoveryService;
|
package/scripts/hooks-system/application/services/guard/__tests__/GuardAutoManagerService.spec.js
ADDED
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
const path = require('path');
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
|
|
4
|
+
const { GuardAutoManagerService } = require('../GuardAutoManagerService');
|
|
5
|
+
|
|
6
|
+
describe('GuardAutoManagerService', () => {
|
|
7
|
+
const repoRoot = fs.mkdtempSync(path.join(require('os').tmpdir(), 'guard-auto-'));
|
|
8
|
+
|
|
9
|
+
afterAll(() => {
|
|
10
|
+
fs.rmSync(repoRoot, { recursive: true, force: true });
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
const createService = (overrides = {}) => {
|
|
14
|
+
const logs = [];
|
|
15
|
+
const logger = {
|
|
16
|
+
info: (msg, data) => logs.push({ level: 'info', msg, data }),
|
|
17
|
+
warn: (msg, data) => logs.push({ level: 'warn', msg, data }),
|
|
18
|
+
error: (msg, data) => logs.push({ level: 'error', msg, data })
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
const enqueue = jest.fn();
|
|
22
|
+
const timers = {
|
|
23
|
+
setInterval: jest.fn((fn) => {
|
|
24
|
+
timers.cb = fn;
|
|
25
|
+
return Symbol('interval');
|
|
26
|
+
}),
|
|
27
|
+
clearInterval: jest.fn()
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
const fsModule = {
|
|
31
|
+
...(overrides.fsModule || fs),
|
|
32
|
+
mkdirSync: jest.fn(),
|
|
33
|
+
appendFileSync: jest.fn(),
|
|
34
|
+
writeFileSync: jest.fn(),
|
|
35
|
+
readFileSync: jest.fn(),
|
|
36
|
+
rmdirSync: jest.fn(),
|
|
37
|
+
unlinkSync: jest.fn(),
|
|
38
|
+
existsSync: jest.fn().mockReturnValue(false)
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
const spawnSync = jest.fn(() => ({ stdout: Buffer.from('ok'), stderr: Buffer.from('') }));
|
|
42
|
+
|
|
43
|
+
const service = new GuardAutoManagerService({
|
|
44
|
+
repoRoot,
|
|
45
|
+
logger,
|
|
46
|
+
notificationCenter: { enqueue },
|
|
47
|
+
fsModule,
|
|
48
|
+
childProcess: { spawnSync },
|
|
49
|
+
timers,
|
|
50
|
+
processRef: { on: jest.fn() }
|
|
51
|
+
});
|
|
52
|
+
service.__test = { logs, enqueue, timers, fsModule, spawnSync };
|
|
53
|
+
return service;
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
it('starts service and schedules monitor loop', () => {
|
|
57
|
+
const service = createService();
|
|
58
|
+
|
|
59
|
+
const started = service.start();
|
|
60
|
+
|
|
61
|
+
expect(started).toBe(true);
|
|
62
|
+
expect(service.__test.timers.setInterval).toHaveBeenCalled();
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
it('enqueues notifications via notification center', () => {
|
|
66
|
+
const service = createService();
|
|
67
|
+
service.start();
|
|
68
|
+
service.notifyUser('Guard-supervisor operativo.', 'info', { reason: 'test', cooldownMs: 0 });
|
|
69
|
+
|
|
70
|
+
expect(service.__test.enqueue).toHaveBeenCalledWith({
|
|
71
|
+
message: 'Guard-supervisor operativo.',
|
|
72
|
+
level: 'info',
|
|
73
|
+
type: 'guard_auto_manager_test',
|
|
74
|
+
metadata: { reason: 'test', cooldownMs: 0 }
|
|
75
|
+
});
|
|
76
|
+
});
|
|
77
|
+
});
|
package/scripts/hooks-system/application/services/installation/ConfigurationGeneratorService.js
ADDED
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
const fs = require('fs');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
|
|
4
|
+
const COLORS = {
|
|
5
|
+
reset: '\x1b[0m',
|
|
6
|
+
green: '\x1b[32m',
|
|
7
|
+
blue: '\x1b[34m',
|
|
8
|
+
yellow: '\x1b[33m'
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
class ConfigurationGeneratorService {
|
|
12
|
+
constructor(targetRoot, hookSystemRoot) {
|
|
13
|
+
this.targetRoot = targetRoot || process.cwd();
|
|
14
|
+
this.hookSystemRoot = hookSystemRoot;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
createProjectConfig(platforms) {
|
|
18
|
+
const config = {
|
|
19
|
+
version: '3.1.0',
|
|
20
|
+
project: {
|
|
21
|
+
name: path.basename(this.targetRoot),
|
|
22
|
+
platforms: platforms,
|
|
23
|
+
created: new Date().toISOString()
|
|
24
|
+
},
|
|
25
|
+
architecture: {
|
|
26
|
+
pattern: 'FEATURE_FIRST_CLEAN_DDD',
|
|
27
|
+
strictMode: true,
|
|
28
|
+
enforcement: 'strict'
|
|
29
|
+
},
|
|
30
|
+
rules: {
|
|
31
|
+
enabled: true,
|
|
32
|
+
platforms: {}
|
|
33
|
+
},
|
|
34
|
+
commitGating: {
|
|
35
|
+
mode: 'strict',
|
|
36
|
+
blockOn: ['critical', 'high'],
|
|
37
|
+
stagingAreaOnly: true
|
|
38
|
+
},
|
|
39
|
+
bypass: {
|
|
40
|
+
enabled: true,
|
|
41
|
+
envVar: 'GIT_BYPASS_HOOK'
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
platforms.forEach(platform => {
|
|
46
|
+
config.rules.platforms[platform] = {
|
|
47
|
+
enabled: true,
|
|
48
|
+
customRulesPath: null
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
if (platform === 'ios') {
|
|
52
|
+
config.architecture.ios = {
|
|
53
|
+
architecturePattern: 'FEATURE_FIRST_CLEAN_DDD',
|
|
54
|
+
allowedPatterns: ['FEATURE_FIRST_CLEAN_DDD', 'MVVM-C'],
|
|
55
|
+
prohibitedPatterns: ['MVC'],
|
|
56
|
+
documentation: 'docs/ARCHITECTURE.md'
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
if (platform === 'android') {
|
|
61
|
+
config.architecture.android = {
|
|
62
|
+
strictKotlin: true,
|
|
63
|
+
composeOnly: true,
|
|
64
|
+
hiltRequired: true
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
const configPath = path.join(this.targetRoot, 'scripts/hooks-system/config/project.config.json');
|
|
70
|
+
// Ensure dir exists just in case
|
|
71
|
+
const configDir = path.dirname(configPath);
|
|
72
|
+
if (!fs.existsSync(configDir)) fs.mkdirSync(configDir, { recursive: true });
|
|
73
|
+
|
|
74
|
+
fs.writeFileSync(configPath, JSON.stringify(config, null, 2));
|
|
75
|
+
this.logSuccess('Configuration created');
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
installESLintConfigs() {
|
|
79
|
+
const templatesDir = path.join(this.hookSystemRoot, 'infrastructure/external-tools/eslint');
|
|
80
|
+
const backendDir = path.join(this.targetRoot, 'apps/backend');
|
|
81
|
+
|
|
82
|
+
if (fs.existsSync(backendDir)) {
|
|
83
|
+
const templatePath = path.join(templatesDir, 'backend.config.template.mjs');
|
|
84
|
+
const targetPath = path.join(backendDir, 'eslint.config.mjs');
|
|
85
|
+
|
|
86
|
+
if (fs.existsSync(templatePath)) {
|
|
87
|
+
fs.copyFileSync(templatePath, targetPath);
|
|
88
|
+
this.logSuccess('Created apps/backend/eslint.config.mjs');
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
addNpmScripts() {
|
|
94
|
+
const projectPackageJsonPath = path.join(this.targetRoot, 'package.json');
|
|
95
|
+
|
|
96
|
+
if (!fs.existsSync(projectPackageJsonPath)) {
|
|
97
|
+
this.logWarning('package.json not found, skipping npm scripts');
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
try {
|
|
102
|
+
const packageJson = JSON.parse(fs.readFileSync(projectPackageJsonPath, 'utf8'));
|
|
103
|
+
|
|
104
|
+
if (!packageJson.scripts) {
|
|
105
|
+
packageJson.scripts = {};
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// Add helper scripts
|
|
109
|
+
packageJson.scripts['ast:refresh'] = 'node scripts/hooks-system/bin/update-evidence.sh';
|
|
110
|
+
packageJson.scripts['ast:audit'] = 'node scripts/hooks-system/infrastructure/ast/ast-intelligence.js';
|
|
111
|
+
|
|
112
|
+
fs.writeFileSync(projectPackageJsonPath, JSON.stringify(packageJson, null, 2));
|
|
113
|
+
this.logSuccess('npm scripts added');
|
|
114
|
+
} catch (error) {
|
|
115
|
+
this.logWarning(`Failed to update package.json: ${error.message}`);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
logSuccess(msg) { process.stdout.write(`${COLORS.green}✓ ${msg}${COLORS.reset}\n`); }
|
|
120
|
+
logWarning(msg) { process.stdout.write(`${COLORS.yellow}⚠️ ${msg}${COLORS.reset}\n`); }
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
module.exports = ConfigurationGeneratorService;
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
const fs = require('fs');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
|
|
4
|
+
const COLORS = {
|
|
5
|
+
reset: '\x1b[0m',
|
|
6
|
+
green: '\x1b[32m',
|
|
7
|
+
cyan: '\x1b[36m'
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
class FileSystemInstallerService {
|
|
11
|
+
constructor(targetRoot, hookSystemRoot, logger = null) {
|
|
12
|
+
this.targetRoot = targetRoot || process.cwd();
|
|
13
|
+
this.hookSystemRoot = hookSystemRoot;
|
|
14
|
+
this.logger = logger;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
createDirectoryStructure() {
|
|
18
|
+
const dirs = [
|
|
19
|
+
'scripts/hooks-system',
|
|
20
|
+
'scripts/hooks-system/docs',
|
|
21
|
+
'scripts/hooks-system/config'
|
|
22
|
+
];
|
|
23
|
+
|
|
24
|
+
dirs.forEach(dir => {
|
|
25
|
+
const fullPath = path.join(this.targetRoot, dir);
|
|
26
|
+
if (!fs.existsSync(fullPath)) {
|
|
27
|
+
fs.mkdirSync(fullPath, { recursive: true });
|
|
28
|
+
if (this.logger) this.logger.debug('DIR_CREATED', { path: fullPath });
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
this.logSuccess('Directory structure created');
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
copySystemFiles() {
|
|
35
|
+
const itemsToCopy = [
|
|
36
|
+
'domain/',
|
|
37
|
+
'application/',
|
|
38
|
+
'infrastructure/',
|
|
39
|
+
'presentation/',
|
|
40
|
+
'docs/examples/',
|
|
41
|
+
'docs/guides/',
|
|
42
|
+
'bin/',
|
|
43
|
+
'index.js'
|
|
44
|
+
];
|
|
45
|
+
|
|
46
|
+
itemsToCopy.forEach(item => {
|
|
47
|
+
const source = path.join(this.hookSystemRoot, item);
|
|
48
|
+
const dest = path.join(this.targetRoot, 'scripts/hooks-system', item);
|
|
49
|
+
|
|
50
|
+
if (fs.existsSync(source)) {
|
|
51
|
+
if (item === 'infrastructure/') {
|
|
52
|
+
this.copyRecursiveExcluding(source, dest, ['scripts']);
|
|
53
|
+
} else {
|
|
54
|
+
this.copyRecursive(source, dest);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
this.logSuccess('System files copied');
|
|
59
|
+
if (this.logger) this.logger.info('SYSTEM_FILES_COPIED');
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
copyManageLibraryScript() {
|
|
63
|
+
// Assuming hookSystemRoot is .../scripts/hooks-system or .../node_modules/@package/
|
|
64
|
+
// We need to go up to the root of the library package
|
|
65
|
+
const libraryRoot = path.resolve(this.hookSystemRoot, '..');
|
|
66
|
+
const source = path.join(libraryRoot, 'manage-library.sh');
|
|
67
|
+
const dest = path.join(this.targetRoot, 'manage-library.sh');
|
|
68
|
+
|
|
69
|
+
if (fs.existsSync(source) && !fs.existsSync(dest)) {
|
|
70
|
+
fs.copyFileSync(source, dest);
|
|
71
|
+
fs.chmodSync(dest, '755');
|
|
72
|
+
this.logSuccess('Copied manage-library.sh to project root');
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
copyRecursive(source, dest) {
|
|
77
|
+
if (fs.statSync(source).isDirectory()) {
|
|
78
|
+
if (!fs.existsSync(dest)) {
|
|
79
|
+
fs.mkdirSync(dest, { recursive: true });
|
|
80
|
+
}
|
|
81
|
+
fs.readdirSync(source).forEach(file => {
|
|
82
|
+
this.copyRecursive(path.join(source, file), path.join(dest, file));
|
|
83
|
+
});
|
|
84
|
+
} else {
|
|
85
|
+
fs.copyFileSync(source, dest);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
copyRecursiveExcluding(source, dest, excludeDirs) {
|
|
90
|
+
if (fs.statSync(source).isDirectory()) {
|
|
91
|
+
if (!fs.existsSync(dest)) {
|
|
92
|
+
fs.mkdirSync(dest, { recursive: true });
|
|
93
|
+
}
|
|
94
|
+
fs.readdirSync(source).forEach(file => {
|
|
95
|
+
if (excludeDirs.includes(file)) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
this.copyRecursiveExcluding(
|
|
99
|
+
path.join(source, file),
|
|
100
|
+
path.join(dest, file),
|
|
101
|
+
excludeDirs
|
|
102
|
+
);
|
|
103
|
+
});
|
|
104
|
+
} else {
|
|
105
|
+
fs.copyFileSync(source, dest);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
logSuccess(msg) { process.stdout.write(`${COLORS.green}✓ ${msg}${COLORS.reset}\n`); }
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
module.exports = FileSystemInstallerService;
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
const fs = require('fs');
|
|
2
|
+
const path = require('path');
|
|
3
|
+
const { execSync, spawnSync } = require('child_process');
|
|
4
|
+
|
|
5
|
+
const COLORS = {
|
|
6
|
+
reset: '\x1b[0m',
|
|
7
|
+
blue: '\x1b[34m',
|
|
8
|
+
green: '\x1b[32m',
|
|
9
|
+
yellow: '\x1b[33m',
|
|
10
|
+
red: '\x1b[31m',
|
|
11
|
+
cyan: '\x1b[36m'
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
class GitEnvironmentService {
|
|
15
|
+
constructor(targetRoot) {
|
|
16
|
+
this.targetRoot = targetRoot || process.cwd();
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
checkGitRepository() {
|
|
20
|
+
const gitDir = path.join(this.targetRoot, '.git');
|
|
21
|
+
if (!fs.existsSync(gitDir)) {
|
|
22
|
+
this.logError('❌ CRITICAL: Git repository not found!');
|
|
23
|
+
this.logWarning(' This library REQUIRES a Git repository to function properly.');
|
|
24
|
+
this.logInfo(' Please run: git init\n');
|
|
25
|
+
this.logWarning('⚠️ Without Git:');
|
|
26
|
+
this.logInfo(' • Pre-commit hooks cannot be installed');
|
|
27
|
+
this.logInfo(' • Git Flow automation will not work');
|
|
28
|
+
this.logInfo(' • Code analysis on commits is disabled\n');
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
try {
|
|
33
|
+
execSync('git rev-parse --show-toplevel', {
|
|
34
|
+
cwd: this.targetRoot,
|
|
35
|
+
stdio: 'ignore'
|
|
36
|
+
});
|
|
37
|
+
return true;
|
|
38
|
+
} catch (err) {
|
|
39
|
+
this.logError('❌ Git repository is not properly initialized!');
|
|
40
|
+
this.logWarning(' Found .git directory but git commands fail.');
|
|
41
|
+
this.logInfo(' Please ensure Git is installed and working.\n');
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
ensureGitInfoExclude() {
|
|
47
|
+
const gitDir = path.join(this.targetRoot, '.git');
|
|
48
|
+
if (!fs.existsSync(gitDir)) return;
|
|
49
|
+
|
|
50
|
+
const excludePath = path.join(gitDir, 'info', 'exclude');
|
|
51
|
+
fs.mkdirSync(path.dirname(excludePath), { recursive: true });
|
|
52
|
+
|
|
53
|
+
const header = '# AST Intelligence Hooks (generated artifacts)';
|
|
54
|
+
const patterns = [
|
|
55
|
+
'.AI_TOKEN_STATUS.txt',
|
|
56
|
+
'.audit-reports/*.log',
|
|
57
|
+
'.realtime-guard.pid',
|
|
58
|
+
'.token-monitor-guard.pid'
|
|
59
|
+
];
|
|
60
|
+
|
|
61
|
+
let existing = '';
|
|
62
|
+
if (fs.existsSync(excludePath)) {
|
|
63
|
+
existing = fs.readFileSync(excludePath, 'utf8');
|
|
64
|
+
if (existing.includes(header)) return;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
const block = '\n' + header + '\n' + patterns.join('\n') + '\n';
|
|
68
|
+
fs.appendFileSync(excludePath, block);
|
|
69
|
+
this.logSuccess(' ✅ Added artifact patterns to .git/info/exclude');
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
installGitHooks() {
|
|
73
|
+
const gitHooksDir = path.join(this.targetRoot, '.git/hooks');
|
|
74
|
+
|
|
75
|
+
if (!fs.existsSync(gitHooksDir)) {
|
|
76
|
+
this.logError('✗ .git/hooks directory not found');
|
|
77
|
+
this.logWarning(' Git hooks cannot be installed without a valid Git repository.');
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const preCommitHook = this.getPreCommitHookContent();
|
|
82
|
+
const preCommitPath = path.join(gitHooksDir, 'pre-commit');
|
|
83
|
+
|
|
84
|
+
fs.writeFileSync(preCommitPath, preCommitHook);
|
|
85
|
+
fs.chmodSync(preCommitPath, '755');
|
|
86
|
+
this.logSuccess(' ✅ Installed pre-commit hook');
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
getPreCommitHookContent() {
|
|
90
|
+
return `#!/bin/bash
|
|
91
|
+
# AST Intelligence Hooks - Pre-commit
|
|
92
|
+
# Auto-generated by @pumuki/ast-intelligence-hooks v5.3.1
|
|
93
|
+
|
|
94
|
+
# Check for bypass
|
|
95
|
+
if [[ -n "\${GIT_BYPASS_HOOK}" ]]; then
|
|
96
|
+
echo "⚠️ Bypassing AST hooks (GIT_BYPASS_HOOK=1)"
|
|
97
|
+
exit 0
|
|
98
|
+
fi
|
|
99
|
+
|
|
100
|
+
# Change to project root (where package.json is)
|
|
101
|
+
cd "$(git rev-parse --show-toplevel)" || exit 1
|
|
102
|
+
|
|
103
|
+
# Check if there are staged files
|
|
104
|
+
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM 2>/dev/null | grep -E '\\.(ts|tsx|js|jsx|swift|kt)$' || true)
|
|
105
|
+
if [ -z "$STAGED_FILES" ]; then
|
|
106
|
+
# No staged files to analyze, allow commit
|
|
107
|
+
exit 0
|
|
108
|
+
fi
|
|
109
|
+
|
|
110
|
+
# Try node_modules/.bin first (works with npm install)
|
|
111
|
+
if [ -f "node_modules/.bin/ast-hooks" ]; then
|
|
112
|
+
OUTPUT=$(node_modules/.bin/ast-hooks ast 2>&1)
|
|
113
|
+
EXIT_CODE=$?
|
|
114
|
+
echo "$OUTPUT"
|
|
115
|
+
if [ $EXIT_CODE -ne 0 ]; then
|
|
116
|
+
exit $EXIT_CODE
|
|
117
|
+
fi
|
|
118
|
+
# Block commits only when there are actual CRITICAL/HIGH violations.
|
|
119
|
+
# Do NOT block on summary lines like: "CRITICAL=0 HIGH=0".
|
|
120
|
+
if echo "$OUTPUT" | grep -qE "CRITICAL=[1-9]|HIGH=[1-9]|\[CRITICAL\]|\[HIGH\]"; then
|
|
121
|
+
echo ""
|
|
122
|
+
echo "❌ Commit blocked: Critical or High violations detected in staged files"
|
|
123
|
+
|
|
124
|
+
# Extract counts (best-effort) for notification.
|
|
125
|
+
# Prefer explicit totals (CRITICAL=, HIGH=) and fallback to tag counts.
|
|
126
|
+
CRITICAL_COUNT=$(echo "$OUTPUT" | grep -oE "CRITICAL=[0-9]+" | head -1 | cut -d= -f2)
|
|
127
|
+
HIGH_COUNT=$(echo "$OUTPUT" | grep -oE "HIGH=[0-9]+" | head -1 | cut -d= -f2)
|
|
128
|
+
|
|
129
|
+
if [ -z "$CRITICAL_COUNT" ]; then
|
|
130
|
+
CRITICAL_COUNT=$(echo "$OUTPUT" | grep -oE "\[CRITICAL\]" | wc -l | tr -d ' ')
|
|
131
|
+
fi
|
|
132
|
+
if [ -z "$HIGH_COUNT" ]; then
|
|
133
|
+
HIGH_COUNT=$(echo "$OUTPUT" | grep -oE "\[HIGH\]" | wc -l | tr -d ' ')
|
|
134
|
+
fi
|
|
135
|
+
|
|
136
|
+
CRITICAL_COUNT=$(printf '%s' "$CRITICAL_COUNT" | tr -cd '0-9')
|
|
137
|
+
HIGH_COUNT=$(printf '%s' "$HIGH_COUNT" | tr -cd '0-9')
|
|
138
|
+
[ -z "$CRITICAL_COUNT" ] && CRITICAL_COUNT=0
|
|
139
|
+
[ -z "$HIGH_COUNT" ] && HIGH_COUNT=0
|
|
140
|
+
TOTAL_VIOLATIONS=$((CRITICAL_COUNT + HIGH_COUNT))
|
|
141
|
+
[ "$TOTAL_VIOLATIONS" -le 0 ] && TOTAL_VIOLATIONS=1
|
|
142
|
+
|
|
143
|
+
osascript -e "display notification \\"Commit blocked by violations\\" with title \\"🚫 Commit Blocked\\" sound name \\"Basso\\"" 2>/dev/null || true
|
|
144
|
+
|
|
145
|
+
exit 1
|
|
146
|
+
fi
|
|
147
|
+
# Copy ast-summary.json to root if it exists
|
|
148
|
+
if [ -f ".audit_tmp/ast-summary.json" ]; then
|
|
149
|
+
cp .audit_tmp/ast-summary.json ast-summary.json 2>/dev/null || true
|
|
150
|
+
fi
|
|
151
|
+
exit 0
|
|
152
|
+
fi
|
|
153
|
+
|
|
154
|
+
# Fallback: direct execution logic here...
|
|
155
|
+
echo "⚠️ ast-intelligence-hooks not found"
|
|
156
|
+
exit 0
|
|
157
|
+
`;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
logInfo(msg) { process.stdout.write(`${COLORS.cyan}${msg}${COLORS.reset}\n`); }
|
|
161
|
+
logSuccess(msg) { process.stdout.write(`${COLORS.green}${msg}${COLORS.reset}\n`); }
|
|
162
|
+
logWarning(msg) { process.stdout.write(`${COLORS.yellow}${msg}${COLORS.reset}\n`); }
|
|
163
|
+
logError(msg) { process.stdout.write(`${COLORS.red}${msg}${COLORS.reset}\n`); }
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
module.exports = GitEnvironmentService;
|